X-Git-Url: https://delta.frontaccounting.com/gitweb/?a=blobdiff_plain;f=inventory%2Ftransfers.php;h=5315a23c64b6573d46a4d9eef46af8913dffad44;hb=7e8df3a179c05c51085349e139aac9ce88b9378d;hp=874d7bff79b344e9a8e61e67d6fd3dc8b7274f36;hpb=1571869d54be48452fdbe08f25130972ff0a7b5a;p=fa-stable.git diff --git a/inventory/transfers.php b/inventory/transfers.php index 874d7bff..5315a23c 100644 --- a/inventory/transfers.php +++ b/inventory/transfers.php @@ -21,9 +21,9 @@ include_once($path_to_root . "/includes/data_checks.inc"); include_once($path_to_root . "/inventory/includes/stock_transfers_ui.inc"); include_once($path_to_root . "/inventory/includes/inventory_db.inc"); $js = ""; -if ($use_popup_windows) +if ($SysPrefs->use_popup_windows) $js .= get_js_open_window(800, 500); -if ($use_date_picker) +if (user_use_date_picker()) $js .= get_js_date_picker(); page(_($help_context = "Inventory Location Transfers"), false, false, "", $js); @@ -31,8 +31,6 @@ page(_($help_context = "Inventory Location Transfers"), false, false, "", $js); check_db_has_costable_items(_("There are no inventory items defined in the system (Purchased or manufactured items).")); -check_db_has_movement_types(_("There are no inventory movement types defined in the system. Please define at least one inventory adjustment type.")); - //----------------------------------------------------------------------------------------------- if (isset($_GET['AddedID'])) @@ -76,7 +74,6 @@ function handle_new_order() if (isset($_POST['Process'])) { - global $Refs; $tr = &$_SESSION['transfer_items']; $input_error = 0; @@ -84,7 +81,7 @@ if (isset($_POST['Process'])) if (count($tr->line_items) == 0) { display_error(_("You must enter at least one non empty item line.")); set_focus('stock_id'); - return false; + $input_error = 1; } if (!$Refs->is_valid($_POST['ref'])) { @@ -115,17 +112,14 @@ if (isset($_POST['Process'])) display_error(_("The locations to transfer from and to must be different.")); set_focus('FromStockLocation'); $input_error = 1; - } - else + } + elseif (!$SysPrefs->allow_negative_stock()) { - $failed_item = $tr->check_qoh($_POST['FromStockLocation'], $_POST['AdjDate'], true); - if ($failed_item >= 0) + $low_stock = $tr->check_qoh($_POST['FromStockLocation'], $_POST['AdjDate'], true); + + if ($low_stock) { - $line = $tr->line_items[$failed_item]; - display_error(_("The quantity entered is greater than the available quantity for this item at the source location :") . - " " . $line->stock_id . " - " . $line->item_description); - echo "
"; - $_POST['Edit'.$failed_item] = 1; // enter edit mode + display_error(_("The transfer cannot be processed because it would cause negative inventory balance in source location for marked items as of document date or later.")); $input_error = 1; } } @@ -141,7 +135,7 @@ if (isset($_POST['Process'])) $trans_no = add_stock_transfer($_SESSION['transfer_items']->line_items, $_POST['FromStockLocation'], $_POST['ToStockLocation'], - $_POST['AdjDate'], $_POST['type'], $_POST['ref'], $_POST['memo_']); + $_POST['AdjDate'], $_POST['ref'], $_POST['memo_']); new_doc_date($_POST['AdjDate']); $_SESSION['transfer_items']->clear_items(); unset($_SESSION['transfer_items']); @@ -153,7 +147,7 @@ if (isset($_POST['Process'])) function check_item_data() { - if (!check_num('qty', 0)) + if (!check_num('qty', 0) || input_num('qty') == 0) { display_error(_("The quantity entered must be a positive number.")); set_focus('qty'); @@ -166,13 +160,10 @@ function check_item_data() function handle_update_item() { - if($_POST['UpdateItem'] != "" && check_item_data()) - { - $id = $_POST['LineNo']; - if (!isset($_POST['std_cost'])) - $_POST['std_cost'] = $_SESSION['transfer_items']->line_items[$id]->standard_cost; - $_SESSION['transfer_items']->update_cart_item($id, input_num('qty'), $_POST['std_cost']); - } + $id = $_POST['LineNo']; + if (!isset($_POST['std_cost'])) + $_POST['std_cost'] = $_SESSION['transfer_items']->line_items[$id]->standard_cost; + $_SESSION['transfer_items']->update_cart_item($id, input_num('qty'), $_POST['std_cost']); line_start_focus(); } @@ -188,8 +179,6 @@ function handle_delete_item($id) function handle_new_item() { - if (!check_item_data()) - return; if (!isset($_POST['std_cost'])) $_POST['std_cost'] = 0; add_to_order($_SESSION['transfer_items'], $_POST['stock_id'], input_num('qty'), $_POST['std_cost']); @@ -201,10 +190,10 @@ $id = find_submit('Delete'); if ($id != -1) handle_delete_item($id); -if (isset($_POST['AddItem'])) +if (isset($_POST['AddItem']) && check_item_data()) handle_new_item(); -if (isset($_POST['UpdateItem'])) +if (isset($_POST['UpdateItem']) && check_item_data()) handle_update_item(); if (isset($_POST['CancelItemChanges'])) { @@ -222,7 +211,7 @@ start_form(); display_order_header($_SESSION['transfer_items']); -start_table(TABLESTYLE, "width=70%", 10); +start_table(TABLESTYLE, "width='70%'", 10); start_row(); echo ""; display_transfer_items(_("Items"), $_SESSION['transfer_items']); @@ -237,4 +226,3 @@ submit_center_last('Process', _("Process Transfer"), '', 'default'); end_form(); end_page(); -?>