Added explicit ob_end_flush on shutdown for php 5
[fa-stable.git] / includes / ui / ui_input.inc
index 67abbbde5861271a68e393e98e56c33cf2e998db..0f20919277ad65138640d96f9a08b12e3d4d5b1c 100644 (file)
@@ -1,5 +1,18 @@
 <?php
 
+function get_post($name, $dflt='') {
+       return ((!isset($_POST[$name]) || $_POST[$name] === '') ? $dflt : $_POST[$name]);
+}
+//
+// Sets local POST value and adds Value to ajax posting if needed 
+//
+/*function set_post($name, $value, $ajax_trigger=true) {
+    global $Ajax;
+
+    $_POST[$name] = $value;
+    if ($ajax_trigger) $Ajax->activate($name);
+}
+*/
 //------------------------------------------------------------------------------
 //    Seek for _POST variable with $prefix.
 //    If var is found returns variable name with prefix stripped,
@@ -31,54 +44,58 @@ function input_num($postname=null) {
 
 function hidden($name, $value)
 {
+  global $Ajax;
        echo "<input type=\"hidden\" name=\"$name\" value=\"$value\">\n";
+       $Ajax->addUpdate($name, $name, $value);
 }
 
 //---------------------------------------------------------------------------------
 
-function submit($name, $value, $echo=true)
+function submit($name, $value, $echo=true, $async=false)
 {
-
-       $submit_str = "<input type=\"submit\" class=\"inputsubmit\" name=\"$name\" value=\"$value\">\n";
+       default_focus($name);
+       $submit_str = "<input type=\"submit\" class=\""
+           .($async ? 'ajaxsubmit' : 'inputsubmit') 
+           ."\" name=\"$name\"  id=\"$name\" value=\"$value\" >\n";
        if ($echo)
                echo $submit_str;
        else
                return $submit_str;
 }
 
-function submit_center($name, $value, $echo=true)
+function submit_center($name, $value, $echo=true, $async=false)
 {
        echo "<center>";
-       submit($name, $value, $echo);
+       submit($name, $value, $echo, $async);
        echo "</center>";
 }
 
-function submit_center_first($name, $value)
+function submit_center_first($name, $value, $async=false)
 {
        echo "<center>";
-       submit($name, $value);
+       submit($name, $value, true, $async);
        echo "&nbsp;";
 }
 
-function submit_center_last($name, $value)
+function submit_center_last($name, $value, $async=false)
 {
        echo "&nbsp;";
-       submit($name, $value);
+       submit($name, $value, true, $async);
        echo "</center>";
 }
 
-function submit_add_or_update($add=true)
+function submit_add_or_update($add=true, $async=false)
 {
        if ($add)
-               submit('ADD_ITEM', _("Save"));
+               submit('ADD_ITEM', _("Save"), true, $async);
        else
-               submit('UPDATE_ITEM', _("Update"));
+               submit('UPDATE_ITEM', _("Update"), true, $async);
 }
 
-function submit_add_or_update_center($add=true)
+function submit_add_or_update_center($add=true, $async=false)
 {
        echo "<center>";
-       submit_add_or_update($add);
+       submit_add_or_update($add, $async);
        echo "</center>";
 }
 
@@ -90,24 +107,24 @@ function submit_add_or_update_row($add=true)
        echo "</td></tr>\n";
 }
 */
-function submit_add_or_update_row($add=true, $right=true, $extra="")
+function submit_add_or_update_row($add=true, $right=true, $extra="", $async=false)
 {
        echo "<tr>";
        if ($right)
                echo "<td>&nbsp;</td>\n";
        echo "<td $extra>";
-       submit_add_or_update($add);
+       submit_add_or_update($add, $async);
        echo "</td></tr>\n";
 }
 
-function submit_cells($name, $value, $extra="")
+function submit_cells($name, $value, $extra="", $async=false)
 {
        echo "<td $extra>";
-       submit($name, $value);
+       submit($name, $value, true, $async);
        echo "</td>\n";
 }
 
-function submit_row($name, $value, $right=true, $extra="")
+function submit_row($name, $value, $right=true, $extra="", $async=false)
 {
        echo "<tr>";
        if ($right)
@@ -119,6 +136,7 @@ function submit_row($name, $value, $right=true, $extra="")
 
 function button($name, $value, $onclick)
 {
+  default_focus($name);
   echo "<input type=\"button\" class=\"inputsubmit\" name=\"$name\" value=\"$value\" onclick=\"$onclick\" />\n";
 }
 
@@ -140,6 +158,9 @@ function check_value($name)
 
 function check($label, $name, $value, $submit_on_change=false)
 {
+  global $Ajax;
+
+       default_focus($name);
        if ($label)
                echo $label . "  ";
 
@@ -152,6 +173,7 @@ function check($label, $name, $value, $submit_on_change=false)
        if ($submit_on_change)
                echo " onclick='this.form.submit();' ";
        echo " >\n";
+       $Ajax->addUpdate($name, $name, $value);
 }
 
 function check_cells($label, $name, $value, $submit_on_change=false)
@@ -177,33 +199,41 @@ function labelheader_cell($label, $params="")
        echo "<td class='tableheader' $params>$label</td>\n";
 }
 
-function label_cell($label, $params="")
+function label_cell($label, $params="", $id=null)
 {
+    global $Ajax;
+    
+       if(isset($id)) {
+           $params .= " id='$id'";
+           $Ajax->addUpdate($id, $id, $label);
+       }
        echo "<td $params>$label</td>\n";
+
+       return $label;
 }
 
-function amount_cell($label, $bold=false)
+function amount_cell($label, $bold=false, $params="", $id=null)
 {
        if ($bold)
-               label_cell("<b>".price_format($label)."</b>", "nowrap align=right");
+               label_cell("<b>".price_format($label)."</b>", "nowrap align=right ".$params, $id);
        else
-               label_cell(price_format($label), "nowrap align=right");
+               label_cell(price_format($label), "nowrap align=right ".$params, $id);
 }
 
-function percent_cell($label, $bold=false)
+function percent_cell($label, $bold=false, $id=null)
 {
        if ($bold)
-               label_cell("<b>".percent_format($label)."</b>", "nowrap align=right");
+               label_cell("<b>".percent_format($label)."</b>", "nowrap align=right", $id);
        else
-               label_cell(percent_format($label), "nowrap align=right");
+               label_cell(percent_format($label), "nowrap align=right", $id);
 }
 
-function qty_cell($label, $bold=false, $dec=null)
+function qty_cell($label, $bold=false, $dec=null, $id=null)
 {
        if ($bold)
-               label_cell("<b>".qty_format($label, $dec)."</b>", "nowrap align=right");
+               label_cell("<b>".qty_format($label, $dec)."</b>", "nowrap align=right", $id);
        else
-               label_cell(qty_format($label, $dec), "nowrap align=right");
+               label_cell(qty_format($label, $dec), "nowrap align=right", $id);
 }
 
 function label_cells($label, $value, $params="", $params2="")
@@ -226,6 +256,9 @@ function label_row($label, $value, $params="", $params2="", $leftfill=0)
 
 function text_cells($label, $name, $value, $size="", $max="", $params="", $post_label="", $disabled="")
 {
+  global $Ajax;
+
+       default_focus($name);
        if ($label != null)
                label_cell($label, $params);
        echo "<td>";
@@ -238,10 +271,14 @@ function text_cells($label, $name, $value, $size="", $max="", $params="", $post_
                echo " " . $post_label;
 
        echo "</td>\n";
+       $Ajax->addUpdate($name, $name, $value);
 }
 
 function text_cells_ex($label, $name, $size, $max=null, $init=null, $params=null, $post_label=null)
 {
+  global $Ajax;
+
+       default_focus($name);
        if (!isset($_POST[$name]) || $_POST[$name] == "")
        {
                if ($init)
@@ -263,6 +300,7 @@ function text_cells_ex($label, $name, $size, $max=null, $init=null, $params=null
                echo " " . $post_label;
 
        echo "</td>\n";
+       $Ajax->addUpdate($name, $name, $_POST[$name]);
 }
 
 function text_row($label, $name, $value, $size, $max, $params="", $post_label="")
@@ -357,6 +395,8 @@ function percent_row($label, $name, $init=null)
 
 function amount_cells_ex($label, $name, $size, $max=null, $init=null, $params=null, $post_label=null, $dec=null)
 {
+global $Ajax;
+
        if (!isset($dec))
          $dec = user_price_dec();
        if (!isset($_POST[$name]) || $_POST[$name] == "")
@@ -380,6 +420,7 @@ function amount_cells_ex($label, $name, $size, $max=null, $init=null, $params=nu
                echo " " . $post_label;
 
        echo "</td>\n";
+       $Ajax->addUpdate($name, $name, $_POST[$name]);
 }
 
 
@@ -454,11 +495,15 @@ function small_qty_cells($label, $name, $init=null, $params=null, $post_label=nu
 
 function textarea_cells($label, $name, $value, $cols, $rows, $params="")
 {
+  global $Ajax;
+  
+       default_focus($name);
        if ($label != null)
                echo "<td $params>$label</td>\n";
        if ($value == null)
                $value = (!isset($_POST[$name]) ? "" : $_POST[$name]);
        echo "<td><textarea name='$name' cols='$cols' rows='$rows'>$value</textarea></td>\n";
+       $Ajax->addUpdate($name, $name, $value);
 }
 
 function textarea_row($label, $name, $value, $cols, $rows, $params="")
@@ -472,6 +517,9 @@ function textarea_row($label, $name, $value, $cols, $rows, $params="")
 
 function text_row_with_submit($label, $name, $value, $size, $max, $input_name, $input_value)
 {
+  global $Ajax;
+  
+       default_focus($name);
        echo "<tr><td>$label</td>\n";
        echo "<td>";
 
@@ -482,6 +530,7 @@ function text_row_with_submit($label, $name, $value, $size, $max, $input_name, $
        submit($input_name, $input_value);
 
        echo "</td></tr>\n";
+       $Ajax->addUpdate($name, $name, $value);
 }
 
 //-----------------------------------------------------------------------------------