annotate MPIWGStaff.py @ 241:99432bde94ed

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