--- MPIWGWeb/MPIWGProjects.py 2006/11/08 14:47:13 1.47.2.64 +++ MPIWGWeb/MPIWGProjects.py 2006/11/08 16:36:38 1.47.2.65 @@ -282,7 +282,7 @@ def manage_addMPIWGTemplate(self, MPIWGT class MPIWGRoot(ZSQLExtendFolder): - """Stammordner für den Web-Server""" + """Stammordner fuer den Web-Server""" fieldLabels={'WEB_title':'WEB_Title','xdata_01':'Responsible Scientists','xdata_02':'Department', 'xdata_03':'Historical Persons','xdata_04':'Time period', @@ -642,7 +642,7 @@ class MPIWGRoot(ZSQLExtendFolder): def getProjectsByFieldContent(self,fieldName,fieldContentsEntry, date=None): - """gib alle Projekte aus mit Value von field mit fieldName enthält ein Element der Liste fieldContents""" + """gib alle Projekte aus mit Value von field mit fieldName enthaelt ein Element der Liste fieldContents""" def sort(x,y): return cmp(x.WEB_title[0],y.WEB_title[0]) @@ -1066,10 +1066,10 @@ class MPIWGRoot(ZSQLExtendFolder): title=[project[0].getContent('WEB_title')] #print title - if idNr[0]=="x": # kompatibilitŠt mit alter Konvention, x vor der Nummer macht project inactive + if idNr[0]=="x": # kompatibilitaet mit alter Konvention, x vor der Nummer macht project inactive project[0].setActiveFlag(False) - if (not dep) or (idNr[0]==dep): #falls dep gesetzt ist nur dieses hinzufŸgen. + if (not dep) or (idNr[0]==dep): #falls dep gesetzt ist nur dieses hinzufuegen. if onlyActive and project[0].isActiveProject(): #nur active projekte returnList.append((depth,nr,title,project[0])) elif not onlyActive: @@ -1251,6 +1251,36 @@ class MPIWGRoot(ZSQLExtendFolder): return string.join(ret,";") + def getMembersFromList(self,list): + """get member names from person full text list""" + memberlist=[] + persons=list.split(";") + for person in persons: + if len(person)>1: #nicht nur Trennzeichen + splitted=person.split(",") + if len(splitted)==1: + splitted=person.lstrip().rstrip().split(" ") + splittedNew=[re.sub(r'\s(.*)','$1',split) for split in splitted] + if splittedNew[0]=='': + del splittedNew[0] + search=string.join(splittedNew,' AND ') + + if not search=='': + try: + member=self.MembersCatalog({'title':search}) + except: + member=None + + if member and (member[0].getObject().isPublished()): + if person =="Otto Sibum" : person="H. Otto Sibum" + if person =="Norton Wise" : person="M. Norton Wise" + #memberlist.append("%s"%(member[0].absolute_url,person.encode('utf-8'))) + memberlist.append((person, member[0].getObject().getId())) + else: + #memberlist.append("%s"%person.encode('utf-8')) + memberlist.append((person,None)) + return memberlist + def getUrlFromPerson(self,list): """get urls to person list""" ret=[] @@ -1280,7 +1310,7 @@ class MPIWGRoot(ZSQLExtendFolder): if self.MPIWGrootURL().split("/")[-1]=='en': tmpPath="/en/staff/members/" else: - tmpPath="/de/mitarbeiter/members/" + tmpPath="/de/mitarbeiter/members/" ret.append("%s"%(tmpPath+proj[0].getObject().getId()+"/index.html",person)) else: #ret.append("%s"%person.encode('utf-8')) @@ -2008,7 +2038,7 @@ class MPIWGProject(CatalogAware,Folder): def generateTemplate(self,RESPONSE=None): - """Erzeuge Template für defined fields not_used""" + """Erzeuge Template fuer defined fields not_used""" id="index_html" title=id @@ -2100,24 +2130,24 @@ class MPIWGProject(CatalogAware,Folder): return pt() def getGetNeighbourhood(self,wordStr, length=100,tagging=True): - """finde umgebung um die worte in wordStr, zurŸckgegeben wird eine Array mit den Umgebungen von Fundstellen der Worte + """finde umgebung um die worte in wordStr, zurueckgegeben wird eine Array mit den Umgebungen von Fundstellen der Worte alle Tags werden entfernt, die Fundstellen werden mit XX getaggt, die Umgebungen werden case insensitive gesucht @param wordStr: string mit Worten getrennt durch Leerzeichen, Phrasen sind mit " gekennzeichnet "eine phrase", "*" bezeichnet wildcards und wird ignoriert" - @param length: optional, default wert 100, 2*length ist die grš§e der Umgebung + @param length: optional, default wert 100, 2*length ist die groesse der Umgebung @param tagging: optional default wert true, kein span tag wird erzweugt falls tag=false """ - ret=[] # nimmt das Array auf, dass spŠter zurŸckgegeben wird + ret=[] # nimmt das Array auf, dass spaeter zurueckgegeben wird ranges=[] #Array mit tupeln x,y wobei x die Position des Anfang und y des Endes der i-ten Umgebung angiebt def isInRanges(nr,length): - """test ob eine gegeben Position nr schon irgendwo in einer Umgebung ist, gibt den Index des ersten Wertes aus ranges zurŸck, + """test ob eine gegeben Position nr schon irgendwo in einer Umgebung ist, gibt den Index des ersten Wertes aus ranges zurueck, -1, wenn kein Treffer - @param nr: Position die geprŸft werden soll - @param length: LŠnge des Wortes das geprŸft werden soll + @param nr: Position die geprueft werden soll + @param length: Laenge des Wortes das geprueft werden soll """ for x in ranges: if (x[0]<=nr) and (nr < (x[1]-length)): @@ -2158,7 +2188,7 @@ class MPIWGProject(CatalogAware,Folder): #is word already in one of the results nr=isInRanges(pos,len(word)) - if nr >=0:# word ist in einer schon gefunden Umgebung, dann vergrš§ere diese + if nr >=0:# word ist in einer schon gefunden Umgebung, dann vergroessere diese x=min(ranges[nr][0],x) y=max(ranges[nr][1],y) @@ -2168,7 +2198,7 @@ class MPIWGProject(CatalogAware,Folder): ranges[nr]=(x,y) # neue Position der Umgebung ret[nr]=str # neue Umgebung - else: # andernfalls neue Umgebung hinzufŸgen + else: # andernfalls neue Umgebung hinzufuegen ranges.append((x,y)) ret.append(str) @@ -2302,7 +2332,7 @@ class MPIWGProject(CatalogAware,Folder): else: text5=text2 - #teste ob WEB_project_description und keine führenden p tags + #teste ob WEB_project_description und keine fuehrenden p tags if (len(text5)>4) and (not text5[0:3]=='

') and (field=='WEB_project_description'): text5= "

"+text5+"

"