8f9a01fca6fdfb9b023baba9c3e72f946d775f4b
[auf_rh_dae.git] / project / dae / templates / dae / poste.html
1 {% extends 'base.html' %}
2
3 {% block title %}RH - DAE{% endblock %}
4 {% block titre %}Ressources humaines{% endblock %}
5 {% block sous_titre %}
6 Demande d'autorisation d'embauche
7 {% endblock %}
8
9 {% block extrahead %}
10 <script src="{{ MEDIA_URL }}js/jquery-1.5.1.min.js"
11 type="text/javascript"></script>
12 <script src="{{ MEDIA_URL }}js/jquery-ui-1.8.11.custom.min.js"
13 type="text/javascript"></script>
14 <link href="{{ MEDIA_URL }}/css/redmond/jquery-ui-1.8.11.custom.css"
15 rel="stylesheet" />
16
17 <style>
18 h1.section {background-color: #D0E8F8; text-align: center; color: #5F5F5F; margin: 50px 0px 26px 0px; border-bottom: 3px solid #BBD8EC; padding: 4px;}
19 .row {padding: 10px 0px; clear: both; display:block;}
20 .row * {float: left; margin: 0px; padding: 0px; margin-right: 4px;}
21 .row li {list-style-type: none;}
22 .underline {text-decoration: underline;}
23 .clear {display: block; clear: both;}
24 .note {text-decoration: underline; font-style: italic; margin-left: 12px;}
25 .info {font-size:13px; font-style: italic;}
26 .noborder {border:none; margin:0; padding; 0}
27 tr.noborder td {border:none; padding-left: 0;}
28 </style>
29 {% endblock %}
30
31 {% block main %}
32 <h1>Demande d'autorisation de création de poste</h1>
33
34 <form action="" method="post">
35 <fieldset>
36 <h2>
37 {% if new %}
38 Nouveau poste
39 {% else %}
40 Poste existant : {{ poste.nom }} ({{ poste.implantation.nom }})
41 {% endif %}
42 </h2>
43 <table>
44 <tbody>
45 <tr>
46 <th>{{ form.poste.label_tag }} :<br />{{ form.poste.errors }}</th>
47 <td>{{ form.poste }}</td>
48 </tr>
49 <tr>
50 <th>{{ form.nom.label_tag }} :<br />{{ form.nom.errors }}</th>
51 <td>{{ form.nom }}</td>
52 </tr>
53 <tr>
54 <th>{{ form.type_poste.label_tag }} :<br />{{ form.type_poste.errors }}</th>
55 <td>{{ form.type_poste }}</td>
56 </tr>
57 <tr>
58 <th>{{ form.implantation.label_tag }} :<br />{{ form.implantation.errors }}</th>
59 <td>{{ form.implantation }}</td>
60 </tr>
61 <tr>
62 <th>{{ form.service.label_tag }} :<br />{{ form.service.errors }}</th>
63 <td>{{ form.service }}</td>
64 </tr>
65 <tr>
66 <th>{{ form.responsable.label_tag }} :<br />{{ form.responsable.errors }}</th>
67 <td>{{ form.responsable }}</td>
68 </tr>
69 </tbody>
70 </table>
71 </fieldset>
72
73 <fieldset>
74 <h2>Recrutement</h2>
75 <table>
76 <tbody>
77 <tr>
78 <th>{{ form.statut_residence.label_tag }} :<br />{{ form.statut_residence.errors }}</th>
79 <td>
80 <span class="row">
81 {{ form.statut_residence }}
82 {{ form.mise_a_disposition.label_tag }}
83 {{ form.mise_a_disposition.errors }}
84 {{ form.mise_a_disposition }}
85 </span>
86 </td>
87 </tr>
88 <tr>
89 <th>{{ form.appel.label_tag }} :<br />{{ form.appel.errors }}</th>
90 <td>
91 <span class="row">
92 {{ form.appel }}
93 </span>
94 </td>
95 </tr>
96 </tbody>
97 </table>
98 </fieldset>
99
100 <fieldset>
101 <h2>Durée prévue du poste </h2>
102 <span class="info">Indépendamment du titulaire du poste</span>
103 <table>
104 <tbody>
105 <tr>
106 <th rowspan="2">Durée :</th>
107 <td>du</td>
108 <td>
109 {{ form.date_debut }}<br />
110 <span class="info">({{form.date_debut.help_text }})</span><br />
111 {{ form.date_debut.errors }}
112 </td>
113 <td> au </td>
114 <td>
115 {{ form.date_fin }}<br />
116 <span class="info">({{form.date_fin.help_text }})</span><br />
117 {{ form.date_fin.errors }}
118 </td>
119 </tr>
120 <tr>
121 <td colspan="4" class="info">Pour une durée indéterminée, spécifier uniquement la date de début.</td>
122 </tr>
123 <tr>
124 <th>{{ form.regime_travail.label_tag }} :<br />{{ form.regime_travail.errors }}</th>
125 <td colspan="4">
126 {{ form.regime_travail }}
127 <span class="info">{{ form.regime_travail.help_text }}</span>
128 </td>
129 </tr>
130 <tr>
131 <th>
132 {{ form.regime_travail_nb_heure_semaine.label_tag }} :<br />
133 {{ form.regime_travail_nb_heure_semaine.errors }}
134 </th>
135 <td colspan="4">{{ form.regime_travail_nb_heure_semaine }}</td>
136 </tr>
137 </tbody>
138 </table>
139 </fieldset>
140
141 <fieldset>
142 <h2>Classement du poste</h2>
143 <table>
144 <tbody>
145 <tr>
146 <th></th>
147 <th>Échelon AUF</th>
148 <th>Coefficient</th>
149 <th>Valeur du point</th>
150 <th>Devise</th>
151 <th colspan="2">Salaire de base</th>
152 <th colspan="2">Indemnité, responsabilité (le cas échéant)</th>
153 <th colspan="2">Autres</th>
154 <th colspan="2">TOTAL</th>
155 <th>Taux&nbsp;>&nbsp;</th>
156 <th colspan="2">Conversion EUR</th>
157 </tr>
158 <tr>
159 <th>Minimum</th>
160 <td>{{ form.classement_min }}</td>
161 <td>{{ form.coefficient_min }}</td>
162 <td>
163 {{ form.valeur_point_min }}
164 {{ form.valeur_point_min.errors }}
165 </td>
166 <td>
167 {{ form.devise_min }}
168 {{ form.devise_min.errors }}
169 </td>
170 <td >{{ form.salaire_min }}</td>
171 <td><span class="devise_min_code">EUR</span></td>
172 <td>{{ form.indemn_min }}</td>
173 <td><span class="devise_min_code">EUR</span></td>
174 <td>{{ form.autre_min }}</td>
175 <td><span class="devise_min_code">EUR</span></td>
176 <td id="total_min" class="cell-nombre">0.00</td>
177 <td><span class="devise_min_code">EUR</span></td>
178 <td id="taux_min_euro_display">1</td>
179 <td id="total_min_euro" class="cell-nombre">0.00</td>
180 <td></td>
181 </tr>
182 <tr>
183 <th>Maximun</th>
184 <td>{{ form.classement_max }}</td>
185 <td>{{ form.coefficient_max }}</td>
186 <td>
187 {{ form.valeur_point_max }}
188 {{ form.valeur_point_max.errors }}
189 </td>
190 <td>
191 {{ form.devise_max }}
192 {{ form.devise_max.errors }}
193 </td>
194 <td>{{ form.salaire_max }}</td>
195 <td><span class="devise_max_code">EUR</span></td>
196 <td>{{ form.indemn_max }}</td>
197 <td><span class="devise_max_code">EUR</span></td>
198 <td>{{ form.autre_max }}</td>
199 <td><span class="devise_max_code">EUR</span></td>
200 <td id="total_max" class="cell-nombre">0.00</td>
201 <td><span class="devise_max_code">EUR</span></td>
202 <td id="taux_max_euro_display">1</td>
203 <td id="total_max_euro" class="cell-nombre">0.00</td>
204 <td></td>
205 </tr>
206 </tbody>
207 </table>
208
209 <p class="info">N.B Conversion en EUROS au taux de change budgétaire</p>
210 </fieldset>
211
212 {% if new %}
213 <fieldset>
214 <h2>Éléments de comparaison</h2>
215 <p class="info">Compléter uniquement lors de la création d'un poste</p>
216 <table>
217 <tbody>
218 <tr>
219 <th></th>
220 <th>Locale</th>
221 <th>Université</th>
222 <th>Fonction publique</th>
223 <th>ONG</th>
224 <th>Autre</th>
225 </tr>
226 <tr>
227 <th>Minimum</th>
228 <td>{{ form.comp_locale_min }}</td>
229 <td>{{ form.comp_universite_min }}</td>
230 <td>{{ form.comp_fonctionpub_min }}</td>
231 <td>{{ form.comp_ong_min }}</td>
232 <td>{{ form.comp_autre_min }}</td>
233 </tr>
234 <tr>
235 <th>Maximum</th>
236 <td>{{ form.comp_locale_max }}</td>
237 <td>{{ form.comp_universite_max }}</td>
238 <td>{{ form.comp_fonctionpub_max }}</td>
239 <td>{{ form.comp_ong_max }}</td>
240 <td>{{ form.comp_autre_max }}</td>
241 </tr>
242 </tbody>
243 </table>
244 </fieldset>
245 {% endif %}
246
247 {% comment %}
248 <h1 class="section clear">SECTION 2 - PERSONNEL ENGAGÉ</h1>
249 <div class="row"></div>
250
251 <h1 class="section">SECTION 3 - COÛT GLOBAL</h1>
252 <div class="row"></div>
253
254 <h1 class="section">SECTION 4 - JUSTIFICATION DE LA DEMANDE (OBLIGATOIRE)</h1>
255 <div class="row"></div>
256 {% endcomment %}
257 <input type="submit" name="save" value="Sauvegarder" />
258 </form>
259
260 <fieldset>
261 <h2>Financement</h2>
262
263 <table cellspacing="0" id="financing">
264 <tr>
265 <th>Type</th>
266 <th>Montant</th>
267 <th>Devise</th>
268 <th>Pourcentage</th>
269 <th>Commentaire</th>
270 <th></th>
271 </tr>
272 {% for fin in poste.financements.all %}
273 <tr>
274 <td>{{ fin.get_type_display }}</td>
275 <td>{{ fin.montant }}</td>
276 <td>
277 {% comment %}
278 {{ fin.devise }}
279 {% endcomment %}
280 </td>
281 <td>{{ fin.pourcentage }}</td>
282 <td>{{ fin.commentaire }}</td>
283 <td><a href="{% url financement poste_key fin.id %}">Modifier</a></td>
284 </tr>
285 {% empty %}
286 <tr>
287 <td colspan="5">
288 {% if new %}
289 Vous devez enregister ce nouveau poste avant de pouvoir spécifier
290 la ou les sources de financement.
291 {% else %}
292 Aucun financement au registre
293 {% endif %}
294 </td>
295 </tr>
296 {% endfor %}
297 </table>
298 {% if not new %}
299 <a href="{% url financement poste_key %}" class="new">
300 Ajouter une source de financement
301 </a>
302 {% endif %}
303
304 <div id="financing-form"></div>
305 </fieldset>
306
307 <script type="text/javascript">
308 $('#id_poste').change(function() {
309 window.location = '{% url poste %}/' + $(this).val();
310 });
311 $('#financing a, a.new').click(function() {
312 $('#financing-form').load($(this).attr('href') + '?ajax=1')
313 .dialog({
314 modal: true,
315 height: 500,
316 width: 550
317 });
318 return false;
319 });
320
321 /* CLASSEMENT MIN */
322 $(document).ready(function() {
323 valeur_min = '<input type="hidden" id="valeur_min" name="valeur_min" value="0" disabled="disabled">'
324 devise_min_code = '<input type="hidden" id="devise_min_code" name="devise_min_code" value="5" disabled="disabled">'
325 taux_min_euro = '<input type="hidden" id="taux_min_euro" name="taux_min_euro" value="1" disabled="disabled">'
326 $('#id_valeur_point_min').after(valeur_min)
327 $('#id_devise_min').after(devise_min_code)
328 $('#total_min_euro').after(taux_min_euro)
329 });
330 /* bindings */
331 $('#id_coefficient_min').bind('coeff_min_modified', function(){
332 $('#id_salaire_min').trigger('update_salaire_min');
333 });
334 $('.devise_min_code').bind('update_devise_min_code', function(){
335 devise_code = $('#devise_min_code').val();
336 $('.devise_min_code').empty();
337 $('.devise_min_code').text(devise_code);
338 });
339 $('#id_salaire_min').bind('update_salaire_min', function(){
340 valeur = $('#valeur_min').val();
341 coeff = $('#id_coefficient_min').val();
342 salaire = coeff * valeur;
343 salaire = clean_float(salaire);
344 $(this).val(salaire);
345 $('#total_min').trigger('update_total_min');
346 });
347 $('#total_min').bind('update_total_min', function(){
348 total = 0;
349 salaire = $('#id_salaire_min').val();
350 indemn = $('#id_indemn_min').val();
351 autre = $('#id_autre_min').val();
352 salaire = clean_float(salaire);
353 indemn = clean_float(indemn);
354 autre = clean_float(autre);
355 total = salaire + indemn + autre;
356 $(this).empty();
357 $(this).text(total.toFixed(2));
358 $('#total_min_euro').trigger('update_total_min_euro');
359 });
360 $('#total_min_euro').bind('update_total_min_euro', function(){
361 total = $('#total_min').text();
362 taux_euro = $('#taux_min_euro').val();
363 total = clean_float(total);
364 taux_euro = clean_float(taux_euro);
365 total_euro = total * taux_euro;
366 $(this).empty();
367 $(this).text(total_euro.toFixed(2));
368 });
369 /* change */
370 $('#id_coefficient_min').change(function(){
371 $(this).trigger('coeff_min_modified');
372 });
373 $('#id_classement_min').change(function() {
374 url = "{% url dae_coefficient %}";
375 $.post(url, {'classement':$(this).val()}, function(data){
376 $('#id_coefficient_min').val(data["coefficient"]);
377 $('#id_coefficient_min').trigger('coeff_min_modified');
378 }, 'json');
379 });
380 $('#id_valeur_point_min').change(function() {
381 url_valeur = "{% url dae_valeur %}";
382 url_devise = "{% url dae_devise %}";
383 $.post(url_valeur, {'valeur_point':$(this).val()}, function(data){
384 $('#valeur_min').val(data["valeur"]);
385 $('#id_salaire_min').trigger('update_salaire_min');
386 $('#total_min_euro').trigger('update_total_min_euro');
387 }, 'json');
388 $.post(url_devise, {'valeur_point':$(this).val()}, function(data){
389 $('#id_devise_min').val(data["devise"]);
390 $('#devise_min_code').val(data["devise_code"]);
391 $('#taux_min_euro').val(data["taux_euro"]);
392 $('#taux_min_euro_display').empty();
393 $('#taux_min_euro_display').text(data["taux_euro"]);
394 $('.devise_min_code').trigger('update_devise_min_code');
395 $('#total_min_euro').trigger('update_total_min_euro');
396 }, 'json');
397 });
398 $('#id_devise_min').change(function(){
399 url_devise_code = "{% url dae_devise_code %}";
400 $.post(url_devise_code, {'devise':$(this).val()}, function(data){
401 $('#devise_min_code').val(data["devise_code"]);
402 $('#taux_min_euro').val(data["taux_euro"]);
403 $('#taux_min_euro_display').empty();
404 $('#taux_min_euro_display').text(data["taux_euro"]);
405 $('.devise_min_code').trigger('update_devise_min_code');
406 $('#total_min_euro').trigger('update_total_min_euro');
407 }, 'json');
408 });
409 $('#id_salaire_min').change(function(){
410 $('#total_min').trigger('update_total_min');
411 });
412 $('#id_indemn_min').change(function(){
413 $('#total_min').trigger('update_total_min');
414 });
415 $('#id_autre_min').change(function(){
416 $('#total_min').trigger('update_total_min');
417 });
418
419 /* CLASSEMENT MAX */
420 $('#id_classement_max').change(function() {
421 url = "{% url dae_coefficient %}";
422 $.post(url, {'classement':$(this).val()}, function(data){
423 $('#id_coefficient_max').val(data["coefficient"]);
424 }, 'json');
425 });
426
427 /* helpers */
428 function clean_float(value){
429 if (value == undefined)
430 output = 0;
431 else
432 output = parseFloat(value);
433 output = Math.round(output*100)/100;
434 return output;
435 }
436
437 </script>
438 {% endblock %}