Support for database oriented checkboxes as control in LiveGrid tables
[misc/kostenrechnung] / lib / mask.php
1 <?php
2
3 # function mask_fields($list)
4 # {
5 #   $ret = array();
6
7 #   foreach ($list as $field => $data)
8 #     $ret[] = $field;
9
10 #   return $ret;
11 # }
12
13 function build_form($name, $fields)
14 {
15   global $jscode;
16   $ret = array();
17
18   $jscode[] = 'Rico.onLoad( function() {';
19   $jscode[] = "form_init();";
20   $jscode[] = '});';
21
22   $ret[] = '<div class="form">';
23   $ret[] = '<p class="title">Datensatz bearbeiten</p>';
24   $ret[] = '<form id="form_edit">';
25
26   $ret[] = '<input type="hidden" id="edit_id" name="id" value="">';
27   $ret[] = sprintf('<input type="hidden" id="edit_source" name="source" value="%s">', $name);
28
29   foreach ($fields as $id => $info) {
30     if ($info['type'] == 'text' || $info['type'] == 'passwd' || $info['type'] == 'number') {
31       $v = array('id="edit_'.$id.'"',
32                  'name="'.$id.'"');
33       $v[] = 'size="'.(empty($info['size'])?'10':$info['size']).'"';
34       $v[] = 'type="'.($info['type']=='passwd'?'password':'text').'"';
35       $ret[] = sprintf('<label for="edit_%s">%s</label><br>', $id, $info['name']);
36       $ret[] = sprintf('<input %s><br>', implode(' ', $v));
37     } elseif ($info['type'] == 'boolean') {
38       $ret[] = sprintf('<label for="edit_%s">%s</label><br>', $id, $info['name']);
39       $ret[] = sprintf('<input type="checkbox" id="edit_%s" name="%s"><br>', $id, $id);
40     } elseif ($info['type'] == 'select') {
41       $ret[] = sprintf('<label for="edit_%s">%s</label><br>', $id, $info['name']);
42       $ret[] = sprintf('<select id="edit_%s" name="%s">', $id, $id);
43       if (is_array($info['options'])) $options = $info['options'];
44       else $options = query_db($info['options']);
45       foreach ($options as $row)
46         $ret[] = sprintf('<option value="%s">%s</option>', $row['id'], $row['text']);
47       $ret[] = '</select><br>';
48     } elseif ($info['type'] == 'date') {
49       error_log('type = date');
50     }
51   }
52
53   $ret[] = '<span id="form_status"></span>';
54   $ret[] = '<div class="buttons">';
55   $ret[] = '<button id="button_save" onclick="return form_save(this);">Speichern</button>';
56   $ret[] = '<span></span>';
57   $ret[] = '<button id="button_insert" onclick="return form_insert(this);">Hinzufügen</button>';
58   $ret[] = '<span></span>';
59   $ret[] = '<button id="button_delete" onclick="return form_delete(this);">Löschen</button>';
60   $ret[] = '</div>';
61
62   $ret[] = '</form>';
63   $ret[] = '</div>';
64
65   return $ret;
66 }
67
68 function build_grid($name, $mask)
69 {
70   global $jscode;
71   $ret = array();
72
73   $jscode[] = 'Rico.writeDebugMsg = function(msg, resetFlag) {};';
74
75   $opts = array("click: gridDrillDown",
76                 "menuEvent: 'contextmenu'",
77                 "highlightElem: 'menuRow'");
78
79   if (array_key_exists('rows', $mask)) $opts[] = 'visibleRows: ' . $mask['rows'];
80   if (array_key_exists('sort', $mask)) $opts[] = 'sortCol: ' . $mask['sort'];
81   if ($mask['prefetch'] === false) $opts[] = 'prefetch: false';
82   # $opts[] = 'frozenColumns: ' . count($mask['list']);
83   $opts[] = 'saveColumnInfo: {width: true, filter: true, sort: true}';
84
85   $ret[] = sprintf('<table id="grid_%s" class="ricoLiveGrid">', $name);
86   $ret[] = '  <tr>';
87   $specs = array();
88   $fields = array();
89   foreach ($mask['list'] as $field => $data) {
90     $ret[] = sprintf('  <th>%s</th>', $data['name']);
91     $s = array(sprintf("FieldName: 'input_%s'", $field),
92                sprintf("ColName: 'input_%s'", $data['name']));
93     $s = array();
94     if ($data['visible'] === false) $s[] = 'visible: false';
95     if ($data['width'] > 0) $s[] = 'width: ' . $data['width'];
96     if (array_key_exists('type', $data)) $s[] = "type: '" . $data['type'] . "'";
97     if (array_key_exists('specs', $data)) $s[] = $data['specs'];
98     $specs[] = '{' . implode(', ', $s) . '}';
99
100     if (array_key_exists('sql', $data))
101       $fields[] = $data['sql'] . ' AS ' . $field;
102     else
103       $fields[] = $field;
104   }
105
106   grid_sql($name, $mask);
107
108   $ret[] = '  </tr>';
109   $ret[] = '</table>';
110
111   $opts[] = 'columnSpecs: [' . implode(', ', $specs) . ']';
112
113   if (strstr($opts[count($opts)-1], 'filterUI') !== false) $opts[] = 'FilterLocation: -1';
114
115   $jscode[] = 'var grid;';
116   $jscode[] = 'Rico.onLoad( function() {';
117   $jscode[] = sprintf("var %s_opts = {\n  %s\n};", $name, implode(",\n  ", $opts));
118   $jscode[] = sprintf("grid = new Rico.LiveGrid ('grid_%s', new Rico.Buffer.AjaxSQL('ajax/ricoXMLquery.php'), %s_opts);", $name, $name);
119   $jscode[] = "grid.menu = new Rico.GridMenu();";
120   $jscode[] = "grid.edit = new Rico.TableEdit(grid);";
121   $jscode[] = '});';
122   $jscode[] = "Rico.acceptLanguage('de-de,de;q=0.8,en;q=0.5,en-us;q=0.3');";
123   $jscode[] = "Rico.loadModule('Effect','Calendar','LiveGridForms','LiveGridAjax','LiveGridMenu');";
124
125   return $ret;
126 }
127
128 function build_details($name, $details)
129 {
130   $ret = array();
131
132   $ret[] = '<div class="box" id="details">';
133   $ret[] = sprintf('<h3>%s</h3>', $details['title']);
134   if (array_key_exists('subtitle', $details))
135     $ret[] = sprintf('<p class="subtitle">%s</p>', $details['subtitle']);
136   $ret[] = '<ul>';
137   foreach ($details['list'] as $name => $info) {
138     $ret[] = sprintf('<li>%s: <span id="detail_%s"></span></li>', $info['name'], $name);
139   }
140   $ret[] = '</ul>';
141   $ret[] = '</div>';
142
143   return $ret;
144 }
145
146 function build_select($name, $details)
147 {
148   $ret = array();
149
150   $ret[] = '<div class="form">';
151   $ret[] = sprintf('<p class="title">%s</p>', $details['title']);
152   $ret[] = sprintf ('<select%s>', array_key_exists('onchange',$details)?sprintf(' onchange="%s"',$details['onchange']):'');
153   if (is_array($details['options']))
154     $options = $details['options'];
155   else
156     $options = query_db($details['options']);
157
158   if (array_key_exists('default',$details))
159     $ret[] = sprintf('<option value="">%s</option>', $details['default']);
160
161   foreach ($options as $row) {
162     $selected = array_key_exists('selected',$details) && $details['selected'] == $row['id'] ? true : false;
163     $ret[] = sprintf('<option value="%s"%s>%s</option>', $row['id'], $selected?' selected':'',$row['text']);
164   }
165
166   $ret[] = '</select>';
167   $ret[] = '</div>';
168
169   return $ret;
170 }
171
172 function build_mask($name, $mask)
173 {
174   $grid = build_grid($name, $mask);
175   $status = array('<span id="status"></span><br>');
176
177   if (array_key_exists('details', $mask))
178     $details = build_details($name, $mask['details']);
179   else
180     $details = array();
181
182   if (array_key_exists('select', $mask))
183     $select = build_select($name, $mask['select']);
184   else
185     $select = array();
186
187   if (array_key_exists('edit', $mask))
188     $edit = build_form($name, $mask['edit']);
189   else
190     $edit = array();
191
192   $title = $mask['title'];
193   if (array_key_exists('subtitle', $mask))
194     $title .= ' &ndash; ' . $mask['subtitle'];
195
196   $head = array();
197   $head[] = sprintf('<h3>%s</h3>', $title);
198   $head[] = '<div class="right">';
199
200   return array_merge($head,
201                      $grid,
202                      array('</div>','<div class="left">'),
203                      $details,
204                      $select,
205                      $edit,
206                      $status,
207                      array('</div>'));
208 }
209
210 function mask($name)
211 {
212   global $jsfiles;
213   global $mask;
214
215   $ret = array();
216
217   if (load_mask($name) === false)
218     return;
219
220   $jsfiles[] = 'lib/functions.js';
221   $jsfiles[] = 'lib/rico/rico.js';
222
223   if (array_key_exists('table',$mask) && array_key_exists('list',$mask))
224     $ret = build_mask($name, $mask);
225
226   error_log(count($ret));
227   return implode("\n", $ret);
228 }
229
230 ?>