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");
15 //--------------------------------------------------------------------------------
17 function add_to_order(&$order, $new_item, $new_item_qty, $standard_cost)
19 if ($order->find_cart_item($new_item))
20 display_error(_("For Part :") . $new_item . " " . "This item is already on this document. You can change the quantity on the existing line if necessary.");
22 $order->add_to_cart (count($order->line_items), $new_item, $new_item_qty, $standard_cost);
25 //--------------------------------------------------------------------------------
27 function display_order_header(&$order)
31 start_outer_table(TABLESTYLE, "width='70%'");
35 locations_list_row(_("From Location:"), 'FromStockLocation', null, false, false, $order->fixed_asset);
36 locations_list_row(_("To Location:"), 'ToStockLocation', null,false, false, $order->fixed_asset);
38 table_section(2, "50%");
40 date_row(_("Date:"), 'AdjDate', '', true);
42 ref_row(_("Reference:"), 'ref', '', $Refs->get_next(ST_LOCTRANSFER, null, array('date'=>get_post('AdjDate'), 'location'=> get_post('FromStockLocation'))),
43 false, ST_LOCTRANSFER);
45 end_outer_table(1); // outer table
48 //---------------------------------------------------------------------------------
50 function display_transfer_items($title, &$order)
54 display_heading($title);
55 div_start('items_table');
56 start_table(TABLESTYLE, "width='80%'");
57 $th = array(_("Item Code"), _("Item Description"), _("Quantity"), _("Unit"), '');
58 if (!$order->fixed_asset && count($order->line_items)) $th[] = '';
60 $k = 0; //row colour counter
62 $low_stock = $order->check_qoh($_POST['FromStockLocation'], $_POST['AdjDate'], true);
63 $id = find_submit('Edit');
64 foreach ($order->line_items as $line_no=>$stock_item)
69 if (in_array($stock_item->stock_id, $low_stock))
70 start_row("class='stockmankobg'"); // notice low stock status
72 alt_table_row_color($k);
74 if ($order->fixed_asset)
75 label_cell($stock_item->stock_id);
77 view_stock_status_cell($stock_item->stock_id);
78 label_cell($stock_item->item_description);
79 qty_cell($stock_item->quantity, false, get_qty_dec($stock_item->stock_id));
80 label_cell($stock_item->units);
82 if (!$order->fixed_asset)
83 edit_button_cell("Edit$line_no", _("Edit"), _('Edit document line'));
84 delete_button_cell("Delete$line_no", _("Delete"), _('Remove line from document'));
89 transfer_edit_item_controls($order, $line_no);
94 transfer_edit_item_controls($order);
98 display_note(_("Marked items have insufficient quantities in stock as on day of transfer."), 0, 1, "class='stockmankofg'");
102 //---------------------------------------------------------------------------------
104 function transfer_edit_item_controls(&$order, $line_no=-1)
109 $id = find_submit('Edit');
110 if ($line_no != -1 && $line_no == $id)
112 $_POST['stock_id'] = $order->line_items[$id]->stock_id;
113 $_POST['qty'] = qty_format($order->line_items[$id]->quantity, $order->line_items[$id]->stock_id, $dec);
114 $_POST['units'] = $order->line_items[$id]->units;
116 hidden('stock_id', $_POST['stock_id']);
117 label_cell($_POST['stock_id']);
118 label_cell($order->line_items[$id]->item_description);
119 $Ajax->activate('items_table');
123 if ($order->fixed_asset)
124 stock_disposable_fa_list_cells(null, 'stock_id', null, false, true, $order->line_items);
126 stock_costable_items_list_cells(null, 'stock_id', null, false, true);
128 if (list_updated('stock_id')) {
129 $Ajax->activate('units');
130 $Ajax->activate('qty');
133 $item_info = get_item_edit_info($_POST['stock_id']);
135 $dec = $item_info['decimals'];
136 $_POST['qty'] = number_format2(0, $dec);
137 $_POST['units'] = $item_info["units"];
140 if ($order->fixed_asset) {
142 qty_cell(1, false, 0);
144 small_qty_cells(null, 'qty', $_POST['qty'], null, null, $dec);
146 label_cell($_POST['units'], '', 'units');
150 button_cell('UpdateItem', _("Update"),
151 _('Confirm changes'), ICON_UPDATE);
152 button_cell('CancelItemChanges', _("Cancel"),
153 _('Cancel changes'), ICON_CANCEL);
154 hidden('LineNo', $line_no);
159 submit_cells('AddItem', _("Add Item"), "colspan=2",
160 _('Add new item to document'), true);
167 //---------------------------------------------------------------------------------
169 function transfer_options_controls()
174 textarea_row(_("Memo"), 'memo_', null, 50, 3);
180 //---------------------------------------------------------------------------------