New files from unstable branch
[fa-stable.git] / inventory / includes / item_adjustments_ui.inc
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 include_once($path_to_root . "/includes/ui.inc");
13 include_once($path_to_root . "/includes/ui/items_cart.inc");
14
15 //--------------------------------------------------------------------------------
16
17 function add_to_order(&$order, $new_item, $new_item_qty, $standard_cost)
18 {
19     if ($order->find_cart_item($new_item))
20          display_error(_("For Part :") . $new_item . " " . "This item is already on this order.  You can change the quantity ordered of the existing line if necessary.");
21         else
22          $order->add_to_cart (count($order->line_items), $new_item, $new_item_qty, $standard_cost);
23 }
24
25 //--------------------------------------------------------------------------------
26
27 function display_order_header(&$order)
28 {
29         global $Refs;
30
31         start_outer_table(TABLESTYLE2, "width=70%"); // outer table
32         table_section(1);
33
34         locations_list_row(_("Location:"), 'StockLocation', null);
35         ref_row(_("Reference:"), 'ref', '', $Refs->get_next(ST_INVADJUST));
36
37         table_section(2, "33%");
38
39     date_row(_("Date:"), 'AdjDate', '', true);
40
41         table_section(3, "33%");
42
43     movement_types_list_row(_("Detail:"), 'type', null);
44
45     if (!isset($_POST['Increase']))
46         $_POST['Increase'] = 1;
47     yesno_list_row(_("Type:"), 'Increase', $_POST['Increase'],
48         _("Positive Adjustment"), _("Negative Adjustment"));
49
50         end_outer_table(1); // outer table
51 }
52
53 //---------------------------------------------------------------------------------
54
55 function display_adjustment_items($title, &$order)
56 {
57         global $path_to_root;
58
59         display_heading($title);
60     div_start('items_table');
61         start_table(TABLESTYLE, "width=80%");
62         $th = array(_("Item Code"), _("Item Description"), _("Quantity"),
63                 _("Unit"), _("Unit Cost"), _("Total"), "");
64         if ( count($order->line_items)) $th[] = '';
65
66         table_header($th);
67         $total = 0;
68         $k = 0;  //row colour counter
69
70         $id = find_submit('Edit');
71         foreach ($order->line_items as $line_no=>$stock_item)
72         {
73
74                 $total += ($stock_item->standard_cost * $stock_item->quantity);
75
76                 if ($id != $line_no)
77                 {
78                 alt_table_row_color($k);
79
80                         view_stock_status_cell($stock_item->stock_id);
81                         label_cell($stock_item->item_description);
82                 qty_cell($stock_item->quantity, false, get_qty_dec($stock_item->stock_id));
83                         label_cell($stock_item->units);
84                         amount_decimal_cell($stock_item->standard_cost);
85                         amount_cell($stock_item->standard_cost * $stock_item->quantity);
86
87                         edit_button_cell("Edit$line_no", _("Edit"),
88                                 _('Edit document line'));
89                         delete_button_cell("Delete$line_no", _("Delete"),
90                                 _('Remove line from document'));
91                         end_row();
92                 }
93                 else
94                 {
95                         adjustment_edit_item_controls($order, $line_no);
96                 }
97         }
98
99         if ($id == -1)
100                 adjustment_edit_item_controls($order);
101
102         label_row(_("Total"), number_format2($total,user_price_dec()), "align=right colspan=5", "align=right", 2);
103
104     end_table();
105         div_end();
106 }
107
108 //---------------------------------------------------------------------------------
109
110 function adjustment_edit_item_controls(&$order, $line_no=-1)
111 {
112         global $Ajax;
113         start_row();
114
115         $dec2 = 0;
116         $id = find_submit('Edit');
117         if ($line_no != -1 && $line_no == $id)
118         {
119                 $_POST['stock_id'] = $order->line_items[$id]->stock_id;
120                 $_POST['qty'] = qty_format($order->line_items[$id]->quantity, 
121                         $order->line_items[$id]->stock_id, $dec);
122                 //$_POST['std_cost'] = price_format($order->line_items[$id]->standard_cost);
123                 $_POST['std_cost'] = price_decimal_format($order->line_items[$id]->standard_cost, $dec2);
124                 $_POST['units'] = $order->line_items[$id]->units;
125
126                 hidden('stock_id', $_POST['stock_id']);
127                 label_cell($_POST['stock_id']);
128                 label_cell($order->line_items[$id]->item_description, 'nowrap');
129             $Ajax->activate('items_table');
130         }
131         else
132         {
133         stock_costable_items_list_cells(null, 'stock_id', null, false, true);
134                 if (list_updated('stock_id')) {
135                             $Ajax->activate('units');
136                             $Ajax->activate('qty');
137                             $Ajax->activate('std_cost');
138                 }
139
140         $item_info = get_item_edit_info($_POST['stock_id']);
141                 $dec = $item_info['decimals'];
142                 $_POST['qty'] = number_format2(0, $dec);
143                 //$_POST['std_cost'] = price_format($item_info["standard_cost"]);
144                 $_POST['std_cost'] = price_decimal_format($item_info["standard_cost"], $dec2);
145                 $_POST['units'] = $item_info["units"];
146         }
147
148         qty_cells(null, 'qty', $_POST['qty'], null, null, $dec);
149         label_cell($_POST['units'], '', 'units');
150
151         //amount_cells(null, 'std_cost', $_POST['std_cost']);
152         amount_cells(null, 'std_cost', null, null, null, $dec2);
153         label_cell("&nbsp;");
154
155         if ($id != -1)
156         {
157                 button_cell('UpdateItem', _("Update"),
158                                 _('Confirm changes'), ICON_UPDATE);
159                 button_cell('CancelItemChanges', _("Cancel"),
160                                 _('Cancel changes'), ICON_CANCEL);
161                 hidden('LineNo', $line_no);
162                 set_focus('qty');
163         }
164         else
165         {
166                 submit_cells('AddItem', _("Add Item"), "colspan=2",
167                     _('Add new item to document'), true);
168         }
169
170         end_row();
171 }
172
173
174 //---------------------------------------------------------------------------------
175
176 function adjustment_options_controls()
177 {
178           echo "<br>";
179           start_table();
180
181           textarea_row(_("Memo"), 'memo_', null, 50, 3);
182
183           end_table(1);
184 }
185
186
187 //---------------------------------------------------------------------------------
188
189 ?>