Code cleanup after db_pager optimization.
[fa-stable.git] / sales / allocations / customer_allocation_main.php
1 <?php
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");
16
17 include_once($path_to_root . "/sales/includes/sales_ui.inc");
18 include_once($path_to_root . "/sales/includes/sales_db.inc");
19 $js = "";
20 if ($use_popup_windows)
21         $js .= get_js_open_window(900, 500);
22 page(_("Customer Allocations"), false, false, "", $js);
23
24 //--------------------------------------------------------------------------------
25
26 start_form();
27         /* show all outstanding receipts and credits to be allocated */
28         /*Clear any previous allocation records */
29         if (isset($_SESSION['alloc']))
30         {
31                 unset($_SESSION['alloc']->allocs);
32                 unset($_SESSION['alloc']);
33         }
34     if (!isset($_POST['customer_id']))
35         $_POST['customer_id'] = get_global_customer();
36
37     echo "<center>" . _("Select a customer: ") . "&nbsp;&nbsp;";
38         customer_list('customer_id', $_POST['customer_id'], true, true);
39     echo "<br>";
40     check(_("Show Settled Items:"), 'ShowSettled', null, true);
41         echo "</center><br><br>";
42
43         set_global_customer($_POST['customer_id']);
44
45         if (isset($_POST['customer_id']) && ($_POST['customer_id'] == ALL_TEXT))
46         {
47                 unset($_POST['customer_id']);
48         }
49
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;
54         }*/
55
56         $settled = false;
57         if (check_value('ShowSettled'))
58                 $settled = true;
59
60         $customer_id = null;
61         if (isset($_POST['customer_id']))
62                 $customer_id = $_POST['customer_id'];
63
64 //--------------------------------------------------------------------------------
65 function systype_name($dummy, $type)
66 {
67         global $systypes_array;
68
69         return $systypes_array[$type];
70 }
71
72 function trans_view($trans)
73 {
74         return get_trans_view_str($trans["type"], $trans["trans_no"]);
75 }
76
77 function alloc_link($row)
78 {
79         return pager_link(_("Allocate"),
80                 "/sales/allocations/customer_allocate.php?trans_no="
81                         .$row["trans_no"] . "&trans_type=" . $row["type"], ICON_MONEY);
82 }
83
84 function amount_left($row)
85 {
86         return price_format($row["Total"]-$row["alloc"]);
87 }
88
89 function check_settled($row)
90 {
91         return $row['settled'] == 1;
92 }
93
94
95 $sql = get_allocatable_from_cust_sql($customer_id, $settled);
96
97 $cols = array(
98         _("Transaction Type") => array('fun'=>'systype_name'),
99         _("#") => array('fun'=>'trans_view'),
100         _("Reference"), 
101         _("Date") => array('name'=>'tran_date', 'type'=>'date', 'ord'=>'asc'),
102         _("Customer") => array('ord'=>''),
103         _("Currency") => array('align'=>'center'),
104         _("Total") => 'amount', 
105         _("Left to Allocate") => array('align'=>'right','insert'=>true, 'fun'=>'amount_left'), 
106         array('insert'=>true, 'fun'=>'alloc_link')
107         );
108
109 if (isset($_POST['customer_id'])) {
110         $cols[_("Customer")] = 'skip';
111         $cols[_("Currency")] = 'skip';
112 }
113
114 $table =& new_db_pager('alloc_tbl', $sql, $cols);
115 $table->set_marker('check_settled', _("Marked items are settled."), 'settledbg', 'settledfg');
116
117 $table->width = "75%";
118
119 display_db_pager($table);
120 end_form();
121
122 end_page();
123 ?>