source: main/waeup.kofa/trunk/src/waeup/kofa/applicants/utils.py @ 16447

Last change on this file since 16447 was 16415, checked in by Henrik Bettermann, 4 years ago

Special applicants can add a payment ticket before saving the form. Take at least care that the total amount can be determined.

  • Property svn:keywords set to Id
File size: 5.4 KB
Line 
1## $Id: utils.py 16415 2021-03-17 20:29:00Z 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"""General helper functions and utilities for the applicants section.
19"""
20
21from time import time
22from datetime import datetime
23import grok
24from zope.component import getUtility
25from zope.catalog.interfaces import ICatalog
26from waeup.kofa.interfaces import MessageFactory as _
27from waeup.kofa.applicants.interfaces import IApplicantsUtils
28from waeup.kofa.applicants.workflow import (INITIALIZED,
29    STARTED, PAID, ADMITTED, NOT_ADMITTED, SUBMITTED, CREATED, PROCESSED)
30
31class ApplicantsUtils(grok.GlobalUtility):
32    """A collection of parameters and methods subject to customization.
33    """
34    grok.implements(IApplicantsUtils)
35
36    #: A dictionary containing application type names, titles and
37    #: access code prefixes (meanwhile deprecated).
38    APP_TYPES_DICT = {
39      'app': ['General Studies', 'APP'],
40      'special': ['Special Application', 'SPE'],
41      }
42
43    #: A dictionary which maps widget names to headlines.
44    #: The headline is rendered in forms and on pdf slips above the
45    #: respective display or input widget.
46    SEPARATORS_DICT = {
47      'form.applicant_id': _(u'Base Data'),
48      'form.course1': _(u'Desired Study Courses'),
49      'form.notice': _(u'Application Process Data'),
50      'form.referees': _(u'Referees (automatically invited by email '
51                          'after final submission of this form)'),
52      }
53
54    #: A tuple of tuple of file names to be uploaded by applicants and copied
55    #: over to the students section.
56    ADDITIONAL_FILES = (('Test File','testfile.pdf'),)
57
58    def setPaymentDetails(self, container, payment, applicant):
59        """Set the payment data of an applicant.
60        In contrast to its `StudentsUtils` counterpart, the payment ticket
61        must exist and is an argument of this method.
62        """
63        timestamp = ("%d" % int(time()*10000))[1:]
64        if container.year:
65            session = str(container.year)
66            try:
67                session_config = grok.getSite()['configuration'][session]
68            except KeyError:
69                return _(u'Session configuration object is not available.')
70        payment.p_id = "p%s" % timestamp
71        payment.p_item = container.title
72        if container.year:
73            payment.p_session = container.year
74        else:
75            payment.p_session = datetime.now().year
76        payment.amount_auth = 0.0
77        if applicant.special:
78            if applicant.special_application:
79                fee_name = applicant.special_application + '_fee'
80                payment.amount_auth = getattr(session_config, fee_name, None)
81                payment.p_category = applicant.special_application
82            if payment.amount_auth in (0.0, None):
83                return _('Amount could not be determined. Have you saved the form?')
84            return
85        payment.p_category = 'application'
86        container_fee = container.application_fee
87        if not container_fee:
88            return _('Amount could not be determined.')
89        payment.amount_auth = container_fee
90        return
91
92    def getApplicantsStatistics(self, container):
93        """Count applicants in applicants containers.
94        """
95        state_stats = {INITIALIZED:0, STARTED:0, PAID:0, SUBMITTED:0,
96            ADMITTED:0, NOT_ADMITTED:0, CREATED:0, PROCESSED:0}
97        cat = getUtility(ICatalog, name='applicants_catalog')
98        code = container.code
99        for state in state_stats:
100            if state == 'initialized':
101                results = cat.searchResults(
102                                state=(state, state),
103                                container_code=(code + '+', code + '+'))
104                state_stats[state] = len(results)
105            else:
106                results = cat.searchResults(
107                    state=(state, state),
108                    container_code=(code + '+', code + '-'))
109                state_stats[state] = len(results)
110        return state_stats, None
111
112    def sortCertificates(self, context, resultset):
113        """Sort already filtered certificates in `AppCatCertificateSource`.
114        Display also current course even if certificate in the academic
115        section has been removed.
116        """
117        resultlist = sorted(resultset, key=lambda value: value.code)
118        curr_course = context.course1
119        if curr_course is not None and curr_course not in resultlist:
120            resultlist = [curr_course,] + resultlist
121        return resultlist
122
123    def getCertTitle(self, context, value):
124        """Compose the titles in `AppCatCertificateSource`.
125        """
126        return "%s - %s" % (value.code, value.title)
127
128    def isPictureEditable(self, container):
129        """False if applicants are not allowed to edit uploaded pictures.
130        """
131        return container.with_picture
Note: See TracBrowser for help on using the repository browser.