X-Git-Url: https://delta.frontaccounting.com/gitweb/?a=blobdiff_plain;f=manufacturing%2Fwork_order_issue.php;h=025a91258c2dcfb7f76c398c90927b23c7ea9951;hb=7226477a2624571ba8460f773092f6e38bbc46f3;hp=ec3945669a8304d838508e7119af6f3f66076dc4;hpb=431531eebf3ba494002cfbf7ea36f9e82d4975c0;p=fa-stable.git diff --git a/manufacturing/work_order_issue.php b/manufacturing/work_order_issue.php index ec394566..025a9125 100644 --- a/manufacturing/work_order_issue.php +++ b/manufacturing/work_order_issue.php @@ -1,7 +1,17 @@ . +***********************************************************************/ +$page_security = 'SA_MANUFISSUE'; +$path_to_root = ".."; -$page_security = 3; -$path_to_root=".."; include_once($path_to_root . "/includes/ui/items_cart.inc"); include_once($path_to_root . "/includes/session.inc"); @@ -13,20 +23,35 @@ include_once($path_to_root . "/manufacturing/includes/manufacturing_db.inc"); include_once($path_to_root . "/manufacturing/includes/manufacturing_ui.inc"); include_once($path_to_root . "/manufacturing/includes/work_order_issue_ui.inc"); $js = ""; -if ($use_date_picker) +if ($SysPrefs->use_popup_windows) + $js .= get_js_open_window(800, 500); +if (user_use_date_picker()) $js .= get_js_date_picker(); -page(_("Issue Items to Work Order"), false, false, "", $js); + +page(_($help_context = "Issue Items to Work Order"), false, false, "", $js); //----------------------------------------------------------------------------------------------- if (isset($_GET['AddedID'])) { - echo "
" . _("The work order issue has been entered."); - echo "
"; - hyperlink_no_params("search_work_orders.php", _("Select another Work Order to Process")); - echo "

"; - end_page(); - exit; + $id = $_GET['AddedID']; + display_notification(_("The work order issue has been entered.")); + + display_note(get_trans_view_str(ST_WORKORDER, $id, _("View this Work Order"))); + + display_note(get_gl_view_str(ST_WORKORDER, $id, _("View the GL Journal Entries for this Work Order")), 1); + + hyperlink_no_params("search_work_orders.php", _("Select another &Work Order to Process")); + + display_footer_exit(); +} +//-------------------------------------------------------------------------------------------------- + +function line_start_focus() { + global $Ajax; + + $Ajax->activate('items_table'); + set_focus('_stock_id_edit'); } //-------------------------------------------------------------------------------------------------- @@ -39,50 +64,42 @@ function handle_new_order() unset ($_SESSION['issue_items']); } - Session_register("issue_items"); - - $_SESSION['issue_items'] = new items_cart; + $_SESSION['issue_items'] = new items_cart(ST_MANUISSUE); $_SESSION['issue_items']->order_id = $_GET['trans_no']; } //----------------------------------------------------------------------------------------------- - function can_process() { - if (!is_date($_POST['date_'])) + if (!is_date($_POST['date_'])) { display_error(_("The entered date for the issue is invalid.")); + set_focus('date_'); return false; } - elseif (!is_date_in_fiscalyear($_POST['date_'])) - { - display_error(_("The entered date is not in fiscal year.")); - return false; - } - if (!references::is_valid($_POST['ref'])) + elseif (!is_date_in_fiscalyear($_POST['date_'])) { - display_error(_("You must enter a reference.")); + display_error(_("The entered date is out of fiscal year or is closed for further data entry.")); + set_focus('date_'); return false; } - - if (!is_new_reference($_POST['ref'], 28)) + if (!check_reference($_POST['ref'], ST_MANUISSUE)) { - display_error(_("The entered reference is already in use.")); + set_focus('ref'); return false; } $failed_item = $_SESSION['issue_items']->check_qoh($_POST['Location'], $_POST['date_'], !$_POST['IssueType']); - if ($failed_item != null) + if ($failed_item) { - display_error( _("The issue cannot be processed because an entered item would cause a negative inventory balance :") . - " " . $failed_item->stock_id . " - " . $failed_item->item_description); + display_error(_("The issue cannot be processed because it would cause negative inventory balance for marked items as of document date or later.")); return false; } return true; } -if (isset($_POST['Process'])) +if (isset($_POST['Process']) && can_process()) { // if failed, returns a stockID @@ -98,7 +115,7 @@ if (isset($_POST['Process'])) } else { - meta_forward($_SERVER['PHP_SELF'], "AddedID=1"); + meta_forward($_SERVER['PHP_SELF'], "AddedID=".$_SESSION['issue_items']->order_id); } } /*end of process credit note */ @@ -107,21 +124,17 @@ if (isset($_POST['Process'])) function check_item_data() { - if (!is_numeric($_POST['qty'])) + if (input_num('qty') == 0 || !check_num('qty', 0)) { - display_error(_("The quantity entered is not a valid number.")); + display_error(_("The quantity entered is negative or invalid.")); + set_focus('qty'); return false; } - if ($_POST['qty'] <= 0) - { - display_error(_("The quantity entered must be greater than zero.")); - return false; - } - - if (!is_numeric($_POST['std_cost']) || $_POST['std_cost'] < 0) + if (!check_num('std_cost', 0)) { display_error(_("The entered standard cost is negative or invalid.")); + set_focus('std_cost'); return false; } @@ -134,15 +147,18 @@ function handle_update_item() { if($_POST['UpdateItem'] != "" && check_item_data()) { - $_SESSION['issue_items']->update_cart_item($_POST['stock_id'], $_POST['qty'], $_POST['std_cost']); + $id = $_POST['LineNo']; + $_SESSION['issue_items']->update_cart_item($id, input_num('qty'), input_num('std_cost')); } + line_start_focus(); } //----------------------------------------------------------------------------------------------- -function handle_delete_item() +function handle_delete_item($id) { - $_SESSION['issue_items']->remove_from_cart($_GET['Delete']); + $_SESSION['issue_items']->remove_from_cart($id); + line_start_focus(); } //----------------------------------------------------------------------------------------------- @@ -152,20 +168,26 @@ function handle_new_item() if (!check_item_data()) return; - add_to_order($_SESSION['issue_items'], $_POST['stock_id'], $_POST['qty'], $_POST['std_cost']); + add_to_issue($_SESSION['issue_items'], $_POST['stock_id'], input_num('qty'), + input_num('std_cost')); + line_start_focus(); } //----------------------------------------------------------------------------------------------- +$id = find_submit('Delete'); +if ($id != -1) + handle_delete_item($id); -if ($_GET['Delete']!="") - handle_delete_item(); - -if ($_POST['AddItem']!="") +if (isset($_POST['AddItem'])) handle_new_item(); -if ($_POST['UpdateItem']!="") +if (isset($_POST['UpdateItem'])) handle_update_item(); +if (isset($_POST['CancelItemChanges'])) { + line_start_focus(); +} + //----------------------------------------------------------------------------------------------- if (isset($_GET['trans_no'])) @@ -175,30 +197,20 @@ if (isset($_GET['trans_no'])) //----------------------------------------------------------------------------------------------- -display_order_header($_SESSION['issue_items']); +display_wo_details($_SESSION['issue_items']->order_id); +echo "
"; -start_form(false, true); +start_form(); -start_table("$table_style width=90%", '10'); +start_table(TABLESTYLE, "width='90%'", 10); echo ""; -display_adjustment_items(_("Items to Issue"), $_SESSION['issue_items']); -adjustment_options_controls(); +display_issue_items(_("Items to Issue"), $_SESSION['issue_items']); +issue_options_controls(); echo ""; end_table(); -if (!isset($_POST['Process'])) -{ - start_table(); - start_row(); - submit_cells('Update', _("Update")); - if ($_SESSION['issue_items']->count_items() >= 1) - { - submit_cells('Process', _("Process Issue")); - } - end_row(); - end_table(); -} +submit_center('Process', _("Process Issue"), true, '', 'default'); end_form(); @@ -206,4 +218,3 @@ end_form(); end_page(); -?>