File:  [Repository] / ECHO_content / ECHO_Nav.py
Revision 1.71: download - view: text, annotated - select for diffs - revision graph
Mon Jan 16 17:33:00 2006 UTC (18 years, 4 months ago) by dwinter
Branches: MAIN
CVS tags: HEAD
minor

    1: # Objekte zur Erzeugung von Navigationselement
    2: from AccessControl import ClassSecurityInfo
    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 *
   16: from ECHO_collection import content_html 
   17: from types import *
   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: 
   31: import urllib
   32: from ECHO_helpers import displayTypes,checkOnlyOneInGroup
   33: from ECHO_collection import content_html
   34: import zLOG
   35: 
   36: try:    
   37:     from Products.ZSQLExtend.ZSQLExtend import ZSQLExtendFolder
   38: except:
   39:     zLOG.LOG('ECHO_Nav',zLOG.INFO,'ZSQLSimpleSearch not supported')
   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: 
   59:         
   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:         
   84:         pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','changeECHO_ZCatalogElement.zpt')).__of__(self)
   85:         return pt()
   86: 
   87:     def changeECHO_ZCatalogElement(self,title,field,catalogId,baseUrl,weight,contentType,RESPONSE=None):
   88:         """change"""
   89:         self.title=title
   90:         self.catalogId=catalogId
   91:         self.field=field
   92:         self.baseUrl=baseUrl
   93:         self.weight=weight
   94:         self.contentType=contentType
   95:         
   96:         if RESPONSE is not None:
   97:             RESPONSE.redirect('manage_main')
   98:     def getKeywordList(self):
   99:         return getattr(self,self.catalogId).uniqueValuesFor(self.field)
  100:     
  101:     def getNavList(self):
  102:         """ausgabe der treffer list fuer navigation"""
  103:         
  104:         records=self.getKeywordList()
  105:         
  106:         records=[x.encode('utf-8') for x in records]
  107:         records.sort()
  108:         if not records:
  109:             return []
  110:         else:
  111:             ret=[]
  112:             for record in records:
  113:              
  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"""
  127:     pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','AddECHO_ZCatalogElement.zpt')).__of__(self)
  128:     return pt()
  129: 
  130: def manage_addECHO_ZCatalogElement(self,id,title,field,catalogId,baseUrl,weight,contentType,RESPONSE=None):
  131:     """Add an ECHO_ZCatalogelement"""
  132: 
  133:     self._setObject(id,ECHO_ZCatalogElement(id,title,field,catalogId,baseUrl,weight,contentType))
  134:     
  135:     if RESPONSE is not None:
  136:         RESPONSE.redirect('manage_main')
  137: 
  138: 
  139: 
  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"""
  152:         pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','changeECHO_contentType.zpt')).__of__(self)
  153:         return pt()
  154:  
  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: 
  199: 
  200: class ECHO_sqlElement(SimpleItem):
  201:     """Erzeuge navigation aus sql-abfrage"""
  202:     meta_type="ECHO_sqlElement"
  203:     baseUrl=""
  204: 
  205: 
  206:     
  207:     def __init__(self,id,title,query,field,searchField,baseUrl,weight,contentType):
  208:         """init"""
  209:         self.id=id
  210:         self.title=title
  211:         self.query=query
  212:         self.field=field
  213:         if searchField=="":
  214:             self.searchField=field
  215:         else:
  216:             self.searchField=searchField
  217:         self.baseUrl=baseUrl
  218: 
  219:         self.content=contentType
  220: 
  221:     manage_options= SimpleItem.manage_options+(
  222:         {'label':'Main Config','action':'changeECHO_sqlElementForm'},
  223:         )
  224: 
  225:     def getSearchField(self):
  226:         try:
  227:             return self.searchField
  228:         except:
  229:             return self.field
  230:         
  231:     def getWeight(self):
  232:         """get weight"""
  233:         if hasattr(self,'weight'):
  234:             return self.weight
  235:         else:
  236:             return 0
  237:         
  238:     def getcontentType(self):
  239:         """get weight"""
  240:         
  241:         if hasattr(self,'contentType'):
  242:             return self.contentType
  243:         else:
  244:             return 0
  245:         
  246: 
  247:     def changeECHO_sqlElementForm(self):
  248:         """change"""
  249:         
  250:         pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','changeECHO_sqlElement.zpt')).__of__(self)
  251:         return pt()
  252: 
  253:     def changeECHO_sqlElement(self,title,query,field,searchField,baseUrl,weight,contentType,RESPONSE=None):
  254:         """change"""
  255:         self.title=title
  256:         self.query=query
  257:         self.field=field
  258:         self.searchField=searchField
  259:         self.baseUrl=baseUrl
  260:         self.weight=weight
  261:         self.contentType=contentType
  262:         
  263:         if RESPONSE is not None:
  264:             RESPONSE.redirect('manage_main')
  265: 
  266:     try:    
  267:         searchQuery=ZSQLExtendFolder.ZSQLSimpleSearch
  268:     except:
  269:         zLOG.LOG('ECHO_Nav',zLOG.INFO,'ZSQLSimpleSearch not supported')
  270:             
  271:     def getNavList(self): 
  272:         """ausgabe der treffer list fuer navigation"""
  273:         
  274:         #naechste schritte sind trial and error, warum geht mal das eine mal das andere 2.3 / 2.4 ??
  275:         
  276:         try:
  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 (??)
  281:         except:
  282:             records=self.searchQuery()#python 2.3 version(??)
  283:       
  284:         
  285:         if not records:
  286:             return []
  287:         else:
  288:             ret=[]
  289:             for record in records:
  290:                 try:
  291:                     ret.append((getattr(record,self.field),self.baseUrl+urllib.quote(str(getattr(record,self.getSearchField())))))
  292:                 except:
  293:                     """notrhing"""
  294:                     
  295:             return ret
  296:     
  297: 
  298: def manage_addECHO_sqlElementForm(self):
  299:     """Form for adding"""
  300:     pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','AddECHO_sqlElement.zpt')).__of__(self)
  301:     return pt()
  302: 
  303: def manage_addECHO_sqlElement(self,id,title,query,field,searchField,baseUrl,weight,contentType,RESPONSE=None):
  304:     """Add an ECHO_sqlelement"""
  305:     self._setObject(id,ECHO_sqlElement(id,title,query,field,searchField,baseUrl,weight,contentType))
  306:     
  307:     if RESPONSE is not None:
  308:         RESPONSE.redirect('manage_main')
  309: 
  310: 
  311: class ECHO_pageTemplate(ZopePageTemplate,ECHO_basis):
  312:     """pageTemplate Objekt"""
  313:     meta_type="ECHO_pageTemplate"
  314:     security=ClassSecurityInfo()
  315:     
  316:     
  317:     _default_content_fn = os.path.join(package_home(globals()),
  318:                                        'html/ECHO_pageTemplateDefault.html')
  319: 
  320:     manage_options=ZopePageTemplate.manage_options+ECHO_basis.manage_options+(
  321:         {'label':'Main Config','action':'changeECHO_pageTemplateMainForm'},
  322:         {'label':'Graphic Coords','action':'ECHO_graphicEntry'},
  323:         )
  324: 
  325:     security.declarePublic('content_html')
  326: 
  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
  333:     
  334:     def content_html(self):
  335:         """content_html"""
  336:         return content_html(self,'pageTemplate')
  337: 
  338:     def changeECHO_pageTemplateMainForm(self):
  339:         """change"""
  340:         pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','ChangeECHO_pageTemplateMain.zpt')).__of__(self)
  341:         return pt()
  342: 
  343:     def changeECHO_pageTemplateMain(self,weight,contentType,label,description,RESPONSE=None,isAlwaysClickable=None,suffix=None,prefix=None):
  344:         """change"""
  345:         self.weight=weight
  346:         self.contentType=contentType
  347:         self.label=label
  348:         self.description=description
  349:         self.isAlwaysClickable=isAlwaysClickable
  350:         self.suffix=suffix
  351:         self.prefix=prefix
  352:         
  353:         if RESPONSE is not None:
  354:             RESPONSE.redirect('manage_main')
  355:      
  356:     def getWeight(self):
  357:         """get weight"""
  358:         if hasattr(self,'weight'):
  359:             return self.weight
  360:         else:
  361:             return 0
  362:         
  363:     def getcontentType(self):
  364:         """get contentType"""
  365:         if hasattr(self,'contentType'):
  366:             return self.contentType
  367:         else:
  368:             return 0
  369: 
  370: 
  371: 
  372: 
  373:     ## def __init__(self, id, text=None, contentType=None):
  374: ##         self.id = str(id)
  375: ##         self.ZBindings_edit(self._default_bindings)
  376: ##         if text is None:
  377: ##             text = open(self._default_cont).read()
  378: ##         self.pt_edit(text, contentType)
  379: 
  380: def manage_addECHO_pageTemplateForm(self):
  381:     """Form for adding"""
  382:     pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','AddECHO_pageTemplate.zpt')).__of__(self)
  383:     return pt()
  384: 
  385: from urllib import quote
  386: 
  387: 
  388: def manage_addECHO_pageTemplate(self, id, label, weight= 0,contentType=0,title=None, text=None,
  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)
  397:         setattr(ob,'weight',weight)
  398:         setattr(ob,'label',label)
  399:         setattr(ob,'contentType',contentType)
  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:
  409:             zpt = ECHO_pageTemplate(id, file, headers.get('contentType'))
  410: 
  411:         self._setObject(id, zpt)
  412:         ob = getattr(self, id)
  413:         setattr(ob,'weight',weight)
  414:         setattr(ob,'label',label)
  415:         if title:
  416:             ob.pt_setTitle(title)
  417:         
  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:     management_page_charset="utf-8"
  433:     def searchExternalCollection(self,url,simpleSearch):
  434:         """search external collection via xmlrpc"""
  435:         server=xmlrpclib.Server(url)
  436:         
  437:         results=server.getSubcolsXMLRpc(simpleSearch)
  438:         
  439:         return results
  440:     
  441:     def getXMLRpcConnection(self,url):
  442:         """getxmlrpc"""
  443:         if not hasattr(self,"_v_server"):
  444:             self._v_server=[]
  445:         
  446:         server=xmlrpclib.Server(url)
  447:         self._v_server.append(server)
  448:         
  449:         return len(self._v_server)-1
  450:     
  451:     def getXMLRpcMethod(self,nr,method,compressed=None):
  452:         """getmethod"""
  453:         
  454:         ret= eval('self._v_server[%i].%s'%(nr,method))
  455:         if compressed:
  456:             ret=decodeRPC(ret)
  457:         return ret
  458:     
  459:     def getNavInfo(self):
  460:         """root informationen"""
  461:         if hasattr(self,'logo_image'):
  462:             if hasattr(self.logo_image,'tag'):
  463:                 imageTag=self.logo_image.tag()
  464:         else:
  465:             imageTag=''
  466:         return (self.title,imageTag)
  467: 
  468:     def linkBar(self,parent):
  469:         """linkbarer balken"""
  470:         str=""
  471: 
  472:         
  473:         while not(parent.meta_type == "ECHO_root"):
  474:             fragment="""<a href="%s">%s</a>"""%(parent.absolute_url(),parent.label)
  475:             str=fragment+"/"+str
  476:             parent=parent.aq_parent
  477: 
  478:         return str
  479:     
  480:     def decode(self,str):
  481:         """decoder"""
  482:         if not str:
  483:             return ""
  484:         if type(str) is StringType:
  485:             
  486:             return str.decode('utf-8')
  487:         else:
  488:             
  489:             return str
  490: 
  491:     def ECHOFormatListStr(self,list,search="\n",replace="<br>"):
  492:         """formatiert liste im str"""
  493:         if list:
  494:                 return re.sub(search,replace,list)
  495:         else:
  496:                 return 
  497: 
  498:     def ECHO_cacheManageForm(self):
  499:             """change form"""
  500:             pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','ECHO_cacheManageForm')).__of__(self)
  501:             pt.content_type="text/html"
  502:             return pt()
  503: 
  504:     def ECHO_cacheManage(self,cacheManagerName=None,deleteCache=None, activateCache=None,RESPONSE=None):
  505:             """cachemanager"""
  506:             if cacheManagerName=="": chacheManagerName=None
  507:             
  508:             self.cacheManagerName=cacheManagerName
  509:             self.setCache(managerName=cacheManagerName)
  510:             
  511:             if deleteCache:
  512:                 try:
  513:                     self.deleteCache()
  514:                 except:
  515:                     for roots in self.ZopeFind(self,obj_metatypes=['ECHO_root'],search_sub=1):
  516:                         roots[1].deleteCache()
  517:                     
  518: 
  519:             self.activateCache=activateCache
  520: 
  521:             if RESPONSE is not None:
  522:                     RESPONSE.redirect('manage_main')
  523:         
  524:     def setCache(self,obj=None,RESPONSE=None,managerName='CacheManager'):
  525:         """setze alle collections auf cache = CacheManager"""
  526: 
  527: 
  528:         if not obj:
  529:             obj = self
  530:             
  531:         entries=obj.ZopeFind(obj,obj_metatypes=['ECHO_collection','VLP_resource'],search_sub=1)
  532: 
  533:         for entry in entries:
  534:             entry[1].ZCacheable_setManagerId(managerName)
  535: 
  536:         
  537:         return "changed all CM in: "+self.title
  538: 
  539:     
  540: 
  541:     displayableMetaTypes=displayTypes
  542:     
  543:     def getImageViewers(self):
  544:         """images"""
  545:         viewers=self.ZopeFind(self.standardImageViewer,obj_metatypes=['OSAS_ViewerObject'])
  546:         return viewers
  547:     
  548:     def getR(self):
  549:         """re"""
  550:         return self.REQUEST
  551: 
  552:     def __init__(self,id,title,pathToHierarchy):
  553:         """init"""
  554:         self.id=id
  555:         self.title=title
  556:         self.pathToHierarchy=pathToHierarchy
  557:         self.displayedMetaTypes=displayTypes
  558:         
  559:     manage_options = Folder.manage_options+(
  560:         {'label':'Main Config','action':'ECHO_navigationConfigForm'},
  561:         {'label':'Cache','action':'ECHO_cacheManageForm'},
  562: 
  563:         )
  564:     displayedMetaTypes=displayTypes
  565:     
  566:     def ECHO_navigationConfigForm(self):
  567:         """configForm"""
  568:         pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','ChangeECHO_navigation.zpt')).__of__(self)
  569:         return pt()
  570:     
  571:     def ECHO_navigationConfig(self,title,pathToHierarchy,displayedMetaTypes=displayTypes,RESPONSE=None):
  572:         """config"""
  573:         self.title=title
  574:         self.pathToHierarchy=pathToHierarchy
  575:         self.displayedMetaTypes=toList(displayedMetaTypes)[0:]
  576: 
  577: 
  578:         if RESPONSE is not None:
  579:             RESPONSE.redirect('manage_main')
  580: 
  581: 
  582:     def getColls(self,obj,depth,checkOnly="no"):
  583:         nav={}
  584:         #print "HERE",obj.
  585:         for x_objs in obj.ZopeFind(obj,obj_metatypes=self.displayedMetaTypes):
  586:             x=x_objs[1]
  587:             if checkOnly=="yes":
  588:                 x = checkOnlyOneInGroup(x)
  589:             if depth>1:
  590:                 nav[x.getId()]=(self.getColls(x,depth-1),x)
  591:             else:
  592:                 nav[x.getId()]=(None,x)
  593:         return nav
  594:     
  595:     def createNavHash(self,depth,checkOnly="no"):
  596:         """Auslesen des Hierarchiebuames"""
  597:         temp=self.pathToHierarchy[0:]
  598:         temp=re.sub("/",".",temp)
  599:         temp="self.aq_parent"+temp
  600: 
  601:         
  602:         objtemp=eval(temp)
  603:         nav={}
  604:         
  605:         #check if cash is enabled and if already exists and if not empty
  606:         if getattr(self,'_v_hash',None) and getattr(self,'activateCache',None) and self._v_hash.get(str(depth),None):
  607:            
  608:            return self._v_hash[str(depth)]
  609: 
  610:         # if not generate new hash
  611:         obj=objtemp      
  612: 
  613:         for keys in obj.ZopeFind(obj,obj_metatypes=self.displayedMetaTypes):
  614:             x=keys[1]
  615:             if depth>1:
  616:                 nav[x.getId()]=(self.getColls(x,int(depth)-1,checkOnly),x)
  617:             else:
  618:                 nav[x.getId()]=(None,x)
  619:             
  620:         #store in cache if activated
  621:         if getattr(self,'activateCache',None):
  622:             
  623:             try:
  624:                 self._v_hash[str(depth)]={}
  625:             except:
  626:                 self._v_hash={}
  627:                 self._v_hash[str(depth)]={}
  628: 
  629:             for x in nav.keys():
  630:                 self._v_hash[str(depth)][x]=nav[x]
  631: 
  632:         return nav
  633: 
  634:     def barFromHash(self,hash,start=None,sortField=None,location=None):
  635:         """Erzeuge Navigations Element"""
  636:                 
  637:         listNav=[]
  638:         if not start:
  639:             temp=hash
  640:             sortField="weight"
  641:         else: # liste mit pfad zum hash
  642:             temp=hash
  643:             #print "HI",sortField
  644:             if not sortField:
  645:                 tempObj=self.pathToHierarchy[0:]
  646:                 tempObj=re.sub("/",".",tempObj)
  647:                 tempObj="self.aq_parent"+tempObj
  648:                 #print tempObj
  649:                 objtemp=eval(tempObj)
  650: 
  651:                 obj=objtemp
  652: 
  653:                 for x in start:
  654:                     #print "OBJ",start,obj,obj.getId(),x
  655: 
  656:                     obj=getattr(obj,x)
  657: 
  658:                 if hasattr(obj,'sortfield'):
  659:                     sortField=obj.sortfield
  660:                 else:
  661:                     sortField='weight'
  662:             #print "START",start
  663:             for x in start:
  664:                 #print "N2",x,temp[x]
  665:                 try:
  666:                     temp=temp[x][0]
  667:                 except:
  668:                     """nothing"""
  669:                     return []
  670:             #print "TEMP",temp,self.tempSorted(temp, field=sortField)
  671: 
  672:         for x in self.tempSorted(temp, field=sortField):
  673:             
  674:             if not temp[x][1].title == "":
  675:                 
  676:                 if (temp[x][1].meta_type=="ECHO_sqlElement") or (temp[x][1].meta_type=="ECHO_ZCatalogElement"):
  677:             
  678:                     for z in temp[x][1].getNavList():
  679:                         listNav.append((z[0],z[1],None,'',''))
  680:             
  681:                 else:
  682:                     # add label falls existiert und nicht leer
  683:                     if hasattr(temp[x][1],'label'):
  684:                         
  685:                         if not temp[x][1].getLabel()=='':
  686:                                 label=temp[x][1].getLabel()
  687:                         else:
  688:                             try:
  689:                                 label=temp[x][1].getTitle()
  690:                             except:
  691:                                 zLOG.LOG("ECHO_Nav",zLOG.ERROR,"%s has neither getLabel nor getTile implemented"%temp[x][1].getId())
  692:                                 label=""
  693:                     else:
  694:                         label=temp[x][1].getTitle()
  695: 
  696:                         
  697:                     if location:
  698: 
  699:                         loc=getattr(temp[x][1],'location','top')
  700:                         if (loc==location):
  701: 
  702:                             
  703:                             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','')))
  704:                     else:
  705:                         
  706:                         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','')))
  707:         #print self.REQUEST
  708:         return listNav
  709: 
  710:     def tempSorted(self,hash,field="weight"):
  711:         ls=[]
  712: 
  713:         for x in hash.keys():
  714:             #print hash[x][1]
  715:             if hasattr(hash[x][1],field):
  716:                 try:
  717:                     weight=int(getattr(hash[x][1],field))
  718:                 except:
  719:                     weight=getattr(hash[x][1],field)
  720:                 #print weight
  721:             else:
  722:                 weight=0
  723: 
  724:             ls.append((x,weight))
  725: 
  726:         ls.sort(sortWeight)
  727:         
  728:         return [x[0] for x in ls]
  729: 
  730:     
  731:         
  732:             
  733:     def isSelectedPath(self,item):
  734:         """test is path is already selected"""
  735: 
  736:         testStr=re.sub("/index_html",'',self.REQUEST.get('URL',''))
  737: 	
  738: 	if len(item)<2:
  739: 		return 0
  740:         #falls exakte Übereinstimmung dann immer 1
  741:         if  (testStr==item[1]) and (self.REQUEST.get('QUERY_STRING','')==''):
  742:             
  743:             return 1
  744:            
  745:         found=re.search("\?(.*)",item[1])
  746:         
  747:         if found:
  748:             temp=re.sub(" ","%20",found.group(0))
  749:           
  750:             #print temp+"::"+self.REQUEST['QUERY_STRING']
  751:             if ("?"+self.REQUEST['QUERY_STRING'])==temp:
  752:                 if getattr(item[2],'isAlwaysClickable',None): #immer auswaehlbar?
  753:                 
  754:                     return 2
  755:                 else:
  756:                     return 1
  757: 
  758:         if (getattr(item[2],'meta_type','')=="ECHO_pageTemplate") and (re.search(item[1],self.REQUEST['URL'])):
  759:             if getattr(item[2],'isAlwaysClickable',None): #immer auswaehlbar?
  760:                 
  761:                 return 2
  762:             else:
  763:                 return 1
  764: 
  765:         if re.search(item[1]+"/",self.REQUEST['URL']):
  766:             if getattr(item[2],'isAlwaysClickable',None): #immer auswaehlbar?
  767:                 
  768:                 return 2
  769:             else:
  770:                 return 1
  771:         else:
  772:             return 0
  773:     
  774: 
  775:     def getPathStyle(self, item, style=""):
  776:         """returns a string with the given style + 'sel' if the path is already selected."""
  777: 
  778:         if self.isSelectedPath(item):
  779:             return style + 'sel'
  780:         else:
  781:             return style
  782:         
  783:     
  784:     def buttonsFromHash(self,hash,start=None,orientation="horizontal"):
  785:         
  786:         """Generate Buttons"""
  787:         if orientation=="horizontal":
  788:             html="<table><tr>"
  789:             startTag="<td>"
  790:             endTag="</td>"
  791:             endHtml="</tr></table>"
  792: 
  793:         else:
  794:             html="<table>"
  795:             startTag="<tr><td>"
  796:             endTag="</td></tr>"
  797:             endHtml="</table>"
  798:             
  799:         if not start:
  800:             temp=hash
  801:         else:
  802:             temp=hash
  803:             for x in start:
  804:                 temp=temp[x][0]
  805:                 #print temp
  806:         
  807:         for key in self.tempSorted(temp):
  808:             
  809:             description=temp[x][1].title
  810:             
  811:             
  812:             url=createPath(self,self.absolute_url(),temp[key][1].absolute_url(relative=1))
  813: 
  814:             if (self.REQUEST['URL']==url) | (self.REQUEST['URL']==url+"/index_html"):
  815:                 html=html+startTag+"[%s]" % description+endTag
  816:             else:                
  817:                 html=html+startTag+"[<a href='%s'>%s</a>]" % (url,description)+endTag
  818:             
  819: 
  820:         html=html+endHtml
  821:         
  822:         return html
  823: 
  824:     def mainNavBar(self):
  825:         """print main navigation bar"""
  826:         keys=""
  827: 
  828:         try:
  829:             keys=self.buttonsFromHash(self.createNavHash(0))
  830:         except:
  831:             keys=""
  832:             
  833:         return keys
  834: 
  835:     def mainNavElements(self,location=None):
  836:         """print main navigation bar"""
  837:         keys=""
  838:         #print "NAVELEMENT",self.getId()
  839:         #try:
  840:         
  841:         keys=self.barFromHash(self.createNavHash(0),location=location)
  842:         
  843:         #except:
  844:         #    keys=""
  845:      
  846:         return keys
  847: 
  848:     def numberOfMainNavElements(self):
  849:         """number of main elements"""
  850: 
  851:         return len(self.barFromHash(self.createNavHash(0))) 
  852: 
  853:     def startOfHierarchy(self,list):
  854:         splitted=self.pathToHierarchy.split("/")
  855:         last=splitted[len(splitted)-1]
  856:         #print last,list
  857:         try:
  858:             nr=list.index(last)
  859:         except:
  860:             nr=0
  861:         return nr+1
  862:     
  863:     def secondNavElements(self):
  864:         """Zweite Ordnung Navigationselemente"""
  865:         
  866:         hash=self.createNavHash(2,checkOnly="no")
  867:         
  868:         actual_url=self.REQUEST['URL']
  869:         
  870:         ult_temp=re.sub(self.absolute_url(),"",actual_url)
  871:         #print ult_temp
  872: 
  873:         splitted=ult_temp.split("/")
  874:         
  875:         #print "AU",self.absolute_url(),splitted
  876:         #start=[splitted[2]] #orig
  877:         startNr= self.startOfHierarchy(splitted)
  878:         
  879:         start=[splitted[startNr]]
  880:         
  881:         #print start
  882: 
  883:         keys=self.barFromHash(hash,start=start)
  884:         
  885:         
  886:         return keys
  887: 
  888:     def navElements(self,order):
  889:         """n-te Ordnung"""
  890:         
  891:         hash=self.createNavHash(order)
  892:         actual_url=self.REQUEST['URL']
  893:         
  894:         ult_temp=re.sub(self.absolute_url(),"",actual_url)
  895:         #print ult_temp
  896: 
  897:         splitted=ult_temp.split("/")
  898:         
  899: 
  900:         ## if splitted[len(splitted)-1]=="index_html":
  901: ##             start=[splitted[len(splitted)-2]]
  902: ##         else:
  903: ##             start=[splitted[len(splitted)-1]]
  904: 
  905:         #start=splitted[2:order+1] #orig
  906:         startNr= self.startOfHierarchy(splitted)
  907:         #print startNr
  908:         start=splitted[startNr:order+startNr-1] 
  909:         #print start
  910:        
  911:         keys=self.barFromHash(hash,start=start)
  912:         
  913:         
  914:         return keys
  915: 
  916: 
  917:     def secondNavBar(self):
  918:         """Zweite Ordnung"""
  919: 
  920:         hash=self.createNavHash(2)
  921:         actual_url=self.REQUEST['URL']
  922:         
  923:         ult_temp=re.sub(self.absolute_url(),"",actual_url)
  924:         #print ult_temp
  925: 
  926:         splitted=ult_temp.split("/")
  927:         
  928: 
  929:         ## if splitted[len(splitted)-1]=="index_html":
  930: ##             start=[splitted[len(splitted)-2]]
  931: ##         else:
  932: ##             start=[splitted[len(splitted)-1]]
  933: 
  934:         start=[splitted[2]]
  935:         #print start
  936:         
  937:         keys=self.buttonsFromHash(hash,start=start,orientation="vertical")
  938:         
  939:         
  940:         return keys
  941: 
  942: def manage_addECHO_navigationForm(self):
  943:     """Form for adding"""
  944:     pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt','AddECHO_navigation.zpt')).__of__(self)
  945:     return pt()
  946: 
  947: def manage_addECHO_navigation(self,id,title,pathToHierarchy,RESPONSE=None):
  948:     """Add an ECHO_root"""
  949:     self._setObject(id,ECHO_navigation(id,title,pathToHierarchy))
  950:     
  951:     if RESPONSE is not None:
  952:         RESPONSE.redirect('manage_main')
  953: 
  954: 
  955: #helpers
  956: 
  957: 
  958: 
  959: def createPath(self,url1,url2):
  960:     #bugfix in absolute_url, ploetzlich erschein in absolute_url der physikalische pfad.
  961:     
  962:     if self.REQUEST.has_key('VirtualRootPhysicalPath'):
  963:         vp="/".join(self.REQUEST['VirtualRootPhysicalPath'])
  964:         if vp[0]=="/":
  965:             vp=vp[1:]
  966:         
  967:         url2=url2.replace(vp+"/",'')
  968:     else:
  969:         temp1=url1.split("/")
  970:         temp2=url2.split("/")
  971:         for test in temp1:
  972:           if temp2[0]==test:
  973:             del temp2[0]
  974:     
  975:         url2= string.join(temp2,"/")
  976:         
  977:     return url1+"/"+url2
  978: 
  979: def sortWeight(x,y):
  980:     #print x[1],y[1]
  981:     return cmp(x[1],y[1])
  982:     

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