Add details according to mail request
[misc/kostenrechnung] / lib / mask.php
index 6791c47..eb64b46 100644 (file)
@@ -1,14 +1,25 @@
 <?php
 
-# function mask_fields($list)
-# {
-#   $ret = array();
-# 
-#   foreach ($list as $field => $data)
-#     $ret[] = $field;
-# 
-#   return $ret;
-# }
+function check_edit($name)
+{
+  $sql = sprintf("SELECT sys_mask.id,edit FROM sys_mask "
+                . "JOIN sys_group_mask ON sys_mask.id = sys_group_mask.mask "
+                . "WHERE gid = %d AND fname = '%s' "
+                . "ORDER BY edit DESC LIMIT 1",
+                $_SESSION['sys']['group'], pg_escape_string($name));
+
+  $sth = pg_query($sql);
+
+  if ($sth === false) return false;
+
+  $row = pg_fetch_assoc($sth);
+  if ($row === false) return false;
+
+  if ($row['edit'] == '0')
+    return false;
+
+  return true;
+}
 
 function build_form($name, $mask)
 {
@@ -59,14 +70,17 @@ function build_form($name, $mask)
       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[] = sprintf('<option value="%s"%s>%s</option>',
+                        $row['id'],
+                        !empty($info['selected']) && $row['id'] == $info['selected'] ? ' selected' : '',
+                        $row['text']);
       $ret[] = '</select>';
     } elseif ($info['type'] == 'textarea') {
       $ret[] = sprintf('<label for="edit_%s">%s</label><br>', $id, $info['name']);
       $v = array('id="edit_'.$id.'"',
                 'name="'.$id.'"');
-      $v[] = sprintf('cols="%d"', empty($info['columns'])?'25':$info['columns']);
-      $v[] = sprintf('rows="%d"', empty($info['rows'])?'5':$info['columns']);
+      $v[] = sprintf('cols="%d"', empty($info['columns'])?33:$info['columns']);
+      $v[] = sprintf('rows="%d"', empty($info['rows'])?5:$info['columns']);
       $ret[] = sprintf('<textarea %s></textarea>', implode(' ', $v));
     }
     if (array_key_exists('comment',$info))
@@ -75,13 +89,25 @@ function build_form($name, $mask)
       $ret[] = '<br>';
   }
 
+  $v_save = array('id="button_save"',
+                 'onclick="return form_save(this);"');
+  if ($mask['buttons']['save'] === false) $v_save[] = 'style="display: none"';
+
+  $v_insert = array('id="button_insert"',
+                 'onclick="return form_insert(this);"');
+  if ($mask['buttons']['insert'] === false) $v_insert[] = 'style="display: none"';
+
+  $v_delete = array('id="button_delete"',
+                   'onclick="return form_delete(this);"');
+  if ($mask['buttons']['delete'] === false) $v_delete[] = 'style="display: none"';
+
   $ret[] = '<span id="form_status">&nbsp;</span>';
   $ret[] = '<div class="buttons">';
-  $ret[] = '<button id="button_save" onclick="return form_save(this);">Speichern</button>';
+  $ret[] = sprintf('<button %s>%s</button>', implode(' ', $v_save), 'Speichern');
   $ret[] = '<span></span>';
-  $ret[] = '<button id="button_insert" onclick="return form_insert(this);">Hinzufügen</button>';
+  $ret[] = sprintf('<button %s>%s</button>', implode(' ', $v_insert), 'Hinzufügen');
   $ret[] = '<span></span>';
-  $ret[] = '<button id="button_delete" onclick="return form_delete(this);">Löschen</button>';
+  $ret[] = sprintf('<button %s>%s</button>', implode(' ', $v_delete), 'Löschen');
   $ret[] = '</div>';
 
   $ret[] = '</form>';
@@ -95,8 +121,6 @@ function build_grid($name, $mask)
   global $jscode;
   $ret = array();
 
-  $jscode[] = 'Rico.writeDebugMsg = function(msg, resetFlag) {};';
-
   $opts = array("click: gridDrillDown",
                "menuEvent: 'contextmenu'",
                "highlightElem: 'menuRow'");
@@ -201,7 +225,14 @@ function build_select($name, $details)
 
 function build_mask($name, $mask)
 {
-  $grid = build_grid($name, $mask);
+  global $jscode;
+  $jscode[] = 'Rico.writeDebugMsg = function(msg, resetFlag) {};';
+
+  if (array_key_exists('list', $mask))
+    $grid = build_grid($name, $mask);
+  else
+    $grid = array();
+
   $status = array('<span id="status"></span><br>');
 
   if (array_key_exists('details', $mask))
@@ -214,7 +245,7 @@ function build_mask($name, $mask)
   else
     $select = array();
 
-  if (array_key_exists('edit', $mask))
+  if (array_key_exists('edit', $mask) && check_edit($name))
     $edit = build_form($name, $mask);
   else
     $edit = array();
@@ -225,9 +256,15 @@ function build_mask($name, $mask)
 
   $head = array();
   $head[] = sprintf('<h3>%s</h3>', $title);
-  $head[] = '<div class="right">';
+
+  if (array_key_exists('html', $mask) &&
+      !array_key_exists('details', $mask) &&
+      !array_key_exists('select', $mask) &&
+      !array_key_exists('edit', $mask))
+    return array_merge($head, array($mask['html']),$status);
 
   return array_merge($head,
+                    array('<div class="right">'),
                     $grid,
                     array('</div>','<div class="left">'),
                     $details,
@@ -250,7 +287,7 @@ 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))
     $ret = build_mask($name, $mask);
 
   return sprintf('<span id="source" style="display: none;">%s</span>', $_GET['mask'])