annotate MPIWGStaff.py @ 213:8d6d14498778

trying # 130: sortProjects funktioniert nicht https://it-dev.mpiwg-berlin.mpg.de/tracs/webpage/ticket/130
author casties
date Wed, 07 Aug 2013 11:27:29 +0200
parents 7791d4fc8a0e
children 3b517b412f77
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
bca61e893fcc first checkin of MPIWGWeb r2 branch from CVS into mercurial
casties
parents:
diff changeset
1 """This file contains the classes for the organization of the staff"""
bca61e893fcc first checkin of MPIWGWeb r2 branch from CVS into mercurial
casties
parents:
diff changeset
2
bca61e893fcc first checkin of MPIWGWeb r2 branch from CVS into mercurial
casties
parents:
diff changeset
3 from OFS.Folder import Folder
bca61e893fcc first checkin of MPIWGWeb r2 branch from CVS into mercurial
casties
parents:
diff changeset
4 from Products.PageTemplates.PageTemplateFile import PageTemplateFile
bca61e893fcc first checkin of MPIWGWeb r2 branch from CVS into mercurial
casties
parents:
diff changeset
5
186
3ea224968f95 fix traversal to MPIWGStaffMember objects.
casties
parents: 185
diff changeset
6 from zope.interface import implements
3ea224968f95 fix traversal to MPIWGStaffMember objects.
casties
parents: 185
diff changeset
7 from zope.publisher.interfaces import IPublishTraverse
3ea224968f95 fix traversal to MPIWGStaffMember objects.
casties
parents: 185
diff changeset
8 from ZPublisher.BaseRequest import DefaultPublishTraverse
191
90d44df497a6 updated breadcrumb handling, works for members now.
casties
parents: 190
diff changeset
9 from Acquisition import aq_parent
186
3ea224968f95 fix traversal to MPIWGStaffMember objects.
casties
parents: 185
diff changeset
10
3
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
11 from AccessControl import ClassSecurityInfo
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
12 from App.class_init import InitializeClass
159
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
13 from App.ImageFile import ImageFile
86
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
14 from Products.PythonScripts.standard import sql_quote
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
15 from Products.ExtFile import ExtFile
0
bca61e893fcc first checkin of MPIWGWeb r2 branch from CVS into mercurial
casties
parents:
diff changeset
16 import logging
bca61e893fcc first checkin of MPIWGWeb r2 branch from CVS into mercurial
casties
parents:
diff changeset
17 import email
bca61e893fcc first checkin of MPIWGWeb r2 branch from CVS into mercurial
casties
parents:
diff changeset
18 import re
86
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
19
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
20 from Products.ZDBInterface.ZDBInterfaceFolder import ZDBInterfaceFolder
2
ddf6c1a27a4b new version with main_template and css in product.
casties
parents: 0
diff changeset
21
188
16d55695f1c8 fix updating staff entries through "Update personal homepages". (creating new entries doesn't work)
casties
parents: 187
diff changeset
22 from SrvTxtUtils import getInt, unicodify, utf8ify, sqlName
86
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
23 import MPIWGHelper
0
bca61e893fcc first checkin of MPIWGWeb r2 branch from CVS into mercurial
casties
parents:
diff changeset
24
86
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
25 #
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
26 # compatibility
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
27 # TODO: should be removed when done
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
28 import MPIWGStaff_old
0
bca61e893fcc first checkin of MPIWGWeb r2 branch from CVS into mercurial
casties
parents:
diff changeset
29
189
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
30 #createNewDBEntry = MPIWGStaff_old.createNewDBEntry
0
bca61e893fcc first checkin of MPIWGWeb r2 branch from CVS into mercurial
casties
parents:
diff changeset
31
86
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
32 class MPIWGStaff(MPIWGStaff_old.MPIWGStaff):
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
33 """Staff"""
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
34 pass
0
bca61e893fcc first checkin of MPIWGWeb r2 branch from CVS into mercurial
casties
parents:
diff changeset
35
86
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
36 manage_addMPIWGStaffForm = MPIWGStaff_old.manage_addMPIWGStaffForm
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
37 manage_addMPIWGStaff = MPIWGStaff_old.manage_addMPIWGStaff
0
bca61e893fcc first checkin of MPIWGWeb r2 branch from CVS into mercurial
casties
parents:
diff changeset
38
3
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
39
0
bca61e893fcc first checkin of MPIWGWeb r2 branch from CVS into mercurial
casties
parents:
diff changeset
40
2
ddf6c1a27a4b new version with main_template and css in product.
casties
parents: 0
diff changeset
41 class MPIWGStaffFolder(ZDBInterfaceFolder):
ddf6c1a27a4b new version with main_template and css in product.
casties
parents: 0
diff changeset
42 """Folder of staff objects"""
186
3ea224968f95 fix traversal to MPIWGStaffMember objects.
casties
parents: 185
diff changeset
43 implements(IPublishTraverse)
2
ddf6c1a27a4b new version with main_template and css in product.
casties
parents: 0
diff changeset
44
ddf6c1a27a4b new version with main_template and css in product.
casties
parents: 0
diff changeset
45 meta_type="MPIWGStaffFolder"
ddf6c1a27a4b new version with main_template and css in product.
casties
parents: 0
diff changeset
46 security=ClassSecurityInfo()
3
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
47
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
48 #
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
49 # templates
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
50 #
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
51 member_index_html = PageTemplateFile('zpt/staff/member_index_html', globals())
159
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
52 edit_css = ImageFile('css/edit.css', globals())
3
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
53
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
54
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
55 #
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
56 # hook into traversal to create folder of virtual staff objects
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
57 # like /members/$username/index_html
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
58 #
186
3ea224968f95 fix traversal to MPIWGStaffMember objects.
casties
parents: 185
diff changeset
59 def publishTraverse(self, request, name):
3ea224968f95 fix traversal to MPIWGStaffMember objects.
casties
parents: 185
diff changeset
60 """change the traversal"""
3ea224968f95 fix traversal to MPIWGStaffMember objects.
casties
parents: 185
diff changeset
61 # get stored path
3ea224968f95 fix traversal to MPIWGStaffMember objects.
casties
parents: 185
diff changeset
62 logging.debug("publishtraverse: name=%s"%(name))
3
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
63
186
3ea224968f95 fix traversal to MPIWGStaffMember objects.
casties
parents: 185
diff changeset
64 # try name as username
3ea224968f95 fix traversal to MPIWGStaffMember objects.
casties
parents: 185
diff changeset
65 member = self.getMember(username=name)
3ea224968f95 fix traversal to MPIWGStaffMember objects.
casties
parents: 185
diff changeset
66 if member is not None:
3ea224968f95 fix traversal to MPIWGStaffMember objects.
casties
parents: 185
diff changeset
67 # traverse to MPIWGStaffMember object
3ea224968f95 fix traversal to MPIWGStaffMember objects.
casties
parents: 185
diff changeset
68 member = member.__of__(self)
3ea224968f95 fix traversal to MPIWGStaffMember objects.
casties
parents: 185
diff changeset
69 return member
3ea224968f95 fix traversal to MPIWGStaffMember objects.
casties
parents: 185
diff changeset
70
3ea224968f95 fix traversal to MPIWGStaffMember objects.
casties
parents: 185
diff changeset
71 # use default traverser
3ea224968f95 fix traversal to MPIWGStaffMember objects.
casties
parents: 185
diff changeset
72 tr = DefaultPublishTraverse(self, request)
3ea224968f95 fix traversal to MPIWGStaffMember objects.
casties
parents: 185
diff changeset
73 ob = tr.publishTraverse(request, name)
3ea224968f95 fix traversal to MPIWGStaffMember objects.
casties
parents: 185
diff changeset
74 return ob
3ea224968f95 fix traversal to MPIWGStaffMember objects.
casties
parents: 185
diff changeset
75
3
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
76
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
77 def getMember(self, username=None, key=None):
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
78 """returns a MPIWGStaffMember object if the username exists"""
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
79 member = None
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
80 if username is not None:
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
81 # TODO: we should have a username column
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
82 email = '%s@mpiwg-berlin.mpg.de'%username
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
83 content = self.executeZSQL("select * from personal_www where e_mail = %s", [email])
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
84 if len(content) > 0:
86
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
85 member = MPIWGStaffMember(self, dbresult=content[0])
3
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
86
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
87 elif key is not None:
40
fd8e78bbc5ed more work on projects.
casties
parents: 38
diff changeset
88 # TODO: sometimes key is lowercased (e.g. responsibleScientistsList), we should fix the data
fd8e78bbc5ed more work on projects.
casties
parents: 38
diff changeset
89 content = self.executeZSQL("select * from personal_www where lower(key) = %s", [key.lower()])
3
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
90 if len(content) > 0:
86
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
91 member = MPIWGStaffMember(self, dbresult=content[0])
3
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
92
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
93 return member
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
94
2
ddf6c1a27a4b new version with main_template and css in product.
casties
parents: 0
diff changeset
95
40
fd8e78bbc5ed more work on projects.
casties
parents: 38
diff changeset
96 def isActiveMember(self, key):
fd8e78bbc5ed more work on projects.
casties
parents: 38
diff changeset
97 """returns if member key is active"""
fd8e78bbc5ed more work on projects.
casties
parents: 38
diff changeset
98 res = self.executeZSQL("select * from personal_www where lower(key) = %s and publish_the_data = 'yes'", [key.lower()])
fd8e78bbc5ed more work on projects.
casties
parents: 38
diff changeset
99 return len(res) > 0
fd8e78bbc5ed more work on projects.
casties
parents: 38
diff changeset
100
fd8e78bbc5ed more work on projects.
casties
parents: 38
diff changeset
101
206
31b28f369fd3 more flexible getMemberList()
casties
parents: 204
diff changeset
102 def getMemberList(self, department=None, sortBy='last_name', onlyCurrent=False, arrivedWithin=None,
31b28f369fd3 more flexible getMemberList()
casties
parents: 204
diff changeset
103 onlyPublished=True, onlyWithEmail=True, onlyScholar=True, limit=0):
86
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
104 """Return the list of members.
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
105
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
106 Returns a list of MPIWGStaffMember objects.
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
107 """
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
108 members = []
206
31b28f369fd3 more flexible getMemberList()
casties
parents: 204
diff changeset
109 args = []
31b28f369fd3 more flexible getMemberList()
casties
parents: 204
diff changeset
110 wheres = []
189
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
111
206
31b28f369fd3 more flexible getMemberList()
casties
parents: 204
diff changeset
112 if onlyPublished:
31b28f369fd3 more flexible getMemberList()
casties
parents: 204
diff changeset
113 wheres.append("publish_the_data = 'yes'")
31b28f369fd3 more flexible getMemberList()
casties
parents: 204
diff changeset
114
31b28f369fd3 more flexible getMemberList()
casties
parents: 204
diff changeset
115 if onlyWithEmail:
31b28f369fd3 more flexible getMemberList()
casties
parents: 204
diff changeset
116 wheres.append("e_mail <> ''")
31b28f369fd3 more flexible getMemberList()
casties
parents: 204
diff changeset
117
31b28f369fd3 more flexible getMemberList()
casties
parents: 204
diff changeset
118 if onlyScholar:
31b28f369fd3 more flexible getMemberList()
casties
parents: 204
diff changeset
119 wheres.append("is_scholar = 'yes'")
31b28f369fd3 more flexible getMemberList()
casties
parents: 204
diff changeset
120
93
48e88706cfc3 department filter for getMemberList.
casties
parents: 86
diff changeset
121 if department is not None:
206
31b28f369fd3 more flexible getMemberList()
casties
parents: 204
diff changeset
122 wheres.append("department ilike %s")
93
48e88706cfc3 department filter for getMemberList.
casties
parents: 86
diff changeset
123 args.append('%%%s%%'%department)
86
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
124
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
125 if onlyCurrent:
206
31b28f369fd3 more flexible getMemberList()
casties
parents: 204
diff changeset
126 wheres.append("date_from < CURRENT_DATE")
86
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
127
175
7d85ebe92ecf getMemberList gets arrivedWithin parameter.
casties
parents: 162
diff changeset
128 if arrivedWithin is not None:
206
31b28f369fd3 more flexible getMemberList()
casties
parents: 204
diff changeset
129 wheres.append("date_from > CURRENT_DATE - interval %s")
175
7d85ebe92ecf getMemberList gets arrivedWithin parameter.
casties
parents: 162
diff changeset
130 args.append(arrivedWithin)
206
31b28f369fd3 more flexible getMemberList()
casties
parents: 204
diff changeset
131
31b28f369fd3 more flexible getMemberList()
casties
parents: 204
diff changeset
132 # assemble query
31b28f369fd3 more flexible getMemberList()
casties
parents: 204
diff changeset
133 query = "SELECT * FROM personal_www_list"
31b28f369fd3 more flexible getMemberList()
casties
parents: 204
diff changeset
134 if len(wheres) > 0:
31b28f369fd3 more flexible getMemberList()
casties
parents: 204
diff changeset
135 query += " WHERE " + " AND ".join(wheres)
175
7d85ebe92ecf getMemberList gets arrivedWithin parameter.
casties
parents: 162
diff changeset
136
86
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
137 if sortBy == 'last_name':
206
31b28f369fd3 more flexible getMemberList()
casties
parents: 204
diff changeset
138 query += " ORDER BY lower(last_name)"
86
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
139 elif sortBy == 'date_from':
206
31b28f369fd3 more flexible getMemberList()
casties
parents: 204
diff changeset
140 query += " ORDER BY date_from DESC"
86
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
141
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
142 if limit > 0:
206
31b28f369fd3 more flexible getMemberList()
casties
parents: 204
diff changeset
143 query += " LIMIT %s"%int(limit)
86
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
144
93
48e88706cfc3 department filter for getMemberList.
casties
parents: 86
diff changeset
145 result = self.executeZSQL(query, args)
86
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
146 for res in result:
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
147 members.append(MPIWGStaffMember(self, dbresult=res))
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
148
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
149 return members
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
150
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
151
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
152 def sortPriority(self,list):
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
153 def sort(x,y):
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
154 try:
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
155 xInt=int(x.priority)
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
156 except:
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
157 xInt=0
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
158 try:
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
159 yInt=int(y.priority)
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
160 except:
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
161 yInt=0
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
162
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
163 return cmp(xInt,yInt)
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
164
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
165 if not list:
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
166 return []
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
167 tmp=[x for x in list]
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
168 tmp.sort(sort)
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
169
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
170 return tmp
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
171
86
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
172
106
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
173 def importSortingModeFromOldStaff(self):
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
174 """ only used for the migration to the new website """
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
175 ret=[]
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
176 for member in self.getMemberList():
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
177 email = member.content.e_mail
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
178 un = email.split("@")[0]
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
179
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
180 logging.debug(un)
122
4a54537ddcf7 fix converting old members
dwinter
parents: 110
diff changeset
181 olduser = self.members_old.get(un)
106
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
182
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
183 if not olduser is None:
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
184 mode =olduser.getSortingMode()
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
185
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
186
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
187 if mode.startswith("year"):
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
188 mode="year"
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
189
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
190 query="UPDATE personal_www SET publications_mode=%s WHERE key=%s"
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
191
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
192 self.executeZSQL(query,[mode,member.getKey()])
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
193
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
194 return ret
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
195
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
196
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
197 def importPublishFotoFromOldStaff(self):
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
198 """ only used for the migration to the new website """
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
199 ret=[]
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
200 for member in self.getMemberList():
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
201 email = member.content.e_mail
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
202 un = email.split("@")[0]
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
203
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
204 logging.debug(un)
122
4a54537ddcf7 fix converting old members
dwinter
parents: 110
diff changeset
205 olduser = self.members_old.get(un)
106
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
206
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
207 if not olduser is None:
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
208 mode =olduser.getPublishImage()
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
209
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
210
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
211
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
212 query="UPDATE personal_www SET image_p=%s WHERE key=%s"
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
213
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
214 self.executeZSQL(query,[mode,member.getKey()])
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
215
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
216 return ret
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
217
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
218 def showDownloadableFiles(self):
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
219 """copy df to the new"""
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
220 logging.debug("huh")
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
221 ret=[]
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
222
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
223 for member in self.getMemberList(onlyCurrent=True):
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
224 email = member.content.e_mail
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
225 un = email.split("@")[0]
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
226
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
227 logging.debug(un)
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
228 olduser = self.www_neu.members.get(un)
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
229 if olduser is None:
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
230 continue;
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
231 df = olduser.get('downloadableFiles')
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
232 if df is not None:
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
233 ret.append(olduser)
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
234
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
235 return ret,len(ret)
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
236
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
237
189
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
238 def createNewDBEntry(self,publish_the_data,key,name,vorname,titles_new,position,e_mail,e_mail_p,date_from,date_to,abteilung,heimat_inst,funded_by="",e_mail2="",txt="",txt_p="no",stay_at_mpiwg="",group="",web_object_created="no",current_work=""):
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
239 """lege person in der datenbank an"""
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
240
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
241 if date_to=="": # wenn date_to leer
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
242 date_to="date_none"
106
7dd264f9b728 importOldSettingforSorting and Publish
dwinter
parents: 100
diff changeset
243
189
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
244 if date_from=="": # wenn date_fromleer
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
245 date_from="date_none"
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
246 msg=""
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
247 #test ob id schon existiert
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
248 if self.ZSQLQuery("select key from personal_www where key='%s'"%id):
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
249 return False,"ERROR:key%s already exists"%key
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
250
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
251 #eintragen
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
252 columnlist="""publish_the_data,key,last_name,first_name,titles_new,status,e_mail,e_mail_p,date_from,date_to,department,home_inst,funded_by,e_mail2,date_stay_at_mpiwg,web_object_created,"group",current_work,current_work_p """
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
253 insertTuple=(publish_the_data,key,name,vorname,titles_new,position,e_mail,e_mail_p,date_from,date_to,abteilung,heimat_inst,funded_by,e_mail2,stay_at_mpiwg,web_object_created,group,current_work,"yes")
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
254
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
255 insert=[]
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
256 for element in insertTuple:
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
257 if element=="date_none": # date_none eintrag wird zu null uebersetzt
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
258 insert.append('null')
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
259 else:
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
260 insert.append("%s"%self.ZSQLQuote(element))
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
261
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
262 insertStr=",".join(insert)
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
263 queryStr="INSERT INTO personal_www (%s) VALUES (%s)"%(columnlist,insertStr)
210
7791d4fc8a0e remove "set datestyle" as it confuses psycopg date parsing. make sure postgresql default is set accordingly.
casties
parents: 208
diff changeset
264 #self.ZSQLQuery("SET DATESTYLE TO 'German'")
189
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
265 self.ZSQLQuery(queryStr)
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
266 logging.info("createNewDBEntry %s:"%queryStr)
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
267 #currentwork
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
268 #if not (current_work==""):
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
269 # queryStr="INSERT INTO current_work (key_main,current,publish) VALUES ('%s',%s,'%s')"%(key,self.ZSQLQuote(current_work),"yes")
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
270
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
271 # self.ZSQLQuery(queryStr)
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
272
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
273 return True,msg
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
274
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
275 def addEmails(self,RESPONSE):
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
276 """add emails to the members from form"""
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
277 memberFolder=getattr(self,'members')
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
278 args=self.REQUEST.form
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
279 arg_k=args.keys()
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
280 arg_k.remove("submit")
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
281 ret="<html><body>"
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
282 for key in arg_k:
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
283 k=key
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
284
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
285 qstr="select * from personal_www where key=%s"%self.ZSQLQuote(k)
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
286 res=self.executeZSQL(qstr)[0]
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
287 if args[key]!="": #email-adresse wurde eingetragen
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
288 #create the object
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
289 e_mail=args[key]
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
290
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
291
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
292 qstr="update personal_www set web_object_created='yes',e_mail='%s@mpiwg-berlin.mpg.de' where key=%s"%(e_mail,self.ZSQLQuote(k))
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
293 self.executeZSQL(qstr)
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
294
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
295 ret+="<p>Added: %s</p>"%k
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
296
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
297
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
298 return ret+"</body></html>"
2
ddf6c1a27a4b new version with main_template and css in product.
casties
parents: 0
diff changeset
299 def manage_addMPIWGStaffFolderForm(self):
ddf6c1a27a4b new version with main_template and css in product.
casties
parents: 0
diff changeset
300 """form for adding the project"""
ddf6c1a27a4b new version with main_template and css in product.
casties
parents: 0
diff changeset
301 pt=PageTemplateFile('zpt/addMPIWGStaffFolderForm', globals()).__of__(self)
ddf6c1a27a4b new version with main_template and css in product.
casties
parents: 0
diff changeset
302 return pt()
ddf6c1a27a4b new version with main_template and css in product.
casties
parents: 0
diff changeset
303
ddf6c1a27a4b new version with main_template and css in product.
casties
parents: 0
diff changeset
304 def manage_addMPIWGStaffFolder(self,id,title,RESPONSE=None):
ddf6c1a27a4b new version with main_template and css in product.
casties
parents: 0
diff changeset
305 """add it"""
ddf6c1a27a4b new version with main_template and css in product.
casties
parents: 0
diff changeset
306 newObj=MPIWGStaffFolder(id,title)
ddf6c1a27a4b new version with main_template and css in product.
casties
parents: 0
diff changeset
307
ddf6c1a27a4b new version with main_template and css in product.
casties
parents: 0
diff changeset
308 self._setObject(id,newObj)
ddf6c1a27a4b new version with main_template and css in product.
casties
parents: 0
diff changeset
309
ddf6c1a27a4b new version with main_template and css in product.
casties
parents: 0
diff changeset
310 if RESPONSE is not None:
ddf6c1a27a4b new version with main_template and css in product.
casties
parents: 0
diff changeset
311 RESPONSE.redirect('manage_main')
ddf6c1a27a4b new version with main_template and css in product.
casties
parents: 0
diff changeset
312
3
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
313
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
314 class MPIWGStaffMember(Folder):
3
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
315 """MPIWG staff member object from database"""
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
316
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
317 security = ClassSecurityInfo()
65
63184d71c014 lots of cleaning up.
casties
parents: 59
diff changeset
318
63184d71c014 lots of cleaning up.
casties
parents: 59
diff changeset
319 # templates
63184d71c014 lots of cleaning up.
casties
parents: 59
diff changeset
320 mainEditFile=PageTemplateFile('zpt/staff/edit_main', globals())
100
f4ac675b2031 more members pages.
casties
parents: 93
diff changeset
321 talks_full_html = PageTemplateFile('zpt/staff/talks_full_html', globals())
f4ac675b2031 more members pages.
casties
parents: 93
diff changeset
322 teaching_full_html = PageTemplateFile('zpt/staff/teaching_full_html', globals())
f4ac675b2031 more members pages.
casties
parents: 93
diff changeset
323
3
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
324
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
325 def __init__(self, folder, dbresult):
86
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
326 """constructor: takes parent MPIWGStaffFolder and content (DB row)"""
3
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
327 self.folder = folder
86
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
328 self.content = dbresult
3
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
329
186
3ea224968f95 fix traversal to MPIWGStaffMember objects.
casties
parents: 185
diff changeset
330
3ea224968f95 fix traversal to MPIWGStaffMember objects.
casties
parents: 185
diff changeset
331 def index_html(self, REQUEST, RESPONSE):
3ea224968f95 fix traversal to MPIWGStaffMember objects.
casties
parents: 185
diff changeset
332 """show homepage"""
3ea224968f95 fix traversal to MPIWGStaffMember objects.
casties
parents: 185
diff changeset
333 # get template /template/member_index_html (with acquisition)
3ea224968f95 fix traversal to MPIWGStaffMember objects.
casties
parents: 185
diff changeset
334 pt = getattr(self.template, 'member_index_html', None)
3ea224968f95 fix traversal to MPIWGStaffMember objects.
casties
parents: 185
diff changeset
335 if pt is not None:
3ea224968f95 fix traversal to MPIWGStaffMember objects.
casties
parents: 185
diff changeset
336 return pt(member=self)
3ea224968f95 fix traversal to MPIWGStaffMember objects.
casties
parents: 185
diff changeset
337
3ea224968f95 fix traversal to MPIWGStaffMember objects.
casties
parents: 185
diff changeset
338 return "No template /template/member_index_html"
3ea224968f95 fix traversal to MPIWGStaffMember objects.
casties
parents: 185
diff changeset
339
3ea224968f95 fix traversal to MPIWGStaffMember objects.
casties
parents: 185
diff changeset
340
3
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
341 def isValid(self):
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
342 """returns if this member exists"""
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
343 return len(self.content) > 0
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
344
79
7f26c8e6c8e9 more styles for project lists.
casties
parents: 73
diff changeset
345 def isActive(self):
7f26c8e6c8e9 more styles for project lists.
casties
parents: 73
diff changeset
346 """Return if this member is visible (published)."""
7f26c8e6c8e9 more styles for project lists.
casties
parents: 73
diff changeset
347 return (self.content.publish_the_data == 'yes')
7f26c8e6c8e9 more styles for project lists.
casties
parents: 73
diff changeset
348
3
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
349 def getKey(self):
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
350 """returns the db key"""
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
351 return self.content.key
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
352
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
353 def getUsername(self):
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
354 """returns the username"""
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
355 id = re.sub('@mpiwg-berlin\.mpg\.de', '', self.content.e_mail)
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
356 return id
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
357
86
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
358 getId = getUsername
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
359
46
955d102392db pubman integration 0.2
dwinter
parents: 38
diff changeset
360 def getConeId(self):
955d102392db pubman integration 0.2
dwinter
parents: 38
diff changeset
361 """return cone ID"""
86
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
362 results= self.folder.executeZSQL("SELECT coneid FROM keys WHERE key_main = %s",[self.content.key])
46
955d102392db pubman integration 0.2
dwinter
parents: 38
diff changeset
363 for res in results:
79
7f26c8e6c8e9 more styles for project lists.
casties
parents: 73
diff changeset
364 return res.coneid
46
955d102392db pubman integration 0.2
dwinter
parents: 38
diff changeset
365 return None
955d102392db pubman integration 0.2
dwinter
parents: 38
diff changeset
366
159
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
367 def getPublishedImageUrl(self, width=None, height=None, showAlways=False):
3
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
368 """returns the URL to the image if it is published"""
159
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
369 if self.content.image_p == 'yes' or showAlways:
3
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
370 url = 'http://digilib.mpiwg-berlin.mpg.de/digitallibrary/Scaler?fn=permanent/mpiwg/staff/%s'%self.getUsername()
159
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
371 if width is not None:
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
372 url += '&dw=%s'%width
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
373
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
374 if height is not None:
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
375 url += '&dh=%s'%height
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
376
3
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
377 return url
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
378
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
379 return None
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
380
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
381 def getContent(self):
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
382 """returns the db content of this object"""
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
383 return self.content
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
384
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
385
3
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
386 # TODO: ugly!
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
387 security.declarePublic('sortBibliography')
79
7f26c8e6c8e9 more styles for project lists.
casties
parents: 73
diff changeset
388 def sortBibliography(self, bib, sortingMode=None, max=None):
3
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
389 """sort bibliography"""
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
390 if not sortingMode:
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
391 sortingMode= "priority"
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
392
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
393 l = [x for x in bib]
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
394
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
395 if sortingMode == "year":
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
396 l.sort(key=lambda x: getInt(x.year))
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
397 else:
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
398 l.sort(key=lambda x: getInt(x.priority))
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
399
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
400 if max:
79
7f26c8e6c8e9 more styles for project lists.
casties
parents: 73
diff changeset
401 return l[0:max]
3
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
402 else:
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
403 return l
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
404
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
405
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
406
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
407 def execute(self,mode,REQUEST=None):
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
408 method = getattr(self,mode,None)
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
409 if method is not None:
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
410 return method(REQUEST);
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
411 else:
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
412 return "NOT FOUND"
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
413
86
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
414
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
415 getUrl = MPIWGHelper.getUrl
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
416
100
f4ac675b2031 more members pages.
casties
parents: 93
diff changeset
417 def getTalks(self, published=True, sortBy='priority'):
f4ac675b2031 more members pages.
casties
parents: 93
diff changeset
418 """Return the list of talks"""
f4ac675b2031 more members pages.
casties
parents: 93
diff changeset
419 query = "SELECT oid,* FROM talks WHERE key_main = %s"
f4ac675b2031 more members pages.
casties
parents: 93
diff changeset
420 if published:
f4ac675b2031 more members pages.
casties
parents: 93
diff changeset
421 query += " and published = 'yes'"
f4ac675b2031 more members pages.
casties
parents: 93
diff changeset
422
f4ac675b2031 more members pages.
casties
parents: 93
diff changeset
423 if sortBy == 'priority':
f4ac675b2031 more members pages.
casties
parents: 93
diff changeset
424 query += " order by priority"
f4ac675b2031 more members pages.
casties
parents: 93
diff changeset
425
f4ac675b2031 more members pages.
casties
parents: 93
diff changeset
426 return self.folder.executeZSQL(query, [self.content.key])
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
427
100
f4ac675b2031 more members pages.
casties
parents: 93
diff changeset
428 def getTeaching(self, published=True, sortBy='priority'):
f4ac675b2031 more members pages.
casties
parents: 93
diff changeset
429 """Return the list of teaching activities"""
f4ac675b2031 more members pages.
casties
parents: 93
diff changeset
430 query = "SELECT oid,* FROM teaching WHERE key_main = %s"
f4ac675b2031 more members pages.
casties
parents: 93
diff changeset
431 if published:
f4ac675b2031 more members pages.
casties
parents: 93
diff changeset
432 query += " AND published = 'yes'"
f4ac675b2031 more members pages.
casties
parents: 93
diff changeset
433
f4ac675b2031 more members pages.
casties
parents: 93
diff changeset
434 if sortBy == 'priority':
f4ac675b2031 more members pages.
casties
parents: 93
diff changeset
435 query += " ORDER BY priority"
f4ac675b2031 more members pages.
casties
parents: 93
diff changeset
436
107
bf3dc3a12147 needed second level foldable
dwinter
parents: 106
diff changeset
437 return self.folder.executeZSQL(query,[self.content.key])
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
438
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
439
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
440 def getLastUpdateCV(self):
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
441 """getDate of Last Update"""
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
442 try:
162
47392bf3fcba clean ups and fixes
casties
parents: 159
diff changeset
443 fname="%s_cv.pdf"%self.getUsername().encode('utf-8')
47392bf3fcba clean ups and fixes
casties
parents: 159
diff changeset
444 logging.debug(fname)
47392bf3fcba clean ups and fixes
casties
parents: 159
diff changeset
445 ob=self.folder._getOb("downloadableFiles")._getOb(fname)
47392bf3fcba clean ups and fixes
casties
parents: 159
diff changeset
446 return ob.bobobase_modification_time()
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
447 except:
162
47392bf3fcba clean ups and fixes
casties
parents: 159
diff changeset
448 return "No file yet!"
86
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
449
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
450
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
451 def getLastUpdatePublications(self):
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
452 """getDate of Last Update"""
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
453 try:
162
47392bf3fcba clean ups and fixes
casties
parents: 159
diff changeset
454 ob=self.folder._getOb("downloadableFiles")._getOb("%s_publications.pdf"%self.getUsername().encode('utf-8'))
47392bf3fcba clean ups and fixes
casties
parents: 159
diff changeset
455 return ob.bobobase_modification_time()
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
456 except:
162
47392bf3fcba clean ups and fixes
casties
parents: 159
diff changeset
457 return "No file yet!"
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
458
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
459
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
460 def downloadCV(self,REQUEST):
194
45984e00665f upload and download cv and publicationlist
dwinter
parents: 193
diff changeset
461 """download the cv"""
45984e00665f upload and download cv and publicationlist
dwinter
parents: 193
diff changeset
462
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
463 fname="%s_cv.pdf"%self.getUsername().encode('utf-8')
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
464 logging.debug(fname)
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
465 ob=self.folder._getOb("downloadableFiles")._getOb(fname)
194
45984e00665f upload and download cv and publicationlist
dwinter
parents: 193
diff changeset
466
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
467 REQUEST.RESPONSE.redirect(ob.absolute_url())
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
468
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
469 def downloadPublications(self,REQUEST):
194
45984e00665f upload and download cv and publicationlist
dwinter
parents: 193
diff changeset
470 """donwload the publication list"""
45984e00665f upload and download cv and publicationlist
dwinter
parents: 193
diff changeset
471
45984e00665f upload and download cv and publicationlist
dwinter
parents: 193
diff changeset
472
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
473 ob=self.folder._getOb("downloadableFiles")._getOb("%s_publications.pdf"%self.getUsername().encode('utf-8'))
194
45984e00665f upload and download cv and publicationlist
dwinter
parents: 193
diff changeset
474
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
475 REQUEST.RESPONSE.redirect(ob.absolute_url())
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
476
159
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
477
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
478 def getAdditionalLinks(self):
208
6d6076e28430 fix deleteField for additionalLink (still ugly though)
casties
parents: 206
diff changeset
479 return self.folder.executeZSQL("SELECT oid,* FROM additionallink WHERE key_main = %s ORDER BY priority",[self.content.key])
159
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
480
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
481
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
482 def getPathStyle(self, path, selected, style=""):
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
483 """returns a string with the given style + 'sel' if path == selected."""
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
484
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
485 if path == selected:
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
486 return style + 'sel'
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
487 else:
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
488 return style
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
489
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
490
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
491 security.declareProtected('View management screens','edit')
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
492 def edit(self,REQUEST=None):
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
493 """Edit the basic information"""
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
494 if REQUEST:
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
495 argv=REQUEST.form
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
496
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
497 if argv.has_key('last_name'): #got data to change
149
0d9eb2a859d3 fixed typo
casties
parents: 147
diff changeset
498 self.invalidate_cache()
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
499 self.changeData(argv);
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
500
159
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
501 pt=PageTemplateFile('zpt/staff/edit_basic', globals()).__of__(self)
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
502 return pt()
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
503
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
504
159
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
505 security.declareProtected('View management screens','editShortEntry')
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
506 def editShortEntry(self,REQUEST=None):
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
507 """Edit the basic information"""
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
508 if REQUEST:
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
509 argv=REQUEST.form
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
510
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
511 if argv.has_key('current_work'): #got data to change
149
0d9eb2a859d3 fixed typo
casties
parents: 147
diff changeset
512 self.invalidate_cache()
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
513 self.changeData(argv);
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
514
159
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
515 pt=PageTemplateFile('zpt/staff/edit_shortEntry', globals()).__of__(self)
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
516 return pt()
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
517
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
518
159
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
519 security.declareProtected('View management screens', 'editProfile')
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
520 def editProfile(self, REQUEST=None):
159
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
521 """edit Profile, new entry replaces CD, current work and research interests"""
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
522 if REQUEST:
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
523 kupu = REQUEST.form.get('kupu', None);
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
524 preview = REQUEST.form.get('preview', None);
3
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
525
159
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
526 if kupu:
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
527 start = kupu.find("<body>")
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
528 end = kupu.find("</body>")
187
71c2d76f09b5 fix editProfile.
casties
parents: 186
diff changeset
529 newcontent = kupu[start+6:end]
71c2d76f09b5 fix editProfile.
casties
parents: 186
diff changeset
530 query = "UPDATE personal_www SET profile=%s WHERE key=%s"
71c2d76f09b5 fix editProfile.
casties
parents: 186
diff changeset
531 self.executeZSQL(query, [newcontent, self.content.key])
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
532
159
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
533 if preview:
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
534 pass
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
535 # TODO: not supported yet
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
536 # if RESPONSE:
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
537 # self.redirect(RESPONSE,"editProfile")
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
538 # return self.preview(newcontent)
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
539
159
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
540 pt = PageTemplateFile('zpt/staff/edit_profile.zpt', globals()).__of__(self)
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
541 return pt()
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
542
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
543
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
544
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
545 security.declareProtected('View management screens','editTalks')
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
546 def editTalks(self,REQUEST):
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
547 """edit talks"""
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
548 if REQUEST:
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
549 argv=REQUEST.form
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
550
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
551 if argv.has_key('main_fields'): #got data to change
149
0d9eb2a859d3 fixed typo
casties
parents: 147
diff changeset
552 self.invalidate_cache()
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
553 self.changeAdditionalData(argv);
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
554
159
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
555 pt=PageTemplateFile('zpt/staff/edit_talks.zpt', globals()).__of__(self)
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
556 return pt()
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
557
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
558
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
559 security.declareProtected('View management screens','editTeaching')
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
560 def editTeaching(self,REQUEST):
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
561 """edit teaching"""
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
562 if REQUEST:
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
563 argv=REQUEST.form
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
564
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
565 if argv.has_key('main_fields'): #got data to change
149
0d9eb2a859d3 fixed typo
casties
parents: 147
diff changeset
566 self.invalidate_cache()
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
567 self.changeAdditionalData(argv);
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
568
159
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
569 pt=PageTemplateFile('zpt/staff/edit_teaching.zpt', globals()).__of__(self)
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
570 return pt()
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
571
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
572
159
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
573 security.declareProtected('View management screens','editAdditionalLinks')
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
574 def editAdditionalLinks(self,REQUEST):
159
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
575 """editiere die additional link von der Webseite"""
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
576 if REQUEST:
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
577 argv=REQUEST.form
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
578
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
579 if argv.has_key('main_fields'): #got data to change
149
0d9eb2a859d3 fixed typo
casties
parents: 147
diff changeset
580 self.invalidate_cache()
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
581 self.changeAdditionalData(argv);
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
582
159
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
583 pt=PageTemplateFile('zpt/staff/edit_additionalLinks.zpt', globals()).__of__(self)
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
584 return pt()
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
585
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
586
86
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
587 security.declareProtected('View management screens','editDownloads')
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
588 def editDownloads(self,REQUEST):
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
589 """editiere die Downloads von der Webseite"""
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
590
159
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
591 pt=PageTemplateFile('zpt/staff/edit_downloads.zpt', globals()).__of__(self)
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
592 return pt()
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
593
47
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
594 def editPublications(self,REQUEST):
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
595 """editiere die Publications von der Webseite"""
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
596 data=REQUEST.form
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
597
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
598 if data.has_key('selectionMode'):
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
599 query="UPDATE personal_www SET publications_mode=%s WHERE key=%s"
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
600
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
601 self.executeZSQL(query,[data['selectionMode'],self.getKey()])
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
602
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
603 self.refresh_content()
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
604
159
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
605 pt=PageTemplateFile('zpt/staff/edit_publications.zpt', globals()).__of__(self)
47
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
606 return pt()
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
607
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
608
159
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
609 security.declareProtected('View management screens','editImage')
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
610 def editImage(self,REQUEST=None):
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
611 """Edit the image information"""
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
612 if REQUEST:
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
613 argv=REQUEST.form
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
614
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
615 if argv.has_key('image_p'): #got data to change
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
616 self.invalidate_cache()
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
617 self.changeData(argv);
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
618
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
619 pt=PageTemplateFile('zpt/staff/edit_image', globals()).__of__(self)
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
620 return pt()
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
621
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
622
47
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
623 def refresh_content(self,):
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
624 self.content = self.folder.executeZSQL("select * from personal_www where key = %s", [self.getKey()])[0]
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
625
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
626
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
627 def changeDownloads(self,REQUEST):
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
628 """"change the downloadable files"""
149
0d9eb2a859d3 fixed typo
casties
parents: 147
diff changeset
629 self.invalidate_cache();
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
630
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
631 data=REQUEST.form
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
632
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
633 ob = self.folder._getOb("downloadableFiles")
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
634
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
635 if data.get('cv_publish',None):
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
636
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
637 self.changeData({'cv_p':data['cv_publish']})
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
638
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
639 if data.get('publications_publish',None):
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
640 self.changeData({'publications_p':data['publications_publish']})
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
641
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
642
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
643 if data.get('cv_pdf',None):
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
644 cvName ="%s_cv.pdf"%self.getUsername()
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
645 cvName=cvName.encode('utf-8')
195
124efbedd35b publish CV and publications on personal pages
dwinter
parents: 194
diff changeset
646
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
647 if not hasattr(ob,cvName):
194
45984e00665f upload and download cv and publicationlist
dwinter
parents: 193
diff changeset
648 cvFile = ExtFile.ExtFile(cvName,cvName)
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
649 ob._setObject(cvName,cvFile)
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
650
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
651 cvFile = getattr(ob,cvName)
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
652
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
653 cvFile.manage_upload(file=data['cv_pdf'])
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
654
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
655 if data.get('publications_pdf',None):
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
656 pdfName="%s_publications.pdf"%self.getUsername()
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
657 pdfName=pdfName.encode('utf-8')
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
658
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
659 if not hasattr(ob,pdfName):
194
45984e00665f upload and download cv and publicationlist
dwinter
parents: 193
diff changeset
660 cvFile = ExtFile.ExtFile(pdfName,pdfName)
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
661 ob._setObject(pdfName,cvFile)
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
662
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
663 cvFile = getattr(ob,pdfName)
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
664
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
665 cvFile.manage_upload(file=data['publications_pdf'])
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
666
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
667
194
45984e00665f upload and download cv and publicationlist
dwinter
parents: 193
diff changeset
668 REQUEST.response.redirect("editDownloads");
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
669
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
670
188
16d55695f1c8 fix updating staff entries through "Update personal homepages". (creating new entries doesn't work)
casties
parents: 187
diff changeset
671 security.declareProtected('View management screens','changeData')
16d55695f1c8 fix updating staff entries through "Update personal homepages". (creating new entries doesn't work)
casties
parents: 187
diff changeset
672 def changeData(self, changeSet):
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
673 """changes the data in the database, changeset expects field --> value."""
188
16d55695f1c8 fix updating staff entries through "Update personal homepages". (creating new entries doesn't work)
casties
parents: 187
diff changeset
674 fields = []
16d55695f1c8 fix updating staff entries through "Update personal homepages". (creating new entries doesn't work)
casties
parents: 187
diff changeset
675 values = []
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
676 for field in changeSet.keys():
159
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
677 if hasattr(self.content, field):
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
678 logging.debug("Changing: %s"%field)
188
16d55695f1c8 fix updating staff entries through "Update personal homepages". (creating new entries doesn't work)
casties
parents: 187
diff changeset
679 fields.append('"'+sqlName(field)+'" = %s')
16d55695f1c8 fix updating staff entries through "Update personal homepages". (creating new entries doesn't work)
casties
parents: 187
diff changeset
680 values.append(changeSet.get(field))
16d55695f1c8 fix updating staff entries through "Update personal homepages". (creating new entries doesn't work)
casties
parents: 187
diff changeset
681
16d55695f1c8 fix updating staff entries through "Update personal homepages". (creating new entries doesn't work)
casties
parents: 187
diff changeset
682 if len(fields) == 0:
16d55695f1c8 fix updating staff entries through "Update personal homepages". (creating new entries doesn't work)
casties
parents: 187
diff changeset
683 return
16d55695f1c8 fix updating staff entries through "Update personal homepages". (creating new entries doesn't work)
casties
parents: 187
diff changeset
684
16d55695f1c8 fix updating staff entries through "Update personal homepages". (creating new entries doesn't work)
casties
parents: 187
diff changeset
685 query = "update personal_www set " + ', '.join(fields) + " where key = %s"
16d55695f1c8 fix updating staff entries through "Update personal homepages". (creating new entries doesn't work)
casties
parents: 187
diff changeset
686 values.append(self.getKey().encode('utf-8'))
16d55695f1c8 fix updating staff entries through "Update personal homepages". (creating new entries doesn't work)
casties
parents: 187
diff changeset
687 results = self.folder.executeZSQL(query, values)
16d55695f1c8 fix updating staff entries through "Update personal homepages". (creating new entries doesn't work)
casties
parents: 187
diff changeset
688 logging.debug(results)
16d55695f1c8 fix updating staff entries through "Update personal homepages". (creating new entries doesn't work)
casties
parents: 187
diff changeset
689
159
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
690 self.refresh_content()
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
691
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
692
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
693 security.declareProtected('View management screens','changeAdditionalData')
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
694 def changeAdditionalData(self,data):
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
695 """change the research entries"""
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
696
149
0d9eb2a859d3 fixed typo
casties
parents: 147
diff changeset
697 self.invalidate_cache();
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
698
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
699 newEntries={}
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
700
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
701
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
702 mainfieldL=data['main_fields'].split(",") #fields to be changed
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
703 # format DATABASE__FIELDNAME
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
704
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
705 mainfield={}
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
706 for x in mainfieldL:
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
707 tmp=x.split('__')
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
708 mainfield[tmp[0]]=tmp[1]
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
709 for field in data:
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
710 splittedField=field.split("__")
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
711 if len(splittedField)<3:
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
712 pass #kein datenbank eintrag
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
713
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
714 elif splittedField[2]=='new': # store new entries
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
715 if not newEntries.has_key(splittedField[0]):
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
716 newEntries[splittedField[0]]={}
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
717
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
718 newEntries[splittedField[0]][splittedField[1]]=data[field]
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
719
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
720 else:
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
721 query="UPDATE %s "%splittedField[0]
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
722 query+="SET %s = '%s' "%(splittedField[1],sql_quote(data[field]))
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
723 query+="WHERE oid = '%s' "%sql_quote(splittedField[2])
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
724
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
725 self.executeZSQL(query)
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
726
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
727
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
728 #new entries
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
729 for newEntry in newEntries.keys():
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
730 query="INSERT INTO %s "%newEntry
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
731 keys=['key_main']
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
732 values=["'"+sql_quote(self.getKey())+"'"]
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
733 for key in newEntries[newEntry].keys():
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
734 keys.append(key)
193
522d32a50c2b bug with umlauts in editing talks and teachung fixed
dwinter
parents: 191
diff changeset
735
522d32a50c2b bug with umlauts in editing talks and teachung fixed
dwinter
parents: 191
diff changeset
736 val = sql_quote(newEntries[newEntry][key])
522d32a50c2b bug with umlauts in editing talks and teachung fixed
dwinter
parents: 191
diff changeset
737 if not isinstance(val, unicode):
522d32a50c2b bug with umlauts in editing talks and teachung fixed
dwinter
parents: 191
diff changeset
738 val = val.decode("utf-8")
522d32a50c2b bug with umlauts in editing talks and teachung fixed
dwinter
parents: 191
diff changeset
739
522d32a50c2b bug with umlauts in editing talks and teachung fixed
dwinter
parents: 191
diff changeset
740 values.append("'"+val+"'")
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
741
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
742
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
743 keystring=",".join(keys)
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
744
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
745 valuestring=",".join(values)
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
746
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
747 query+=" (%s) "%keystring
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
748 query+="VALUES (%s)"%valuestring
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
749 if not (newEntries[newEntry][mainfield[newEntry]].lstrip().rstrip()==""):
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
750 self.executeZSQL(query)
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
751
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
752
38
3c98cc79dd14 version 0.1 mit publicationen von pubman (TEST!!)
dwinter
parents: 37
diff changeset
753
208
6d6076e28430 fix deleteField for additionalLink (still ugly though)
casties
parents: 206
diff changeset
754 security.declareProtected('View management screens','deleteField')
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
755 def deleteField(self,REQUEST):
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
756 """delete entry"""
208
6d6076e28430 fix deleteField for additionalLink (still ugly though)
casties
parents: 206
diff changeset
757 # TODO: this is ugly
6d6076e28430 fix deleteField for additionalLink (still ugly though)
casties
parents: 206
diff changeset
758 CHANGEABLE=['talks','teaching','pubmanbiblio','additionallink']
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
759
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
760 table = REQUEST.form.get('table',None);
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
761 oid = REQUEST.form.get('oid',None);
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
762
185
a8d5ba6729f3 bug in delete entries fixes
dwinter
parents: 175
diff changeset
763
a8d5ba6729f3 bug in delete entries fixes
dwinter
parents: 175
diff changeset
764 if not table in CHANGEABLE:
a8d5ba6729f3 bug in delete entries fixes
dwinter
parents: 175
diff changeset
765 return
a8d5ba6729f3 bug in delete entries fixes
dwinter
parents: 175
diff changeset
766 if oid is None:
a8d5ba6729f3 bug in delete entries fixes
dwinter
parents: 175
diff changeset
767 oid = REQUEST.form.get('key',None);
a8d5ba6729f3 bug in delete entries fixes
dwinter
parents: 175
diff changeset
768
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
769 if table is None or oid is None:
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
770 return
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
771
208
6d6076e28430 fix deleteField for additionalLink (still ugly though)
casties
parents: 206
diff changeset
772 query="DELETE FROM %s WHERE oid = %%s"%(table)
6d6076e28430 fix deleteField for additionalLink (still ugly though)
casties
parents: 206
diff changeset
773 self.executeZSQL(query, [oid])
6d6076e28430 fix deleteField for additionalLink (still ugly though)
casties
parents: 206
diff changeset
774
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
775 REQUEST.response.redirect(self.REQUEST['HTTP_REFERER'])
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
776
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
777
40
fd8e78bbc5ed more work on projects.
casties
parents: 38
diff changeset
778 def invalidate_cache(self):
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
779 #TODO: How to invalidate the varnish cache from the member object
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
780 pass;
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
781
79
7f26c8e6c8e9 more styles for project lists.
casties
parents: 73
diff changeset
782
7f26c8e6c8e9 more styles for project lists.
casties
parents: 73
diff changeset
783 # TODO: compat, is this used?
7f26c8e6c8e9 more styles for project lists.
casties
parents: 73
diff changeset
784 getStaffURL = getUsername
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
785
191
90d44df497a6 updated breadcrumb handling, works for members now.
casties
parents: 190
diff changeset
786
90d44df497a6 updated breadcrumb handling, works for members now.
casties
parents: 190
diff changeset
787 def getBreadcrumbs(self):
90d44df497a6 updated breadcrumb handling, works for members now.
casties
parents: 190
diff changeset
788 """return list of breadcrumbs from here to the root"""
90d44df497a6 updated breadcrumb handling, works for members now.
casties
parents: 190
diff changeset
789 crumbs = []
90d44df497a6 updated breadcrumb handling, works for members now.
casties
parents: 190
diff changeset
790 label = '%s %s'%(self.content.first_name, self.content.last_name)
90d44df497a6 updated breadcrumb handling, works for members now.
casties
parents: 190
diff changeset
791 baseUrl = None
90d44df497a6 updated breadcrumb handling, works for members now.
casties
parents: 190
diff changeset
792 parent = aq_parent(self)
90d44df497a6 updated breadcrumb handling, works for members now.
casties
parents: 190
diff changeset
793 # get parents breadcrumbs
90d44df497a6 updated breadcrumb handling, works for members now.
casties
parents: 190
diff changeset
794 if hasattr(parent, 'getBreadcrumbs'):
90d44df497a6 updated breadcrumb handling, works for members now.
casties
parents: 190
diff changeset
795 crumbs = parent.getBreadcrumbs()
90d44df497a6 updated breadcrumb handling, works for members now.
casties
parents: 190
diff changeset
796 if len(crumbs) > 0:
90d44df497a6 updated breadcrumb handling, works for members now.
casties
parents: 190
diff changeset
797 # get base url from crumbs
90d44df497a6 updated breadcrumb handling, works for members now.
casties
parents: 190
diff changeset
798 baseUrl = crumbs[-1]['url'] + '/members'
90d44df497a6 updated breadcrumb handling, works for members now.
casties
parents: 190
diff changeset
799
90d44df497a6 updated breadcrumb handling, works for members now.
casties
parents: 190
diff changeset
800 if baseUrl is None:
90d44df497a6 updated breadcrumb handling, works for members now.
casties
parents: 190
diff changeset
801 baseUrl = '/en/staff/members'
90d44df497a6 updated breadcrumb handling, works for members now.
casties
parents: 190
diff changeset
802
90d44df497a6 updated breadcrumb handling, works for members now.
casties
parents: 190
diff changeset
803 # add this
90d44df497a6 updated breadcrumb handling, works for members now.
casties
parents: 190
diff changeset
804 crumbs.append({'text':label, 'url':self.getUrl(baseUrl=baseUrl), 'object':self})
90d44df497a6 updated breadcrumb handling, works for members now.
casties
parents: 190
diff changeset
805
90d44df497a6 updated breadcrumb handling, works for members now.
casties
parents: 190
diff changeset
806 return crumbs
90d44df497a6 updated breadcrumb handling, works for members now.
casties
parents: 190
diff changeset
807
90d44df497a6 updated breadcrumb handling, works for members now.
casties
parents: 190
diff changeset
808
56
a6ace48c2bf2 publication management f?r projekte
dwinter
parents: 53
diff changeset
809 def getPublicationsFromPubman(self,limit=None,publicationType=None):
141
45b7b24c8c42 move getPublicationsFromPubman to MPIWGStaffMember.
casties
parents: 134
diff changeset
810 """Return list of publications."""
110
b554becd8226 Incomplete - # 74: More Link auf den pers?nlichne Homepages
dwinter
parents: 107
diff changeset
811 if self.content.publications_mode=="year":
47
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
812 coneId = self.getConeId();
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
813 if coneId:
141
45b7b24c8c42 move getPublicationsFromPubman to MPIWGStaffMember.
casties
parents: 134
diff changeset
814 pubs = self.folder.mpiwgPubman.getPublications(coneId,limit=limit,publicationType=publicationType)
45b7b24c8c42 move getPublicationsFromPubman to MPIWGStaffMember.
casties
parents: 134
diff changeset
815 #pubs= self.folder.getPublicationsFromPubman(coneId,limit=limit,publicationType=publicationType)
156
a9ad7dd7a8b2 clean up projects.
casties
parents: 149
diff changeset
816 return pubs
38
3c98cc79dd14 version 0.1 mit publicationen von pubman (TEST!!)
dwinter
parents: 37
diff changeset
817
47
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
818 elif self.content.publications_mode=="priority":
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
819 selPubs= self.getSelectedPublications()
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
820
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
821 pubs=[]
73
33c663a08025 projekte publicationen jetzt nach typen geordnet
dwinter
parents: 71
diff changeset
822 count =0
47
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
823 for selPub in selPubs:
73
33c663a08025 projekte publicationen jetzt nach typen geordnet
dwinter
parents: 71
diff changeset
824 if limit and count >= limit:
33c663a08025 projekte publicationen jetzt nach typen geordnet
dwinter
parents: 71
diff changeset
825 break
110
b554becd8226 Incomplete - # 74: More Link auf den pers?nlichne Homepages
dwinter
parents: 107
diff changeset
826
53
e718d9a72f19 bibliographie funktionen
dwinter
parents: 48
diff changeset
827 logging.debug("searchFor:%s"%selPub.escidocid)
110
b554becd8226 Incomplete - # 74: More Link auf den pers?nlichne Homepages
dwinter
parents: 107
diff changeset
828 entry = self.mpiwgPubman.getEntryFromPubman(selPub.escidocid,extendedData=True);
b554becd8226 Incomplete - # 74: More Link auf den pers?nlichne Homepages
dwinter
parents: 107
diff changeset
829
b554becd8226 Incomplete - # 74: More Link auf den pers?nlichne Homepages
dwinter
parents: 107
diff changeset
830 #TODO getEntryFromPubmanShould return long texts
b554becd8226 Incomplete - # 74: More Link auf den pers?nlichne Homepages
dwinter
parents: 107
diff changeset
831 typesLongShort={'http://purl.org/eprint/type/Book':'book',
b554becd8226 Incomplete - # 74: More Link auf den pers?nlichne Homepages
dwinter
parents: 107
diff changeset
832 'http://purl.org/eprint/type/BookItem':'book-item',
b554becd8226 Incomplete - # 74: More Link auf den pers?nlichne Homepages
dwinter
parents: 107
diff changeset
833 'http://purl.org/escidoc/metadata/ves/publication-types/article':'article'};
b554becd8226 Incomplete - # 74: More Link auf den pers?nlichne Homepages
dwinter
parents: 107
diff changeset
834
156
a9ad7dd7a8b2 clean up projects.
casties
parents: 149
diff changeset
835 if publicationType is not None:
a9ad7dd7a8b2 clean up projects.
casties
parents: 149
diff changeset
836 #publicaitions typ ist gesetzt
134
9f45ed6ffeab bugs in publications
dwinter
parents: 128
diff changeset
837
156
a9ad7dd7a8b2 clean up projects.
casties
parents: 149
diff changeset
838 if not ((entry[1] == publicationType) or (entry[1] == typesLongShort.get(publicationType,''))) :
a9ad7dd7a8b2 clean up projects.
casties
parents: 149
diff changeset
839 #stimmt nicht dann weiter
110
b554becd8226 Incomplete - # 74: More Link auf den pers?nlichne Homepages
dwinter
parents: 107
diff changeset
840 continue;
202
c3c834cf1a6d minor bug in sho preprints
dwinter
parents: 201
diff changeset
841
c3c834cf1a6d minor bug in sho preprints
dwinter
parents: 201
diff changeset
842 if len(entry)>4:
c3c834cf1a6d minor bug in sho preprints
dwinter
parents: 201
diff changeset
843 pubs.append((selPub.escidocid,entry[0],entry[2],entry[3],entry[4]));
c3c834cf1a6d minor bug in sho preprints
dwinter
parents: 201
diff changeset
844 count+=1
47
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
845
46
955d102392db pubman integration 0.2
dwinter
parents: 38
diff changeset
846 return pubs
156
a9ad7dd7a8b2 clean up projects.
casties
parents: 149
diff changeset
847
a9ad7dd7a8b2 clean up projects.
casties
parents: 149
diff changeset
848 return []
47
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
849
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
850
100
f4ac675b2031 more members pages.
casties
parents: 93
diff changeset
851 def publications_full_html(self, REQUEST):
47
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
852 """show publication"""
100
f4ac675b2031 more members pages.
casties
parents: 93
diff changeset
853 pt=PageTemplateFile('zpt/staff/pubman/show_publications.zpt', globals()).__of__(self)
47
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
854 return pt(member=self.content)
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
855
185
a8d5ba6729f3 bug in delete entries fixes
dwinter
parents: 175
diff changeset
856
a8d5ba6729f3 bug in delete entries fixes
dwinter
parents: 175
diff changeset
857 security.declareProtected('View management screens','addPublicationsFromPubman')
47
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
858 def addPublicationsFromPubman(self,REQUEST):
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
859 """addPublications from pubman"""
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
860
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
861 data=REQUEST.form
38
3c98cc79dd14 version 0.1 mit publicationen von pubman (TEST!!)
dwinter
parents: 37
diff changeset
862
47
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
863 if data.get("method",None) is None:
159
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
864 pt=PageTemplateFile('zpt/staff/pubman/add_publications.zpt', globals()).__of__(self)
47
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
865 return pt()
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
866
37
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
867
9b38ba45773b ?berarbeitung MPIWGStaff
dwinter
parents: 28
diff changeset
868
47
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
869 if data.get("method") == "search":
73
33c663a08025 projekte publicationen jetzt nach typen geordnet
dwinter
parents: 71
diff changeset
870
33c663a08025 projekte publicationen jetzt nach typen geordnet
dwinter
parents: 71
diff changeset
871
33c663a08025 projekte publicationen jetzt nach typen geordnet
dwinter
parents: 71
diff changeset
872
201
81a8177ca354 shows where a entry comes from in editing mode
dwinter
parents: 195
diff changeset
873 entries= self.mpiwgPubman.search(data,contexts=["escidoc:85274","escidoc:38279","escidoc:644427"],resultWithContext=True)
159
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
874 pt=PageTemplateFile('zpt/staff/pubman/add_publications.zpt', globals()).__of__(self)
47
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
875
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
876
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
877 return pt(values=entries)
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
878
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
879
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
880
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
881 if data.get("method") == "add":
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
882
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
883 return self.addEntriesToPublicationList(data)
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
884 #pt=PageTemplateFile(os.path.join(package_home(globals()),'zpt/staff/pubman','add_publications.zpt')).__of__(self)
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
885
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
886
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
887
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
888 def addEntriesToPublicationList(self,data):
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
889 """fuege eintrage aus data zur publications liste,
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
890 @param data Map mit escidocID --> value
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
891 value muss "add" sein damit hinzugefuegt wird"""
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
892
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
893 for key in data.keys():
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
894
56
a6ace48c2bf2 publication management f?r projekte
dwinter
parents: 53
diff changeset
895 if key.startswith('escidoc:'):
a6ace48c2bf2 publication management f?r projekte
dwinter
parents: 53
diff changeset
896
47
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
897
56
a6ace48c2bf2 publication management f?r projekte
dwinter
parents: 53
diff changeset
898 query="INSERT INTO pubmanbiblio (key_main,escidocId) values (%s,%s)"
47
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
899
56
a6ace48c2bf2 publication management f?r projekte
dwinter
parents: 53
diff changeset
900 if data.get(key)=="add":
a6ace48c2bf2 publication management f?r projekte
dwinter
parents: 53
diff changeset
901 self.executeZSQL(query,[self.getKey(),key])
a6ace48c2bf2 publication management f?r projekte
dwinter
parents: 53
diff changeset
902
47
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
903
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
904
56
a6ace48c2bf2 publication management f?r projekte
dwinter
parents: 53
diff changeset
905 #selectedPublications = self.getSelectedPublications()
a6ace48c2bf2 publication management f?r projekte
dwinter
parents: 53
diff changeset
906
a6ace48c2bf2 publication management f?r projekte
dwinter
parents: 53
diff changeset
907 #pt = PageTemplateFile(os.path.join(package_home(globals()),'zpt/staff/pubman','change_publications.zpt')).__of__(self)
47
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
908
56
a6ace48c2bf2 publication management f?r projekte
dwinter
parents: 53
diff changeset
909 #return pt()
a6ace48c2bf2 publication management f?r projekte
dwinter
parents: 53
diff changeset
910 if hasattr(self,'REQUEST'):
a6ace48c2bf2 publication management f?r projekte
dwinter
parents: 53
diff changeset
911 return self.REQUEST.response.redirect("changePublications")
47
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
912
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
913
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
914 def changePublications(self,REQUEST):
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
915 """change published publications"""
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
916
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
917 data=REQUEST.form
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
918
147
6ae0201b1257 bug in edit publications. behoben
dwinter
parents: 141
diff changeset
919 if data.get("method","") == "change":
6ae0201b1257 bug in edit publications. behoben
dwinter
parents: 141
diff changeset
920
47
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
921 for key in data.keys():
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
922 splitted=key.split("__") #format escidoc_id__p fuer priority, nur escidocid
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
923 value=data[key]
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
924 if len(splitted)==1:
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
925 self.deleteFromPublicationList(key);
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
926
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
927 elif(splitted[1]) == "p":
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
928 self.setPublicationPriority(splitted[0],value);
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
929
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
930
159
ee79f6ba8d01 clean up staff editing and some zpt forms.
casties
parents: 156
diff changeset
931 pt = PageTemplateFile('zpt/staff/pubman/change_publications', globals()).__of__(self)
47
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
932 return pt()
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
933
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
934
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
935 def deleteFromPublicationList(self,escidocid):
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
936 """Loessche publication with escidoc id from publication list"""
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
937
147
6ae0201b1257 bug in edit publications. behoben
dwinter
parents: 141
diff changeset
938 query ="DELETE FROM pubmanbiblio WHERE escidocid=%s and lower(key_main)=%s"
47
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
939
147
6ae0201b1257 bug in edit publications. behoben
dwinter
parents: 141
diff changeset
940 self.executeZSQL(query,[escidocid,self.getKey().lower()]);
47
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
941
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
942
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
943 def setPublicationPriority(self,escidocid,value):
56
a6ace48c2bf2 publication management f?r projekte
dwinter
parents: 53
diff changeset
944 try:
147
6ae0201b1257 bug in edit publications. behoben
dwinter
parents: 141
diff changeset
945 query="update pubmanbiblio set priority=%s where escidocid=%s and lower(key_main)=%s"
56
a6ace48c2bf2 publication management f?r projekte
dwinter
parents: 53
diff changeset
946
203
9ce5816e89b2 faeng priority fehler ab bei biblio
dwinter
parents: 202
diff changeset
947 try:
9ce5816e89b2 faeng priority fehler ab bei biblio
dwinter
parents: 202
diff changeset
948 x=int(value)
9ce5816e89b2 faeng priority fehler ab bei biblio
dwinter
parents: 202
diff changeset
949 except:
9ce5816e89b2 faeng priority fehler ab bei biblio
dwinter
parents: 202
diff changeset
950 logging.error("priority not a number")
9ce5816e89b2 faeng priority fehler ab bei biblio
dwinter
parents: 202
diff changeset
951 return
9ce5816e89b2 faeng priority fehler ab bei biblio
dwinter
parents: 202
diff changeset
952
147
6ae0201b1257 bug in edit publications. behoben
dwinter
parents: 141
diff changeset
953 self.executeZSQL(query,[value,escidocid,self.getKey().lower()]);
56
a6ace48c2bf2 publication management f?r projekte
dwinter
parents: 53
diff changeset
954
a6ace48c2bf2 publication management f?r projekte
dwinter
parents: 53
diff changeset
955 except:
a6ace48c2bf2 publication management f?r projekte
dwinter
parents: 53
diff changeset
956 logging.error("couldn't change:")
a6ace48c2bf2 publication management f?r projekte
dwinter
parents: 53
diff changeset
957 logging.error(escidocid)
a6ace48c2bf2 publication management f?r projekte
dwinter
parents: 53
diff changeset
958 logging.error(value)
a6ace48c2bf2 publication management f?r projekte
dwinter
parents: 53
diff changeset
959
80
b1893c4c9d2c more display of project pages.
casties
parents: 79
diff changeset
960
47
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
961 def getSelectedPublications(self):
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
962 """hole publications aus der datenbank"""
100
f4ac675b2031 more members pages.
casties
parents: 93
diff changeset
963 query="select * from pubmanbiblio where lower(key_main) = lower(%s) order by priority ASC"
47
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
964 return self.executeZSQL(query,[self.getKey()])
68
2ad8aa9d306c bugs in MPIWGTemplate fixed
dwinter
parents: 59
diff changeset
965
2ad8aa9d306c bugs in MPIWGTemplate fixed
dwinter
parents: 59
diff changeset
966
86
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
967 def getProfile(self,REQUEST):
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
968 """get the profile"""
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
969 self.REQUEST.RESPONSE.setHeader('Last-Modified',email.Utils.formatdate().split("-")[0]+'GMT')
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
970
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
971
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
972 html="""<html><body>%s</body></html>"""
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
973 if self.content.profile and self.content.profile != "":
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
974
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
975 return html%self.content.profile
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
976 else:
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
977
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
978 return html%""
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
979
ab836d3f96dc styles for staff list.
casties
parents: 85
diff changeset
980
68
2ad8aa9d306c bugs in MPIWGTemplate fixed
dwinter
parents: 59
diff changeset
981 def generateProfileForPerson(self,REQUEST=None):
2ad8aa9d306c bugs in MPIWGTemplate fixed
dwinter
parents: 59
diff changeset
982 """erzeugt ein automatisches Profil aus den alten Eintraegen CV, Current work, und research interests"""
2ad8aa9d306c bugs in MPIWGTemplate fixed
dwinter
parents: 59
diff changeset
983
2ad8aa9d306c bugs in MPIWGTemplate fixed
dwinter
parents: 59
diff changeset
984 ret=""
2ad8aa9d306c bugs in MPIWGTemplate fixed
dwinter
parents: 59
diff changeset
985 #founds=self.ZSQLInlineSearch(_table='research_interest',key_main=person.getKeyUTF8())
80
b1893c4c9d2c more display of project pages.
casties
parents: 79
diff changeset
986 founds=self.executeZSQL('select * from research_interest where lower(key_main) = %s', [self.getKey().lower()])
68
2ad8aa9d306c bugs in MPIWGTemplate fixed
dwinter
parents: 59
diff changeset
987 if founds:
2ad8aa9d306c bugs in MPIWGTemplate fixed
dwinter
parents: 59
diff changeset
988 ret="<p class=\"bio_section_header\">Research interests: </p><br/>"
2ad8aa9d306c bugs in MPIWGTemplate fixed
dwinter
parents: 59
diff changeset
989 for found in self.sortPriority(founds):
2ad8aa9d306c bugs in MPIWGTemplate fixed
dwinter
parents: 59
diff changeset
990 ret+=found.interest+"<br/>"
2ad8aa9d306c bugs in MPIWGTemplate fixed
dwinter
parents: 59
diff changeset
991 if (self.content.current_work) and (not self.content.current_work==""):
2ad8aa9d306c bugs in MPIWGTemplate fixed
dwinter
parents: 59
diff changeset
992 ret+="<p class=\"bio_section_header\">Current work: </p><br/>"
80
b1893c4c9d2c more display of project pages.
casties
parents: 79
diff changeset
993 ret+=self.content.current_work+"<br/>"
68
2ad8aa9d306c bugs in MPIWGTemplate fixed
dwinter
parents: 59
diff changeset
994 if (self.content.cv) and (not self.content.cv==""):
2ad8aa9d306c bugs in MPIWGTemplate fixed
dwinter
parents: 59
diff changeset
995 ret+="<p class=\"bio_section_header\">Curriculum Vitae: </p><br/>"
2ad8aa9d306c bugs in MPIWGTemplate fixed
dwinter
parents: 59
diff changeset
996 ret+=self.formatAscii(self.content.cv)
2ad8aa9d306c bugs in MPIWGTemplate fixed
dwinter
parents: 59
diff changeset
997
2ad8aa9d306c bugs in MPIWGTemplate fixed
dwinter
parents: 59
diff changeset
998 return ret
47
225179dfd892 getPublications erweitert nach Typ
dwinter
parents: 46
diff changeset
999
189
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
1000
cc5198541af8 erzeugen neuer eintr?ge auf der homepage mittels updatexml
dwinter
parents: 188
diff changeset
1001
186
3ea224968f95 fix traversal to MPIWGStaffMember objects.
casties
parents: 185
diff changeset
1002 # initialize security
3ea224968f95 fix traversal to MPIWGStaffMember objects.
casties
parents: 185
diff changeset
1003 InitializeClass(MPIWGStaffFolder)
3
ee3eb9a6665a MPIWGStaffFolder shows members from db now.
casties
parents: 2
diff changeset
1004 InitializeClass(MPIWGStaffMember)