version 1.47.2.64, 2006/11/08 14:47:13
|
version 1.47.2.70, 2007/03/23 14:16:48
|
Line 167 class MPIWGLink(SimpleItem):
|
Line 167 class MPIWGLink(SimpleItem):
|
if RESPONSE is not None: |
if RESPONSE is not None: |
RESPONSE.redirect('manage') |
RESPONSE.redirect('manage') |
|
|
def index_html(self): |
def index_html(self,**argv): |
"""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 288 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 295 class MPIWGRoot(ZSQLExtendFolder):
|
Line 301 class MPIWGRoot(ZSQLExtendFolder):
|
folders=['MPIWGProject','Folder','ECHO_Navigation'] |
folders=['MPIWGProject','Folder','ECHO_Navigation'] |
meta_type='MPIWGRoot' |
meta_type='MPIWGRoot' |
|
|
|
|
def harvestProjects(self): |
def harvestProjects(self): |
"""harvest""" |
"""harvest""" |
folder="/tmp" |
folder="/tmp" |
Line 642 class MPIWGRoot(ZSQLExtendFolder):
|
Line 649 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 1073 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 1258 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 1513 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 1508 class MPIWGRoot(ZSQLExtendFolder):
|
Line 1545 class MPIWGRoot(ZSQLExtendFolder):
|
|
|
|
|
dh=getattr(self,'deletedHistoricalNames',{}) |
dh=getattr(self,'deletedHistoricalNames',{}) |
|
|
|
if type(dh) is ListType: |
|
dh={} |
if not dh.has_key(name): |
if not dh.has_key(name): |
dh=occurrances.split("\n") |
dh[name]=occurrances.split("\n") |
else: |
else: |
dh+=occurrances.split("\n") |
dh[name]+=occurrances.split("\n") |
|
|
self.deletedHistoricalNames=dh |
self.deletedHistoricalNames=dh |
|
|
Line 1685 class MPIWGProject(CatalogAware,Folder):
|
Line 1725 class MPIWGProject(CatalogAware,Folder):
|
for split in splitted[1:]: |
for split in splitted[1:]: |
tmp=split.split("</p>") |
tmp=split.split("</p>") |
#return repr(splitted[1]) |
#return repr(splitted[1]) |
|
|
try: |
try: |
imageURLs.append(tmp[0].split("\"")[1].encode('utf-8')) |
imageURLs.append(tmp[0].split("\"")[1].encode('utf-8')) |
except: |
except: |
|
|
|
try: |
imageURLs.append(tmp[0].split("src=")[1].split(" ")[0].encode('utf-8')) |
imageURLs.append(tmp[0].split("src=")[1].split(" ")[0].encode('utf-8')) |
|
except: |
|
imageURLs.append("") |
|
|
split2="</p>".join(tmp[1:]) |
split2="</p>".join(tmp[1:]) |
|
|
Line 1838 class MPIWGProject(CatalogAware,Folder):
|
Line 1883 class MPIWGProject(CatalogAware,Folder):
|
|
|
def getImages(self): |
def getImages(self): |
"""get all Images""" |
"""get all Images""" |
|
|
def sort_images(x,y): |
def sort_images(x,y): |
return cmp(getattr(x[1],'place',0),getattr(y[1],'place',0)) |
return cmp(getattr(x[1],'place',0),getattr(y[1],'place',0)) |
|
|
|
|
|
if (getattr(self,'imageURL','')!='') or (getattr(self,'imagecap','')!='') : |
|
try: |
|
self.addImage(None,getattr(self,'imagecap',''),RESPONSE=None,filename=getattr(self,'imageURL','')) |
|
except: |
|
pass |
|
self.imageURL='' |
|
self.imagecap='' |
|
|
images=self.ZopeFind(self,obj_metatypes=['MPIWGProject_image']) |
images=self.ZopeFind(self,obj_metatypes=['MPIWGProject_image']) |
|
|
images.sort(sort_images) |
images.sort(sort_images) |
Line 1871 class MPIWGProject(CatalogAware,Folder):
|
Line 1926 class MPIWGProject(CatalogAware,Folder):
|
else: |
else: |
return False |
return False |
|
|
|
|
def addImage(self,fileHd,caption,RESPONSE=None,filename=None): |
def addImage(self,fileHd,caption,RESPONSE=None,filename=None): |
"""add an MPIWG_Project_image""" |
"""add an MPIWG_Project_image""" |
|
|
Line 1887 class MPIWGProject(CatalogAware,Folder):
|
Line 1943 class MPIWGProject(CatalogAware,Folder):
|
obj.caption=caption[0:] |
obj.caption=caption[0:] |
obj.enabled=True; |
obj.enabled=True; |
obj.place=self.getLastImageNumber()+1 |
obj.place=self.getLastImageNumber()+1 |
|
obj.id=filename |
|
|
if RESPONSE is not None: |
if RESPONSE is not None: |
RESPONSE.redirect('manageImages') |
RESPONSE.redirect('manageImages') |
Line 2008 class MPIWGProject(CatalogAware,Folder):
|
Line 2065 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 2157 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 2215 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 2225 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 2279 class MPIWGProject(CatalogAware,Folder):
|
Line 2336 class MPIWGProject(CatalogAware,Folder):
|
try: |
try: |
self.imageURL=tmp[0].split("\"")[1].encode('utf-8') |
self.imageURL=tmp[0].split("\"")[1].encode('utf-8') |
except: |
except: |
|
try: |
self.imageURL=tmp[0].split("src=")[1].split(" ")[0].encode('utf-8') |
self.imageURL=tmp[0].split("src=")[1].split(" ")[0].encode('utf-8') |
|
except: |
|
self.imageURL="" |
|
|
split2="</p>".join(tmp[1:]) |
split2="</p>".join(tmp[1:]) |
|
|
Line 2302 class MPIWGProject(CatalogAware,Folder):
|
Line 2362 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>" |
|
|
|
|
#filter image |
#filter image |
|
|
|
text5=text5.lstrip().rstrip() #loescher leerzeichen und einzelndes br |
|
if (text5=="<br>") or (text5=="<br/>"): |
|
text5="" |
|
|
return text5.encode('utf-8') |
return text5.encode('utf-8') |
|
|
Line 2429 class MPIWGProject(CatalogAware,Folder):
|
Line 2492 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'): |