--- ECHO_content/VLPExtension.py 2004/07/16 16:31:12 1.13 +++ ECHO_content/VLPExtension.py 2004/08/05 13:51:32 1.15 @@ -11,6 +11,15 @@ except: import xml.dom.minidom import urllib +def makeXML(str): + try: + dom=xml.dom.minidom.parseString(str) + return str + except: + return """ + %s + """%str + def getText(nodelist): rc = "" @@ -63,6 +72,7 @@ class VLP_essay(Folder): self.title=title self.label=label + def getPage(self,pagenum): """gibt essay page mit num aus""" def sortFind(x,y): @@ -73,9 +83,9 @@ class VLP_essay(Folder): pages.sort(sortFind) #print str(pages[int(pagenum)][1]()) if pages[int(pagenum)-1][1].meta_type=='File': - return self.xml2html(str(pages[int(pagenum)-1][1])) + return self.xml2html(makeXML(str(pages[int(pagenum)-1][1])),quote="no") else: - return str(self.xml2html(pages[int(pagenum)-1][1]())) + return str(self.xml2html(makeXML(pages[int(pagenum)-1][1]()),quote="no")) def nextPage(self,pagenum,url): pages=len(self.ZopeFind(self,obj_metatypes=['DTML Document','File'])) # teste ob performance ok, sonst in variable @@ -193,20 +203,9 @@ class VLP_resource(ECHO_resource): {'label':'Update Index','action':'createIndexFile'}, {'label':'Reset MetaLink','action':'resetMetaLink'}, {'label':'Generate Title','action':'generate_title'}, + {'label':'Generate Library Template','action':'generateLibraryTemplateHTML'}, ) - - def printDict(self): - """dict""" - return self.__dict__ - - ## def __init__(self,id,link,metalink,resourceID,title,label,description,contentType,renderingType,responsible,credits,weight,coords): -## """angepasstes init""" - - -## return ECHO_resource(id,link,metalink,resourceID,title,label,description,contentType,renderingType,responsible,credits,weight,coords) - - def resetMetaLink(self,all="no",RESPONSE=None): """resets metalink to standard resp. in case of server change it sets to the new server url""" if all=="yes": @@ -225,13 +224,33 @@ class VLP_resource(ECHO_resource): if self.REQUEST.get('p',None): self.REQUEST.set('pn',self.file2page(self.REQUEST.get('p',None))) - + if hasattr(self,'libraryTemplate.html'): + return getattr(self,'libraryTemplate.html')() + pt=PageTemplateFile('Products/ECHO_content/vlp/library_template.zpt').__of__(self) pt.content_type="text/html" return pt() index_html=show - + + def generateLibraryTemplateHTML(self,RESPONSE=None): + """lege standard index.html an""" + + if not hasattr(self,'libraryTemplate.html'): + zt=ZopePageTemplate('libraryTemplate.html') + self._setObject('libraryTemplate.html',zt) + default_content_fn = os.path.join(package_home(globals()), + 'vlp/library_template.zpt') + text = open(default_content_fn).read() + zt.pt_edit(text, 'text/html') + + else: + return "already exists!" + + if RESPONSE is not None: + RESPONSE.redirect('manage_main') + + def index_meta(self): """index_meta"""