Add select box and framework in left part for general selection
[misc/kostenrechnung] / lib / mask.php
index 3b9c3fa..0325e7a 100644 (file)
@@ -129,7 +129,6 @@ function build_details($name, $details)
 {
   $ret = array();
 
-
   $ret[] = '<div class="box" id="details">';
   $ret[] = sprintf('<h3>%s</h3>', $details['title']);
   if (array_key_exists('subtitle', $details))
@@ -144,6 +143,32 @@ function build_details($name, $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);
@@ -154,6 +179,11 @@ function build_mask($name, $mask)
   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
@@ -171,6 +201,7 @@ function build_mask($name, $mask)
                     $grid,
                     array('</div>','<div class="left">'),
                     $details,
+                    $select,
                     $edit,
                     $status,
                     array('</div>'));