Annotation of ECHO_content/ECHO_Nav.py, revision 1.78
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):
1.72 dwinter 99: try:
100: return getattr(self,self.catalogId).uniqueValuesFor(self.field)
101: except:
102: #return getattr(self,self.catalogId).query(self.field)
103:
104: list= [x for x in getattr(getattr(self,self.catalogId),self.field).words()]
105: list.sort()
106: return list
1.35 dwinter 107:
108: def getNavList(self):
1.64 dwinter 109: """ausgabe der treffer list fuer navigation"""
1.37 dwinter 110:
1.35 dwinter 111: records=self.getKeywordList()
112:
1.64 dwinter 113: records=[x.encode('utf-8') for x in records]
114: records.sort()
1.35 dwinter 115: if not records:
116: return []
117: else:
118: ret=[]
119: for record in records:
1.64 dwinter 120:
1.35 dwinter 121: #print "RC",record
122: #if record:
123: # ret.append((record,self.baseUrl+urllib.quote(record)))
124: try:
125: ret.append((record,self.baseUrl+urllib.quote(record)))
126: except:
127: """nothing"""
128:
129: return ret
130:
131:
132: def manage_addECHO_ZCatalogElementForm(self):
133: """Form for adding"""
1.49 dwinter 134: pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','AddECHO_ZCatalogElement.zpt')).__of__(self)
1.35 dwinter 135: return pt()
136:
1.64 dwinter 137: def manage_addECHO_ZCatalogElement(self,id,title,field,catalogId,baseUrl,weight,contentType,RESPONSE=None):
1.35 dwinter 138: """Add an ECHO_ZCatalogelement"""
1.64 dwinter 139:
140: self._setObject(id,ECHO_ZCatalogElement(id,title,field,catalogId,baseUrl,weight,contentType))
1.35 dwinter 141:
142: if RESPONSE is not None:
143: RESPONSE.redirect('manage_main')
144:
145:
146:
1.11 dwinter 147: class ECHO_contentType(Image):
148: """ContentType Object"""
149:
150: meta_type="ECHO_contentType"
151:
152:
153: manage_options=Image.manage_options+(
154: {'label':'Change Description','action':'changeECHO_contentTypeForm'},
155: )
156:
157: def changeECHO_contentTypeForm(self):
158: """Change the description text"""
1.48 dwinter 159: pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','changeECHO_contentType.zpt')).__of__(self)
1.11 dwinter 160: return pt()
1.48 dwinter 161:
1.11 dwinter 162: def changeECHO_contentType(self,description,RESPONSE=None):
163: """Change the Content"""
164: self.description=description
165: if RESPONSE is not None:
166: RESPONSE.redirect('manage_main')
167:
168: manage_addECHO_contentTypeForm=DTMLFile('dtml/ECHO_contentTypeAdd',globals(),
169: Kind='ECHO_contentType',kind='ECHO_contentType')
170:
171: def manage_addECHO_contentType(self, id, file=None, title='', precondition='', content_type='', description='',
172: REQUEST=None):
173: """
174: Add a new Image object.
175:
176: Creates a new Image object 'id' with the contents of 'file'.
177: """
178:
179: id=str(id)
180: title=str(title)
181: content_type=str(content_type)
182: precondition=str(precondition)
183:
184: id, title = cookId(id, title, file)
185:
186: self=self.this()
187:
188: # First, we create the image without data:
189: self._setObject(id, ECHO_contentType(id,title,'',content_type, precondition))
190:
191: self._getOb(id).description=description
192:
193: # Now we "upload" the data. By doing this in two steps, we
194: # can use a database trick to make the upload more efficient.
195: if file:
196: self._getOb(id).manage_upload(file)
197: if content_type:
198: self._getOb(id).content_type=content_type
199:
200: if REQUEST is not None:
201: try: url=self.DestinationURL()
202: except: url=REQUEST['URL1']
203: REQUEST.RESPONSE.redirect('%s/manage_main' % url)
204: return id
205:
1.1 dwinter 206:
207: class ECHO_sqlElement(SimpleItem):
208: """Erzeuge navigation aus sql-abfrage"""
209: meta_type="ECHO_sqlElement"
210: baseUrl=""
1.41 dwinter 211:
212:
1.1 dwinter 213:
1.10 dwinter 214: def __init__(self,id,title,query,field,searchField,baseUrl,weight,contentType):
1.1 dwinter 215: """init"""
216: self.id=id
217: self.title=title
218: self.query=query
219: self.field=field
1.7 dwinter 220: if searchField=="":
221: self.searchField=field
222: else:
223: self.searchField=searchField
1.1 dwinter 224: self.baseUrl=baseUrl
1.38 dwinter 225:
1.10 dwinter 226: self.content=contentType
1.1 dwinter 227:
228: manage_options= SimpleItem.manage_options+(
229: {'label':'Main Config','action':'changeECHO_sqlElementForm'},
230: )
231:
1.7 dwinter 232: def getSearchField(self):
233: try:
234: return self.searchField
235: except:
236: return self.field
237:
1.3 dwinter 238: def getWeight(self):
1.4 dwinter 239: """get weight"""
240: if hasattr(self,'weight'):
241: return self.weight
1.3 dwinter 242: else:
243: return 0
244:
1.10 dwinter 245: def getcontentType(self):
1.6 dwinter 246: """get weight"""
247:
1.10 dwinter 248: if hasattr(self,'contentType'):
249: return self.contentType
1.6 dwinter 250: else:
251: return 0
1.3 dwinter 252:
253:
1.1 dwinter 254: def changeECHO_sqlElementForm(self):
255: """change"""
1.6 dwinter 256:
1.48 dwinter 257: pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','changeECHO_sqlElement.zpt')).__of__(self)
1.1 dwinter 258: return pt()
259:
1.10 dwinter 260: def changeECHO_sqlElement(self,title,query,field,searchField,baseUrl,weight,contentType,RESPONSE=None):
1.1 dwinter 261: """change"""
262: self.title=title
263: self.query=query
264: self.field=field
1.7 dwinter 265: self.searchField=searchField
1.1 dwinter 266: self.baseUrl=baseUrl
1.3 dwinter 267: self.weight=weight
1.10 dwinter 268: self.contentType=contentType
1.6 dwinter 269:
1.1 dwinter 270: if RESPONSE is not None:
271: RESPONSE.redirect('manage_main')
272:
1.49 dwinter 273: try:
274: searchQuery=ZSQLExtendFolder.ZSQLSimpleSearch
275: except:
276: zLOG.LOG('ECHO_Nav',zLOG.INFO,'ZSQLSimpleSearch not supported')
277:
278: def getNavList(self):
1.61 dwinter 279: """ausgabe der treffer list fuer navigation"""
1.37 dwinter 280:
1.60 dwinter 281: #naechste schritte sind trial and error, warum geht mal das eine mal das andere 2.3 / 2.4 ??
1.77 dwinter 282:
1.60 dwinter 283: try:
1.77 dwinter 284: try:
285: records=self.ZSQLSimpleSearch(query=self.query)
286: except:
287: records=self.searchQuery(self.aq_parent,query=self.query) #python 2.4 version (??)
1.60 dwinter 288: except:
1.77 dwinter 289: records=self.searchQuery(query=self.query)#python 2.3 version(??)
1.37 dwinter 290:
1.77 dwinter 291:
1.1 dwinter 292: if not records:
293: return []
294: else:
295: ret=[]
296: for record in records:
1.7 dwinter 297: try:
298: ret.append((getattr(record,self.field),self.baseUrl+urllib.quote(str(getattr(record,self.getSearchField())))))
299: except:
1.77 dwinter 300: zLOG.LOG('ECHO_Nav',zLOG.INFO,"error, search")
1.7 dwinter 301: """notrhing"""
302:
1.1 dwinter 303: return ret
304:
305:
1.6 dwinter 306: def manage_addECHO_sqlElementForm(self):
1.1 dwinter 307: """Form for adding"""
1.48 dwinter 308: pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','AddECHO_sqlElement.zpt')).__of__(self)
1.1 dwinter 309: return pt()
310:
1.10 dwinter 311: def manage_addECHO_sqlElement(self,id,title,query,field,searchField,baseUrl,weight,contentType,RESPONSE=None):
1.1 dwinter 312: """Add an ECHO_sqlelement"""
1.10 dwinter 313: self._setObject(id,ECHO_sqlElement(id,title,query,field,searchField,baseUrl,weight,contentType))
1.1 dwinter 314:
315: if RESPONSE is not None:
316: RESPONSE.redirect('manage_main')
317:
318:
1.51 dwinter 319: class ECHO_pageTemplate(ZopePageTemplate,ECHO_basis):
1.1 dwinter 320: """pageTemplate Objekt"""
321: meta_type="ECHO_pageTemplate"
1.54 dwinter 322: security=ClassSecurityInfo()
323:
1.56 dwinter 324:
1.1 dwinter 325: _default_content_fn = os.path.join(package_home(globals()),
1.6 dwinter 326: 'html/ECHO_pageTemplateDefault.html')
1.1 dwinter 327:
1.51 dwinter 328: manage_options=ZopePageTemplate.manage_options+ECHO_basis.manage_options+(
1.39 dwinter 329: {'label':'Main Config','action':'changeECHO_pageTemplateMainForm'},
1.56 dwinter 330: {'label':'Graphic Coords','action':'ECHO_graphicEntry'},
1.3 dwinter 331: )
1.23 dwinter 332:
1.54 dwinter 333: security.declarePublic('content_html')
334:
1.59 dwinter 335: def addChanges(self):
336: """do nothing leere methode, notwendig, da bei veerbung
337: von dieser klasse nur ueberschrieben werden kann,
338: falls methode per url aufgerufen werden soll"""
339:
340: return True
1.54 dwinter 341:
1.23 dwinter 342: def content_html(self):
1.58 dwinter 343: """content_html"""
344: return content_html(self,'pageTemplate')
1.3 dwinter 345:
1.39 dwinter 346: def changeECHO_pageTemplateMainForm(self):
1.4 dwinter 347: """change"""
1.48 dwinter 348: pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','ChangeECHO_pageTemplateMain.zpt')).__of__(self)
1.4 dwinter 349: return pt()
350:
1.47 dwinter 351: def changeECHO_pageTemplateMain(self,weight,contentType,label,description,RESPONSE=None,isAlwaysClickable=None,suffix=None,prefix=None):
1.4 dwinter 352: """change"""
353: self.weight=weight
1.10 dwinter 354: self.contentType=contentType
1.15 dwinter 355: self.label=label
1.39 dwinter 356: self.description=description
1.43 dwinter 357: self.isAlwaysClickable=isAlwaysClickable
1.47 dwinter 358: self.suffix=suffix
359: self.prefix=prefix
1.15 dwinter 360:
1.4 dwinter 361: if RESPONSE is not None:
362: RESPONSE.redirect('manage_main')
1.51 dwinter 363:
1.4 dwinter 364: def getWeight(self):
365: """get weight"""
366: if hasattr(self,'weight'):
367: return self.weight
368: else:
369: return 0
1.6 dwinter 370:
1.10 dwinter 371: def getcontentType(self):
1.33 jdamerow 372: """get contentType"""
373: if hasattr(self,'contentType'):
374: return self.contentType
1.6 dwinter 375: else:
376: return 0
377:
1.3 dwinter 378:
379:
1.1 dwinter 380:
1.10 dwinter 381: ## def __init__(self, id, text=None, contentType=None):
1.1 dwinter 382: ## self.id = str(id)
383: ## self.ZBindings_edit(self._default_bindings)
384: ## if text is None:
385: ## text = open(self._default_cont).read()
1.10 dwinter 386: ## self.pt_edit(text, contentType)
1.1 dwinter 387:
1.6 dwinter 388: def manage_addECHO_pageTemplateForm(self):
1.1 dwinter 389: """Form for adding"""
1.49 dwinter 390: pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','AddECHO_pageTemplate.zpt')).__of__(self)
1.1 dwinter 391: return pt()
392:
393: from urllib import quote
394:
395:
1.15 dwinter 396: def manage_addECHO_pageTemplate(self, id, label, weight= 0,contentType=0,title=None, text=None,
1.1 dwinter 397: REQUEST=None, submit=None):
398: "Add a Page Template with optional file content."
399:
400:
401: id = str(id)
402: if REQUEST is None:
403: self._setObject(id, ECHO_pageTemplate(id, text))
404: ob = getattr(self, id)
1.3 dwinter 405: setattr(ob,'weight',weight)
1.15 dwinter 406: setattr(ob,'label',label)
1.10 dwinter 407: setattr(ob,'contentType',contentType)
1.1 dwinter 408: if title:
409: ob.pt_setTitle(title)
410: return ob
411: else:
412: file = REQUEST.form.get('file')
413: headers = getattr(file, 'headers', None)
414: if headers is None or not file.filename:
415: zpt = ECHO_pageTemplate(id)
416: else:
1.10 dwinter 417: zpt = ECHO_pageTemplate(id, file, headers.get('contentType'))
1.1 dwinter 418:
419: self._setObject(id, zpt)
1.3 dwinter 420: ob = getattr(self, id)
421: setattr(ob,'weight',weight)
1.34 dwinter 422: setattr(ob,'label',label)
1.8 dwinter 423: if title:
424: ob.pt_setTitle(title)
425:
1.1 dwinter 426: try:
427: u = self.DestinationURL()
428: except AttributeError:
429: u = REQUEST['URL1']
430:
431: if submit == " Add and Edit ":
432: u = "%s/%s" % (u, quote(id))
433: REQUEST.RESPONSE.redirect(u+'/manage_main')
434: return ''
435:
436:
437: class ECHO_navigation(Folder):
438: """Navigations Element"""
439: meta_type="ECHO_Navigation"
1.69 dwinter 440: management_page_charset="utf-8"
1.74 dwinter 441:
442: def getUsername(self):
443: """get name of user"""
444: username=str(self.REQUEST['AUTHENTICATED_USER'])
445: if username=='Anonymous User':
446: return None
447: else:
448: return username
449:
1.67 dwinter 450: def searchExternalCollection(self,url,simpleSearch):
451: """search external collection via xmlrpc"""
452: server=xmlrpclib.Server(url)
453:
454: results=server.getSubcolsXMLRpc(simpleSearch)
455:
456: return results
457:
458: def getXMLRpcConnection(self,url):
459: """getxmlrpc"""
460: if not hasattr(self,"_v_server"):
461: self._v_server=[]
462:
463: server=xmlrpclib.Server(url)
464: self._v_server.append(server)
465:
466: return len(self._v_server)-1
467:
468: def getXMLRpcMethod(self,nr,method,compressed=None):
469: """getmethod"""
470:
471: ret= eval('self._v_server[%i].%s'%(nr,method))
472: if compressed:
473: ret=decodeRPC(ret)
474: return ret
475:
1.59 dwinter 476: def getNavInfo(self):
477: """root informationen"""
478: if hasattr(self,'logo_image'):
479: if hasattr(self.logo_image,'tag'):
480: imageTag=self.logo_image.tag()
481: else:
482: imageTag=''
483: return (self.title,imageTag)
484:
1.53 dwinter 485: def linkBar(self,parent):
486: """linkbarer balken"""
487: str=""
488:
489:
490: while not(parent.meta_type == "ECHO_root"):
491: fragment="""<a href="%s">%s</a>"""%(parent.absolute_url(),parent.label)
492: str=fragment+"/"+str
493: parent=parent.aq_parent
494:
495: return str
496:
497: def decode(self,str):
498: """decoder"""
499: if not str:
500: return ""
1.69 dwinter 501: if type(str) is StringType:
1.73 dwinter 502: try:
503: return str.decode('utf-8')
504: except:
505: return str.decode('latin-1')
1.69 dwinter 506: else:
1.53 dwinter 507:
508: return str
1.69 dwinter 509:
1.41 dwinter 510: def ECHOFormatListStr(self,list,search="\n",replace="<br>"):
511: """formatiert liste im str"""
1.58 dwinter 512: if list:
513: return re.sub(search,replace,list)
514: else:
515: return
1.42 dwinter 516:
1.41 dwinter 517: def ECHO_cacheManageForm(self):
1.58 dwinter 518: """change form"""
519: pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','ECHO_cacheManageForm')).__of__(self)
520: pt.content_type="text/html"
521: return pt()
1.41 dwinter 522:
523: def ECHO_cacheManage(self,cacheManagerName=None,deleteCache=None, activateCache=None,RESPONSE=None):
1.58 dwinter 524: """cachemanager"""
525: if cacheManagerName=="": chacheManagerName=None
526:
527: self.cacheManagerName=cacheManagerName
528: self.setCache(managerName=cacheManagerName)
529:
530: if deleteCache:
1.46 dwinter 531: try:
1.58 dwinter 532: self.deleteCache()
1.46 dwinter 533: except:
534: for roots in self.ZopeFind(self,obj_metatypes=['ECHO_root'],search_sub=1):
535: roots[1].deleteCache()
536:
1.41 dwinter 537:
1.58 dwinter 538: self.activateCache=activateCache
1.41 dwinter 539:
1.58 dwinter 540: if RESPONSE is not None:
541: RESPONSE.redirect('manage_main')
542:
1.41 dwinter 543: def setCache(self,obj=None,RESPONSE=None,managerName='CacheManager'):
544: """setze alle collections auf cache = CacheManager"""
545:
546:
547: if not obj:
548: obj = self
549:
1.58 dwinter 550: entries=obj.ZopeFind(obj,obj_metatypes=['ECHO_collection','VLP_resource'],search_sub=1)
1.41 dwinter 551:
552: for entry in entries:
553: entry[1].ZCacheable_setManagerId(managerName)
554:
555:
556: return "changed all CM in: "+self.title
557:
1.48 dwinter 558:
1.35 dwinter 559:
1.48 dwinter 560: displayableMetaTypes=displayTypes
561:
1.35 dwinter 562: def getImageViewers(self):
563: """images"""
564: viewers=self.ZopeFind(self.standardImageViewer,obj_metatypes=['OSAS_ViewerObject'])
565: return viewers
1.1 dwinter 566:
1.28 dwinter 567: def getR(self):
1.58 dwinter 568: """re"""
569: return self.REQUEST
1.28 dwinter 570:
1.1 dwinter 571: def __init__(self,id,title,pathToHierarchy):
572: """init"""
573: self.id=id
574: self.title=title
575: self.pathToHierarchy=pathToHierarchy
1.48 dwinter 576: self.displayedMetaTypes=displayTypes
577:
1.1 dwinter 578: manage_options = Folder.manage_options+(
579: {'label':'Main Config','action':'ECHO_navigationConfigForm'},
1.41 dwinter 580: {'label':'Cache','action':'ECHO_cacheManageForm'},
581:
1.1 dwinter 582: )
1.48 dwinter 583: displayedMetaTypes=displayTypes
584:
1.1 dwinter 585: def ECHO_navigationConfigForm(self):
586: """configForm"""
1.48 dwinter 587: pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','ChangeECHO_navigation.zpt')).__of__(self)
1.1 dwinter 588: return pt()
589:
1.48 dwinter 590: def ECHO_navigationConfig(self,title,pathToHierarchy,displayedMetaTypes=displayTypes,RESPONSE=None):
1.1 dwinter 591: """config"""
592: self.title=title
593: self.pathToHierarchy=pathToHierarchy
1.48 dwinter 594: self.displayedMetaTypes=toList(displayedMetaTypes)[0:]
595:
1.1 dwinter 596:
597: if RESPONSE is not None:
598: RESPONSE.redirect('manage_main')
599:
600:
1.19 dwinter 601: def getColls(self,obj,depth,checkOnly="no"):
1.1 dwinter 602: nav={}
603: #print "HERE",obj.
1.18 dwinter 604: for x_objs in obj.ZopeFind(obj,obj_metatypes=self.displayedMetaTypes):
605: x=x_objs[1]
1.22 dwinter 606: if checkOnly=="yes":
1.19 dwinter 607: x = checkOnlyOneInGroup(x)
1.18 dwinter 608: if depth>1:
609: nav[x.getId()]=(self.getColls(x,depth-1),x)
610: else:
611: nav[x.getId()]=(None,x)
1.1 dwinter 612: return nav
613:
1.19 dwinter 614: def createNavHash(self,depth,checkOnly="no"):
1.1 dwinter 615: """Auslesen des Hierarchiebuames"""
616: temp=self.pathToHierarchy[0:]
617: temp=re.sub("/",".",temp)
618: temp="self.aq_parent"+temp
1.40 dwinter 619:
1.1 dwinter 620:
621: objtemp=eval(temp)
622: nav={}
1.40 dwinter 623:
1.41 dwinter 624: #check if cash is enabled and if already exists and if not empty
625: if getattr(self,'_v_hash',None) and getattr(self,'activateCache',None) and self._v_hash.get(str(depth),None):
626:
627: return self._v_hash[str(depth)]
1.1 dwinter 628:
1.41 dwinter 629: # if not generate new hash
630: obj=objtemp
1.37 dwinter 631:
632: for keys in obj.ZopeFind(obj,obj_metatypes=self.displayedMetaTypes):
633: x=keys[1]
1.41 dwinter 634: if depth>1:
635: nav[x.getId()]=(self.getColls(x,int(depth)-1,checkOnly),x)
636: else:
637: nav[x.getId()]=(None,x)
1.37 dwinter 638:
1.41 dwinter 639: #store in cache if activated
640: if getattr(self,'activateCache',None):
641:
642: try:
643: self._v_hash[str(depth)]={}
644: except:
645: self._v_hash={}
646: self._v_hash[str(depth)]={}
1.1 dwinter 647:
1.41 dwinter 648: for x in nav.keys():
649: self._v_hash[str(depth)][x]=nav[x]
1.40 dwinter 650:
1.1 dwinter 651: return nav
652:
1.32 dwinter 653: def barFromHash(self,hash,start=None,sortField=None,location=None):
1.1 dwinter 654: """Erzeuge Navigations Element"""
1.68 dwinter 655:
1.1 dwinter 656: listNav=[]
657: if not start:
658: temp=hash
1.5 dwinter 659: sortField="weight"
1.41 dwinter 660: else: # liste mit pfad zum hash
1.1 dwinter 661: temp=hash
1.7 dwinter 662: #print "HI",sortField
1.5 dwinter 663: if not sortField:
664: tempObj=self.pathToHierarchy[0:]
665: tempObj=re.sub("/",".",tempObj)
666: tempObj="self.aq_parent"+tempObj
1.58 dwinter 667: #print tempObj
1.5 dwinter 668: objtemp=eval(tempObj)
669:
670: obj=objtemp
671:
672: for x in start:
1.7 dwinter 673: #print "OBJ",start,obj,obj.getId(),x
1.5 dwinter 674:
675: obj=getattr(obj,x)
676:
677: if hasattr(obj,'sortfield'):
678: sortField=obj.sortfield
679: else:
680: sortField='weight'
1.7 dwinter 681: #print "START",start
1.1 dwinter 682: for x in start:
1.7 dwinter 683: #print "N2",x,temp[x]
684: try:
1.5 dwinter 685: temp=temp[x][0]
1.7 dwinter 686: except:
687: """nothing"""
688: return []
689: #print "TEMP",temp,self.tempSorted(temp, field=sortField)
1.13 dwinter 690:
1.5 dwinter 691: for x in self.tempSorted(temp, field=sortField):
1.77 dwinter 692:
1.4 dwinter 693: if not temp[x][1].title == "":
1.35 dwinter 694:
695: if (temp[x][1].meta_type=="ECHO_sqlElement") or (temp[x][1].meta_type=="ECHO_ZCatalogElement"):
1.77 dwinter 696:
1.4 dwinter 697: for z in temp[x][1].getNavList():
1.47 dwinter 698: listNav.append((z[0],z[1],None,'',''))
1.37 dwinter 699:
1.4 dwinter 700: else:
1.27 dwinter 701: # add label falls existiert und nicht leer
1.7 dwinter 702: if hasattr(temp[x][1],'label'):
1.47 dwinter 703:
1.71 dwinter 704: if not temp[x][1].getLabel()=='':
1.47 dwinter 705: label=temp[x][1].getLabel()
1.7 dwinter 706: else:
1.71 dwinter 707: try:
708: label=temp[x][1].getTitle()
709: except:
710: zLOG.LOG("ECHO_Nav",zLOG.ERROR,"%s has neither getLabel nor getTile implemented"%temp[x][1].getId())
711: label=""
1.7 dwinter 712: else:
1.69 dwinter 713: label=temp[x][1].getTitle()
714:
1.63 dwinter 715:
1.51 dwinter 716: if location:
1.32 dwinter 717:
718: loc=getattr(temp[x][1],'location','top')
719: if (loc==location):
1.65 dwinter 720:
721:
722: listNav.append((label,createPath(self,self.absolute_url(),temp[x][1].absolute_url(relative=1))+getattr(temp[x][1],'queryString',''),temp[x][1],getattr(temp[x][1],'prefix',''),getattr(temp[x][1],'suffix','')))
1.32 dwinter 723: else:
1.65 dwinter 724:
725: listNav.append((label,createPath(self,self.absolute_url(),temp[x][1].absolute_url(relative=1))+getattr(temp[x][1],'queryString',''),temp[x][1],getattr(temp[x][1],'prefix',''),getattr(temp[x][1],'suffix','')))
726: #print self.REQUEST
1.1 dwinter 727: return listNav
728:
1.5 dwinter 729: def tempSorted(self,hash,field="weight"):
1.4 dwinter 730: ls=[]
1.13 dwinter 731:
1.4 dwinter 732: for x in hash.keys():
733: #print hash[x][1]
1.5 dwinter 734: if hasattr(hash[x][1],field):
1.52 dwinter 735: try:
736: weight=int(getattr(hash[x][1],field))
737: except:
738: weight=getattr(hash[x][1],field)
1.4 dwinter 739: #print weight
740: else:
741: weight=0
742:
743: ls.append((x,weight))
744:
745: ls.sort(sortWeight)
746:
747: return [x[0] for x in ls]
748:
749:
750:
751:
1.1 dwinter 752: def isSelectedPath(self,item):
753: """test is path is already selected"""
1.45 dwinter 754:
755: testStr=re.sub("/index_html",'',self.REQUEST.get('URL',''))
1.70 dwinter 756:
757: if len(item)<2:
758: return 0
1.45 dwinter 759: #falls exakte Übereinstimmung dann immer 1
1.70 dwinter 760: if (testStr==item[1]) and (self.REQUEST.get('QUERY_STRING','')==''):
1.45 dwinter 761:
762: return 1
763:
764: found=re.search("\?(.*)",item[1])
1.43 dwinter 765:
1.1 dwinter 766: if found:
767: temp=re.sub(" ","%20",found.group(0))
1.45 dwinter 768:
1.1 dwinter 769: #print temp+"::"+self.REQUEST['QUERY_STRING']
770: if ("?"+self.REQUEST['QUERY_STRING'])==temp:
1.43 dwinter 771: if getattr(item[2],'isAlwaysClickable',None): #immer auswaehlbar?
772:
773: return 2
774: else:
775: return 1
776:
1.44 dwinter 777: if (getattr(item[2],'meta_type','')=="ECHO_pageTemplate") and (re.search(item[1],self.REQUEST['URL'])):
1.43 dwinter 778: if getattr(item[2],'isAlwaysClickable',None): #immer auswaehlbar?
779:
780: return 2
781: else:
1.1 dwinter 782: return 1
783:
1.26 dwinter 784: if re.search(item[1]+"/",self.REQUEST['URL']):
1.43 dwinter 785: if getattr(item[2],'isAlwaysClickable',None): #immer auswaehlbar?
786:
787: return 2
788: else:
789: return 1
1.1 dwinter 790: else:
791: return 0
1.57 casties 792:
793:
794: def getPathStyle(self, item, style=""):
1.58 dwinter 795: """returns a string with the given style + 'sel' if the path is already selected."""
1.43 dwinter 796:
1.58 dwinter 797: if self.isSelectedPath(item):
798: return style + 'sel'
799: else:
800: return style
1.1 dwinter 801:
802:
803: def buttonsFromHash(self,hash,start=None,orientation="horizontal"):
804:
805: """Generate Buttons"""
806: if orientation=="horizontal":
807: html="<table><tr>"
808: startTag="<td>"
809: endTag="</td>"
810: endHtml="</tr></table>"
811:
812: else:
813: html="<table>"
814: startTag="<tr><td>"
815: endTag="</td></tr>"
816: endHtml="</table>"
817:
818: if not start:
819: temp=hash
820: else:
821: temp=hash
822: for x in start:
823: temp=temp[x][0]
824: #print temp
825:
1.5 dwinter 826: for key in self.tempSorted(temp):
1.1 dwinter 827:
828: description=temp[x][1].title
1.65 dwinter 829:
830:
831: url=createPath(self,self.absolute_url(),temp[key][1].absolute_url(relative=1))
1.2 dwinter 832:
1.1 dwinter 833: if (self.REQUEST['URL']==url) | (self.REQUEST['URL']==url+"/index_html"):
834: html=html+startTag+"[%s]" % description+endTag
835: else:
836: html=html+startTag+"[<a href='%s'>%s</a>]" % (url,description)+endTag
837:
838:
839: html=html+endHtml
840:
841: return html
842:
843: def mainNavBar(self):
844: """print main navigation bar"""
845: keys=""
1.13 dwinter 846:
1.1 dwinter 847: try:
848: keys=self.buttonsFromHash(self.createNavHash(0))
849: except:
850: keys=""
851:
852: return keys
853:
1.32 dwinter 854: def mainNavElements(self,location=None):
1.1 dwinter 855: """print main navigation bar"""
856: keys=""
1.12 dwinter 857: #print "NAVELEMENT",self.getId()
1.5 dwinter 858: #try:
1.32 dwinter 859:
860: keys=self.barFromHash(self.createNavHash(0),location=location)
1.12 dwinter 861:
1.5 dwinter 862: #except:
863: # keys=""
1.71 dwinter 864:
1.1 dwinter 865: return keys
1.12 dwinter 866:
867: def numberOfMainNavElements(self):
1.58 dwinter 868: """number of main elements"""
1.12 dwinter 869:
1.58 dwinter 870: return len(self.barFromHash(self.createNavHash(0)))
1.12 dwinter 871:
1.29 dwinter 872: def startOfHierarchy(self,list):
873: splitted=self.pathToHierarchy.split("/")
874: last=splitted[len(splitted)-1]
875: #print last,list
876: try:
877: nr=list.index(last)
878: except:
879: nr=0
880: return nr+1
881:
1.78 ! dwinter 882: def subNavStatic(self,obj):
! 883: """subnav" von self"""
! 884: def sortWeight(x,y):
! 885: x1=int(getattr(x[1],'weight','0'))
! 886: y1=int(getattr(y[1],'weight','0'))
! 887: return cmp(x1,y1)
! 888: print "obj",obj
! 889: subs=self.ZopeFind(obj,obj_metatypes=self.displayedMetaTypes)
! 890: subret=[]
! 891:
! 892: for x in subs:
! 893: if not(x[1].title==""):
! 894: subret.append(x)
! 895: subret.sort(sortWeight)
! 896: return subret
! 897:
1.1 dwinter 898: def secondNavElements(self):
1.57 casties 899: """Zweite Ordnung Navigationselemente"""
1.1 dwinter 900:
1.22 dwinter 901: hash=self.createNavHash(2,checkOnly="no")
1.68 dwinter 902:
1.1 dwinter 903: actual_url=self.REQUEST['URL']
904:
905: ult_temp=re.sub(self.absolute_url(),"",actual_url)
906: #print ult_temp
907:
908: splitted=ult_temp.split("/")
909:
1.58 dwinter 910: #print "AU",self.absolute_url(),splitted
911: #start=[splitted[2]] #orig
1.29 dwinter 912: startNr= self.startOfHierarchy(splitted)
913:
1.58 dwinter 914: start=[splitted[startNr]]
915:
1.29 dwinter 916: #print start
1.68 dwinter 917:
1.25 dwinter 918: keys=self.barFromHash(hash,start=start)
1.7 dwinter 919:
920:
921: return keys
922:
923: def navElements(self,order):
924: """n-te Ordnung"""
925:
926: hash=self.createNavHash(order)
927: actual_url=self.REQUEST['URL']
928:
929: ult_temp=re.sub(self.absolute_url(),"",actual_url)
930: #print ult_temp
931:
932: splitted=ult_temp.split("/")
933:
934:
935: ## if splitted[len(splitted)-1]=="index_html":
936: ## start=[splitted[len(splitted)-2]]
937: ## else:
938: ## start=[splitted[len(splitted)-1]]
939:
1.28 dwinter 940: #start=splitted[2:order+1] #orig
1.29 dwinter 941: startNr= self.startOfHierarchy(splitted)
1.30 dwinter 942: #print startNr
1.58 dwinter 943: start=splitted[startNr:order+startNr-1]
1.1 dwinter 944: #print start
1.5 dwinter 945:
1.1 dwinter 946: keys=self.barFromHash(hash,start=start)
947:
948:
949: return keys
950:
951:
952: def secondNavBar(self):
953: """Zweite Ordnung"""
954:
955: hash=self.createNavHash(2)
956: actual_url=self.REQUEST['URL']
957:
958: ult_temp=re.sub(self.absolute_url(),"",actual_url)
959: #print ult_temp
960:
961: splitted=ult_temp.split("/")
962:
963:
964: ## if splitted[len(splitted)-1]=="index_html":
965: ## start=[splitted[len(splitted)-2]]
966: ## else:
967: ## start=[splitted[len(splitted)-1]]
968:
969: start=[splitted[2]]
970: #print start
971:
972: keys=self.buttonsFromHash(hash,start=start,orientation="vertical")
973:
974:
975: return keys
976:
1.6 dwinter 977: def manage_addECHO_navigationForm(self):
1.1 dwinter 978: """Form for adding"""
1.48 dwinter 979: pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','AddECHO_navigation.zpt')).__of__(self)
1.1 dwinter 980: return pt()
981:
1.6 dwinter 982: def manage_addECHO_navigation(self,id,title,pathToHierarchy,RESPONSE=None):
1.1 dwinter 983: """Add an ECHO_root"""
984: self._setObject(id,ECHO_navigation(id,title,pathToHierarchy))
985:
986: if RESPONSE is not None:
987: RESPONSE.redirect('manage_main')
988:
989:
990: #helpers
991:
1.3 dwinter 992:
993:
1.65 dwinter 994: def createPath(self,url1,url2):
995: #bugfix in absolute_url, ploetzlich erschein in absolute_url der physikalische pfad.
996:
1.66 dwinter 997: if self.REQUEST.has_key('VirtualRootPhysicalPath'):
998: vp="/".join(self.REQUEST['VirtualRootPhysicalPath'])
1.76 dwinter 999: if (len(vp)>0):
1000: if vp[0]=="/":
1001: vp=vp[1:]
1.66 dwinter 1002:
1.76 dwinter 1003: url2=url2.replace(vp+"/",'')
1.68 dwinter 1004: else:
1005: temp1=url1.split("/")
1006: temp2=url2.split("/")
1007: for test in temp1:
1008: if temp2[0]==test:
1009: del temp2[0]
1010:
1011: url2= string.join(temp2,"/")
1.66 dwinter 1012:
1.65 dwinter 1013: return url1+"/"+url2
1.4 dwinter 1014:
1015: def sortWeight(x,y):
1016: #print x[1],y[1]
1017: return cmp(x[1],y[1])
1.1 dwinter 1018:
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>