source: main/waeup.kofa/trunk/docs/source/userdocs/customization.rst @ 13170

Last change on this file since 13170 was 13167, checked in by Henrik Bettermann, 10 years ago

More docs.

File size: 8.1 KB
RevLine 
[13120]1.. _customization:
2
3Portal Customization
4********************
5
[13121]6Portal customization requires profound knowledge of the Python
7programming language. Customization is part of the portal deployment
8process. It can only be done by the custom package manager and
9activated by the system administrator, who is allowed to
10update/upgrade the package on the server and restart the portal.
11Usually, custom packages are not designed for regular
12reconfiguration. Due to the complexity of school fee computation at
13Nigerian universities, however, a lot of configuration had to be
14done in the Python code and can thus not be subject to online
15configuration. Technically speaking, the parameters are only loaded
16and registered once during start-up and are not stored in the
17database like the configuration parameters described in
18:ref:`configuration`.
[13120]19
[13121]20Kofa must not be customized by manipulating original Kofa code, i.e.
21by editing Python files, Zope page templates or ZCML configuration
22files in the Kofa base package. Customization is done by deploying a
23custom package which can inherit all the Python classes from the
24base package, in order to override distinct attributes and methods
25and register these customized classes instead of the orginal classes
26during start-up. It would go beyond the scope of the user handbook
27to explain, how to build such a Kofa custom package. This will be
28done in the :ref:`developer_handbook`. Here we roughly describe the
29three different customization approaches with a focus on the third
30approach, the customization of utility attributes and methods.
[13120]31
32Localization
33============
34
[13121]35The base language of the Kofa User Interface (Kofa UI) is English.
36The English language regime has been specified by WAeUP's first
37customer, the University of Benin in Nigeria. Kofa is language-aware,
38which means it has been translated into different languages (German
39and French so far), and the preferred language can be selected via
40the UI. The Kofa UI translations and also the English language
41regime can be localized in custom packages by overriding single
42entries of the language files. Headlines, field labels, field
43descriptions, navigation tabs, buttons, page comments, flash
44messages etc. can be easily adjusted to the needs of the institution
45which wants to deploy Kofa.
46
47Kofa is using the `GNU gettext utilities
48<http://www.gnu.org/software/gettext>`_ for translation and
49localization. Translation is done via ``po`` text files which are
50located in the ``locales`` folder of a package. Each language has
[13124]51its own subfolder. Localized English Kofa terms, for instance, can be
[13121]52found in ``locales/en/LC_MESSAGES/waeup.kofa.po``. A single
53entry/message consists of two lines.
54
55Example::
56
57  msgid "Login"
58  msgstr "Let me in"
59
60``msgid`` contains the original term from the base package,
61``msgstr`` contains its localized/translated version, which results
62into a renamed login tab on the right side of the navigation bar.
63
64``po`` files must be compiled before restarting the portal. Editing
65and compilation of ``po`` files can be done with a nice tool called
66'Poedit' which is `available <https://poedit.net/download>`_ for
67various operating systems.
68
69
[13120]70Zope Interfaces
71===============
72
[13124]73Adding further schema field attributes to content components can be
74done by inheriting Zope interfaces from the base package and adding
75new schema fields to these custom interfaces, see :ref:`note
76<kofa_interfaces>`. This sounds simple, but it isn't. There are many
77things to think about, when customizing interfaces:
78
791. A customized interface alone doesn't have any effect, beause the
80   content classes still implement the original interfaces. Thus, also
81   all content classes, which are supposed to implement the extended
82   interfaces, must be customized, and must be registered instead of
83   the orginal classes which they inherit from. Drawback is, that this
84   must be done before the first start-up of the portal. Otherwise,
85   instances of the original content classes might have been created
86   which cannot be changed afterwards.
87
882. Also the forms which are being auto-generated by
89   `grok.AutoFields` (see :ref:`views_pages`), must be customized and
90   use the new and extended interfaces. Otherwise added fields won't
91   appear on form pages.
92
933. The same holds for exporters and importers. They also consider
94   the fields from interfaces when processing the data. If we forget to
95   customize exporter or batch processor classes, only the fields from
96   the original interfaces will be exported or reimported.
97
98
[13120]99Zope Utilities
100==============
101
[13124]102Kofa's global utilities are perfectly suited for customization.
103Their attributes and methods can be easily overridden in custom
104packages.
[13120]105
106Kofa Utils
107----------
108
[13124]109The central `KofaUtils` utility contains not only most dictionaries
[13132]110used for sources (see :py:class:`API
[13133]111<waeup.kofa.utils.utils.KofaUtils>`) but also **configuration
[13167]112attributes** like:
[13124]113
[13132]114.. autoattribute:: waeup.kofa.utils.utils.KofaUtils.PORTAL_LANGUAGE
115   :noindex:
116
117.. autoattribute:: waeup.kofa.utils.utils.KofaUtils.tzinfo
118   :noindex:
119
120.. autoattribute:: waeup.kofa.utils.utils.KofaUtils.SYSTEM_MAX_LOAD
121   :noindex:
122
[13133]123Customizable **utility methods** are:
[13124]124
[13133]125.. automethod:: waeup.kofa.utils.utils.KofaUtils.sendContactForm
[13124]126   :noindex:
127
[13133]128.. automethod:: waeup.kofa.utils.utils.KofaUtils.fullname
[13124]129   :noindex:
130
[13133]131.. automethod:: waeup.kofa.utils.utils.KofaUtils.genPassword
[13124]132   :noindex:
133
[13133]134.. automethod:: waeup.kofa.utils.utils.KofaUtils.sendCredentials
[13124]135   :noindex:
136
[13133]137.. automethod:: waeup.kofa.utils.utils.KofaUtils.getPaymentItem
[13124]138   :noindex:
139
[13133]140Students Utilities
141------------------
[13120]142
[13133]143`StudentsUtils` contains the following **configuration attributes**:
[13132]144
145.. autoattribute:: waeup.kofa.students.utils.StudentsUtils.STUDENT_ID_PREFIX
146   :noindex:
147
148.. autoattribute:: waeup.kofa.students.utils.StudentsUtils.SKIP_UPLOAD_VIEWLETS
149   :noindex:
150
151.. autoattribute:: waeup.kofa.students.utils.StudentsUtils.PORTRAIT_CHANGE_STATES
152   :noindex:
153
154.. autoattribute:: waeup.kofa.students.utils.StudentsUtils.SEPARATORS_DICT
155   :noindex:
156
157.. autoattribute:: waeup.kofa.students.utils.StudentsUtils.STUDENT_EXPORTER_NAMES
158   :noindex:
159
160.. autoattribute:: waeup.kofa.students.utils.StudentsUtils.STUDENT_BACKUP_EXPORTER_NAMES
161   :noindex:
162
[13133]163Customizable **utility methods** are:
[13124]164
[13133]165.. automethod:: waeup.kofa.students.utils.StudentsUtils.getReturningData
[13124]166   :noindex:
167
[13133]168.. automethod:: waeup.kofa.students.utils.StudentsUtils.setReturningData
[13124]169   :noindex:
170
[13133]171.. automethod:: waeup.kofa.students.utils.StudentsUtils.setPaymentDetails
[13124]172   :noindex:
173
[13133]174.. automethod:: waeup.kofa.students.utils.StudentsUtils.setBalanceDetails
[13124]175   :noindex:
176
[13133]177.. automethod:: waeup.kofa.students.utils.StudentsUtils.increaseMatricInteger
[13124]178   :noindex:
179
[13133]180.. automethod:: waeup.kofa.students.utils.StudentsUtils.constructMatricNumber
[13124]181   :noindex:
182
[13133]183.. automethod:: waeup.kofa.students.utils.StudentsUtils.setMatricNumber
[13124]184   :noindex:
185
[13133]186.. automethod:: waeup.kofa.students.utils.StudentsUtils.getAccommodationDetails
[13124]187   :noindex:
188
[13133]189.. automethod:: waeup.kofa.students.utils.StudentsUtils.selectBed
[13124]190   :noindex:
191
[13133]192.. automethod:: waeup.kofa.students.utils.StudentsUtils.renderPDFAdmissionLetter
[13124]193   :noindex:
194
[13133]195.. automethod:: waeup.kofa.students.utils.StudentsUtils.getPDFCreator
[13124]196   :noindex:
197
[13133]198.. automethod:: waeup.kofa.students.utils.StudentsUtils.renderPDF
[13124]199   :noindex:
200
[13133]201.. automethod:: waeup.kofa.students.utils.StudentsUtils.renderPDFTranscript
[13124]202   :noindex:
203
[13133]204.. automethod:: waeup.kofa.students.utils.StudentsUtils.maxCredits
[13124]205   :noindex:
206
[13133]207.. automethod:: waeup.kofa.students.utils.StudentsUtils.getBedCoordinates
[13124]208   :noindex:
209
210
[13133]211Applicants Utililties
212---------------------
[13120]213
[13133]214`ApplicantsUtils` contains the following **configuration attributes**:
[13120]215
[13133]216.. autoattribute:: waeup.kofa.applicants.utils.ApplicantsUtils.APP_TYPES_DICT
217   :noindex:
218
219.. autoattribute:: waeup.kofa.applicants.utils.ApplicantsUtils.SEPARATORS_DICT
220   :noindex:
221
222Customizable **utility methods** are:
223
224.. automethod:: waeup.kofa.applicants.utils.ApplicantsUtils.setPaymentDetails
225   :noindex:
226
227.. automethod:: waeup.kofa.applicants.utils.ApplicantsUtils.getApplicantsStatistics
228   :noindex:
229
230.. automethod:: waeup.kofa.applicants.utils.ApplicantsUtils.sortCertificates
231   :noindex:
232
233.. automethod:: waeup.kofa.applicants.utils.ApplicantsUtils.getCertTitle
234   :noindex:
Note: See TracBrowser for help on using the repository browser.