X-Git-Url: https://delta.frontaccounting.com/gitweb/?a=blobdiff_plain;f=manufacturing%2Fwork_order_issue.php;h=025a91258c2dcfb7f76c398c90927b23c7ea9951;hb=2778621096dd6e321f75f9587a6c18b6e50669ef;hp=943dbc66be3851546fc0eae9ae1a6455d1009e9a;hpb=6183e9450dcd7e4c747889c10903f6ff1b0add33;p=fa-stable.git
diff --git a/manufacturing/work_order_issue.php b/manufacturing/work_order_issue.php
index 943dbc66..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,54 +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_']))
+ elseif (!is_date_in_fiscalyear($_POST['date_']))
{
- display_error(_("The entered date is not in fiscal year."));
+ display_error(_("The entered date is out of fiscal year or is closed for further data entry."));
set_focus('date_');
return false;
}
- if (!references::is_valid($_POST['ref']))
- {
- display_error(_("You must enter a reference."));
- set_focus('ref');
- 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
@@ -102,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 */
@@ -111,21 +124,14 @@ if (isset($_POST['Process']))
function check_item_data()
{
- if (!is_numeric($_POST['qty']))
- {
- display_error(_("The quantity entered is not a valid number."));
- set_focus('qty');
- return false;
- }
-
- if ($_POST['qty'] <= 0)
+ if (input_num('qty') == 0 || !check_num('qty', 0))
{
- display_error(_("The quantity entered must be greater than zero."));
+ display_error(_("The quantity entered is negative or invalid."));
set_focus('qty');
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');
@@ -141,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();
}
//-----------------------------------------------------------------------------------------------
@@ -159,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']))
@@ -182,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();
@@ -213,4 +218,3 @@ end_form();
end_page();
-?>