Remove require flag from devices
[misc/kostenrechnung] / masks / arbeitsberichte.php
1 <?php
2
3 $jscode[] = <<<EOC
4
5 Rico.loadModule('Calendar');
6
7 function get_number(name)
8 {
9   var elems = name.split(':');
10   if (elems.length == 1) return 0;
11   return Number(elems[elems.length-1]);
12 }
13
14 function select_gebiet_callback(data)
15 {
16     select_update('edit_kostenstelle',data.info,1);
17 }
18
19 function select_gebiet(obj)
20 {
21     get_info('kostenstellen', {gebiet: obj.options[obj.selectedIndex].value}, select_gebiet_callback);
22 }
23
24 function select_geraet_callback(data)
25 {
26     var num = get_number(data.parameter.id);
27
28     var id = 'edit_anbaugeraet';
29     if (num > 0) id += ':' + num;
30
31     select_update(id,data.info);
32 }
33
34 function select_geraet(obj)
35 {
36     get_info('anbaugeraete',
37              {geraet: obj.options[obj.selectedIndex].value, id: obj.id},
38              select_geraet_callback);
39 }
40
41 function form_onload()
42 {
43     get_info('gebiete', {}, function (data) { select_update('edit_gebiet',data.info, 1); });
44     get_info('ordnungen', {}, function (data) { select_update('edit_ordnung',data.info,1); });
45     get_info('mitarbeiter', {}, function (data) { select_update('edit_personal',data.info, 1); });
46     get_info('geraete', {}, function (data) { select_update('edit_geraet',data.info, 1); });
47     get_info('arbeitsarten', {}, function (data) { select_update('edit_arbeitsart',data.info,1); });
48 }
49
50 function replicate_personal()
51 {
52     var elem;
53     var personal = document.getElementById('edit_personal');
54     var stunden = document.getElementById('edit_stunden');
55
56     var number = get_number(personal.parentNode.children[personal.parentNode.children.length-1].name) + 1;
57
58     elem = document.createElement('br');
59     personal.parentNode.appendChild(elem);
60
61     elem = document.createElement('select');
62     elem.id = 'edit_personal:' + number;
63     elem.name = 'personal:' + number;
64     elem.options[0] = new Option('Bitte wählen Sie','',false,false);
65     personal.parentNode.appendChild(elem);
66     get_info('mitarbeiter', {}, function (data) { select_update('edit_personal:'+number,data.info, 1); });
67
68     elem = document.createElement('br');
69     stunden.parentNode.appendChild(elem);
70
71     elem = document.createElement('input');
72     elem.id = 'edit_stunden:' + number;
73     elem.name = 'stunden:' + number;
74     elem.type = 'text';
75     elem.size = 5;
76     stunden.parentNode.appendChild(elem);
77
78     return false;
79 }
80
81 function replicate_geraete()
82 {
83     var elem;
84     var geraet = document.getElementById('edit_geraet');
85     var anbaugeraet = document.getElementById('edit_anbaugeraet');
86     var geraetstunden = document.getElementById('edit_geraetstunden');
87
88     var number = get_number(geraet.parentNode.children[geraet.parentNode.children.length-1].name) + 1;
89
90     elem = document.createElement('br');
91     geraet.parentNode.appendChild(elem);
92
93     elem = document.createElement('select');
94     elem.id = 'edit_geraet:' + number;
95     elem.name = 'geraet:' + number;
96     elem.options[0] = new Option('Bitte wählen Sie','',false,false);
97     elem.onchange = function() { select_geraet(this); };
98     geraet.parentNode.appendChild(elem);
99     get_info('geraete', {}, function (data) { select_update('edit_geraet:'+number,data.info, 1); });
100
101     elem = document.createElement('br');
102     anbaugeraet.parentNode.appendChild(elem);
103
104     elem = document.createElement('select');
105     elem.id = 'edit_anbaugeraet:' + number;
106     elem.name = 'anbaugeraet:' + number;
107     anbaugeraet.parentNode.appendChild(elem);
108
109     elem = document.createElement('br');
110     geraetstunden.parentNode.appendChild(elem);
111
112     elem = document.createElement('input');
113     elem.id = 'edit_geraetstunden:' + number;
114     elem.name = 'geraetstunden:' + number;
115     elem.type = 'text';
116     elem.size = 5;
117     geraetstunden.parentNode.appendChild(elem);
118
119     return false;
120 }
121
122 function einsatz_check()
123 {
124     var fields = {
125         datum: 'Datum',
126         gebiet: 'Gebiet',
127         kostenstelle: 'Gewässer',
128         ordnung: 'Gewässerordnung',
129         arbeitsart: 'Arbeiten',
130         personal: 'Mitarbeiter',
131         stunden: 'Stunden'};
132
133     for (id in fields) {
134         var elem = document.getElementById('edit_' + id);
135
136         if (elem.nodeName.toLowerCase() == 'input') {
137             if (!elem.value.length) {
138                 alert('Das Feld ' + fields[id] + ' muß ausgefüllt werden');
139                 return false;
140             }
141             continue;
142         }
143
144         if (elem.nodeName.toLowerCase() == 'select') {
145             if (!elem.options[elem.selectedIndex].value.length) {
146                 alert('Das Feld ' + fields[id] + ' muß ausgefüllt werden');
147                 return false;
148             }
149             continue;
150         }
151     }
152
153     return true;
154 }
155
156 function einsatz_callback(data)
157 {
158     info('Neuer Arbeitsbericht gespeichert');
159     window.location.reload();
160 }
161
162 function einsatz_submit()
163 {
164     if (!einsatz_check()) return false;
165
166     var form = document.getElementById('edit_form');
167     var source = document.getElementById('source');
168     if (!source || !form) return false;
169
170     ajax_request('insert', Form.serialize(form) + '&source=' + source.innerHTML, einsatz_callback);
171
172     return false;
173 }
174
175 Rico.onLoad(form_onload);
176
177 EOC;
178
179 $formular = <<<EOC
180 <div class="form">
181 <form id="edit_form">
182
183 <table width="100%" cellspacing="2" border="0">
184 <tr>
185  <td width="25%"><label for="edit_datum">Datum</label></td>
186  <td width="25%"><label for="edit_gebiet">Gebiet</label></td>
187  <td width="25%"><label for="edit_kostenstelle">Gewässer</label></td>
188  <td width="25%"><label for="edit_ordnung">Gewässerordnung</label></td>
189 </tr>
190 <tr>
191  <td width="25%"><input id="edit_datum" name="datum" size="8">&nbsp;<img class="calendar" src="images/icons/calendar.gif" onclick="calendar('edit_datum',event)"></td>
192  <td width="25%"><select id="edit_gebiet" name="gebiet" onchange="select_gebiet(this)"><option value="">Bitte wählen Sie</option></select></td>
193  <td width="25%"><select id="edit_kostenstelle" name="kostenstelle"><option value="">Bitte wählen Sie</option></select></td>
194  <td width="25%"><select id="edit_ordnung" name="ordnung"><option value="">Bitte wählen Sie</option></select></td>
195 </tr>
196 </table>
197
198 <table width="100%" cellspacing="2" border="0" style="border: 1px solid #CCC; border-bottom: none; background: #e5e5e5;">
199 <tr>
200  <td width="30%"><label for="edit_personal">Mitarbeiter</label></td>
201  <td width="30%"><label for="edit_stunden">Stunden</label></td>
202  <td width="30%">&nbsp;</td>
203  <td width="10%">&nbsp;</td>
204 </tr>
205 <tr>
206  <td width="30%"><select id="edit_personal" name="personal"><option value="">Bitte wählen Sie</option></select></td>
207  <td width="30%"><input id="edit_stunden" name="stunden" size="5" type="text"></td>
208   <td width="30%">&nbsp;</td>
209  <td width="10%" align="right"valign="bottom"><button onclick="return replicate_personal()" style="color: red; font-weight: bold;">+&nbsp;</button></td>
210 </tr>
211 </table>
212
213 <table width="100%" cellspacing="2" border="0" style="border: 1px solid #CCC; background: #e5e5e5;">
214 <tr>
215  <td width="30%"><label for="edit_geraet">Gerät</label></td>
216  <td width="30%"><label for="edit_anbaugeraet">Anbaugerät</label></td>
217  <td width="30%"><label for="edit_geraetstunden">Stunden</label></td>
218  <td width="10%">&nbsp;</td>
219 </tr>
220 <tr>
221  <td width="30%"><select id="edit_geraet" name="geraet" onchange="select_geraet(this)"><option value="">Bitte wählen Sie</option></select></td>
222  <td width="30%"><select id="edit_anbaugeraet" name="anbaugeraet"></select></td>
223  <td width="30%"><input id="edit_geraetstunden" name="stunden" size="5" type="text"></td>
224  <td width="10%" align="right"valign="bottom"><button onclick="return replicate_geraete()" style="color: red; font-weight: bold;">+&nbsp;</button></td>
225 </tr>
226 </table>
227
228 <table width="100%" cellspacing="2" border="0" style="margin-top: 5px;">
229 <tr>
230  <td width="50%"><label for="edit_bemerkung">Bemerkung</label></td>
231  <td width="25%"><label for="edit_arbeitsart">Arbeiten</label></td>
232  <td width="25%"><label for="edit_akkord">Akkord</label></td>
233 </tr>
234 <tr>
235  <td width="50%" valign="top"><textarea id="edit_bemerkung" name="bemerkung" cols="66" rows="5"></textarea></td>
236  <td width="25%" valign="top"><select id="edit_arbeitsart" name="arbeitsart"><option value="">Bitte wählen Sie</option></select></td>
237  <td width="25%" valign="top"><input id="edit_akkord" name="akkord" type="checkbox"></td>
238 </tr>
239 </table>
240
241
242 <div align="center" style="margin-bottom: 5px;"><button onclick="return einsatz_submit()">Hinzufügen</button></div>
243 </form>
244 </div>
245 EOC;
246
247 function einsatz_insert($mask)
248 {
249   $date = explode('.',$_POST['datum']);
250   $date = sprintf('%04d-%02d-%02d', $date[2], $date[1], $date[0]);
251
252   $sql = sprintf("INSERT INTO einsatz (datum,ordnung,gebiet,kostenstelle,arbeiten,akkord,bemerkung,sys_user,sys_edit) " .
253                  "VALUES ('%s',%d,%d,%d,%d,%d,%s,'%s',now())",
254                  $date,
255                  $_POST['ordnung'],
256                  $_POST['gebiet'],
257                  $_POST['kostenstelle'],
258                  $_POST['arbeitsart'],
259                  $_POST['akkord'],
260                  empty($_POST['bemerkung']) ? 'NULL' : "'" . pg_escape_string($_POST['bemerkung']) . "'",
261                  pg_escape_string($_SESSION['sys']['login']));
262
263   $sth = pg_query($sql);
264
265   if ($sth === false) {
266     error_log($sql . ': ' . pg_last_error());
267     return array('error' => pg_last_error(),
268                  'sql' => $sql);
269   }
270
271   $sql = "SELECT currval('einsatz_id_seq')";
272   $sth =  pg_query($sql);
273
274   if ($sth === false) {
275     error_log($sql . ': ' . pg_last_error());
276     return array('error' => pg_last_error(),
277                  'sql' => $sql);
278   }
279
280   $row = pg_fetch_assoc($sth);
281   $einsatz = $row['currval'];
282
283   $num = 0;$app='';
284   while (true) {
285     if ($num) {
286       $app = ':'.$num;
287       if (empty($_POST['personal'.$app])) break;
288     }
289     $sql = sprintf("INSERT INTO einsatzpersonal (einsatz,personal,stunden,sys_user,sys_edit) " .
290                    "VALUES (%d,%d,%.2f,'%s',now())",
291                    $einsatz,
292                    $_POST['personal'.$app],
293                    $_POST['stunden'.$app],
294                    pg_escape_string($_SESSION['sys']['login']));
295
296     $sth = pg_query($sql);
297
298     if ($sth === false) {
299       error_log($sql . ': ' . pg_last_error());
300       return array('error' => pg_last_error(),
301                    'sql' => $sql);
302     }
303
304     $num++;
305   }
306
307   $num = 0;$app='';
308   while (true) {
309     if ($num) $app = ':'.$num;
310     if (empty($_POST['geraet'.$app])) break;
311     $sql = sprintf("INSERT INTO einsatzgeraete (einsatz,geraet,anbaugeraet,stunden,sys_user,sys_edit) " .
312                    "VALUES (%d,%d,%s,%.2f,'%s',now())",
313                    $einsatz,
314                    $_POST['geraet'.$app],
315                    empty($_POST['anbaugeraet'.$app]) ? 'NULL' : intval($_POST['anbaugeraet'.$app]),
316                    $_POST['stunden'.$app],
317                    pg_escape_string($_SESSION['sys']['login']));
318
319     $sth = pg_query($sql);
320
321     if ($sth === false) {
322       error_log($sql . ': ' . pg_last_error());
323       return array('error' => pg_last_error(),
324                    'sql' => $sql);
325     }
326
327     $num++;
328   }
329
330   return array('status' => true);
331 }
332
333 $mask = array(
334               'table' => 'einsatz',
335               'title' => 'Arbeitsberichte',
336               'html' => $formular,
337               'insert' => einsatz_insert,
338               'info' => array(
339                               'gebiete' => array(
340                                             'sql' => 'SELECT id,gebiet AS text FROM gebiet ORDER BY text',
341                                             ),
342                               'ordnungen' => array(
343                                             'sql' => 'SELECT id,name AS text FROM ordnungen ORDER BY id',
344                                             ),
345                               'mitarbeiter' => array(
346                                             'sql' => 'SELECT id,name || \', \' || vorname AS text FROM personal WHERE aktiv = 1 ORDER BY text',
347                                             ),
348                               'geraete' => array(
349                                             'sql' => 'SELECT id,geraet AS text FROM gerate ORDER BY text',
350                                             ),
351                               'arbeitsarten' => array(
352                                             'sql' => 'SELECT id,arbeitsart AS text FROM arbeitsarten ORDER BY text',
353                                             ),
354                               'kostenstellen' => array(
355                                             'sql' => 'SELECT id,kostenstelle AS text FROM kostenstellen WHERE gebiet = {gebiet} ORDER BY text',
356                                             ),
357                               'anbaugeraete' => array(
358                                             'sql' => 'SELECT anbaugeraete.id,anbaugeraet as text FROM anbaugeraete ' .
359                                                      'JOIN gerate ON anbaugeraete.geraetetyp = gerate.geraetetyp ' .
360                                                      'WHERE gerate.id = {geraet} ORDER BY text',
361                                             ),
362                                    ),
363               );
364
365 ?>