--- ECHO_content/ECHO_collection.py 2004/04/14 23:45:58 1.39
+++ ECHO_content/ECHO_collection.py 2004/04/22 17:35:14 1.49
@@ -28,12 +28,13 @@ from Globals import Persistent, package_
from Acquisition import Implicit
#from psycopg import libpq
-#from pyPgSQL import libpq
+from pyPgSQL import libpq
import xml.dom.minidom
import urllib
import xml.dom.minidom
from ECHO_graphicalOverview import javaHandler,javaScriptMain
+import ECHO_helpers
#List of different types for the graphical linking viewer
viewClassificationListMaster=['view point','area']
@@ -264,6 +265,15 @@ class ECHO_resource(Folder):
viewClassificationList=viewClassificationListMaster
+ getSubCols = ECHO_helpers.getSubCols
+ def getTitle(self):
+ """title"""
+ return self.title.encode('utf-8')
+
+ def getLabel(self):
+ """title"""
+ return self.label.encode('utf-8')
+
def content_html(self):
"""template fuer content"""
return content_html(self,'resource')
@@ -310,6 +320,11 @@ class ECHO_resource(Folder):
except:
return []
+ def getContentType(self):
+ try:
+ return self.contentType
+ except:
+ return ""
def ECHO_resource_config(self):
"""Main configuration"""
@@ -433,6 +448,14 @@ class ECHO_externalLink(Folder):
security=ClassSecurityInfo()
meta_type='ECHO_externalLink'
+ def getTitle(self):
+ """title"""
+ return self.title.encode('utf-8')
+
+ def getLabel(self):
+ """title"""
+ return self.label.encode('utf-8')
+
def content_html(self):
"""template fuer content"""
return content_html(self,'externalLink')
@@ -522,6 +545,32 @@ class ECHO_collection(Folder, Persistent
security=ClassSecurityInfo()
meta_type='ECHO_collection'
+ def getTitle(self):
+ """title"""
+ return self.title.encode('utf-8')
+
+ def getLabel(self):
+ """title"""
+ return self.label.encode('utf-8')
+
+ def createRessourcesFromXMLForm(self):
+ """form"""
+ pt=PageTemplateFile('Products/ECHO_content/zpt/createRessourcesFromXMLForm.zpt').__of__(self)
+ return pt()
+ def createRessourcesFromXML(self,fileupload):
+ """read an XML file for generating resources"""
+ dom=xml.dom.minidom.parse(fileupload)
+ ret="
Added
"
+ for resource in dom.getElementsByTagName('resource'):
+ link=getText(resource.getElementsByTagName('link')[0].childNodes)
+ label=getText(resource.getElementsByTagName('label')[0].childNodes)
+ #splitted=link.split("?")[0].split("/")
+ #id=splitted[len(splitted)-1].encode('ascii')
+ id=re.sub(" ","_",label).encode('ascii')
+
+ ret+=""+label+"
"
+ manage_addECHO_resource(self,id,label.encode('ascii'),label.encode('ascii'),"","","",link.encode('ascii'),"","")
+ return ret
def getImageTag(self):
"""GetTag"""
try:
@@ -560,7 +609,7 @@ class ECHO_collection(Folder, Persistent
for entry in object.__dict__.keys():
element=getattr(object,entry)
try:
- if element.meta_type=="ECHO_collection":
+ if element.meta_type in ["ECHO_collection","ECHO_group"]:
collections+=""
collections+=getCollection(element,depth)+"\n"
except:
@@ -576,7 +625,11 @@ class ECHO_collection(Folder, Persistent
dynamical=""
for ob in self.getGraphicCoords():
- dynamical+="""Coords.push(new Coord('%s', Img, %s));\n"""%(ob[1],ob[0])
+ if ob[4][4] == "":
+ dynamical+="""Coords.push(new Coord('%s', Img, %s));\n"""%(ob[1],ob[0])
+ else:
+ dynamical+="""Coords.push(new Coord('%s', Img, %s));//%s\n"""%(ob[1],ob[0],ob[4][4])
+ dynamical+="ShowArrow(new getObj('i.%s'),Img,%s);\n"%(ob[1],ob[0])
ret+=javaHandler%dynamical
return ret
@@ -608,21 +661,21 @@ class ECHO_collection(Folder, Persistent
return ret
security.declarePublic('ECHO_rerenderLinksMD')
- def ECHO_rerenderLinksMD(self):
+ def ECHO_rerenderLinksMD(self,obj=None):
"""Rerender all Links"""
-
- for entry in self.__dict__.keys():
- object=getattr(self,entry)
-
+ if not obj:
+ obj = self
- try:
+ entries=obj.ZopeFind(obj,obj_metatypes=['ECHO_resource','ECHO_collection'])
+
+ for entry in entries:
+ if entry[1].meta_type == 'ECHO_resource':
+ entry[1].ECHO_getResourceMD(template="no")
+ print "rerender",entry[1].getId()
+ else:
+ self.ECHO_rerenderLinksMD(entry[1])
+
- if object.meta_type == 'ECHO_resource':
-
- object.ECHO_getResourceMD(template="no")
-
- except:
- """nothing"""
return "Rerenderd all links to resources in: "+self.title
@@ -664,6 +717,7 @@ class ECHO_collection(Folder, Persistent
{'label':'Main Config','action':'ECHO_collection_config'},
{'label':'Rerender Links','action':'ECHO_rerenderLinksMD'},
{'label':'Graphics','action':'ECHO_graphicEntry'},
+ {'label':'create resources from XML','action':'createRessourcesFromXMLForm'},
)
@@ -739,9 +793,11 @@ class ECHO_collection(Folder, Persistent
self.coords=None
setECHO_collectionInformation(self,title,label,description,contentType,responsible,credits,weight,coordsnew)
-
-
-
+ try:
+ self.coords=coordsnew[0:] # HACK fehler in setECHO_collection
+ except:
+ """none"""
+
self.sortfield=sortfield
if RESPONSE is not None:
@@ -798,53 +854,25 @@ class ECHO_collection(Folder, Persistent
if len(coordtemp)>3:
coord=coordtemp[0:4]
if hasattr(object,'label') and not object.label=="":
- ids.append([string.join(coord,", "),object.getId(),object.label,object])
+ ids.append([string.join(coord,", "),object.getId(),object.label,object,coordtemp])
elif hasattr(object,'title'):
if not object.title=="":
- ids.append([string.join(coord,", "),object.getId(),object.title,object])
+ ids.append([string.join(coord,", "),object.getId(),object.title,object,coordtemp])
else:
- ids.append([string.join(coord,", "),object.getId(),object.getId(),object])
+ ids.append([string.join(coord,", "),object.getId(),object.getId(),object,coordtemp])
else:
- ids.append([string.join(coord,", "),object.getId(),object.getId(),object])
+ ids.append([string.join(coord,", "),object.getId(),object.getId(),object,coordtemp])
except:
"""nothing"""
return ids
- def getSubCols(self,sortfield="weight"):
- subColTypes=['ECHO_collection','ECHO_externalLink','ECHO_resource']
- ids=[]
- for entry in self.__dict__.keys():
- object=getattr(self,entry)
- try:
- if object.meta_type in subColTypes:
- ids.append(object)
-
- except:
- """nothing"""
- try:
- sortfield=self.sortfield
- except:
- """nothing"""
-
- tmplist=[]
- for x in ids:
- if hasattr(x,sortfield):
- try:
- x=int(x)
- except:
- """nothing"""
- tmp=getattr(x,sortfield)
- else:
- tmp=10000000
- tmplist.append((tmp,x))
- tmplist.sort()
- return [x for (key,x) in tmplist]
+
+
+ getSubCols = ECHO_helpers.getSubCols
-
-
@@ -889,14 +917,15 @@ class ECHO_group(ECHO_collection):
pt=PageTemplateFile('Products/ECHO_content/zpt/ChangeECHO_group.zpt').__of__(self)
return pt()
- def changeECHO_group(self,title,label,description,contentType,responsible,weight,secondaryLink,secondaryLinkTitle,credits=None,sortfield="weight",coords=None,RESPONSE=None,imageTag="",bgcolour=""):
+ def changeECHO_group(self,title,label,description,contentType,responsible,weight,secondaryLink,secondaryLinkTitle,credits=None,sortfield="weight",coords=None,RESPONSE=None,imageTag="",bgcolour="",logo=""):
"""Änderung der Properties"""
self.secondaryLink=secondaryLink
self.secondaryLinkTitle=secondaryLinkTitle
self.imageTag=imageTag
self.bgcolour=bgcolour
-
+ self.logo=logo
+
if coords:
coordsnew=[ string.split(x,",") for x in coords]
self.coords=coordsnew[0:]
@@ -912,7 +941,14 @@ class ECHO_group(ECHO_collection):
if RESPONSE is not None:
RESPONSE.redirect('manage_main')
-
+
+ def getLogo(self):
+ """logo ausgeben"""
+ try:
+ return self.logo
+ except:
+ return "ECHO_groups"
+
def content_html(self):
"""template fuer content"""
return content_html(self,'group')
@@ -925,14 +961,15 @@ def manage_addECHO_groupForm(self):
return pt()
-def manage_addECHO_group(self,id,title,label,description,contentType,responsible,weight,sortfield,coords="",secondaryLinkTitle="",secondaryLink="",credits=None,RESPONSE=None,imageTag="",bgcolour=""):
+def manage_addECHO_group(self,id,title,label,description,contentType,responsible,weight,sortfield,coords="",secondaryLinkTitle="",secondaryLink="",credits=None,RESPONSE=None,imageTag="",bgcolour="",logo=""):
"""add a echo group"""
newObj=ECHO_group(id,title,label,description,contentType,responsible,credits,weight,sortfield,coords,secondaryLinkTitle=secondaryLinkTitle,secondaryLink=secondaryLink,imageTag=imageTag,bgcolour="")
+ setattr(newObj,'logo',logo)
self._setObject(id,newObj)
-
+
if RESPONSE is not None:
RESPONSE.redirect('manage_main')
@@ -942,6 +979,13 @@ class ECHO_root(Folder,Persistent,Implic
"""ECHO Root Folder"""
meta_type="ECHO_root"
+
+ def getImageTag(self):
+ """needed by main_template"""
+ return ""
+ secondaryLink="" #needed by main_template
+ secondaryLinkTitle="" #needed by main_template
+
def getBgcolour(self):
"""hack"""
return "#dddddd"
@@ -980,7 +1024,7 @@ class ECHO_root(Folder,Persistent,Implic
entry[1].patchContentType(entry[1])
- return "Rerenderd all links to resources in: "+self.title
+ return "changed all contenttypes in: "+self.title
def ECHO_newViewerLink(self,obj=None):
"""change links (:86 faellt weg)"""