Annotation of ECHO_content/ECHO_Nav.py, revision 1.53
1.1 dwinter 1: # Objekte zur Erzeugung von Navigationselementen
2:
1.11 dwinter 3: from Globals import DTMLFile
4: from OFS.Image import Image,cookId
1.1 dwinter 5: from OFS.Folder import Folder
6: from OFS.SimpleItem import SimpleItem
7: from Products.PageTemplates.PageTemplateFile import PageTemplateFile
8: from Products.PageTemplates.PageTemplate import PageTemplate
9: import re
10: import string
11: from Products.PageTemplates.ZopePageTemplate import ZopePageTemplate
12: import os.path
13: from Globals import package_home
14: import urllib
1.48 dwinter 15: from ECHO_helpers import *
1.23 dwinter 16: from ECHO_collection import content_html
1.48 dwinter 17: from types import *
1.35 dwinter 18:
19:
20: from Globals import DTMLFile
21: from OFS.Image import Image,cookId
22: from OFS.Folder import Folder
23: from OFS.SimpleItem import SimpleItem
24: from Products.PageTemplates.PageTemplateFile import PageTemplateFile
25: from Products.PageTemplates.PageTemplate import PageTemplate
26: import re
27: import string
28: from Products.PageTemplates.ZopePageTemplate import ZopePageTemplate
29: import os.path
30: from Globals import package_home
31: import urllib
32: from ECHO_helpers import displayTypes,checkOnlyOneInGroup
33: from ECHO_collection import content_html
1.50 dwinter 34: import zLOG
1.35 dwinter 35:
1.49 dwinter 36: try:
37: from Products.ZSQLExtend.ZSQLExtend import ZSQLExtendFolder
38: except:
39: zLOG.LOG('ECHO_Nav',zLOG.INFO,'ZSQLSimpleSearch not supported')
1.35 dwinter 40:
41:
42:
43: class ECHO_ZCatalogElement(SimpleItem):
44: """Erzeuge navigation aus ZCatalog-abfrage"""
45: meta_type="ECHO_ZCatalogElement"
46: baseUrl=""
47:
48: def __init__(self,id,title,field,catalogId,baseUrl,weight,contentType):
49: """init"""
50: self.id=id
51: self.title=title
52: self.catalogId=catalogId
53: self.field=field
54:
55: self.baseUrl=baseUrl
56: self.weight=weight
57: self.content=contentType
58:
1.48 dwinter 59:
1.35 dwinter 60: manage_options= SimpleItem.manage_options+(
61: {'label':'Main Config','action':'changeECHO_ZCatalogElementForm'},
62: )
63:
64:
65: def getWeight(self):
66: """get weight"""
67: if hasattr(self,'weight'):
68: return self.weight
69: else:
70: return 0
71:
72: def getcontentType(self):
73: """get weight"""
74:
75: if hasattr(self,'contentType'):
76: return self.contentType
77: else:
78: return 0
79:
80:
81: def changeECHO_ZCatalogElementForm(self):
82: """change"""
83:
1.48 dwinter 84: pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','changeECHO_ZCatalogElement.zpt')).__of__(self)
1.35 dwinter 85: return pt()
86:
87: def changeECHO_ZCatalogElement(self,title,field,catalogId,baseUrl,weight,contentType,RESPONSE=None):
88: """change"""
89: self.title=title
90: self.catalogId=catalogId
91: self.field=field
92: self.baseUrl=baseUrl
93: self.weight=weight
94: self.contentType=contentType
95:
96: if RESPONSE is not None:
97: RESPONSE.redirect('manage_main')
98: def getKeywordList(self):
99: return getattr(self,self.catalogId).uniqueValuesFor(self.field)
100:
101: def getNavList(self):
102: """ausgabe der treffer list für navigation"""
1.37 dwinter 103:
1.35 dwinter 104: records=self.getKeywordList()
105:
1.37 dwinter 106:
1.35 dwinter 107: if not records:
108: return []
109: else:
110: ret=[]
111: for record in records:
112: #print "RC",record
113: #if record:
114: # ret.append((record,self.baseUrl+urllib.quote(record)))
115: try:
116: ret.append((record,self.baseUrl+urllib.quote(record)))
117: except:
118: """nothing"""
119:
120: return ret
121:
122:
123: def manage_addECHO_ZCatalogElementForm(self):
124: """Form for adding"""
1.49 dwinter 125: pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','AddECHO_ZCatalogElement.zpt')).__of__(self)
1.35 dwinter 126: return pt()
127:
128: def manage_addECHO_ZCatalogElement(self,id,title,field,baseUrl,weight,contentType,RESPONSE=None):
129: """Add an ECHO_ZCatalogelement"""
130: self._setObject(id,ECHO_ZCatalogElement(id,title,field,baseUrl,weight,contentType))
131:
132: if RESPONSE is not None:
133: RESPONSE.redirect('manage_main')
134:
135:
136:
1.11 dwinter 137: class ECHO_contentType(Image):
138: """ContentType Object"""
139:
140: meta_type="ECHO_contentType"
141:
142:
143: manage_options=Image.manage_options+(
144: {'label':'Change Description','action':'changeECHO_contentTypeForm'},
145: )
146:
147: def changeECHO_contentTypeForm(self):
148: """Change the description text"""
1.48 dwinter 149: pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','changeECHO_contentType.zpt')).__of__(self)
1.11 dwinter 150: return pt()
1.48 dwinter 151:
1.11 dwinter 152: def changeECHO_contentType(self,description,RESPONSE=None):
153: """Change the Content"""
154: self.description=description
155: if RESPONSE is not None:
156: RESPONSE.redirect('manage_main')
157:
158: manage_addECHO_contentTypeForm=DTMLFile('dtml/ECHO_contentTypeAdd',globals(),
159: Kind='ECHO_contentType',kind='ECHO_contentType')
160:
161: def manage_addECHO_contentType(self, id, file=None, title='', precondition='', content_type='', description='',
162: REQUEST=None):
163: """
164: Add a new Image object.
165:
166: Creates a new Image object 'id' with the contents of 'file'.
167: """
168:
169: id=str(id)
170: title=str(title)
171: content_type=str(content_type)
172: precondition=str(precondition)
173:
174: id, title = cookId(id, title, file)
175:
176: self=self.this()
177:
178: # First, we create the image without data:
179: self._setObject(id, ECHO_contentType(id,title,'',content_type, precondition))
180:
181: self._getOb(id).description=description
182:
183: # Now we "upload" the data. By doing this in two steps, we
184: # can use a database trick to make the upload more efficient.
185: if file:
186: self._getOb(id).manage_upload(file)
187: if content_type:
188: self._getOb(id).content_type=content_type
189:
190: if REQUEST is not None:
191: try: url=self.DestinationURL()
192: except: url=REQUEST['URL1']
193: REQUEST.RESPONSE.redirect('%s/manage_main' % url)
194: return id
195:
1.1 dwinter 196:
197: class ECHO_sqlElement(SimpleItem):
198: """Erzeuge navigation aus sql-abfrage"""
199: meta_type="ECHO_sqlElement"
200: baseUrl=""
1.41 dwinter 201:
202:
1.1 dwinter 203:
1.10 dwinter 204: def __init__(self,id,title,query,field,searchField,baseUrl,weight,contentType):
1.1 dwinter 205: """init"""
206: self.id=id
207: self.title=title
208: self.query=query
209: self.field=field
1.7 dwinter 210: if searchField=="":
211: self.searchField=field
212: else:
213: self.searchField=searchField
1.1 dwinter 214: self.baseUrl=baseUrl
1.38 dwinter 215:
1.10 dwinter 216: self.content=contentType
1.1 dwinter 217:
218: manage_options= SimpleItem.manage_options+(
219: {'label':'Main Config','action':'changeECHO_sqlElementForm'},
220: )
221:
1.7 dwinter 222: def getSearchField(self):
223: try:
224: return self.searchField
225: except:
226: return self.field
227:
1.3 dwinter 228: def getWeight(self):
1.4 dwinter 229: """get weight"""
230: if hasattr(self,'weight'):
231: return self.weight
1.3 dwinter 232: else:
233: return 0
234:
1.10 dwinter 235: def getcontentType(self):
1.6 dwinter 236: """get weight"""
237:
1.10 dwinter 238: if hasattr(self,'contentType'):
239: return self.contentType
1.6 dwinter 240: else:
241: return 0
1.3 dwinter 242:
243:
1.1 dwinter 244: def changeECHO_sqlElementForm(self):
245: """change"""
1.6 dwinter 246:
1.48 dwinter 247: pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','changeECHO_sqlElement.zpt')).__of__(self)
1.1 dwinter 248: return pt()
249:
1.10 dwinter 250: def changeECHO_sqlElement(self,title,query,field,searchField,baseUrl,weight,contentType,RESPONSE=None):
1.1 dwinter 251: """change"""
252: self.title=title
253: self.query=query
254: self.field=field
1.7 dwinter 255: self.searchField=searchField
1.1 dwinter 256: self.baseUrl=baseUrl
1.3 dwinter 257: self.weight=weight
1.10 dwinter 258: self.contentType=contentType
1.6 dwinter 259:
1.1 dwinter 260: if RESPONSE is not None:
261: RESPONSE.redirect('manage_main')
262:
1.49 dwinter 263: try:
264: searchQuery=ZSQLExtendFolder.ZSQLSimpleSearch
265: except:
266: zLOG.LOG('ECHO_Nav',zLOG.INFO,'ZSQLSimpleSearch not supported')
267:
268: def getNavList(self):
1.1 dwinter 269: """ausgabe der treffer list für navigation"""
1.37 dwinter 270:
1.1 dwinter 271: records=self.searchQuery()
1.37 dwinter 272:
273:
1.1 dwinter 274: if not records:
275: return []
276: else:
277: ret=[]
278: for record in records:
1.7 dwinter 279: try:
280: ret.append((getattr(record,self.field),self.baseUrl+urllib.quote(str(getattr(record,self.getSearchField())))))
281: except:
282: """notrhing"""
283:
1.1 dwinter 284: return ret
285:
286:
1.6 dwinter 287: def manage_addECHO_sqlElementForm(self):
1.1 dwinter 288: """Form for adding"""
1.48 dwinter 289: pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','AddECHO_sqlElement.zpt')).__of__(self)
1.1 dwinter 290: return pt()
291:
1.10 dwinter 292: def manage_addECHO_sqlElement(self,id,title,query,field,searchField,baseUrl,weight,contentType,RESPONSE=None):
1.1 dwinter 293: """Add an ECHO_sqlelement"""
1.10 dwinter 294: self._setObject(id,ECHO_sqlElement(id,title,query,field,searchField,baseUrl,weight,contentType))
1.1 dwinter 295:
296: if RESPONSE is not None:
297: RESPONSE.redirect('manage_main')
298:
299:
1.51 dwinter 300: class ECHO_pageTemplate(ZopePageTemplate,ECHO_basis):
1.1 dwinter 301: """pageTemplate Objekt"""
302: meta_type="ECHO_pageTemplate"
303:
304: _default_content_fn = os.path.join(package_home(globals()),
1.6 dwinter 305: 'html/ECHO_pageTemplateDefault.html')
1.1 dwinter 306:
1.51 dwinter 307: manage_options=ZopePageTemplate.manage_options+ECHO_basis.manage_options+(
1.39 dwinter 308: {'label':'Main Config','action':'changeECHO_pageTemplateMainForm'},
1.3 dwinter 309: )
1.23 dwinter 310:
311: def content_html(self):
312: """content_html"""
313: return content_html(self,'pageTemplate')
1.3 dwinter 314:
1.39 dwinter 315: def changeECHO_pageTemplateMainForm(self):
1.4 dwinter 316: """change"""
1.48 dwinter 317: pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','ChangeECHO_pageTemplateMain.zpt')).__of__(self)
1.4 dwinter 318: return pt()
319:
1.47 dwinter 320: def changeECHO_pageTemplateMain(self,weight,contentType,label,description,RESPONSE=None,isAlwaysClickable=None,suffix=None,prefix=None):
1.4 dwinter 321: """change"""
322: self.weight=weight
1.10 dwinter 323: self.contentType=contentType
1.15 dwinter 324: self.label=label
1.39 dwinter 325: self.description=description
1.43 dwinter 326: self.isAlwaysClickable=isAlwaysClickable
1.47 dwinter 327: self.suffix=suffix
328: self.prefix=prefix
1.15 dwinter 329:
1.4 dwinter 330: if RESPONSE is not None:
331: RESPONSE.redirect('manage_main')
1.51 dwinter 332:
1.4 dwinter 333: def getWeight(self):
334: """get weight"""
335: if hasattr(self,'weight'):
336: return self.weight
337: else:
338: return 0
1.6 dwinter 339:
1.10 dwinter 340: def getcontentType(self):
1.33 jdamerow 341: """get contentType"""
342: if hasattr(self,'contentType'):
343: return self.contentType
1.6 dwinter 344: else:
345: return 0
346:
1.3 dwinter 347:
348:
1.1 dwinter 349:
1.10 dwinter 350: ## def __init__(self, id, text=None, contentType=None):
1.1 dwinter 351: ## self.id = str(id)
352: ## self.ZBindings_edit(self._default_bindings)
353: ## if text is None:
354: ## text = open(self._default_cont).read()
1.10 dwinter 355: ## self.pt_edit(text, contentType)
1.1 dwinter 356:
1.6 dwinter 357: def manage_addECHO_pageTemplateForm(self):
1.1 dwinter 358: """Form for adding"""
1.49 dwinter 359: pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','AddECHO_pageTemplate.zpt')).__of__(self)
1.1 dwinter 360: return pt()
361:
362: from urllib import quote
363:
364:
1.15 dwinter 365: def manage_addECHO_pageTemplate(self, id, label, weight= 0,contentType=0,title=None, text=None,
1.1 dwinter 366: REQUEST=None, submit=None):
367: "Add a Page Template with optional file content."
368:
369:
370: id = str(id)
371: if REQUEST is None:
372: self._setObject(id, ECHO_pageTemplate(id, text))
373: ob = getattr(self, id)
1.3 dwinter 374: setattr(ob,'weight',weight)
1.15 dwinter 375: setattr(ob,'label',label)
1.10 dwinter 376: setattr(ob,'contentType',contentType)
1.1 dwinter 377: if title:
378: ob.pt_setTitle(title)
379: return ob
380: else:
381: file = REQUEST.form.get('file')
382: headers = getattr(file, 'headers', None)
383: if headers is None or not file.filename:
384: zpt = ECHO_pageTemplate(id)
385: else:
1.10 dwinter 386: zpt = ECHO_pageTemplate(id, file, headers.get('contentType'))
1.1 dwinter 387:
388: self._setObject(id, zpt)
1.3 dwinter 389: ob = getattr(self, id)
390: setattr(ob,'weight',weight)
1.34 dwinter 391: setattr(ob,'label',label)
1.8 dwinter 392: if title:
393: ob.pt_setTitle(title)
394:
1.1 dwinter 395: try:
396: u = self.DestinationURL()
397: except AttributeError:
398: u = REQUEST['URL1']
399:
400: if submit == " Add and Edit ":
401: u = "%s/%s" % (u, quote(id))
402: REQUEST.RESPONSE.redirect(u+'/manage_main')
403: return ''
404:
405:
406: class ECHO_navigation(Folder):
407: """Navigations Element"""
408: meta_type="ECHO_Navigation"
409:
1.53 ! dwinter 410: def linkBar(self,parent):
! 411: """linkbarer balken"""
! 412: str=""
! 413:
! 414:
! 415: while not(parent.meta_type == "ECHO_root"):
! 416: fragment="""<a href="%s">%s</a>"""%(parent.absolute_url(),parent.label)
! 417: str=fragment+"/"+str
! 418: parent=parent.aq_parent
! 419:
! 420: return str
! 421:
! 422: def decode(self,str):
! 423: """decoder"""
! 424: if not str:
! 425: return ""
! 426: if type(str)==StringType:
! 427:
! 428: return str
! 429: else:
! 430: try:
! 431: return str.encode('utf-8')
! 432: except:
! 433: return str.encode('latin-1')
1.41 dwinter 434: def ECHOFormatListStr(self,list,search="\n",replace="<br>"):
435: """formatiert liste im str"""
1.42 dwinter 436: if list:
437: return re.sub(search,replace,list)
438: else:
439: return
440:
1.41 dwinter 441: def ECHO_cacheManageForm(self):
442: """change form"""
1.48 dwinter 443: pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','ECHO_cacheManageForm')).__of__(self)
1.41 dwinter 444: pt.content_type="text/html"
445: return pt()
446:
447: def ECHO_cacheManage(self,cacheManagerName=None,deleteCache=None, activateCache=None,RESPONSE=None):
448: """cachemanager"""
449: if cacheManagerName=="": chacheManagerName=None
450:
451: self.cacheManagerName=cacheManagerName
452: self.setCache(managerName=cacheManagerName)
453:
454: if deleteCache:
1.46 dwinter 455: try:
1.41 dwinter 456: self.deleteCache()
1.46 dwinter 457: except:
458: for roots in self.ZopeFind(self,obj_metatypes=['ECHO_root'],search_sub=1):
459: roots[1].deleteCache()
460:
1.41 dwinter 461:
462: self.activateCache=activateCache
463:
464: if RESPONSE is not None:
465: RESPONSE.redirect('manage_main')
466:
467: def setCache(self,obj=None,RESPONSE=None,managerName='CacheManager'):
468: """setze alle collections auf cache = CacheManager"""
469:
470:
471: if not obj:
472: obj = self
473:
474: entries=obj.ZopeFind(obj,obj_metatypes=['ECHO_collection'],search_sub=1)
475:
476: for entry in entries:
477: #print entry[0]
478: entry[1].ZCacheable_setManagerId(managerName)
479:
480:
481: return "changed all CM in: "+self.title
482:
1.48 dwinter 483:
1.35 dwinter 484:
1.48 dwinter 485: displayableMetaTypes=displayTypes
486:
1.35 dwinter 487: def getImageViewers(self):
488: """images"""
489: viewers=self.ZopeFind(self.standardImageViewer,obj_metatypes=['OSAS_ViewerObject'])
490: return viewers
1.1 dwinter 491:
1.28 dwinter 492: def getR(self):
493: """re"""
494: return self.REQUEST
495:
1.1 dwinter 496: def __init__(self,id,title,pathToHierarchy):
497: """init"""
498: self.id=id
499: self.title=title
500: self.pathToHierarchy=pathToHierarchy
1.48 dwinter 501: self.displayedMetaTypes=displayTypes
502:
1.1 dwinter 503: manage_options = Folder.manage_options+(
504: {'label':'Main Config','action':'ECHO_navigationConfigForm'},
1.41 dwinter 505: {'label':'Cache','action':'ECHO_cacheManageForm'},
506:
1.1 dwinter 507: )
1.48 dwinter 508: displayedMetaTypes=displayTypes
509:
1.1 dwinter 510: def ECHO_navigationConfigForm(self):
511: """configForm"""
1.48 dwinter 512: pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','ChangeECHO_navigation.zpt')).__of__(self)
1.1 dwinter 513: return pt()
514:
1.48 dwinter 515: def ECHO_navigationConfig(self,title,pathToHierarchy,displayedMetaTypes=displayTypes,RESPONSE=None):
1.1 dwinter 516: """config"""
517: self.title=title
518: self.pathToHierarchy=pathToHierarchy
1.48 dwinter 519: self.displayedMetaTypes=toList(displayedMetaTypes)[0:]
520:
1.1 dwinter 521:
522: if RESPONSE is not None:
523: RESPONSE.redirect('manage_main')
524:
525:
1.19 dwinter 526: def getColls(self,obj,depth,checkOnly="no"):
1.1 dwinter 527: nav={}
528: #print "HERE",obj.
1.18 dwinter 529: for x_objs in obj.ZopeFind(obj,obj_metatypes=self.displayedMetaTypes):
530: x=x_objs[1]
1.22 dwinter 531: if checkOnly=="yes":
1.19 dwinter 532: x = checkOnlyOneInGroup(x)
1.18 dwinter 533: if depth>1:
534: nav[x.getId()]=(self.getColls(x,depth-1),x)
535: else:
536: nav[x.getId()]=(None,x)
1.1 dwinter 537: return nav
538:
1.19 dwinter 539: def createNavHash(self,depth,checkOnly="no"):
1.1 dwinter 540: """Auslesen des Hierarchiebuames"""
541: temp=self.pathToHierarchy[0:]
542: temp=re.sub("/",".",temp)
543: temp="self.aq_parent"+temp
1.40 dwinter 544:
1.1 dwinter 545:
546: objtemp=eval(temp)
547: nav={}
1.40 dwinter 548:
1.41 dwinter 549: #check if cash is enabled and if already exists and if not empty
550: if getattr(self,'_v_hash',None) and getattr(self,'activateCache',None) and self._v_hash.get(str(depth),None):
551:
552: return self._v_hash[str(depth)]
1.1 dwinter 553:
1.41 dwinter 554: # if not generate new hash
555: obj=objtemp
1.37 dwinter 556:
557: for keys in obj.ZopeFind(obj,obj_metatypes=self.displayedMetaTypes):
558: x=keys[1]
1.41 dwinter 559: if depth>1:
560: nav[x.getId()]=(self.getColls(x,int(depth)-1,checkOnly),x)
561: else:
562: nav[x.getId()]=(None,x)
1.37 dwinter 563:
1.41 dwinter 564: #store in cache if activated
565: if getattr(self,'activateCache',None):
566:
567: try:
568: self._v_hash[str(depth)]={}
569: except:
570: self._v_hash={}
571: self._v_hash[str(depth)]={}
1.1 dwinter 572:
1.41 dwinter 573: for x in nav.keys():
574: self._v_hash[str(depth)][x]=nav[x]
1.40 dwinter 575:
1.1 dwinter 576: return nav
577:
1.32 dwinter 578: def barFromHash(self,hash,start=None,sortField=None,location=None):
1.1 dwinter 579: """Erzeuge Navigations Element"""
580: #print "hash",hash
581: listNav=[]
582: if not start:
583: temp=hash
1.5 dwinter 584: sortField="weight"
1.41 dwinter 585: else: # liste mit pfad zum hash
1.1 dwinter 586: temp=hash
1.7 dwinter 587: #print "HI",sortField
1.5 dwinter 588: if not sortField:
589: tempObj=self.pathToHierarchy[0:]
590: tempObj=re.sub("/",".",tempObj)
591: tempObj="self.aq_parent"+tempObj
1.28 dwinter 592: #print tempObj
1.5 dwinter 593: objtemp=eval(tempObj)
594:
595: obj=objtemp
596:
597: for x in start:
1.7 dwinter 598: #print "OBJ",start,obj,obj.getId(),x
1.5 dwinter 599:
600: obj=getattr(obj,x)
601:
602: if hasattr(obj,'sortfield'):
603: sortField=obj.sortfield
604: else:
605: sortField='weight'
1.7 dwinter 606: #print "START",start
1.1 dwinter 607: for x in start:
1.7 dwinter 608: #print "N2",x,temp[x]
609: try:
1.5 dwinter 610: temp=temp[x][0]
1.7 dwinter 611: except:
612: """nothing"""
613: return []
614: #print "TEMP",temp,self.tempSorted(temp, field=sortField)
1.13 dwinter 615:
1.5 dwinter 616: for x in self.tempSorted(temp, field=sortField):
1.37 dwinter 617:
1.4 dwinter 618: if not temp[x][1].title == "":
1.35 dwinter 619:
620: if (temp[x][1].meta_type=="ECHO_sqlElement") or (temp[x][1].meta_type=="ECHO_ZCatalogElement"):
1.37 dwinter 621:
1.4 dwinter 622: for z in temp[x][1].getNavList():
1.47 dwinter 623: listNav.append((z[0],z[1],None,'',''))
1.37 dwinter 624:
1.4 dwinter 625: else:
1.27 dwinter 626: # add label falls existiert und nicht leer
1.7 dwinter 627: if hasattr(temp[x][1],'label'):
1.47 dwinter 628:
1.7 dwinter 629: if not temp[x][1].label=='':
1.38 dwinter 630: try:
1.47 dwinter 631: label=temp[x][1].getLabel()
1.38 dwinter 632: except:
633: label=temp[x][1].label
1.7 dwinter 634: else:
1.16 dwinter 635: label=temp[x][1].title.encode('utf-8')
1.7 dwinter 636: else:
1.16 dwinter 637: label=temp[x][1].title.encode('utf-8')
1.51 dwinter 638:
639: if location:
1.32 dwinter 640:
641: loc=getattr(temp[x][1],'location','top')
642: if (loc==location):
1.51 dwinter 643: listNav.append((label,createPath(self.absolute_url(),temp[x][1].absolute_url())+getattr(temp[x][1],'queryString',''),temp[x][1],getattr(temp[x][1],'prefix',''),getattr(temp[x][1],'suffix','')))
1.32 dwinter 644: else:
1.51 dwinter 645: listNav.append((label,createPath(self.absolute_url(),temp[x][1].absolute_url())+getattr(temp[x][1],'queryString',''),temp[x][1],getattr(temp[x][1],'prefix',''),getattr(temp[x][1],'suffix','')))
1.1 dwinter 646:
647: return listNav
648:
1.5 dwinter 649: def tempSorted(self,hash,field="weight"):
1.4 dwinter 650: ls=[]
1.13 dwinter 651:
1.4 dwinter 652: for x in hash.keys():
653: #print hash[x][1]
1.5 dwinter 654: if hasattr(hash[x][1],field):
1.52 dwinter 655: try:
656: weight=int(getattr(hash[x][1],field))
657: except:
658: weight=getattr(hash[x][1],field)
1.4 dwinter 659: #print weight
660: else:
661: weight=0
662:
663: ls.append((x,weight))
664:
665: ls.sort(sortWeight)
666:
667: return [x[0] for x in ls]
668:
669:
670:
671:
1.1 dwinter 672: def isSelectedPath(self,item):
673: """test is path is already selected"""
1.45 dwinter 674:
675: testStr=re.sub("/index_html",'',self.REQUEST.get('URL',''))
676:
677: #falls exakte Übereinstimmung dann immer 1
678: if (testStr==item[1]) and (self.REQUEST.get('QUERY_STRING','')==''):
679:
680: return 1
681:
682: found=re.search("\?(.*)",item[1])
1.43 dwinter 683:
1.1 dwinter 684: if found:
685: temp=re.sub(" ","%20",found.group(0))
1.45 dwinter 686:
1.1 dwinter 687: #print temp+"::"+self.REQUEST['QUERY_STRING']
688: if ("?"+self.REQUEST['QUERY_STRING'])==temp:
1.43 dwinter 689: if getattr(item[2],'isAlwaysClickable',None): #immer auswaehlbar?
690:
691: return 2
692: else:
693: return 1
694:
1.44 dwinter 695: if (getattr(item[2],'meta_type','')=="ECHO_pageTemplate") and (re.search(item[1],self.REQUEST['URL'])):
1.43 dwinter 696: if getattr(item[2],'isAlwaysClickable',None): #immer auswaehlbar?
697:
698: return 2
699: else:
1.1 dwinter 700: return 1
701:
1.26 dwinter 702: if re.search(item[1]+"/",self.REQUEST['URL']):
1.43 dwinter 703: if getattr(item[2],'isAlwaysClickable',None): #immer auswaehlbar?
704:
705: return 2
706: else:
707: return 1
1.1 dwinter 708: else:
709: return 0
1.43 dwinter 710:
711:
1.1 dwinter 712:
713:
714: def buttonsFromHash(self,hash,start=None,orientation="horizontal"):
715:
716: """Generate Buttons"""
717: if orientation=="horizontal":
718: html="<table><tr>"
719: startTag="<td>"
720: endTag="</td>"
721: endHtml="</tr></table>"
722:
723: else:
724: html="<table>"
725: startTag="<tr><td>"
726: endTag="</td></tr>"
727: endHtml="</table>"
728:
729: if not start:
730: temp=hash
731: else:
732: temp=hash
733: for x in start:
734: temp=temp[x][0]
735: #print temp
736:
1.5 dwinter 737: for key in self.tempSorted(temp):
1.1 dwinter 738:
739: description=temp[x][1].title
1.2 dwinter 740:
1.3 dwinter 741: url=createPath(self.absolute_url(),temp[key][1].absolute_url())
1.2 dwinter 742:
1.1 dwinter 743: if (self.REQUEST['URL']==url) | (self.REQUEST['URL']==url+"/index_html"):
744: html=html+startTag+"[%s]" % description+endTag
745: else:
746: html=html+startTag+"[<a href='%s'>%s</a>]" % (url,description)+endTag
747:
748:
749: html=html+endHtml
750:
751: return html
752:
753: def mainNavBar(self):
754: """print main navigation bar"""
755: keys=""
1.13 dwinter 756:
1.1 dwinter 757: try:
758: keys=self.buttonsFromHash(self.createNavHash(0))
759: except:
760: keys=""
761:
762: return keys
763:
1.32 dwinter 764: def mainNavElements(self,location=None):
1.1 dwinter 765: """print main navigation bar"""
766: keys=""
1.12 dwinter 767: #print "NAVELEMENT",self.getId()
1.5 dwinter 768: #try:
1.32 dwinter 769:
770: keys=self.barFromHash(self.createNavHash(0),location=location)
1.12 dwinter 771:
1.5 dwinter 772: #except:
773: # keys=""
1.1 dwinter 774:
775: return keys
1.12 dwinter 776:
777: def numberOfMainNavElements(self):
778: """number of main elements"""
779:
780: return len(self.barFromHash(self.createNavHash(0)))
781:
1.29 dwinter 782: def startOfHierarchy(self,list):
783: splitted=self.pathToHierarchy.split("/")
784: last=splitted[len(splitted)-1]
785: #print last,list
786: try:
787: nr=list.index(last)
788: except:
789: nr=0
790: return nr+1
791:
1.1 dwinter 792: def secondNavElements(self):
1.51 dwinter 793: """Zweite Ordnung Navigationselemente
794:
795: """
1.1 dwinter 796:
1.22 dwinter 797: hash=self.createNavHash(2,checkOnly="no")
1.1 dwinter 798: actual_url=self.REQUEST['URL']
799:
800: ult_temp=re.sub(self.absolute_url(),"",actual_url)
801: #print ult_temp
802:
803: splitted=ult_temp.split("/")
804:
1.29 dwinter 805: #print "AU",self.absolute_url(),splitted
1.28 dwinter 806: #start=[splitted[2]] #orig
1.29 dwinter 807: startNr= self.startOfHierarchy(splitted)
808:
809: start=[splitted[startNr]]
1.28 dwinter 810:
1.29 dwinter 811: #print start
1.7 dwinter 812:
1.25 dwinter 813: keys=self.barFromHash(hash,start=start)
1.7 dwinter 814:
815:
816: return keys
817:
818: def navElements(self,order):
819: """n-te Ordnung"""
820:
821: hash=self.createNavHash(order)
822: actual_url=self.REQUEST['URL']
823:
824: ult_temp=re.sub(self.absolute_url(),"",actual_url)
825: #print ult_temp
826:
827: splitted=ult_temp.split("/")
828:
829:
830: ## if splitted[len(splitted)-1]=="index_html":
831: ## start=[splitted[len(splitted)-2]]
832: ## else:
833: ## start=[splitted[len(splitted)-1]]
834:
1.28 dwinter 835: #start=splitted[2:order+1] #orig
1.29 dwinter 836: startNr= self.startOfHierarchy(splitted)
1.30 dwinter 837: #print startNr
838: start=splitted[startNr:order+startNr-1]
1.1 dwinter 839: #print start
1.5 dwinter 840:
1.1 dwinter 841: keys=self.barFromHash(hash,start=start)
842:
843:
844: return keys
845:
846:
847: def secondNavBar(self):
848: """Zweite Ordnung"""
849:
850: hash=self.createNavHash(2)
851: actual_url=self.REQUEST['URL']
852:
853: ult_temp=re.sub(self.absolute_url(),"",actual_url)
854: #print ult_temp
855:
856: splitted=ult_temp.split("/")
857:
858:
859: ## if splitted[len(splitted)-1]=="index_html":
860: ## start=[splitted[len(splitted)-2]]
861: ## else:
862: ## start=[splitted[len(splitted)-1]]
863:
864: start=[splitted[2]]
865: #print start
866:
867: keys=self.buttonsFromHash(hash,start=start,orientation="vertical")
868:
869:
870: return keys
871:
1.6 dwinter 872: def manage_addECHO_navigationForm(self):
1.1 dwinter 873: """Form for adding"""
1.48 dwinter 874: pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','AddECHO_navigation.zpt')).__of__(self)
1.1 dwinter 875: return pt()
876:
1.6 dwinter 877: def manage_addECHO_navigation(self,id,title,pathToHierarchy,RESPONSE=None):
1.1 dwinter 878: """Add an ECHO_root"""
879: self._setObject(id,ECHO_navigation(id,title,pathToHierarchy))
880:
881: if RESPONSE is not None:
882: RESPONSE.redirect('manage_main')
883:
884:
885: #helpers
886:
1.3 dwinter 887:
888:
889: def createPath(url1,url2):
890: temp1=url1.split("/")
891: temp2=url2.split("/")
892: for test in temp1:
893: if temp2[0]==test:
894: del temp2[0]
895:
1.28 dwinter 896: #print "CP:"+url1+"::"+url2+"::"+url1+"/"+string.join(temp2,"/")
1.3 dwinter 897: return url1+"/"+string.join(temp2,"/")
1.4 dwinter 898:
899: def sortWeight(x,y):
900: #print x[1],y[1]
901: return cmp(x[1],y[1])
1.1 dwinter 902:
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>