3 # function mask_fields($list)
7 # foreach ($list as $field => $data)
13 function build_form($name, $mask)
18 $jscode[] = 'Rico.onLoad( function() {';
19 $jscode[] = "form_init();";
22 $ret[] = '<div class="form">';
23 if (empty($mask['edit_title']))
24 $ret[] = '<p class="title">Datensatz bearbeiten</p>';
26 $ret[] = sprintf('<p class="title">%s</p>', $mask['edit_title']);
27 $ret[] = '<form id="form_edit">';
29 $ret[] = '<input type="hidden" id="edit_id" name="id" value="">';
30 $ret[] = sprintf('<input type="hidden" id="edit_source" name="source" value="%s">', $name);
32 foreach ($mask['edit'] as $id => $info) {
33 if ($info['type'] == 'text' || $info['type'] == 'passwd' ||
34 $info['type'] == 'decimal' || $info['type'] == 'number') {
35 $v = array('id="edit_'.$id.'"',
37 $v[] = 'size="'.(empty($info['size'])?'10':$info['size']).'"';
38 $v[] = 'type="'.($info['type']=='passwd'?'password':'text').'"';
39 $ret[] = sprintf('<label for="edit_%s">%s</label><br>', $id, $info['name']);
40 $ret[] = sprintf('<input %s>', implode(' ', $v));
41 } elseif ($info['type'] == 'date') {
42 $ret[] = sprintf('<label for="edit_%s">%s</label><br>', $id, $info['name']);
43 $ret[] = sprintf('<input id="edit_%s" name="%s" size="8"> '.
44 '<img class="calendar" src="images/icons/calendar.gif" onclick="calendar(\'edit_%s\',event)" />',
46 } elseif ($info['type'] == 'boolean') {
47 $ret[] = sprintf('<label for="edit_%s">%s</label><br>', $id, $info['name']);
48 $ret[] = sprintf('<input type="checkbox" id="edit_%s" name="%s">', $id, $id);
49 } elseif ($info['type'] == 'select') {
50 $ret[] = sprintf('<label for="edit_%s">%s</label><br>', $id, $info['name']);
51 $ret[] = sprintf('<select id="edit_%s" name="%s">', $id, $id);
52 if (is_array($info['options'])) $options = $info['options'];
53 else $options = query_db($info['options']);
54 foreach ($options as $row)
55 $ret[] = sprintf('<option value="%s">%s</option>', $row['id'], $row['text']);
58 if (array_key_exists('comment',$info))
59 $ret[] = sprintf('<span class="comment">%s</span>', $info['comment']);
63 $ret[] = '<span id="form_status"> </span>';
64 $ret[] = '<div class="buttons">';
65 $ret[] = '<button id="button_save" onclick="return form_save(this);">Speichern</button>';
66 $ret[] = '<span></span>';
67 $ret[] = '<button id="button_insert" onclick="return form_insert(this);">Hinzufügen</button>';
68 $ret[] = '<span></span>';
69 $ret[] = '<button id="button_delete" onclick="return form_delete(this);">Löschen</button>';
78 function build_grid($name, $mask)
83 $jscode[] = 'Rico.writeDebugMsg = function(msg, resetFlag) {};';
85 $opts = array("click: gridDrillDown",
86 "menuEvent: 'contextmenu'",
87 "highlightElem: 'menuRow'");
89 if (array_key_exists('rows', $mask)) $opts[] = 'visibleRows: ' . $mask['rows'];
90 if (array_key_exists('sort', $mask)) $opts[] = 'sortCol: ' . $mask['sort'];
91 if ($mask['prefetch'] === false) $opts[] = 'prefetch: false';
92 # $opts[] = 'frozenColumns: ' . count($mask['list']);
93 $opts[] = 'saveColumnInfo: {width: true, filter: true, sort: true}';
95 $ret[] = sprintf('<table id="grid_%s" class="ricoLiveGrid">', $name);
99 foreach ($mask['list'] as $field => $data) {
100 $ret[] = sprintf(' <th>%s</th>', $data['name']);
101 $s = array(sprintf("FieldName: 'input_%s'", $field),
102 sprintf("ColName: 'input_%s'", $data['name']));
104 if ($data['visible'] === false) $s[] = 'visible: false';
105 if ($data['width'] > 0) $s[] = 'width: ' . $data['width'];
106 if (array_key_exists('type', $data)) $s[] = "type: '" . $data['type'] . "'";
107 if (array_key_exists('specs', $data)) $s[] = $data['specs'];
108 if (array_key_exists('control', $data)) $s[] = 'control: ' . $data['control'];
109 $specs[] = '{' . implode(', ', $s) . '}';
111 if (array_key_exists('sql', $data))
112 $fields[] = $data['sql'] . ' AS ' . $field;
117 grid_sql($name, $mask);
122 $opts[] = 'columnSpecs: [' . implode(', ', $specs) . ']';
124 if (strstr($opts[count($opts)-1], 'filterUI') !== false) $opts[] = 'FilterLocation: -1';
126 $jscode[] = 'var grid;';
127 $jscode[] = 'Rico.onLoad( function() {';
128 $jscode[] = sprintf("var %s_opts = {\n %s\n};", $name, implode(",\n ", $opts));
129 $jscode[] = sprintf("grid = new Rico.LiveGrid ('grid_%s', new Rico.Buffer.AjaxSQL('ajax/ricoXMLquery.php'), %s_opts);", $name, $name);
130 $jscode[] = "grid.menu = new Rico.GridMenu();";
131 $jscode[] = "grid.edit = new Rico.TableEdit(grid);";
133 $jscode[] = "Rico.acceptLanguage('de-de,de;q=0.8,en;q=0.5,en-us;q=0.3');";
134 $jscode[] = "Rico.loadModule('Effect','Calendar','LiveGridForms','LiveGridAjax','LiveGridMenu');";
139 function build_details($name, $details)
143 $ret[] = '<div class="box" id="details">';
144 $ret[] = sprintf('<h3>%s</h3>', $details['title']);
145 if (array_key_exists('subtitle', $details))
146 $ret[] = sprintf('<p class="subtitle">%s</p>', $details['subtitle']);
148 foreach ($details['list'] as $name => $info) {
149 $ret[] = sprintf('<li>%s: <span id="detail_%s"></span></li>', $info['name'], $name);
157 function build_select($name, $details)
161 $ret[] = '<div class="form">';
162 $ret[] = sprintf('<p class="title">%s</p>', $details['title']);
163 $ret[] = sprintf ('<select%s>', array_key_exists('onchange',$details)?sprintf(' onchange="%s"',$details['onchange']):'');
164 if (is_array($details['options']))
165 $options = $details['options'];
167 $options = query_db($details['options']);
169 if (array_key_exists('default',$details))
170 $ret[] = sprintf('<option value="">%s</option>', $details['default']);
172 foreach ($options as $row) {
173 $selected = array_key_exists('selected',$details) && $details['selected'] == $row['id'] ? true : false;
174 $ret[] = sprintf('<option value="%s"%s>%s</option>', $row['id'], $selected?' selected':'',$row['text']);
177 $ret[] = '</select>';
183 function build_mask($name, $mask)
185 $grid = build_grid($name, $mask);
186 $status = array('<span id="status"></span><br>');
188 if (array_key_exists('details', $mask))
189 $details = build_details($name, $mask['details']);
193 if (array_key_exists('select', $mask))
194 $select = build_select($name, $mask['select']);
198 if (array_key_exists('edit', $mask))
199 $edit = build_form($name, $mask);
203 $title = $mask['title'];
204 if (array_key_exists('subtitle', $mask))
205 $title .= ' – ' . $mask['subtitle'];
208 $head[] = sprintf('<h3>%s</h3>', $title);
209 $head[] = '<div class="right">';
211 return array_merge($head,
213 array('</div>','<div class="left">'),
228 if (load_mask($name) === false)
231 $jsfiles[] = 'lib/functions.js';
232 $jsfiles[] = 'lib/rico/rico.js';
234 if (array_key_exists('table',$mask) && array_key_exists('list',$mask))
235 $ret = build_mask($name, $mask);
237 return sprintf('<span id="source" style="display: none;">%s</span>', $_GET['mask'])
238 . implode("\n", $ret);