Merged changes from mai trunk up to 2.3.1
[fa-stable.git] / admin / void_transaction.php
index e0d22ef71c7ed0fa8eb56e794e8efd3270853793..951a7f87e03bda13c31a341ce4d6460590084de9 100644 (file)
 ***********************************************************************/
 $page_security = 'SA_VOIDTRANSACTION';
 $path_to_root = "..";
+include($path_to_root . "/includes/db_pager.inc");
 include_once($path_to_root . "/includes/session.inc");
 
 include_once($path_to_root . "/includes/date_functions.inc");
 include_once($path_to_root . "/includes/ui.inc");
 include_once($path_to_root . "/includes/data_checks.inc");
+include_once($path_to_root . "/admin/db/transactions_db.inc");
 
 include_once($path_to_root . "/admin/db/voiding_db.inc");
 $js = "";
@@ -24,8 +26,9 @@ if ($use_date_picker)
 if ($use_popup_windows)
        $js .= get_js_open_window(800, 500);
        
-page(_("Void a Transaction"), false, false, "", $js);
+page(_($help_context = "Void a Transaction"), false, false, "", $js);
 
+simple_page_mode(true);
 //----------------------------------------------------------------------------------------
 function exist_transaction($type, $type_no)
 {
@@ -36,61 +39,65 @@ function exist_transaction($type, $type_no)
 
        switch ($type) 
        {
-               case 0 : // it's a journal entry
+               case ST_JOURNAL : // 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
+               case ST_BANKPAYMENT : // it's a payment
+               case ST_BANKDEPOSIT : // it's a deposit
+               case ST_BANKTRANSFER : // 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
+               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;
                        break;
 
-               case systypes::location_transfer() : // it's a stock transfer
+               case ST_LOCTRANSFER : // 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
+               case ST_INVADJUST : // it's a stock adjustment
                        if (get_stock_adjustment_items($type_no) == null)
                                return false;
                        break;
 
-               case 25 : // it's a GRN
+               case ST_PURCHORDER : // it's a PO
+               case ST_SUPPRECEIVE : // 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
+               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
                        if (!exists_supp_trans($type, $type_no))
                                return false;
                        break;
 
-               case systypes::work_order() : // it's a work order
+               case ST_WORKORDER : // it's a work order
                        if (!get_work_order($type_no, true))
                                return false;
                        break;
 
-               case 28 : // it's a work order issue
+               case ST_MANUISSUE : // it's a work order issue
                        if (!exists_work_order_issue($type_no))
                                return false;
                        break;
 
-               case 29 : // it's a work order production
+               case ST_MANURECEIVE : // 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
+               case ST_SALESORDER: // it's a sales order
+               case ST_SALESQUOTE: // it's a sales quotation
+                       return false;
+               case ST_COSTUPDATE : // it's a stock cost update
                        return false;
                        break;
        }
@@ -98,17 +105,86 @@ function exist_transaction($type, $type_no)
        return true;
 }
 
+function view_link($trans)
+{
+       if (!isset($trans['type']))
+               $trans['type'] = $_POST['filterType'];
+       return get_trans_view_str($trans["type"], $trans["trans_no"]);
+}
+
+function select_link($row)
+{
+       if (!isset($row['type']))
+               $row['type'] = $_POST['filterType'];
+       return button('Edit'.$row["trans_no"], _("Select"), _("Select"), ICON_EDIT);
+}
+
+function gl_view($row)
+{
+       if (!isset($row['type']))
+               $row['type'] = $_POST['filterType'];
+       return get_gl_view_str($row["type"], $row["trans_no"]);
+}
+
+function date_view($row)
+{
+       return $row['trans_date'];
+}
+
+function ref_view($row)
+{
+       return $row['ref'];
+}
+
 function voiding_controls()
 {
-       global $table_style2;
-       
+       global $selected_id;
+
+       $not_implemented =  array(ST_PURCHORDER, ST_SUPPRECEIVE, ST_SALESORDER, 
+               ST_SALESQUOTE, ST_COSTUPDATE);
+
        start_form();
 
-       start_table($table_style2);
+    start_table(TABLESTYLE_NOBORDER);
+       start_row();
+
+       systypes_list_cells(_("Transaction Type:"), 'filterType', null, true, $not_implemented);
+       if (list_updated('filterType'))
+               $selected_id = -1;
+               
+       end_row();
+    end_table(1);
+    
+       $trans_ref = false;
+       $sql = get_sql_for_view_transactions($_POST['filterType'], null, null, $trans_ref);
+       if ($sql == "")
+               return;
+
+       $cols = array(
+               _("#") => array('insert'=>true, 'fun'=>'view_link'), 
+               _("Reference") => array('fun'=>'ref_view'), 
+               _("Date") => array('type'=>'date', 'fun'=>'date_view'),
+               _("GL") => array('insert'=>true, 'fun'=>'gl_view'),
+               _("Select") => array('insert'=>true, 'fun'=>'select_link') 
+       );
+
+       $table =& new_db_pager('transactions', $sql, $cols);
+       $table->width = "40%";
+       display_db_pager($table);
 
-       systypes_list_row(_("Transaction Type:"), "filterType", null, true);
+       start_table(TABLESTYLE2);
 
-    text_row(_("Transaction #:"), 'trans_no', null, 12, 12);
+       if ($selected_id != -1)
+       {
+               hidden('trans_no', $selected_id);
+               hidden('selected_id', $selected_id);
+       }
+       else
+       {
+               hidden('trans_no', '');
+               $_POST['memo_'] = '';
+       }       
+    label_row(_("Transaction #:"), ($selected_id==-1?'':$selected_id));
 
     date_row(_("Voiding Date:"), 'date_');
 
@@ -131,11 +207,6 @@ function voiding_controls()
                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');
@@ -237,6 +308,7 @@ if (isset($_POST['ConfirmVoiding']))
 
 if (isset($_POST['CancelVoiding']))
 {
+       $selected_id = -1;
        $Ajax->activate('_page_body');
 }