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