File:  [Repository] / ECHO_content / ECHO_collection.py
Revision 1.66: download - view: text, annotated - select for diffs - revision graph
Fri May 7 15:07:22 2004 UTC (20 years, 1 month ago) by dwinter
Branches: MAIN
CVS tags: HEAD
getgraphiccoord vereinfacht

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

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