X-Git-Url: https://delta.frontaccounting.com/gitweb/?a=blobdiff_plain;f=includes%2Fui%2Fui_lists.inc;h=d84b0d9df04d6f310e4d9daf92192059b6128f0a;hb=b3d1d752776bf325ddb7e5955e177b92b59fc94b;hp=f0c268e91e66c98e9295813f260c7e89e7135b91;hpb=0aae39a72064797c8fc9132fe4cf100c77a783a4;p=fa-stable.git diff --git a/includes/ui/ui_lists.inc b/includes/ui/ui_lists.inc index f0c268e9..d84b0d9d 100644 --- a/includes/ui/ui_lists.inc +++ b/includes/ui/ui_lists.inc @@ -1,299 +1,546 @@ . +***********************************************************************/ include_once($path_to_root . "/includes/banking.inc"); +include_once($path_to_root . "/includes/types.inc"); +include_once($path_to_root . "/includes/current_user.inc"); + +$_search_button = " "; + +$_select_button = " "; + +$all_items = ALL_TEXT; + +//---------------------------------------------------------------------------- +// Universal sql combo generator +// $sql must return selector values and selector texts in columns 0 & 1 +// Options are merged with defaults. + +function combo_input($name, $selected_id, $sql, $valfield, $namefield, + $options=null) +{ +global $Ajax; + +$opts = array( // default options + 'where'=> array(), // additional constraints + 'order' => $namefield, // list sort order + // special option parameters + 'spec_option'=>false, // option text or false + 'spec_id' => 0, // option id + // submit on select parameters + 'default' => '', // default value when $_POST is not set + 'multi' => false, // multiple select + 'select_submit' => false, //submit on select: true/false + 'async' => true, // select update via ajax (true) vs _page_body reload + // search box parameters + 'sel_hint' => null, + 'search_box' => false, // name or true/false + 'type' => 0, // type of extended selector: + // 0 - with (optional) visible search box, search by id + // 1 - with hidden search box, search by option text + // 2 - TODO reverse: box with hidden selector available via enter; this + // would be convenient for optional ad hoc adding of new item + 'search_submit' => true, //search submit button: true/false + 'size' => 8, // size and max of box tag + 'max' => 50, + 'height' => false, // number of lines in select box + 'cells' => false, // combo displayed as 2 cells + 'search' => array(), // sql field names to search + 'format' => null, // format functions for regular options + 'disabled' => false, + 'box_hint' => null, // box/selectors hints; null = std see below + 'category' => false, // category column name or false + 'show_inactive' => false // show inactive records. +); +// ------ merge options with defaults ---------- + if($options != null) + $opts = array_merge($opts, $options); + if (!is_array($opts['where'])) $opts['where'] = array($opts['where']); + + $search_box = $opts['search_box']===true ? '_'.$name.'_edit' : $opts['search_box']; + $search_submit = $opts['search_submit']===true ? '_'.$name.'_button' : $opts['search_submit']; + $select_submit = $opts['select_submit']; + $spec_id = $opts['spec_id']; + $spec_option = $opts['spec_option']; + $by_id = ($opts['type'] == 0); + $class = $by_id ? 'combo':'combo2'; + $disabled = $opts['disabled'] ? "disabled" : ''; + $multi = $opts['multi']; + + if(!count($opts['search'])) { + $opts['search'] = array($by_id ? $valfield : $namefield); + } + if ($opts['sel_hint'] === null) + $opts['sel_hint'] = $by_id || $search_box==false ? + '' : _('Press Space tab for search pattern entry'); -$all_items = reserved_words::get_all(); + if ($opts['box_hint'] === null) + $opts['box_hint'] = $search_box && $search_submit != false ? + ($by_id ? _('Enter code fragment to search or * for all') + : _('Enter description fragment to search or * for all')) :''; -// TDB for all list functions : if there is no data, display a link to the releveant -// page to add an item, eg. for locations, if no locations, link to Add Location + if ($selected_id == null) { + $selected_id = get_post($name, $opts['default']); + } + if(!is_array($selected_id)) + $selected_id = array($selected_id); // code is generalized for multiple selection support -function supplier_list($name, $selected_id, $all_option=false, $submit_on_change=false) -{ - if ($submit_on_change==true) - echo ""; + $txt = get_post($search_box); + $rel = ''; + $limit = ''; - $company_currency = get_company_currency(); + if (isset($_POST['_'.$name.'_update'])) { + if ($by_id) $txt = $_POST[$name]; - $supplier_sql = "SELECT supplier_id, supp_name, curr_code FROM ".TB_PREF."suppliers ORDER BY supp_name"; - $supplier_result = db_query($supplier_sql); + if (!$opts['async']) + $Ajax->activate('_page_body'); + else + $Ajax->activate($name); + } + if ($search_box) { + // search related sql modifications + + $rel = "rel='$search_box'"; // set relation to list + if ($opts['search_submit']) { + if (isset($_POST[$search_submit])) { + $selected_id = array(); // ignore selected_id while search + if (!$opts['async']) + $Ajax->activate('_page_body'); + else + $Ajax->activate($name); + } + if ($txt == '') { + if ($spec_option === false && $selected_id == array()) + $limit = ' LIMIT 1'; + else + $opts['where'][] = $valfield . "='". get_post($name, $spec_id)."'"; + } + else + if ($txt != '*') { - if ($selected_id == null) - $selected_id = (!isset($_POST[$name]) ? "" : $_POST[$name]); - if ($all_option == true) - { - if (reserved_words::get_all() == $selected_id) - { - echo "\n"; - } - else - { - echo "\n"; - } - if ($selected_id == "") - { - $selected_id = reserved_words::get_all(); + foreach($opts['search'] as $i=> $s) + $opts['search'][$i] = $s . " LIKE '%{$txt}%'"; + $opts['where'][] = '('. implode($opts['search'], ' OR ') . ')'; } } - - while ($supplier_row = db_fetch_row($supplier_result)) - { - if ($selected_id==$supplier_row[0]) - { - echo "\n"; - if ($selected_id == "") - { - $selected_id = $supplier_row[0]; - $_POST[$name] = $selected_id; + $sql .= $limit; + // ------ make selector ---------- + $selector = $first_opt = ''; + $first_id = false; + $found = false; + $lastcat = null; +//if($name=='stock_id') display_error($sql); + if($result = db_query($sql)) { + while ($contact_row = db_fetch($result)) { + $value = $contact_row[0]; + $descr = $opts['format']==null ? $contact_row[1] : + call_user_func($opts['format'], $contact_row); + $sel = ''; + if (get_post($search_submit) && ($txt === $value)) { + $selected_id[] = $value; + } + if (in_array($value, $selected_id)) { + $sel = 'selected'; + $found = $value; + } + // show selected option even if inactive + if (!$opts['show_inactive'] && @$contact_row['inactive'] && $sel==='') { + continue; + } else + $optclass = @$contact_row['inactive'] ? "class='inactive'" : ''; + + if ($first_id === false) { + $first_id = $value; + $first_opt = $descr; + } + $cat = $contact_row[$opts['category']]; + if ($opts['category'] !== false && $cat != $lastcat){ + $selector .= "\n"; + $lastcat = $cat; + } + $selector .= "\n"; } + db_free_result($result); } - echo ""; + // Prepend special option. + if ($spec_option !== false) { // if special option used - add it + $first_id = $spec_id; + $first_opt = $spec_option; +// } +// if($first_id !== false) { + $sel = $found===false ? 'selected' : ''; + $optclass = @$contact_row['inactive'] ? "class='inactive'" : ''; + $selector = "\n" + . $selector; + } - db_free_result($supplier_result); -} + if ($found===false) { + $selected_id = array($first_id); + } + $_POST[$name] = $multi ? $selected_id : $selected_id[0]; -function supplier_list_cells($label, $name, $selected_id, $all_option=false, $submit_on_change=false) -{ - if ($label != null) - echo "$label\n"; - echo ""; - supplier_list($name, $selected_id, $all_option, $submit_on_change); - echo "\n"; + if ($by_id && $search_box != false) { + $txt = $found; + $Ajax->addUpdate($name, $search_box, $txt ? $txt : ''); + } + $selector = "\n"; + + $Ajax->addUpdate($name, "_{$name}_sel", $selector); + + // because of bug which M$ cannot fix since IE 5.0 + // we must embed whole selector in span tags to enable proper ajax update + $selector = "".$selector."\n"; + + if ($select_submit != false) { // if submit on change is used - add select button + global $_select_button; + // button class selects form reload/ajax selector update + $selector .= sprintf($_select_button, $disabled, user_theme(), + (fallback_mode() ? '' : 'display:none;'), + '_'.$name.'_update')."\n"; + } +// ------ make combo ---------- + + $edit_entry = ''; + if ($search_box != false) { + $edit_entry = "\n"; + if ($search_submit != false) { + global $_search_button; + $edit_entry .= sprintf($_search_button, $disabled, user_theme(), + (fallback_mode() ? '' : 'display:none;'), + $search_submit)."\n"; + } + } + default_focus(($search_box && $by_id) ? $search_box : $name); + + if ($search_box && $opts['cells']) + $str = ($edit_entry!='' ? "$edit_entry" : '')."$selector"; + else + $str = $edit_entry.$selector; + return $str; } -function supplier_list_row($label, $name, $selected_id, $all_option=false, $submit_on_change=false) +/* + Helper function. + Returns true if selector $name is subject to update. +*/ +function list_updated($name) { - echo "\n"; - supplier_list_cells($label, $name, $selected_id, $all_option, $submit_on_change); - echo "\n"; + return isset($_POST['_'.$name.'_update']) || isset($_POST['_'.$name.'_button']); } - //---------------------------------------------------------------------------------------------- +// Universal array combo generator +// $items is array of options 'value' => 'description' +// Options is reduced set of combo_selector options and is merged with defaults. + +function array_selector($name, $selected_id, $items, $options=null) +{ + global $Ajax; + +$opts = array( // default options + 'spec_option'=>false, // option text or false + 'spec_id' => 0, // option id + 'select_submit' => false, //submit on select: true/false + 'async' => true, // select update via ajax (true) vs _page_body reload + 'default' => '', // default value when $_POST is not set + 'multi'=>false, // multiple select + // search box parameters + 'height' => false, // number of lines in select box + 'sel_hint' => null, + 'disabled' => false +); +// ------ merge options with defaults ---------- + if($options != null) + $opts = array_merge($opts, $options); + $select_submit = $opts['select_submit']; + $spec_id = $opts['spec_id']; + $spec_option = $opts['spec_option']; + $disabled = $opts['disabled'] ? "disabled" : ''; + $multi = $opts['multi']; + + if ($selected_id == null) { + $selected_id = get_post($name, $opts['default']); + } + if(!is_array($selected_id)) + $selected_id = array($selected_id); // code is generalized for multiple selection support -function customer_list($name, $selected_id, $all_option=false, $submit_on_change=false) -{ - if ($submit_on_change==true) - echo ""; + if (isset($_POST[ '_'.$name.'_update'])) { + if (!$opts['async']) + $Ajax->activate('_page_body'); + else + $Ajax->activate($name); + } - $customer_sql = "SELECT debtor_no, name, curr_code FROM ".TB_PREF."debtors_master ORDER BY name"; - $customer_result = db_query($customer_sql); + // ------ make selector ---------- + $selector = $first_opt = ''; + $first_id = false; + $found = false; +//if($name=='SelectStockFromList') display_error($sql); + foreach($items as $value=>$descr) { + $sel = ''; + if (in_array((string)$value, $selected_id)) { + $sel = 'selected'; + $found = $value; + } + if ($first_id === false) { + $first_id = $value; + $first_opt = $descr; + } + $selector .= "\n"; + } - $company_currency = get_company_currency(); + // Prepend special option. + if ($spec_option !== false) { // if special option used - add it + $first_id = $spec_id; + $first_opt = $spec_option; + $sel = $found===false ? 'selected' : ''; + $selector = "\n" + . $selector; + } - if ($selected_id == null) - $selected_id = (!isset($_POST[$name]) ? "" : $_POST[$name]); - if (($all_option == true)) - { - if (reserved_words::get_all() == $selected_id) - { - echo "\n"; - } - else - { - echo "\n"; - } - if ($selected_id == "") - { - $selected_id = reserved_words::get_all(); - } + if ($found===false) { + $selected_id = array($first_id); } + $_POST[$name] = $multi ? $selected_id : $selected_id[0]; + $selector = "\n"; - while ($customer_row = db_fetch_row($customer_result)) - { - if ($selected_id == $customer_row[0]) - { - echo "\n"; - // if no initial selection - set the first item - // do we want to do this for all lists ???? probably - if ($selected_id == "") - { - $selected_id = $customer_row[0]; - $_POST[$name] = $selected_id; - } + if ($select_submit != false) { // if submit on change is used - add select button + global $_select_button; + $selector .= sprintf($_select_button, $disabled, user_theme(), + (fallback_mode() ? '' : 'display:none;'), + '_'.$name.'_update')."\n"; } + default_focus($name); + + return $selector; +} +//---------------------------------------------------------------------------------------------- - echo ""; +function _format_add_curr($row) +{ + static $company_currency; - db_free_result($customer_result); + if ($company_currency == null) + { + $company_currency = get_company_currency(); + } + return $row[1] . ($row[2] == $company_currency ? + '' : (" - " . $row[2])); } -function customer_list_cells($label, $name, $selected_id, $all_option = false, $submit_on_change=false) +function supplier_list($name, $selected_id=null, $spec_option=false, $submit_on_change=false, + $all=false, $editkey = false) { - if ($label != null) - echo "$label\n"; - echo ""; - customer_list($name, $selected_id, $all_option, $submit_on_change); - echo "\n"; + global $all_items; + + $sql = "SELECT supplier_id, supp_ref, curr_code, inactive FROM ".TB_PREF."suppliers "; + + $mode = get_company_pref('no_supplier_list'); + + if ($editkey) + set_editor('supplier', $name, $editkey); + + return combo_input($name, $selected_id, $sql, 'supplier_id', 'supp_name', + array( + 'format' => '_format_add_curr', + 'order' => array('supp_ref'), + 'search_box' => $mode!=0, + 'type' => 1, + 'spec_option' => $spec_option === true ? _("All Suppliers") : $spec_option, + 'spec_id' => $all_items, + 'select_submit'=> $submit_on_change, + 'async' => false, + 'sel_hint' => $mode ? _('Press Space tab to filter by name fragment') : + _('Select supplier'), + 'show_inactive'=>$all + )); } -function customer_list_row($label, $name, $selected_id, $all_option = false, $submit_on_change=false) +function supplier_list_cells($label, $name, $selected_id=null, $all_option=false, + $submit_on_change=false, $all=false, $editkey = false) { - echo "\n"; - customer_list_cells($label, $name, $selected_id, $all_option, $submit_on_change); - echo "\n"; + if ($label != null) + echo "$label\n"; + echo supplier_list($name, $selected_id, $all_option, $submit_on_change, + $all, $editkey); + echo "\n"; } -//------------------------------------------------------------------------------------------------ +function supplier_list_row($label, $name, $selected_id=null, $all_option = false, + $submit_on_change=false, $all=false, $editkey = false) +{ + echo "$label"; + echo supplier_list($name, $selected_id, $all_option, $submit_on_change, + $all, $editkey); + echo "\n"; +} +//---------------------------------------------------------------------------------------------- -function customer_branches_list($customer_id, $name, $selected_id, - $all_option = true, $enabled=true, $submit_on_change=false) +function customer_list($name, $selected_id=null, $spec_option=false, $submit_on_change=false, + $show_inactive=false, $editkey = false) { global $all_items; - if ($submit_on_change==true) - echo ""; - - $sql = "SELECT branch_code, br_name FROM ".TB_PREF."cust_branch - WHERE debtor_no='" . $customer_id . "'"; - if ($enabled) - $sql .= " AND disable_trans = 0"; - $result = db_query($sql); + $sql = "SELECT debtor_no, debtor_ref, curr_code, inactive FROM ".TB_PREF."debtors_master "; - if ($selected_id == null) - $selected_id = (!isset($_POST[$name]) ? "" : $_POST[$name]); - if ($all_option == true) - { - echo "\n"; - - if ($selected_id == "") - { - $selected_id = reserved_words::get_all(); - } - } - - while ($row = db_fetch_row($result)) - { - if ($selected_id == $row[0]) - { - echo "\n"; + $mode = get_company_pref('no_customer_list'); - if ($selected_id == "") - { - $selected_id = $row[0]; - $_POST[$name] = $selected_id; - } - } + if ($editkey) + set_editor('customer', $name, $editkey); - echo ""; - db_free_result($result); + return combo_input($name, $selected_id, $sql, 'debtor_no', 'name', + array( + 'format' => '_format_add_curr', + 'order' => array('debtor_ref'), + 'search_box' => $mode!=0, + 'type' => 1, + 'size' => 20, + 'spec_option' => $spec_option === true ? _("All Customers") : $spec_option, + 'spec_id' => $all_items, + 'select_submit'=> $submit_on_change, + 'async' => false, + 'sel_hint' => $mode ? _('Press Space tab to filter by name fragment; F2 - entry new customer') : + _('Select customer'), + 'show_inactive' => $show_inactive + ) ); } -function customer_branches_list_cells($label,$customer_id, $name, $selected_id, $all_option = true, $enabled=true, $submit_on_change=false) +function customer_list_cells($label, $name, $selected_id=null, $all_option=false, + $submit_on_change=false, $show_inactive=false, $editkey = false) { if ($label != null) echo "$label\n"; - echo ""; - customer_branches_list($customer_id, $name, $selected_id, $all_option, $enabled, $submit_on_change); + echo ""; + echo customer_list($name, $selected_id, $all_option, $submit_on_change, + $show_inactive, $editkey); echo "\n"; } -function customer_branches_list_row($label,$customer_id, $name, $selected_id, $all_option = true, $enabled=true, $submit_on_change=false) +function customer_list_row($label, $name, $selected_id=null, $all_option = false, + $submit_on_change=false, $show_inactive=false, $editkey = false) { - echo ""; - customer_branches_list_cells($label, $customer_id, $name, $selected_id, $all_option, $enabled, $submit_on_change); - echo ""; + echo "$label"; + echo customer_list($name, $selected_id, $all_option, $submit_on_change, + $show_inactive, $editkey); + echo "\n\n"; } //------------------------------------------------------------------------------------------------ -function locations_list($name, $selected_id, $all_option=false, $submit_on_change=false, $all_option_name="") +function customer_branches_list($customer_id, $name, $selected_id=null, + $spec_option = true, $enabled=true, $submit_on_change=false, $editkey = false) { - if ($submit_on_change == true) - echo ""; + global $all_items; -// if ($selected_id =="" AND isset($_SESSION['UserStockLocation']) AND $_SESSION['UserStockLocation'] !="") { -// $selected_id = $_SESSION['UserStockLocation']; -// } + $sql = "SELECT branch_code, branch_ref FROM ".TB_PREF."cust_branch + WHERE debtor_no='" . $customer_id . "' "; - $sql = "SELECT loc_code, location_name FROM ".TB_PREF."locations"; - $result = db_query($sql); + if ($editkey) + set_editor('branch', $name, $editkey); - if ($selected_id == null) - $selected_id = (!isset($_POST[$name]) ? "" : $_POST[$name]); - if ($all_option == true) - { - echo "\n"; + $where = $enabled ? array("disable_trans = 0") : array(); + return combo_input($name, $selected_id, $sql, 'branch_code', 'br_name', + array( + 'where' => $where, + 'order' => array('branch_ref'), + 'spec_option' => $spec_option === true ? _('All branches') : $spec_option, + 'spec_id' => $all_items, + 'select_submit'=> $submit_on_change, + 'sel_hint' => _('Select customer branch') + ) ); +} +//------------------------------------------------------------------------------------------------ - if ($selected_id == "") { - $selected_id = reserved_words::get_all(); - } - } +function customer_branches_list_cells($label,$customer_id, $name, $selected_id=null, + $all_option = true, $enabled=true, $submit_on_change=false, $editkey = false) +{ + if ($label != null) + echo "$label\n"; + echo ""; + echo customer_branches_list($customer_id, $name, $selected_id, $all_option, $enabled, + $submit_on_change, $editkey); + echo "\n"; +} - while ($row = db_fetch_row($result)) - { - if ($selected_id == $row[0]) - { - echo "\n"; +function customer_branches_list_row($label, $customer_id, $name, $selected_id=null, + $all_option = true, $enabled=true, $submit_on_change=false, $editkey = false) +{ + echo ""; + customer_branches_list_cells($label, $customer_id, $name, $selected_id, + $all_option, $enabled, $submit_on_change, $editkey); + echo ""; +} - if ($selected_id == "") - { - $selected_id = $row[0]; - $_POST[$name] = $selected_id; - } - } +//------------------------------------------------------------------------------------------------ - echo ""; +function locations_list($name, $selected_id=null, $all_option=false, $submit_on_change=false) +{ + global $all_items; + + $sql = "SELECT loc_code, location_name, inactive FROM ".TB_PREF."locations"; - db_free_result($result); +return combo_input($name, $selected_id, $sql, 'loc_code', 'location_name', + array( + 'spec_option' => $all_option === true ? _("All Locations") : $all_option, + 'spec_id' => $all_items, + 'select_submit'=> $submit_on_change + ) ); } -function locations_list_cells($label, $name, $selected_id, $all_option=false, $submit_on_change=false) +function locations_list_cells($label, $name, $selected_id=null, $all_option=false, $submit_on_change=false) { if ($label != null) echo "$label\n"; echo ""; - locations_list($name, $selected_id, $all_option, $submit_on_change); + echo locations_list($name, $selected_id, $all_option, $submit_on_change); echo "\n"; } -function locations_list_row($label, $name, $selected_id, $all_option=false, $submit_on_change=false) +function locations_list_row($label, $name, $selected_id=null, $all_option=false, $submit_on_change=false) { echo ""; locations_list_cells($label, $name, $selected_id, $all_option, $submit_on_change); @@ -302,723 +549,606 @@ function locations_list_row($label, $name, $selected_id, $all_option=false, $sub //----------------------------------------------------------------------------------------------- -function currencies_list($name, &$selected_id, $submit_on_change=false) +function currencies_list($name, $selected_id=null, $submit_on_change=false) { - if ($submit_on_change==true) - echo ""; - - $company_currency = get_company_currency(); + $sql = "SELECT curr_abrev, currency, inactive FROM ".TB_PREF."currencies"; - $sql = "SELECT curr_abrev, currency FROM ".TB_PREF."currencies"; - $result = db_query($sql); +// default to the company currency - if ($selected_id == null) - $selected_id = (!isset($_POST[$name]) ? "" : $_POST[$name]); - while ($row = db_fetch_row($result)) - { - // default to the company currency - if ($selected_id == "" && ($row[0] == $company_currency)) - { - $selected_id = $row[0]; - $_POST[$name] = $selected_id; - } - - if ($selected_id == $row[0]) - { - echo "\n"; - } - - echo ""; - db_free_result($result); +return combo_input($name, $selected_id, $sql, 'curr_abrev', 'currency', + array( + 'select_submit'=> $submit_on_change, + 'default' => get_company_currency(), + 'async' => false + ) ); } -function currencies_list_cells($label, $name, $selected_id) +function currencies_list_cells($label, $name, $selected_id=null, $submit_on_change=false) { if ($label != null) echo "$label\n"; echo ""; - currencies_list($name, $selected_id); + echo currencies_list($name, $selected_id, $submit_on_change); echo "\n"; } -function currencies_list_row($label, $name, $selected_id) +function currencies_list_row($label, $name, $selected_id=null, $submit_on_change=false) { echo "\n"; - currencies_list_cells($label, $name, $selected_id); + currencies_list_cells($label, $name, $selected_id, $submit_on_change); echo "\n"; } //--------------------------------------------------------------------------------------------------- -function fiscalyears_list($name, &$selected_id, $submit_on_change=false) +function fiscalyears_list($name, $selected_id=null, $submit_on_change=false) { - if ($submit_on_change == true) - echo ""; - $company_year = get_company_pref('f_year'); + $sql = "SELECT * FROM ".TB_PREF."fiscal_year"; - $sql = "SELECT * FROM ".TB_PREF."fiscal_year ORDER BY begin"; - $result = db_query($sql); +// default to the company current fiscal year - if ($selected_id == null) - $selected_id = (!isset($_POST[$name]) ? "" : $_POST[$name]); - while ($row = db_fetch_row($result)) - { - // default to the company current fiscal year - if ($selected_id == "" && ($row[0] == $company_year)) - { - $selected_id = $row[0]; - $_POST[$name] = $selected_id; - } - - if ($selected_id == $row[0]) - { - echo "\n"; - } +return combo_input($name, $selected_id, $sql, 'id', '', + array( + 'order' => 'begin', + 'default' => get_company_pref('f_year'), + 'format' => '_format_fiscalyears', + 'select_submit'=> $submit_on_change, + 'async' => false + ) ); +} - echo ""; - db_free_result($result); +function _format_fiscalyears($row) +{ + return sql2date($row[1]) . " - " . sql2date($row[2]) + . "  " . ($row[3] ? _('Closed') : _('Active')) . "\n"; } -function fiscalyears_list_cells($label, $name, $selected_id) +function fiscalyears_list_cells($label, $name, $selected_id=null) { if ($label != null) echo "$label\n"; echo ""; - fiscalyears_list($name, $selected_id); + echo fiscalyears_list($name, $selected_id); echo "\n"; } -function fiscalyears_list_row($label, $name, $selected_id) +function fiscalyears_list_row($label, $name, $selected_id=null) { echo "\n"; fiscalyears_list_cells($label, $name, $selected_id); echo "\n"; } +//------------------------------------------------------------------------------------ -//--------------------------------------------------------------------------------------------------- - -function simple_codeandname_list($sql, $name, &$selected_id, - $all_option=false, $all_option_name=null, $all_option_numeric=false, - $submit_on_change=false, $returnzero=false) +function dimensions_list($name, $selected_id=null, $no_option=false, $showname=' ', + $submit_on_change=false, $showclosed=false, $showtype=1) { - if ($submit_on_change == true) - echo ""; - - if ($selected_id == null) - $selected_id = (!isset($_POST[$name]) ? "" : $_POST[$name]); - if ($all_option == true) - { - if ($returnzero) - $reserved_word = 0; - elseif ($all_option_numeric) - $reserved_word = reserved_words::get_all_numeric(); - else - $reserved_word = reserved_words::get_all(); - - if ($reserved_word == $selected_id) - { - echo "\n"; - } - else - { - echo "\n"; - } - if ($selected_id == "") - { - $selected_id = $reserved_word; - } - } - - $result = db_query($sql); - - while ($row = db_fetch_row($result)) - { - if ($selected_id == $row[0]) - { - echo "\n"; - - if (!$returnzero && $selected_id == "") - { - $selected_id = $row[0]; - $_POST[$name] = $selected_id; - } - } +$sql = "SELECT id, CONCAT(reference,' ',name) as ref FROM ".TB_PREF."dimensions"; - echo ""; - db_free_result($result); -} +$options = array( + 'order' => 'reference', + 'spec_option'=>$no_option ? $showname : false, + 'spec_id' => 0, + 'select_submit'=> $submit_on_change, + 'async' => false, + ); -//------------------------------------------------------------------------------------ + if (!$showclosed) + $options['where'][] = "closed=0"; + if($showtype) + $options['where'][] = "type_=$showtype"; -function dimensions_list($name, &$selected_id, $no_option=false, $showname=null, - $submit_on_change=false, $showclosed=false, $showtype=1) -{ - $sql = "SELECT id, CONCAT(reference,' ',name) FROM ".TB_PREF."dimensions"; - if ($showclosed || $showtype) - { - $sql .= " WHERE"; - if ($showclosed) - $sql .= " closed=0"; - if ($showclosed && $showtype) - $sql .= " AND type_=$showtype"; - else if ($showtype) - $sql .= " type_=$showtype"; - } - $sql .= " ORDER BY reference"; - simple_codeandname_list($sql, $name, &$selected_id, $no_option, $showname, - true, $submit_on_change, true); + return combo_input($name, $selected_id, $sql, 'id', 'ref', $options); } -function dimensions_list_cells($label, $name, $selected_id, $no_option=false, $showname=null, - $showclosed=false, $showtype=0) +function dimensions_list_cells($label, $name, $selected_id=null, $no_option=false, $showname=null, + $showclosed=false, $showtype=0, $submit_on_change=false) { if ($label != null) echo "$label\n"; echo ""; - dimensions_list($name, $selected_id, $no_option, $showname, false, $showclosed, $showtype); + echo dimensions_list($name, $selected_id, $no_option, $showname, $submit_on_change, $showclosed, $showtype); echo "\n"; } -function dimensions_list_row($label, $name, $selected_id, $no_option=false, $showname=null, - $showclosed=false, $showtype=0) +function dimensions_list_row($label, $name, $selected_id=null, $no_option=false, $showname=null, + $showclosed=false, $showtype=0, $submit_on_change=false) { echo "\n"; - dimensions_list_cells($label, $name, $selected_id, $no_option, $showname, - $showclosed, $showtype); + dimensions_list_cells($label, $name, $selected_id, $no_option, $showname, + $showclosed, $showtype, $submit_on_change); echo "\n"; } //--------------------------------------------------------------------------------------------------- -function stock_items_list($name, $selected_id, $all_option=false, $submit_on_change=false, $extra="") +function stock_items_list($name, $selected_id=null, $all_option=false, + $submit_on_change=false, $opts=array(), $editkey = false) { global $all_items; - if ($submit_on_change==true) - echo ""; - else - echo ""; - db_free_result($result); +function _format_stock_items($row) +{ + return (user_show_codes() ? ($row[0] . " - ") : "") . $row[1]; } -function stock_items_list_cells($label, $name, $selected_id, $all_option=false, $submit_on_change=false, $extra="") +function stock_items_list_cells($label, $name, $selected_id=null, $all_option=false, + $submit_on_change=false, $all=false, $editkey = false) { - if ($label != null) + if ($label != null) echo "$label\n"; - echo ""; - stock_items_list($name, $selected_id, $all_option, $submit_on_change, $extra); - echo "\n"; + echo stock_items_list($name, $selected_id, $all_option, $submit_on_change, + array('cells'=>true, 'show_inactive'=>$all), $editkey); } - -function stock_items_list_row($label, $name, $selected_id, $all_option=false, $submit_on_change=false) +/* +function stock_items_list_row($label, $name, $selected_id=null, $all_option=false, $submit_on_change=false) { echo "\n"; stock_items_list_cells($label, $name, $selected_id, $all_option, $submit_on_change); echo "\n"; } - -//------------------------------------------------------------------------------------ - -function stock_bom_items_list($name, $selected_id, $all_option=false, $submit_on_change=false) +*/ +//--------------------------------------------------------------------------------------------------- +// +// Select item via foreign code. +// +function sales_items_list($name, $selected_id=null, $all_option=false, + $submit_on_change=false, $type='', $opts=array()) { global $all_items; + // all sales codes + $sql = "SELECT i.item_code, i.description, c.description, count(*)>1 as kit, + i.inactive + FROM + ".TB_PREF."stock_master s, + ".TB_PREF."item_codes i + LEFT JOIN + ".TB_PREF."stock_category c + ON i.category_id=c.category_id + WHERE i.stock_id=s.stock_id"; - if ($submit_on_change==true) - echo ""; - - $sql = "SELECT stock_id, ".TB_PREF."stock_master.description, ".TB_PREF."stock_category.description - FROM ".TB_PREF."stock_master,".TB_PREF."stock_category WHERE ".TB_PREF."stock_master.category_id=".TB_PREF."stock_category.category_id - AND (".TB_PREF."stock_master.mb_flag='M' OR ".TB_PREF."stock_master.mb_flag='K')"; - $result = db_query($sql); - - if ($selected_id == null) - $selected_id = (!isset($_POST[$name]) ? "" : $_POST[$name]); - if (($all_option == true)) - { - if ($all_items == $selected_id) - { - echo "\n"; - } - else - { - echo "\n"; - } - if ($selected_id == "") - { - $selected_id = $all_items; - } + + if ($type == 'local') { // exclude foreign codes + $sql .= " AND !i.is_foreign"; + } elseif ($type == 'kits') { // sales kits + $sql .= " AND !i.is_foreign AND i.item_code!=i.stock_id"; } + $sql .= " AND !i.inactive AND !s.inactive AND !s.no_sale"; + $sql .= " GROUP BY i.item_code"; + + return combo_input($name, $selected_id, $sql, 'i.item_code', 'c.description', + array_merge( + array( + 'format' => '_format_stock_items', + 'spec_option' => $all_option===true ? _("All Items") : $all_option, + 'spec_id' => $all_items, + 'search_box' => true, + 'search' => array("i.item_code", "c.description", "i.description"), + 'search_submit' => get_company_pref('no_item_list')!=0, + 'size'=>15, + 'select_submit'=> $submit_on_change, + 'category' => 2, + 'order' => array('c.description','i.item_code') + ), $opts) ); +} + +function sales_items_list_cells($label, $name, $selected_id=null, $all_option=false, $submit_on_change=false) +{ + if ($label != null) + echo "$label\n"; + echo sales_items_list($name, $selected_id, $all_option, $submit_on_change, + '', array('cells'=>true)); +} - while ($row = db_fetch_row($result)) - { - if ($selected_id==$row[0]) - { - echo "\n"; +function sales_kits_list($name, $selected_id=null, $all_option=false, $submit_on_change=false) +{ + return sales_items_list($name, $selected_id, $all_option, $submit_on_change, + 'kits', array('cells'=>false)); +} - if ($selected_id == "") - { - $selected_id = $row[0]; - $_POST[$name] = $selected_id; - } - } +function sales_local_items_list_row($label, $name, $selected_id=null, $all_option=false, $submit_on_change=false) +{ + echo ""; + if ($label != null) + echo "$label\n"; + echo ""; + echo sales_items_list($name, $selected_id, $all_option, $submit_on_change, + 'local', array('cells'=>false)); + echo ""; +} +//------------------------------------------------------------------------------------ - echo ""; - db_free_result($result); +function stock_manufactured_items_list($name, $selected_id=null, + $all_option=false, $submit_on_change=false) +{ + return stock_items_list($name, $selected_id, $all_option, $submit_on_change, + array('where'=>array("mb_flag= 'M'"))); } -function stock_bom_items_list_cells($label, $name, $selected_id, $all_option=false, $submit_on_change=false) +function stock_manufactured_items_list_cells($label, $name, $selected_id=null, + $all_option=false, $submit_on_change=false) { if ($label != null) echo "$label\n"; echo ""; - stock_bom_items_list($name, $selected_id, $all_option, $submit_on_change); + echo stock_manufactured_items_list($name, $selected_id, $all_option, $submit_on_change); echo "\n"; } -function stock_bom_items_list_row($label, $name, $selected_id, $all_option=false, $submit_on_change=false) +function stock_manufactured_items_list_row($label, $name, $selected_id=null, + $all_option=false, $submit_on_change=false) { echo "\n"; - stock_bom_items_list_cells($label, $name, $selected_id, $all_option, $submit_on_change); + stock_manufactured_items_list_cells($label, $name, $selected_id, $all_option, $submit_on_change); echo "\n"; } - //------------------------------------------------------------------------------------ -function base_stock_items_list($sql, $name, &$selected_id, - $all_option=false, $all_option_name="", $submit_on_change=false, $extra="") +function stock_component_items_list($name, $parent_stock_id, $selected_id=null, + $all_option=false, $submit_on_change=false, $editkey = false) { - if ($submit_on_change==true) - echo ""; - else - echo ""; - db_free_result($result); + return stock_items_list($name, $selected_id, $all_option, $submit_on_change, + array('where'=>array("stock_id != '$parent_stock_id'")), $editkey); } +function stock_component_items_list_cells($label, $name, $parent_stock_id, + $selected_id=null, $all_option=false, $submit_on_change=false, $editkey = false) +{ + if ($label != null) + echo "$label\n"; + echo stock_items_list($name, $selected_id, $all_option, $submit_on_change, + array('where'=>array("stock_id != '$parent_stock_id'"), 'cells'=>true), + $editkey); +} //------------------------------------------------------------------------------------ -function stock_manufactured_items_list($name, $selected_id, +function stock_costable_items_list($name, $selected_id=null, $all_option=false, $submit_on_change=false) { - $sql = "SELECT stock_id, ".TB_PREF."stock_master.description, ".TB_PREF."stock_category.description - FROM ".TB_PREF."stock_master,".TB_PREF."stock_category WHERE ".TB_PREF."stock_master.category_id=".TB_PREF."stock_category.category_id - AND (".TB_PREF."stock_master.mb_flag='M')"; + return stock_items_list($name, $selected_id, $all_option, $submit_on_change, + array('where'=>array("mb_flag!='D'"))); +} + +function stock_costable_items_list_cells($label, $name, $selected_id=null, + $all_option=false, $submit_on_change=false) +{ + if ($label != null) + echo "$label\n"; + echo stock_items_list($name, $selected_id, $all_option, $submit_on_change, + array('where'=>array("mb_flag!='D'"), 'cells'=>true)); +} - base_stock_items_list($sql, $name, &$selected_id, $all_option, _("All Items"), - $submit_on_change); +//------------------------------------------------------------------------------------ +function stock_purchasable_items_list($name, $selected_id=null, + $all_option=false, $submit_on_change=false, $all=false, $editkey=false) +{ + return stock_items_list($name, $selected_id, $all_option, $submit_on_change, + array('where'=>array("mb_flag!= 'M'"), + 'show_inactive'=>$all), $editkey); } -function stock_manufactured_items_list_cells($label, $name, $selected_id, $all_option=false, $submit_on_change=false) +function stock_purchasable_items_list_cells($label, $name, $selected_id=null, + $all_option=false, $submit_on_change=false, $editkey=false) { if ($label != null) echo "$label\n"; - echo ""; - stock_manufactured_items_list($name, $selected_id, $all_option, $submit_on_change); - echo "\n"; + echo stock_items_list($name, $selected_id, $all_option, $submit_on_change, + array('where'=>array("mb_flag!= 'M'"), + 'cells'=>true), $editkey); } -function stock_manufactured_items_list_row($label, $name, $selected_id, $all_option=false, $submit_on_change=false) +function stock_purchasable_items_list_row($label, $name, $selected_id=null, + $all_option=false, $submit_on_change=false, $editkey=false) { echo "\n"; - stock_manufactured_items_list_cells($label, $name, $selected_id, $all_option, $submit_on_change); + stock_purchasable_items_list_cells($label, $name, $selected_id=null, + $all_option, $submit_on_change, $editkey); echo "\n"; } //------------------------------------------------------------------------------------ -function stock_component_items_list($name, $parent_stock_id, &$selected_id, - $all_option=false, $submit_on_change=false) +function stock_item_types_list_row($label, $name, $selected_id=null, $enabled=true) { - $sql = "SELECT stock_id, ".TB_PREF."stock_master.description, ".TB_PREF."stock_category.description - FROM ".TB_PREF."stock_master,".TB_PREF."stock_category WHERE - ".TB_PREF."stock_master.category_id=".TB_PREF."stock_category.category_id - AND stock_id != '$parent_stock_id'"; + global $stock_types; - base_stock_items_list($sql, $name, &$selected_id, - $all_option, _("All Items"), $submit_on_change); + echo ""; + if ($label != null) + echo "$label\n"; + echo ""; + + echo array_selector($name, $selected_id, $stock_types, + array( + 'select_submit'=> true, + 'disabled' => !$enabled) ); + echo "\n"; +} + +function stock_units_list_row($label, $name, $value=null, $enabled=true) +{ + $result = get_all_item_units(); + echo ""; + if ($label != null) + echo "$label\n"; + echo ""; + + while($unit = db_fetch($result)) + $units[$unit['abbr']] = $unit['name']; + + echo array_selector($name, $value, $units, array( 'disabled' => !$enabled) ); + + echo "\n"; } //------------------------------------------------------------------------------------ -function stock_purchasable_items_list($name, &$selected_id, - $all_option=false, $submit_on_change=false, $extra="") +function tax_types_list($name, $selected_id=null, $none_option=false, $submit_on_change=false) { - $sql = "SELECT stock_id, ".TB_PREF."stock_master.description, ".TB_PREF."stock_category.description - FROM ".TB_PREF."stock_master,".TB_PREF."stock_category WHERE ".TB_PREF."stock_master.category_id=".TB_PREF."stock_category.category_id - AND mb_flag !='M'"; + $sql = "SELECT id, CONCAT(name, ' (',rate,'%)') as name FROM ".TB_PREF."tax_types"; - base_stock_items_list($sql, $name, &$selected_id, - $all_option, _("All Items"), $submit_on_change, $extra); + return combo_input($name, $selected_id, $sql, 'id', 'name', + array( + 'spec_option' => $none_option, + 'spec_id' => ALL_NUMERIC, + 'select_submit'=> $submit_on_change, + 'async' => false, + ) ); } -function stock_purchasable_items_list_cells($label, $name, &$selected_id, $all_option=false, $submit_on_change=false, $extra = "") +function tax_types_list_cells($label, $name, $selected_id=null, $none_option=false, + $submit_on_change=false) { if ($label != null) echo "$label\n"; echo ""; - stock_purchasable_items_list($name, $selected_id, $all_option, $submit_on_change, $extra); + echo tax_types_list($name, $selected_id, $none_option, $submit_on_change); echo "\n"; } -function stock_purchasable_items_list_row($label, $name, &$selected_id, $all_option=false, $submit_on_change=false) +function tax_types_list_row($label, $name, $selected_id=null, $none_option=false, + $submit_on_change=false) { echo "\n"; - stock_purchasable_items_list_cells($label, $name, $selected_id, $all_option, $submit_on_change); + tax_types_list_cells($label, $name, $selected_id, $none_option, $submit_on_change); echo "\n"; } //------------------------------------------------------------------------------------ -function stock_costable_items_list($name, &$selected_id, - $all_option=false, $submit_on_change=false) +function tax_groups_list($name, $selected_id=null, + $none_option=false, $submit_on_change=false) { - $sql = "SELECT stock_id, ".TB_PREF."stock_master.description, ".TB_PREF."stock_category.description - FROM ".TB_PREF."stock_master,".TB_PREF."stock_category WHERE ".TB_PREF."stock_master.category_id=".TB_PREF."stock_category.category_id - AND mb_flag !='D'"; + $sql = "SELECT id, name FROM ".TB_PREF."tax_groups"; - base_stock_items_list($sql, $name, &$selected_id, - $all_option, _("All Items"), $submit_on_change); + return combo_input($name, $selected_id, $sql, 'id', 'name', + array( + 'order' => 'id', + 'spec_option' => $none_option, + 'spec_id' => ALL_NUMERIC, + 'select_submit'=> $submit_on_change, + 'async' => false, + ) ); } -//------------------------------------------------------------------------------------ - -function stock_item_types_list_row($label, $name, $selected_id, $enabled=true) +function tax_groups_list_cells($label, $name, $selected_id=null, $none_option=false, $submit_on_change=false) { - echo ""; - if ($label != NULL) + if ($label != null) echo "$label\n"; - echo ""; - if ($enabled) - echo "\n"; - if ($selected_id == null) - $selected_id = (!isset($_POST[$name]) ? "" : $_POST[$name]); - if ($selected_id == "") - $_POST[$name] = $selected_id = "B"; - echo "\n"; - echo "\n"; - echo "\n"; - echo "\n"; + echo ""; + echo tax_groups_list($name, $selected_id, $none_option, $submit_on_change); + echo "\n"; } -function stock_units_list_row($label, $name, $value, $enabled=true) +function tax_groups_list_row($label, $name, $selected_id=null, $none_option=false, $submit_on_change=false) { - global $stock_units; - - echo "$label\n"; - if ($enabled) - echo ""; - - if ($value == null) - $value = (!isset($_POST[$name]) ? "" : $_POST[$name]); - foreach ($stock_units as $unit) - { - if ($value == "") - $_POST[$name] = $value = $unit; - if ($value==$unit) - { - echo "\n"; - } - else - { - echo "\n"; - } - } - echo "\n"; + echo "\n"; + tax_groups_list_cells($label, $name, $selected_id, $none_option, $submit_on_change); + echo "\n"; } //------------------------------------------------------------------------------------ -function tax_types_list($name, $selected_id, - $none_option=false, $none_option_name=null, $submit_on_change=false) +function item_tax_types_list($name, $selected_id=null) { - simple_codeandname_list("SELECT id, name FROM ".TB_PREF."tax_types", - $name, $selected_id, $none_option, $none_option_name, true, $submit_on_change); + $sql ="SELECT id, name FROM ".TB_PREF."item_tax_types"; + return combo_input($name, $selected_id, $sql, 'id', 'name', array('order' => 'id') ); } -function tax_types_list_cells($label, $name, $selected_id, $none_option=false, - $none_option_name=null, $submit_on_change=false) +function item_tax_types_list_cells($label, $name, $selected_id=null) { if ($label != null) echo "$label\n"; echo ""; - tax_types_list($name, $selected_id, $none_option, $none_option_name, $submit_on_change); + echo item_tax_types_list($name, $selected_id); echo "\n"; } -function tax_types_list_row($label, $name, $selected_id, $none_option=false, - $none_option_name=null, $submit_on_change=false) +function item_tax_types_list_row($label, $name, $selected_id=null) { echo "\n"; - tax_types_list_cells($label, $name, $selected_id, $none_option, $none_option_name, $submit_on_change); + item_tax_types_list_cells($label, $name, $selected_id); echo "\n"; } //------------------------------------------------------------------------------------ -function tax_groups_list($name, $selected_id, - $none_option=false, $none_option_name=null, $submit_on_change=false) +function shippers_list($name, $selected_id=null) { - simple_codeandname_list("SELECT id, name FROM ".TB_PREF."tax_groups ORDER BY id", - $name, $selected_id, $none_option, $none_option_name, true, $submit_on_change); + $sql = "SELECT shipper_id, shipper_name, inactive FROM ".TB_PREF."shippers"; + return combo_input($name, $selected_id, $sql, 'shipper_id', 'shipper_name', + array('order'=>array('shipper_name'))); } -function tax_groups_list_cells($label, $name, $selected_id, $submit_on_change=false) +function shippers_list_cells($label, $name, $selected_id=null) { if ($label != null) echo "$label\n"; echo ""; - tax_groups_list($name, $selected_id, false, null, $submit_on_change); + echo shippers_list($name, $selected_id); echo "\n"; } -function tax_groups_list_row($label, $name, $selected_id, $submit_on_change=false) +function shippers_list_row($label, $name, $selected_id=null) { echo "\n"; - tax_groups_list_cells($label, $name, $selected_id, false, null, $submit_on_change); + shippers_list_cells($label, $name, $selected_id); echo "\n"; } -//------------------------------------------------------------------------------------ +//------------------------------------------------------------------------------------- -function item_tax_types_list($name, $selected_id) +function sales_persons_list($name, $selected_id=null, $spec_opt=false) { - simple_codeandname_list("SELECT id, name FROM ".TB_PREF."item_tax_types ORDER BY id", - $name, $selected_id); + $sql = "SELECT salesman_code, salesman_name, inactive FROM ".TB_PREF."salesman"; + return combo_input($name, $selected_id, $sql, 'salesman_code', 'salesman_name', + array('order'=>array('salesman_name'), + 'spec_option' => $spec_opt, + 'spec_id' => ALL_NUMERIC)); } -function item_tax_types_list_cells($label, $name, $selected_id) +function sales_persons_list_cells($label, $name, $selected_id=null, $spec_opt=false) { if ($label != null) echo "$label\n"; - echo ""; - item_tax_types_list($name, $selected_id); + echo "\n"; + echo sales_persons_list($name, $selected_id, $spec_opt); echo "\n"; } -function item_tax_types_list_row($label, $name, $selected_id) +function sales_persons_list_row($label, $name, $selected_id=null, $spec_opt=false) { echo "\n"; - item_tax_types_list_cells($label, $name, $selected_id); + sales_persons_list_cells($label, $name, $selected_id, $spec_opt); echo "\n"; } //------------------------------------------------------------------------------------ -function shippers_list($name, $selected_id) +function sales_areas_list($name, $selected_id=null) { - simple_codeandname_list("SELECT shipper_id, shipper_name FROM ".TB_PREF."shippers", - $name, $selected_id); + $sql = "SELECT area_code, description, inactive FROM ".TB_PREF."areas"; + return combo_input($name, $selected_id, $sql, 'area_code', 'description', array()); } -function shippers_list_cells($label, $name, $selected_id) +function sales_areas_list_cells($label, $name, $selected_id=null) { if ($label != null) echo "$label\n"; echo ""; - shippers_list($name, $selected_id); + echo sales_areas_list($name, $selected_id); echo "\n"; } -function shippers_list_row($label, $name, $selected_id) +function sales_areas_list_row($label, $name, $selected_id=null) { echo "\n"; - shippers_list_cells($label, $name, $selected_id); + sales_areas_list_cells($label, $name, $selected_id); echo "\n"; } -//------------------------------------------------------------------------------------- +//------------------------------------------------------------------------------------ -function sales_persons_list($name, $selected_id) +function sales_groups_list($name, $selected_id=null, $special_option=false) { - simple_codeandname_list("SELECT salesman_code, salesman_name FROM ".TB_PREF."salesman", - $name, $selected_id); + $sql = "SELECT id, description, inactive FROM ".TB_PREF."groups"; + return combo_input($name, $selected_id, $sql, 'id', 'description', array( + 'spec_option' => $special_option===true ? ' ' : $special_option, + 'order' => 'description', 'spec_id' => 0, + )); } -function sales_persons_list_cells($label, $name, $selected_id) +function sales_groups_list_cells($label, $name, $selected_id=null, $special_option=false) { if ($label != null) echo "$label\n"; - echo "\n"; - sales_persons_list($name, $selected_id); + echo ""; + echo sales_groups_list($name, $selected_id, $special_option); echo "\n"; } -function sales_persons_list_row($label, $name, $selected_id) +function sales_groups_list_row($label, $name, $selected_id=null, $special_option=false) { echo "\n"; - sales_persons_list_cells($label, $name, $selected_id); + sales_groups_list_cells($label, $name, $selected_id, $special_option); echo "\n"; } //------------------------------------------------------------------------------------ -function sales_areas_list($name, $selected_id) +function _format_template_items($row) +{ + return ($row[0] . " -  " . _("Amount") . " ".$row[1]); +} + +function templates_list($name, $selected_id=null, $special_option=false) { - simple_codeandname_list("SELECT area_code, description FROM ".TB_PREF."areas", - $name, $selected_id); + $sql = "SELECT sorder.order_no, Sum(line.unit_price*line.quantity*(1-line.discount_percent)) AS OrderValue + FROM ".TB_PREF."sales_orders as sorder, ".TB_PREF."sales_order_details as line + WHERE sorder.order_no = line.order_no AND sorder.type = 1 GROUP BY line.order_no"; + return combo_input($name, $selected_id, $sql, 'order_no', 'OrderValue', array( + 'format' => '_format_template_items', + 'spec_option' => $special_option===true ? ' ' : $special_option, + 'order' => 'order_no', 'spec_id' => 0, + )); } -function sales_areas_list_cells($label, $name, $selected_id) +function templates_list_cells($label, $name, $selected_id=null, $special_option=false) { if ($label != null) echo "$label\n"; echo ""; - sales_areas_list($name, $selected_id); + echo templates_list($name, $selected_id, $special_option); echo "\n"; } -function sales_areas_list_row($label, $name, $selected_id) +function templates_list_row($label, $name, $selected_id=null, $special_option=false) { echo "\n"; - sales_areas_list_cells($label, $name, $selected_id); + templates_list_cells($label, $name, $selected_id, $special_option); echo "\n"; } //------------------------------------------------------------------------------------ -function workorders_list($name, $selected_id) +function workorders_list($name, $selected_id=null) { - simple_codeandname_list("SELECT id, wo_ref FROM ".TB_PREF."workorders WHERE closed=0", - $name, $selected_id); + $sql = "SELECT id, wo_ref FROM ".TB_PREF."workorders WHERE closed=0"; + return combo_input($name, $selected_id, $sql, 'id', 'wo_ref', array()); } -function workorders_list_cells($label, $name, $selected_id) +function workorders_list_cells($label, $name, $selected_id=null) { if ($label != null) echo "$label\n"; echo ""; - workorders_list($name, $selected_id); + echo workorders_list($name, $selected_id); echo "\n"; } -function workorders_list_row($label, $name, $selected_id) +function workorders_list_row($label, $name, $selected_id=null) { echo "\n"; workorders_list_cells($label, $name, $selected_id); @@ -1027,22 +1157,22 @@ function workorders_list_row($label, $name, $selected_id) //------------------------------------------------------------------------------------ -function payment_terms_list($name, $selected_id) +function payment_terms_list($name, $selected_id=null) { - simple_codeandname_list("SELECT terms_indicator, terms FROM ".TB_PREF."payment_terms", - $name, $selected_id); + $sql = "SELECT terms_indicator, terms, inactive FROM ".TB_PREF."payment_terms"; + return combo_input($name, $selected_id, $sql, 'terms_indicator', 'terms', array()); } -function payment_terms_list_cells($label, $name, $selected_id) +function payment_terms_list_cells($label, $name, $selected_id=null) { if ($label != null) echo "$label\n"; echo ""; - payment_terms_list($name, $selected_id); + echo payment_terms_list($name, $selected_id); echo "\n"; } -function payment_terms_list_row($label, $name, $selected_id) +function payment_terms_list_row($label, $name, $selected_id=null) { echo "\n"; payment_terms_list_cells($label, $name, $selected_id); @@ -1051,22 +1181,22 @@ function payment_terms_list_row($label, $name, $selected_id) //------------------------------------------------------------------------------------ -function credit_status_list($name, $selected_id) +function credit_status_list($name, $selected_id=null) { - simple_codeandname_list("SELECT id, reason_description FROM ".TB_PREF."credit_status", - $name, $selected_id); + $sql ="SELECT id, reason_description, inactive FROM ".TB_PREF."credit_status"; + return combo_input($name, $selected_id, $sql, 'id', 'reason_description', array()); } -function credit_status_list_cells($label, $name, $selected_id) +function credit_status_list_cells($label, $name, $selected_id=null) { if ($label != null) echo "$label\n"; echo ""; - credit_status_list($name, $selected_id); + echo credit_status_list($name, $selected_id); echo "\n"; } -function credit_status_list_row($label, $name, $selected_id) +function credit_status_list_row($label, $name, $selected_id=null) { echo "\n"; credit_status_list_cells($label, $name, $selected_id); @@ -1075,46 +1205,53 @@ function credit_status_list_row($label, $name, $selected_id) //----------------------------------------------------------------------------------------------- -function sales_types_list($name, $selected_id) +function sales_types_list($name, $selected_id=null, $submit_on_change=false, $special_option=false) { - simple_codeandname_list("SELECT id, sales_type FROM ".TB_PREF."sales_types", - $name, $selected_id); + $sql = "SELECT id, sales_type, inactive FROM ".TB_PREF."sales_types"; + + return combo_input($name, $selected_id, $sql, 'id', 'sales_type', + array( + 'spec_option' => $special_option===true ? _("All Sales Types") : $special_option, + 'spec_id' => 0, + 'select_submit'=> $submit_on_change, + // 'async' => false, + ) ); } -function sales_types_list_cells($label, $name, $selected_id) +function sales_types_list_cells($label, $name, $selected_id=null, $submit_on_change=false, $special_option=false) { if ($label != null) echo "$label\n"; echo ""; - sales_types_list($name, $selected_id); + echo sales_types_list($name, $selected_id, $submit_on_change, $special_option); echo "\n"; } -function sales_types_list_row($label, $name, $selected_id) +function sales_types_list_row($label, $name, $selected_id=null, $submit_on_change=false, $special_option=false) { echo "\n"; - sales_types_list_cells($label, $name, $selected_id); + sales_types_list_cells($label, $name, $selected_id, $submit_on_change, $special_option); echo "\n"; } //----------------------------------------------------------------------------------------------- -function movement_types_list($name, $selected_id) +function movement_types_list($name, $selected_id=null) { - simple_codeandname_list("SELECT id, name FROM ".TB_PREF."movement_types", - $name, $selected_id); + $sql = "SELECT id, name FROM ".TB_PREF."movement_types"; + return combo_input($name, $selected_id, $sql, 'id', 'name', array()); } -function movement_types_list_cells($label, $name, $selected_id) +function movement_types_list_cells($label, $name, $selected_id=null) { if ($label != null) echo "$label\n"; echo ""; - movement_types_list($name, $selected_id); + echo movement_types_list($name, $selected_id); echo "\n"; } -function movement_types_list_row($label, $name, $selected_id) +function movement_types_list_row($label, $name, $selected_id=null) { echo "\n"; movement_types_list_cells($label, $name, $selected_id); @@ -1122,80 +1259,67 @@ function movement_types_list_row($label, $name, $selected_id) } //----------------------------------------------------------------------------------------------- +function _format_date($row) +{ + return sql2date($row['reconciled']); +} -function bank_trans_types_list($name, $selected_id) +function bank_reconciliation_list($account, $name, $selected_id=null, $submit_on_change=false, $special_option=false) { - simple_codeandname_list("SELECT id, name FROM ".TB_PREF."bank_trans_types", - $name, $selected_id); + $sql = "SELECT reconciled, reconciled FROM ".TB_PREF."bank_trans + WHERE bank_act=".db_escape($account)." AND reconciled IS NOT NULL + GROUP BY reconciled"; + return combo_input($name, $selected_id, $sql, 'id', 'reconciled', + array( + 'spec_option' => $special_option, + 'format' => '_format_date', + 'spec_id' => '', + 'select_submit'=> $submit_on_change + ) ); } -function bank_trans_types_list_cells($label, $name, $selected_id) +function bank_reconciliation_list_cells($label,$account, $name, $selected_id=null, $submit_on_change=false, $special_option=false) { if ($label != null) echo "$label\n"; echo ""; - bank_trans_types_list($name, $selected_id); + echo bank_reconciliation_list($account, $name, $selected_id, $submit_on_change, $special_option); echo "\n"; } - -function bank_trans_types_list_row($label, $name, $selected_id) +/* +function bank_reconciliation_list_row($label, $account, $name, $selected_id=null, $submit_on_change=false, $special_option=false) { echo "\n"; - bank_trans_types_list_cells($label, $name, $selected_id); + bank_reconciliation_list_cells($label, $account, $name, $selected_id, $submit_on_change, $special_option); echo "\n"; } - +*/ //----------------------------------------------------------------------------------------------- -function workcenter_list($name, $selected_id, $all_option=false) +function workcenter_list($name, $selected_id=null, $all_option=false) { global $all_items; - echo ""; - db_free_result($result); + return combo_input($name, $selected_id, $sql, 'id', 'name', + array( + 'spec_option' =>$all_option===true ? _("All Suppliers") : $all_option, + 'spec_id' => $all_items, + ) ); } -function workcenter_list_cells($label, $name, $selected_id, $all_option=false) +function workcenter_list_cells($label, $name, $selected_id=null, $all_option=false) { + default_focus($name); if ($label != null) echo "$label\n"; echo ""; - workcenter_list($name, $selected_id, $all_option); + echo workcenter_list($name, $selected_id, $all_option); echo "\n"; } -function workcenter_list_row($label, $name, $selected_id, $all_option=false) +function workcenter_list_row($label, $name, $selected_id=null, $all_option=false) { echo "\n"; workcenter_list_cells($label, $name, $selected_id, $all_option); @@ -1204,109 +1328,110 @@ function workcenter_list_row($label, $name, $selected_id, $all_option=false) //----------------------------------------------------------------------------------------------- -function bank_accounts_list($name, $selected_id, $submit_on_change=false) +function bank_accounts_list($name, $selected_id=null, $submit_on_change=false) { - if ($submit_on_change==true) - echo ""; + $sql = "SELECT ".TB_PREF."bank_accounts.id, bank_account_name, bank_curr_code, inactive + FROM ".TB_PREF."bank_accounts"; + + return combo_input($name, $selected_id, $sql, 'id', 'bank_account_name', + array( + 'format' => '_format_add_curr', + 'select_submit'=> $submit_on_change, + 'async' => false + ) ); +} + +function bank_accounts_list_cells($label, $name, $selected_id=null, $submit_on_change=false) +{ + if ($label != null) + echo "$label\n"; + echo ""; + echo bank_accounts_list($name, $selected_id, $submit_on_change); + echo "\n"; +} + +function bank_accounts_list_row($label, $name, $selected_id=null, $submit_on_change=false) +{ + echo "\n"; + bank_accounts_list_cells($label, $name, $selected_id, $submit_on_change); + echo "\n"; +} +//----------------------------------------------------------------------------------------------- + +function cash_accounts_list_row($label, $name, $selected_id=null, $submit_on_change=false) +{ + $sql = "SELECT ".TB_PREF."bank_accounts.id, bank_account_name, bank_curr_code, inactive + FROM ".TB_PREF."bank_accounts + WHERE ".TB_PREF."bank_accounts.account_type=3"; + + if ($label != null) + echo "$label\n"; + echo ""; + echo combo_input($name, $selected_id, $sql, 'id', 'bank_account_name', + array( + 'format' => '_format_add_curr', + 'select_submit'=> $submit_on_change, + 'async' => true + ) ); + echo "\n"; +} +//----------------------------------------------------------------------------------------------- - $company_currency = get_company_currency(); +function pos_list_row($label, $name, $selected_id=null, $spec_option=false, $submit_on_change=false) +{ + $sql = "SELECT id, pos_name, inactive FROM ".TB_PREF."sales_pos"; - $sql = "SELECT ".TB_PREF."bank_accounts.account_code, bank_account_name, bank_curr_code - FROM ".TB_PREF."bank_accounts, ".TB_PREF."chart_master - WHERE ".TB_PREF."bank_accounts.account_code=".TB_PREF."chart_master.account_code"; - $result = db_query($sql); + default_focus($name); + echo ''; + if ($label != null) + echo "$label\n"; + echo ""; - if ($selected_id == null) - $selected_id = (!isset($_POST[$name]) ? "" : $_POST[$name]); - while ($row = db_fetch_row($result)) - { - if ($selected_id == $row[0]) - { - echo "\n"; - if ($selected_id == "") - { - $selected_id = $row[0]; - $_POST[$name] = $selected_id; - } - } + echo combo_input($name, $selected_id, $sql, 'id', 'pos_name', + array( + 'select_submit'=> $submit_on_change, + 'async' => true, + 'spec_option' =>$spec_option, + 'spec_id' => -1, + 'order'=> array('pos_name') + ) ); + echo "\n"; - echo ""; - db_free_result($result); } +//----------------------------------------------------------------------------------------------- -function bank_accounts_list_cells($label, $name, $selected_id, $submit_on_change=false) +function sale_payment_list_cells($label, $name, $selected_id=null, $submit_on_change=false) { if ($label != null) echo "$label\n"; echo ""; - bank_accounts_list($name, $selected_id, $submit_on_change); + echo yesno_list($name, $selected_id, _('Cash'), _('Delayed'), $submit_on_change); echo "\n"; } - -function bank_accounts_list_row($label, $name, $selected_id, $submit_on_change=false) -{ - echo "\n"; - bank_accounts_list_cells($label, $name, $selected_id, $submit_on_change); - echo "\n"; -} - //----------------------------------------------------------------------------------------------- -function class_list($name, $selected_id, $submit_on_change=false) +function class_list($name, $selected_id=null, $submit_on_change=false) { - if ($submit_on_change==true) - echo ""; - $sql = "SELECT cid, class_name FROM ".TB_PREF."chart_class"; - $result = db_query($sql); - if ($selected_id == null) - $selected_id = (!isset($_POST[$name]) ? "" : $_POST[$name]); - while ($row = db_fetch_row($result)) - { - if ($selected_id == $row[0]) - { - echo "\n"; - if ($selected_id == "") - { - $selected_id = $row[0]; - $_POST[$name] = $selected_id; - } - } + return combo_input($name, $selected_id, $sql, 'cid', 'class_name', + array( + 'select_submit'=> $submit_on_change, + 'async' => false + ) ); - echo ""; - db_free_result($result); } -function class_list_cells($label, $name, $selected_id, $submit_on_change=false) +function class_list_cells($label, $name, $selected_id=null, $submit_on_change=false) { if ($label != null) echo "$label\n"; echo ""; - class_list($name, $selected_id, $submit_on_change); + echo class_list($name, $selected_id, $submit_on_change); echo "\n"; } -function class_list_row($label, $name, $selected_id, $submit_on_change=false) +function class_list_row($label, $name, $selected_id=null, $submit_on_change=false) { echo "\n"; class_list_cells($label, $name, $selected_id, $submit_on_change); @@ -1314,176 +1439,152 @@ function class_list_row($label, $name, $selected_id, $submit_on_change=false) } //----------------------------------------------------------------------------------------------- - -function stock_categories_list($name, $selected_id) +function stock_categories_list($name, $selected_id=null, $spec_opt=false, $submit_on_change=false) { - simple_codeandname_list("SELECT category_id, description FROM ".TB_PREF."stock_category - ORDER BY category_id", $name, $selected_id); + $sql = "SELECT category_id, description, inactive FROM ".TB_PREF."stock_category"; + return combo_input($name, $selected_id, $sql, 'category_id', 'description', + array('order'=>'category_id', + 'spec_option' => $spec_opt, + 'spec_id' => -1, + 'select_submit'=> $submit_on_change, + 'async' => true + )); } -function stock_categories_list_cells($label, $name, $selected_id) +function stock_categories_list_cells($label, $name, $selected_id=null, $spec_opt=false, $submit_on_change=false) { if ($label != null) echo "$label\n"; echo ""; - stock_categories_list($name, $selected_id); + echo stock_categories_list($name, $selected_id, $spec_opt, $submit_on_change); echo "\n"; } -function stock_categories_list_row($label, $name, $selected_id) +function stock_categories_list_row($label, $name, $selected_id=null, $spec_opt=false, $submit_on_change=false) { echo "\n"; - stock_categories_list_cells($label, $name, $selected_id); + stock_categories_list_cells($label, $name, $selected_id, $spec_opt, $submit_on_change); echo "\n"; } //----------------------------------------------------------------------------------------------- -function gl_account_types_list($name, $selected_id, $all_option, $all_option_name, - $all_option_numeric) +function gl_account_types_list($name, $selected_id=null, $all_option=false, $all_option_numeric=true) { - simple_codeandname_list("SELECT id, name FROM ".TB_PREF."chart_types ORDER BY id", - $name, $selected_id, $all_option, $all_option_name, $all_option_numeric); + global $all_items; + + $sql = "SELECT id, name FROM ".TB_PREF."chart_types"; + + return combo_input($name, $selected_id, $sql, 'id', 'name', + array( + 'order' => 'id', + 'spec_option' =>$all_option, + 'spec_id' => $all_option_numeric ? 0 : $all_items + ) ); } -function gl_account_types_list_cells($label, $name, $selected_id, $all_option=false, $all_option_name=null, +function gl_account_types_list_cells($label, $name, $selected_id=null, $all_option=false, $all_option_numeric=false) { if ($label != null) echo "$label\n"; echo ""; - gl_account_types_list($name, $selected_id, $all_option, $all_option_name, $all_option_numeric); + echo gl_account_types_list($name, $selected_id, $all_option, $all_option_numeric); echo "\n"; } -function gl_account_types_list_row($label, $name, $selected_id, $all_option=false, $all_option_name=null, +function gl_account_types_list_row($label, $name, $selected_id=null, $all_option=false, $all_option_numeric=false) { echo "\n"; - gl_account_types_list_cells($label, $name, $selected_id, $all_option, - $all_option_name, $all_option_numeric); + gl_account_types_list_cells($label, $name, $selected_id, $all_option, + $all_option_numeric); echo "\n"; } //----------------------------------------------------------------------------------------------- - -function gl_all_accounts_list($name, $selected_id, $skip_bank_accounts=false, - $show_group=false, $onchange="") +function gl_all_accounts_list($name, $selected_id=null, $skip_bank_accounts=false, + $cells=false, $all_option=false, $submit_on_change=false, $all=false) { - echo ""; - db_free_result($result); +function _format_account($row) +{ + return $row[0] . "    " . $row[1]; } -function gl_all_accounts_list_cells($label, $name, $selected_id, $skip_bank_accounts=false, - $show_group=false, $onchange="") +function gl_all_accounts_list_cells($label, $name, $selected_id=null, + $skip_bank_accounts=false, $cells=false, $all_option=false, + $submit_on_change=false, $all=false) { if ($label != null) echo "$label\n"; echo ""; - gl_all_accounts_list($name, $selected_id, $skip_bank_accounts, $show_group, $onchange); + echo gl_all_accounts_list($name, $selected_id, + $skip_bank_accounts, $cells, $all_option, $submit_on_change, $all); echo "\n"; } -function gl_all_accounts_list_row($label, $name, $selected_id, $skip_bank_accounts=false, - $show_group=false, $onchange="") +function gl_all_accounts_list_row($label, $name, $selected_id=null, + $skip_bank_accounts=false, $cells=false, $all_option=false) { echo "\n"; - gl_all_accounts_list_cells($label, $name, $selected_id, $skip_bank_accounts, - $show_group, $onchange); + gl_all_accounts_list_cells($label, $name, $selected_id, + $skip_bank_accounts, $cells, $all_option); echo "\n"; } -function yesno_list($name, $selected_id, $name_yes="", $name_no="", $submit_on_change=false) +function yesno_list($name, $selected_id=null, $name_yes="", $name_no="", $submit_on_change=false) { - if ($submit_on_change == true) - echo ""; + $items = array(); + $items['0'] = strlen($name_no) ? $name_no : _("No"); + $items['1'] = strlen($name_yes) ? $name_yes : _("Yes"); - if (strlen($name_yes) == 0) - { - unset($name_yes); - } - if (strlen($name_no) == 0) - { - unset($name_no); - } + return array_selector($name, $selected_id, $items, + array( + 'select_submit'=> $submit_on_change, + 'async' => false ) ); // FIX? +} - if ($selected_id == null) - $selected_id = (!isset($_POST[$name]) ? 0 : $_POST[$name]); - if ($selected_id == 0) - echo "\n"; - else - echo $name_yes . "\n"; - if ($selected_id == 0) - echo "\n"; - else - echo $name_no . "\n"; - echo ""; -} - -function yesno_list_cells($label, $name, $selected_id, $name_yes="", $name_no="", $submit_on_change=false) +function yesno_list_cells($label, $name, $selected_id=null, $name_yes="", $name_no="", $submit_on_change=false) { if ($label != null) echo "$label\n"; echo ""; - yesno_list($name, $selected_id, $name_yes, $name_no, $submit_on_change); + echo yesno_list($name, $selected_id, $name_yes, $name_no, $submit_on_change); echo "\n"; } -function yesno_list_row($label, $name, $selected_id, $name_yes="", $name_no="", $submit_on_change=false) +function yesno_list_row($label, $name, $selected_id=null, $name_yes="", $name_no="", $submit_on_change=false) { echo "\n"; yesno_list_cells($label, $name, $selected_id, $name_yes, $name_no, $submit_on_change); @@ -1492,33 +1593,27 @@ function yesno_list_row($label, $name, $selected_id, $name_yes="", $name_no="", //------------------------------------------------------------------------------------------------ -function languages_list($name, &$selected_id) +function languages_list($name, $selected_id=null) { - global $installed_languages; + global $installed_languages; - echo ""; - - if ($selected_id == null) - $selected_id = (!isset($_POST[$name]) ? "" : $_POST[$name]); - foreach ($bank_account_types as $type) - { - echo "\n"; - } + return array_selector($name, $selected_id, $bank_account_types); } -function bank_account_types_list_cells($label, $name, $selected_id) +function bank_account_types_list_cells($label, $name, $selected_id=null) { if ($label != null) echo "$label\n"; echo ""; - bank_account_types_list($name, $selected_id); + echo bank_account_types_list($name, $selected_id); echo "\n"; } -function bank_account_types_list_row($label, $name, $selected_id) +function bank_account_types_list_row($label, $name, $selected_id=null) { echo "\n"; bank_account_types_list_cells($label, $name, $selected_id); @@ -1561,42 +1646,30 @@ function bank_account_types_list_row($label, $name, $selected_id) } //------------------------------------------------------------------------------------------------ - -function payment_person_types_list($name, $selected_id, $related=null) +function payment_person_types_list($name, $selected_id=null, $submit_on_change=false) { - $types = payment_person_types::get_all(); + global $payment_person_types; - echo ""; - - if ($selected_id == null) - $selected_id = (!isset($_POST[$name]) ? "" : $_POST[$name]); - foreach ($types as $type) - { - echo "\n"; - } - echo ""; + global $wo_types_array; + + return array_selector($name, $selected_id, $wo_types_array, + array( 'select_submit'=> true, 'async' => true ) ); } -function wo_types_list_row($label, $name, &$selected_id) +function wo_types_list_row($label, $name, $selected_id=null) { echo "$label\n"; - wo_types_list($name, $selected_id); + echo wo_types_list($name, $selected_id); echo "\n"; } //------------------------------------------------------------------------------------------------ -function dateformats_list_row($label, $name, $value) +function dateformats_list_row($label, $name, $value=null) { - global $dateformats; + global $dateformats; - echo "$label\n"; - echo "\n"; + echo "$label\n"; + echo array_selector( $name, $value, $dateseps ); + echo "\n"; } -function dateseps_list_row($label, $name, $value) +function thoseps_list_row($label, $name, $value=null) { - global $dateseps; + global $thoseps; - echo "$label\n"; - echo "\n"; + echo "$label\n"; + echo array_selector( $name, $value, $decseps ); + echo "\n"; } -function thoseps_list_row($label, $name, $value) +function themes_list_row($label, $name, $value=null) { - global $thoseps; + global $path_to_root; - echo "$label\n"; - echo "\n"; + ksort($themes); + + echo "$label\n"; + echo array_selector( $name, $value, $themes ); + echo "\n"; } -function decseps_list_row($label, $name, $value) +function pagesizes_list_row($label, $name, $value=null) { - global $decseps; - - echo "$label\n"; - echo "\n"; + echo "$label\n"; + echo array_selector( $name, $value, $items ); + echo "\n"; } -function themes_list_row($label, $name, $value) +function systypes_list($name, $value=null, $spec_opt=false, $submit_on_change=false) { - global $themes; + global $systypes_array; - echo "$label\n"; - echo "\n"; +function systypes_list_row($label, $name, $value=null, $submit_on_change=false) +{ + echo "\n"; + systypes_list_cells($label, $name, $value, false, $submit_on_change); + echo "\n"; } -function pagesizes_list_row($label, $name, $value) +function journal_types_list_cells($label, $name, $value=null, $submit_on_change=false) { - global $pagesizes; + global $systypes_array; - echo "$label\n"; - echo "\n"; + // exclude quotes, orders and dimensions + foreach (array(ST_PURCHORDER, ST_WORKORDER, ST_SALESORDER, ST_DIMENSION, + ST_SALESQUOTE) as $excl) + unset($items[$excl]); + + echo array_selector($name, $value, $items, + array( + 'spec_option'=> _("All"), + 'spec_id' => -1, + 'select_submit'=> $submit_on_change, + 'async' => false + ) + ); + echo "\n"; } -function security_headings_list_row($label, $name, $value) +function cust_allocations_list_cells($label, $name, $selected=null) { - global $security_headings; + global $all_items; - echo "$label\n"; - echo "\n"; + echo "\n"; + $allocs = array( + $all_items=>_("All Types"), + '1'=> _("Invoices"), + '2'=> _("Overdue Invoices"), + '3' => _("Payments"), + '4' => _("Credit Notes"), + '5' => _("Overdue Credit Notes") + ); + echo array_selector($name, $selected, $allocs); + echo "\n"; } -function systypes_list_cells($label, $name, $value, $submit_on_change=false) +function policy_list_cells($label, $name, $selected=null) { - global $systypes_array; - if ($label != null) - echo "$label\n"; - echo "\n"; + label_cell($label); + echo "\n"; + echo array_selector($name, $selected, + array( '' => _("Automatically put balance on back order"), + 'CAN' => _("Cancel any quantites not delivered")) ); + echo "\n"; } -function systypes_list_row($label, $name, $value, $submit_on_change=false) +function policy_list_row($label, $name, $selected=null) { echo "\n"; - systypes_list_cells($label, $name, $value, $submit_on_change); + policy_list_cells($label, $name, $selected); echo "\n"; } -function cust_allocations_list_cells($label, $name, $selected) +function credit_type_list_cells($label, $name, $selected=null, $submit_on_change=false) { if ($label != null) label_cell($label); - if ($selected == null) - $selected = (!isset($_POST[$name]) ? "" : $_POST[$name]); - echo "\n"; -} - -function supp_allocations_list_cells($name, $selected) -{ - if ($selected == null) - $selected = (!isset($_POST[$name]) ? "" : $_POST[$name]); - echo "\n"; -} - -function policy_list_cells($label, $name, $selected) -{ - if ($selected == null) - { - $selected = (!isset($_POST[$name]) ? "" : $_POST[$name]); - if ($selected == "") - $_POST[$name] = $selected; - } + echo "\n"; + echo array_selector($name, $selected, + array( 'Return' => _("Items Returned to Inventory Location"), + 'WriteOff' => _("Items Written Off")), + array( 'select_submit'=> $submit_on_change ) ); + echo "\n"; +} + +function credit_type_list_row($label, $name, $selected=null, $submit_on_change=false) +{ + echo "\n"; + credit_type_list_cells($label, $name, $selected, $submit_on_change); + echo "\n"; +} + +function number_list($name, $selected, $from, $to, $no_option=false) +{ + $items = array(); + for ($i = $from; $i <= $to; $i++) + $items[$i] = "$i"; + + return array_selector($name, $selected, $items, + array( 'spec_option' => $no_option, + 'spec_id' => ALL_NUMERIC) ); +} + +function number_list_cells($label, $name, $selected, $from, $to, $no_option=false) +{ if ($label != null) label_cell($label); - echo "\n"; + echo "\n"; + echo number_list($name, $selected, $from, $to, $no_option); + echo "\n"; } -function policy_list_row($label, $name, $selected) +function number_list_row($label, $name, $selected, $from, $to, $no_option=false) { echo "\n"; - policy_list_cells($label, $name, $selected); + echo number_list_cells($label, $name, $selected, $from, $to, $no_option); echo "\n"; } -function credit_type_list_cells($label, $name, $selected, $submit_on_change=false) +function print_profiles_list_row($label, $name, $selected_id=null, $spec_opt=false, + $submit_on_change=true) { - if ($selected == null) - { - $selected = (!isset($_POST[$name]) ? "Return" : $_POST[$name]); - if ($selected == "Return") - $_POST[$name] = $selected; - } + $sql = "SELECT profile FROM ".TB_PREF."print_profiles" + ." GROUP BY profile"; + $result = db_query($sql, 'cannot get all profile names'); + $profiles = array(); + while($myrow=db_fetch($result)) { + $profiles[$myrow['profile']] = $myrow['profile']; + } + + echo ""; if ($label != null) - label_cell($label); - echo "\n"; + echo "$label\n"; + echo ""; + + echo array_selector($name, $selected_id, $profiles, + array( 'select_submit'=> $submit_on_change, + 'spec_option'=>$spec_opt, + 'spec_id' => '' + )); + + echo "\n"; +} + +function printers_list($name, $selected_id=null, $spec_opt=false, $submit_on_change=false) +{ + static $printers; // query only once for page display + + if (!$printers) { + $sql = "SELECT id, name, description FROM ".TB_PREF."printers"; + $result = db_query($sql, 'cannot get all printers'); + $printers = array(); + while($myrow=db_fetch($result)) { + $printers[$myrow['id']] = $myrow['name'].' - '.$myrow['description']; + } + } + return array_selector($name, $selected_id, $printers, + array( 'select_submit'=> $submit_on_change, + 'spec_option'=>$spec_opt, + 'spec_id' => '' + )); +} + +//------------------------------------------------------------------------------------------------ + +function quick_entries_list($name, $selected_id=null, $type=null, $submit_on_change=false) +{ + $where = false; + $sql = "SELECT id, description FROM ".TB_PREF."quick_entries"; + if ($type != null) + $sql .= " WHERE type=$type"; + + return combo_input($name, $selected_id, $sql, 'id', 'description', + array( + 'spec_id' => '', + 'order' => 'description', + 'select_submit'=> $submit_on_change, + 'async' => false + ) ); + +} + +function quick_entries_list_cells($label, $name, $selected_id=null, $type, $submit_on_change=false) +{ + echo "$label\n"; + echo quick_entries_list($name, $selected_id, $type, $submit_on_change); + echo ""; } -function credit_type_list_row($label, $name, $selected, $submit_on_change=false) +function quick_entries_list_row($label, $name, $selected_id=null, $type, $submit_on_change=false) { echo "\n"; - credit_type_list_cells($label, $name, $selected, $submit_on_change); + quick_entries_list_cells($label, $name, $selected_id, $type, $submit_on_change); echo "\n"; } -function number_list($name, $selected, $from, $to, $firstlabel="") + +function quick_actions_list_row($label, $name, $selected_id=null, $submit_on_change=false) { - if ($selected == null) - { - $selected = (!isset($_POST[$name]) ? $from : $_POST[$name]); - if ($selected == $from) - $_POST[$name] = $selected; - } - echo "\n"; + } + echo "\n"; + echo "$label\n"; + echo array_selector($name, $selected_id, $tabs); + echo "\n"; +} + +//----------------------------------------------------------------------------------------------- + +function tag_list($name, $height, $type, $multi=false, $all=false, $spec_opt = false) +{ + // Get tags + global $path_to_root; + include_once($path_to_root . "/admin/db/tags_db.inc"); + $results = get_tags($type, $all); + + while ($tag = db_fetch($results)) + $tags[$tag['id']] = $tag['name']; + + if (!isset($tags)) { + $tags[''] = $all ? _("No tags defined.") : _("No active tags defined."); + $spec_opt = false; + } + return array_selector($name, null, $tags, + array( + 'multi' => $multi, + 'height' => $height, + 'spec_option'=> $spec_opt, + 'spec_id' => -1, + ) ); } -function number_list_cells($label, $name, $selected, $from, $to) +function tag_list_cells($label, $name, $height, $type, $mult=false, $all=false, $spec_opt = false) { if ($label != null) - label_cell($label); + echo "$label\n"; echo "\n"; - number_list($name, $selected, $from, $to); + echo tag_list($name, $height, $type, $mult, $all, $spec_opt); echo "\n"; -} + +} -function number_list_row($label, $name, $selected, $from, $to) +function tag_list_row($label, $name, $height, $type, $mult=false, $all=false, $spec_opt = false) { echo "\n"; - number_list_cells($label, $name, $selected, $from, $to); - echo "\n"; + tag_list_cells($label, $name, $height, $type, $mult, $all, $spec_opt); + echo "\n"; +} + +//--------------------------------------------------------------------------------------------- +// List of sets of active extensions +// +function extset_list($name, $value=null, $submit_on_change=false) +{ + global $db_connections; + + $items = array(); + foreach ($db_connections as $comp) + $items[] = sprintf(_("Activated for '%s'"), $comp['name']); + return array_selector( $name, $value, $items, + array( + 'spec_option'=> _("Installed on system"), + 'spec_id' => -1, + 'select_submit'=> $submit_on_change, + 'async' => true + )); } + ?> \ No newline at end of file