Add support for password fields
[misc/kostenrechnung] / lib / mask.php
index f2503cc..074889a 100644 (file)
@@ -10,7 +10,7 @@
 #   return $ret;
 # }
 
-function build_form($fields)
+function build_form($name, $fields)
 {
   $ret = array();
 
@@ -18,15 +18,19 @@ function build_form($fields)
   $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'] == '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') {
+      $ret[] = sprintf('<label for="edit_%s">%s</label><br>', $id, $info['name']);
+      $ret[] = sprintf('<input type="checkbox" id="edit_%s" name="%s"><br>', $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);
@@ -35,14 +39,18 @@ function build_form($fields)
       foreach ($options as $row)
        $ret[] = sprintf('<option value="%s">%s</option>', $row['id'], $row['text']);
       $ret[] = '</select><br>';
-
-      error_log('type = select');
     } elseif ($info['type'] == 'date') {
       error_log('type = date');
     }
   }
 
-  $ret[] = '<div align="center"><button onclick="return form_save(this);">Speichern</button></div>';
+  $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>';
@@ -134,6 +142,7 @@ 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']);
@@ -151,6 +160,7 @@ function build_mask($name, $mask)
   return array_merge($head,
                     $grid,
                     array('</div>','<div class="left">'),
+                    $status,
                     $details,
                     array('</div>'));
 }
@@ -172,7 +182,7 @@ function mask($name)
     $ret = build_mask($name, $mask);
 
   if (array_key_exists('edit', $mask))
-    $ret = array_merge($ret, build_form($mask['edit']));
+    $ret = array_merge($ret, build_form($name, $mask['edit']));
 
   return implode("\n", $ret);
 }