X-Git-Url: https://delta.frontaccounting.com/gitweb/?a=blobdiff_plain;f=admin%2Fvoid_transaction.php;h=c28c916b48ea15d7b70639f9ccb21c4393081061;hb=11e485e4a7c5f12c9424713b7330815a9cc5e4ae;hp=4b5669400032cc4cca1800f5a303eaff8699bbc1;hpb=8cac19c37c960e50f7c11964510c0d09a530e7b5;p=fa-stable.git diff --git a/admin/void_transaction.php b/admin/void_transaction.php index 4b566940..c28c916b 100644 --- a/admin/void_transaction.php +++ b/admin/void_transaction.php @@ -1,7 +1,16 @@ . +***********************************************************************/ +$page_security = 'SA_VOIDTRANSACTION'; +$path_to_root = ".."; include_once($path_to_root . "/includes/session.inc"); include_once($path_to_root . "/includes/date_functions.inc"); @@ -12,15 +21,92 @@ include_once($path_to_root . "/admin/db/voiding_db.inc"); $js = ""; if ($use_date_picker) $js .= get_js_date_picker(); +if ($use_popup_windows) + $js .= get_js_open_window(800, 500); + page(_("Void a Transaction"), false, false, "", $js); //---------------------------------------------------------------------------------------- +function exist_transaction($type, $type_no) +{ + $void_entry = get_voided_entry($type, $type_no); + + if ($void_entry != null) + return false; + + switch ($type) + { + case 0 : // it's a journal entry + if (!exists_gl_trans($type, $type_no)) + return false; + break; + + case 1 : // it's a payment + case 2 : // it's a deposit + case 4 : // it's a transfer + if (!exists_bank_trans($type, $type_no)) + return false; + break; + + case 10 : // it's a customer invoice + case 11 : // it's a customer credit note + case 12 : // it's a customer payment + case 13 : // it's a customer dispatch + if (!exists_customer_trans($type, $type_no)) + return false; + break; + + case systypes::location_transfer() : // it's a stock transfer + if (get_stock_transfer_items($type_no) == null) + return false; + break; + + case systypes::inventory_adjustment() : // it's a stock adjustment + if (get_stock_adjustment_items($type_no) == null) + return false; + break; + + case 18 : // it's a PO + case 25 : // it's a GRN + return false; + case 20 : // it's a suppler invoice + case 21 : // it's a supplier credit note + case 22 : // it's a supplier payment + if (!exists_supp_trans($type, $type_no)) + return false; + break; + + case systypes::work_order() : // it's a work order + if (!get_work_order($type_no, true)) + return false; + break; + + case 28 : // it's a work order issue + if (!exists_work_order_issue($type_no)) + return false; + break; + + case 29 : // it's a work order production + if (!exists_work_order_produce($type_no)) + return false; + break; + + case 30: // it's a sales order + case 32: // it's a sales quotation + return false; + case systypes::cost_update() : // it's a stock cost update + return false; + break; + } + + return true; +} function voiding_controls() { global $table_style2; - start_form(false, true); + start_form(); start_table($table_style2); @@ -35,13 +121,29 @@ function voiding_controls() end_table(1); if (!isset($_POST['ProcessVoiding'])) - submit_center('ProcessVoiding', _("Void Transaction"), true, '', true); + submit_center('ProcessVoiding', _("Void Transaction"), true, '', 'default'); else { - - display_note(_("Are you sure you want to void this transaction ? This action cannot be undone."), 0, 1); - submit_center_first('ConfirmVoiding', _("Proceed"), '', true); - submit_center_last('CancelVoiding', _("Cancel"), '', true); + if (!exist_transaction($_POST['filterType'],$_POST['trans_no'])) + { + display_error(_("The entered transaction does not exist or cannot be voided.")); + unset($_POST['trans_no']); + unset($_POST['memo_']); + unset($_POST['date_']); + submit_center('ProcessVoiding', _("Void Transaction"), true, '', 'default'); + } + else + { + display_warning(_("Are you sure you want to void this transaction ? This action cannot be undone."), 0, 1); + if ($_POST['filterType'] == 0) // GL transaction are not included in get_trans_view_str + $view_str = get_gl_view_str($_POST['filterType'],$_POST['trans_no'], _("View Transaction")); + else + $view_str = get_trans_view_str($_POST['filterType'],$_POST['trans_no'], _("View Transaction")); + display_note($view_str); + br(); + submit_center_first('ConfirmVoiding', _("Proceed"), '', true); + submit_center_last('CancelVoiding', _("Cancel"), '', 'cancel'); + } } end_form(); @@ -51,6 +153,12 @@ function voiding_controls() function check_valid_entries() { + if (is_closed_trans($_POST['filterType'],$_POST['trans_no'])) + { + display_error(_("The selected transaction was closed for edition and cannot be voided.")); + set_focus('trans_no'); + return; + } if (!is_date($_POST['date_'])) { display_error(_("The entered date is invalid.")); @@ -80,7 +188,6 @@ function handle_void_transaction() { if (check_valid_entries()==true) { - $void_entry = get_voided_entry($_POST['filterType'], $_POST['trans_no']); if ($void_entry != null) {