. ***********************************************************************/ 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 fragment inside id // 1 - with hidden search box, search by option text // 2 - with (optional) visible search box, search by fragment at the start of id // 3 - 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. 'editable' => false // false, or length of editable entry field ); // ------ 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']; // select content filtered by search field: $search_submit = $opts['search_submit']===true ? '_'.$name.'_button' : $opts['search_submit']; // select set by select content field $search_button = $opts['editable'] ? '_'.$name.'_button' : ($search_box ? $search_submit : false); $select_submit = $opts['select_submit']; $spec_id = $opts['spec_id']; $spec_option = $opts['spec_option']; if ($opts['type'] == 0) { $by_id = true; $class = 'combo'; } elseif($opts['type'] == 1) { $by_id = false; $class = 'combo2'; } else { $by_id = true; $class = 'combo3'; } $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'); 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')) :''; if ($selected_id == null) { $selected_id = get_post($name, (string)$opts['default']); } if(!is_array($selected_id)) $selected_id = array((string)$selected_id); // code is generalized for multiple selection support $txt = get_post($search_box); $rel = ''; $limit = ''; if (isset($_POST['_'.$name.'_update'])) { // select list or search box change if ($by_id) $txt = $_POST[$name]; if (!$opts['async']) $Ajax->activate('_page_body'); else $Ajax->activate($name); } if (isset($_POST[$search_button])) { 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_button])) { $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 . "=". db_escape(get_post($name, $spec_id)); } else if ($txt != '*') { foreach($opts['search'] as $i=> $s) $opts['search'][$i] = $s . " LIKE " .db_escape(($class=='combo3' ? '' : '%').$txt.'%'); $opts['where'][] = '('. implode($opts['search'], ' OR ') . ')'; } } } // sql completion if (count($opts['where'])) { $where = strpos($sql, 'WHERE')==false ? ' WHERE ':' AND '; $where .= '('. implode($opts['where'], ' AND ') . ')'; $group_pos = strpos($sql, 'GROUP BY'); if ($group_pos) { $group = substr($sql, $group_pos); $sql = substr($sql, 0, $group_pos) . $where.' '.$group; } else { $sql .= $where; } } if ($opts['order'] != false) { if (!is_array($opts['order'])) $opts['order'] = array($opts['order']); $sql .= ' ORDER BY '.implode(',',$opts['order']); } $sql .= $limit; // ------ make selector ---------- $selector = $first_opt = ''; $first_id = false; $found = false; $lastcat = null; $edit = false; //if($name=='stock_id') display_notification('
'.print_r($_POST, true).'
'); //if($name=='curr_default') display_notification($opts['search_submit']); 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_button) && ($txt == $value)) { $selected_id[] = $value; } if (in_array((string)$value, $selected_id, true)) { $sel = 'selected'; $found = $value; $edit = $opts['editable'] && $contact_row['editable'] && (@$_POST[$search_box] == $value) ? $contact_row[1] : false; // get non-formatted description if ($edit) break; // selected field is editable - abandon list construction } // 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); } // 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; } if ($found===false) { $selected_id = array($first_id); } $_POST[$name] = $multi ? $selected_id : $selected_id[0]; $selector = "\n"; if ($by_id && ($search_box != false || $opts['editable']) ) { // on first display show selector list if (isset($_POST[$search_box]) && $opts['editable'] && $edit) { $selector = "" ."\n"; set_focus($name.'_text'); // prevent lost focus } else if (get_post($search_submit ? $search_submit : "_{$name}_button")) set_focus($name); // prevent lost focus if (!$opts['editable']) $txt = $found; $Ajax->addUpdate($name, $search_box, $txt ? $txt : ''); } $Ajax->addUpdate($name, "_{$name}_sel", $selector); // span for select list/input field update $selector = "".$selector."\n"; // if selectable or editable list is used - add select button if ($select_submit != false || $search_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 || $opts['editable']) { global $_search_button; $edit_entry .= sprintf($_search_button, $disabled, user_theme(), (fallback_mode() ? '' : 'display:none;'), $search_submit ? $search_submit : "_{$name}_button")."\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; } /* Helper function. Returns true if selector $name is subject to update. */ function list_updated($name) { 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((string)$selected_id); // code is generalized for multiple selection support if (isset($_POST[ '_'.$name.'_update'])) { if (!$opts['async']) $Ajax->activate('_page_body'); else $Ajax->activate($name); } // ------ 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, true)) { $sel = 'selected'; $found = $value; } if ($first_id === false) { $first_id = $value; $first_opt = $descr; } $selector .= "\n"; } if ($first_id!==false) { $sel = ($found===$first_id) || ($found===false && ($spec_option===false)) ? "selected='selected'" : ''; $selector = sprintf($first_opt, $sel).$selector; } // 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 ($found===false) { $selected_id = array($first_id); } $_POST[$name] = $multi ? $selected_id : $selected_id[0]; $selector = "\n"; $Ajax->addUpdate($name, "_{$name}_sel", $selector); $selector = "".$selector."\n"; 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; } //---------------------------------------------------------------------------------------------- function _format_add_curr($row) { static $company_currency; if ($company_currency == null) { $company_currency = get_company_currency(); } return $row[1] . ($row[2] == $company_currency ? '' : (" - " . $row[2])); } function add_edit_combo($type) { global $path_to_root, $popup_editors, $use_icon_for_editkey; if (!isset($use_icon_for_editkey) || $use_icon_for_editkey==0) return ""; // Derive theme path $theme_path = $path_to_root . '/themes/' . user_theme(); $key = $popup_editors[$type][1]; $onclick = "onclick=\"javascript:callEditor($key); return false;\""; $img = "Add/Edit"; return "$img"; } function supplier_list($name, $selected_id=null, $spec_option=false, $submit_on_change=false, $all=false, $editkey = false) { 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); $ret = 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, 'search' => array("supp_ref","supp_name","gst_no"), '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 )); if ($editkey) $ret .= add_edit_combo('supplier'); return $ret; } function supplier_list_cells($label, $name, $selected_id=null, $all_option=false, $submit_on_change=false, $all=false, $editkey = false) { 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_list($name, $selected_id=null, $spec_option=false, $submit_on_change=false, $show_inactive=false, $editkey = false) { global $all_items; $sql = "SELECT debtor_no, debtor_ref, curr_code, inactive FROM ".TB_PREF."debtors_master "; $mode = get_company_pref('no_customer_list'); if ($editkey) set_editor('customer', $name, $editkey); $ret = combo_input($name, $selected_id, $sql, 'debtor_no', 'debtor_ref', array( 'format' => '_format_add_curr', 'order' => array('debtor_ref'), 'search_box' => $mode!=0, 'type' => 1, 'size' => 20, 'search' => array("debtor_ref","name","tax_id"), '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 ) ); if ($editkey) $ret .= add_edit_combo('customer'); return $ret; } 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 ""; echo customer_list($name, $selected_id, $all_option, $submit_on_change, $show_inactive, $editkey); echo "\n"; } function customer_list_row($label, $name, $selected_id=null, $all_option = false, $submit_on_change=false, $show_inactive=false, $editkey = false) { echo "$label"; echo customer_list($name, $selected_id, $all_option, $submit_on_change, $show_inactive, $editkey); echo "\n\n"; } //------------------------------------------------------------------------------------------------ function customer_branches_list($customer_id, $name, $selected_id=null, $spec_option = true, $enabled=true, $submit_on_change=false, $editkey = false) { global $all_items; $sql = "SELECT branch_code, branch_ref FROM ".TB_PREF."cust_branch WHERE debtor_no=" . db_escape($customer_id)." "; if ($editkey) set_editor('branch', $name, $editkey); $where = $enabled ? array("inactive = 0") : array(); $ret = combo_input($name, $selected_id, $sql, 'branch_code', 'branch_ref', 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 ($editkey) { $ret .= add_edit_combo('branch'); } return $ret; } //------------------------------------------------------------------------------------------------ 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"; } function customer_branches_list_row($label, $customer_id, $name, $selected_id=null, $all_option = true, $enabled=true, $submit_on_change=false, $editkey = false) { echo "$label"; customer_branches_list_cells(null, $customer_id, $name, $selected_id, $all_option, $enabled, $submit_on_change, $editkey); 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"; 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=null, $all_option=false, $submit_on_change=false) { if ($label != null) echo "$label\n"; echo ""; echo locations_list($name, $selected_id, $all_option, $submit_on_change); echo "\n"; } function locations_list_row($label, $name, $selected_id=null, $all_option=false, $submit_on_change=false) { echo "$label"; locations_list_cells(null, $name, $selected_id, $all_option, $submit_on_change); echo "\n"; } //----------------------------------------------------------------------------------------------- function currencies_list($name, $selected_id=null, $submit_on_change=false) { $sql = "SELECT curr_abrev, currency, inactive FROM ".TB_PREF."currencies"; // default to the company currency 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=null, $submit_on_change=false) { if ($label != null) echo "$label\n"; echo ""; echo currencies_list($name, $selected_id, $submit_on_change); echo "\n"; } function currencies_list_row($label, $name, $selected_id=null, $submit_on_change=false) { echo "$label"; currencies_list_cells(null, $name, $selected_id, $submit_on_change); echo "\n"; } //--------------------------------------------------------------------------------------------------- function fiscalyears_list($name, $selected_id=null, $submit_on_change=false) { $sql = "SELECT * FROM ".TB_PREF."fiscal_year"; // default to the company current fiscal year 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 ) ); } function _format_fiscalyears($row) { return sql2date($row[1]) . " - " . sql2date($row[2]) . "  " . ($row[3] ? _('Closed') : _('Active')) . "\n"; } function fiscalyears_list_cells($label, $name, $selected_id=null) { if ($label != null) echo "$label\n"; echo ""; echo fiscalyears_list($name, $selected_id); echo "\n"; } function fiscalyears_list_row($label, $name, $selected_id=null) { echo "$label"; fiscalyears_list_cells(null, $name, $selected_id); echo "\n"; } //------------------------------------------------------------------------------------ function dimensions_list($name, $selected_id=null, $no_option=false, $showname=' ', $submit_on_change=false, $showclosed=false, $showtype=1) { $sql = "SELECT id, CONCAT(reference,' ',name) as ref FROM ".TB_PREF."dimensions"; $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_=".db_escape($showtype); return combo_input($name, $selected_id, $sql, 'id', 'ref', $options); } 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 ""; echo dimensions_list($name, $selected_id, $no_option, $showname, $submit_on_change, $showclosed, $showtype); echo "\n"; } function dimensions_list_row($label, $name, $selected_id=null, $no_option=false, $showname=null, $showclosed=false, $showtype=0, $submit_on_change=false) { echo "$label"; dimensions_list_cells(null, $name, $selected_id, $no_option, $showname, $showclosed, $showtype, $submit_on_change); echo "\n"; } //--------------------------------------------------------------------------------------------------- function stock_items_list($name, $selected_id=null, $all_option=false, $submit_on_change=false, $opts=array(), $editkey = false) { global $all_items; $sql = "SELECT stock_id, s.description, c.description, s.inactive, s.editable FROM ".TB_PREF."stock_master s,".TB_PREF."stock_category c WHERE s.category_id=c.category_id"; if ($editkey) set_editor('item', $name, $editkey); $ret = combo_input($name, $selected_id, $sql, 'stock_id', 's.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("stock_id", "c.description","s.description"), 'search_submit' => get_company_pref('no_item_list')!=0, 'size'=>10, 'select_submit'=> $submit_on_change, 'category' => 2, 'order' => array('c.description','stock_id') ), $opts) ); if ($editkey) $ret .= add_edit_combo('item'); return $ret; } function _format_stock_items($row) { return (user_show_codes() ? ($row[0] . " - ") : "") . $row[1]; } function stock_items_list_cells($label, $name, $selected_id=null, $all_option=false, $submit_on_change=false, $all=false, $editkey = false) { if ($label != null) echo "$label\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=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"; } */ //--------------------------------------------------------------------------------------------------- // // 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, if(count(*)>1, '0', s.editable) as editable 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 ($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'), 'editable' => 30, 'max' => 255 ), $opts) ); } function sales_items_list_cells($label, $name, $selected_id=null, $all_option=false, $submit_on_change=false, $editkey=false) { if ($editkey) set_editor('item', $name, $editkey); if ($label != null) echo "$label\n"; echo sales_items_list($name, $selected_id, $all_option, $submit_on_change, '', array('cells'=>true)); } 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, 'editable' => false)); } 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, 'editable' => false)); echo ""; } //------------------------------------------------------------------------------------ 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_manufactured_items_list_cells($label, $name, $selected_id=null, $all_option=false, $submit_on_change=false) { if ($label != null) echo "$label\n"; echo ""; echo stock_manufactured_items_list($name, $selected_id, $all_option, $submit_on_change); echo "\n"; } function stock_manufactured_items_list_row($label, $name, $selected_id=null, $all_option=false, $submit_on_change=false) { echo "$label"; stock_manufactured_items_list_cells(null, $name, $selected_id, $all_option, $submit_on_change); echo "\n"; } //------------------------------------------------------------------------------------ function stock_component_items_list($name, $parent_stock_id, $selected_id=null, $all_option=false, $submit_on_change=false, $editkey = false) { return stock_items_list($name, $selected_id, $all_option, $submit_on_change, array('where'=>array("stock_id != ".db_escape($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 != ".db_escape($parent_stock_id)), 'cells'=>true), $editkey); } //------------------------------------------------------------------------------------ function stock_costable_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!='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)); } //------------------------------------------------------------------------------------ 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("NOT no_purchase"), 'show_inactive'=>$all), $editkey); } // // This helper is used in PO/GRN/PI entry and supports editable descriptions. // 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_items_list($name, $selected_id, $all_option, $submit_on_change, array('where'=>array("NOT no_purchase"), 'editable' => 30, 'cells'=>true), $editkey); } /* function stock_purchasable_items_list_row($label, $name, $selected_id=null, $all_option=false, $submit_on_change=false, $editkey=false) { echo "$label"; stock_purchasable_items_list_cells(null, $name, $selected_id=null, $all_option, $submit_on_change, $editkey); echo "\n"; } */ //------------------------------------------------------------------------------------ function stock_item_types_list_row($label, $name, $selected_id=null, $enabled=true) { global $stock_types; 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 tax_types_list($name, $selected_id=null, $none_option=false, $submit_on_change=false) { $sql = "SELECT id, CONCAT(name, ' (',rate,'%)') as name FROM ".TB_PREF."tax_types"; 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 tax_types_list_cells($label, $name, $selected_id=null, $none_option=false, $submit_on_change=false) { if ($label != null) echo "$label\n"; echo ""; echo tax_types_list($name, $selected_id, $none_option, $submit_on_change); echo "\n"; } function tax_types_list_row($label, $name, $selected_id=null, $none_option=false, $submit_on_change=false) { echo "$label"; tax_types_list_cells(null, $name, $selected_id, $none_option, $submit_on_change); echo "\n"; } //------------------------------------------------------------------------------------ function tax_groups_list($name, $selected_id=null, $none_option=false, $submit_on_change=false) { $sql = "SELECT id, name FROM ".TB_PREF."tax_groups"; 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 tax_groups_list_cells($label, $name, $selected_id=null, $none_option=false, $submit_on_change=false) { if ($label != null) echo "$label\n"; echo ""; echo tax_groups_list($name, $selected_id, $none_option, $submit_on_change); echo "\n"; } function tax_groups_list_row($label, $name, $selected_id=null, $none_option=false, $submit_on_change=false) { echo "$label"; tax_groups_list_cells(null, $name, $selected_id, $none_option, $submit_on_change); echo "\n"; } //------------------------------------------------------------------------------------ function item_tax_types_list($name, $selected_id=null) { $sql ="SELECT id, name FROM ".TB_PREF."item_tax_types"; return combo_input($name, $selected_id, $sql, 'id', 'name', array('order' => 'id') ); } function item_tax_types_list_cells($label, $name, $selected_id=null) { if ($label != null) echo "$label\n"; echo ""; echo item_tax_types_list($name, $selected_id); echo "\n"; } function item_tax_types_list_row($label, $name, $selected_id=null) { echo "$label"; item_tax_types_list_cells(null, $name, $selected_id); echo "\n"; } //------------------------------------------------------------------------------------ function shippers_list($name, $selected_id=null) { $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 shippers_list_cells($label, $name, $selected_id=null) { if ($label != null) echo "$label\n"; echo ""; echo shippers_list($name, $selected_id); echo "\n"; } function shippers_list_row($label, $name, $selected_id=null) { echo "$label"; shippers_list_cells(null, $name, $selected_id); echo "\n"; } //------------------------------------------------------------------------------------- function sales_persons_list($name, $selected_id=null, $spec_opt=false) { $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 sales_persons_list_cells($label, $name, $selected_id=null, $spec_opt=false) { if ($label != null) echo "$label\n"; echo "\n"; echo sales_persons_list($name, $selected_id, $spec_opt); echo "\n"; } function sales_persons_list_row($label, $name, $selected_id=null, $spec_opt=false) { echo "$label"; sales_persons_list_cells(null, $name, $selected_id, $spec_opt); echo "\n"; } //------------------------------------------------------------------------------------ function sales_areas_list($name, $selected_id=null) { $sql = "SELECT area_code, description, inactive FROM ".TB_PREF."areas"; return combo_input($name, $selected_id, $sql, 'area_code', 'description', array()); } function sales_areas_list_cells($label, $name, $selected_id=null) { if ($label != null) echo "$label\n"; echo ""; echo sales_areas_list($name, $selected_id); echo "\n"; } function sales_areas_list_row($label, $name, $selected_id=null) { echo "$label"; sales_areas_list_cells(null, $name, $selected_id); echo "\n"; } //------------------------------------------------------------------------------------ function sales_groups_list($name, $selected_id=null, $special_option=false) { $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_groups_list_cells($label, $name, $selected_id=null, $special_option=false) { if ($label != null) echo "$label\n"; echo ""; echo sales_groups_list($name, $selected_id, $special_option); echo "\n"; } function sales_groups_list_row($label, $name, $selected_id=null, $special_option=false) { echo "$label"; sales_groups_list_cells(null, $name, $selected_id, $special_option); echo "\n"; } //------------------------------------------------------------------------------------ function _format_template_items($row) { return ($row[0] . " -  " . _("Amount") . " ".$row[1]); } function templates_list($name, $selected_id=null, $special_option=false) { $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 templates_list_cells($label, $name, $selected_id=null, $special_option=false) { if ($label != null) echo "$label\n"; echo ""; echo templates_list($name, $selected_id, $special_option); echo "\n"; } function templates_list_row($label, $name, $selected_id=null, $special_option=false) { echo "$label"; templates_list_cells(null, $name, $selected_id, $special_option); echo "\n"; } //------------------------------------------------------------------------------------ function workorders_list($name, $selected_id=null) { $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=null) { if ($label != null) echo "$label\n"; echo ""; echo workorders_list($name, $selected_id); echo "\n"; } function workorders_list_row($label, $name, $selected_id=null) { echo "$label"; workorders_list_cells(null, $name, $selected_id); echo "\n"; } //------------------------------------------------------------------------------------ function payment_terms_list($name, $selected_id=null) { $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=null) { if ($label != null) echo "$label\n"; echo ""; echo payment_terms_list($name, $selected_id); echo "\n"; } function payment_terms_list_row($label, $name, $selected_id=null) { echo "$label"; payment_terms_list_cells(null, $name, $selected_id); echo "\n"; } //------------------------------------------------------------------------------------ function credit_status_list($name, $selected_id=null) { $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=null) { if ($label != null) echo "$label\n"; echo ""; echo credit_status_list($name, $selected_id); echo "\n"; } function credit_status_list_row($label, $name, $selected_id=null) { echo "$label"; credit_status_list_cells(null, $name, $selected_id); echo "\n"; } //----------------------------------------------------------------------------------------------- function sales_types_list($name, $selected_id=null, $submit_on_change=false, $special_option=false) { $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=null, $submit_on_change=false, $special_option=false) { if ($label != null) echo "$label\n"; echo ""; echo sales_types_list($name, $selected_id, $submit_on_change, $special_option); echo "\n"; } function sales_types_list_row($label, $name, $selected_id=null, $submit_on_change=false, $special_option=false) { echo "$label"; sales_types_list_cells(null, $name, $selected_id, $submit_on_change, $special_option); echo "\n"; } //----------------------------------------------------------------------------------------------- function movement_types_list($name, $selected_id=null) { $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=null) { if ($label != null) echo "$label\n"; echo ""; echo movement_types_list($name, $selected_id); echo "\n"; } function movement_types_list_row($label, $name, $selected_id=null) { echo "$label"; movement_types_list_cells(null, $name, $selected_id); echo "\n"; } //----------------------------------------------------------------------------------------------- function _format_date($row) { return sql2date($row['reconciled']); } function bank_reconciliation_list($account, $name, $selected_id=null, $submit_on_change=false, $special_option=false) { $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_reconciliation_list_cells($label,$account, $name, $selected_id=null, $submit_on_change=false, $special_option=false) { if ($label != null) echo "$label\n"; echo ""; echo bank_reconciliation_list($account, $name, $selected_id, $submit_on_change, $special_option); echo "\n"; } /* function bank_reconciliation_list_row($label, $account, $name, $selected_id=null, $submit_on_change=false, $special_option=false) { echo "\n"; bank_reconciliation_list_cells($label, $account, $name, $selected_id, $submit_on_change, $special_option); echo "\n"; } */ //----------------------------------------------------------------------------------------------- function workcenter_list($name, $selected_id=null, $all_option=false) { global $all_items; $sql = "SELECT id, name, inactive FROM ".TB_PREF."workcentres"; 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=null, $all_option=false) { default_focus($name); if ($label != null) echo "$label\n"; echo ""; echo workcenter_list($name, $selected_id, $all_option); echo "\n"; } function workcenter_list_row($label, $name, $selected_id=null, $all_option=false) { echo "$label"; workcenter_list_cells(null, $name, $selected_id, $all_option); echo "\n"; } //----------------------------------------------------------------------------------------------- function bank_accounts_list($name, $selected_id=null, $submit_on_change=false, $spec_option=false) { $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, 'spec_option' => $spec_option, 'spec_id' => '', '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 "$label"; bank_accounts_list_cells(null, $name, $selected_id, $submit_on_change); echo "\n"; } //----------------------------------------------------------------------------------------------- function cash_accounts_list_row($label, $name, $selected_id=null, $submit_on_change=false, $all_option=false) { global $all_items; $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=".BT_CASH; if ($label != null) echo "$label\n"; echo ""; echo combo_input($name, $selected_id, $sql, 'id', 'bank_account_name', array( 'spec_option' => $all_option, 'spec_id' => $all_items, 'format' => '_format_add_curr', 'select_submit'=> $submit_on_change, 'async' => true ) ); echo "\n"; } //----------------------------------------------------------------------------------------------- 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"; default_focus($name); echo ''; if ($label != null) echo "$label\n"; echo ""; 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"; } //----------------------------------------------------------------------------------------------- // Payment type selector for current user. // function sale_payment_list($name, $category, $selected_id=null, $submit_on_change=true, $prepayments=true) { $sql = "SELECT terms_indicator, terms, inactive FROM ".TB_PREF."payment_terms"; if ($category == PM_CASH) // only cash $sql .= " WHERE days_before_due=0 AND day_in_following_month=0"; elseif ($category == PM_CREDIT) // only delayed payments $sql .= " WHERE days_before_due".($prepayments ? '!=': '>')."0 OR day_in_following_month!=0"; elseif (!$prepayments) $sql .= " WHERE days_before_due>=0"; return combo_input($name, $selected_id, $sql, 'terms_indicator', 'terms', array( 'select_submit'=> $submit_on_change, 'async' => true ) ); } function sale_payment_list_cells($label, $name, $category, $selected_id=null, $submit_on_change=true, $prepayments=true) { if ($label != null) echo "$label\n"; echo ""; echo sale_payment_list($name, $category, $selected_id, $submit_on_change, $prepayments); echo "\n"; } //----------------------------------------------------------------------------------------------- function class_list($name, $selected_id=null, $submit_on_change=false) { $sql = "SELECT cid, class_name FROM ".TB_PREF."chart_class"; return combo_input($name, $selected_id, $sql, 'cid', 'class_name', array( 'select_submit'=> $submit_on_change, 'async' => false ) ); } function class_list_cells($label, $name, $selected_id=null, $submit_on_change=false) { if ($label != null) echo "$label\n"; echo ""; echo class_list($name, $selected_id, $submit_on_change); echo "\n"; } function class_list_row($label, $name, $selected_id=null, $submit_on_change=false) { echo "$label"; class_list_cells(null, $name, $selected_id, $submit_on_change); echo "\n"; } //----------------------------------------------------------------------------------------------- function stock_categories_list($name, $selected_id=null, $spec_opt=false, $submit_on_change=false) { $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=null, $spec_opt=false, $submit_on_change=false) { if ($label != null) echo "$label\n"; echo ""; echo stock_categories_list($name, $selected_id, $spec_opt, $submit_on_change); echo "\n"; } function stock_categories_list_row($label, $name, $selected_id=null, $spec_opt=false, $submit_on_change=false) { echo "$label"; stock_categories_list_cells(null, $name, $selected_id, $spec_opt, $submit_on_change); echo "\n"; } //----------------------------------------------------------------------------------------------- function gl_account_types_list($name, $selected_id=null, $all_option=false, $all=true) { global $all_items; $sql = "SELECT id, name FROM ".TB_PREF."chart_types"; return combo_input($name, $selected_id, $sql, 'id', 'name', array( 'format' => '_format_account', 'order' => array('class_id', 'id', 'parent'), 'spec_option' =>$all_option, 'spec_id' => $all_items ) ); } function gl_account_types_list_cells($label, $name, $selected_id=null, $all_option=false, $all=false) { if ($label != null) echo "$label\n"; echo ""; echo gl_account_types_list($name, $selected_id, $all_option, $all); echo "\n"; } function gl_account_types_list_row($label, $name, $selected_id=null, $all_option=false, $all=false) { echo "$label"; gl_account_types_list_cells(null, $name, $selected_id, $all_option, $all); echo "\n"; } //----------------------------------------------------------------------------------------------- function gl_all_accounts_list($name, $selected_id=null, $skip_bank_accounts=false, $cells=false, $all_option=false, $submit_on_change=false, $all=false) { if ($skip_bank_accounts) $sql = "SELECT chart.account_code, chart.account_name, type.name, chart.inactive, type.id FROM (".TB_PREF."chart_master chart,".TB_PREF."chart_types type) " ."LEFT JOIN ".TB_PREF."bank_accounts acc " ."ON chart.account_code=acc.account_code WHERE acc.account_code IS NULL AND chart.account_type=type.id"; else $sql = "SELECT chart.account_code, chart.account_name, type.name, chart.inactive, type.id FROM ".TB_PREF."chart_master chart,".TB_PREF."chart_types type WHERE chart.account_type=type.id"; return combo_input($name, $selected_id, $sql, 'chart.account_code', 'chart.account_name', array( 'format' => '_format_account', 'spec_option' => $all_option===true ? _("Use Item Sales Accounts") : $all_option, 'spec_id' => '', 'type' => 2, 'order' => array('type.class_id','type.id','account_code'), 'search_box' => $cells, 'search_submit' => false, 'size' => 12, 'max' => 10, 'cells' => true, 'select_submit'=> $submit_on_change, 'async' => false, 'category' => 2, 'show_inactive' => $all ) ); } function _format_account($row) { return $row[0] . "    " . $row[1]; } 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 ""; 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=null, $skip_bank_accounts=false, $cells=false, $all_option=false) { echo "$label"; gl_all_accounts_list_cells(null, $name, $selected_id, $skip_bank_accounts, $cells, $all_option); echo "\n"; } function yesno_list($name, $selected_id=null, $name_yes="", $name_no="", $submit_on_change=false) { $items = array(); $items['0'] = strlen($name_no) ? $name_no : _("No"); $items['1'] = strlen($name_yes) ? $name_yes : _("Yes"); return array_selector($name, $selected_id, $items, array( 'select_submit'=> $submit_on_change, 'async' => false ) ); // FIX? } function yesno_list_cells($label, $name, $selected_id=null, $name_yes="", $name_no="", $submit_on_change=false) { if ($label != null) echo "$label\n"; echo ""; echo yesno_list($name, $selected_id, $name_yes, $name_no, $submit_on_change); echo "\n"; } function yesno_list_row($label, $name, $selected_id=null, $name_yes="", $name_no="", $submit_on_change=false) { echo "$label"; yesno_list_cells(null, $name, $selected_id, $name_yes, $name_no, $submit_on_change); echo "\n"; } //------------------------------------------------------------------------------------------------ function languages_list($name, $selected_id=null, $all_option=false) { global $installed_languages; $items = array(); if ($all_option) $items[''] = $all_option; foreach ($installed_languages as $lang) $items[$lang['code']] = $lang['name']; return array_selector($name, $selected_id, $items); } function languages_list_cells($label, $name, $selected_id=null, $all_option=false) { if ($label != null) echo "$label\n"; echo ""; echo languages_list($name, $selected_id, $all_option); echo "\n"; } function languages_list_row($label, $name, $selected_id=null, $all_option=false) { echo "$label"; languages_list_cells(null, $name, $selected_id, $all_option); echo "\n"; } //------------------------------------------------------------------------------------------------ function bank_account_types_list($name, $selected_id=null) { global $bank_account_types; return array_selector($name, $selected_id, $bank_account_types); } function bank_account_types_list_cells($label, $name, $selected_id=null) { if ($label != null) echo "$label\n"; echo ""; echo bank_account_types_list($name, $selected_id); echo "\n"; } function bank_account_types_list_row($label, $name, $selected_id=null) { echo "$label"; bank_account_types_list_cells(null, $name, $selected_id); echo "\n"; } //------------------------------------------------------------------------------------------------ function payment_person_types_list($name, $selected_id=null, $submit_on_change=false) { global $payment_person_types; $items = array(); foreach ($payment_person_types as $key=>$type) { if ($key != PT_WORKORDER) $items[$key] = $type; } return array_selector($name, $selected_id, $items, array( 'select_submit'=> $submit_on_change ) ); } function payment_person_types_list_cells($label, $name, $selected_id=null, $related=null) { if ($label != null) echo "$label\n"; echo ""; echo payment_person_types_list($name, $selected_id, $related); echo "\n"; } function payment_person_types_list_row($label, $name, $selected_id=null, $related=null) { echo "$label"; payment_person_types_list_cells(null, $name, $selected_id, $related); echo "\n"; } //------------------------------------------------------------------------------------------------ function wo_types_list($name, $selected_id=null) { 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=null) { echo "$label\n"; echo wo_types_list($name, $selected_id); echo "\n"; } //------------------------------------------------------------------------------------------------ function dateformats_list_row($label, $name, $value=null) { global $dateformats; echo "$label\n"; echo array_selector( $name, $value, $dateformats ); echo "\n"; } function dateseps_list_row($label, $name, $value=null) { global $dateseps; echo "$label\n"; echo array_selector( $name, $value, $dateseps ); echo "\n"; } function thoseps_list_row($label, $name, $value=null) { global $thoseps; echo "$label\n"; echo array_selector( $name, $value, $thoseps ); echo "\n"; } function decseps_list_row($label, $name, $value=null) { global $decseps; echo "$label\n"; echo array_selector( $name, $value, $decseps ); echo "\n"; } function themes_list_row($label, $name, $value=null) { global $path_to_root; $path = $path_to_root.'/themes/'; $themes = array(); $themedir = opendir($path); while(false !== ($fname = readdir($themedir))) { if($fname!='.' && $fname!='..' && $fname!='CVS' && is_dir($path.$fname)) { $themes[$fname] = $fname; } } ksort($themes); echo "$label\n"; echo array_selector( $name, $value, $themes ); echo "\n"; } function pagesizes_list_row($label, $name, $value=null) { global $pagesizes; $items = array(); foreach ($pagesizes as $pz) $items[$pz] = $pz; echo "$label\n"; echo array_selector( $name, $value, $items ); echo "\n"; } function systypes_list($name, $value=null, $spec_opt=false, $submit_on_change=false, $exclude=array()) { global $systypes_array; // emove non-voidable transactions if needed $systypes = array_diff_key($systypes_array, array_flip($exclude)); return array_selector($name, $value, $systypes, array( 'spec_option'=> $spec_opt, 'spec_id' => ALL_NUMERIC, 'select_submit'=> $submit_on_change, 'async' => false, ) ); } function systypes_list_cells($label, $name, $value=null, $submit_on_change=false, $exclude=array()) { if ($label != null) echo "$label\n"; echo ""; echo systypes_list($name, $value, false, $submit_on_change, $exclude); echo "\n"; } function systypes_list_row($label, $name, $value=null, $submit_on_change=false, $exclude=array()) { echo "$label"; systypes_list_cells(null, $name, $value, $submit_on_change, $exclude); echo "\n"; } function journal_types_list_cells($label, $name, $value=null, $submit_on_change=false) { global $systypes_array; if ($label != null) echo "$label\n"; echo ""; $items = $systypes_array; // exclude quotes, orders and dimensions foreach (array(ST_PURCHORDER, ST_SALESORDER, ST_DIMENSION, ST_SALESQUOTE, ST_LOCTRANSFER) 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 cust_allocations_list_cells($label, $name, $selected=null) { global $all_items; if ($label != null) label_cell($label); echo "\n"; $allocs = array( $all_items=>_("All Types"), '1'=> _("Sales Invoices"), '2'=> _("Overdue Invoices"), '3' => _("Payments"), '4' => _("Credit Notes"), '5' => _("Delivery Notes") ); echo array_selector($name, $selected, $allocs); echo "\n"; } function supp_allocations_list_cell($name, $selected=null) { global $all_items; 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 supp_transactions_list_cell($name, $selected=null) { global $all_items; echo "\n"; $allocs = array( $all_items=>_("All Types"), '6'=>_("GRNs"), '1'=> _("Invoices"), '2'=> _("Overdue Invoices"), '3' => _("Payments"), '4' => _("Credit Notes"), '5' => _("Overdue Credit Notes") ); echo array_selector($name, $selected, $allocs); echo "\n"; } function policy_list_cells($label, $name, $selected=null) { if ($label != null) 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 policy_list_row($label, $name, $selected=null) { echo "$label"; policy_list_cells(null, $name, $selected); echo "\n"; } function credit_type_list_cells($label, $name, $selected=null, $submit_on_change=false) { if ($label != null) label_cell($label); 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 "$label"; credit_type_list_cells(null, $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 number_list($name, $selected, $from, $to, $no_option); echo "\n"; } function number_list_row($label, $name, $selected, $from, $to, $no_option=false) { echo "$label"; echo number_list_cells(null, $name, $selected, $from, $to, $no_option); echo "\n"; } function print_profiles_list_row($label, $name, $selected_id=null, $spec_opt=false, $submit_on_change=true) { $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) 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) { if ($label != null) echo "$label\n"; echo ""; echo quick_entries_list($name, $selected_id, $type, $submit_on_change); echo ""; } function quick_entries_list_row($label, $name, $selected_id=null, $type, $submit_on_change=false) { echo "$label"; quick_entries_list_cells(null, $name, $selected_id, $type, $submit_on_change); echo "\n"; } function quick_actions_list_row($label, $name, $selected_id=null, $submit_on_change=false) { global $quick_actions; echo "$label"; echo array_selector($name, $selected_id, $quick_actions, array( 'select_submit'=> $submit_on_change ) ); echo "\n"; } function quick_entry_types_list_row($label, $name, $selected_id=null, $submit_on_change=false) { global $quick_entry_types; echo "$label"; echo array_selector($name, $selected_id, $quick_entry_types, array( 'select_submit'=> $submit_on_change ) ); echo "\n"; } function record_status_list_row($label, $name) { return yesno_list_row($label, $name, null, _('Inactive'), _('Active')); } function class_types_list_row($label, $name, $selected_id=null, $submit_on_change=false) { global $class_types; echo "$label"; echo array_selector($name, $selected_id, $class_types, array( 'select_submit'=> $submit_on_change ) ); echo "\n"; } //------------------------------------------------------------------------------------------------ function security_roles_list($name, $selected_id=null, $new_item=false, $submit_on_change=false, $show_inactive = false) { global $all_items; $sql = "SELECT id, role, inactive FROM ".TB_PREF."security_roles"; return combo_input($name, $selected_id, $sql, 'id', 'description', array( 'spec_option'=>$new_item ? _("New role") : false, 'spec_id' => '', 'select_submit'=> $submit_on_change, 'show_inactive' => $show_inactive ) ); } function security_roles_list_cells($label, $name, $selected_id=null, $new_item=false, $submit_on_change=false, $show_inactive = false) { if ($label != null) echo "$label\n"; echo ""; echo security_roles_list($name, $selected_id, $new_item, $submit_on_change, $show_inactive); echo "\n"; } function security_roles_list_row($label, $name, $selected_id=null, $new_item=false, $submit_on_change=false, $show_inactive = false) { echo "$label"; security_roles_list_cells(null, $name, $selected_id, $new_item, $submit_on_change, $show_inactive); echo "\n"; } function tab_list_row($label, $name, $selected_id=null) { global $installed_extensions; $tabs = array(); foreach ($_SESSION['App']->applications as $app) { $tabs[$app->id] = access_string($app->name, true); } 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 tag_list_cells($label, $name, $height, $type, $mult=false, $all=false, $spec_opt = false) { if ($label != null) echo "$label\n"; echo "\n"; echo tag_list($name, $height, $type, $mult, $all, $spec_opt); echo "\n"; } function tag_list_row($label, $name, $height, $type, $mult=false, $all=false, $spec_opt = false) { echo "$label"; tag_list_cells(null, $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'=> _("Available and/or installed"), 'spec_id' => -1, 'select_submit'=> $submit_on_change, 'async' => true )); } function crm_category_types_list($name, $selected_id=null, $filter=array(), $submit_on_change=true) { $sql = "SELECT id, name, type, inactive FROM ".TB_PREF."crm_categories"; $multi = false; $groups = false; $where = array(); if (@$filter['class']) { $where[] = 'type='.db_escape($filter['class']); } else $groups = 'type'; if (@$filter['subclass']) $where[] = 'action='.db_escape($filter['subclass']); if (@$filter['entity']) $where[] = 'entity_id='.db_escape($filter['entity']); if (@$filter['multi']) { // contact category selector for person $multi = true; } return combo_input($name, $selected_id, $sql, 'id', 'name', array( 'multi' => $multi, 'height' => $multi ? 5:1, 'category' => $groups, 'select_submit'=> $submit_on_change, 'async' => true, 'where' => $where )); } function crm_category_types_list_row($label, $name, $selected_id=null, $filter=array(), $submit_on_change=true) { echo "$label"; echo crm_category_types_list($name, $selected_id, $filter, $submit_on_change); echo "\n"; } function payment_type_list_row($label, $name, $selected_id=null, $submit_on_change=false) { global $pterm_types; echo "$label"; echo array_selector($name, $selected_id, $pterm_types, array( 'select_submit'=> $submit_on_change ) ); echo "\n"; } function coa_list_row($label, $name, $value=null) { global $path_to_root, $installed_extensions; $path = $path_to_root.'/sql/'; $coas = array(); $sqldir = opendir($path); while (false !== ($fname = readdir($sqldir))) { if (is_file($path.$fname) && substr($fname,-4)=='.sql' && @($fname[2] == '_')) { $ext = array_search_value($fname, $installed_extensions, 'sql'); if ($ext!=null) { $descr = $ext['name']; } elseif ($fname == 'en_US-new.sql') { // two standard COAs $descr = _("Standard new company American COA (4 digit)"); } elseif ($fname == 'en_US-demo.sql') { $descr = _("Standard American COA (4 digit) with demo data"); } else $descr = $fname; $coas[$fname] = $descr; } } ksort($coas); echo "$label\n"; echo array_selector( $name, $value, $coas ); echo "\n"; } function payment_services($name) { global $payment_services; $services = array_combine(array_keys($payment_services), array_keys($payment_services)); return array_selector($name, null, $services, array( 'spec_option'=> _("No payment Link"), 'spec_id' => '', )); } function tax_algorithm_list($name, $value=null, $submit_on_change = false) { global $tax_algorithms; return array_selector($name, $value, $tax_algorithms, array( 'select_submit'=> $submit_on_change, 'async' => true, ) ); } function tax_algorithm_list_cells($label, $name, $value=null, $submit_on_change=false) { if ($label != null) echo "$label\n"; echo ""; echo tax_algorithm_list($name, $value, $submit_on_change); echo "\n"; } function tax_algorithm_list_row($label, $name, $value=null, $submit_on_change=false) { echo "$label"; tax_algorithm_list_cells(null, $name, $value, $submit_on_change); echo "\n"; } //---------------------------------------------------------------------------------------------- function subledger_list($name, $account, $selected_id=null) { global $all_items; $type = is_subledger_account($account); if (!$type) return ''; if($type > 0) $sql = "SELECT DISTINCT d.debtor_no as id, debtor_ref as name FROM " .TB_PREF."debtors_master d," .TB_PREF."cust_branch c WHERE d.debtor_no=c.debtor_no AND c.receivables_account=".db_escape($account); else $sql = "SELECT supplier_id as id, supp_ref as name FROM " .TB_PREF."suppliers s WHERE s.payable_account=".db_escape($account); $mode = get_company_pref('no_customer_list'); return combo_input($name, $selected_id, $sql, 'id', 'name', array( 'type' => 1, 'size' => 20, 'async' => false, ) ); } function subledger_list_cells($label, $name, $account, $selected_id=null) { if ($label != null) echo "$label\n"; echo ""; echo subledger_list($name, $account, $selected_id); echo "\n"; } function subledger_list_row($label, $name, $selected_id=null, $all_option = false, $submit_on_change=false, $show_inactive=false, $editkey = false) { echo "$label"; echo subledger_list($name, $account, $selected_id); echo "\n\n"; } function accounts_type_list_row($label, $name, $selected_id=null) { echo ""; if ($label != null) echo "$label\n"; echo ""; $sel = array(_("Numeric"), _("Alpha Numeric"), _("ALPHA NUMERIC")); echo array_selector($name, $selected_id, $sel); echo "\n"; }