X-Git-Url: https://git.infodrom.org/?p=misc%2Fkostenrechnung;a=blobdiff_plain;f=lib%2Fmask.php;h=074889aa386852df6547c3b0cfb0317d0e8bbef7;hp=139cf7fbc1beb2875f485ec9f259ec0691eddc93;hb=b5672ad38ca113fcb1ad7c5d15f4c2b8ead4c883;hpb=ac90efb29524322c95d976a4b89e47349a15e22b
diff --git a/lib/mask.php b/lib/mask.php
index 139cf7f..074889a 100644
--- a/lib/mask.php
+++ b/lib/mask.php
@@ -10,30 +10,47 @@
# return $ret;
# }
-function build_form($fields)
+function build_form($name, $fields)
{
$ret = array();
- $ret[] = '
';
+ $ret[] = '
';
@@ -81,6 +98,7 @@ function build_grid($name, $mask)
$_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'];
$ret[] = ' ';
$ret[] = '';
@@ -102,16 +120,51 @@ function build_grid($name, $mask)
return $ret;
}
-function build_mask($name, $mask)
+function build_details($name, $details)
{
- $ret = build_grid($name, $mask);
+ $ret = array();
- if (array_key_exists('edit', $mask))
- $ret = array_merge($ret, build_form($mask['edit']));
+
+ $ret[] = '
';
+ $ret[] = sprintf('
%s
', $details['title']);
+ if (array_key_exists('subtitle', $details))
+ $ret[] = sprintf('
%s
', $details['subtitle']);
+ $ret[] = '
';
+ foreach ($details['list'] as $name => $info) {
+ $ret[] = sprintf('- %s:
', $info['name'], $name);
+ }
+ $ret[] = '
';
+ $ret[] = '
';
return $ret;
}
+function build_mask($name, $mask)
+{
+ $grid = build_grid($name, $mask);
+ $status = array('
');
+
+ if (array_key_exists('details', $mask))
+ $details = build_details($name, $mask['details']);
+ else
+ $details = array();
+
+ $title = $mask['title'];
+ if (array_key_exists('subtitle', $mask))
+ $title .= ' – ' . $mask['subtitle'];
+
+ $head = array();
+ $head[] = sprintf('
%s
', $title);
+ $head[] = '
';
+
+ return array_merge($head,
+ $grid,
+ array('
','
'),
+ $status,
+ $details,
+ array('
'));
+}
+
function mask($name)
{
global $jsfiles;
@@ -125,9 +178,11 @@ function mask($name)
$jsfiles[] = 'lib/functions.js';
$jsfiles[] = 'lib/rico/rico.js';
- if (array_key_exists('table',$mask) && array_key_exists('list',$mask)) {
+ 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($name, $mask['edit']));
return implode("\n", $ret);
}