Fixed bug for combos type 0 in non-js mode
[fa-stable.git] / includes / ui / ui_input.inc
index 6c09d0979f83f6fcf806ed45628396a49152249a..8842fc537a0ae3f25781bea30027a7daaa2c3076 100644 (file)
@@ -1,17 +1,34 @@
 <?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,
 //    and null or -1 otherwise.
 //
-function find_submit($prefix, $numeric=true) {
+function find_submit($prefix, $numeric=true)
+{
 
-    foreach($_POST as $postkey=>$postval ) {
-       if (strpos($postkey, $prefix) === 0) {
-               $id = substr($postkey, strlen($prefix));
-               return $numeric ? (int)$id : $id;
-       }
+    foreach($_POST as $postkey=>$postval )
+    {
+               if (strpos($postkey, $prefix) === 0)
+               {
+                       $id = substr($postkey, strlen($prefix));
+                       return $numeric ? (int)$id : $id;
+               }
     }
     return $numeric ? -1 : null;
 }
@@ -20,65 +37,76 @@ function find_submit($prefix, $numeric=true) {
 //
 //     Read numeric value from user formatted input
 //
-function input_num($postname=null) {
-       if (!isset($_POST[$postname])) 
-         return null;
+function input_num($postname=null)
+{
+       if (!isset($_POST[$postname]))
+               return null;
 
     return user_numeric($_POST[$postname]);
 }
 
 //---------------------------------------------------------------------------------
 
-function hidden($name, $value)
+function hidden($name, $value, $echo=true)
 {
-       echo "<input type=\"hidden\" name=\"$name\" value=\"$value\">\n";
+       global $Ajax;
+       $ret = "<input type=\"hidden\" name=\"$name\" value=\"$value\">";
+       $Ajax->addUpdate($name, $name, $value);
+       if ($echo)
+               echo $ret."\n";
+       else
+               return $ret;
 }
 
 //---------------------------------------------------------------------------------
 
-function submit($name, $value, $echo=true)
+function submit($name, $value, $echo=true, $title=false, $async=false)
 {
        default_focus($name);
-       $submit_str = "<input type=\"submit\" class=\"inputsubmit\" name=\"$name\" value=\"$value\">\n";
+       $submit_str = "<input type=\"submit\" class=\""
+           .($async ? 'ajaxsubmit' : 'inputsubmit')
+           ."\" name=\"$name\"  id=\"$name\" value=\"$value\""
+           .($title ? " title='$title'" : '')
+           .">\n";
        if ($echo)
                echo $submit_str;
        else
                return $submit_str;
 }
 
-function submit_center($name, $value, $echo=true)
+function submit_center($name, $value, $echo=true, $title=false, $async=false)
 {
        echo "<center>";
-       submit($name, $value, $echo);
+       submit($name, $value, $echo, $title, $async);
        echo "</center>";
 }
 
-function submit_center_first($name, $value)
+function submit_center_first($name, $value, $title=false, $async=false)
 {
        echo "<center>";
-       submit($name, $value);
+       submit($name, $value, true, $title, $async);
        echo "&nbsp;";
 }
 
-function submit_center_last($name, $value)
+function submit_center_last($name, $value, $title=false, $async=false)
 {
        echo "&nbsp;";
-       submit($name, $value);
+       submit($name, $value, true, $title, $async);
        echo "</center>";
 }
 
-function submit_add_or_update($add=true)
+function submit_add_or_update($add=true, $title=false, $async=false)
 {
        if ($add)
-               submit('ADD_ITEM', _("Save"));
+               submit('ADD_ITEM', _("Save"), true, $title, $async);
        else
-               submit('UPDATE_ITEM', _("Update"));
+               submit('UPDATE_ITEM', _("Update"), true, $title, $async);
 }
 
-function submit_add_or_update_center($add=true)
+function submit_add_or_update_center($add=true, $title=false, $async=false)
 {
        echo "<center>";
-       submit_add_or_update($add);
+       submit_add_or_update($add, $title, $async);
        echo "</center>";
 }
 
@@ -90,43 +118,45 @@ 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="", $title=false, $async=false)
 {
        echo "<tr>";
        if ($right)
                echo "<td>&nbsp;</td>\n";
        echo "<td $extra>";
-       submit_add_or_update($add);
+       submit_add_or_update($add, $title, $async);
        echo "</td></tr>\n";
 }
 
-function submit_cells($name, $value, $extra="")
+function submit_cells($name, $value, $extra="", $title=false, $async=false)
 {
        echo "<td $extra>";
-       submit($name, $value);
+       submit($name, $value, true, $title, $async);
        echo "</td>\n";
 }
 
-function submit_row($name, $value, $right=true, $extra="")
+function submit_row($name, $value, $right=true, $extra="", $title=false, $async=false)
 {
        echo "<tr>";
        if ($right)
                echo "<td>&nbsp;</td>\n";
-       submit_cells($name, $value, $extra);
+       submit_cells($name, $value, $extra, $title);
        echo "</tr>\n";
 }
 //---------------------------------------------------------------------------------
 
-function button($name, $value, $onclick)
+function button($name, $value, $onclick, $title=false)
 {
-  default_focus($name);
-  echo "<input type=\"button\" class=\"inputsubmit\" name=\"$name\" value=\"$value\" onclick=\"$onclick\" />\n";
+       default_focus($name);
+       echo "<input type=\"button\" class=\"inputsubmit\" name=\"$name\" value=\"$value\" onclick=\"$onclick\""
+           .($title ? " title='$title'" : '')
+           ." />\n";
 }
 
-function button_cell($name, $value, $onclick)
+function button_cell($name, $value, $onclick, $title=false)
 {
        echo "<td>";
-       button($name, $value, $onclick);
+       button($name, $value, $onclick, $title);
        echo "</td>\n";
 }
 
@@ -139,36 +169,39 @@ function check_value($name)
        return 1;
 }
 
-function check($label, $name, $value, $submit_on_change=false)
+function check($label, $name, $value, $submit_on_change=false, $title=false)
 {
+       global $Ajax;
+
        default_focus($name);
        if ($label)
                echo $label . "  ";
 
        if ($value == null)
                $value = (!isset($_POST[$name]) ? 0 : $_POST[$name]);
-       if ($value == 1)
-               echo "<input checked type='checkbox' name='$name' value='1' ";
-       else
-               echo "<input type='checkbox' name='$name' value='1'";
-       if ($submit_on_change)
-               echo " onclick='this.form.submit();' ";
-       echo " >\n";
+       
+               echo "<input"
+                   .($value == 1 ? ' checked':'')
+                   ." type='checkbox' name='$name' value='1'"
+                   .($submit_on_change ? " onclick='this.form.submit();'" : '')
+                   .($title ? " title='$title'" : '')
+                   ." >\n";
+       $Ajax->addUpdate($name, $name, $value);
 }
 
-function check_cells($label, $name, $value, $submit_on_change=false)
+function check_cells($label, $name, $value, $submit_on_change=false, $title=false)
 {
        if ($label != null)
                echo "<td>$label</td>\n";
        echo "<td>";
-       check(null, $name, $value, $submit_on_change);
+       check(null, $name, $value, $submit_on_change, $title);
        echo "</td>";
 }
 
-function check_row($label, $name, $value, $submit_on_change=false)
+function check_row($label, $name, $value, $submit_on_change=false, $title=false)
 {
        echo "<tr>";
-       check_cells($label, $name, $value, $submit_on_change);
+       check_cells($label, $name, $value, $submit_on_change, $title);
        echo "</tr>\n";
 }
 
@@ -179,33 +212,42 @@ 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="")
@@ -219,15 +261,17 @@ function label_row($label, $value, $params="", $params2="", $leftfill=0)
 {
        echo "<tr>";
        label_cells($label, $value, $params, $params2);
-       if($leftfill!=0)
-         echo "<td colspan=$leftfill></td>";
+       if ($leftfill!=0)
+               echo "<td colspan=$leftfill></td>";
        echo "</tr>\n";
 }
 
 //-----------------------------------------------------------------------------------
 
-function text_cells($label, $name, $value, $size="", $max="", $params="", $post_label="", $disabled="")
+function text_cells($label, $name, $value, $size="", $max="", $title=false, $params="", $post_label="", $disabled="")
 {
+       global $Ajax;
+
        default_focus($name);
        if ($label != null)
                label_cell($label, $params);
@@ -235,16 +279,21 @@ function text_cells($label, $name, $value, $size="", $max="", $params="", $post_
 
        if ($value == null)
                $value = (!isset($_POST[$name]) ? "" : $_POST[$name]);
-       echo "<input $disabled type=\"text\" name=\"$name\" size=\"$size\" maxlength=\"$max\" value=\"$value\">";
+       echo "<input $disabled type=\"text\" name=\"$name\" size=\"$size\" maxlength=\"$max\" value=\"$value\""
+           .($title ? " title='$title'" : '')
+           .">";
 
        if ($post_label != "")
                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)
+function text_cells_ex($label, $name, $size, $max=null, $init=null, $title=null, $params=null, $post_label=null, $submit_on_change=false)
 {
+       global $Ajax;
+
        default_focus($name);
        if (!isset($_POST[$name]) || $_POST[$name] == "")
        {
@@ -260,38 +309,40 @@ function text_cells_ex($label, $name, $size, $max=null, $init=null, $params=null
                $max = $size;
 
        echo "<td>";
-
-       echo "<input type=\"text\" name=\"$name\" size=\"$size\" maxlength=\"$max\" value=\"" . $_POST[$name]. "\">";
+       $class = $submit_on_change ? 'class="searchbox"' : '';
+       echo "<input $class type=\"text\" name=\"$name\" size=\"$size\" maxlength=\"$max\" value=\"" . $_POST[$name]. "\""
+        .($title ? " title='$title'": '')." >";
 
        if ($post_label)
                echo " " . $post_label;
 
        echo "</td>\n";
+       $Ajax->addUpdate($name, $name, $_POST[$name]);
 }
 
-function text_row($label, $name, $value, $size, $max, $params="", $post_label="")
+function text_row($label, $name, $value, $size, $max, $title=null, $params="", $post_label="")
 {
        echo "<tr>";
 
-       text_cells($label, $name, $value, $size, $max, $params, $post_label);
+       text_cells($label, $name, $value, $size, $max, $title, $params, $post_label);
 
        echo "</tr>\n";
 }
 
 //-----------------------------------------------------------------------------------
 
-function text_row_ex($label, $name, $size, $max=null, $value=null, $params=null, $post_label=null)
+function text_row_ex($label, $name, $size, $max=null, $title=null, $value=null, $params=null, $post_label=null)
 {
        echo "<tr>";
 
-       text_cells_ex($label, $name, $size, $max, $value, $params, $post_label);
+       text_cells_ex($label, $name, $size, $max, $value, $title, $params, $post_label);
 
        echo "</tr>\n";
 }
 
 //-----------------------------------------------------------------------------------
 
-function date_cells($label, $name, $init=null, $inc_days=0, $inc_months=0, $inc_years=0, $params=null)
+function date_cells($label, $name, $title = null, $init=null, $inc_days=0, $inc_months=0, $inc_years=0, $params=null)
 {
        global $use_date_picker, $path_to_root;
        if (!isset($_POST[$name]) || $_POST[$name] == "")
@@ -316,33 +367,33 @@ function date_cells($label, $name, $init=null, $inc_days=0, $inc_months=0, $inc_
                        $_POST[$name] = $init;
        }
        if ($use_date_picker)
-               $post_label = "<a tabindex='-1' href=\"javascript:date_picker(document.forms[0].$name);\">"
+               $post_label = "<a tabindex='-1' href=\"javascript:date_picker(document.getElementsByName('$name')[0]);\">"
                . "     <img src='$path_to_root/themes/default/images/cal.gif' width='16' height='16' border='0' alt='"._('Click Here to Pick up the date')."'></a>\n";
        else
                $post_label = "";
-       text_cells_ex($label, $name, 9, 12, $_POST[$name], $params, $post_label);
+       text_cells_ex($label, $name, 9, 12, $_POST[$name], $title, $params, $post_label);
 }
 
-function date_row($label, $name, $init=null, $inc_days=0, $inc_months=0, $inc_years=0, $params=null)
+function date_row($label, $name, $title=null, $init=null, $inc_days=0, $inc_months=0, $inc_years=0, $params=null)
 {
        echo "<tr>";
-       date_cells($label, $name, $init, $inc_days, $inc_months, $inc_years, $params);
+       date_cells($label, $name, $title, $init, $inc_days, $inc_months, $inc_years, $params);
        echo "</tr>\n";
 }
 
 //-----------------------------------------------------------------------------------
 
-function ref_cells($label, $name, $init=null, $params=null)
+function ref_cells($label, $name, $title=null, $init=null, $params=null, $submit_on_change=false)
 {
-       text_cells_ex($label, $name, 16, 18, $init, $params);
+       text_cells_ex($label, $name, 16, 18, $init, $title, $params, null, $submit_on_change);
 }
 
 //-----------------------------------------------------------------------------------
 
-function ref_row($label, $name, $init=null)
+function ref_row($label, $name, $title=null, $init=null, $submit_on_change=false)
 {
        echo "<tr>";
-       ref_cells($label, $name, $init);
+       ref_cells($label, $name, $title, $init, null, $submit_on_change);
        echo "</tr>\n";
 }
 
@@ -353,7 +404,7 @@ function percent_row($label, $name, $init=null)
 
        if (!isset($_POST[$name]) || $_POST[$name]=="")
        {
-                       $_POST[$name] = $init== null ? '' : $init;
+               $_POST[$name] = $init== null ? '' : $init;
        }
 
        small_amount_row($label, $name, $_POST[$name], null, "%", user_percent_dec());
@@ -361,8 +412,10 @@ 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();
+               $dec = user_price_dec();
        if (!isset($_POST[$name]) || $_POST[$name] == "")
        {
                if ($init)
@@ -384,6 +437,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]);
 }
 
 
@@ -412,16 +466,16 @@ function small_amount_row($label, $name, $init=null, $params=null, $post_label=n
 
 function qty_cells($label, $name, $init=null, $params=null, $post_label=null, $dec=null)
 {
-       if(!isset($dec))
-         $dec = user_qty_dec();
+       if (!isset($dec))
+               $dec = user_qty_dec();
 
        amount_cells_ex($label, $name, 15, 15, $init, $params, $post_label, $dec);
 }
 
 function qty_row($label, $name, $init=null, $params=null, $post_label=null, $dec=null)
 {
-       if(!isset($dec))
-         $dec = user_qty_dec();
+       if (!isset($dec))
+               $dec = user_qty_dec();
 
        echo "<tr>";
        amount_cells($label, $name, $init, $params, $post_label, $dec);
@@ -430,8 +484,8 @@ function qty_row($label, $name, $init=null, $params=null, $post_label=null, $dec
 
 function small_qty_row($label, $name, $init=null, $params=null, $post_label=null, $dec=null)
 {
-       if(!isset($dec))
-         $dec = user_qty_dec();
+       if (!isset($dec))
+               $dec = user_qty_dec();
 
        echo "<tr>";
        small_amount_cells($label, $name, $init, $params, $post_label, $dec);
@@ -449,34 +503,41 @@ function small_amount_cells($label, $name, $init=null, $params=null, $post_label
 
 function small_qty_cells($label, $name, $init=null, $params=null, $post_label=null, $dec=null)
 {
-  if (!isset($dec))
-         $dec = user_qty_dec();
+       if (!isset($dec))
+               $dec = user_qty_dec();
        amount_cells_ex($label, $name, 7, 12, $init, $params, $post_label, $dec);
 }
 
 //-----------------------------------------------------------------------------------
 
-function textarea_cells($label, $name, $value, $cols, $rows, $params="")
+function textarea_cells($label, $name, $value, $cols, $rows, $title = null, $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";
+       echo "<td><textarea name='$name' cols='$cols' rows='$rows'"
+       .($title ? " title='$title'" : '')
+       .">$value</textarea></td>\n";
+       $Ajax->addUpdate($name, $name, $value);
 }
 
-function textarea_row($label, $name, $value, $cols, $rows, $params="")
+function textarea_row($label, $name, $value, $cols, $rows, $title=null, $params="")
 {
        echo "<tr>";
-       textarea_cells($label, $name, $value, $cols, $rows, $params);
+       textarea_cells($label, $name, $value, $cols, $rows, $title, $params);
        echo "</tr>\n";
 }
 
 //-----------------------------------------------------------------------------------
-
+/*
 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>";
@@ -488,8 +549,9 @@ 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);
 }
-
+*/
 //-----------------------------------------------------------------------------------