# return $ret;
# }
-function build_form($fields)
+function build_form($name, $fields)
{
+ global $jscode;
$ret = array();
+ $jscode[] = 'Rico.onLoad( function() {';
+ $jscode[] = "form_init();";
+ $jscode[] = '});';
+
$ret[] = '<div class="form">';
+ $ret[] = '<p class="title">Datensatz bearbeiten</p>';
$ret[] = '<form id="form_edit">';
$ret[] = '<input type="hidden" id="edit_id" name="id" value="">';
+ $ret[] = sprintf('<input type="hidden" id="edit_source" name="source" value="%s">', $name);
foreach ($fields as $id => $info) {
- if ($info['type'] == 'text') {
+ if ($info['type'] == 'text' || $info['type'] == 'passwd' ||
+ $info['type'] == 'decimal' || $info['type'] == 'number') {
$v = array('id="edit_'.$id.'"',
- 'name="'.$id.'"',
- 'size="'.$info['size'].'"',
- 'type="text"');
- $ret[] = sprintf('<label for="edit_%s"><b>%s</b></label><br>', $id, $info['name']);
- $ret[] = sprintf('<input %s><br>', implode(' ', $v));
-
+ 'name="'.$id.'"');
+ $v[] = 'size="'.(empty($info['size'])?'10':$info['size']).'"';
+ $v[] = 'type="'.($info['type']=='passwd'?'password':'text').'"';
+ $ret[] = sprintf('<label for="edit_%s">%s</label><br>', $id, $info['name']);
+ $ret[] = sprintf('<input %s>', implode(' ', $v));
} elseif ($info['type'] == 'date') {
- error_log('type = date');
+ $ret[] = sprintf('<label for="edit_%s">%s</label><br>', $id, $info['name']);
+ $ret[] = sprintf('<input id="edit_%s" name="%s" size="8"> '.
+ '<img class="calendar" src="images/icons/calendar.gif" onclick="calendar(\'edit_%s\',event)" />',
+ $id, $id, $id);
+ } elseif ($info['type'] == 'boolean') {
+ $ret[] = sprintf('<label for="edit_%s">%s</label><br>', $id, $info['name']);
+ $ret[] = sprintf('<input type="checkbox" id="edit_%s" name="%s">', $id, $id);
+ } elseif ($info['type'] == 'select') {
+ $ret[] = sprintf('<label for="edit_%s">%s</label><br>', $id, $info['name']);
+ $ret[] = sprintf('<select id="edit_%s" name="%s">', $id, $id);
+ if (is_array($info['options'])) $options = $info['options'];
+ else $options = query_db($info['options']);
+ foreach ($options as $row)
+ $ret[] = sprintf('<option value="%s">%s</option>', $row['id'], $row['text']);
+ $ret[] = '</select>';
}
+ if (array_key_exists('comment',$info))
+ $ret[] = sprintf('<span class="comment">%s</span>', $info['comment']);
+ $ret[] = '<br>';
}
- $ret[] = '<div align="center"><button onclick="return form_save(this);">Speichern</button></div>';
+ $ret[] = '<span id="form_status"> </span>';
+ $ret[] = '<div class="buttons">';
+ $ret[] = '<button id="button_save" onclick="return form_save(this);">Speichern</button>';
+ $ret[] = '<span></span>';
+ $ret[] = '<button id="button_insert" onclick="return form_insert(this);">Hinzufügen</button>';
+ $ret[] = '<span></span>';
+ $ret[] = '<button id="button_delete" onclick="return form_delete(this);">Löschen</button>';
+ $ret[] = '</div>';
$ret[] = '</form>';
$ret[] = '</div>';
if ($data['width'] > 0) $s[] = 'width: ' . $data['width'];
if (array_key_exists('type', $data)) $s[] = "type: '" . $data['type'] . "'";
if (array_key_exists('specs', $data)) $s[] = $data['specs'];
+ if (array_key_exists('control', $data)) $s[] = 'control: ' . $data['control'];
$specs[] = '{' . implode(', ', $s) . '}';
if (array_key_exists('sql', $data))
else
$fields[] = $field;
}
- $_SESSION['grid_' . $name] = sprintf("SELECT %s FROM %s",
- implode(',', $fields), $mask['table']);
- if (array_key_exists('join', $mask)) $_SESSION['grid_' . $name] .= ' JOIN ' . join(' JOIN ', $mask['join']);
- if (array_key_exists('where', $mask)) $_SESSION['grid_' . $name] .= ' WHERE ' . $mask['where'];
+
+ grid_sql($name, $mask);
$ret[] = ' </tr>';
$ret[] = '</table>';
{
$ret = array();
-
$ret[] = '<div class="box" id="details">';
$ret[] = sprintf('<h3>%s</h3>', $details['title']);
if (array_key_exists('subtitle', $details))
return $ret;
}
+function build_select($name, $details)
+{
+ $ret = array();
+
+ $ret[] = '<div class="form">';
+ $ret[] = sprintf('<p class="title">%s</p>', $details['title']);
+ $ret[] = sprintf ('<select%s>', array_key_exists('onchange',$details)?sprintf(' onchange="%s"',$details['onchange']):'');
+ if (is_array($details['options']))
+ $options = $details['options'];
+ else
+ $options = query_db($details['options']);
+
+ if (array_key_exists('default',$details))
+ $ret[] = sprintf('<option value="">%s</option>', $details['default']);
+
+ foreach ($options as $row) {
+ $selected = array_key_exists('selected',$details) && $details['selected'] == $row['id'] ? true : false;
+ $ret[] = sprintf('<option value="%s"%s>%s</option>', $row['id'], $selected?' selected':'',$row['text']);
+ }
+
+ $ret[] = '</select>';
+ $ret[] = '</div>';
+
+ return $ret;
+}
+
function build_mask($name, $mask)
{
$grid = build_grid($name, $mask);
+ $status = array('<span id="status"></span><br>');
if (array_key_exists('details', $mask))
$details = build_details($name, $mask['details']);
else
$details = array();
+ if (array_key_exists('select', $mask))
+ $select = build_select($name, $mask['select']);
+ else
+ $select = array();
+
+ if (array_key_exists('edit', $mask))
+ $edit = build_form($name, $mask['edit']);
+ else
+ $edit = array();
+
$title = $mask['title'];
if (array_key_exists('subtitle', $mask))
$title .= ' – ' . $mask['subtitle'];
$grid,
array('</div>','<div class="left">'),
$details,
+ $select,
+ $edit,
+ $status,
array('</div>'));
}
if (array_key_exists('table',$mask) && array_key_exists('list',$mask))
$ret = build_mask($name, $mask);
- if (array_key_exists('edit', $mask))
- $ret = array_merge($ret, build_form($mask['edit']));
-
+ error_log(count($ret));
return implode("\n", $ret);
}