Build detail box
[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($fields)
14 {
15   $ret = array();
16
17   $ret[] = '<div class="form">';
18   $ret[] = '<form id="form_edit">';
19
20   $ret[] = '<input type="hidden" id="edit_id" name="id" value="">';
21
22   foreach ($fields as $id => $info) {
23     if ($info['type'] == 'text') {
24       $v = array('id="edit_'.$id.'"',
25                  'name="'.$id.'"',
26                  'size="'.$info['size'].'"',
27                  'type="text"');
28       $ret[] = sprintf('<label for="edit_%s"><b>%s</b></label><br>', $id, $info['name']);
29       $ret[] = sprintf('<input %s><br>', implode(' ', $v));
30
31     } elseif ($info['type'] == 'date') {
32       error_log('type = date');
33     }
34   }
35
36   $ret[] = '<div align="center"><button onclick="return form_save(this);">Speichern</button></div>';
37
38   $ret[] = '</form>';
39   $ret[] = '</div>';
40
41   return $ret;
42 }
43
44 function build_grid($name, $mask)
45 {
46   global $jscode;
47   $ret = array();
48
49   $jscode[] = 'Rico.writeDebugMsg = function(msg, resetFlag) {};';
50
51   $opts = array("click: gridDrillDown",
52                 "menuEvent: 'contextmenu'",
53                 "highlightElem: 'menuRow'");
54
55   if (array_key_exists('rows', $mask)) $opts[] = 'visibleRows: ' . $mask['rows'];
56   if (array_key_exists('sort', $mask)) $opts[] = 'sortCol: ' . $mask['sort'];
57   if ($mask['prefetch'] === false) $opts[] = 'prefetch: false';
58   # $opts[] = 'frozenColumns: ' . count($mask['list']);
59   $opts[] = 'saveColumnInfo: {width: true, filter: true, sort: true}';
60
61   $ret[] = sprintf('<table id="grid_%s" class="ricoLiveGrid">', $name);
62   $ret[] = '  <tr>';
63   $specs = array();
64   $fields = array();
65   foreach ($mask['list'] as $field => $data) {
66     $ret[] = sprintf('  <th>%s</th>', $data['name']);
67     $s = array(sprintf("FieldName: 'input_%s'", $field),
68                sprintf("ColName: 'input_%s'", $data['name']));
69     $s = array();
70     if ($data['visible'] === false) $s[] = 'visible: false';
71     if ($data['width'] > 0) $s[] = 'width: ' . $data['width'];
72     if (array_key_exists('type', $data)) $s[] = "type: '" . $data['type'] . "'";
73     if (array_key_exists('specs', $data)) $s[] = $data['specs'];
74     $specs[] = '{' . implode(', ', $s) . '}';
75
76     if (array_key_exists('sql', $data))
77       $fields[] = $data['sql'] . ' AS ' . $field;
78     else
79       $fields[] = $field;
80   }
81   $_SESSION['grid_' . $name] = sprintf("SELECT %s FROM %s",
82                                        implode(',', $fields), $mask['table']);
83   if (array_key_exists('join', $mask)) $_SESSION['grid_' . $name] .= ' JOIN ' . join(' JOIN ', $mask['join']);
84
85   $ret[] = '  </tr>';
86   $ret[] = '</table>';
87
88   $opts[] = 'columnSpecs: [' . implode(', ', $specs) . ']';
89
90   if (strstr($opts[count($opts)-1], 'filterUI') !== false) $opts[] = 'FilterLocation: -1';
91
92   $jscode[] = 'var grid;';
93   $jscode[] = 'Rico.onLoad( function() {';
94   $jscode[] = sprintf("var %s_opts = {\n  %s\n};", $name, implode(",\n  ", $opts));
95   $jscode[] = sprintf("grid = new Rico.LiveGrid ('grid_%s', new Rico.Buffer.AjaxSQL('ajax/ricoXMLquery.php'), %s_opts);", $name, $name);
96   $jscode[] = "grid.menu = new Rico.GridMenu();";
97   $jscode[] = "grid.edit = new Rico.TableEdit(grid);";
98   $jscode[] = '});';
99   $jscode[] = "Rico.acceptLanguage('de-de,de;q=0.8,en;q=0.5,en-us;q=0.3');";
100   $jscode[] = "Rico.loadModule('Effect','Calendar','LiveGridForms','LiveGridAjax','LiveGridMenu');";
101
102   return $ret;
103 }
104
105 function build_details($name, $details)
106 {
107   $ret = array();
108
109
110   $ret[] = '<div class="box">';
111   $ret[] = sprintf('<h2>%s</h2>', $details['title']);
112   if (array_key_exists('subtitle', $details))
113     $ret[] = sprintf('<p class="subtitle">%s</p>', $details['subtitle']);
114   $ret[] = '<ul>';
115   foreach ($details['list'] as $name => $info) {
116     $ret[] = sprintf('<li>%s: <span id="detail_%s"></span></li>', $info['name'], $name);
117   }
118   $ret[] = '</ul>';
119   $ret[] = '</div>';
120
121   return $ret;
122 }
123
124 function build_mask($name, $mask)
125 {
126   $grid = build_grid($name, $mask);
127
128   if (array_key_exists('details', $mask))
129     $details = build_details($name, $mask['details']);
130   else
131     $details = array();
132
133   return array_merge(
134                      array('<div class="right">'),
135                      $grid,
136                      array('</div>','<div class="left">'),
137                      $details,
138                      array('</div>'));
139 }
140
141 function mask($name)
142 {
143   global $jsfiles;
144   global $mask;
145
146   $ret = array();
147
148   if (load_mask($name) === false)
149     return;
150
151   $jsfiles[] = 'lib/functions.js';
152   $jsfiles[] = 'lib/rico/rico.js';
153
154   if (array_key_exists('table',$mask) && array_key_exists('list',$mask))
155     $ret = build_mask($name, $mask);
156
157   if (array_key_exists('edit', $mask))
158     $ret = array_merge($ret, build_form($mask['edit']));
159
160   return implode("\n", $ret);
161 }
162
163 ?>