3 function check_edit($name)
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));
11 $sth = pg_query($sql);
13 if ($sth === false) return false;
15 $row = pg_fetch_assoc($sth);
16 if ($row === false) return false;
18 if ($row['edit'] == '0')
24 function build_form($name, $mask)
29 $jscode[] = 'Rico.onLoad( function() {';
30 $jscode[] = "form_init();";
33 $ret[] = '<div class="form">';
34 if (empty($mask['edit_title']))
35 $ret[] = '<p class="title">Datensatz bearbeiten</p>';
37 $ret[] = sprintf('<p class="title">%s</p>', $mask['edit_title']);
38 $ret[] = '<form id="form_edit">';
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);
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.'"',
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"> '.
57 '<img class="calendar" src="images/icons/calendar.gif" onclick="calendar(\'edit_%s\',event)" />',
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.'"',
65 if (array_key_exists('onchange',$info))
66 $v[] = sprintf('onchange="%s"', $info['onchange']);
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>',
78 !empty($info['selected']) && $row['id'] == $info['selected'] ? ' selected' : '',
81 } elseif ($info['type'] == 'textarea') {
82 $ret[] = sprintf('<label for="edit_%s">%s</label><br>', $id, $info['name']);
83 $v = array('id="edit_'.$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));
89 if (array_key_exists('comment',$info))
90 $ret[] = sprintf('<span class="comment">%s</span>', $info['comment']);
91 if ($info['type'] != 'hidden')
95 $v_save = array('id="button_save"',
96 'onclick="return form_save(this);"');
97 if ($mask['buttons']['save'] === false) $v_save[] = 'style="display: none"';
99 $v_insert = array('id="button_insert"',
100 'onclick="return form_insert(this);"');
101 if ($mask['buttons']['insert'] === false) $v_insert[] = 'style="display: none"';
103 $v_delete = array('id="button_delete"',
104 'onclick="return form_delete(this);"');
105 if ($mask['buttons']['delete'] === false) $v_delete[] = 'style="display: none"';
107 $ret[] = '<span id="form_status"> </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');
122 function build_grid($name, $mask)
127 $opts = array("click: gridDrillDown",
128 "menuEvent: 'contextmenu'",
129 "highlightElem: 'menuRow'");
131 if (array_key_exists('rows', $mask)) $opts[] = 'visibleRows: ' . $mask['rows'];
132 if (array_key_exists('sort', $mask)) $opts[] = 'sortCol: ' . $mask['sort'];
133 if ($mask['prefetch'] === false) $opts[] = 'prefetch: false';
134 # $opts[] = 'frozenColumns: ' . count($mask['list']);
135 $opts[] = 'saveColumnInfo: {width: true, filter: true, sort: true}';
137 $ret[] = sprintf('<table id="grid_%s" class="ricoLiveGrid">', $name);
141 foreach ($mask['list'] as $field => $data) {
142 $ret[] = sprintf(' <th>%s</th>', $data['name']);
143 $s = array(sprintf("FieldName: 'input_%s'", $field),
144 sprintf("ColName: 'input_%s'", $data['name']));
146 if ($data['visible'] === false) $s[] = 'visible: false';
147 if ($data['width'] > 0) $s[] = 'width: ' . $data['width'];
148 if (array_key_exists('type', $data)) $s[] = "type: '" . $data['type'] . "'";
149 if (array_key_exists('specs', $data)) $s[] = $data['specs'];
150 if (array_key_exists('control', $data)) $s[] = 'control: ' . $data['control'];
151 $specs[] = '{' . implode(', ', $s) . '}';
153 if (array_key_exists('sql', $data))
154 $fields[] = $data['sql'] . ' AS ' . $field;
159 grid_sql($name, $mask);
164 $opts[] = 'columnSpecs: [' . implode(', ', $specs) . ']';
166 if (strstr($opts[count($opts)-1], 'filterUI') !== false) $opts[] = 'FilterLocation: -1';
168 $jscode[] = 'var grid;';
169 $jscode[] = 'Rico.onLoad( function() {';
170 $jscode[] = sprintf("var %s_opts = {\n %s\n};", $name, implode(",\n ", $opts));
171 $jscode[] = sprintf("grid = new Rico.LiveGrid ('grid_%s', new Rico.Buffer.AjaxSQL('ajax/ricoXMLquery.php'), %s_opts);", $name, $name);
172 $jscode[] = "grid.menu = new Rico.GridMenu();";
173 $jscode[] = "grid.edit = new Rico.TableEdit(grid);";
175 $jscode[] = "Rico.acceptLanguage('de-de,de;q=0.8,en;q=0.5,en-us;q=0.3');";
176 $jscode[] = "Rico.loadModule('Effect','Calendar','LiveGridForms','LiveGridAjax','LiveGridMenu');";
181 function build_details($name, $details)
185 $ret[] = '<div class="box" id="details">';
186 $ret[] = sprintf('<h3>%s</h3>', $details['title']);
187 if (array_key_exists('subtitle', $details))
188 $ret[] = sprintf('<p class="subtitle">%s</p>', $details['subtitle']);
189 if (array_key_exists('html',$details)) {
190 $ret[] = $details['html'];
191 } elseif (array_key_exists('list',$details)) {
193 foreach ($details['list'] as $name => $info) {
194 $ret[] = sprintf('<li>%s: <span id="detail_%s"></span></li>', $info['name'], $name);
203 function build_select($name, $details)
207 $ret[] = '<div class="form">';
208 $ret[] = sprintf('<p class="title">%s</p>', $details['title']);
209 $ret[] = sprintf ('<select%s>', array_key_exists('onchange',$details)?sprintf(' onchange="%s"',$details['onchange']):'');
210 if (is_array($details['options']))
211 $options = $details['options'];
213 $options = query_db($details['options']);
215 if (array_key_exists('default',$details))
216 $ret[] = sprintf('<option value="">%s</option>', $details['default']);
218 foreach ($options as $row) {
219 $selected = array_key_exists('selected',$details) && $details['selected'] == $row['id'] ? true : false;
220 $ret[] = sprintf('<option value="%s"%s>%s</option>', $row['id'], $selected?' selected':'',$row['text']);
223 $ret[] = '</select>';
229 function build_mask($name, $mask)
232 $jscode[] = 'Rico.writeDebugMsg = function(msg, resetFlag) {};';
234 if (array_key_exists('list', $mask))
235 $grid = build_grid($name, $mask);
239 $status = array('<span id="status"></span><br>');
241 if (array_key_exists('details', $mask))
242 $details = build_details($name, $mask['details']);
246 if (array_key_exists('select', $mask))
247 $select = build_select($name, $mask['select']);
251 if (array_key_exists('edit', $mask) && check_edit($name))
252 $edit = build_form($name, $mask);
256 $title = $mask['title'];
257 if (array_key_exists('subtitle', $mask))
258 $title .= ' – ' . $mask['subtitle'];
261 $head[] = sprintf('<h3>%s</h3>', $title);
263 if (array_key_exists('html', $mask) &&
264 !array_key_exists('details', $mask) &&
265 !array_key_exists('select', $mask) &&
266 !array_key_exists('edit', $mask))
267 return array_merge($head, array($mask['html']),$status);
269 return array_merge($head,
270 array('<div class="right">'),
272 array('</div>','<div class="left">'),
287 if (load_mask($name) === false)
290 $jsfiles[] = 'lib/functions.js';
291 $jsfiles[] = 'lib/rico/rico.js';
293 if (array_key_exists('table',$mask))
294 $ret = build_mask($name, $mask);
296 return sprintf('<span id="source" style="display: none;">%s</span>', $_GET['mask'])
297 . implode("\n", $ret);