Possibility to view a transaction before final voiding.
authorJoe Hunt <joe.hunt.consulting@gmail.com>
Wed, 19 Nov 2008 10:11:13 +0000 (10:11 +0000)
committerJoe Hunt <joe.hunt.consulting@gmail.com>
Wed, 19 Nov 2008 10:11:13 +0000 (10:11 +0000)
CHANGELOG.txt
admin/void_transaction.php

index 7b7522837eb10ee8468b56c705c2472fbbe5bae2..1635f5c18e813bd18e60b41517383a1b090dcab8 100644 (file)
@@ -19,6 +19,10 @@ Legend:
 ! -> Note
 $ -> Affected files
 
+19-Nov-2008 Joe Hunt
++ Possibility to view a transaction before final voiding.
+$ /admin/void_transaction.php
+
 11-Nov-2008 Janusz Dobrowolski
 # Fixed right alignment of amount cells.
 $ /includes/ui/ui_input.inc
index 4b5669400032cc4cca1800f5a303eaff8699bbc1..551f15e365bea1830110d403a986bc2fce3051b4 100644 (file)
@@ -12,9 +12,82 @@ 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 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 systypes::cost_update() : // it's a stock cost update
+                       return false;
+                       break;
+       }
+
+       return true;
+}
 
 function voiding_controls()
 {
@@ -38,10 +111,26 @@ function voiding_controls()
        submit_center('ProcessVoiding', _("Void Transaction"), true, '', true);
     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, '', true);
+               }       
+               else
+               {
+               display_notification_centered(_("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"), '', true);
+       }       
     }
 
        end_form();