version 1.47.2.2, 2005/05/26 08:47:29
|
version 1.47.2.13, 2005/06/14 12:35:55
|
Line 168 class MPIWGRoot(ZSQLExtendFolder):
|
Line 168 class MPIWGRoot(ZSQLExtendFolder):
|
folders=['MPIWGProject','Folder','ECHO_Navigation'] |
folders=['MPIWGProject','Folder','ECHO_Navigation'] |
meta_type='MPIWGRoot' |
meta_type='MPIWGRoot' |
|
|
|
def getKategory(self,url): |
|
"""kategorie""" |
|
splitted=url.split("/") |
|
return splitted[4] |
|
|
|
def generateUrlProject(self,url,project=None): |
|
"""erzeuge aus absoluter url, relative des Projektes""" |
|
|
|
splitted=url.split("/") |
|
length=len(splitted) |
|
short=splitted[length-2:length] |
|
if project: |
|
base=self.REQUEST['URL3']+"/"+"/".join(short) |
|
else: |
|
base=self.REQUEST['URL1']+"/"+"/".join(short) |
|
return base |
|
|
def isNewCapital(self,text=None,reset=None): |
def isNewCapital(self,text=None,reset=None): |
if reset: |
if reset: |
self.REQUEST['capital']="A" |
self.REQUEST['capital']="A" |
Line 187 class MPIWGRoot(ZSQLExtendFolder):
|
Line 204 class MPIWGRoot(ZSQLExtendFolder):
|
return cmp(x1,y1) |
return cmp(x1,y1) |
if hasattr(self,id): |
if hasattr(self,id): |
subs=self.ZopeFind(getattr(self,id),obj_metatypes=['MPIWGTemplate']) |
subs=self.ZopeFind(getattr(self,id),obj_metatypes=['MPIWGTemplate']) |
subs.sort(sortWeight) |
subret=[] |
return subs |
for x in subs: |
|
if not(x[1].title==""): |
|
subret.append(x) |
|
subret.sort(sortWeight) |
|
return subret |
else: |
else: |
return None |
return None |
def isActive(self,name): |
def isActive(self,name): |
Line 397 class MPIWGRoot(ZSQLExtendFolder):
|
Line 418 class MPIWGRoot(ZSQLExtendFolder):
|
|
|
def getProjectsByFieldContent(self,fieldName,fieldContentsEntry): |
def getProjectsByFieldContent(self,fieldName,fieldContentsEntry): |
"""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 enthält ein Element der Liste fieldContents""" |
|
def sort(x,y): |
|
return cmp(x.WEB_title[0],y.WEB_title[0]) |
|
|
if type(fieldContentsEntry) is StringType: |
if type(fieldContentsEntry) is StringType: |
fieldContents=[fieldContentsEntry] |
fieldContentsTmp=[fieldContentsEntry] |
else: |
else: |
fieldContents=fieldContentsEntry |
fieldContentsTmp=fieldContentsEntry |
|
|
projects=self.ProjectCatalog({fieldName:string.join(fieldContents,' OR')}) |
fieldContents=[] |
|
for x in fieldContentsTmp: |
|
fieldContents.append(" AND ".join(x.split())) |
|
projects=self.ProjectCatalog({fieldName:string.join(fieldContents,' AND')}) |
#print projects |
#print projects |
return projects |
ret=[x for x in projects] |
|
ret.sort(sort) |
|
return ret |
|
|
def changeMPIWGRootForm(self): |
def changeMPIWGRootForm(self): |
"""edit""" |
"""edit""" |
Line 423 class MPIWGRoot(ZSQLExtendFolder):
|
Line 452 class MPIWGRoot(ZSQLExtendFolder):
|
|
|
def getDisciplineList(self): |
def getDisciplineList(self): |
"""get disciplines as list""" |
"""get disciplines as list""" |
return self.disciplineList.split("\n") |
list= self.disciplineList.split("\n") |
|
return [x.rstrip().lstrip() for x in list] |
|
|
def getThemeList(self): |
def getThemeList(self): |
"""get themes as list""" |
"""get themes as list""" |
return self.themesList.split("\n") |
list= self.themesList.split("\n") |
|
return [x.rstrip().lstrip() for x in list] |
|
|
def test(self): |
def test(self): |
"""test""" |
"""test""" |
Line 618 class MPIWGRoot(ZSQLExtendFolder):
|
Line 649 class MPIWGRoot(ZSQLExtendFolder):
|
#title=project[0].WEB_title |
#title=project[0].WEB_title |
title=[project[0].getContent('WEB_title')] |
title=[project[0].getContent('WEB_title')] |
#print title |
#print title |
|
if idNr[0]!="x": |
returnList.append((depth,nr,title,project[0])) |
returnList.append((depth,nr,title,project[0])) |
|
|
return returnList |
return returnList |
|
|
|
def formatElementsAsList(self,elements): |
|
"""formatiere tree als liste""" |
|
|
|
actualDepth=0 |
|
ret="" |
|
for element in elements: |
|
if (element[0]>actualDepth): |
|
#fuege soviele ul ein wie unterschied in tiefe |
|
if element[0]==1: |
|
ret+="""<div class="dept">\n<ul class="liste">\n""" |
|
else: |
|
for i in range(element[0]-actualDepth): |
|
if i>0: |
|
ret+="<li>" |
|
ret+="""<ul class="liste">\n""" |
|
|
|
actualDepth=element[0] |
|
|
|
elif (element[0]<actualDepth): |
|
#fuege soviele /ul ein wie unterschied in tiefe |
|
for i in range(-element[0]+actualDepth): |
|
|
|
ret+="<br><br></li></ul>\n" |
|
|
|
#ret+="<br><br>\n</li>\n</ul>\n</li>\n" |
|
|
|
|
|
if element[0]==1: |
|
department=int(element[3].getContent('xdata_05'))-1 |
|
|
|
ret+="""</ul></div>\n""" |
|
if department==4: #hack |
|
department=3 |
|
|
|
ret+="""<div class="bildspalte"><img src="../grafik/dept%i.jpg" width="160" height="120" vspace="40"></div> |
|
<div class="dept">\n<ul class="liste">\n |
|
"""%department |
|
|
|
actualDepth=element[0] |
|
else: |
|
ret+="""\n</li>\n""" |
|
ret+="""<li>\n""" |
|
|
|
if actualDepth==1: |
|
departmentName={'1':'Department I','2':'Department II','3':'Department III', '4':'Ind. Research Group','5':'Ind. Research Group'} |
|
department=element[3].getContent('xdata_05') |
|
ret+="""<a href="#top"><img src="../grafik/totop.gif" vspace="10" border="0"></a><br><a name="dept%s"></a>%s: """%(department,departmentName[department]) |
|
|
|
ret+="""<a href="%s">%s</a>"""%(self.generateUrlProject(element[3].absolute_url())+"/index.html",element[3].getContent('WEB_title')) |
|
return ret |
|
|
def formatElementForOverview(self,element): |
def formatElementForOverview(self,element): |
"""format the element for output in overview""" |
"""format the element for output in overview""" |
Line 1094 class MPIWGProject(CatalogAware,Folder):
|
Line 1176 class MPIWGProject(CatalogAware,Folder):
|
"""get attrbiute""" |
"""get attrbiute""" |
return getattr(self,field) |
return getattr(self,field) |
|
|
def getContent(self,field): |
def getContent(self,field,filter=None): |
"""Inhalt des Feldes""" |
"""Inhalt des Feldes""" |
|
|
text=u'' |
text=u'' |
Line 1126 class MPIWGProject(CatalogAware,Folder):
|
Line 1208 class MPIWGProject(CatalogAware,Folder):
|
if (text2=='') and (field=='WEB_project_header'): |
if (text2=='') and (field=='WEB_project_header'): |
return self.getContent('WEB_title') |
return self.getContent('WEB_title') |
|
|
|
if filter: |
|
splitted=text2.split("""<p class="picture">""") |
|
if len(splitted)>1: |
|
tmp=splitted[1].split("</p>") |
|
#return repr(splitted[1]) |
|
try: |
|
self.imageURL=tmp[0].split("\"")[1].encode('utf-8') |
|
except: |
|
self.imageURL=tmp[0].split("src=")[1].split(" ")[0].encode('utf-8') |
|
|
|
split2="</p>".join(tmp[1:]) |
|
|
|
text3=splitted[0]+split2 |
|
|
|
splitted=text3.split("""<p class="picturetitle">""") |
|
if len(splitted)>1: |
|
tmp=splitted[1].split("</p>") |
|
self.imagecap=tmp[0].encode('utf-8') |
|
|
|
split4="".join(tmp[1:]) |
|
|
|
text5=splitted[0]+split4 |
|
else: |
|
#keine caption |
|
text5=text3 |
|
else: |
|
#kein bild |
|
text5=text2 |
|
else: |
|
text5=text2 |
|
|
#teste ob WEB_project_description und keine führenden p tags |
#teste ob WEB_project_description und keine führenden p tags |
if (len(text2)>4) and (not text2[0:3]=='<p>') and (field=='WEB_project_description'): |
if (len(text5)>4) and (not text5[0:3]=='<p>') and (field=='WEB_project_description'): |
return "<p>"+text2+"</p>" |
text5= "<p>"+text5+"</p>" |
|
|
|
|
|
#filter image |
|
|
|
|
|
return text5.encode('utf-8') |
|
|
|
def showImagesOfPage(self,imageUrl=None): |
|
"""show Images of project""" |
|
self.getContent('WEB_project_description',filter='yes') #get the content and store image infos into session |
|
pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','projectImageView.zpt')).__of__(self) |
|
return pt() |
|
|
return text2.encode('utf-8') |
|
|
|
def show_html(self): |
def show_html(self): |
"""simple index""" |
"""simple index""" |
Line 1195 class MPIWGProject(CatalogAware,Folder):
|
Line 1318 class MPIWGProject(CatalogAware,Folder):
|
else: |
else: |
splitted=list[0].split(";") |
splitted=list[0].split(";") |
|
|
|
splitted=[y.rstrip().lstrip() for y in splitted] |
|
|
for x in splitted: |
for x in splitted: |
if (not x==u'') and x in wert: |
if (not x==u'') and x in wert: |