.
***********************************************************************/
$page_security = 'SA_SUPPLIERALLOC';
$path_to_root = "../..";
include($path_to_root . "/includes/db_pager.inc");
include_once($path_to_root . "/includes/session.inc");
include_once($path_to_root . "/includes/date_functions.inc");
include_once($path_to_root . "/includes/ui.inc");
include_once($path_to_root . "/includes/banking.inc");
include_once($path_to_root . "/sales/includes/sales_db.inc");
$js = "";
if ($SysPrefs->use_popup_windows)
$js .= get_js_open_window(900, 500);
page(_($help_context = "Supplier Allocations"), false, false, "", $js);
//--------------------------------------------------------------------------------
start_form();
/* show all outstanding receipts and credits to be allocated */
if (!isset($_POST['supplier_id']))
$_POST['supplier_id'] = get_global_supplier();
echo "
" . _("Select a Supplier: ") . " ";
echo supplier_list('supplier_id', $_POST['supplier_id'], true, true);
echo "
";
check(_("Show Settled Items:"), 'ShowSettled', null, true);
echo "
";
set_global_supplier($_POST['supplier_id']);
if (isset($_POST['supplier_id']) && ($_POST['supplier_id'] == ALL_TEXT))
{
unset($_POST['supplier_id']);
}
$settled = false;
if (check_value('ShowSettled'))
$settled = true;
$supplier_id = null;
if (isset($_POST['supplier_id']))
$supplier_id = $_POST['supplier_id'];
//--------------------------------------------------------------------------------
function systype_name($dummy, $type)
{
global $systypes_array;
return $systypes_array[$type];
}
function trans_view($trans)
{
return get_trans_view_str($trans["type"], $trans["trans_no"]);
}
function alloc_link($row)
{
return pager_link(_("Allocate"),
"/purchasing/allocations/supplier_allocate.php?trans_no="
.$row["trans_no"] . "&trans_type=" . $row["type"]. "&supplier_id=" . $row["supplier_id"], ICON_ALLOC);
}
function amount_left($row)
{
return price_format($row['type'] == ST_JOURNAL ? abs($row["Total"])-$row["alloc"] : -$row["Total"]-$row["alloc"]);
}
function amount_total($row)
{
return price_format(-$row["Total"]);
}
function check_settled($row)
{
return $row['settled'] == 1;
}
$sql = get_allocatable_from_supp_sql($supplier_id, $settled);
$cols = array(
_("Transaction Type") => array('fun'=>'systype_name'),
_("#") => array('fun'=>'trans_view', 'align'=>'right'),
_("Reference"),
_("Date") => array('name'=>'tran_date', 'type'=>'date', 'ord'=>'asc'),
_("Supplier") => array('ord'=>''),
_("Currency") => array('align'=>'center'),
_("Total") => array('align'=>'right', 'fun'=>'amount_total'),
_("Left to Allocate") => array('align'=>'right','insert'=>true, 'fun'=>'amount_left'),
array('insert'=>true, 'fun'=>'alloc_link')
);
if (isset($_POST['customer_id'])) {
$cols[_("Supplier")] = 'skip';
$cols[_("Currency")] = 'skip';
}
$table =& new_db_pager('alloc_tbl', $sql, $cols);
$table->set_marker('check_settled', _("Marked items are settled."), 'settledbg', 'settledfg');
$table->width = "80%";
display_db_pager($table);
end_form();
end_page();