File:  [Repository] / ECHO_content / ECHO_Nav.py
Revision 1.47: download - view: text, annotated - select for diffs - revision graph
Mon Sep 27 14:39:59 2004 UTC (19 years, 8 months ago) by dwinter
Branches: MAIN
CVS tags: HEAD
prefix /suffix for pagetemplate

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

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>