Add framework for setting variables from frontend stored in the session
[misc/kostenrechnung] / lib / mask.php
index b60a650..03e772d 100644 (file)
 
 function build_form($name, $fields)
 {
+  global $jscode;
   $ret = array();
 
-  $ret[] = '<div class="form" style="clear: both;">';
+  $jscode[] = 'Rico.onLoad( function() {';
+  $jscode[] = "form_init();";
+  $jscode[] = '});';
+
+  $ret[] = '<div class="form">';
+  $ret[] = '<p id="form_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' || $info['type'] == 'number') {
+    if ($info['type'] == 'text' || $info['type'] == 'passwd' || $info['type'] == 'number') {
       $v = array('id="edit_'.$id.'"',
-                'name="'.$id.'"',
-                'size="'.$info['size'].'"',
-                'type="text"');
+                '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><br>', implode(' ', $v));
     } elseif ($info['type'] == 'boolean') {
@@ -44,7 +50,14 @@ function build_form($name, $fields)
     }
   }
 
-  $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>';
@@ -136,12 +149,18 @@ function build_details($name, $details)
 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('edit', $mask))
+    $edit = build_form($name, $mask['edit']);
+  else
+    $edit = array();
+
   $title = $mask['title'];
   if (array_key_exists('subtitle', $mask))
     $title .= ' &ndash; ' . $mask['subtitle'];
@@ -154,6 +173,8 @@ function build_mask($name, $mask)
                     $grid,
                     array('</div>','<div class="left">'),
                     $details,
+                    $edit,
+                    $status,
                     array('</div>'));
 }
 
@@ -173,9 +194,7 @@ function mask($name)
   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']));
-
+  error_log(count($ret));
   return implode("\n", $ret);
 }