source: main/waeup.fceokene/trunk/src/waeup/fceokene/applicants/interfaces.py @ 15630

Last change on this file since 15630 was 15594, checked in by Henrik Bettermann, 5 years ago

Update tests. Remove GATEWAY_AMT again. See ticket #262.

  • Property svn:keywords set to Id
File size: 13.9 KB
Line 
1## $Id: interfaces.py 15594 2019-09-19 13:30:53Z henrik $
2##
3## Copyright (C) 2011 Uli Fouquet & Henrik Bettermann
4## This program is free software; you can redistribute it and/or modify
5## it under the terms of the GNU General Public License as published by
6## the Free Software Foundation; either version 2 of the License, or
7## (at your option) any later version.
8##
9## This program is distributed in the hope that it will be useful,
10## but WITHOUT ANY WARRANTY; without even the implied warranty of
11## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12## GNU General Public License for more details.
13##
14## You should have received a copy of the GNU General Public License
15## along with this program; if not, write to the Free Software
16## Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
17##
18"""Customized interfaces of the university application package.
19"""
20
21from zope import schema
22from zc.sourcefactory.basic import BasicSourceFactory
23from waeup.kofa.applicants.interfaces import (
24    IApplicantBaseData,
25    AppCatCertificateSource, CertificateSource)
26from waeup.kofa.schoolgrades import ResultEntryField
27from waeup.kofa.interfaces import (
28    SimpleKofaVocabulary, academic_sessions_vocab, validate_email,
29    IKofaObject)
30from waeup.kofa.schema import FormattedDate, TextLineChoice, PhoneNumber
31from waeup.kofa.schoolgrades import ResultEntryField
32from waeup.kofa.students.vocabularies import nats_vocab, GenderSource
33from waeup.kofa.applicants.interfaces import contextual_reg_num_source
34from kofacustom.nigeria.applicants.interfaces import (
35    LGASource, high_qual, high_grade, exam_types,
36    INigeriaUGApplicant, INigeriaPGApplicant,
37    INigeriaApplicantOnlinePayment,
38    INigeriaUGApplicantEdit,
39    INigeriaApplicantUpdateByRegNo,
40    IPUTMEApplicantEdit,
41    OMIT_DISPLAY_FIELDS
42    )
43from waeup.fceokene.applicants.schools import SCHOOLS
44from waeup.fceokene.interfaces import MessageFactory as _
45
46BEC_OMIT_DISPLAY_FIELDS = OMIT_DISPLAY_FIELDS
47BEC_OMIT_PDF_FIELDS = BEC_OMIT_DISPLAY_FIELDS + ('phone',)
48BEC_OMIT_MANAGE_FIELDS = ('special_application',)
49BEC_OMIT_EDIT_FIELDS = BEC_OMIT_MANAGE_FIELDS + OMIT_DISPLAY_FIELDS + (
50    'student_id', 'notice',
51    'screening_score',
52    'screening_venue',
53    'screening_date',
54    #'jamb_subjects',
55    #'jamb_score',
56    'aggregate')
57
58class SchoolSource(BasicSourceFactory):
59    """A source that delivers all kinds of schools.
60    """
61    def getValues(self):
62        sorted_items = sorted(
63            SCHOOLS.items(),
64            key=lambda element: element[1][0] + element[1][1] +element[1][2])
65        return [item[0] for item in sorted_items]
66
67    def getToken(self, value):
68        return value
69
70    def getTitle(self, value):
71        if not SCHOOLS.get(value, None):
72            return u"none-existent"
73        return u"%s: %s -- %s" % (
74            SCHOOLS[value][0],
75            SCHOOLS[value][1],
76            SCHOOLS[value][2],)
77
78class ITPURegistration(IKofaObject):
79    """A TPU registrant.
80    """
81
82    suspended = schema.Bool(
83        title = _(u'Account suspended'),
84        default = False,
85        required = False,
86        )
87
88    locked = schema.Bool(
89        title = _(u'Form locked'),
90        default = False,
91        required = False,
92        )
93
94    applicant_id = schema.TextLine(
95        title = _(u'Applicant Id'),
96        required = False,
97        readonly = False,
98        )
99
100    reg_number = schema.TextLine(
101        title = _(u'Registration Number'),
102        required = False,
103        readonly = False,
104        )
105
106    matric_number = schema.TextLine(
107        title = _(u'Matriculation Number'),
108        required = False,
109        readonly = False,
110        )
111
112    firstname = schema.TextLine(
113        title = _(u'First Name'),
114        required = True,
115        )
116
117    middlename = schema.TextLine(
118        title = _(u'Middle Name'),
119        required = False,
120        )
121
122    lastname = schema.TextLine(
123        title = _(u'Last Name (Surname)'),
124        required = True,
125        )
126
127    email = schema.ASCIILine(
128        title = _(u'Email Address'),
129        required = True,
130        constraint=validate_email,
131        )
132
133    phone = PhoneNumber(
134        title = _(u'Phone'),
135        description = u'',
136        required = False,
137        )
138
139    perm_address = schema.Text(
140        title = _(u'Home Address'),
141        required = False,
142        readonly = False,
143        )
144
145    lga = schema.Choice(
146        source = LGASource(),
147        title = _(u'State/LGA'),
148        required = False,
149        )
150
151    subj_comb = schema.TextLine(
152        title = _(u'Subject Combination'),
153        required = False,
154        readonly = False,
155        )
156
157    school1 = schema.Choice(
158        title = _(u'1st Choice TPZ and School'),
159        source = SchoolSource(),
160        required = False,
161        )
162
163    #school2 = schema.Choice(
164    #    title = _(u'2nd Choice TPZ and School'),
165    #    source = SchoolSource(),
166    #    required = False,
167    #    )
168
169    #school3 = schema.Choice(
170    #    title = _(u'3rd Choice TPZ and School'),
171    #    source = SchoolSource(),
172    #    required = False,
173    #    )
174
175class ICustomUGApplicant(INigeriaUGApplicant):
176    """An undergraduate applicant.
177
178    This interface defines the least common multiple of all fields
179    in ug application forms. In customized forms, fields can be excluded by
180    adding them to the OMIT* tuples.
181    """
182
183    nationality = schema.Choice(
184        source = nats_vocab,
185        title = _(u'Nationality'),
186        required = True,
187        )
188    lga = schema.Choice(
189        source = LGASource(),
190        title = _(u'State/LGA (Nigerians only)'),
191        required = False,
192        )
193    #perm_address = schema.Text(
194    #    title = _(u'Permanent Address'),
195    #    required = False,
196    #    )
197    course1 = schema.Choice(
198        title = _(u'1st Choice Course of Study'),
199        source = AppCatCertificateSource(),
200        required = False,
201        )
202    course2 = schema.Choice(
203        title = _(u'2nd Choice Course of Study'),
204        source = AppCatCertificateSource(),
205        required = False,
206        )
207    olevel_type = schema.Choice(
208        title = _(u'1st Qualification Obtained'),
209        required = False,
210        readonly = False,
211        vocabulary = exam_types,
212        )
213    olevel_school = schema.TextLine(
214        title = _(u'1st Institution Attended'),
215        required = False,
216        readonly = False,
217        )
218    olevel_exam_number = schema.TextLine(
219        title = _(u'1st Exam Number'),
220        required = False,
221        readonly = False,
222        )
223    olevel_exam_date = FormattedDate(
224        title = _(u'1st Exam Date'),
225        required = False,
226        readonly = False,
227        show_year = True,
228        )
229    olevel_results = schema.List(
230        title = _(u'1st Exam Results'),
231        value_type = ResultEntryField(),
232        required = False,
233        readonly = False,
234        defaultFactory=list,
235        )
236    olevel_type2 = schema.Choice(
237        title = _(u'2nd Qualification Obtained'),
238        required = False,
239        readonly = False,
240        vocabulary = exam_types,
241        )
242    olevel_school2 = schema.TextLine(
243        title = _(u'2nd Institution Attended'),
244        required = False,
245        readonly = False,
246        )
247    olevel_exam_number2 = schema.TextLine(
248        title = _(u'2nd Exam Number'),
249        required = False,
250        readonly = False,
251        )
252    olevel_exam_date2 = FormattedDate(
253        title = _(u'2nd Exam Date'),
254        required = False,
255        readonly = False,
256        show_year = True,
257        )
258    olevel_results2 = schema.List(
259        title = _(u'2nd Exam Results'),
260        value_type = ResultEntryField(),
261        required = False,
262        readonly = False,
263        defaultFactory=list,
264        )
265    hq_type = schema.Choice(
266        title = _(u'Qualification Obtained'),
267        required = False,
268        readonly = False,
269        vocabulary = high_qual,
270        )
271    hq_matric_no = schema.TextLine(
272        title = _(u'Former Matric Number'),
273        required = False,
274        readonly = False,
275        )
276    hq_degree = schema.Choice(
277        title = _(u'Class of Degree'),
278        required = False,
279        readonly = False,
280        vocabulary = high_grade,
281        )
282    hq_school = schema.TextLine(
283        title = _(u'Institution Attended'),
284        required = False,
285        readonly = False,
286        )
287    hq_session = schema.TextLine(
288        title = _(u'Years Attended'),
289        required = False,
290        readonly = False,
291        )
292    hq_disc = schema.TextLine(
293        title = _(u'Discipline'),
294        required = False,
295        readonly = False,
296        )
297    jamb_subjects = schema.Text(
298        title = _(u'Subjects and Scores'),
299        description = _(u'(one subject with score per line)'),
300        required = False,
301        )
302    jamb_score = schema.Int(
303        title = _(u'Total JAMB Score'),
304        required = False,
305        )
306    jamb_reg_number = schema.TextLine(
307        title = _(u'JAMB Registration Number'),
308        required = False,
309        )
310    notice = schema.Text(
311        title = _(u'Notice'),
312        required = False,
313        )
314    screening_venue = schema.TextLine(
315        title = _(u'Screening Venue'),
316        required = False,
317        )
318    screening_date = schema.TextLine(
319        title = _(u'Screening Date'),
320        required = False,
321        )
322    screening_score = schema.Int(
323        title = _(u'Screening Score (%)'),
324        required = False,
325        )
326    aggregate = schema.Int(
327        title = _(u'Aggregate Score (%)'),
328        description = _(u'(average of relative JAMB and PUTME scores)'),
329        required = False,
330        )
331    result_uploaded = schema.Bool(
332        title = _(u'Result uploaded'),
333        default = False,
334        required = False,
335        )
336    student_id = schema.TextLine(
337        title = _(u'Student Id'),
338        required = False,
339        readonly = False,
340        )
341    course_admitted = schema.Choice(
342        title = _(u'Admitted Course of Study'),
343        source = CertificateSource(),
344        required = False,
345        )
346    locked = schema.Bool(
347        title = _(u'Form locked'),
348        default = False,
349        required = False,
350        )
351
352
353class ICustomPGApplicant(INigeriaPGApplicant):
354    """A postgraduate applicant.
355
356    This interface defines the least common multiple of all fields
357    in pg application forms. In customized forms, fields can be excluded by
358    adding them to the PG_OMIT* tuples.
359    """
360
361class ICustomApplicant(ICustomUGApplicant, ICustomPGApplicant,
362    ITPURegistration):
363    """An interface for all types of applicants.
364
365    Attention: The ICustomPGApplicant field seetings will be overwritten
366    by ICustomPGApplicant field settings. If a field is defined
367    in both interfaces zope.schema validates only against the
368    constraints in ICustomUGApplicant. This does not affect the forms
369    since they are build on either ICustomUGApplicant or ICustomPGApplicant.
370    """
371
372    def writeLogMessage(view, comment):
373        """Adds an INFO message to the log file
374        """
375
376    def createStudent():
377        """Create a student object from applicatnt data
378        and copy applicant object.
379        """
380
381class ICustomUGApplicantEdit(ICustomUGApplicant):
382    """An undergraduate applicant interface for edit forms.
383
384    Here we can repeat the fields from base data and set the
385    `required` and `readonly` attributes to True to further restrict
386    the data access. Or we can allow only certain certificates to be
387    selected by choosing the appropriate source.
388
389    We cannot omit fields here. This has to be done in the
390    respective form page.
391    """
392
393
394    email = schema.ASCIILine(
395        title = _(u'Email Address'),
396        required = True,
397        constraint=validate_email,
398        )
399    date_of_birth = FormattedDate(
400        title = _(u'Date of Birth'),
401        required = True,
402        show_year = True,
403        )
404    jamb_reg_number = schema.TextLine(
405        title = _(u'JAMB Registration Number'),
406        required = True,
407        )
408    course1 = schema.Choice(
409        title = _(u'1st Choice Course of Study'),
410        source = AppCatCertificateSource(),
411        required = True,
412        )
413
414ICustomUGApplicantEdit[
415    'date_of_birth'].order =  ICustomUGApplicant['date_of_birth'].order
416ICustomUGApplicantEdit[
417    'email'].order =  ICustomUGApplicant['email'].order
418ICustomUGApplicantEdit[
419    'jamb_reg_number'].order =  ICustomUGApplicant['jamb_reg_number'].order
420ICustomUGApplicantEdit[
421    'course1'].order =  ICustomUGApplicant['course1'].order
422
423class ICustomPGApplicantEdit(ICustomPGApplicant):
424    """A postgraduate applicant interface for editing.
425
426    Here we can repeat the fields from base data and set the
427    `required` and `readonly` attributes to True to further restrict
428    the data access. Or we can allow only certain certificates to be
429    selected by choosing the appropriate source.
430
431    We cannot omit fields here. This has to be done in the
432    respective form page.
433    """
434
435    email = schema.ASCIILine(
436        title = _(u'Email Address'),
437        required = True,
438        constraint=validate_email,
439        )
440    date_of_birth = FormattedDate(
441        title = _(u'Date of Birth'),
442        required = True,
443        show_year = True,
444        )
445
446ICustomPGApplicantEdit[
447    'date_of_birth'].order =  ICustomPGApplicant['date_of_birth'].order
448ICustomPGApplicantEdit[
449    'email'].order =  ICustomPGApplicant['email'].order
450
451
452class ICustomApplicantOnlinePayment(INigeriaApplicantOnlinePayment):
453    """An applicant payment via payment gateways.
454
455    """
456
457class IPUTMEApplicantEdit(IPUTMEApplicantEdit):
458    """An undergraduate applicant interface for editing.
459
460    Here we can repeat the fields from base data and set the
461    `required` and `readonly` attributes to True to further restrict
462    the data access. Or we can allow only certain certificates to be
463    selected by choosing the appropriate source.
464
465    We cannot omit fields here. This has to be done in the
466    respective form page.
467    """
468
469class ICustomApplicantUpdateByRegNo(INigeriaApplicantUpdateByRegNo):
470    """Representation of an applicant.
471
472    Skip regular reg_number validation if reg_number is used for finding
473    the applicant object.
474    """
475
Note: See TracBrowser for help on using the repository browser.