Annotation of ECHO_content/ECHO_Nav.py, revision 1.62
1.60 dwinter 1: # Objekte zur Erzeugung von Navigationselement
1.54 dwinter 2: from AccessControl import ClassSecurityInfo
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.59 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
1.55 dwinter 30:
1.35 dwinter 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.61 dwinter 269: """ausgabe der treffer list fuer navigation"""
1.37 dwinter 270:
1.60 dwinter 271: #naechste schritte sind trial and error, warum geht mal das eine mal das andere 2.3 / 2.4 ??
1.62 ! dwinter 272:
1.60 dwinter 273: try:
1.62 ! dwinter 274: try:
! 275: records=self.ZSQLSimpleSearch(query=self.query)
! 276: except:
! 277: records=self.searchQuery(self.aq_parent,query=self.query) #python 2.4 version (??)
1.60 dwinter 278: except:
1.61 dwinter 279: records=self.searchQuery()#python 2.3 version(??)
1.37 dwinter 280:
281:
1.1 dwinter 282: if not records:
283: return []
284: else:
285: ret=[]
286: for record in records:
1.7 dwinter 287: try:
288: ret.append((getattr(record,self.field),self.baseUrl+urllib.quote(str(getattr(record,self.getSearchField())))))
289: except:
290: """notrhing"""
291:
1.1 dwinter 292: return ret
293:
294:
1.6 dwinter 295: def manage_addECHO_sqlElementForm(self):
1.1 dwinter 296: """Form for adding"""
1.48 dwinter 297: pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','AddECHO_sqlElement.zpt')).__of__(self)
1.1 dwinter 298: return pt()
299:
1.10 dwinter 300: def manage_addECHO_sqlElement(self,id,title,query,field,searchField,baseUrl,weight,contentType,RESPONSE=None):
1.1 dwinter 301: """Add an ECHO_sqlelement"""
1.10 dwinter 302: self._setObject(id,ECHO_sqlElement(id,title,query,field,searchField,baseUrl,weight,contentType))
1.1 dwinter 303:
304: if RESPONSE is not None:
305: RESPONSE.redirect('manage_main')
306:
307:
1.51 dwinter 308: class ECHO_pageTemplate(ZopePageTemplate,ECHO_basis):
1.1 dwinter 309: """pageTemplate Objekt"""
310: meta_type="ECHO_pageTemplate"
1.54 dwinter 311: security=ClassSecurityInfo()
312:
1.56 dwinter 313:
1.1 dwinter 314: _default_content_fn = os.path.join(package_home(globals()),
1.6 dwinter 315: 'html/ECHO_pageTemplateDefault.html')
1.1 dwinter 316:
1.51 dwinter 317: manage_options=ZopePageTemplate.manage_options+ECHO_basis.manage_options+(
1.39 dwinter 318: {'label':'Main Config','action':'changeECHO_pageTemplateMainForm'},
1.56 dwinter 319: {'label':'Graphic Coords','action':'ECHO_graphicEntry'},
1.3 dwinter 320: )
1.23 dwinter 321:
1.54 dwinter 322: security.declarePublic('content_html')
323:
1.59 dwinter 324: def addChanges(self):
325: """do nothing leere methode, notwendig, da bei veerbung
326: von dieser klasse nur ueberschrieben werden kann,
327: falls methode per url aufgerufen werden soll"""
328:
329: return True
1.54 dwinter 330:
1.23 dwinter 331: def content_html(self):
1.58 dwinter 332: """content_html"""
333: return content_html(self,'pageTemplate')
1.3 dwinter 334:
1.39 dwinter 335: def changeECHO_pageTemplateMainForm(self):
1.4 dwinter 336: """change"""
1.48 dwinter 337: pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','ChangeECHO_pageTemplateMain.zpt')).__of__(self)
1.4 dwinter 338: return pt()
339:
1.47 dwinter 340: def changeECHO_pageTemplateMain(self,weight,contentType,label,description,RESPONSE=None,isAlwaysClickable=None,suffix=None,prefix=None):
1.4 dwinter 341: """change"""
342: self.weight=weight
1.10 dwinter 343: self.contentType=contentType
1.15 dwinter 344: self.label=label
1.39 dwinter 345: self.description=description
1.43 dwinter 346: self.isAlwaysClickable=isAlwaysClickable
1.47 dwinter 347: self.suffix=suffix
348: self.prefix=prefix
1.15 dwinter 349:
1.4 dwinter 350: if RESPONSE is not None:
351: RESPONSE.redirect('manage_main')
1.51 dwinter 352:
1.4 dwinter 353: def getWeight(self):
354: """get weight"""
355: if hasattr(self,'weight'):
356: return self.weight
357: else:
358: return 0
1.6 dwinter 359:
1.10 dwinter 360: def getcontentType(self):
1.33 jdamerow 361: """get contentType"""
362: if hasattr(self,'contentType'):
363: return self.contentType
1.6 dwinter 364: else:
365: return 0
366:
1.3 dwinter 367:
368:
1.1 dwinter 369:
1.10 dwinter 370: ## def __init__(self, id, text=None, contentType=None):
1.1 dwinter 371: ## self.id = str(id)
372: ## self.ZBindings_edit(self._default_bindings)
373: ## if text is None:
374: ## text = open(self._default_cont).read()
1.10 dwinter 375: ## self.pt_edit(text, contentType)
1.1 dwinter 376:
1.6 dwinter 377: def manage_addECHO_pageTemplateForm(self):
1.1 dwinter 378: """Form for adding"""
1.49 dwinter 379: pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','AddECHO_pageTemplate.zpt')).__of__(self)
1.1 dwinter 380: return pt()
381:
382: from urllib import quote
383:
384:
1.15 dwinter 385: def manage_addECHO_pageTemplate(self, id, label, weight= 0,contentType=0,title=None, text=None,
1.1 dwinter 386: REQUEST=None, submit=None):
387: "Add a Page Template with optional file content."
388:
389:
390: id = str(id)
391: if REQUEST is None:
392: self._setObject(id, ECHO_pageTemplate(id, text))
393: ob = getattr(self, id)
1.3 dwinter 394: setattr(ob,'weight',weight)
1.15 dwinter 395: setattr(ob,'label',label)
1.10 dwinter 396: setattr(ob,'contentType',contentType)
1.1 dwinter 397: if title:
398: ob.pt_setTitle(title)
399: return ob
400: else:
401: file = REQUEST.form.get('file')
402: headers = getattr(file, 'headers', None)
403: if headers is None or not file.filename:
404: zpt = ECHO_pageTemplate(id)
405: else:
1.10 dwinter 406: zpt = ECHO_pageTemplate(id, file, headers.get('contentType'))
1.1 dwinter 407:
408: self._setObject(id, zpt)
1.3 dwinter 409: ob = getattr(self, id)
410: setattr(ob,'weight',weight)
1.34 dwinter 411: setattr(ob,'label',label)
1.8 dwinter 412: if title:
413: ob.pt_setTitle(title)
414:
1.1 dwinter 415: try:
416: u = self.DestinationURL()
417: except AttributeError:
418: u = REQUEST['URL1']
419:
420: if submit == " Add and Edit ":
421: u = "%s/%s" % (u, quote(id))
422: REQUEST.RESPONSE.redirect(u+'/manage_main')
423: return ''
424:
425:
426: class ECHO_navigation(Folder):
427: """Navigations Element"""
428: meta_type="ECHO_Navigation"
429:
1.59 dwinter 430: def getNavInfo(self):
431: """root informationen"""
432: if hasattr(self,'logo_image'):
433: if hasattr(self.logo_image,'tag'):
434: imageTag=self.logo_image.tag()
435: else:
436: imageTag=''
437: return (self.title,imageTag)
438:
1.53 dwinter 439: def linkBar(self,parent):
440: """linkbarer balken"""
441: str=""
442:
443:
444: while not(parent.meta_type == "ECHO_root"):
445: fragment="""<a href="%s">%s</a>"""%(parent.absolute_url(),parent.label)
446: str=fragment+"/"+str
447: parent=parent.aq_parent
448:
449: return str
450:
451: def decode(self,str):
452: """decoder"""
453: if not str:
454: return ""
455: if type(str)==StringType:
456:
457: return str
458: else:
459: try:
460: return str.encode('utf-8')
461: except:
462: return str.encode('latin-1')
1.41 dwinter 463: def ECHOFormatListStr(self,list,search="\n",replace="<br>"):
464: """formatiert liste im str"""
1.58 dwinter 465: if list:
466: return re.sub(search,replace,list)
467: else:
468: return
1.42 dwinter 469:
1.41 dwinter 470: def ECHO_cacheManageForm(self):
1.58 dwinter 471: """change form"""
472: pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','ECHO_cacheManageForm')).__of__(self)
473: pt.content_type="text/html"
474: return pt()
1.41 dwinter 475:
476: def ECHO_cacheManage(self,cacheManagerName=None,deleteCache=None, activateCache=None,RESPONSE=None):
1.58 dwinter 477: """cachemanager"""
478: if cacheManagerName=="": chacheManagerName=None
479:
480: self.cacheManagerName=cacheManagerName
481: self.setCache(managerName=cacheManagerName)
482:
483: if deleteCache:
1.46 dwinter 484: try:
1.58 dwinter 485: self.deleteCache()
1.46 dwinter 486: except:
487: for roots in self.ZopeFind(self,obj_metatypes=['ECHO_root'],search_sub=1):
488: roots[1].deleteCache()
489:
1.41 dwinter 490:
1.58 dwinter 491: self.activateCache=activateCache
1.41 dwinter 492:
1.58 dwinter 493: if RESPONSE is not None:
494: RESPONSE.redirect('manage_main')
495:
1.41 dwinter 496: def setCache(self,obj=None,RESPONSE=None,managerName='CacheManager'):
497: """setze alle collections auf cache = CacheManager"""
498:
499:
500: if not obj:
501: obj = self
502:
1.58 dwinter 503: entries=obj.ZopeFind(obj,obj_metatypes=['ECHO_collection','VLP_resource'],search_sub=1)
1.41 dwinter 504:
505: for entry in entries:
506: entry[1].ZCacheable_setManagerId(managerName)
507:
508:
509: return "changed all CM in: "+self.title
510:
1.48 dwinter 511:
1.35 dwinter 512:
1.48 dwinter 513: displayableMetaTypes=displayTypes
514:
1.35 dwinter 515: def getImageViewers(self):
516: """images"""
517: viewers=self.ZopeFind(self.standardImageViewer,obj_metatypes=['OSAS_ViewerObject'])
518: return viewers
1.1 dwinter 519:
1.28 dwinter 520: def getR(self):
1.58 dwinter 521: """re"""
522: return self.REQUEST
1.28 dwinter 523:
1.1 dwinter 524: def __init__(self,id,title,pathToHierarchy):
525: """init"""
526: self.id=id
527: self.title=title
528: self.pathToHierarchy=pathToHierarchy
1.48 dwinter 529: self.displayedMetaTypes=displayTypes
530:
1.1 dwinter 531: manage_options = Folder.manage_options+(
532: {'label':'Main Config','action':'ECHO_navigationConfigForm'},
1.41 dwinter 533: {'label':'Cache','action':'ECHO_cacheManageForm'},
534:
1.1 dwinter 535: )
1.48 dwinter 536: displayedMetaTypes=displayTypes
537:
1.1 dwinter 538: def ECHO_navigationConfigForm(self):
539: """configForm"""
1.48 dwinter 540: pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','ChangeECHO_navigation.zpt')).__of__(self)
1.1 dwinter 541: return pt()
542:
1.48 dwinter 543: def ECHO_navigationConfig(self,title,pathToHierarchy,displayedMetaTypes=displayTypes,RESPONSE=None):
1.1 dwinter 544: """config"""
545: self.title=title
546: self.pathToHierarchy=pathToHierarchy
1.48 dwinter 547: self.displayedMetaTypes=toList(displayedMetaTypes)[0:]
548:
1.1 dwinter 549:
550: if RESPONSE is not None:
551: RESPONSE.redirect('manage_main')
552:
553:
1.19 dwinter 554: def getColls(self,obj,depth,checkOnly="no"):
1.1 dwinter 555: nav={}
556: #print "HERE",obj.
1.18 dwinter 557: for x_objs in obj.ZopeFind(obj,obj_metatypes=self.displayedMetaTypes):
558: x=x_objs[1]
1.22 dwinter 559: if checkOnly=="yes":
1.19 dwinter 560: x = checkOnlyOneInGroup(x)
1.18 dwinter 561: if depth>1:
562: nav[x.getId()]=(self.getColls(x,depth-1),x)
563: else:
564: nav[x.getId()]=(None,x)
1.1 dwinter 565: return nav
566:
1.19 dwinter 567: def createNavHash(self,depth,checkOnly="no"):
1.1 dwinter 568: """Auslesen des Hierarchiebuames"""
569: temp=self.pathToHierarchy[0:]
570: temp=re.sub("/",".",temp)
571: temp="self.aq_parent"+temp
1.40 dwinter 572:
1.1 dwinter 573:
574: objtemp=eval(temp)
575: nav={}
1.40 dwinter 576:
1.41 dwinter 577: #check if cash is enabled and if already exists and if not empty
578: if getattr(self,'_v_hash',None) and getattr(self,'activateCache',None) and self._v_hash.get(str(depth),None):
579:
580: return self._v_hash[str(depth)]
1.1 dwinter 581:
1.41 dwinter 582: # if not generate new hash
583: obj=objtemp
1.37 dwinter 584:
585: for keys in obj.ZopeFind(obj,obj_metatypes=self.displayedMetaTypes):
586: x=keys[1]
1.41 dwinter 587: if depth>1:
588: nav[x.getId()]=(self.getColls(x,int(depth)-1,checkOnly),x)
589: else:
590: nav[x.getId()]=(None,x)
1.37 dwinter 591:
1.41 dwinter 592: #store in cache if activated
593: if getattr(self,'activateCache',None):
594:
595: try:
596: self._v_hash[str(depth)]={}
597: except:
598: self._v_hash={}
599: self._v_hash[str(depth)]={}
1.1 dwinter 600:
1.41 dwinter 601: for x in nav.keys():
602: self._v_hash[str(depth)][x]=nav[x]
1.40 dwinter 603:
1.1 dwinter 604: return nav
605:
1.32 dwinter 606: def barFromHash(self,hash,start=None,sortField=None,location=None):
1.1 dwinter 607: """Erzeuge Navigations Element"""
608: #print "hash",hash
609: listNav=[]
610: if not start:
611: temp=hash
1.5 dwinter 612: sortField="weight"
1.41 dwinter 613: else: # liste mit pfad zum hash
1.1 dwinter 614: temp=hash
1.7 dwinter 615: #print "HI",sortField
1.5 dwinter 616: if not sortField:
617: tempObj=self.pathToHierarchy[0:]
618: tempObj=re.sub("/",".",tempObj)
619: tempObj="self.aq_parent"+tempObj
1.58 dwinter 620: #print tempObj
1.5 dwinter 621: objtemp=eval(tempObj)
622:
623: obj=objtemp
624:
625: for x in start:
1.7 dwinter 626: #print "OBJ",start,obj,obj.getId(),x
1.5 dwinter 627:
628: obj=getattr(obj,x)
629:
630: if hasattr(obj,'sortfield'):
631: sortField=obj.sortfield
632: else:
633: sortField='weight'
1.7 dwinter 634: #print "START",start
1.1 dwinter 635: for x in start:
1.7 dwinter 636: #print "N2",x,temp[x]
637: try:
1.5 dwinter 638: temp=temp[x][0]
1.7 dwinter 639: except:
640: """nothing"""
641: return []
642: #print "TEMP",temp,self.tempSorted(temp, field=sortField)
1.13 dwinter 643:
1.5 dwinter 644: for x in self.tempSorted(temp, field=sortField):
1.37 dwinter 645:
1.4 dwinter 646: if not temp[x][1].title == "":
1.35 dwinter 647:
648: if (temp[x][1].meta_type=="ECHO_sqlElement") or (temp[x][1].meta_type=="ECHO_ZCatalogElement"):
1.37 dwinter 649:
1.4 dwinter 650: for z in temp[x][1].getNavList():
1.47 dwinter 651: listNav.append((z[0],z[1],None,'',''))
1.37 dwinter 652:
1.4 dwinter 653: else:
1.27 dwinter 654: # add label falls existiert und nicht leer
1.7 dwinter 655: if hasattr(temp[x][1],'label'):
1.47 dwinter 656:
1.7 dwinter 657: if not temp[x][1].label=='':
1.38 dwinter 658: try:
1.47 dwinter 659: label=temp[x][1].getLabel()
1.38 dwinter 660: except:
661: label=temp[x][1].label
1.7 dwinter 662: else:
1.16 dwinter 663: label=temp[x][1].title.encode('utf-8')
1.7 dwinter 664: else:
1.16 dwinter 665: label=temp[x][1].title.encode('utf-8')
1.51 dwinter 666:
667: if location:
1.32 dwinter 668:
669: loc=getattr(temp[x][1],'location','top')
670: if (loc==location):
1.51 dwinter 671: 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 672: else:
1.51 dwinter 673: 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 674:
675: return listNav
676:
1.5 dwinter 677: def tempSorted(self,hash,field="weight"):
1.4 dwinter 678: ls=[]
1.13 dwinter 679:
1.4 dwinter 680: for x in hash.keys():
681: #print hash[x][1]
1.5 dwinter 682: if hasattr(hash[x][1],field):
1.52 dwinter 683: try:
684: weight=int(getattr(hash[x][1],field))
685: except:
686: weight=getattr(hash[x][1],field)
1.4 dwinter 687: #print weight
688: else:
689: weight=0
690:
691: ls.append((x,weight))
692:
693: ls.sort(sortWeight)
694:
695: return [x[0] for x in ls]
696:
697:
698:
699:
1.1 dwinter 700: def isSelectedPath(self,item):
701: """test is path is already selected"""
1.45 dwinter 702:
703: testStr=re.sub("/index_html",'',self.REQUEST.get('URL',''))
704:
705: #falls exakte Übereinstimmung dann immer 1
706: if (testStr==item[1]) and (self.REQUEST.get('QUERY_STRING','')==''):
707:
708: return 1
709:
710: found=re.search("\?(.*)",item[1])
1.43 dwinter 711:
1.1 dwinter 712: if found:
713: temp=re.sub(" ","%20",found.group(0))
1.45 dwinter 714:
1.1 dwinter 715: #print temp+"::"+self.REQUEST['QUERY_STRING']
716: if ("?"+self.REQUEST['QUERY_STRING'])==temp:
1.43 dwinter 717: if getattr(item[2],'isAlwaysClickable',None): #immer auswaehlbar?
718:
719: return 2
720: else:
721: return 1
722:
1.44 dwinter 723: if (getattr(item[2],'meta_type','')=="ECHO_pageTemplate") and (re.search(item[1],self.REQUEST['URL'])):
1.43 dwinter 724: if getattr(item[2],'isAlwaysClickable',None): #immer auswaehlbar?
725:
726: return 2
727: else:
1.1 dwinter 728: return 1
729:
1.26 dwinter 730: if re.search(item[1]+"/",self.REQUEST['URL']):
1.43 dwinter 731: if getattr(item[2],'isAlwaysClickable',None): #immer auswaehlbar?
732:
733: return 2
734: else:
735: return 1
1.1 dwinter 736: else:
737: return 0
1.57 casties 738:
739:
740: def getPathStyle(self, item, style=""):
1.58 dwinter 741: """returns a string with the given style + 'sel' if the path is already selected."""
1.43 dwinter 742:
1.58 dwinter 743: if self.isSelectedPath(item):
744: return style + 'sel'
745: else:
746: return style
1.1 dwinter 747:
748:
749: def buttonsFromHash(self,hash,start=None,orientation="horizontal"):
750:
751: """Generate Buttons"""
752: if orientation=="horizontal":
753: html="<table><tr>"
754: startTag="<td>"
755: endTag="</td>"
756: endHtml="</tr></table>"
757:
758: else:
759: html="<table>"
760: startTag="<tr><td>"
761: endTag="</td></tr>"
762: endHtml="</table>"
763:
764: if not start:
765: temp=hash
766: else:
767: temp=hash
768: for x in start:
769: temp=temp[x][0]
770: #print temp
771:
1.5 dwinter 772: for key in self.tempSorted(temp):
1.1 dwinter 773:
774: description=temp[x][1].title
1.2 dwinter 775:
1.3 dwinter 776: url=createPath(self.absolute_url(),temp[key][1].absolute_url())
1.2 dwinter 777:
1.1 dwinter 778: if (self.REQUEST['URL']==url) | (self.REQUEST['URL']==url+"/index_html"):
779: html=html+startTag+"[%s]" % description+endTag
780: else:
781: html=html+startTag+"[<a href='%s'>%s</a>]" % (url,description)+endTag
782:
783:
784: html=html+endHtml
785:
786: return html
787:
788: def mainNavBar(self):
789: """print main navigation bar"""
790: keys=""
1.13 dwinter 791:
1.1 dwinter 792: try:
793: keys=self.buttonsFromHash(self.createNavHash(0))
794: except:
795: keys=""
796:
797: return keys
798:
1.32 dwinter 799: def mainNavElements(self,location=None):
1.1 dwinter 800: """print main navigation bar"""
801: keys=""
1.12 dwinter 802: #print "NAVELEMENT",self.getId()
1.5 dwinter 803: #try:
1.32 dwinter 804:
805: keys=self.barFromHash(self.createNavHash(0),location=location)
1.12 dwinter 806:
1.5 dwinter 807: #except:
808: # keys=""
1.1 dwinter 809:
810: return keys
1.12 dwinter 811:
812: def numberOfMainNavElements(self):
1.58 dwinter 813: """number of main elements"""
1.12 dwinter 814:
1.58 dwinter 815: return len(self.barFromHash(self.createNavHash(0)))
1.12 dwinter 816:
1.29 dwinter 817: def startOfHierarchy(self,list):
818: splitted=self.pathToHierarchy.split("/")
819: last=splitted[len(splitted)-1]
820: #print last,list
821: try:
822: nr=list.index(last)
823: except:
824: nr=0
825: return nr+1
826:
1.1 dwinter 827: def secondNavElements(self):
1.57 casties 828: """Zweite Ordnung Navigationselemente"""
1.1 dwinter 829:
1.22 dwinter 830: hash=self.createNavHash(2,checkOnly="no")
1.1 dwinter 831: actual_url=self.REQUEST['URL']
832:
833: ult_temp=re.sub(self.absolute_url(),"",actual_url)
834: #print ult_temp
835:
836: splitted=ult_temp.split("/")
837:
1.58 dwinter 838: #print "AU",self.absolute_url(),splitted
839: #start=[splitted[2]] #orig
1.29 dwinter 840: startNr= self.startOfHierarchy(splitted)
841:
1.58 dwinter 842: start=[splitted[startNr]]
843:
1.29 dwinter 844: #print start
1.7 dwinter 845:
1.25 dwinter 846: keys=self.barFromHash(hash,start=start)
1.7 dwinter 847:
848:
849: return keys
850:
851: def navElements(self,order):
852: """n-te Ordnung"""
853:
854: hash=self.createNavHash(order)
855: actual_url=self.REQUEST['URL']
856:
857: ult_temp=re.sub(self.absolute_url(),"",actual_url)
858: #print ult_temp
859:
860: splitted=ult_temp.split("/")
861:
862:
863: ## if splitted[len(splitted)-1]=="index_html":
864: ## start=[splitted[len(splitted)-2]]
865: ## else:
866: ## start=[splitted[len(splitted)-1]]
867:
1.28 dwinter 868: #start=splitted[2:order+1] #orig
1.29 dwinter 869: startNr= self.startOfHierarchy(splitted)
1.30 dwinter 870: #print startNr
1.58 dwinter 871: start=splitted[startNr:order+startNr-1]
1.1 dwinter 872: #print start
1.5 dwinter 873:
1.1 dwinter 874: keys=self.barFromHash(hash,start=start)
875:
876:
877: return keys
878:
879:
880: def secondNavBar(self):
881: """Zweite Ordnung"""
882:
883: hash=self.createNavHash(2)
884: actual_url=self.REQUEST['URL']
885:
886: ult_temp=re.sub(self.absolute_url(),"",actual_url)
887: #print ult_temp
888:
889: splitted=ult_temp.split("/")
890:
891:
892: ## if splitted[len(splitted)-1]=="index_html":
893: ## start=[splitted[len(splitted)-2]]
894: ## else:
895: ## start=[splitted[len(splitted)-1]]
896:
897: start=[splitted[2]]
898: #print start
899:
900: keys=self.buttonsFromHash(hash,start=start,orientation="vertical")
901:
902:
903: return keys
904:
1.6 dwinter 905: def manage_addECHO_navigationForm(self):
1.1 dwinter 906: """Form for adding"""
1.48 dwinter 907: pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','AddECHO_navigation.zpt')).__of__(self)
1.1 dwinter 908: return pt()
909:
1.6 dwinter 910: def manage_addECHO_navigation(self,id,title,pathToHierarchy,RESPONSE=None):
1.1 dwinter 911: """Add an ECHO_root"""
912: self._setObject(id,ECHO_navigation(id,title,pathToHierarchy))
913:
914: if RESPONSE is not None:
915: RESPONSE.redirect('manage_main')
916:
917:
918: #helpers
919:
1.3 dwinter 920:
921:
922: def createPath(url1,url2):
923: temp1=url1.split("/")
924: temp2=url2.split("/")
925: for test in temp1:
926: if temp2[0]==test:
927: del temp2[0]
928:
1.28 dwinter 929: #print "CP:"+url1+"::"+url2+"::"+url1+"/"+string.join(temp2,"/")
1.3 dwinter 930: return url1+"/"+string.join(temp2,"/")
1.4 dwinter 931:
932: def sortWeight(x,y):
933: #print x[1],y[1]
934: return cmp(x[1],y[1])
1.1 dwinter 935:
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>