File:  [Repository] / ECHO_content / ECHO_collection.py
Revision 1.43: download - view: text, annotated - select for diffs - revision graph
Fri Apr 16 10:24:09 2004 UTC (20 years, 2 months ago) by dwinter
Branches: MAIN
CVS tags: HEAD
logo inm groups added

    1: """New version of the product started February, 8th. Without scientific classification, use content-type for further classification."""
    2: """Echo collection provides the classes for the ECHO content web-site.
    3: 
    4: class ECHO_collection is the basis class for an ECHO collection.
    5: 
    6: class ECHO_resource contains information on ECHO resources (e.g. an Display environment for Metadata
    7: 
    8: class ECHO_externalLink contains information on externalLinks
    9: 
   10: 
   11: """
   12: import string
   13: import re
   14: import os
   15: import OFS.Image
   16: from types import *
   17: from OFS.Image import Image
   18: from Globals import DTMLFile
   19: from OFS.Folder import Folder
   20: from OFS.SimpleItem import SimpleItem
   21: from AccessControl import ClassSecurityInfo
   22: from Globals import InitializeClass
   23: from Globals import DTMLFile
   24: from Products.PageTemplates.PageTemplateFile import PageTemplateFile
   25: from Products.PageTemplates.PageTemplate import PageTemplate
   26: from Products.PageTemplates.ZopePageTemplate import ZopePageTemplate
   27: from Globals import Persistent, package_home
   28: from Acquisition import Implicit
   29: 
   30: #from psycopg import libpq
   31: #from pyPgSQL import libpq
   32: import xml.dom.minidom
   33: 
   34: import urllib
   35: import xml.dom.minidom
   36: from ECHO_graphicalOverview import javaHandler,javaScriptMain
   37: import ECHO_helpers
   38: 
   39: #List of different types for the graphical linking viewer
   40: viewClassificationListMaster=['view point','area']
   41: 
   42: def content_html(self,type):
   43:         """template fuer content"""
   44:         #templates = self.ZopeFind(self.aq_parent,obj_ids=[type+"_template"])
   45:         #
   46:         #if templates:
   47:         #    return templates[0][1]()
   48: 
   49:         try:
   50:             obj=getattr(self,type+"_template")
   51:             return obj()
   52:         except:
   53:             pt=PageTemplateFile('Products/ECHO_content/zpt/ECHO_%s_template_standard.zpt'%type).__of__(self)
   54:             pt.content_type="text/html"
   55:             return pt()
   56:     
   57: def toList(field):
   58:     """Einzelfeld in Liste umwandeln"""
   59:     if type(field)==StringType:
   60:         return [field]
   61:     else:
   62:         return field
   63:     
   64: def getText(nodelist):
   65: 
   66:     rc = ""
   67:     for node in nodelist:
   68:     	if node.nodeType == node.TEXT_NODE:
   69:            rc = rc + node.data
   70:     return rc
   71: 
   72: 
   73: def readMetadata(url):
   74:     """Methoden zum Auslesen der Metadateninformation zu einer Resource
   75:     Vorerst noch Typ bib"""
   76:     
   77:     metadict={}
   78:     try:
   79:         geturl=""
   80:         for line in urllib.urlopen(url).readlines():
   81:             geturl=geturl+line
   82:         
   83:         
   84:     except:
   85:         return (None,"Cannot open: "+url)
   86: 
   87:     try:
   88:         dom=xml.dom.minidom.parseString(geturl)
   89:     except:
   90:         return (None,"Cannot parse: "+url+"<br>"+geturl)
   91: 
   92:     metanode=dom.getElementsByTagName('bib')
   93:     metadict['bib_type']='Book'
   94:     if len(metanode)==0:
   95:         metanode=dom.getElementsByTagName('archimedes')
   96:         metadict['bib_type']='Archimedes'
   97:         #print "HELLO"
   98:         
   99:     if not len(metanode)==0:    
  100:         metacontent=metanode[0].childNodes
  101:     
  102:         try:
  103:             metadict['bib_type']=getText(dom.getElementsByTagName('bib')[0].attributes['type'].childNodes)
  104:         except:
  105:             """nothing"""
  106:         
  107:         for node in metacontent:
  108:             try:
  109:                 metadict[node.tagName.lower()]=getText(node.childNodes)
  110:             except:
  111:                 """nothing"""
  112: 
  113:     #print metadict
  114:     return metadict,""
  115:     
  116: 
  117: def setECHO_collectionInformation(self,title,label,description,contentType,responsible,credits,weight,coordstrs,viewClassification=""):
  118: 
  119:         """Allegemeine Informationen zu einer ECHO Collection"""
  120: 
  121:         self.viewClassification=viewClassification
  122: 
  123:         self.label = label
  124:         self.title=title
  125:         self.description=description
  126:         self.contentType=contentType
  127:         self.responsible=responsible
  128:         self.credits=toList(credits)
  129:         self.weight=weight
  130: 
  131:         coords=[]
  132:         #coordinates of for rectangles
  133: 
  134:         #print "cs", coordstrs
  135:         if coordstrs:
  136:             for coordstr in coordstrs:
  137:                 #print "cs", coordstr
  138:                 try:
  139:                     temco=coordstr.split(",")
  140:                 except:
  141:                     temco=[]
  142:                 #temco.append(angle)
  143:                 coords.append(temco)
  144: 
  145: 
  146:         self.coords=coords[0:]
  147:             
  148: 
  149: class scientificClassification(SimpleItem,Persistent,Implicit):
  150:     """outdated will be deleeted in the next versions: subclass"""
  151:     security=ClassSecurityInfo()
  152:     
  153:     def __init__(self,context,science,practice):
  154:         self.context=context
  155:         self.science=science
  156:         self.practice=practice
  157:         self.id="scientific_Classification"
  158:         
  159:     security.declarePublic('get_context')
  160:     def get_context(self):
  161:         return self.context
  162:     
  163:     security.declarePublic('get_science')
  164:     def get_science(self):
  165:         return self.science
  166:         
  167:     security.declarePublic('get_practice')
  168:     def get_practice(self):
  169:         return self.practice
  170:     
  171:                 
  172: class scientificInformation(Folder,Persistent,Implicit):
  173:     """outdated will be deleted in the next versions: subclass scientificInformation"""
  174:     security=ClassSecurityInfo()
  175:     
  176:     
  177:     
  178:     def __init__(self,source_type,period):
  179: 
  180:         self.id="scientific_Information"
  181:         self.source_type=source_type
  182:         self.period=period
  183:         
  184: 
  185: 
  186:     security.declarePublic('get_source_type')
  187:     def get_source_type(self):
  188:         return self.source_type
  189:     
  190:     security.declarePublic('get_period')
  191:     def get_period(self):
  192:         return self.period
  193: 
  194: class ECHO_layoutTemplate(ZopePageTemplate):
  195:     """Create a layout Template for different purposes"""
  196: 
  197:     meta_type="ECHO_layoutTemplate"
  198: 
  199:     def __init__(self, id, text=None, content_type=None,EchoType=None):
  200:         self.id = str(id)
  201: 
  202: 
  203: 
  204:         self.ZBindings_edit(self._default_bindings)
  205:         if text is None:
  206:             self._default_content_fn = os.path.join(package_home(globals()),
  207:                                                'zpt/ECHO_%s_template_standard.zpt'%EchoType)
  208:             text = open(self._default_content_fn).read()
  209:         self.pt_edit(text, content_type)
  210: 
  211:     
  212:         """change form"""
  213: 
  214: 
  215: def manage_addECHO_layoutTemplateForm(self):
  216:     """Form for adding"""
  217:     pt=PageTemplateFile('Products/ECHO_content/zpt/AddECHO_layoutTemplate.zpt').__of__(self)
  218:     return pt()
  219: 
  220: from urllib import quote
  221: 
  222: 
  223: def manage_addECHO_layoutTemplate(self, EchoType,title=None,REQUEST=None):
  224:     "Add a Page Template with optional file content."
  225:     if type(EchoType)==StringType:
  226:         EchoTypes=[EchoType]
  227:     else:
  228:         EchoTypes=EchoType
  229:         
  230:     for singleType in EchoTypes:
  231: 
  232:         id = str(singleType)+"_template"
  233:         if REQUEST is None:
  234:             self._setObject(id, ECHO_layoutTemplate(id, text,EchoType=singleType))
  235:             ob = getattr(self, id)
  236:             
  237:             if title:
  238:                 ob.pt_setTitle(title)
  239:             return ob
  240:         else:
  241:             file = REQUEST.form.get('file')
  242:             headers = getattr(file, 'headers', None)
  243:             if headers is None or not file.filename:
  244:                 zpt = ECHO_layoutTemplate(id,EchoType=singleType)
  245:             else:
  246:                 zpt = ECHO_layoutTemplate(id, file, headers.get('content_type'))
  247: 
  248:             self._setObject(id, zpt)
  249:             ob = getattr(self, id)
  250:             if title:
  251:                 ob.pt_setTitle(title)
  252: 
  253:             try:
  254:                 u = self.DestinationURL()
  255:             except AttributeError:
  256:                 u = REQUEST['URL1']
  257: 
  258:             
  259:     REQUEST.RESPONSE.redirect(u+'/manage_main')
  260:     return ''
  261: 
  262: class ECHO_resource(Folder):
  263:     """ECHO Ressource"""
  264:     meta_type='ECHO_resource'
  265: 
  266:     viewClassificationList=viewClassificationListMaster
  267: 
  268:     getSubCols = ECHO_helpers.getSubCols
  269: 
  270:     def content_html(self):
  271:         """template fuer content"""
  272:         return content_html(self,'resource')
  273:     
  274:     def getViewClassification(self):
  275:         if hasattr(self,'viewClassification'):
  276:             return self.viewClassification
  277:         else:
  278:             return ""
  279:         
  280:     def getCredits(self):
  281:         """Ausgabe der credits"""
  282:         if self.credits:
  283:             return self.credits
  284:         else:
  285:             return []
  286:     
  287:     def __init__(self,id,link,metalink,title,label,description,contentType,responsible,credits,weight,coords):
  288: 
  289:         self.id = id
  290:         """Festlegen der ID"""
  291:         
  292:         self.label = label
  293:         self.link= link
  294:         self.metalink=metalink
  295:         self.title=title
  296:         self.weight=weight
  297:         self.credits=toList(credits)
  298:         self.description=description
  299:         self.contentType=contentType
  300:         self.responsible=responsible
  301:         
  302:         if coords:
  303:             coordsnew=[ string.split(x,",") for x in coords]
  304:         else:
  305:             coordsnew=[]
  306:         
  307:         self.coords=coordsnew
  308: 
  309: 
  310:     def getCoords(self):
  311:         try:
  312:             return [string.join(x,",") for x in self.coords]  
  313:         except:
  314:             return []
  315: 
  316: 
  317:     def ECHO_resource_config(self):
  318:         """Main configuration"""
  319: 
  320:         if not hasattr(self,'weight'):
  321:             self.weight=""
  322:         if not hasattr(self,'coords'):
  323:             self.coords=[]
  324: 
  325:         print "vorher",self.coords
  326:         pt=PageTemplateFile('Products/ECHO_content/zpt/ChangeECHO_resource.zpt').__of__(self)
  327:         return pt()
  328:     
  329: 
  330:     def changeECHO_resource(self,metalink,link,title,label,description,contentType,responsible,weight,viewClassification="",coords=None,credits=None,RESPONSE=None):
  331:         """Änderung der Properties"""
  332:         
  333: 	try:        
  334:         	coordsnew=[ string.split(x,",") for x in coords]
  335:         except:
  336: 		coordsnew=[]	
  337:         
  338:         setECHO_collectionInformation(self,title,label,description,contentType,responsible,credits,weight,coordsnew)
  339: 
  340:         self.coords=coordsnew[0:]
  341:         self.link=link
  342:         self.metalink=metalink
  343:         
  344:         if RESPONSE is not None:
  345:             RESPONSE.redirect('manage_main')
  346:             
  347:             
  348:     manage_options = Folder.manage_options+(
  349:         {'label':'Main Config','action':'ECHO_resource_config'},
  350:         {'label':'Metadata','action':'ECHO_getResourceMD'},
  351:         {'label':'Graphics','action':'ECHO_graphicEntry'},
  352:         )
  353: 
  354:     def getOverview(self):
  355:         """overview graphics"""
  356:         
  357:         return self.aq_parent.ZopeFind(self.aq_parent,obj_ids=['overview'])[0][1]
  358: 
  359:     def ECHO_graphicEntry(self):
  360:         """DO nothing"""
  361:         overview = self.aq_parent.ZopeFind(self.aq_parent,obj_ids=['overview'])
  362:         if overview: 
  363:             pt=PageTemplateFile('Products/ECHO_content/zpt/ECHO_draw.zpt').__of__(self)
  364:             return pt()
  365:         else:
  366:             return "NO OVERVIEW GRAPHICS"
  367: 
  368:     def ECHO_enterCoords(self,coordstr,angle="",RESPONSE=None):
  369:         """Enter coords"""
  370:         coords=self.coords
  371:         temco=coordstr.split(",")
  372:         temco.append(angle)
  373:         coords.append(temco)
  374:         
  375:         self.coords=coords[0:]
  376: 
  377:         if RESPONSE is not None:
  378:             RESPONSE.redirect('ECHO_graphicEntry')
  379: 
  380:     def ECHO_getResourceMD(self,template="yes"):
  381:         """Einlesen der Metadaten und Anlegen dieser Metadaten als Informationen zur Resource"""
  382:         (metadict, error)=readMetadata(self.metalink)
  383: 
  384: 
  385: 
  386:         if not error=="": #Fehler beim Auslesen des Metafiles
  387:             return "ERROR:",error
  388:         for key in metadict.keys():#Hinzufügen der Felder
  389: 
  390:             setattr(self,key,metadict[key].encode('ascii','replace'))
  391:         
  392: 
  393:         self.metadata=metadict.keys()
  394: 
  395:         self.label=self.generate_label()
  396:         
  397:         if template=="yes":
  398:             pt=PageTemplateFile('Products/ECHO_content/zpt/ECHO_resourceMD.zpt').__of__(self)
  399:             return pt()
  400:     
  401:     def ECHO_getMD(self,item):
  402:         """Ausgabe der MD"""
  403:         return getattr(self,item)
  404:         
  405:     def index_html(self):
  406:         """standard page"""
  407:         
  408:         return self.REQUEST.RESPONSE.redirect(self.link)
  409: 
  410:     def generate_label(self):
  411:         """Erzeugt_standard_Label aus Template"""
  412:         pt=getattr(self,"label_template_"+self.bib_type)
  413: 
  414:         return pt()
  415: 
  416: def manage_addECHO_resourceForm(self):
  417:         """Form for adding a ressource"""
  418:         pt=PageTemplateFile('Products/ECHO_content/zpt/AddECHO_resourceForm.zpt').__of__(self)
  419:         return pt()
  420: 
  421: 
  422: 
  423: def manage_addECHO_resource(self,id,title,label,description,contentType,responsible,link,metalink,weight,credits=None,coords=None,RESPONSE=None):
  424:     """addaresource"""
  425: 
  426:     newObj=ECHO_resource(id,link,metalink,title,label,description,contentType,responsible,credits,weight,coords)
  427: 
  428:     self._setObject(id,newObj)
  429: 
  430:     if RESPONSE is not None:
  431:         RESPONSE.redirect('manage_main')
  432:  
  433: 
  434: class ECHO_externalLink(Folder):
  435:     """Link zu einer externen Ressource"""
  436:     security=ClassSecurityInfo()
  437:     meta_type='ECHO_externalLink'
  438: 
  439:     def content_html(self):
  440:         """template fuer content"""
  441:         return content_html(self,'externalLink')
  442:     
  443:     def __init__(self,id,link,title,label,description,contentType,responsible,credits,weight,coords):
  444: 
  445:         self.id = id
  446:         """Festlegen der ID"""
  447: 
  448:         self.credits=toList(credits)
  449:         self.label = label
  450:         self.link= link
  451:         self.title=title
  452:         self.weight=weight
  453:         self.description=description
  454:         self.contentType=contentType
  455:         self.responsible=responsible
  456:         coordsnew=[ string.split(x,",") for x in coords]
  457:         self.coords=coordsnew
  458: 
  459:     def ECHO_externalLink_config(self):
  460:         """Main configuration"""
  461: 
  462:         if not hasattr(self,'weight'):
  463:             self.weight=""
  464:         if not hasattr(self,'coords'):
  465:             
  466:             self.coords=['']
  467:             #print "G",self.coords
  468: 
  469:         pt=PageTemplateFile('Products/ECHO_content/zpt/ChangeECHO_externalLink.zpt').__of__(self)
  470:         return pt()
  471:     
  472: 
  473:     def changeECHO_externalLink(self,link,title,label,description,contentType,responsible,weight,coords=None,credits=None,RESPONSE=None):
  474: 
  475:         """Änderung der Properties"""
  476: 	try:
  477: 		coordsnew=[ string.split(x,",") for x in coords]
  478: 	except:
  479: 		coordsnew=[]
  480: 
  481:         setECHO_collectionInformation(self,title,label,description,contentType,responsible,credits,weight,coords)
  482: 
  483:         self.coords=coordsnew[0:]
  484:         self.link=link
  485:         if RESPONSE is not None:
  486:             RESPONSE.redirect('manage_main')
  487:             
  488:             
  489:     manage_options = Folder.manage_options+(
  490:         {'label':'Main Config','action':'ECHO_externalLink_config'},
  491:         )
  492: 
  493:     def getCredits(self):
  494:         """Ausgabe der credits"""
  495:         if self.credits:
  496:             return self.credits
  497:         else:
  498:             return []
  499:         
  500:     def index_html(self):
  501:         """standard page"""
  502:         
  503:         return self.REQUEST.RESPONSE.redirect(self.link)
  504: 
  505: def manage_addECHO_externalLinkForm(self):
  506:         """Form for external Links"""
  507:         pt=PageTemplateFile('Products/ECHO_content/zpt/AddECHO_externalLinkForm.zpt').__of__(self)
  508:         return pt()
  509: 
  510: 
  511: def manage_addECHO_externalLink(self,id,title,label,description,contentType,responsible,link,weight,coords=None,credits=None,RESPONSE=None):
  512:     """Add an external Link"""
  513: 
  514:     newObj=ECHO_externalLink(id,link,title,label,description,contentType,responsible,credits,weight,coords)
  515: 
  516:     self._setObject(id,newObj)
  517: 
  518:     if RESPONSE is not None:
  519:         RESPONSE.redirect('manage_main')
  520:  
  521: 
  522: 
  523: class ECHO_collection(Folder, Persistent, Implicit):
  524:     """ECHO Collection"""
  525:     security=ClassSecurityInfo()
  526:     meta_type='ECHO_collection'
  527: 
  528:     def getImageTag(self):
  529:         """GetTag"""
  530:         try:
  531:             return self.imageTag
  532:         except:
  533:             return ""
  534: 
  535:     def addResource(self,id,title,label,description,contentType,responsible,link,metalink,weight,credits=None,coords=None,RESPONSE=None):
  536:         """SSS"""
  537:         try:
  538:             manage_addECHO_resource(self,id,title,label,description,contentType,responsible,link,metalink,weight,credits=None,coords=None,RESPONSE=None)
  539:             return "done"
  540:         except:
  541:             return None
  542: 
  543:     def getSecondaryLink(self):
  544:         """secondary link"""
  545:         try:
  546:             return self.secondaryLink
  547:         except:
  548:             return ""
  549: 
  550:     def getSecondaryLinkTitle(self):
  551:         """secondary link"""
  552:         try:
  553:             return self.secondaryLinkTitle
  554:         except:
  555:             return ""
  556:         
  557:     def getCollectionTreeXML(self):
  558:         """Tree as XML"""
  559: 
  560:         def getCollection(object,depth=0):
  561:             depth+=1
  562:             collections=""
  563:             for entry in object.__dict__.keys():
  564:                 element=getattr(object,entry)
  565:                 try:
  566:                     if element.meta_type in ["ECHO_collection","ECHO_group"]:
  567:                         collections+="<element name=\""+element.title+"\" url=\""+element.absolute_url()+"\">"
  568:                         collections+=getCollection(element,depth)+"</element>\n"
  569:                 except:
  570:                     """nothing"""
  571:             return collections
  572:         
  573: 
  574:         return "<collection>"+getCollection(self)+"</collection>"
  575:     
  576:     def createJavaScript(self):
  577:         """CreateJava"""
  578:         ret=javaScriptMain
  579: 
  580:         dynamical=""
  581:         for ob in self.getGraphicCoords():
  582:             dynamical+="""Coords.push(new Coord('%s', Img, %s));\n"""%(ob[1],ob[0])
  583:         ret+=javaHandler%dynamical
  584:         return ret
  585:     
  586:     security.declarePublic('getCreditObject')
  587:     def getCreditObject(self,name):
  588:         """credit id to credititem"""
  589:         try:
  590:             return getattr(self.partners,name)
  591:         except:
  592:             return ""
  593: 
  594:     security.declarePublic('ECHO_generateNavBar')
  595:     def ECHO_generateNavBar(self):
  596:         """Erzeuge Navigationsbar"""
  597:         link=""
  598:         object="self"
  599:         ret=[]
  600:         path=self.getPhysicalPath()
  601:         for element in path:
  602:             
  603:            
  604:             if not element=="":
  605:                 object+="."+element
  606:                 
  607:                 label=eval(object).label
  608:                 link+="/"+element
  609:                 if not label=="":
  610:                     ret.append((label,link))
  611:         return ret
  612:     
  613:     security.declarePublic('ECHO_rerenderLinksMD')
  614:     def ECHO_rerenderLinksMD(self):
  615:         """Rerender all Links"""
  616:         
  617:         for entry in self.__dict__.keys():
  618:             object=getattr(self,entry)
  619:             
  620:             
  621:             try:
  622:                 
  623:                 if object.meta_type == 'ECHO_resource':
  624:                     
  625:                     object.ECHO_getResourceMD(template="no")
  626:                     
  627:             except:
  628:                 """nothing"""
  629:                 
  630:         return "Rerenderd all links to resources in: "+self.title
  631: 
  632:     security.declarePublic('ECHO_newViewerLink')
  633:     
  634: 
  635:     def getCoords(self):
  636:         try:
  637:             
  638:             x=  [string.join(x,",") for x in self.coords]  
  639:             return x
  640: 
  641:         except:
  642: 
  643:             return []
  644:         
  645:     def __init__(self,id,title,label,description,contentType,responsible,credits,weight,sortfield,coords,secondaryLinkTitle,secondaryLink,imageTag="",bgcolour=""):
  646:         #print "CO",coords
  647: 
  648:         self.id = id
  649:         """Festlegen der ID"""
  650:         self.credits=toList(credits)
  651:         self.label = label
  652:         self.title=title
  653:         self.description=description
  654:         self.contentType=contentType
  655:         self.responsible=responsible
  656:         self.imageTag=imageTag
  657:         self.weight=weight
  658:         self.sortfield=sortfield
  659:         coordsnew=[ string.split(x,",") for x in coords]
  660:         self.coords=coordsnew
  661:         self.secondaryLinkTitle=secondaryLinkTitle
  662:         self.secondaryLink=secondaryLink
  663: 	self.bgcolour=bgcolour
  664:         
  665: 
  666:     manage_options = Folder.manage_options+(
  667:         {'label':'Main Config','action':'ECHO_collection_config'},
  668:         {'label':'Rerender Links','action':'ECHO_rerenderLinksMD'},
  669:         {'label':'Graphics','action':'ECHO_graphicEntry'},
  670: 
  671:         )
  672: 
  673:     def getOverview(self):
  674:         """overview graphics"""
  675:         
  676:         return self.aq_parent.ZopeFind(self.aq_parent,obj_ids=['overview'])[0][1]
  677:     
  678:     
  679:     def ECHO_graphicEntry(self):
  680:         """DO nothing"""
  681:         overview = self.aq_parent.ZopeFind(self.aq_parent,obj_ids=['overview'])
  682:         
  683:     
  684:         if overview:
  685:             pt=PageTemplateFile('Products/ECHO_content/zpt/ECHO_draw.zpt').__of__(self)
  686:             return pt()
  687:         else:
  688:             return "NO OVERVIEW GRAPHICS"
  689: 
  690:     def ECHO_enterCoords(self,coordstr,angle="",RESPONSE=None):
  691:         """Enter coords"""
  692:         coords=self.coords
  693:         temco=coordstr.split(",")
  694:         temco.append(angle)
  695:         coords.append(temco)
  696:         self.coords=coords[0:]
  697: 
  698:         if RESPONSE is not None:
  699:             RESPONSE.redirect('ECHO_graphicEntry')
  700: 
  701:     
  702:     security.declarePublic('ECHO_collection_config')
  703:     def ECHO_collection_config(self):
  704:         """Main configuration"""
  705: 
  706:         if not hasattr(self,'weight'):
  707:             self.weight=""
  708: 
  709:         if not hasattr(self,'sortfield'):
  710:             self.sortfield="weight"
  711:   
  712:         if not hasattr(self,'coords'):
  713:             self.coords=[]
  714: 
  715:         pt=PageTemplateFile('Products/ECHO_content/zpt/ChangeECHO_collection.zpt').__of__(self)
  716:         return pt()
  717: 
  718: 
  719:     security.declarePublic('changeECHO_collection')
  720: 
  721: 
  722:     def getBgcolour(self):
  723: 	    """colour"""
  724: 	    if hasattr(self,'bgcolour') and not (self.bgcolour==""):
  725: 		    return self.bgcolour
  726: 	    else:
  727: 		    return "#dddddd"
  728: 	    
  729:     def changeECHO_collection(self,title,label,description,contentType,responsible,weight,secondaryLink,secondaryLinkTitle,credits=None,sortfield="weight",coords=None,RESPONSE=None,imageTag="",bgcolour=""):
  730:         """Änderung der Properties"""
  731: 
  732:         self.secondaryLink=secondaryLink
  733:         self.secondaryLinkTitle=secondaryLinkTitle
  734:         self.imageTag=imageTag
  735: 	self.bgcolour=bgcolour
  736: 	
  737:         if coords:
  738:             coordsnew=[ string.split(x,",") for x in coords]
  739:             self.coords=coordsnew[0:]
  740:         else:
  741:             coordsnew=None
  742:             self.coords=None
  743:             
  744:         setECHO_collectionInformation(self,title,label,description,contentType,responsible,credits,weight,coordsnew)
  745: 
  746:         self.coords=coordsnew[0:] # HACK fehler in setECHO_collection
  747:         
  748:         self.sortfield=sortfield
  749: 
  750:         if RESPONSE is not None:
  751:             RESPONSE.redirect('manage_main')
  752:             
  753:     security.declarePublic('index_html')
  754: 
  755: 
  756:     def showOverview(self):
  757:         """overview"""
  758:         if 'ECHO_overview.html' in self.__dict__.keys():
  759:             return getattr(self,'ECHO_overview.html')()
  760:         pt=PageTemplateFile('Products/ECHO_content/zpt/ECHO_content_overview.zpt').__of__(self)
  761:         return pt()
  762: 
  763:     
  764:     def index_html(self):
  765:         """standard page"""
  766:         
  767:         if 'index.html' in self.__dict__.keys():
  768:             return getattr(self,'index.html')()
  769:         
  770:         elif 'overview' in self.__dict__.keys():
  771:             return self.showOverview()
  772:         elif hasattr(self,'collection_index_template'):
  773:             return self.collection_index_template()    
  774:         
  775:         pt=PageTemplateFile('Products/ECHO_content/zpt/ECHO_content_standard.zpt').__of__(self)
  776:         pt.content_type="text/html"
  777:         return pt()
  778: 
  779:     def content_html(self):
  780:         """template fuer content"""
  781:         return content_html(self,'collection')
  782:     
  783:     def getCredits(self):
  784:         """Ausgabe der credits"""
  785:         if self.credits:
  786:             return self.credits
  787:         else:
  788:             return []
  789: 
  790: 
  791:         
  792:     def getGraphicCoords(self):
  793:         """Give list of coordinates"""
  794:         subColTypes=['ECHO_collection','ECHO_externalLink','ECHO_resource']
  795:         ids=[]
  796:         for entry in self.__dict__.keys():
  797:             object=getattr(self,entry)
  798:             try:
  799:                 if object.meta_type in subColTypes:
  800:                     for coordtemp in object.coords:
  801:                         if len(coordtemp)>3:
  802:                             coord=coordtemp[0:4]
  803:                             if hasattr(object,'label') and not object.label=="":
  804:                                 ids.append([string.join(coord,", "),object.getId(),object.label,object])
  805:                             elif hasattr(object,'title'):
  806:                                 if not object.title=="":
  807:                                     ids.append([string.join(coord,", "),object.getId(),object.title,object])
  808:                                 else:
  809:                                     ids.append([string.join(coord,", "),object.getId(),object.getId(),object])
  810:                             else:
  811:                                 ids.append([string.join(coord,", "),object.getId(),object.getId(),object])
  812:                     
  813:             except:
  814:                 """nothing"""
  815: 
  816:         return ids
  817:     
  818: 
  819: 
  820: 
  821:     getSubCols = ECHO_helpers.getSubCols
  822:      
  823:                 
  824:     
  825:     
  826: def manage_addECHO_collectionForm(self):
  827:         """Add collection form"""
  828:         pt=PageTemplateFile('Products/ECHO_content/zpt/AddECHO_collectionForm.zpt').__of__(self)
  829:         return pt()
  830: 
  831: 
  832: def manage_addECHO_collection(self,id,title,label,description,contentType,responsible,weight,sortfield,coords="",secondaryLinkTitle="",secondaryLink="",credits=None,RESPONSE=None,imageTag="",bgcolour=""):
  833:     """add a echo collection"""
  834:     
  835: 
  836:     newObj=ECHO_collection(id,title,label,description,contentType,responsible,credits,weight,sortfield,coords,secondaryLinkTitle=secondaryLinkTitle,secondaryLink=secondaryLink,imageTag=imageTag,bgcolour="")
  837: 
  838:     self._setObject(id,newObj)
  839: 
  840:     if RESPONSE is not None:
  841:         RESPONSE.redirect('manage_main')
  842: 
  843: class ECHO_group(ECHO_collection):
  844: 	"""ECHO Gruppe"""
  845: 	meta_type="ECHO_group"
  846: 
  847: 	manage_options = Folder.manage_options+(
  848: 		{'label':'Main Config','action':'ECHO_group_config'},
  849: 		{'label':'Rerender Links','action':'ECHO_rerenderLinksMD'},
  850: 		{'label':'Graphics','action':'ECHO_graphicEntry'},
  851: 		)
  852: 	def ECHO_group_config(self):
  853: 		"""Main configuration"""
  854: 		
  855: 		if not hasattr(self,'weight'):
  856: 			self.weight=""
  857: 			
  858: 		if not hasattr(self,'sortfield'):
  859: 			self.sortfield="weight"
  860: 				
  861: 		if not hasattr(self,'coords'):
  862: 			self.coords=[]
  863: 
  864: 		pt=PageTemplateFile('Products/ECHO_content/zpt/ChangeECHO_group.zpt').__of__(self)
  865: 		return pt()
  866: 
  867: 	def changeECHO_group(self,title,label,description,contentType,responsible,weight,secondaryLink,secondaryLinkTitle,credits=None,sortfield="weight",coords=None,RESPONSE=None,imageTag="",bgcolour="",logo=""):
  868: 		"""Änderung der Properties"""
  869: 
  870: 		self.secondaryLink=secondaryLink
  871: 		self.secondaryLinkTitle=secondaryLinkTitle
  872: 		self.imageTag=imageTag
  873: 		self.bgcolour=bgcolour
  874:                 self.logo=logo
  875:                 
  876: 		if coords:
  877: 		    coordsnew=[ string.split(x,",") for x in coords]
  878: 		    self.coords=coordsnew[0:]
  879: 		else:
  880: 		    coordsnew=None
  881: 		    self.coords=None
  882: 
  883: 		setECHO_collectionInformation(self,title,label,description,contentType,responsible,credits,weight,coordsnew)
  884: 
  885: 
  886: 
  887: 		self.sortfield=sortfield
  888: 
  889: 		if RESPONSE is not None:
  890: 		    RESPONSE.redirect('manage_main')
  891: 
  892: 	def getLogo(self):    
  893: 		"""logo ausgeben"""
  894:                 try:
  895:                     return self.logo
  896:                 except:
  897:                     return "ECHO_groups"
  898: 
  899: 	def content_html(self):
  900: 		"""template fuer content"""
  901: 		return content_html(self,'group')
  902:     
  903: 
  904: 
  905: def manage_addECHO_groupForm(self):
  906:         """Add group form"""
  907:         pt=PageTemplateFile('Products/ECHO_content/zpt/AddECHO_groupForm.zpt').__of__(self)
  908:         return pt()
  909: 
  910: 
  911: def manage_addECHO_group(self,id,title,label,description,contentType,responsible,weight,sortfield,coords="",secondaryLinkTitle="",secondaryLink="",credits=None,RESPONSE=None,imageTag="",bgcolour="",logo=""):
  912:     """add a echo group"""
  913:     
  914: 
  915:     newObj=ECHO_group(id,title,label,description,contentType,responsible,credits,weight,sortfield,coords,secondaryLinkTitle=secondaryLinkTitle,secondaryLink=secondaryLink,imageTag=imageTag,bgcolour="")
  916: 
  917:     setattr(newObj,'logo',logo)
  918:     self._setObject(id,newObj)
  919:     
  920:     if RESPONSE is not None:
  921:         RESPONSE.redirect('manage_main')
  922: 
  923: 
  924: 	
  925: class ECHO_root(Folder,Persistent,Implicit):
  926:     """ECHO Root Folder"""
  927:     meta_type="ECHO_root"
  928: 
  929:     def getBgcolour(self):
  930: 	"""hack"""
  931: 	return "#dddddd"
  932: 
  933:     def contentTypeSelector_HTML(self,selected=None):
  934:         """give type selector"""
  935:         if not selected:
  936:             retStr="<option selected>\n"
  937:         else:
  938:             retStr="<option>\n"
  939:             
  940:         try:
  941:             for contentType in self.ZopeFind(self.contentTypes,obj_metatypes="ECHO_contentType"):
  942:                 if selected and (contentType[0]==selected):
  943:                     retStr+="""<option selected value="%s">%s\n"""%(contentType[0],contentType[0])
  944:                 else:                
  945:                     retStr+="""<option value="%s">%s\n"""%(contentType[0],contentType[0])
  946:         except:
  947:             """nothing"""
  948:         return retStr
  949:             
  950:     def patchContentType(self,obj=None):
  951:         """austauschen content_type with contentType (patch bei umstieg von alter Version)"""
  952:     
  953: 
  954:         if not obj:
  955:             obj = self
  956:             
  957:         entries=obj.ZopeFind(obj,obj_metatypes=['ECHO_resource','ECHO_collection','ECHO_externalLink','ECHO_pageTemplate'])
  958: 
  959:         for entry in entries:
  960:                 setattr(entry[1],'contentType',entry[1].content_type)
  961:                 #entry[1].contentType == entry[1].content_type
  962: 
  963:                 if entry[1].meta_type == 'ECHO_collection':
  964:                     entry[1].patchContentType(entry[1])    
  965: 
  966:                 
  967:         return "Rerenderd all links to resources in: "+self.title
  968:     
  969:     def ECHO_newViewerLink(self,obj=None):
  970:         """change links (:86 faellt weg)"""
  971: 
  972:         if not obj:
  973:             obj = self
  974:             
  975:         entries=obj.ZopeFind(obj,obj_metatypes=['ECHO_resource','ECHO_collection'])
  976: 
  977:         for entry in entries:
  978:                 
  979:                 if entry[1].meta_type == 'ECHO_resource':
  980:                     
  981:                     entry[1].link=re.sub('\:86','',entry[1].link)
  982: 
  983:                 else:
  984:                     
  985:                     entry[1].ECHO_newViewerLink(entry[1])
  986:                 
  987:         return "Rerenderd all links to resources in: "+self.title
  988: 
  989:     def __init__(self,id,title):
  990:         """init"""
  991:         self.id = id
  992:         self.title=title
  993: 
  994:     def deleteSpace(self,str):
  995:         """delete space at the end of a line"""
  996:         if str[len(str)-1]==" ":
  997:             return str[0:len(str)-1]
  998:         else:
  999:             return str
 1000:         
 1001:     
 1002: 
 1003:     # zusaetliche methoden fuer das vlp muessen in ein eigenes produkt
 1004: 
 1005:     def formatAscii(self,str,url=None):
 1006:         """ersetze ascii umbrueche durch <br>"""
 1007:         #url=None
 1008:         if url:
 1009:             
 1010:             retStr=""
 1011:             words=str.split("\n")
 1012:             
 1013:             for word in words:
 1014:                 strUrl=url%word
 1015:                 print "str",strUrl
 1016:                 retStr+="""<a href="%s">%s</a><br/>"""%(strUrl,word)
 1017:             str=retStr
 1018:         if str:
 1019:             return re.sub(r"[\n]","<br/>",str)
 1020:         else:
 1021:             return ""
 1022:         
 1023:     def link2html(self,str):
 1024:         """link2html fuer VLP muss hier noch raus"""
 1025:         if str:
 1026:             print str
 1027:             str=re.sub("\&","&amp;",str)
 1028:             dom=xml.dom.minidom.parseString("<?xml version='1.0' ?><txt>"+str+"</txt>")
 1029:             links=dom.getElementsByTagName("link")
 1030:             
 1031:             print "link",links
 1032:             for link in links:
 1033:                 link.tagName="a"
 1034:                 ref=link.getAttribute("ref")
 1035:                 if self.checkRef(ref):
 1036:                     link.setAttribute("href",self.aq_parent.absolute_url()+"/vlp_coll?id="+ref)
 1037: 
 1038:             return dom.toxml('utf-8')
 1039:         return ""
 1040: 
 1041: 
 1042:     def checkRef(self,ref):
 1043:         dbs={'vl_literature':'AND CD LIKE \'%lise%\'','vl_technology':'','vl_people':''}
 1044:         res=None
 1045:         for db in dbs.keys():
 1046:             #print ref,"select reference from %s where reference =\'%s\' %s"%(db,ref,dbs[db])
 1047: 
 1048:             res=res or self.search(var=str("select reference from %s where reference =\'%s\' %s"%(db,ref,dbs[db])))
 1049:         return res
 1050:                                     
 1051:     #Ende Methode fuer vlp
 1052: 
 1053:     def PgQuoteString(self,string):
 1054:         """Quote string"""
 1055:         #print "PG",string
 1056:         return libpq.PgQuoteString(string)
 1057:         
 1058:     def getPartners(self):
 1059:         """Get list of Partners. Presently only from a subfolder partners"""
 1060:                     
 1061:         return [ item[1] for item in self.partners.ZopeFind(self.partners,obj_metatypes=['ECHO_partner'])]
 1062:                 
 1063:                 
 1064:                    
 1065: 
 1066:     
 1067:     def getPartnersXML(self):
 1068:         """partner liste als xml""" 
 1069:         partners=self.getPartners()
 1070:         ret="<partners>"
 1071:         for partner in partners:
 1072:             ret+="""<partner id="%s" title="%s"/>\n"""%(partner.getId(),partner.title)
 1073: 
 1074:         return ret+"\n</partners>"
 1075:     
 1076:     def getCollectionTree(self):
 1077:         """get the collection tree (list of triples (parent,child, depth)"""
 1078: 
 1079:         def getCollection(object,depth=0):
 1080:             depth+=1
 1081:             collections=[]
 1082:             for entry in object.__dict__.keys():
 1083:                 element=getattr(object,entry)
 1084:                 try:
 1085:                     if element.meta_type=="ECHO_collection":
 1086:                         collections.append((object,element,depth))
 1087:                         collections+=getCollection(element,depth)
 1088:                 except:
 1089:                     """nothing"""
 1090:             return collections
 1091:         
 1092: 
 1093:         return getCollection(self)
 1094:     
 1095:     def getCollectionTreeIds(self):
 1096:         """Show the IDs of the Tree"""
 1097:         ret=[]
 1098:         for collection in self.getCollectionTree():
 1099:             ret.append((collection[0].getId(),collection[1].getId(),collection[2]))
 1100:         return ret
 1101: 
 1102:         
 1103:         
 1104: def manage_addECHO_root(self,id,title,RESPONSE=None):
 1105:     """Add an ECHO_root"""
 1106:     self._setObject(id,ECHO_root(id,title))
 1107:     
 1108:     if RESPONSE is not None:
 1109:         RESPONSE.redirect('manage_main')
 1110: 
 1111: def manage_addECHO_rootForm(self):
 1112:         """Nothing yet"""
 1113:         pt=PageTemplateFile('Products/ECHO_content/zpt/AddECHO_root.zpt').__of__(self)
 1114:         return pt()
 1115:  
 1116: class ECHO_partner(Image,Persistent):
 1117:     """ECHO Partner"""
 1118: 
 1119:     meta_type="ECHO_partner"
 1120: 
 1121:     def __init__(self, id, title,url, file, content_type='', precondition=''):
 1122:         self.__name__=id
 1123:         self.title=title
 1124:         self.url=url
 1125:         self.precondition=precondition
 1126: 
 1127:         data, size = self._read_data(file)
 1128:         content_type=self._get_content_type(file, data, id, content_type)
 1129:         self.update_data(data, content_type, size)
 1130: 
 1131:     manage_options = Image.manage_options+(
 1132:         {'label':'Partner Information','action':'ECHO_partner_config'},
 1133:         )
 1134: 
 1135:     def changeECHO_partner(self,url,RESPONSE=None):
 1136:         """Change main information"""
 1137:         self.url=url
 1138:         if RESPONSE is not None:
 1139:             RESPONSE.redirect('manage_main')
 1140:             
 1141:             
 1142: 
 1143:     def ECHO_partner_config(self):
 1144:         """Main configuration"""
 1145:         if not hasattr(self,'url'):
 1146:             self.url=""
 1147:         pt=PageTemplateFile('Products/ECHO_content/zpt/ChangeECHO_partner.zpt').__of__(self)
 1148:         return pt()
 1149: 
 1150:         
 1151: manage_addECHO_partnerForm=DTMLFile('dtml/ECHO_partnerAdd',globals(),
 1152:                              Kind='ECHO_partner',kind='ECHO_partner')
 1153: 
 1154: 
 1155: 
 1156: def manage_addECHO_partner(self, id, file,url, title='', precondition='', content_type='',
 1157:                     REQUEST=None):
 1158:     """
 1159:     Add a new ECHO_partner object.
 1160: 
 1161:     Creates a new ECHO_partner object 'id' with the contents of 'file'.
 1162:     Based on Image.manage_addImage
 1163:     """
 1164: 
 1165:     id=str(id)
 1166:     title=str(title)
 1167:     content_type=str(content_type)
 1168:     precondition=str(precondition)
 1169: 
 1170:     id, title = OFS.Image.cookId(id, title, file)
 1171: 
 1172:     self=self.this()
 1173: 
 1174:     # First, we create the image without data:
 1175:     self._setObject(id, ECHO_partner(id,title,url,'',content_type, precondition))
 1176: 
 1177:     # Now we "upload" the data.  By doing this in two steps, we
 1178:     # can use a database trick to make the upload more efficient.
 1179:     if file:
 1180:         self._getOb(id).manage_upload(file)
 1181:     if content_type:
 1182:         self._getOb(id).content_type=content_type
 1183: 
 1184:     if REQUEST is not None:
 1185:         try:    url=self.DestinationURL()
 1186:         except: url=REQUEST['URL1']
 1187:         REQUEST.RESPONSE.redirect('%s/manage_main' % url)
 1188:     return id
 1189: 
 1190: 

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