annotate MPIWGStaff.py @ 249:f07dc0d2c60c

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