2 /**********************************************************************
3 Copyright (C) FrontAccounting, LLC.
4 Released under the terms of the GNU General Public License, GPL,
5 as published by the Free Software Foundation, either version 3
6 of the License, or (at your option) any later version.
7 This program is distributed in the hope that it will be useful,
8 but WITHOUT ANY WARRANTY; without even the implied warranty of
9 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
10 See the License here <http://www.gnu.org/licenses/gpl-3.0.html>.
11 ***********************************************************************/
12 $page_security = 'SA_SALESALLOC';
13 $path_to_root = "../..";
14 include($path_to_root . "/includes/db_pager.inc");
15 include_once($path_to_root . "/includes/session.inc");
17 include_once($path_to_root . "/sales/includes/sales_ui.inc");
18 include_once($path_to_root . "/sales/includes/sales_db.inc");
20 if ($use_popup_windows)
21 $js .= get_js_open_window(900, 500);
22 page(_("Customer Allocations"), false, false, "", $js);
24 //--------------------------------------------------------------------------------
27 /* show all outstanding receipts and credits to be allocated */
28 /*Clear any previous allocation records */
29 if (isset($_SESSION['alloc']))
31 unset($_SESSION['alloc']->allocs);
32 unset($_SESSION['alloc']);
34 if (!isset($_POST['customer_id']))
35 $_POST['customer_id'] = get_global_customer();
37 echo "<center>" . _("Select a customer: ") . " ";
38 customer_list('customer_id', $_POST['customer_id'], true, true);
40 check(_("Show Settled Items:"), 'ShowSettled', null, true);
41 echo "</center><br><br>";
43 set_global_customer($_POST['customer_id']);
45 if (isset($_POST['customer_id']) && ($_POST['customer_id'] == reserved_words::get_all()))
47 unset($_POST['customer_id']);
50 /*if (isset($_POST['customer_id'])) {
51 $custCurr = get_customer_currency($_POST['customer_id']);
52 if (!is_company_currency($custCurr))
53 echo _("Customer Currency:") . $custCurr;
57 if (check_value('ShowSettled'))
61 if (isset($_POST['customer_id']))
62 $customer_id = $_POST['customer_id'];
64 //--------------------------------------------------------------------------------
65 function systype_name($dummy, $type)
67 return systypes::name($type);
70 function trans_view($trans)
72 return get_trans_view_str($trans["type"], $trans["trans_no"]);
75 function alloc_link($row)
77 return pager_link(_("Allocate"),
78 "/sales/allocations/customer_allocate.php?trans_no="
79 .$row["trans_no"] . "&trans_type=" . $row["type"], ICON_MONEY);
82 function amount_left($row)
84 return price_format($row["Total"]-$row["alloc"]);
87 function check_settled($row)
89 return $row['settled'] == 1;
93 $sql = get_allocatable_from_cust_sql($customer_id, $settled);
96 _("Transaction Type") => array('fun'=>'systype_name'),
97 _("#") => array('fun'=>'trans_view'),
99 _("Date") => array('name'=>'tran_date', 'type'=>'date', 'ord'=>'asc'),
100 _("Customer") => array('ord'=>''),
101 _("Currency") => array('align'=>'center'),
102 _("Total") => 'amount',
103 _("Left to Allocate") => array('align'=>'right','insert'=>true, 'fun'=>'amount_left'),
104 array('insert'=>true, 'fun'=>'alloc_link')
107 if (isset($_POST['customer_id'])) {
108 $cols[_("Customer")] = 'skip';
109 $cols[_("Currency")] = 'skip';
112 $table =& new_db_pager('alloc_tbl', $sql, $cols);
113 $table->set_marker('check_settled', _("Marked items are settled."), 'settledbg', 'settledfg');
115 if (get_post('_ShowSettled_update') || get_post('_customer_id_update')) {
116 $table->set_sql($sql);
117 $table->set_columns($cols);
119 $table->width = "75%";
121 display_db_pager($table);