bfe1add10c6ce2caf24f6df65130bb088278c093
[misc/kostenrechnung] / lib / mask.php
1 <?php
2
3 function check_edit($name)
4 {
5   $sql = sprintf("SELECT sys_mask.id,edit FROM sys_mask "
6                  . "JOIN sys_group_mask ON sys_mask.id = sys_group_mask.mask "
7                  . "WHERE gid = %d AND fname = '%s' "
8                  . "ORDER BY edit DESC LIMIT 1",
9                  $_SESSION['sys']['group'], pg_escape_string($name));
10
11   $sth = pg_query($sql);
12
13   if ($sth === false) return false;
14
15   $row = pg_fetch_assoc($sth);
16   if ($row === false) return false;
17
18   if ($row['edit'] == '0')
19     return false;
20
21   return true;
22 }
23
24 function build_form($name, $mask)
25 {
26   global $jscode;
27   $ret = array();
28
29   $jscode[] = 'Rico.onLoad( function() {';
30   $jscode[] = "form_init();";
31   $jscode[] = '});';
32
33   $ret[] = '<div class="form">';
34   if (empty($mask['edit_title']))
35     $ret[] = '<p id="mask_edit_title" class="title">Datensatz bearbeiten</p>';
36   else
37     $ret[] = sprintf('<p id="mask_edit_title" class="title">%s</p>', $mask['edit_title']);
38   $ret[] = '<form id="form_edit">';
39
40   $ret[] = '<input type="hidden" id="edit_id" name="id" value="">';
41   $ret[] = sprintf('<input type="hidden" id="edit_source" name="source" value="%s">', $name);
42
43   foreach ($mask['edit'] as $id => $info) {
44     if ($info['type'] == 'hidden') {
45       $ret[] = sprintf('<input type="hidden" id="edit_%s" name="%s">', $id, $id);
46     } else if ($info['type'] == 'text' || $info['type'] == 'passwd' ||
47         $info['type'] == 'decimal' || $info['type'] == 'number') {
48       $v = array('id="edit_'.$id.'"',
49                  'name="'.$id.'"');
50       $v[] = 'size="'.(empty($info['size'])?'10':$info['size']).'"';
51       $v[] = 'type="'.($info['type']=='passwd'?'password':'text').'"';
52       $ret[] = sprintf('<label for="edit_%s">%s</label><br>', $id, $info['name']);
53       $ret[] = sprintf('<input %s>', implode(' ', $v));
54     } elseif ($info['type'] == 'date') {
55       $ret[] = sprintf('<label for="edit_%s">%s</label><br>', $id, $info['name']);
56       $ret[] = sprintf('<input id="edit_%s" name="%s" size="8">&nbsp;'.
57                        '<img class="calendar" src="images/icons/calendar.gif" onclick="calendar(\'edit_%s\',event)" />',
58                        $id, $id, $id);
59     } elseif ($info['type'] == 'boolean') {
60       $ret[] = sprintf('<label for="edit_%s">%s</label><br>', $id, $info['name']);
61       $ret[] = sprintf('<input type="checkbox" id="edit_%s" name="%s">', $id, $id);
62     } elseif ($info['type'] == 'select') {
63       $v = array('id="edit_'.$id.'"',
64                  'name="'.$id.'"');
65       if (array_key_exists('onchange',$info))
66         $v[] = sprintf('onchange="%s"', $info['onchange']);
67
68       $ret[] = sprintf('<label for="edit_%s">%s</label><br>', $id, $info['name']);
69       $ret[] = sprintf('<select %s>', implode(' ', $v));
70       if (array_key_exists('option_empty',$info))
71         $ret[] = sprintf('<option value="">%s</option>',
72                          $info['option_empty']);
73       if (is_array($info['options'])) $options = $info['options'];
74       else $options = query_db($info['options']);
75       foreach ($options as $row)
76         $ret[] = sprintf('<option value="%s"%s>%s</option>',
77                          $row['id'],
78                          !empty($info['selected']) && $row['id'] == $info['selected'] ? ' selected' : '',
79                          $row['text']);
80       $ret[] = '</select>';
81     } elseif ($info['type'] == 'textarea') {
82       $ret[] = sprintf('<label for="edit_%s">%s</label><br>', $id, $info['name']);
83       $v = array('id="edit_'.$id.'"',
84                  'name="'.$id.'"');
85       $v[] = sprintf('cols="%d"', empty($info['columns'])?33:$info['columns']);
86       $v[] = sprintf('rows="%d"', empty($info['rows'])?5:$info['columns']);
87       $ret[] = sprintf('<textarea %s></textarea>', implode(' ', $v));
88     }
89     if (array_key_exists('comment',$info))
90       $ret[] = sprintf('<span class="comment">%s</span>', $info['comment']);
91     if ($info['type'] != 'hidden')
92       $ret[] = '<br>';
93   }
94
95   $v_save = array('id="button_save"',
96                   'onclick="return form_save(this);"');
97   if ($mask['buttons']['save'] === false) $v_save[] = 'style="display: none"';
98
99   $v_insert = array('id="button_insert"',
100                   'onclick="return form_insert(this);"');
101   if ($mask['buttons']['insert'] === false) $v_insert[] = 'style="display: none"';
102
103   $v_delete = array('id="button_delete"',
104                     'onclick="return form_delete(this);"');
105   if ($mask['buttons']['delete'] === false) $v_delete[] = 'style="display: none"';
106
107   $ret[] = '<span id="form_status">&nbsp;</span>';
108   $ret[] = '<div class="buttons">';
109   $ret[] = sprintf('<button %s>%s</button>', implode(' ', $v_save), 'Speichern');
110   $ret[] = '<span></span>';
111   $ret[] = sprintf('<button %s>%s</button>', implode(' ', $v_insert), 'Hinzufügen');
112   $ret[] = '<span></span>';
113   $ret[] = sprintf('<button %s>%s</button>', implode(' ', $v_delete), 'Löschen');
114   $ret[] = '</div>';
115
116   $ret[] = '</form>';
117   $ret[] = '</div>';
118
119   return $ret;
120 }
121
122 function build_grid($name, $mask)
123 {
124   global $jscode;
125   $ret = array();
126
127   $opts = array("click: gridDrillDown",
128                 "onscroll: gridOnScroll",
129                 "menuEvent: 'contextmenu'",
130                 "highlightElem: 'menuRow'");
131
132   if (array_key_exists('rows', $mask)) $opts[] = 'visibleRows: ' . $mask['rows'];
133   if (array_key_exists('sort', $mask)) $opts[] = 'sortCol: ' . $mask['sort'];
134   if ($mask['prefetch'] === false) $opts[] = 'prefetch: false';
135   # $opts[] = 'frozenColumns: ' . count($mask['list']);
136   $opts[] = 'saveColumnInfo: {width: true, filter: true, sort: true}';
137
138   $ret[] = sprintf('<table id="grid_%s" class="ricoLiveGrid">', $name);
139   $ret[] = '  <tr>';
140   $specs = array();
141   $fields = array();
142   foreach ($mask['list'] as $field => $data) {
143     $ret[] = sprintf('  <th>%s</th>', $data['name']);
144     $s = array(sprintf("FieldName: 'input_%s'", $field),
145                sprintf("ColName: 'input_%s'", $data['name']));
146     $s = array();
147     if ($data['visible'] === false) $s[] = 'visible: false';
148     if ($data['width'] > 0) $s[] = 'width: ' . $data['width'];
149     if (array_key_exists('type', $data)) $s[] = "type: '" . $data['type'] . "'";
150     if (array_key_exists('specs', $data)) $s[] = $data['specs'];
151     if (array_key_exists('control', $data)) $s[] = 'control: ' . $data['control'];
152     $specs[] = '{' . implode(', ', $s) . '}';
153
154     if (array_key_exists('sql', $data))
155       $fields[] = $data['sql'] . ' AS ' . $field;
156     else
157       $fields[] = $field;
158   }
159
160   grid_sql($name, $mask);
161
162   $ret[] = '  </tr>';
163   $ret[] = '</table>';
164   $ret[] = '<div id="grid_info"></div>';
165
166   $opts[] = 'columnSpecs: [' . implode(', ', $specs) . ']';
167
168   if (strstr($opts[count($opts)-1], 'filterUI') !== false) $opts[] = 'FilterLocation: -1';
169
170   $jscode[] = 'var grid;';
171   $jscode[] = 'Rico.onLoad( function() {';
172   $jscode[] = sprintf("var %s_opts = {\n  %s\n};", $name, implode(",\n  ", $opts));
173   $jscode[] = sprintf("grid = new Rico.LiveGrid ('grid_%s', new Rico.Buffer.AjaxSQL('ajax/ricoXMLquery.php'), %s_opts);", $name, $name);
174   $jscode[] = "grid.menu = new Rico.GridMenu();";
175   $jscode[] = "grid.edit = new Rico.TableEdit(grid);";
176   $jscode[] = '});';
177   $jscode[] = "Rico.acceptLanguage('de-de,de;q=0.8,en;q=0.5,en-us;q=0.3');";
178   $jscode[] = "Rico.loadModule('Effect','Calendar','LiveGridForms','LiveGridAjax','LiveGridMenu');";
179
180   return $ret;
181 }
182
183 function build_details($name, $details)
184 {
185   $ret = array();
186
187   $ret[] = '<div class="box" id="details">';
188   $ret[] = sprintf('<h3>%s</h3>', $details['title']);
189   if (array_key_exists('subtitle', $details))
190     $ret[] = sprintf('<p class="subtitle">%s</p>', $details['subtitle']);
191   if (array_key_exists('html',$details)) {
192     $ret[] = $details['html'];
193   } elseif (array_key_exists('list',$details)) {
194     $ret[] = '<ul>';
195     foreach ($details['list'] as $name => $info) {
196       $ret[] = sprintf('<li>%s: <span id="detail_%s"></span></li>', $info['name'], $name);
197     }
198     $ret[] = '</ul>';
199   }
200   $ret[] = '</div>';
201
202   return $ret;
203 }
204
205 function build_select($name, $details)
206 {
207   $ret = array();
208
209   $ret[] = '<div class="form">';
210   $ret[] = sprintf('<p class="title">%s</p>', $details['title']);
211   $ret[] = sprintf ('<select%s>', array_key_exists('onchange',$details)?sprintf(' onchange="%s"',$details['onchange']):'');
212   if (is_array($details['options']))
213     $options = $details['options'];
214   else
215     $options = query_db($details['options']);
216
217   if (array_key_exists('default',$details))
218     $ret[] = sprintf('<option value="">%s</option>', $details['default']);
219
220   foreach ($options as $row) {
221     $selected = array_key_exists('selected',$details) && $details['selected'] == $row['id'] ? true : false;
222     $ret[] = sprintf('<option value="%s"%s>%s</option>', $row['id'], $selected?' selected':'',$row['text']);
223   }
224
225   $ret[] = '</select>';
226   $ret[] = '</div>';
227
228   return $ret;
229 }
230
231 function build_mask($name, $mask)
232 {
233   global $jscode;
234   $jscode[] = 'Rico.writeDebugMsg = function(msg, resetFlag) {};';
235
236   if (array_key_exists('list', $mask))
237     $grid = build_grid($name, $mask);
238   else
239     $grid = array();
240
241   $status = array('<span id="status"></span><br>');
242
243   if (array_key_exists('details', $mask))
244     $details = build_details($name, $mask['details']);
245   else
246     $details = array();
247
248   if (array_key_exists('select', $mask))
249     $select = build_select($name, $mask['select']);
250   else
251     $select = array();
252
253   if (array_key_exists('edit', $mask) && check_edit($name))
254     $edit = build_form($name, $mask);
255   else
256     $edit = array();
257
258   $title = $mask['title'];
259   if (array_key_exists('subtitle', $mask))
260     $title .= ' &ndash; ' . $mask['subtitle'];
261
262   $head = array();
263   $head[] = sprintf('<h3>%s</h3>', $title);
264
265   if (array_key_exists('html', $mask) &&
266       !array_key_exists('details', $mask) &&
267       !array_key_exists('select', $mask) &&
268       !array_key_exists('edit', $mask))
269     return array_merge($head, array($mask['html']),$status);
270
271   return array_merge($head,
272                      array('<div class="right">'),
273                      $grid,
274                      array('</div>','<div class="left">'),
275                      $details,
276                      $select,
277                      $edit,
278                      $status,
279                      array('</div>'));
280 }
281
282 function mask($name)
283 {
284   global $jsfiles;
285   global $mask;
286
287   $ret = array();
288
289   if (load_mask($name) === false)
290     return;
291
292   $jsfiles[] = 'lib/functions.js';
293   $jsfiles[] = 'lib/rico/rico.js';
294
295   if (array_key_exists('table',$mask))
296     $ret = build_mask($name, $mask);
297
298   return sprintf('<span id="source" style="display: none;">%s</span>', $_GET['mask'])
299     . implode("\n", $ret);
300 }
301
302 ?>