version 1.47.2.64, 2006/11/08 14:47:13
|
version 1.47.2.67, 2006/11/09 15:16:26
|
Line 170 class MPIWGLink(SimpleItem):
|
Line 170 class MPIWGLink(SimpleItem):
|
def index_html(self): |
def index_html(self): |
"""index""" |
"""index""" |
|
|
|
try: |
return self.getObj().pt_render(extra_context={'here':self}) |
return self.getObj().pt_render(extra_context={'here':self}) |
|
except: |
|
self.REQUEST.RESPONSE.redirect(self.getObj().absolute_url()) |
|
|
|
|
def manage_addMPIWGLinkForm(self): |
def manage_addMPIWGLinkForm(self): |
Line 282 def manage_addMPIWGTemplate(self, MPIWGT
|
Line 285 def manage_addMPIWGTemplate(self, MPIWGT
|
|
|
|
|
class MPIWGRoot(ZSQLExtendFolder): |
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', |
fieldLabels={'WEB_title':'WEB_Title','xdata_01':'Responsible Scientists','xdata_02':'Department', |
'xdata_03':'Historical Persons','xdata_04':'Time period', |
'xdata_03':'Historical Persons','xdata_04':'Time period', |
Line 642 class MPIWGRoot(ZSQLExtendFolder):
|
Line 645 class MPIWGRoot(ZSQLExtendFolder):
|
|
|
|
|
def getProjectsByFieldContent(self,fieldName,fieldContentsEntry, date=None): |
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): |
def sort(x,y): |
return cmp(x.WEB_title[0],y.WEB_title[0]) |
return cmp(x.WEB_title[0],y.WEB_title[0]) |
|
|
Line 1066 class MPIWGRoot(ZSQLExtendFolder):
|
Line 1069 class MPIWGRoot(ZSQLExtendFolder):
|
title=[project[0].getContent('WEB_title')] |
title=[project[0].getContent('WEB_title')] |
#print 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) |
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 |
if onlyActive and project[0].isActiveProject(): #nur active projekte |
returnList.append((depth,nr,title,project[0])) |
returnList.append((depth,nr,title,project[0])) |
elif not onlyActive: |
elif not onlyActive: |
Line 1251 class MPIWGRoot(ZSQLExtendFolder):
|
Line 1254 class MPIWGRoot(ZSQLExtendFolder):
|
return string.join(ret,";") |
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("<a href=%s >%s</a>"%(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): |
def getUrlFromPerson(self,list): |
"""get urls to person list""" |
"""get urls to person list""" |
ret=[] |
ret=[] |
Line 1476 class MPIWGRoot(ZSQLExtendFolder):
|
Line 1509 class MPIWGRoot(ZSQLExtendFolder):
|
results[id]=[] |
results[id]=[] |
objId=found.getObject().getId() |
objId=found.getObject().getId() |
if not (objId in results[id]): |
if not (objId in results[id]): |
print "added %s for %s"%(id,objId) |
print "d %s for %s"%(id,objId) |
results[id].append(objId) |
results[id].append(objId) |
self.nameIndex=results |
self.nameIndex=results |
return results |
return results |
Line 2008 class MPIWGProject(CatalogAware,Folder):
|
Line 2041 class MPIWGProject(CatalogAware,Folder):
|
|
|
|
|
def generateTemplate(self,RESPONSE=None): |
def generateTemplate(self,RESPONSE=None): |
"""Erzeuge Template für defined fields not_used""" |
"""Erzeuge Template fuer defined fields not_used""" |
|
|
id="index_html" |
id="index_html" |
title=id |
title=id |
Line 2100 class MPIWGProject(CatalogAware,Folder):
|
Line 2133 class MPIWGProject(CatalogAware,Folder):
|
return pt() |
return pt() |
|
|
def getGetNeighbourhood(self,wordStr, length=100,tagging=True): |
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 <span class="found">XX</span> getaggt, die Umgebungen werden |
alle Tags werden entfernt, die Fundstellen werden mit <span class="found">XX</span> getaggt, die Umgebungen werden |
case insensitive gesucht |
case insensitive gesucht |
@param wordStr: string mit Worten getrennt durch Leerzeichen, Phrasen sind mit " gekennzeichnet |
@param wordStr: string mit Worten getrennt durch Leerzeichen, Phrasen sind mit " gekennzeichnet |
"eine phrase", "*" bezeichnet wildcards und wird ignoriert" |
"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 |
@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 |
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): |
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 |
-1, wenn kein Treffer |
|
|
@param nr: Position die geprŸft werden soll |
@param nr: Position die geprueft werden soll |
@param length: LŠnge des Wortes das geprŸft werden soll |
@param length: Laenge des Wortes das geprueft werden soll |
""" |
""" |
for x in ranges: |
for x in ranges: |
if (x[0]<=nr) and (nr < (x[1]-length)): |
if (x[0]<=nr) and (nr < (x[1]-length)): |
Line 2158 class MPIWGProject(CatalogAware,Folder):
|
Line 2191 class MPIWGProject(CatalogAware,Folder):
|
|
|
#is word already in one of the results |
#is word already in one of the results |
nr=isInRanges(pos,len(word)) |
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) |
x=min(ranges[nr][0],x) |
y=max(ranges[nr][1],y) |
y=max(ranges[nr][1],y) |
|
|
Line 2168 class MPIWGProject(CatalogAware,Folder):
|
Line 2201 class MPIWGProject(CatalogAware,Folder):
|
ranges[nr]=(x,y) # neue Position der Umgebung |
ranges[nr]=(x,y) # neue Position der Umgebung |
|
|
ret[nr]=str # neue Umgebung |
ret[nr]=str # neue Umgebung |
else: # andernfalls neue Umgebung hinzufŸgen |
else: # andernfalls neue Umgebung hinzufuegen |
ranges.append((x,y)) |
ranges.append((x,y)) |
|
|
ret.append(str) |
ret.append(str) |
Line 2302 class MPIWGProject(CatalogAware,Folder):
|
Line 2335 class MPIWGProject(CatalogAware,Folder):
|
else: |
else: |
text5=text2 |
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]=='<p>') and (field=='WEB_project_description'): |
if (len(text5)>4) and (not text5[0:3]=='<p>') and (field=='WEB_project_description'): |
text5= "<p>"+text5+"</p>" |
text5= "<p>"+text5+"</p>" |
|
|
Line 2429 class MPIWGProject(CatalogAware,Folder):
|
Line 2462 class MPIWGProject(CatalogAware,Folder):
|
|
|
setattr(self,x,[self.REQUEST[x].decode('utf-8')]) |
setattr(self,x,[self.REQUEST[x].decode('utf-8')]) |
|
|
|
|
|
if self.REQUEST.has_key('historicalNames'): |
self.en.changeHistoricalNames(self.getId(),self.REQUEST['historicalNames'].split("\n")) |
self.en.changeHistoricalNames(self.getId(),self.REQUEST['historicalNames'].split("\n")) |
|
|
if self.REQUEST.has_key('active'): |
if self.REQUEST.has_key('active'): |