--- ZSQLExtend/ZSQLExtend.py 2004/04/18 08:58:28 1.15
+++ ZSQLExtend/ZSQLExtend.py 2004/07/20 12:07:57 1.27
@@ -10,22 +10,70 @@ from AccessControl import getSecurityMan
import os.path
from Products.PageTemplates.PageTemplateFile import PageTemplateFile
-def quoteString(name):
- #return re.sub(r'([\(\)\?])',"\\\1",name)
- #return "Euklid"
- return name
-
class ZSQLExtendFolder(Persistent, Implicit, Folder):
"""Folder"""
meta_type="ZSQLExtendFolder"
-
+ def content_html(self):
+ """template fuer content"""
+
+ try:
+ obj=getattr(self,"ZSQLBibliography_template")
+ return obj()
+ except:
+ pt=PageTemplateFile('Products/ZSQLExtend/zpt/ZSQLBibliography_template_standard.zpt',content_type='text/htm').__of__(self)
+ pt.content_type="text/html"
+
+ return pt()
+
+
+ def getWeight(self):
+ """getLabe"""
+ try:
+ return self.weight
+ except:
+ return ""
+
+ def getLabel(self):
+ """getLabe"""
+ try:
+ return self.label
+ except:
+ return ""
+
+ def getDescription(self):
+ """getLabe"""
+ try:
+ return self.description
+ except:
+ return ""
+
+ manage_options=Folder.manage_options+(
+ {'label':'Main Config','action':'changeZSQLExtendForm'},
+ )
+
+ def changeZSQLExtendForm(self):
+ """change folder config"""
+ pt=PageTemplateFile('Products/ZSQLExtend/zpt/changeZSQLExtendForm.zpt').__of__(self)
+ return pt()
+
+
+ def changeZSQLExtend(self,label,description,weight=0,REQUEST=None):
+ """change it"""
+
+ self.weight=weight
+ self.label=label
+ self.description=description
+
+ if REQUEST is not None:
+ return self.manage_main(self, REQUEST)
+
def formatAscii(self,str,url=None):
"""ersetze ascii umbrueche durch
"""
#url=None
- if url:
+ if url and str:
retStr=""
words=str.split("\n")
@@ -97,7 +145,69 @@ class ZSQLExtendFolder(Persistent, Impli
"""%fieldname
return ret
+
+ def ZSQLSelectionFromCRList(self,fieldname,listField,boxType="checkbox",checked=None):
+ """generate select oprions form a cr seperated list"""
+ fields=listField.split("\n")
+ ret=""
+ for field in fields:
+ if checked and (field in checked.split("\n")):
+ ret+="""%s"""%(fieldname,boxType,field.encode('utf-8'),field.encode('utf-8'))
+ else:
+ ret+="""%s"""%(fieldname,boxType,field.encode('utf-8'),field.encode('utf-8'))
+ return ret
+
+
+ def ZSQLOptionsFromCRList(self,fieldname,listField):
+ """generate select oprions form a cr seperated list"""
+ fields=listField.split("\n")
+ ret=""""""
+ return ret
+
+ def ZSQLOptionsFromSearchList(self,fieldname,results,fieldName,valueName=None,start=None):
+ """generate select oprions form a cr seperated list"""
+ if not valueName:
+ valueName=fieldName
+
+ ret=""""""
+ return ret
+
+
+ def ZSQLInlineSearchU(self,storename=None,**argv):
+ """one element if exists"""
+ qs=[]
+ if storename:
+ """store"""
+ else:
+ storename="foundCount"
+
+
+ #print "INLINE:",argv
+ for a in argv.keys():
+ qs.append(a+"="+urllib.quote(str(argv[a])))
+ #return []
+ ret = self.parseQueryString(string.join(qs,","),"_",storename=storename)
+
+ try:
+ return ret[0]
+ except:
+ return None
+
def ZSQLInlineSearch(self,storename=None,**argv):
"""inlinesearch"""
qs=[]
@@ -212,34 +322,57 @@ class ZSQLExtendFolder(Persistent, Impli
self.search(var=queryString)
return self.REQUEST.RESPONSE.redirect(format)
- def ZSQLFind(self,qs="",select="oid,*",storename=None):
+ def ZSQLFind(self,qs="",select="oid,*",storename=None,**argv):
"""Find"""
-
+ def delEmpty(list):
+ ret=[]
+ for x in list:
+ splitted=x.split("=")
+ if (len(splitted)>1) and not (splitted[1]==' '):
+ ret.append(x)
+ return ret
+
if qs=="":
if self.REQUEST['QUERY_STRING']:
qs=self.REQUEST['QUERY_STRING']
qs=string.join(qs.split("&"),",")
+
+ for field in argv.keys():
+
+ qs+=",-%s=%s"%(field,argv[field])
+ #print qs
else:
qs=self.REQUEST.SESSION['query']
+ for field in argv.keys():
+ #print field
+ qs+=",-%s=%s"%(field,argv[field])
+
else:
self.REQUEST['QUERY_STRING']=qs
+
qs=string.join(qs.split("&"),",")
-
+
+
qs=re.sub("\\+"," ",qs)# Austauschen da Leerzeichen bei http-get durch + ersetzt wird, generell sollte alles auf post umgeschrieben werden. vom search formular.
+ qs=string.join(delEmpty(qs.split(",")),",")
+
if storename:
"""store"""
else:
storename="foundCount"
- #print "QS",qs
+
+
+
ret=self.parseQueryString(qs,"-",select=select,storemax="yes",storename=storename)
#print self.REQUEST.SESSION["foundCount"]
+
return ret
def ZSQLFoundCountLen(self,var):
@@ -275,7 +408,7 @@ class ZSQLExtendFolder(Persistent, Impli
else:
storename="foundCount"
- return self.REQUEST.SESSION[storename]['rangeStart']+1
+ return int(self.REQUEST.SESSION[storename]['rangeStart'])+1
def ZSQLRangeSize(self,storename=None):
@@ -293,7 +426,7 @@ class ZSQLExtendFolder(Persistent, Impli
else:
storename="foundCount"
- return self.REQUEST.SESSION[storename]['rangeEnd']
+ return str(min(int(self.REQUEST.SESSION[storename]['rangeEnd']),int(self.REQUEST.SESSION[storename]['count'])))
def parseQueryString(self,qs,iCT,storemax="no",select=None,nostore=None,storename=None):
"""analysieren den QueryString"""
@@ -325,6 +458,7 @@ class ZSQLExtendFolder(Persistent, Impli
value=urllib.unquote(q.split("=",1)[1])
except:
value=""
+ #print "Hi",name[0:3],q
if name[0:3]==iCT+"op":
op=value
@@ -441,9 +575,12 @@ class ZSQLExtendFolder(Persistent, Impli
self.REQUEST.SESSION[storename]['rangeSize']=limit
self.REQUEST.SESSION[storename]['searchFields']=searchFields
- #print "Q",query
- return self.search(var=query)
+ #print "Q",query
+ return self.ZSQLQuery(query)
+ def ZSQLQuery(self,query):
+ """query"""
+ return self.search(var=query)
def ZSQLSearch(self):
"""To be done"""
@@ -485,14 +622,16 @@ class ZSQLExtendFolder(Persistent, Impli
"""nextLink"""
try:
limit=self.REQUEST.SESSION[storename]['rangeSize']
+ if int(limit)==0 :
+ limit="1"
newRangeStart=int(self.REQUEST.SESSION[storename]['rangeStart'])+int(limit)
except:
- limit=0
+ limit=1
newRangeStart=0
- if newRangeStart>self.REQUEST.SESSION[storename]['count']:
- newRangeStart=self.REQUEST.SESSION[storename]['count']-10
-
+ if newRangeStart>=self.REQUEST.SESSION[storename]['count']:
+ #newRangeStart=self.REQUEST.SESSION[storename]['count']-1
+ return ""
#create new query string
@@ -513,10 +652,12 @@ class ZSQLExtendFolder(Persistent, Impli
skipFound=0
for query in queries:
+
#print query.split("=")[0]
if query[0]=="_" : query[0]="-"
if query.split("=")[0].lower()=="-skip":
+
skipFound=1
query="-skip=%i"%newRangeStart
newquery.append(query)
@@ -534,10 +675,14 @@ class ZSQLExtendFolder(Persistent, Impli
"""prev link"""
try:
limit=self.REQUEST.SESSION[storename]['rangeSize']
+ if int(limit)==0 :
+ limit="1"
newRangeStart=int(self.REQUEST.SESSION[storename]['rangeStart'])-int(limit)
except:
- limit=0
+ limit=1
newRangeStart=0
+ if newRangeStart <0:
+ return ""
#print "limit",limit,newRangeStart,int(self.REQUEST.SESSION[storename]['rangeStart'])
@@ -643,7 +788,7 @@ class ZSQLExtendFolder(Persistent, Impli
manage_addZSQLExtendFolderForm=DTMLFile('ZSQLExtendFolderAdd', globals())
-def manage_addZSQLExtendFolder(self, id, title='',
+def manage_addZSQLExtendFolder(self, id, title='', label='', description='',
createPublic=0,
createUserF=0,
REQUEST=None):
@@ -660,7 +805,9 @@ def manage_addZSQLExtendFolder(self, id,
ob.title=title
self._setObject(id, ob)
ob=self._getOb(id)
-
+ setattr(ob,'label',label)
+ setattr(ob,'description',description)
+
checkPermission=getSecurityManager().checkPermission
if createUserF:
@@ -683,7 +830,7 @@ def manage_addZSQLExtendFolder(self, id,
-class ZSQLBibliography(ZSQLExtendFolder):
+class ZSQLBibliography(Folder,ZSQLExtendFolder):
"""Bibliography"""
meta_type="ZSQLBibliography"
def getLabel(self):
@@ -724,8 +871,8 @@ class ZSQLBibliography(ZSQLExtendFolder)
if REQUEST is not None:
return self.manage_main(self, REQUEST)
- manage_options=ZSQLExtendFolder.manage_options+(
- {'label':'Edit Biblio','action':'changeZSQLBibliographyForm'},
+ manage_options=Folder.manage_options+(
+ {'label':'Main Config','action':'changeZSQLBibliographyForm'},
)
@@ -750,7 +897,8 @@ class ZSQLBibliography(ZSQLExtendFolder)
return ret
except:
return None
- def findLabelsFromMapping(self,referenceType):
+
+ def findTagsFromMapping(self,referenceType):
"""gib hash mit label -> generic zurueck"""
self.referencetypes=self.ZopeFind(self.standardMD)
bibdata={}
@@ -758,18 +906,74 @@ class ZSQLBibliography(ZSQLExtendFolder)
fieldlist=self.standardMD.fieldList
for referenceTypeF in self.referencetypes:
- print referenceType,referenceTypeF[1].title
+ #print referenceType,referenceTypeF[1].title
if referenceTypeF[1].title == referenceType:
bibdata[referenceTypeF[1].title]=referenceTypeF[1].fields
bibdata['data']=referenceTypeF[1]
self.fields=bibdata[referenceType]
for field in fieldlist:
- retdata[field]=referenceTypeF[1].getValue(field)[1]
+ if referenceTypeF[1].getValue(field)[0]==None:
+ retdata[field]=field
+ else:
+ retdata[field]=referenceTypeF[1].getValue(field)[0]
return retdata,fieldlist
+ def findLabelsFromMapping(self,referenceType):
+ """gib hash mit label -> generic zurueck"""
+ self.referencetypes=self.ZopeFind(self.standardMD)
+ bibdata={}
+ retdata={}
+ fieldlist=self.standardMD.fieldList
+ for referenceTypeF in self.referencetypes:
+ #print referenceType,referenceTypeF[1].title
+ if referenceTypeF[1].title == referenceType:
+ bibdata[referenceTypeF[1].title]=referenceTypeF[1].fields
+ bibdata['data']=referenceTypeF[1]
+ self.fields=bibdata[referenceType]
+ for field in fieldlist:
+ retdata[field]=referenceTypeF[1].getValue(field)[1]
+ return retdata,fieldlist
+
+ def createIndexTag(self,tag,content):
+ """creste tag"""
+ if content:
+ ret="""<%s>%s%s>"""%(tag,content,tag)
+ return ret
+ else:
+ return ""
+
+ def getMetaDataXML2(self):
+ """crate index meta"""
+
+ fn=os.path.splitext(self.REQUEST['fn'])[0]+"."
+ self.REQUEST['fn']=fn
+
+ pt=PageTemplateFile('Products/ZSQLExtend/zpt/record2.xml').__of__(self)
+ pt.content_type="text/xml"
+ return pt()
+
+ def getMetaDataXML(self):
+ """crate index meta"""
+ pt=PageTemplateFile('Products/ZSQLExtend/zpt/record.xml').__of__(self)
+ pt.content_type="text/xml"
+ return pt()
+
+ def getMetaDatasXML(self):
+ """index"""
+ ret="""
+ """
+ for found in self.search(var="select oid from %s limit ALL"%self.tableName):
+ link=self.absolute_url()+"/"+"record.html?oid=%i"%found.oid
+ metalink=self.absolute_url()+"/"+"getMetaDataXML?oid=%i"%found.oid
+
+ ret+="""\n"""%(link,metalink)
+
+ return ret+"\n"
+
+
manage_addZSQLBibliographyForm=DTMLFile('ZSQLBibliographyAdd', globals())
def manage_addZSQLBibliography(self, id, tableName,label,description,title='',