Annotation of ECHO_content/ECHO_collection.py, revision 1.43
1.13 dwinter 1: """New version of the product started February, 8th. Without scientific classification, use content-type for further classification."""
1.1 casties 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
1.14 dwinter 13: import re
1.29 dwinter 14: import os
1.1 casties 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
1.29 dwinter 26: from Products.PageTemplates.ZopePageTemplate import ZopePageTemplate
27: from Globals import Persistent, package_home
1.1 casties 28: from Acquisition import Implicit
1.29 dwinter 29:
1.15 dwinter 30: #from psycopg import libpq
31: #from pyPgSQL import libpq
1.14 dwinter 32: import xml.dom.minidom
1.1 casties 33:
34: import urllib
35: import xml.dom.minidom
1.23 dwinter 36: from ECHO_graphicalOverview import javaHandler,javaScriptMain
1.41 dwinter 37: import ECHO_helpers
1.1 casties 38:
1.6 dwinter 39: #List of different types for the graphical linking viewer
40: viewClassificationListMaster=['view point','area']
41:
1.29 dwinter 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]()
1.6 dwinter 48:
1.29 dwinter 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:
1.1 casties 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:
1.27 dwinter 117: def setECHO_collectionInformation(self,title,label,description,contentType,responsible,credits,weight,coordstrs,viewClassification=""):
1.1 casties 118:
119: """Allegemeine Informationen zu einer ECHO Collection"""
120:
1.6 dwinter 121: self.viewClassification=viewClassification
122:
1.1 casties 123: self.label = label
124: self.title=title
125: self.description=description
1.27 dwinter 126: self.contentType=contentType
1.1 casties 127: self.responsible=responsible
128: self.credits=toList(credits)
129: self.weight=weight
130:
1.5 dwinter 131: coords=[]
1.1 casties 132: #coordinates of for rectangles
1.10 dwinter 133:
1.9 dwinter 134: #print "cs", coordstrs
135: if coordstrs:
136: for coordstr in coordstrs:
1.12 dwinter 137: #print "cs", coordstr
1.9 dwinter 138: try:
139: temco=coordstr.split(",")
140: except:
141: temco=[]
142: #temco.append(angle)
143: coords.append(temco)
144:
1.10 dwinter 145:
1.5 dwinter 146: self.coords=coords[0:]
1.1 casties 147:
148:
149: class scientificClassification(SimpleItem,Persistent,Implicit):
1.13 dwinter 150: """outdated will be deleeted in the next versions: subclass"""
1.1 casties 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):
1.13 dwinter 173: """outdated will be deleted in the next versions: subclass scientificInformation"""
1.1 casties 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:
1.29 dwinter 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:
1.32 dwinter 211:
1.29 dwinter 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:
1.32 dwinter 231:
1.29 dwinter 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 ''
1.1 casties 261:
262: class ECHO_resource(Folder):
263: """ECHO Ressource"""
264: meta_type='ECHO_resource'
265:
1.6 dwinter 266: viewClassificationList=viewClassificationListMaster
1.1 casties 267:
1.41 dwinter 268: getSubCols = ECHO_helpers.getSubCols
269:
1.29 dwinter 270: def content_html(self):
271: """template fuer content"""
272: return content_html(self,'resource')
273:
1.6 dwinter 274: def getViewClassification(self):
275: if hasattr(self,'viewClassification'):
276: return self.viewClassification
277: else:
278: return ""
1.13 dwinter 279:
1.9 dwinter 280: def getCredits(self):
281: """Ausgabe der credits"""
282: if self.credits:
283: return self.credits
284: else:
285: return []
1.6 dwinter 286:
1.27 dwinter 287: def __init__(self,id,link,metalink,title,label,description,contentType,responsible,credits,weight,coords):
1.1 casties 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
1.27 dwinter 299: self.contentType=contentType
1.1 casties 300: self.responsible=responsible
1.9 dwinter 301:
302: if coords:
303: coordsnew=[ string.split(x,",") for x in coords]
304: else:
305: coordsnew=[]
306:
1.1 casties 307: self.coords=coordsnew
308:
1.3 dwinter 309:
310: def getCoords(self):
311: try:
1.4 dwinter 312: return [string.join(x,",") for x in self.coords]
1.3 dwinter 313: except:
314: return []
315:
1.1 casties 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:
1.21 dwinter 325: print "vorher",self.coords
1.13 dwinter 326: pt=PageTemplateFile('Products/ECHO_content/zpt/ChangeECHO_resource.zpt').__of__(self)
1.1 casties 327: return pt()
328:
329:
1.27 dwinter 330: def changeECHO_resource(self,metalink,link,title,label,description,contentType,responsible,weight,viewClassification="",coords=None,credits=None,RESPONSE=None):
1.1 casties 331: """Änderung der Properties"""
332:
1.33 dwinter 333: try:
334: coordsnew=[ string.split(x,",") for x in coords]
335: except:
336: coordsnew=[]
1.21 dwinter 337:
1.27 dwinter 338: setECHO_collectionInformation(self,title,label,description,contentType,responsible,credits,weight,coordsnew)
1.22 dwinter 339:
1.21 dwinter 340: self.coords=coordsnew[0:]
1.1 casties 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'},
1.3 dwinter 351: {'label':'Graphics','action':'ECHO_graphicEntry'},
1.1 casties 352: )
353:
1.20 dwinter 354: def getOverview(self):
355: """overview graphics"""
356:
357: return self.aq_parent.ZopeFind(self.aq_parent,obj_ids=['overview'])[0][1]
358:
1.3 dwinter 359: def ECHO_graphicEntry(self):
360: """DO nothing"""
1.20 dwinter 361: overview = self.aq_parent.ZopeFind(self.aq_parent,obj_ids=['overview'])
1.19 dwinter 362: if overview:
1.13 dwinter 363: pt=PageTemplateFile('Products/ECHO_content/zpt/ECHO_draw.zpt').__of__(self)
1.3 dwinter 364: return pt()
365: else:
366: return "NO OVERVIEW GRAPHICS"
367:
1.4 dwinter 368: def ECHO_enterCoords(self,coordstr,angle="",RESPONSE=None):
1.3 dwinter 369: """Enter coords"""
370: coords=self.coords
1.4 dwinter 371: temco=coordstr.split(",")
372: temco.append(angle)
373: coords.append(temco)
374:
1.3 dwinter 375: self.coords=coords[0:]
1.13 dwinter 376:
1.3 dwinter 377: if RESPONSE is not None:
378: RESPONSE.redirect('ECHO_graphicEntry')
379:
1.1 casties 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:
1.13 dwinter 384:
1.1 casties 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()
1.13 dwinter 394:
1.1 casties 395: self.label=self.generate_label()
396:
397: if template=="yes":
1.13 dwinter 398: pt=PageTemplateFile('Products/ECHO_content/zpt/ECHO_resourceMD.zpt').__of__(self)
1.1 casties 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)
1.13 dwinter 413:
1.1 casties 414: return pt()
415:
1.13 dwinter 416: def manage_addECHO_resourceForm(self):
417: """Form for adding a ressource"""
418: pt=PageTemplateFile('Products/ECHO_content/zpt/AddECHO_resourceForm.zpt').__of__(self)
1.1 casties 419: return pt()
420:
421:
1.10 dwinter 422:
1.27 dwinter 423: def manage_addECHO_resource(self,id,title,label,description,contentType,responsible,link,metalink,weight,credits=None,coords=None,RESPONSE=None):
1.13 dwinter 424: """addaresource"""
1.1 casties 425:
1.27 dwinter 426: newObj=ECHO_resource(id,link,metalink,title,label,description,contentType,responsible,credits,weight,coords)
1.1 casties 427:
428: self._setObject(id,newObj)
1.13 dwinter 429:
1.1 casties 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:
1.29 dwinter 439: def content_html(self):
440: """template fuer content"""
441: return content_html(self,'externalLink')
442:
1.27 dwinter 443: def __init__(self,id,link,title,label,description,contentType,responsible,credits,weight,coords):
1.1 casties 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
1.27 dwinter 454: self.contentType=contentType
1.1 casties 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'):
1.9 dwinter 465:
1.1 casties 466: self.coords=['']
1.12 dwinter 467: #print "G",self.coords
1.1 casties 468:
1.13 dwinter 469: pt=PageTemplateFile('Products/ECHO_content/zpt/ChangeECHO_externalLink.zpt').__of__(self)
1.1 casties 470: return pt()
471:
472:
1.37 dwinter 473: def changeECHO_externalLink(self,link,title,label,description,contentType,responsible,weight,coords=None,credits=None,RESPONSE=None):
1.1 casties 474:
475: """Änderung der Properties"""
1.36 dwinter 476: try:
477: coordsnew=[ string.split(x,",") for x in coords]
478: except:
479: coordsnew=[]
1.1 casties 480:
1.27 dwinter 481: setECHO_collectionInformation(self,title,label,description,contentType,responsible,credits,weight,coords)
1.1 casties 482:
1.21 dwinter 483: self.coords=coordsnew[0:]
1.1 casties 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: )
1.17 dwinter 492:
493: def getCredits(self):
494: """Ausgabe der credits"""
495: if self.credits:
496: return self.credits
497: else:
498: return []
499:
1.1 casties 500: def index_html(self):
501: """standard page"""
502:
503: return self.REQUEST.RESPONSE.redirect(self.link)
504:
1.13 dwinter 505: def manage_addECHO_externalLinkForm(self):
506: """Form for external Links"""
507: pt=PageTemplateFile('Products/ECHO_content/zpt/AddECHO_externalLinkForm.zpt').__of__(self)
1.1 casties 508: return pt()
509:
510:
1.27 dwinter 511: def manage_addECHO_externalLink(self,id,title,label,description,contentType,responsible,link,weight,coords=None,credits=None,RESPONSE=None):
1.13 dwinter 512: """Add an external Link"""
1.1 casties 513:
1.27 dwinter 514: newObj=ECHO_externalLink(id,link,title,label,description,contentType,responsible,credits,weight,coords)
1.1 casties 515:
516: self._setObject(id,newObj)
1.13 dwinter 517:
1.1 casties 518: if RESPONSE is not None:
519: RESPONSE.redirect('manage_main')
520:
1.24 dwinter 521:
522:
1.1 casties 523: class ECHO_collection(Folder, Persistent, Implicit):
524: """ECHO Collection"""
525: security=ClassSecurityInfo()
526: meta_type='ECHO_collection'
527:
1.25 dwinter 528: def getImageTag(self):
529: """GetTag"""
530: try:
531: return self.imageTag
532: except:
533: return ""
534:
1.27 dwinter 535: def addResource(self,id,title,label,description,contentType,responsible,link,metalink,weight,credits=None,coords=None,RESPONSE=None):
1.24 dwinter 536: """SSS"""
537: try:
1.27 dwinter 538: manage_addECHO_resource(self,id,title,label,description,contentType,responsible,link,metalink,weight,credits=None,coords=None,RESPONSE=None)
1.24 dwinter 539: return "done"
540: except:
541: return None
1.32 dwinter 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:
1.24 dwinter 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:
1.40 dwinter 566: if element.meta_type in ["ECHO_collection","ECHO_group"]:
1.24 dwinter 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:
1.23 dwinter 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
1.1 casties 585:
586: security.declarePublic('getCreditObject')
587: def getCreditObject(self,name):
588: """credit id to credititem"""
1.15 dwinter 589: try:
590: return getattr(self.partners,name)
591: except:
592: return ""
1.17 dwinter 593:
1.1 casties 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"""
1.13 dwinter 616:
1.1 casties 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
1.19 dwinter 631:
632: security.declarePublic('ECHO_newViewerLink')
1.1 casties 633:
634:
635: def getCoords(self):
636: try:
1.11 dwinter 637:
638: x= [string.join(x,",") for x in self.coords]
639: return x
1.4 dwinter 640:
1.11 dwinter 641: except:
1.4 dwinter 642:
1.1 casties 643: return []
1.3 dwinter 644:
1.34 dwinter 645: def __init__(self,id,title,label,description,contentType,responsible,credits,weight,sortfield,coords,secondaryLinkTitle,secondaryLink,imageTag="",bgcolour=""):
1.9 dwinter 646: #print "CO",coords
1.1 casties 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
1.27 dwinter 654: self.contentType=contentType
1.1 casties 655: self.responsible=responsible
1.25 dwinter 656: self.imageTag=imageTag
1.1 casties 657: self.weight=weight
658: self.sortfield=sortfield
659: coordsnew=[ string.split(x,",") for x in coords]
660: self.coords=coordsnew
1.32 dwinter 661: self.secondaryLinkTitle=secondaryLinkTitle
662: self.secondaryLink=secondaryLink
1.35 dwinter 663: self.bgcolour=bgcolour
1.32 dwinter 664:
1.1 casties 665:
666: manage_options = Folder.manage_options+(
1.13 dwinter 667: {'label':'Main Config','action':'ECHO_collection_config'},
1.1 casties 668: {'label':'Rerender Links','action':'ECHO_rerenderLinksMD'},
669: {'label':'Graphics','action':'ECHO_graphicEntry'},
670:
671: )
672:
1.19 dwinter 673: def getOverview(self):
674: """overview graphics"""
1.20 dwinter 675:
676: return self.aq_parent.ZopeFind(self.aq_parent,obj_ids=['overview'])[0][1]
677:
1.19 dwinter 678:
1.1 casties 679: def ECHO_graphicEntry(self):
680: """DO nothing"""
1.20 dwinter 681: overview = self.aq_parent.ZopeFind(self.aq_parent,obj_ids=['overview'])
1.19 dwinter 682:
1.20 dwinter 683:
1.19 dwinter 684: if overview:
1.13 dwinter 685: pt=PageTemplateFile('Products/ECHO_content/zpt/ECHO_draw.zpt').__of__(self)
1.1 casties 686: return pt()
687: else:
688: return "NO OVERVIEW GRAPHICS"
689:
1.4 dwinter 690: def ECHO_enterCoords(self,coordstr,angle="",RESPONSE=None):
1.1 casties 691: """Enter coords"""
1.2 dwinter 692: coords=self.coords
1.4 dwinter 693: temco=coordstr.split(",")
694: temco.append(angle)
695: coords.append(temco)
1.2 dwinter 696: self.coords=coords[0:]
1.13 dwinter 697:
1.2 dwinter 698: if RESPONSE is not None:
699: RESPONSE.redirect('ECHO_graphicEntry')
1.1 casties 700:
701:
1.13 dwinter 702: security.declarePublic('ECHO_collection_config')
703: def ECHO_collection_config(self):
1.1 casties 704: """Main configuration"""
705:
706: if not hasattr(self,'weight'):
707: self.weight=""
708:
709: if not hasattr(self,'sortfield'):
710: self.sortfield="weight"
1.13 dwinter 711:
1.1 casties 712: if not hasattr(self,'coords'):
713: self.coords=[]
714:
1.13 dwinter 715: pt=PageTemplateFile('Products/ECHO_content/zpt/ChangeECHO_collection.zpt').__of__(self)
1.1 casties 716: return pt()
717:
718:
1.13 dwinter 719: security.declarePublic('changeECHO_collection')
1.1 casties 720:
1.10 dwinter 721:
1.34 dwinter 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=""):
1.13 dwinter 730: """Änderung der Properties"""
1.10 dwinter 731:
1.32 dwinter 732: self.secondaryLink=secondaryLink
733: self.secondaryLinkTitle=secondaryLinkTitle
1.25 dwinter 734: self.imageTag=imageTag
1.34 dwinter 735: self.bgcolour=bgcolour
736:
1.32 dwinter 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)
1.17 dwinter 745:
1.42 dwinter 746: self.coords=coordsnew[0:] # HACK fehler in setECHO_collection
1.21 dwinter 747:
1.1 casties 748: self.sortfield=sortfield
749:
750: if RESPONSE is not None:
751: RESPONSE.redirect('manage_main')
752:
753: security.declarePublic('index_html')
754:
1.23 dwinter 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:
1.1 casties 763:
764: def index_html(self):
765: """standard page"""
766:
767: if 'index.html' in self.__dict__.keys():
768: return getattr(self,'index.html')()
1.32 dwinter 769:
1.1 casties 770: elif 'overview' in self.__dict__.keys():
771: return self.showOverview()
1.32 dwinter 772: elif hasattr(self,'collection_index_template'):
773: return self.collection_index_template()
1.1 casties 774:
1.13 dwinter 775: pt=PageTemplateFile('Products/ECHO_content/zpt/ECHO_content_standard.zpt').__of__(self)
1.29 dwinter 776: pt.content_type="text/html"
1.1 casties 777: return pt()
778:
1.29 dwinter 779: def content_html(self):
780: """template fuer content"""
781: return content_html(self,'collection')
782:
1.11 dwinter 783: def getCredits(self):
784: """Ausgabe der credits"""
785: if self.credits:
786: return self.credits
787: else:
788: return []
1.1 casties 789:
1.23 dwinter 790:
791:
1.1 casties 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:
1.4 dwinter 800: for coordtemp in object.coords:
801: if len(coordtemp)>3:
802: coord=coordtemp[0:4]
1.23 dwinter 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'):
1.3 dwinter 806: if not object.title=="":
1.23 dwinter 807: ids.append([string.join(coord,", "),object.getId(),object.title,object])
1.3 dwinter 808: else:
1.23 dwinter 809: ids.append([string.join(coord,", "),object.getId(),object.getId(),object])
1.3 dwinter 810: else:
1.23 dwinter 811: ids.append([string.join(coord,", "),object.getId(),object.getId(),object])
1.1 casties 812:
813: except:
814: """nothing"""
1.13 dwinter 815:
1.1 casties 816: return ids
817:
1.42 dwinter 818:
819:
820:
1.41 dwinter 821: getSubCols = ECHO_helpers.getSubCols
1.1 casties 822:
823:
824:
825:
1.13 dwinter 826: def manage_addECHO_collectionForm(self):
827: """Add collection form"""
828: pt=PageTemplateFile('Products/ECHO_content/zpt/AddECHO_collectionForm.zpt').__of__(self)
1.1 casties 829: return pt()
830:
831:
1.34 dwinter 832: def manage_addECHO_collection(self,id,title,label,description,contentType,responsible,weight,sortfield,coords="",secondaryLinkTitle="",secondaryLink="",credits=None,RESPONSE=None,imageTag="",bgcolour=""):
1.13 dwinter 833: """add a echo collection"""
1.1 casties 834:
835:
1.34 dwinter 836: newObj=ECHO_collection(id,title,label,description,contentType,responsible,credits,weight,sortfield,coords,secondaryLinkTitle=secondaryLinkTitle,secondaryLink=secondaryLink,imageTag=imageTag,bgcolour="")
1.1 casties 837:
838: self._setObject(id,newObj)
1.13 dwinter 839:
1.1 casties 840: if RESPONSE is not None:
841: RESPONSE.redirect('manage_main')
842:
1.38 dwinter 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:
1.43 ! dwinter 867: def changeECHO_group(self,title,label,description,contentType,responsible,weight,secondaryLink,secondaryLinkTitle,credits=None,sortfield="weight",coords=None,RESPONSE=None,imageTag="",bgcolour="",logo=""):
1.38 dwinter 868: """Änderung der Properties"""
869:
870: self.secondaryLink=secondaryLink
871: self.secondaryLinkTitle=secondaryLinkTitle
872: self.imageTag=imageTag
873: self.bgcolour=bgcolour
1.43 ! dwinter 874: self.logo=logo
! 875:
1.38 dwinter 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')
1.40 dwinter 891:
892: def getLogo(self):
893: """logo ausgeben"""
1.43 ! dwinter 894: try:
! 895: return self.logo
! 896: except:
! 897: return "ECHO_groups"
1.40 dwinter 898:
1.38 dwinter 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:
1.43 ! dwinter 911: def manage_addECHO_group(self,id,title,label,description,contentType,responsible,weight,sortfield,coords="",secondaryLinkTitle="",secondaryLink="",credits=None,RESPONSE=None,imageTag="",bgcolour="",logo=""):
1.38 dwinter 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:
1.43 ! dwinter 917: setattr(newObj,'logo',logo)
1.38 dwinter 918: self._setObject(id,newObj)
1.43 ! dwinter 919:
1.38 dwinter 920: if RESPONSE is not None:
921: RESPONSE.redirect('manage_main')
922:
923:
924:
1.1 casties 925: class ECHO_root(Folder,Persistent,Implicit):
926: """ECHO Root Folder"""
927: meta_type="ECHO_root"
1.23 dwinter 928:
1.35 dwinter 929: def getBgcolour(self):
930: """hack"""
931: return "#dddddd"
1.28 dwinter 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:
1.27 dwinter 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:
1.30 dwinter 957: entries=obj.ZopeFind(obj,obj_metatypes=['ECHO_resource','ECHO_collection','ECHO_externalLink','ECHO_pageTemplate'])
1.27 dwinter 958:
959: for entry in entries:
1.31 dwinter 960: setattr(entry[1],'contentType',entry[1].content_type)
961: #entry[1].contentType == entry[1].content_type
1.27 dwinter 962:
963: if entry[1].meta_type == 'ECHO_collection':
964: entry[1].patchContentType(entry[1])
1.19 dwinter 965:
1.27 dwinter 966:
967: return "Rerenderd all links to resources in: "+self.title
968:
1.19 dwinter 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
1.1 casties 988:
989: def __init__(self,id,title):
990: """init"""
991: self.id = id
992: self.title=title
1.13 dwinter 993:
1.14 dwinter 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("\&","&",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:
1.13 dwinter 1053: def PgQuoteString(self,string):
1054: """Quote string"""
1.14 dwinter 1055: #print "PG",string
1.13 dwinter 1056: return libpq.PgQuoteString(string)
1.1 casties 1057:
1058: def getPartners(self):
1059: """Get list of Partners. Presently only from a subfolder partners"""
1.26 dwinter 1060:
1061: return [ item[1] for item in self.partners.ZopeFind(self.partners,obj_metatypes=['ECHO_partner'])]
1.13 dwinter 1062:
1.1 casties 1063:
1.26 dwinter 1064:
1.1 casties 1065:
1.24 dwinter 1066:
1.26 dwinter 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>"
1.24 dwinter 1075:
1.1 casties 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:
1.13 dwinter 1104: def manage_addECHO_root(self,id,title,RESPONSE=None):
1.1 casties 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:
1.13 dwinter 1111: def manage_addECHO_rootForm(self):
1.1 casties 1112: """Nothing yet"""
1.13 dwinter 1113: pt=PageTemplateFile('Products/ECHO_content/zpt/AddECHO_root.zpt').__of__(self)
1.1 casties 1114: return pt()
1115:
1116: class ECHO_partner(Image,Persistent):
1117: """ECHO Partner"""
1118:
1119: meta_type="ECHO_partner"
1120:
1.29 dwinter 1121: def __init__(self, id, title,url, file, content_type='', precondition=''):
1.1 casties 1122: self.__name__=id
1123: self.title=title
1124: self.url=url
1125: self.precondition=precondition
1126:
1127: data, size = self._read_data(file)
1.29 dwinter 1128: content_type=self._get_content_type(file, data, id, content_type)
1129: self.update_data(data, content_type, size)
1.1 casties 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=""
1.13 dwinter 1147: pt=PageTemplateFile('Products/ECHO_content/zpt/ChangeECHO_partner.zpt').__of__(self)
1.1 casties 1148: return pt()
1149:
1150:
1.13 dwinter 1151: manage_addECHO_partnerForm=DTMLFile('dtml/ECHO_partnerAdd',globals(),
1.1 casties 1152: Kind='ECHO_partner',kind='ECHO_partner')
1153:
1154:
1155:
1.29 dwinter 1156: def manage_addECHO_partner(self, id, file,url, title='', precondition='', content_type='',
1.1 casties 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)
1.29 dwinter 1167: content_type=str(content_type)
1.1 casties 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:
1.29 dwinter 1175: self._setObject(id, ECHO_partner(id,title,url,'',content_type, precondition))
1.1 casties 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)
1.29 dwinter 1181: if content_type:
1182: self._getOb(id).content_type=content_type
1.1 casties 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>