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