File:  [Repository] / ECHO_content / ECHO_Nav.py
Revision 1.58: download - view: text, annotated - select for diffs - revision graph
Thu Oct 13 16:58:26 2005 UTC (18 years, 8 months ago) by dwinter
Branches: MAIN
CVS tags: HEAD
minor

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

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