X-Git-Url: https://delta.frontaccounting.com/gitweb/?a=blobdiff_plain;f=admin%2Fdb%2Fvoiding_db.inc;h=5711a0e41eb3ffb3a1f8f95c08e018cf20135c16;hb=4e6811018489ed5d9e4c029342c958e266d7b298;hp=553240c2b016c1d2220d930529d0dd244b21afe6;hpb=ebc600101ceab69c06eac4b1bd4d1782af45de05;p=fa-stable.git diff --git a/admin/db/voiding_db.inc b/admin/db/voiding_db.inc index 553240c2..5711a0e4 100644 --- a/admin/db/voiding_db.inc +++ b/admin/db/voiding_db.inc @@ -16,6 +16,7 @@ include_once($path_to_root . "/manufacturing/includes/manufacturing_db.inc"); function void_transaction($type, $type_no, $date_, $memo_) { + global $Refs; $void_entry = get_voided_entry($type, $type_no); if ($void_entry != null) @@ -28,29 +29,30 @@ function void_transaction($type, $type_no, $date_, $memo_) void_journal_trans($type, $type_no); break; - case ST_BANKPAYMENT : // it's a payment case ST_BANKDEPOSIT : // it's a deposit case ST_BANKTRANSFER : // it's a transfer + if (!check_void_bank_trans($type, $type_no)) + return false; + case ST_BANKPAYMENT : // it's a payment if (!exists_bank_trans($type, $type_no)) return false; void_bank_trans($type, $type_no); break; + case ST_CUSTPAYMENT : // it's a customer payment + if (!check_void_bank_trans($type, $type_no)) + return false; case ST_SALESINVOICE : // it's a customer invoice case ST_CUSTCREDIT : // it's a customer credit note - case ST_CUSTPAYMENT : // it's a customer payment case ST_CUSTDELIVERY : // it's a customer dispatch if (!exists_customer_trans($type, $type_no)) return false; - if ($type == 13) // added 04 Oct 2008 by Joe Hunt. If delivery note has a not voided invoice, then NO. + if ($type == ST_CUSTDELIVERY) // added 04 Oct 2008 by Joe Hunt. If delivery note has a not voided invoice, then NO. { - $delivery = get_customer_trans($type_no, $type); - if ($delivery['trans_link'] != 0) - { - if (get_voided_entry(10, $delivery['trans_link']) === false) + $childs = get_sales_child_lines($type, $type_no, false); // 2011-03-17 This had been changed. Joe + if ($childs && db_num_rows($childs)) return false; - } - } + } post_void_customer_trans($type, $type_no); break; @@ -67,8 +69,11 @@ function void_transaction($type, $type_no, $date_, $memo_) break; case ST_PURCHORDER : // it's a PO - case ST_SUPPRECEIVE : // it's a GRN return false; + + case ST_SUPPRECEIVE : // it's a GRN + if (exists_grn_on_invoices($type_no)) + return false; case ST_SUPPINVOICE : // it's a suppler invoice case ST_SUPPCREDIT : // it's a supplier credit note case ST_SUPPAYMENT : // it's a supplier payment @@ -107,6 +112,7 @@ function void_transaction($type, $type_no, $date_, $memo_) // only add an entry if it's actually been voided add_audit_trail($type, $type_no, $date_, _("Voided.")."\n".$memo_); + $Refs->restore_last($type, $type_no); add_voided_entry($type, $type_no, $date_, $memo_); return true; }