version 1.47.2.63, 2006/11/06 16:08:30
|
version 1.47.2.65, 2006/11/08 16:36:38
|
Line 2
|
Line 2
|
for organizing and maintaining the different project pages |
for organizing and maintaining the different project pages |
|
|
""" |
""" |
#TODO: mechanismus fur links to personen ueberarbeiten, da jetzt alle e_mails als members auftauchen unabhaengig vom status publish_the_data |
#TODO: mechanismus fur links to personen ueberarbeiten, da jetzt alle e_mails als members auftauchen unabhaenig vom status publish_the_data |
#TODO: was passiert wenn aenderungen von jochen im filemaker nicht mit den aenderungen im sql uebereinstimmen |
#TODO: was passiert wenn aenderungen von jochen im filemaker nicht mit den aenderungen im sql uebereinstimmen |
#TODO: in einzelnen projecte steht als pfad auf die bilder noch wwwneu statt www |
#TODO: in einzelnen projecte steht als pfad auf die bilder noch wwwneu statt www |
|
|
Line 33 from Ft.Xml.XPath import Evaluate
|
Line 33 from Ft.Xml.XPath import Evaluate
|
from Ft.Xml.XPath.Context import Context |
from Ft.Xml.XPath.Context import Context |
from Ft.Xml.Domlette import NonvalidatingReader,PrettyPrint, Print |
from Ft.Xml.Domlette import NonvalidatingReader,PrettyPrint, Print |
from Ft.Xml import EMPTY_NAMESPACE |
from Ft.Xml import EMPTY_NAMESPACE |
|
import copy |
|
|
definedFields=['WEB_title','xdata_01','xdata_02','xdata_03','xdata_04','xdata_05','xdata_06','xdata_07','xdata_08','xdata_09','xdata_10','xdata_11','xdata_12','xdata_13','WEB_project_header','WEB_project_description','WEB_related_pub'] |
definedFields=['WEB_title','xdata_01','xdata_02','xdata_03','xdata_04','xdata_05','xdata_06','xdata_07','xdata_08','xdata_09','xdata_10','xdata_11','xdata_12','xdata_13','WEB_project_header','WEB_project_description','WEB_related_pub'] |
|
|
Line 281 def manage_addMPIWGTemplate(self, MPIWGT
|
Line 282 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 638 class MPIWGRoot(ZSQLExtendFolder):
|
Line 639 class MPIWGRoot(ZSQLExtendFolder):
|
"""quote""" |
"""quote""" |
return urllib.unquote(str) |
return urllib.unquote(str) |
|
|
def harvestHistoricalPersons(self): |
|
"""erstelle liste aller erwaehnten actors""" |
|
|
|
def normalize(str): |
|
"""loesche fuhrendes space""" |
|
if (len(str)>1) and (str[0]==" "): |
|
ret=str[1:] |
|
else: |
|
ret=str |
|
return ret |
|
|
|
list={} |
|
projects=self.ZopeFind(self.projects,obj_metatypes=['MPIWGProject']) |
|
|
|
for project in projects: |
|
lg=len(project[1].xdata_03[0])-1 |
|
|
|
if (lg>1) and (project[1].xdata_03[0][lg]==";"): |
|
project[1].xdata_03[0]=project[1].xdata_03[0][0:lg] |
|
|
|
|
|
|
|
|
|
try: |
|
if len(project[1].xdata_03[0].split(";"))>1: # guess if separator is ; |
|
for person in project[1].xdata_03[0].split(";"): |
|
personNormal=normalize(person) |
|
if personNormal in list.keys(): |
|
list[urllib.quote(personNormal)][1].append(project[1]) |
|
else: |
|
list[urllib.quote(personNormal)]=(personNormal,[project[1]]) |
|
else: #guess , is sepeator |
|
for person in project[1].xdata_03[0].split(","): |
|
personNormal=normalize(person) |
|
if urllib.quote(personNormal) in list.keys(): |
|
list[urllib.quote(personNormal)][1].append(project[1]) |
|
else: |
|
list[urllib.quote(personNormal)]=(personNormal,[project[1]]) |
|
|
|
except: |
|
zLOG.LOG("MPIWG Web (harvestHistoricalPerson)",zLOG.ERROR,"cannot analyize: %s"%repr(project)) |
|
|
|
|
|
return list |
|
|
|
def storeHistoricalPersons(self,RESPONSE=None): |
|
"""store persons""" |
|
self.personDict={} |
|
personDict=self.harvestHistoricalPersons() |
|
for person in personDict.keys(): |
|
for project in personDict[person][1]: |
|
if person in self.personDict.keys(): |
|
self.personDict[person][1].append((project.absolute_url(),project.WEB_title[0],project.xdata_01[0])) |
|
else: |
|
self.personDict[person]=(personDict[person][0],[(project.absolute_url(),project.WEB_title[0],project.xdata_01[0])]) |
|
|
|
if RESPONSE is not None: |
|
RESPONSE.redirect("showHistoricalPersons") |
|
|
|
|
|
def getPersonDict(self,name): |
|
"""name von dict""" |
|
|
|
try: |
|
return self.personDict[name][0].encode('utf-8') |
|
except: |
|
return self.personDict[name][0] |
|
return self.personDict[name][0].decode('latin-1').encode('utf-8') |
|
|
|
|
|
def showHistoricalPersons(self): |
|
"""show persons""" |
|
pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','showHistoricalPersons')).__of__(self) |
|
return pt() |
|
|
|
|
|
def editHistoricalPersonsForm(self): |
|
"""edit historical persons for consistency""" |
|
pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','editHistoricalPersonsForm')).__of__(self) |
|
return pt() |
|
|
|
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 1144 class MPIWGRoot(ZSQLExtendFolder):
|
Line 1066 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 1329 class MPIWGRoot(ZSQLExtendFolder):
|
Line 1251 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 1559 class MPIWGRoot(ZSQLExtendFolder):
|
Line 1511 class MPIWGRoot(ZSQLExtendFolder):
|
self.nameIndex=results |
self.nameIndex=results |
return results |
return results |
|
|
|
def editNameIndexHTML(self): |
|
"""edit the name index""" |
|
if not hasattr(self,'nameIndexEdited'): # falls editierter index noch nicht existiert, kopiere automatisch erstellten |
|
self.nameIndexEdited=copy.copy(self.nameIndex) |
|
print "huh" |
|
#self.nameIndexEdited=copy.copy(self.nameIndex) |
|
#print self.nameIndexEdited |
|
pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','editHistoricalNames.zpt')).__of__(self) |
|
return pt() |
|
|
|
def getNamesInProject(self,projectId): |
|
"""get all names ofnameIndexEdited which are references in projec with projectId""" |
|
|
|
ret=[] |
|
for name in self.nameIndexEdited.keys(): |
|
if projectId in self.nameIndexEdited[name]: |
|
ret.append(name) |
|
|
|
return ret |
|
|
|
def editNameIndex(self,RESPONSE=None,name=None,occurrances=None,submit=None): |
|
"""edit the index""" |
|
nI=self.nameIndexEdited # mI introduced to make sure that changes to nameIndexEdited are know to ZODB |
|
if submit=="delete": |
|
|
|
|
|
dh=getattr(self,'deletedHistoricalNames',{}) |
|
if not dh.has_key(name): |
|
dh=occurrances.split("\n") |
|
else: |
|
dh+=occurrances.split("\n") |
|
|
|
self.deletedHistoricalNames=dh |
|
|
|
del self.nameIndexEdited[name] |
|
|
|
|
|
elif (submit=="change"): |
|
|
|
nI[name]=occurrances.split("\n")[0:] |
|
|
|
elif (submit=="add"): |
|
if not nI.has_key(name): |
|
nI[name]=occurrances.split("\n") |
|
else: |
|
nI[name]+=occurrances.split("\n") |
|
|
|
self.nameIndexEdited=nI |
|
|
|
|
|
if RESPONSE is not None: |
|
RESPONSE.redirect('editNameIndexHTML') |
|
|
|
|
|
|
|
def restoreIndex(self): |
|
"""restore""" |
|
self.nameIndexEdited=self.nameIndex |
|
return "done" |
|
|
|
def changeHistoricalNames(self,projId,nameListTmp): |
|
"""add resp change nameIndexEdited b |
|
y adding/changing names menitionen in project projId""" |
|
|
|
#clear namelist from blanks |
|
nameList=[x.lstrip().rstrip() for x in nameListTmp] |
|
|
|
nI=self.nameIndexEdited |
|
for name in nameList: |
|
if not nI.has_key(name): #neuer Name |
|
nI[name]=[projId] |
|
|
|
for name in nI.keys(): |
|
|
|
if name in nameList: #checke if name in name List |
|
|
|
if not(projId in nI[name]): #nicht in listt -> hinzufuegen |
|
|
|
nI[name].append(projId) |
|
|
|
"""loesche falls projekt in nI list aber der name nicht mehr |
|
in der namensliste des projectes auftaucht |
|
""" |
|
|
|
for pr in nI[name]: |
|
|
|
if (pr==projId) and (not name in nameList): |
|
|
|
nI[name].remove(pr) |
|
|
|
self.nameIndexEdited=nI |
|
|
|
|
|
|
def manage_addMPIWGRootForm(self): |
def manage_addMPIWGRootForm(self): |
"""form for adding the root""" |
"""form for adding the root""" |
pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','addMPIWGRootForm.zpt')).__of__(self) |
pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','addMPIWGRootForm.zpt')).__of__(self) |
Line 1992 class MPIWGProject(CatalogAware,Folder):
|
Line 2038 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 2084 class MPIWGProject(CatalogAware,Folder):
|
Line 2130 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 2142 class MPIWGProject(CatalogAware,Folder):
|
Line 2188 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 2152 class MPIWGProject(CatalogAware,Folder):
|
Line 2198 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 2286 class MPIWGProject(CatalogAware,Folder):
|
Line 2332 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 2413 class MPIWGProject(CatalogAware,Folder):
|
Line 2459 class MPIWGProject(CatalogAware,Folder):
|
|
|
setattr(self,x,[self.REQUEST[x].decode('utf-8')]) |
setattr(self,x,[self.REQUEST[x].decode('utf-8')]) |
|
|
|
self.en.changeHistoricalNames(self.getId(),self.REQUEST['historicalNames'].split("\n")) |
|
|
if self.REQUEST.has_key('active'): |
if self.REQUEST.has_key('active'): |
self.setActiveFlag(True) |
self.setActiveFlag(True) |
else: |
else: |