Diff for /MPIWGWeb/MPIWGProjects.py between versions 1.47.2.64 and 1.47.2.65

version 1.47.2.64, 2006/11/08 14:47:13 version 1.47.2.65, 2006/11/08 16:36:38
Line 282  def manage_addMPIWGTemplate(self, MPIWGT Line 282  def manage_addMPIWGTemplate(self, MPIWGT
   
           
 class MPIWGRoot(ZSQLExtendFolder):  class MPIWGRoot(ZSQLExtendFolder):
     """Stammordner für den Web-Server"""      """Stammordner fuer den Web-Server"""
   
     fieldLabels={'WEB_title':'WEB_Title','xdata_01':'Responsible Scientists','xdata_02':'Department',      fieldLabels={'WEB_title':'WEB_Title','xdata_01':'Responsible Scientists','xdata_02':'Department',
              'xdata_03':'Historical Persons','xdata_04':'Time period',               'xdata_03':'Historical Persons','xdata_04':'Time period',
Line 642  class MPIWGRoot(ZSQLExtendFolder): Line 642  class MPIWGRoot(ZSQLExtendFolder):
                   
   
     def getProjectsByFieldContent(self,fieldName,fieldContentsEntry, date=None):      def getProjectsByFieldContent(self,fieldName,fieldContentsEntry, date=None):
         """gib alle Projekte aus mit Value von field mit fieldName enthält ein Element der Liste fieldContents"""          """gib alle Projekte aus mit Value von field mit fieldName enthaelt ein Element der Liste fieldContents"""
         def sort(x,y):          def sort(x,y):
                 return cmp(x.WEB_title[0],y.WEB_title[0])                  return cmp(x.WEB_title[0],y.WEB_title[0])
   
Line 1066  class MPIWGRoot(ZSQLExtendFolder): Line 1066  class MPIWGRoot(ZSQLExtendFolder):
                     title=[project[0].getContent('WEB_title')]                      title=[project[0].getContent('WEB_title')]
                     #print title                      #print title
                                           
                     if idNr[0]=="x": # kompatibilitŠt mit alter Konvention, x vor der Nummer macht project inactive                      if idNr[0]=="x": # kompatibilitaet mit alter Konvention, x vor der Nummer macht project inactive
                         project[0].setActiveFlag(False)                          project[0].setActiveFlag(False)
                                         
                     if (not dep) or (idNr[0]==dep): #falls dep gesetzt ist nur dieses hinzufŸgen.                      if (not dep) or (idNr[0]==dep): #falls dep gesetzt ist nur dieses hinzufuegen.
                         if onlyActive and project[0].isActiveProject(): #nur active projekte                          if onlyActive and project[0].isActiveProject(): #nur active projekte
                            returnList.append((depth,nr,title,project[0]))                             returnList.append((depth,nr,title,project[0]))
                         elif not onlyActive:                          elif not onlyActive:
Line 1251  class MPIWGRoot(ZSQLExtendFolder): Line 1251  class MPIWGRoot(ZSQLExtendFolder):
         return string.join(ret,";")          return string.join(ret,";")
                   
                           
       def getMembersFromList(self,list):
           """get member names from person full text list"""
           memberlist=[]
           persons=list.split(";")
           for person in persons:
               if len(person)>1: #nicht nur Trennzeichen
                   splitted=person.split(",")
                   if len(splitted)==1:
                       splitted=person.lstrip().rstrip().split(" ")
                   splittedNew=[re.sub(r'\s(.*)','$1',split) for split in splitted]
                   if splittedNew[0]=='':
                       del splittedNew[0]
                   search=string.join(splittedNew,' AND ')
                   
                   if not search=='':
                       try:
                           member=self.MembersCatalog({'title':search})
                       except:
                           member=None
   
                   if member and (member[0].getObject().isPublished()):
                       if person =="Otto Sibum" : person="H. Otto Sibum"
                       if person =="Norton Wise" : person="M. Norton Wise"
                       #memberlist.append("<a href=%s >%s</a>"%(member[0].absolute_url,person.encode('utf-8')))
                       memberlist.append((person, member[0].getObject().getId()))
                   else:
                       #memberlist.append("%s"%person.encode('utf-8'))
                       memberlist.append((person,None))
           return memberlist
                            
     def getUrlFromPerson(self,list):      def getUrlFromPerson(self,list):
         """get urls to person list"""          """get urls to person list"""
         ret=[]          ret=[]
Line 2008  class MPIWGProject(CatalogAware,Folder): Line 2038  class MPIWGProject(CatalogAware,Folder):
   
   
     def generateTemplate(self,RESPONSE=None):      def generateTemplate(self,RESPONSE=None):
         """Erzeuge Template für defined fields not_used"""          """Erzeuge Template fuer defined fields not_used"""
   
         id="index_html"          id="index_html"
         title=id          title=id
Line 2100  class MPIWGProject(CatalogAware,Folder): Line 2130  class MPIWGProject(CatalogAware,Folder):
         return pt()          return pt()
             
     def getGetNeighbourhood(self,wordStr, length=100,tagging=True):      def getGetNeighbourhood(self,wordStr, length=100,tagging=True):
         """finde umgebung um die worte in wordStr, zurŸckgegeben wird eine Array mit den Umgebungen von Fundstellen der Worte          """finde umgebung um die worte in wordStr, zurueckgegeben wird eine Array mit den Umgebungen von Fundstellen der Worte
         alle Tags werden entfernt, die Fundstellen werden mit <span class="found">XX</span> getaggt, die Umgebungen werden           alle Tags werden entfernt, die Fundstellen werden mit <span class="found">XX</span> getaggt, die Umgebungen werden 
         case insensitive gesucht          case insensitive gesucht
         @param wordStr: string mit Worten getrennt durch Leerzeichen, Phrasen sind mit " gekennzeichnet          @param wordStr: string mit Worten getrennt durch Leerzeichen, Phrasen sind mit " gekennzeichnet
                         "eine phrase", "*"  bezeichnet wildcards und wird ignoriert"                          "eine phrase", "*"  bezeichnet wildcards und wird ignoriert"
         @param length: optional, default wert 100, 2*length ist die grš§e der Umgebung          @param length: optional, default wert 100, 2*length ist die groesse der Umgebung
         @param tagging: optional default wert true, kein span tag wird erzweugt falls tag=false          @param tagging: optional default wert true, kein span tag wird erzweugt falls tag=false
         """          """
                   
         ret=[] # nimmt das Array auf, dass spŠter zurŸckgegeben wird          ret=[] # nimmt das Array auf, dass spaeter zurueckgegeben wird
         ranges=[] #Array mit tupeln x,y wobei x die Position des Anfang und y des Endes der i-ten Umgebung angiebt          ranges=[] #Array mit tupeln x,y wobei x die Position des Anfang und y des Endes der i-ten Umgebung angiebt
                   
         def isInRanges(nr,length):          def isInRanges(nr,length):
             """test ob eine gegeben Position nr schon irgendwo in einer Umgebung ist, gibt den Index des ersten Wertes aus ranges zurŸck,               """test ob eine gegeben Position nr schon irgendwo in einer Umgebung ist, gibt den Index des ersten Wertes aus ranges zurueck, 
             -1, wenn kein Treffer              -1, wenn kein Treffer
                           
             @param nr: Position die geprŸft werden soll              @param nr: Position die geprueft werden soll
             @param length: LŠnge des Wortes das geprŸft werden soll              @param length: Laenge des Wortes das geprueft werden soll
             """              """
             for x in ranges:              for x in ranges:
                 if (x[0]<=nr) and (nr < (x[1]-length)):                  if (x[0]<=nr) and (nr < (x[1]-length)):
Line 2158  class MPIWGProject(CatalogAware,Folder): Line 2188  class MPIWGProject(CatalogAware,Folder):
                                           
                     #is word already in one of the results                      #is word already in one of the results
                     nr=isInRanges(pos,len(word))                      nr=isInRanges(pos,len(word))
                     if nr >=0:# word ist in einer schon gefunden Umgebung, dann vergrš§ere diese                      if nr >=0:# word ist in einer schon gefunden Umgebung, dann vergroessere diese
                         x=min(ranges[nr][0],x)                          x=min(ranges[nr][0],x)
                         y=max(ranges[nr][1],y)                          y=max(ranges[nr][1],y)
                               
Line 2168  class MPIWGProject(CatalogAware,Folder): Line 2198  class MPIWGProject(CatalogAware,Folder):
                         ranges[nr]=(x,y) # neue Position der Umgebung                          ranges[nr]=(x,y) # neue Position der Umgebung
   
                         ret[nr]=str # neue Umgebung                          ret[nr]=str # neue Umgebung
                     else: # andernfalls neue Umgebung hinzufŸgen                      else: # andernfalls neue Umgebung hinzufuegen
                         ranges.append((x,y))                          ranges.append((x,y))
   
                         ret.append(str)                          ret.append(str)
Line 2302  class MPIWGProject(CatalogAware,Folder): Line 2332  class MPIWGProject(CatalogAware,Folder):
         else:          else:
             text5=text2              text5=text2
   
         #teste ob WEB_project_description und keine führenden p tags          #teste ob WEB_project_description und keine fuehrenden p tags
         if (len(text5)>4) and (not text5[0:3]=='<p>') and (field=='WEB_project_description'):          if (len(text5)>4) and (not text5[0:3]=='<p>') and (field=='WEB_project_description'):
             text5= "<p>"+text5+"</p>"              text5= "<p>"+text5+"</p>"
   

Removed from v.1.47.2.64  
changed lines
  Added in v.1.47.2.65


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