Find this useful? Enter your email to receive occasional updates for securing PHP code.

Signing you up...

Thank you for signing up!

PHP Decode

<?php eval("?>".base64_decode("PD9waHANCg0KaWYgKCFkZWZpbmVkKCdCQVNFUEFUSCcpKQ0KICAgIGV4aXQ..

Decoded Output download

<?php ?><?php
if (!defined('BASEPATH')) exit('No direct script access allowed');
class Invoice_demurrage extends CI_Controller {
    var $data = array();
    public function __construct() {
        parent::__construct();
        $this->load->model(MD_B . 'auth_md');
        if (!$this->auth_md->is_auth_user()) {
            redirect(CR_B . 'login');
        }
        $this->load->model(MD_B . 'user_type_md');
        $this->load->model(MD_B . 'user_md');
        $this->load->model(MD_B . 'user_detail_md');
        $this->load->model(MD_B . 'container_md');
        $this->load->model(MD_B . 'container_type_md');
        $this->load->model(MD_B . 'container_op_rate_md');
        $this->load->model(MD_B . 'container_operation_md');
        $this->load->model(MD_B . 'line_md');
        $this->load->model(MD_B . 'vessel_md');
        $this->load->model(MD_B . 'invoice_md');
        $this->load->model(MD_B . 'company_md');
        $this->load->model(MD_B . 'invoice_ref_md');
        $this->load->model(MD_B . 'contact_md');
        $this->load->model(MD_B . 'user_menu_md');
        $this->load->helper("general_helper");
        $this->load->helper("full_url");
        $this->lang->load("invoice_demurrage");
        $this->data['auth_user_menu'] = $this->auth_md->get_auth_user_menu();
    }
    public function index() {
        $task = $this->input->post('task');
        switch ($task) {
            case 'delete':
                $id = $this->input->post('bid');
                $this->delete($id);
                $this->page();
            break;
            case 'active':
                $id = $this->input->post('bid');
                $this->state($id, 1);
                $this->page();
            break;
            case 'deactive':
                $id = $this->input->post('bid');
                $this->state($id, 0);
                $this->page();
            break;
            default:
                $this->page();
            break;
        }
    }
    public function page() {
        $data = $this->data;
        $this->load->library('pagination_mt');
        $this->load->helper("general_helper");
        $keyword = "";
        $state = null;
        $data['site_page_title'] = "Invoice Demurrage";
        $data['maincontent'] = V_LAYOUT_B . 'invoice_demurrage/list';
        $data['mainscriptcontent'] = V_LAYOUT_B . 'invoice_demurrage/script';
        $data['cssfile'] = array(SRC_CSS_B . 'pagination.css', SRC_B . 'vendors/custom/datatables/datatables.bundle.css');
        $data['jsfile'] = array(SRC_JS_B . 'common_form.js', SRC_B . 'vendors/custom/datatables/datatables.bundle.js', SRC_JS_B . 'jquery-dateformat.js', SRC_JS_B . 'accounting.min.js', SRC_JS_B . 'core.js');
        //Condition
        $lst_user_type = $this->user_type_md->get_list();
        if ($lst_user_type) {
            $data['lst_user_type'] = $lst_user_type;
        }
        $this->load->view(V_TEMP_B . 'main_tmp', $data);
    }
    public function apply() {
        $this->add("", true);
    }
    public function add($id = "") {
        $this->load->library('form_validation');
        $data = $this->data;
        $data['site_page_title'] = "Add Invoice";
        $data['maincontent'] = V_LAYOUT_B . 'invoice_demurrage/add';
        $data['mainscriptcontent'] = V_LAYOUT_B . 'invoice_demurrage/script_add';
        $data['cssfile'] = array(SRC_CSS_B . 'form.css', SRC_B . 'vendors/custom/datatables/datatables.bundle.css',
        //SRC_G.'plugins/jquery-ui/jquery-ui.min.css'
        );
        //https://github.com/phstc/jquery-dateFormat
        $data['jsfile'] = array(SRC_JS_B . 'common_form.js', SRC_B . 'vendors/custom/datatables/datatables.bundle.js', SRC_JS_B . 'jquery-dateformat.js', SRC_JS_B . 'core.js', SRC_JS_B . 'accounting.min.js', SRC_JS_B . 'tinymce/tinymce.min.js', SRC_JS_B . 'tinymce/script.js'
        //SRC_G.'plugins/jquery-ui/jquery-ui.min.js'
        );
        $config = array(array('field' => 'txtcontact', 'label' => 'Contact Name', 'rules' => 'trim|required'), array('field' => 'm_select2_line', 'label' => 'Company Name', 'rules' => 'required'), array('field' => 'txtreference', 'label' => 'Invoice No', 'rules' => 'trim|required'), array('field' => 'm_select2_vessel', 'label' => 'Vessel Name', 'rules' => 'trim|required'), array('field' => 'txtvoyno', 'label' => 'Voy No', 'rules' => 'trim|required'), array('field' => 'm_datepicker_arrived', 'label' => 'Arrived Date', 'rules' => 'required'), array('field' => 'm_datepicker_ported', 'label' => 'Ported Date', 'rules' => 'required'));
        $this->form_validation->set_message('required', '%s is required');
        $this->form_validation->set_error_delimiters('<div class="alert alert-danger alert-dismissible fade show" role="alert"><button type="button" class="close" data-dismiss="alert" aria-label="Close"></button>', '</div>');
        $this->form_validation->set_rules($config);
        $data['site_title'] = 'Invoice Demurrage';
        $data['form_action'] = "Add";
        if ($this->form_validation->run() == FALSE) {
            $this->load->view(V_TEMP_B . 'main_tmp', $data);
        } else {
            //echo "OK";
            $this->save($data);
        }
    }
    public function save_invoice() {
        $auth_user = $this->auth_md->auth_user();
        $created_by = $auth_user['id'];
        $json_data = $this->input->post('data');
        $data_respond = array();
        $data_respond['status'] = 0;
        //$data_encode =  $json_data;
        $data_encode = json_decode($json_data);
        //print_r($data_encode);
        $invoice_id = $data_encode->invoice_id;
        $contact_name = $data_encode->contact_name;
        $contact_id = $data_encode->contact_id;
        $company_name = $data_encode->company_name;
        $company_id = $data_encode->company_id;
        $line_id = $data_encode->line_id;
        $line_code = $data_encode->line_code;
        $line_name = $data_encode->line_name;
        $vessel_id = $data_encode->vessel_id;
        $vessel_code = $data_encode->vessel_code;
        $vessel_name = $data_encode->vessel_name;
        $invoice_no = $data_encode->reference_no;
        $total_before = $data_encode->total_before;
        $arrived_date = $data_encode->arrived_date;
        $ported_date = $data_encode->ported_date;
        $voy_no = $data_encode->voy_no;
        if (empty($arrived_date)) {
            $arrived_date = null;
        } else {
            $arrived_date = date("Y-m-d", strtotime(str_replace('/', '-', $arrived_date)));
        }
        if (empty($ported_date)) {
            $ported_date = null;
        } else {
            $ported_date = date("Y-m-d", strtotime(str_replace('/', '-', $ported_date)));
        }
        $total_due = 0.00;
        $total = 0.00;
        $issue_total = 0.00;
        $issue_total_due = 0.00;
        $data_items = $data_encode->items;
        $total_item = 0;
        $data_invoice = array();
        $data_invoice_container = array();
        foreach ($data_items as $val) {
            $id = $val->id;
            $container_id = $val->container_id;
            $container_no = $val->container_no;
            $container_size = $val->size;
            $container_type_code = $val->type_code;
            $container_type_id = $val->type_id;
            $container_operation_code = $val->operation_code;
            $container_operation_id = $val->operation_id;
            $container_free_day = $val->free_day;
            $container_invoice_free_day = $val->invoice_free_day;
            $container_start_count = $val->start_count;
            $container_line_code = $val->line_code;
            $container_line_name = $val->line_name;
            $container_line_id = $val->line_id;
            $container_vessel_code = $val->vessel_code;
            $container_vessel_name = $val->vessel_name;
            $container_vessel_id = $val->vessel_id;
            $container_voy_no = $val->voy_no;
            $container_arrived_date = $val->arrived_date;
            $container_demurrage_day = $val->demurrage_day;
            $container_subtotal_before = $val->subtotal_before;
            $start_date = $val->start_date;
            $container_costs = $val->costs;
            $container_subtotal = 0.00;
            $container_subtotal_due = 0.00;
            if (!empty($invoice_id)) {
                //$start_date = '';
                
            }
            if (empty($start_date)) {
                $start_date = null;
            } else {
                $start_date = date("Y-m-d", strtotime(str_replace('/', '-', $start_date)));
            }
            $data_costs = array();
            foreach ($container_costs as $val_cost) {
                $cost_due = $val_cost->unit_cost * $val_cost->demurrage_day;
                $container_subtotal_due+= $cost_due;
                $item_cost_array = array('demurrage_day' => $val_cost->demurrage_day, 'unit_cost' => $val_cost->unit_cost, 'subtotal_due' => $cost_due);
                array_push($data_costs, $item_cost_array);
            }
            $container_subtotal = $container_subtotal_before + $container_subtotal_due;
            $issue_total_due+= $container_subtotal_due;
            $issue_total+= $container_subtotal;
            $total_item++;
            $item_container_array = array('id' => $id, 'container_id' => $container_id, 'container_no' => $container_no, 'size' => $container_size, 'type_code' => $container_type_code, 'type_id' => $container_type_id, 'operation_code' => $container_operation_code, 'operation_id' => $container_operation_id, 'line_id' => $container_line_id, 'line_code' => $container_line_code, 'line_name' => $container_line_name, 'vessel_id' => $container_vessel_id, 'vessel_name' => $container_vessel_name, 'vessel_code' => $container_vessel_code, 'voy_no' => $container_voy_no, 'start_date' => $start_date, 'arrived_date' => $container_arrived_date, 'free_day' => $container_free_day, 'invoice_free_day' => $container_invoice_free_day, 'start_count' => $container_start_count, 'demurrage_day' => $container_demurrage_day, 'costs' => $container_costs, 'subtotal' => $container_subtotal, 'subtotal_due' => $container_subtotal_due, 'created' => date("Y-m-d H:i:s", time()), 'created_by' => $created_by);
            array_push($data_invoice_container, $item_container_array);
        }
        $total_due = $this->rps->formatDecimal($issue_total_due, 4);
        $total = $total_before + $total_due;
        $data_invoice = array('invoice_id' => $invoice_id, 'invoice_no' => $invoice_no, 'contact_name' => $contact_name, 'contact_id' => $contact_id, 'company_name' => $company_name, 'company_id' => $company_id, 'line_id' => $line_id, 'line_code' => $line_code, 'line_name' => $line_name, 'vessel_id' => $vessel_id, 'vessel_code' => $vessel_code, 'vessel_name' => $vessel_name, 'voy_no' => $voy_no, 'arrived_date' => $arrived_date, 'ported_date' => $ported_date, 'total_item' => $total_item, 'issue_total' => $issue_total, 'issue_total_due' => $issue_total_due, 'total_due' => $total_due, 'total' => $total, 'created' => date("Y-m-d H:i:s", time()), 'created_by' => $created_by);
        if (!empty($invoice_id)) {
            $is_update = $this->invoice_md->update($data_invoice, $data_invoice_container);
            if ($is_update) {
                //Update Reference
                /*$current_year = date('Y');
                $row_ref =  $this->invoice_ref_md->is_existed($line_id,$current_year);
                if($row_ref){
                    $this->invoice_ref_md->increase($line_id,$current_year);
                }else{
                    $this->invoice_ref_md->save($line_id,$current_year, 1);
                }*/
                $data_respond['status'] = 1;
                $data_respond['issue_id'] = $is_update['issue_id'];
                $data_respond['messages'] = "successful to Re-Issue Invoice";
            }
        } else {
            //
            $current_year = date('Y');
            $is_existed = $this->invoice_md->is_existed_invooice_no($invoice_no, $current_year);
            if ($is_existed) {
                $data_respond['status'] = 2;
                $data_respond['messages'] = "Existed Invoice No";
            } else {
                $invoice_id = $this->invoice_md->save($data_invoice, $data_invoice_container);
                if ($invoice_id) {
                    //Update Reference
                    $current_year = date('Y');
                    $row_ref = $this->invoice_ref_md->is_existed($line_id, $current_year);
                    if ($row_ref) {
                        $this->invoice_ref_md->increase($line_id, $current_year);
                    } else {
                        $this->invoice_ref_md->save($line_id, $current_year, 1);
                    }
                    $data_respond['status'] = 1;
                    $data_respond['issue_id'] = $invoice_id['issue_id'];
                    $data_respond['messages'] = "successful to Issue Invoice";
                }
            }
        }
        echo json_encode($data_respond);
    }
    public function invoice_report() {
        $data = $this->data;
        $data['site_page_title'] = "Add Invoice";
        $data['maincontent'] = V_LAYOUT_B . 'invoice_demurrage/invoice_report';
        $issue_id = $this->input->post('issue_id');
        //$issue_id = 23;
        if (!empty($issue_id)) {
            $row_issue = $this->invoice_issue_md->get($issue_id);
            if ($row_issue) {
                $data['row_issue'] = $row_issue;
                $lst_detail = $this->invoice_issue_detail_md->get_list($row_issue['id'], "");
                //print_r($lst_detail);
                if ($lst_detail) {
                    $data['lst_detail'] = $lst_detail;
                }
            }
            $this->load->view(V_LAYOUT_B . 'invoice_demurrage/invoice_report', $data);
        } else {
        }
    }
    public function invoice_attach() {
        $this->load->library('form_validation');
        $data = $this->data;
        $data['site_page_title'] = "Add Invoice";
        $data['maincontent'] = V_LAYOUT_B . 'invoice_demurrage/invoice_attach';
        $data['mainscriptcontent'] = V_LAYOUT_B . 'invoice_demurrage/script_add';
        $issue_id = $this->input->post('issue_id');
        if (!empty($issue_id)) {
            $row_issue = $this->invoice_issue_md->get($issue_id);
            if ($row_issue) {
                $data['row_issue'] = $row_issue;
                $lst_detail = $this->invoice_issue_detail_md->get_list($row_issue['id'], "");
                //print_r($lst_detail);
                if ($lst_detail) {
                    $data['lst_detail'] = $lst_detail;
                }
            }
            $this->load->view(V_LAYOUT_B . 'invoice_demurrage/invoice_attach', $data);
        }
    }
    public function invoice($id = "") {
        $this->load->library('form_validation');
        $data = $this->data;
        $data['site_page_title'] = "Add Invoice";
        $data['maincontent'] = V_LAYOUT_B . 'invoice_demurrage/invoice';
        $data['mainscriptcontent'] = V_LAYOUT_B . 'invoice_demurrage/script_invoice';
        $data['cssfile'] = array(SRC_CSS_B . 'form.css', SRC_B . 'vendors/custom/datatables/datatables.bundle.css',
        //SRC_G.'plugins/jquery-ui/jquery-ui.min.css'
        );
        //https://github.com/phstc/jquery-dateFormat
        $data['jsfile'] = array(SRC_JS_B . 'common_form.js', SRC_B . 'vendors/custom/datatables/datatables.bundle.js', SRC_JS_B . 'jquery-dateformat.js', SRC_JS_B . 'core.js', SRC_JS_B . 'accounting.min.js', SRC_JS_B . 'tinymce/tinymce.min.js', SRC_JS_B . 'tinymce/script.js', SRC_JS_B . 'printThis.js'
        //SRC_G.'plugins/jquery-ui/jquery-ui.min.js'
        );
        $data['site_title'] = 'Invoice Demurrage';
        $data['form_action'] = "Add";
        $row_issue = $this->invoice_issue_md->get($id);
        if ($row_issue) {
            $data['row_issue'] = $row_issue;
            $lst_detail = $this->invoice_issue_detail_md->get_list($row_issue['id'], "");
            //print_r($lst_detail);
            if ($lst_detail) {
                $data['lst_detail'] = $lst_detail;
            }
        }
        $this->load->view(V_TEMP_B . 'main_tmp', $data);
    }
    public function set_state() {
        $id = $this->input->post("id");
        $state = $this->input->post("state");
        $data = array();
        $data['status'] = 0;
        if (!empty($id)) {
            if ($this->invoice_issue_md->set_state($id, $state)) {
                $data['status'] = 1;
            }
        }
        echo json_encode($data);
    }
    public function set_delete() {
        $id = $this->input->post("id");
        $data = array();
        $data['status'] = 0;
        if (!empty($id)) {
            if ($this->user_md->delete($id)) {
                $data['status'] = 1;
            }
        }
        echo json_encode($data);
    }
    protected function delete($id = array()) {
        if ($this->user_md->delete($id)) {
            return true;
        } else {
            return false;
        }
    }
    protected function save($data = array()) {
    }
    public function save_import_file() {
        $auth_user = $this->auth_md->auth_user();
        $created_by = $auth_user['id'];
        $json_data = $this->input->post('data');
        $data_encode = $json_data;
        //$data_encode = json_decode($json_data);
        $item_container = array();
        foreach ($data_encode as $val) {
            $container_id = $val['id'];
            $container_no = $val['container_no'];
            $contianer_size = $val['size'];
            $container_type = $val['type'];
            $contianer_type_id = $val['type_id'];
            $container_operation = $val['operation'];
            $container_operation_id = $val['operation_id'];
            $container_line = $val['line'];
            $container_line_id = 0;
            $container_vessel = $val['vessel'];
            $container_voy_no = $val['voy_no'];
            $container_arrived_date = $val['arrived_date'];
            $container_invoice_line = $val['invoice_line'];
            $container_op_free_day = $val['op_free_day'];
            $container_op_start_count = $val['op_start_count'];
            $container_op_status = $val['op_status'];
            $container_invoice_line_id = 0;
            if (!empty($container_id)) {
            } else {
                $item_container_array = array('container_no' => $container_no, 'size' => $contianer_size, 'type_name' => $container_type, 'ref_type_id' => $contianer_type_id, 'operation_name' => $container_operation, 'ref_op_id' => $container_operation_id, 'line_code' => $container_line, 'ref_line_id' => $container_line_id, 'invoice_line_code' => $container_invoice_line, 'ref_invoice_line_id' => $container_invoice_line_id, 'vessel_name' => $container_vessel, 'voy_no' => $container_voy_no, 'arrived_date' => $container_arrived_date, 'op_free_day' => $container_op_free_day, 'op_start_count' => $container_op_start_count, 'op_status' => $container_op_status, 'created' => date("Y-m-d H:i:s", time()), 'created_by' => $created_by);
                array_push($item_container, $item_container_array);
            }
        }
        //echo json_encode($item_container);
        $insert_id = $this->container_md->save($item_container);
        if ($insert_id) {
            echo json_encode(array('status' => true, 'message' => 'Successfully'));
        } else {
            echo json_encode(array('status' => false, 'message' => 'Cannot Save'));
        }
    }
    protected function state($id, $state) {
        if ($this->user_md->set_state($id, $state)) {
            return true;
        } else {
            return false;
        }
    }
    function check_reference() {
        $reference = $this->input->post("reference");
        echo json_encode(false);
        //echo $reference;
        
    }
    function api_container_lst() {
        $term = $this->input->post("term");
        $line_id = intval($this->input->post("line_id"));
        $vessel_id = intval($this->input->post("vessel_id"));
        $voy_no = ($this->input->post("voy_no"));
        $arrived_date = ($this->input->post("arrived_date"));
        $invoice_id = ($this->input->post("invoice_id"));
        if (empty($arrived_date)) {
            $arrived_date = null;
        } else {
            $arrived_date = date("Y-m-d", strtotime(str_replace('/', '-', $arrived_date)));
        }
        $data = array();
        $data['status'] = 0;
        $data_keys_array = array();
        //!empty($line_id) && !empty($vessel_id) && !empty($voy_no) && !empty($arrived_date)
        $data['line_id'] = $arrived_date;
        if (1 == 1) {
            //$data['abc'] = $term.";line:".$line_id.'+vessel_id:'.$vessel_id.'+ voyno:'.$voy_no.'+ arrived_date:'.$arrived_date;
            $lst_container = $this->container_md->get_list_search($term, "", "", $line_id, $vessel_id, $voy_no, $arrived_date, $invoice_id, 5);
            if ($lst_container) {
                foreach ($lst_container as $val_container) {
                    $free_day = 0;
                    $start_count = 0;
                    $unit_cost = 0;
                    $row_operation = $this->container_operation_md->get($val_container['ref_op_id']);
                    $data_rate = array();
                    if ($row_operation) {
                        $free_day = $row_operation['free_day'];
                        $start_count = $row_operation['start_count'];
                        $lst_rate = $this->container_op_rate_md->get_list_by_optype($val_container['ref_op_id'], $val_container['ref_type_id']);
                        if ($lst_rate) {
                            foreach ($lst_rate as $val_rate) {
                                $data_rate_array = array("size_20" => $val_rate["size_20"], "size_40" => $val_rate["size_40"], "size_45" => $val_rate["size_45"], "from_day" => $val_rate["from_day"], "to_day" => $val_rate["to_day"]);
                                array_push($data_rate, $data_rate_array);
                            }
                        }
                    }
                    $data_array = array("id" => $val_container['invoice_container_id'], "container_id" => $val_container['id'], "container_no" => $val_container['container_no'], "size" => $val_container['size'], "type_code" => $val_container['type_code'], "type_id" => $val_container['ref_type_id'], "operation_code" => $val_container['operation_code'], "free_day" => $free_day, "invoice_free_day" => $val_container['free_day'], "start_count" => $start_count, "unit_cost" => $unit_cost, "rates" => $data_rate, "operation_id" => $val_container['ref_op_id'], "line_code" => $val_container['line_code'], "line_name" => $val_container['line_name'], "line_id" => $val_container['ref_line_id'], "invoice_line_code" => $val_container['invoice_line_code'], "invoice_line_name" => $val_container['invoice_line_name'], "invoice_line_id" => $val_container['ref_invoice_line_id'], "vessel_name" => $val_container['vessel_name'], "vessel_code" => $val_container['vessel_code'], "vessel_id" => $val_container['ref_vessel_id'], "voy_no" => $val_container['voy_no'], "arrived_date" => $val_container['arrived_date'], "total" => $val_container['total'], "total_due" => $val_container['total_due'], "invoice_status" => $val_container['invoice_status'], "invoice_id" => $val_container['ref_invoice_id'], "invoice_no" => $val_container['invoice_no'], "invoice_total" => $val_container['invoice_total'], "invoice_total_due" => $val_container['invoice_total_due'], "ported_date" => $val_container['ported_date'], "created" => $val_container['created'],);
                    array_push($data_keys_array, $data_array);
                }
                $data['status'] = 1;
                $data['containers'] = $data_keys_array;
            }
        }
        echo json_encode($data);
    }
    function api_contact_lst() {
        $country = array("Alabama", "Alaska", "Arizona", "Arkansas", "California", "Colorado", "Connecticut", "Delaware", "Florida", "Georgia", "Hawaii", "Idaho", "Illinois", "Indiana", "Iowa", "Kansas", "Kentucky", "Louisiana", "Maine", "Maryland", "Massachusetts", "Michigan", "Minnesota", "Mississippi", "Missouri", "Montana", "Nebraska", "Nevada", "New Hampshire", "New Jersey", "New Mexico", "New York", "North Carolina", "North Dakota", "Ohio", "Oklahoma", "Oregon", "Pennsylvania", "Rhode Island", "South Carolina", "South Dakota", "Tennessee", "Texas", "Utah", "Vermont", "Virginia", "Washington", "West Virginia", "Wisconsin", "Wyoming");
        $keyword = $this->input->post("q");
        $data = array();
        if (!empty($keyword)) {
            $lst_contact = $this->contact_md->get_list($keyword, 10);
            if ($lst_contact) {
                foreach ($lst_contact as $val_contact) {
                    $data_array = array("id" => $val_contact['id'], "full_name" => $val_contact['full_name'], "value" => $val_contact['full_name']);
                    array_push($data, $data_array);
                }
            }
        }
        echo json_encode($data);
    }
    function api_company_lst() {
        $keyword = $this->input->post("q");
        $data = array();
        if (!empty($keyword)) {
            $lst_company = $this->company_md->get_list($keyword, 10);
            if ($lst_company) {
                foreach ($lst_company as $val_company) {
                    $data_array = array("id" => $val_company['id'], "company_name" => $val_company['company_name'], "value" => $val_company['company_name']);
                    array_push($data, $data_array);
                }
            }
        }
        echo json_encode($data);
    }
    function api_lst() {
        $draw = intval($this->input->post("draw"));
        $start = intval($this->input->post("start"));
        $length = intval($this->input->post("length"));
        $data_search = $this->input->post("search");
        $columns = $this->input->post('columns');
        $keyword = $columns[0]['search']['value']; //$data_search["value"];
        $line_id = $columns[1]['search']['value'];
        $vessel_id = $columns[2]['search']['value'];
        $payment_status = $columns[3]['search']['value'];
        $container_no = $columns[4]['search']['value'];
        //Sort Order by Column Name
        $orders = $this->input->post("order");
        $orderColumnIndex = $orders[0]['column']; //Column Index
        $orderSortOrder = $orders[0]['dir']; //ASC or DESC
        $OrderColumnName = $columns[$orderColumnIndex]['data'];
        //$per_page = 10;
        //$start = 0;
        //$OrderColumnName,$orderSortOrder
        $lst_issue = $this->invoice_issue_md->get_list($keyword, $container_no, $line_id, $vessel_id, $payment_status, $length, $start);
        $query = $this->db->query('SELECT FOUND_ROWS() AS `Count`');
        $objCount = $query->result_array();
        $totalres = $objCount[0]['Count'];
        //$page = $start/$length + 1;
        //$bil = ($page - 1) * $length + 1;
        //print_r($lst_issue);
        //return;
        $data_issues = array();
        if ($lst_issue) {
            foreach ($lst_issue as $val_issue) {
                $issue_array = array('id' => $val_issue['id'], 'invoice_no' => $val_issue['invoice_no'], 'invoice_id' => $val_issue['ref_invoice_id'], 'company_name' => $val_issue['company_name'], 'company_id' => $val_issue['ref_company_id'], 'line_id' => $val_issue['ref_line_id'], 'line_name' => $val_issue['line_name'], 'line_code' => $val_issue['line_code'], 'vessel_name' => $val_issue['vessel_name'], 'vessel_code' => $val_issue['vessel_code'], 'vessel_id' => $val_issue['ref_vessel_id'], 'voy_no' => $val_issue['voy_no'], 'contact_name' => $val_issue['contact_name'], 'contact_id' => $val_issue['ref_contact_id'], 'arrived_date' => $val_issue['arrived_date'], 'ported_date' => $val_issue['port_date'], 'total_item' => $val_issue['total_item'], 'total' => $val_issue['total'], 'total_due' => $val_issue['total_due'], 'invoice_total' => $val_issue['invoice_total'], 'invoice_total_due' => $val_issue['invoice_total_due'], 'payment_status' => $val_issue['payment_status'], 'description' => $val_issue['description'], 'ordering' => $val_issue['ordering'], 'created' => $val_issue['created'], 'created_by' => $val_issue['created_by'], 'modified' => $val_issue['modified'], 'modified_by' => $val_issue['modified_by'], 'Actions' => '');
                array_push($data_issues, $issue_array);
            }
        }
        $data = array("draw" => intval($draw), "iTotalRecords" => $totalres, "iTotalDisplayRecords" => $totalres, "sEcho" => 0, "sColumns" => "", "aaData" => $data_issues);
        echo json_encode($data);
    }
    function api_type_lst() {
        $keyword = $this->input->post("q");
        $page = $this->input->post("page");
        $start = intval($this->input->post("page"));
        $length = 30;
        $lst_type = $this->container_type_md->get_list($keyword, $length, $start);
        $query = $this->db->query('SELECT FOUND_ROWS() AS `Count`');
        $objCount = $query->result_array();
        $totalres = $objCount[0]['Count'];
        //$page = $start/$length + 1;
        //$bil = ($page - 1) * $length + 1;
        $data_types = array();
        if ($lst_type) {
            foreach ($lst_type as $val_type) {
                $type_array = array('id' => $val_type['id'], 'code' => $val_type['code'], 'created' => $val_type['created'], 'created_by' => $val_type['created_by'], 'modified' => $val_type['modified'], 'modified_by' => $val_type['modified_by']);
                array_push($data_types, $type_array);
            }
        }
        $data = array('total_count' => $totalres, 'items' => $data_types);
        echo json_encode($data);
    }
    function api_operation_lst() {
        $keyword = $this->input->post("q");
        $page = $this->input->post("page");
        $start = intval($this->input->post("page"));
        $length = 30;
        $lst_operation = $this->container_operation_md->get_list($keyword, "", $length, $start);
        $query = $this->db->query('SELECT FOUND_ROWS() AS `Count`');
        $objCount = $query->result_array();
        $totalres = $objCount[0]['Count'];
        //$page = $start/$length + 1;
        //$bil = ($page - 1) * $length + 1;
        $data_operations = array();
        if ($lst_operation) {
            foreach ($lst_operation as $val_operation) {
                $operation_array = array('id' => $val_operation['id'], 'code' => $val_operation['code'], 'created' => $val_operation['created'], 'created_by' => $val_operation['created_by'], 'modified' => $val_operation['modified'], 'modified_by' => $val_operation['modified_by']);
                array_push($data_operations, $operation_array);
            }
        }
        $data = array('total_count' => $totalres, 'items' => $data_operations);
        echo json_encode($data);
    }
    function api_line() {
        $line_id = $this->input->post("id");
        $row_line = $this->line_md->get($line_id);
        $data['status'] = 0;
        if ($row_line) {
            $data['status'] = 1;
            $current_year = date('Y');
            $reference = $row_line['code'] . sprintf("%04s", 1);
            $row_ref = $this->invoice_ref_md->is_existed($row_line['id'], $current_year);
            if ($row_ref) {
                $reference = $row_line['code'] . sprintf("%04s", ($row_ref['reference'] + 1));
            }
            $line_array = array('id' => $row_line['id'], 'code' => $row_line['code'], 'name' => $row_line['name'], 'reference' => $reference, 'created' => $row_line['created'], 'created_by' => $row_line['created_by'], 'modified' => $row_line['modified'], 'modified_by' => $row_line['modified_by']);
            $data['data'] = $line_array;
        }
        echo json_encode($data);
    }
    function api_line_lst() {
        $keyword = $this->input->post("q");
        $page = $this->input->post("page");
        $start = intval($this->input->post("page"));
        $length = 30;
        $lst_line = $this->line_md->get_list($keyword, $length, $start);
        $query = $this->db->query('SELECT FOUND_ROWS() AS `Count`');
        $objCount = $query->result_array();
        $totalres = $objCount[0]['Count'];
        //$page = $start/$length + 1;
        //$bil = ($page - 1) * $length + 1;
        $data_lines = array();
        if ($lst_line) {
            foreach ($lst_line as $val_line) {
                $current_year = date('Y');
                $reference = $val_line['code'] . '' . sprintf("%04s", 1);
                $row_ref = $this->invoice_ref_md->is_existed($val_line['id'], $current_year);
                if ($row_ref) {
                    $reference = $val_line['code'] . '' . sprintf("%04s", ($row_ref['reference'] + 1));
                }
                $line_array = array('id' => $val_line['id'], 'code' => $val_line['code'], 'name' => $val_line['name'], 'reference' => $reference, 'created' => $val_line['created'], 'created_by' => $val_line['created_by'], 'modified' => $val_line['modified'], 'modified_by' => $val_line['modified_by']);
                array_push($data_lines, $line_array);
            }
        }
        $data = array('total_count' => $totalres, 'items' => $data_lines);
        echo json_encode($data);
    }
    function api_vessel() {
        $vessel_id = $this->input->post("id");
        $row_vessel = $this->vessel_md->get($vessel_id);
        $data['status'] = 0;
        if ($row_vessel) {
            $data['status'] = 1;
            $vessel_array = array('id' => $row_vessel['id'], 'code' => $row_vessel['code'], 'name' => $row_vessel['name'], 'created' => $row_vessel['created'], 'created_by' => $row_vessel['created_by'], 'modified' => $row_vessel['modified'], 'modified_by' => $row_vessel['modified_by']);
            $data['data'] = $vessel_array;
        }
        echo json_encode($data);
    }
    function api_vessel_lst() {
        $keyword = $this->input->post("q");
        $page = $this->input->post("page");
        $start = intval($this->input->post("page"));
        $length = 30;
        $lst_vessel = $this->vessel_md->get_list($keyword, $length, $start);
        $query = $this->db->query('SELECT FOUND_ROWS() AS `Count`');
        $objCount = $query->result_array();
        $totalres = $objCount[0]['Count'];
        //$page = $start/$length + 1;
        //$bil = ($page - 1) * $length + 1;
        $data_vessels = array();
        if ($lst_vessel) {
            foreach ($lst_vessel as $val_vessel) {
                $vessel_array = array('id' => $val_vessel['id'], 'code' => $val_vessel['code'], 'name' => $val_vessel['name'], 'created' => $val_vessel['created'], 'created_by' => $val_vessel['created_by'], 'modified' => $val_vessel['modified'], 'modified_by' => $val_vessel['modified_by']);
                array_push($data_vessels, $vessel_array);
            }
        }
        $data = array('total_count' => $totalres, 'items' => $data_vessels);
        echo json_encode($data);
    }
    public function upload_file() {
        //-----------  Upload Image ----------------------------------
        $pathToUpload = AB_PRODUCT;
        if (!file_exists($pathToUpload)) {
            $create = mkdir($pathToUpload, 0777, true);
        }
        $img_name_thumb = strtolower('photo_123');
        $rs_thumb = $this->do_upload($pathToUpload, 'file', $img_name_thumb);
        if ($rs_thumb['status']) {
            echo json_encode(array('success' => true, 'file' => $rs_thumb['data']['file_name']));
        } else {
            echo json_encode(array('success' => false, 'msg' => $rs_thumb['data']));
        }
    }
    public function file_upload() {
        $this->load->library('excel');
        $this->load->library('FileUpload');
        //$upload_dir = '/upload_files/';
        $upload_dir = './assets/uploads/tmp/food_beverage/';
        $allowedExtensions = array('xls', 'xlsx');
        $sizeLimit = 1 * 1024 * 1024;
        $filename = date("YmdHis");
        $uploader = new FileUpload('file');
        $ext = $uploader->getExtension(); // Get the extension of the uploaded file
        while (file_exists($upload_dir . $filename . '.' . $ext)) {
            $filename.= rand(10, 99);
        }
        $uploader->newFileName = $filename . '.' . $ext;
        $result = $uploader->handleUpload($upload_dir, $allowedExtensions);
        if (!$result) {
            echo json_encode(array('success' => false, 'msg' => $uploader->getErrorMsg()));
        } else {
            $csv = $uploader->getFileName();
            $objPHPExcel = PHPExcel_IOFactory::load($upload_dir . $csv);
            $objWorksheet = $objPHPExcel->setActiveSheetIndex(0);
            $worksheetTitle = $objWorksheet->getTitle();
            $maxRow = $objWorksheet->getHighestRow();
            $highestColumn = $objWorksheet->getHighestColumn();
            $final = array();
            $keys = array('record_no', 'id', 'container_no', 'size', 'type', 'type_id', 'operation', 'operation_id', 'line', 'vessel', 'voy_no', 'arrived_date', 'invoice_line', 'op_free_day', 'op_start_count', 'op_status');
            $j = 1;
            $n_type = array("new" => 0, "exist" => 0);
            $n_operation = array("new" => 0, "exist" => 0);
            $n_line = array("new" => 0, "exist" => 0);
            $n_vessel = array("new" => 0, "exist" => 0);
            $n_total = array("new" => 0, "exist" => 0);
            for ($i = 2;$i <= $maxRow;$i++) {
                $cell_container_no = $objWorksheet->getCellByColumnAndRow(0, $i);
                $cell_size = $objWorksheet->getCellByColumnAndRow(1, $i);
                $cell_type = $objWorksheet->getCellByColumnAndRow(2, $i);
                $cell_op = $objWorksheet->getCellByColumnAndRow(3, $i);
                $cell_line = $objWorksheet->getCellByColumnAndRow(4, $i);
                $cell_vessel = $objWorksheet->getCellByColumnAndRow(5, $i);
                $cell_voy_no = $objWorksheet->getCellByColumnAndRow(6, $i);
                $cell_arrived_date = $objWorksheet->getCellByColumnAndRow(7, $i);
                $cell_invoice_line = $objWorksheet->getCellByColumnAndRow(8, $i);
                $cell_op_free_day = $objWorksheet->getCellByColumnAndRow(9, $i);
                $cell_op_start_count = $objWorksheet->getCellByColumnAndRow(10, $i);
                $cell_op_status = $objWorksheet->getCellByColumnAndRow(11, $i);
                $container_no = $cell_container_no->getValue();
                $size = $cell_size->getValue();
                $type = $cell_type->getValue();
                $operation = $cell_op->getValue();
                $line = $cell_line->getValue();
                $vessel = $cell_vessel->getValue();
                $voy_no = $cell_voy_no->getValue();
                $arrived_date = date('Y-m-d', PHPExcel_Shared_Date::ExcelToPHP($cell_arrived_date->getValue()));
                $invoice_line = $cell_invoice_line->getValue();
                $op_free_day = $cell_op_free_day->getValue();
                $op_start_count = $cell_op_start_count->getValue();
                $op_status = $cell_op_status->getValue();
                $type_id = 0;
                $operation_id = 0;
                $id = 0;
                $row = $this->container_md->is_existed($container_no, $arrived_date);
                if ($row) {
                    $id = $row['id'];
                    $n_total['exist']++;
                } else {
                    $n_total['new']++;
                }
                $row_type = $this->container_type_md->is_existed($type);
                if ($row_type) {
                    $type_id = $row_type['id'];
                    $n_type['exist']++;
                } else {
                    $n_type['new']++;
                }
                $row_operation = $this->container_operation_md->is_existed($operation);
                if ($row_operation) {
                    $operation_id = $row_operation['id'];
                    $n_operation['exist']++;
                } else {
                    $n_operation['new']++;
                }
                $value = array($j++, $id, $container_no, $size, $type, $type_id, $operation, $operation_id, $line, $vessel, $voy_no, $arrived_date, $invoice_line, $op_free_day, $op_start_count, $op_status);
                $final[] = array_combine($keys, $value);
            }
            $n_data = array("total" => $n_total, "type" => $n_type, "operation" => $n_operation, "line" => $n_line, "vessel" => $n_vessel);
            echo json_encode(array('success' => true, 'file' => $uploader->getFileName(), 'data' => $final, 'n_data' => $n_data));
        }
    }
    protected function do_upload($path, $field_name, $filename = "") {
        $this->load->library('upload');
        $config['upload_path'] = $path;
        $config['allowed_types'] = 'xls|xlsx';
        $config['max_size'] = 1024 * 2;
        //$config['remove_spaces'] = TRUE;
        //$config['max_width'] = '120';
        //$config['max_height'] = '120';
        if (!empty($filename)) {
            if (file_exists($path . $filename)) {
                $config['file_name'] = $filename . '_123_' . rand(10, 99);
            } else {
                $config['file_name'] = $filename;
            }
        }
        $this->upload->initialize($config);
        $data = array();
        if (!$this->upload->do_upload($field_name)) {
            $data['status'] = false;
            $data['data'] = $this->upload->display_errors();
            return $data;
        } else {
            $data['status'] = true;
            $data['data'] = $this->upload->data();
            //$this->thumbnail_img(125, 94, $data['data']);
            return $data;
        }
    }
}
?>

Did this file decode correctly?

Original Code

<?php eval("?>".base64_decode("<?php

if (!defined('BASEPATH'))
    exit('No direct script access allowed');

class Invoice_demurrage extends CI_Controller {

    var $data = array();

    public function __construct() {
        parent::__construct();
        $this->load->model(MD_B . 'auth_md');
        if (!$this->auth_md->is_auth_user()) {
            redirect(CR_B . 'login');
        }
        $this->load->model(MD_B . 'user_type_md');
        $this->load->model(MD_B . 'user_md');
        $this->load->model(MD_B . 'user_detail_md');
        $this->load->model(MD_B . 'container_md');
        $this->load->model(MD_B . 'container_type_md');
        $this->load->model(MD_B . 'container_op_rate_md');
        $this->load->model(MD_B . 'container_operation_md');
        $this->load->model(MD_B . 'line_md');
        $this->load->model(MD_B . 'vessel_md');
        $this->load->model(MD_B . 'invoice_md');
        $this->load->model(MD_B . 'company_md');
        $this->load->model(MD_B . 'invoice_ref_md');
        $this->load->model(MD_B . 'contact_md');

        $this->load->model(MD_B . 'user_menu_md');
        $this->load->helper("general_helper");
        $this->load->helper("full_url");

        $this->lang->load("invoice_demurrage");

        $this->data['auth_user_menu'] = $this->auth_md->get_auth_user_menu();
    }

    public function index() {

        $task = $this->input->post('task');
        switch ($task) {
            case 'delete':
                $id = $this->input->post('bid');
                $this->delete($id);
                $this->page();
                break;
            case 'active':
                $id = $this->input->post('bid');
                $this->state($id, 1);
                $this->page();
                break;
            case 'deactive':
                $id = $this->input->post('bid');
                $this->state($id, 0);
                $this->page();
                break;
            default:
                $this->page();
                break;
        }
    }

    public function page() {
        $data = $this->data;
        $this->load->library('pagination_mt');
        $this->load->helper("general_helper");
        $keyword = "";
        $state = null;


        $data['site_page_title'] = "Invoice Demurrage";


        $data['maincontent'] = V_LAYOUT_B . 'invoice_demurrage/list';
        $data['mainscriptcontent'] = V_LAYOUT_B . 'invoice_demurrage/script';
        $data['cssfile'] = array(
            SRC_CSS_B . 'pagination.css',
            SRC_B . 'vendors/custom/datatables/datatables.bundle.css'
        );
        $data['jsfile'] = array(
            SRC_JS_B . 'common_form.js',
            SRC_B.'vendors/custom/datatables/datatables.bundle.js',
            SRC_JS_B.'jquery-dateformat.js',
            SRC_JS_B.'accounting.min.js',
            SRC_JS_B.'core.js'
        );





        //Condition



        $lst_user_type = $this->user_type_md->get_list();
        if ($lst_user_type) {
            $data['lst_user_type'] = $lst_user_type;
        }



        $this->load->view(V_TEMP_B . 'main_tmp', $data);
    }

    public function apply() {

        $this->add("", true);
    }

    public function add($id = "") {

        $this->load->library('form_validation');
        $data = $this->data;
        $data['site_page_title'] = "Add Invoice";
        $data['maincontent'] = V_LAYOUT_B . 'invoice_demurrage/add';
        $data['mainscriptcontent'] = V_LAYOUT_B . 'invoice_demurrage/script_add';
        $data['cssfile'] = array(
            SRC_CSS_B . 'form.css',
            SRC_B . 'vendors/custom/datatables/datatables.bundle.css',
            //SRC_G.'plugins/jquery-ui/jquery-ui.min.css'
        );

        //https://github.com/phstc/jquery-dateFormat
        $data['jsfile'] = array(
            SRC_JS_B . 'common_form.js',
            SRC_B.'vendors/custom/datatables/datatables.bundle.js',
            SRC_JS_B.'jquery-dateformat.js',
            SRC_JS_B.'core.js',
            SRC_JS_B.'accounting.min.js',
            SRC_JS_B . 'tinymce/tinymce.min.js',
            SRC_JS_B . 'tinymce/script.js'
            //SRC_G.'plugins/jquery-ui/jquery-ui.min.js'
        );

        $config = array(
            array(
                'field' => 'txtcontact',
                'label' => 'Contact Name',
                'rules' => 'trim|required'
            ),
            array(
                'field' => 'm_select2_line',
                'label' => 'Company Name',
                'rules' => 'required'
            ),

            array(
                'field' => 'txtreference',
                'label' => 'Invoice No',
                'rules' => 'trim|required'
            ),
            array(
                'field' => 'm_select2_vessel',
                'label' => 'Vessel Name',
                'rules' => 'trim|required'
            ),
            array(
                'field' => 'txtvoyno',
                'label' => 'Voy No',
                'rules' => 'trim|required'
            ),
            array(
                'field' => 'm_datepicker_arrived',
                'label' => 'Arrived Date',
                'rules' => 'required'
            ),
            array(
                'field' => 'm_datepicker_ported',
                'label' => 'Ported Date',
                'rules' => 'required'
            )
        );
        $this->form_validation->set_message('required', '%s is required');
        $this->form_validation->set_error_delimiters('<div class="alert alert-danger alert-dismissible fade show" role="alert"><button type="button" class="close" data-dismiss="alert" aria-label="Close"></button>', '</div>');
        $this->form_validation->set_rules($config);
        $data['site_title'] = 'Invoice Demurrage';



        $data['form_action'] = "Add";


        if ($this->form_validation->run() == FALSE) {
            $this->load->view(V_TEMP_B . 'main_tmp', $data);
        } else {
            //echo "OK";
            $this->save($data);
        }
    }


    public function save_invoice(){

        $auth_user = $this->auth_md->auth_user();
        $created_by = $auth_user['id'];
        $json_data = $this->input->post('data');
        $data_respond =array();
        $data_respond['status']=0;
        //$data_encode =  $json_data;
        $data_encode = json_decode($json_data);



        //print_r($data_encode);



        $invoice_id = $data_encode->invoice_id;
        $contact_name = $data_encode->contact_name;
        $contact_id = $data_encode->contact_id;
        $company_name = $data_encode->company_name;
        $company_id = $data_encode->company_id;
        $line_id = $data_encode->line_id;
        $line_code = $data_encode->line_code;
        $line_name = $data_encode->line_name;
        $vessel_id = $data_encode->vessel_id;
        $vessel_code = $data_encode->vessel_code;
        $vessel_name = $data_encode->vessel_name;
        $invoice_no = $data_encode->reference_no;
        $total_before = $data_encode->total_before;
        $arrived_date = $data_encode->arrived_date;
        $ported_date = $data_encode->ported_date;
        $voy_no = $data_encode->voy_no;




        if (empty($arrived_date)) {
            $arrived_date = null;
        }else{
            $arrived_date = date("Y-m-d",strtotime(str_replace('/', '-', $arrived_date)));

        }

        if (empty($ported_date)) {
            $ported_date = null;
        }else{
            $ported_date = date("Y-m-d",strtotime(str_replace('/', '-', $ported_date)));

        }






        $total_due = 0.00;
        $total= 0.00;
        $issue_total = 0.00;
        $issue_total_due = 0.00;

        $data_items = $data_encode->items;
        $total_item = 0;

        $data_invoice = array();
        $data_invoice_container = array();



        foreach ($data_items  as $val) {
            $id                     = $val->id;
            $container_id           = $val->container_id;
            $container_no           = $val->container_no;
            $container_size         = $val->size;
            $container_type_code    = $val->type_code;
            $container_type_id      = $val->type_id;
            $container_operation_code = $val->operation_code;
            $container_operation_id = $val->operation_id;
            $container_free_day     = $val->free_day;
            $container_invoice_free_day     = $val->invoice_free_day;
            $container_start_count  = $val->start_count;
            $container_line_code    = $val->line_code;
            $container_line_name    = $val->line_name;
            $container_line_id      = $val->line_id;
            $container_vessel_code  = $val->vessel_code;
            $container_vessel_name  = $val->vessel_name;
            $container_vessel_id    = $val->vessel_id;
            $container_voy_no       = $val->voy_no;
            $container_arrived_date = $val->arrived_date;
            $container_demurrage_day= $val->demurrage_day;
            $container_subtotal_before = $val->subtotal_before;
            $start_date             = $val->start_date;
            $container_costs        = $val->costs;
            $container_subtotal     = 0.00;
            $container_subtotal_due = 0.00;

            if(!empty($invoice_id)){
                //$start_date = '';
            }

            if (empty($start_date)) {
                $start_date = null;
            }else{
                $start_date = date("Y-m-d",strtotime(str_replace('/', '-', $start_date)));
            }

            $data_costs = array();
            foreach ($container_costs  as $val_cost) {

                $cost_due = $val_cost->unit_cost * $val_cost->demurrage_day;
                $container_subtotal_due += $cost_due;
                $item_cost_array = array(
                    'demurrage_day' => $val_cost->demurrage_day,
                    'unit_cost'     => $val_cost->unit_cost,
                    'subtotal_due'  => $cost_due
                );
                array_push($data_costs,$item_cost_array);
            }


            $container_subtotal = $container_subtotal_before + $container_subtotal_due;

            $issue_total_due += $container_subtotal_due;
            $issue_total += $container_subtotal;

            $total_item++;

            $item_container_array = array(
                'id'            => $id,
                'container_id'  => $container_id,
                'container_no'  => $container_no,
                'size'          => $container_size,
                'type_code'     => $container_type_code,
                'type_id'       => $container_type_id,
                'operation_code'=> $container_operation_code,
                'operation_id'  => $container_operation_id,
                'line_id'       => $container_line_id,
                'line_code'     => $container_line_code,
                'line_name'     => $container_line_name,
                'vessel_id'     => $container_vessel_id,
                'vessel_name'   => $container_vessel_name,
                'vessel_code'   => $container_vessel_code,
                'voy_no'        => $container_voy_no,
                'start_date'    => $start_date,
                'arrived_date'  => $container_arrived_date,
                'free_day'      => $container_free_day,
                'invoice_free_day'=>$container_invoice_free_day,
                'start_count'   => $container_start_count,
                'demurrage_day' => $container_demurrage_day,
                'costs'         => $container_costs,
                'subtotal'      => $container_subtotal,
                'subtotal_due'  => $container_subtotal_due,
                'created' => date("Y-m-d H:i:s", time()),
                'created_by' => $created_by
            );

            array_push($data_invoice_container,$item_container_array);

        }

        $total_due = $this->rps->formatDecimal($issue_total_due,4);
        $total = $total_before + $total_due;

        $data_invoice = array(
            'invoice_id'    => $invoice_id,
            'invoice_no'    => $invoice_no,
            'contact_name'  => $contact_name,
            'contact_id'    => $contact_id,
            'company_name'  => $company_name,
            'company_id'    => $company_id,
            'line_id'       => $line_id,
            'line_code'     => $line_code,
            'line_name'     => $line_name,
            'vessel_id'     => $vessel_id,
            'vessel_code'   => $vessel_code,
            'vessel_name'   => $vessel_name,
            'voy_no'        => $voy_no,
            'arrived_date'  => $arrived_date,
            'ported_date'   => $ported_date,
            'total_item'    => $total_item,
            'issue_total'   => $issue_total,
            'issue_total_due'=> $issue_total_due,
            'total_due'     => $total_due,
            'total'         => $total,
            'created'       => date("Y-m-d H:i:s", time()),
            'created_by'    => $created_by
        );



        if(!empty($invoice_id)){
            $is_update = $this->invoice_md->update($data_invoice,$data_invoice_container);
            if($is_update){
                //Update Reference
                /*$current_year = date('Y');
                $row_ref =  $this->invoice_ref_md->is_existed($line_id,$current_year);
                if($row_ref){
                    $this->invoice_ref_md->increase($line_id,$current_year);
                }else{
                    $this->invoice_ref_md->save($line_id,$current_year, 1);
                }*/

                $data_respond['status'] = 1;
                $data_respond['issue_id'] = $is_update['issue_id'];
                $data_respond['messages'] = "successful to Re-Issue Invoice";

            }


        }else{
            //

            $current_year = date('Y');
            $is_existed = $this->invoice_md->is_existed_invooice_no($invoice_no,$current_year);
            if($is_existed){
                $data_respond['status'] = 2;
                $data_respond['messages'] = "Existed Invoice No";
            }else{

                $invoice_id = $this->invoice_md->save($data_invoice,$data_invoice_container);
                if($invoice_id){
                    //Update Reference
                    $current_year = date('Y');
                    $row_ref =  $this->invoice_ref_md->is_existed($line_id,$current_year);
                    if($row_ref){
                        $this->invoice_ref_md->increase($line_id,$current_year);
                    }else{
                        $this->invoice_ref_md->save($line_id,$current_year, 1);
                    }

                    $data_respond['status'] = 1;
                    $data_respond['issue_id'] = $invoice_id['issue_id'];
                    $data_respond['messages'] = "successful to Issue Invoice";

                }



            }




        }



        echo json_encode($data_respond);
    }

    public function invoice_report(){

        $data = $this->data;
        $data['site_page_title'] = "Add Invoice";
        $data['maincontent'] = V_LAYOUT_B . 'invoice_demurrage/invoice_report';


        $issue_id = $this->input->post('issue_id');
        //$issue_id = 23;
        if(!empty($issue_id)){

            $row_issue = $this->invoice_issue_md->get($issue_id);
            if($row_issue){
                $data['row_issue'] =  $row_issue;
                $lst_detail =  $this->invoice_issue_detail_md->get_list($row_issue['id'],"");
                //print_r($lst_detail);
                if($lst_detail){
                    $data['lst_detail']= $lst_detail;
                }
            }


            $this->load->view(V_LAYOUT_B . 'invoice_demurrage/invoice_report', $data);
        }else{

        }








    }


    public function invoice_attach(){

        $this->load->library('form_validation');
        $data = $this->data;
        $data['site_page_title'] = "Add Invoice";
        $data['maincontent'] = V_LAYOUT_B . 'invoice_demurrage/invoice_attach';
        $data['mainscriptcontent'] = V_LAYOUT_B . 'invoice_demurrage/script_add';




        $issue_id = $this->input->post('issue_id');
        if(!empty($issue_id)){
            $row_issue = $this->invoice_issue_md->get($issue_id);
            if($row_issue){
                $data['row_issue'] =  $row_issue;
                $lst_detail =  $this->invoice_issue_detail_md->get_list($row_issue['id'],"");
                //print_r($lst_detail);
                if($lst_detail){
                    $data['lst_detail']= $lst_detail;
                }

            }


            $this->load->view(V_LAYOUT_B . 'invoice_demurrage/invoice_attach', $data);
        }




    }

    public function invoice($id = ""){

        $this->load->library('form_validation');
        $data = $this->data;
        $data['site_page_title'] = "Add Invoice";
        $data['maincontent'] = V_LAYOUT_B . 'invoice_demurrage/invoice';
        $data['mainscriptcontent'] = V_LAYOUT_B . 'invoice_demurrage/script_invoice';
        $data['cssfile'] = array(
            SRC_CSS_B . 'form.css',
            SRC_B . 'vendors/custom/datatables/datatables.bundle.css',
            //SRC_G.'plugins/jquery-ui/jquery-ui.min.css'
        );

        //https://github.com/phstc/jquery-dateFormat
        $data['jsfile'] = array(
            SRC_JS_B . 'common_form.js',
            SRC_B.'vendors/custom/datatables/datatables.bundle.js',
            SRC_JS_B.'jquery-dateformat.js',
            SRC_JS_B.'core.js',
            SRC_JS_B.'accounting.min.js',
            SRC_JS_B . 'tinymce/tinymce.min.js',
            SRC_JS_B . 'tinymce/script.js',
            SRC_JS_B.  'printThis.js'
            //SRC_G.'plugins/jquery-ui/jquery-ui.min.js'
        );

        $data['site_title'] = 'Invoice Demurrage';
        $data['form_action'] = "Add";


        $row_issue = $this->invoice_issue_md->get($id);
        if($row_issue){
            $data['row_issue'] =  $row_issue;
            $lst_detail =  $this->invoice_issue_detail_md->get_list($row_issue['id'],"");
            //print_r($lst_detail);
            if($lst_detail){
                $data['lst_detail']= $lst_detail;
            }

        }



        $this->load->view(V_TEMP_B . 'main_tmp', $data);

    }

    public function set_state() {
        $id = $this->input->post("id");
        $state = $this->input->post("state");
        $data = array();
        $data['status'] = 0;


        if(!empty($id)){
            if ($this->invoice_issue_md->set_state($id, $state)) {
                $data['status'] = 1;
            }
        }



        echo json_encode($data);
    }

    


    public function set_delete() {
        $id = $this->input->post("id");
        $data = array();
        $data['status'] = 0;


        if(!empty($id)){
            if ($this->user_md->delete($id)) {
                $data['status'] = 1;
            }
        }

        echo json_encode($data);
    }


    protected function delete($id = array()) {
        if ($this->user_md->delete($id)) {
            return true;
        } else {
            return false;
        }
    }

    protected function save($data = array()) {

    }

    public function save_import_file() {



        $auth_user = $this->auth_md->auth_user();
        $created_by = $auth_user['id'];
        $json_data = $this->input->post('data');
        $data_encode =  $json_data;
        //$data_encode = json_decode($json_data);

        $item_container =  array();
        foreach ($data_encode as $val) {
            $container_id = $val['id'];
            $container_no = $val['container_no'];
            $contianer_size = $val['size'];
            $container_type = $val['type'];
            $contianer_type_id = $val['type_id'];
            $container_operation = $val['operation'];
            $container_operation_id = $val['operation_id'];
            $container_line = $val['line'];
            $container_line_id=0;
            $container_vessel = $val['vessel'];
            $container_voy_no = $val['voy_no'];
            $container_arrived_date = $val['arrived_date'];
            $container_invoice_line = $val['invoice_line'];
            $container_op_free_day = $val['op_free_day'];
            $container_op_start_count = $val['op_start_count'];
            $container_op_status = $val['op_status'];
            $container_invoice_line_id=0;



            if(!empty($container_id)){

            }else{
                $item_container_array = array(
                    'container_no' => $container_no,
                    'size' => $contianer_size,
                    'type_name' => $container_type,
                    'ref_type_id' => $contianer_type_id,
                    'operation_name' => $container_operation,
                    'ref_op_id' => $container_operation_id,
                    'line_code' => $container_line,
                    'ref_line_id' => $container_line_id,
                    'invoice_line_code' => $container_invoice_line,
                    'ref_invoice_line_id' => $container_invoice_line_id,
                    'vessel_name' => $container_vessel,
                    'voy_no' => $container_voy_no,
                    'arrived_date' => $container_arrived_date,
                    'op_free_day'=>$container_op_free_day,
                    'op_start_count'=>$container_op_start_count,
                    'op_status'=>$container_op_status,
                    'created' => date("Y-m-d H:i:s", time()),
                    'created_by' => $created_by
                );

                array_push($item_container,$item_container_array);
            }



        }


        //echo json_encode($item_container);
        $insert_id = $this->container_md->save($item_container);
        if($insert_id){
            echo json_encode(array('status' => true, 'message'=>'Successfully'));

        }else{
            echo json_encode(array('status' => false, 'message'=>'Cannot Save'));
        }


    }

    protected function state($id, $state) {
        if ($this->user_md->set_state($id, $state)) {
            return true;
        } else {
            return false;
        }
    }


    function check_reference(){
        $reference = $this->input->post("reference");

        echo json_encode( false);
        //echo $reference;



    }


    function api_container_lst(){
        $term = $this->input->post("term");
        $line_id = intval($this->input->post("line_id"));
        $vessel_id = intval($this->input->post("vessel_id"));
        $voy_no = ($this->input->post("voy_no"));
        $arrived_date = ($this->input->post("arrived_date"));
        $invoice_id = ($this->input->post("invoice_id"));

        if (empty($arrived_date)) {
            $arrived_date = null;
        }else{
            $arrived_date = date("Y-m-d",strtotime(str_replace('/', '-', $arrived_date)));

        }




        $data = array();
        $data['status'] = 0;
        $data_keys_array = array();

        //!empty($line_id) && !empty($vessel_id) && !empty($voy_no) && !empty($arrived_date)
        $data['line_id'] = $arrived_date;
        if(1==1){

            //$data['abc'] = $term.";line:".$line_id.'+vessel_id:'.$vessel_id.'+ voyno:'.$voy_no.'+ arrived_date:'.$arrived_date;


            $lst_container = $this->container_md->get_list_search($term, "","",$line_id,$vessel_id,$voy_no,$arrived_date,$invoice_id, 5);

            if($lst_container){
                foreach($lst_container as $val_container){

                    $free_day = 0;
                    $start_count = 0;
                    $unit_cost = 0;
                    $row_operation = $this->container_operation_md->get($val_container['ref_op_id']);
                    $data_rate = array();
                    if($row_operation){
                        $free_day = $row_operation['free_day'];
                        $start_count = $row_operation['start_count'];

                        $lst_rate = $this->container_op_rate_md->get_list_by_optype($val_container['ref_op_id'],$val_container['ref_type_id']);
                        if($lst_rate){
                            foreach($lst_rate as $val_rate){
                                $data_rate_array = array(
                                    "size_20"   =>  $val_rate["size_20"],
                                    "size_40"   =>  $val_rate["size_40"],
                                    "size_45"   =>  $val_rate["size_45"],
                                    "from_day"  =>  $val_rate["from_day"],
                                    "to_day"    =>  $val_rate["to_day"]
                                );
                                array_push($data_rate,$data_rate_array);
                            }
                        }
                    }
                    $data_array = array(
                        "id"                =>  $val_container['invoice_container_id'],
                        "container_id"      =>  $val_container['id'],
                        "container_no"      =>  $val_container['container_no'],
                        "size"              =>  $val_container['size'],
                        "type_code"         =>  $val_container['type_code'],
                        "type_id"           =>  $val_container['ref_type_id'],
                        "operation_code"    =>  $val_container['operation_code'],
                        "free_day"          =>  $free_day,
                        "invoice_free_day"    =>  $val_container['free_day'],
                        "start_count"       =>  $start_count,
                        "unit_cost"         =>  $unit_cost,
                        "rates"             =>  $data_rate,
                        "operation_id"      =>  $val_container['ref_op_id'],
                        "line_code"         =>  $val_container['line_code'],
                        "line_name"         =>  $val_container['line_name'],
                        "line_id"           =>  $val_container['ref_line_id'],
                        "invoice_line_code" =>  $val_container['invoice_line_code'],
                        "invoice_line_name" =>  $val_container['invoice_line_name'],
                        "invoice_line_id"   =>  $val_container['ref_invoice_line_id'],
                        "vessel_name"       =>  $val_container['vessel_name'],
                        "vessel_code"       =>  $val_container['vessel_code'],
                        "vessel_id"         =>  $val_container['ref_vessel_id'],
                        "voy_no"            =>  $val_container['voy_no'],
                        "arrived_date"      =>  $val_container['arrived_date'],
                        "total"             =>  $val_container['total'],
                        "total_due"         =>  $val_container['total_due'],
                        "invoice_status"    =>  $val_container['invoice_status'],
                        "invoice_id"        =>  $val_container['ref_invoice_id'],
                        "invoice_no"        =>  $val_container['invoice_no'],
                        "invoice_total"     => $val_container['invoice_total'],
                        "invoice_total_due"     => $val_container['invoice_total_due'],
                        "ported_date"       =>  $val_container['ported_date'],
                        "created"           =>  $val_container['created'],
                        );
                    array_push($data_keys_array, $data_array);

                }

                $data['status'] = 1;
                $data['containers'] = $data_keys_array;
            }




        }



        echo json_encode($data);

    }


    function api_contact_lst(){


        $country = array(
            "Alabama","Alaska","Arizona","Arkansas","California","Colorado","Connecticut","Delaware","Florida","Georgia","Hawaii","Idaho","Illinois","Indiana","Iowa","Kansas","Kentucky","Louisiana","Maine","Maryland","Massachusetts",
            "Michigan","Minnesota","Mississippi","Missouri","Montana","Nebraska","Nevada","New Hampshire","New Jersey","New Mexico","New York","North Carolina","North Dakota","Ohio","Oklahoma","Oregon","Pennsylvania","Rhode Island","South Carolina","South Dakota","Tennessee",
            "Texas","Utah","Vermont","Virginia","Washington","West Virginia","Wisconsin","Wyoming"
        );

        $keyword = $this->input->post("q");
        $data = array();

        if(!empty($keyword)){
            $lst_contact = $this->contact_md->get_list($keyword, 10);
            if($lst_contact){
                foreach($lst_contact as $val_contact){
                    $data_array = array(
                        "id" => $val_contact['id'],
                        "full_name"=> $val_contact['full_name'],
                        "value"=> $val_contact['full_name']
                    );
                    array_push($data,$data_array);

                }
            }

        }

        echo json_encode($data);

    }


    function api_company_lst(){



        $keyword = $this->input->post("q");
        $data = array();

        if(!empty($keyword)){
            $lst_company = $this->company_md->get_list($keyword, 10);
            if($lst_company){
                foreach($lst_company as $val_company){
                    $data_array = array(
                        "id" => $val_company['id'],
                        "company_name"=> $val_company['company_name'],
                        "value"=> $val_company['company_name']
                    );
                    array_push($data,$data_array);

                }
            }

        }

        echo json_encode($data);

    }


    function api_lst(){

        $draw = intval($this->input->post("draw"));
        $start = intval($this->input->post("start"));
        $length = intval($this->input->post("length"));
        $data_search = $this->input->post("search");
        $columns = $this->input->post('columns');
        $keyword = $columns[0]['search']['value'];//$data_search["value"];
        $line_id = $columns[1]['search']['value'];
        $vessel_id = $columns[2]['search']['value'];
        $payment_status = $columns[3]['search']['value'];
        $container_no = $columns[4]['search']['value'];


        //Sort Order by Column Name
        $orders = $this->input->post("order");
        $orderColumnIndex = $orders[0]['column'];//Column Index
        $orderSortOrder = $orders[0]['dir'];//ASC or DESC

        $OrderColumnName = $columns[$orderColumnIndex]['data'];


        //$per_page = 10;
        //$start = 0;
        //$OrderColumnName,$orderSortOrder
        $lst_issue = $this->invoice_issue_md->get_list($keyword,$container_no,$line_id,$vessel_id,$payment_status, $length, $start);
        $query = $this->db->query('SELECT FOUND_ROWS() AS `Count`');
        $objCount = $query->result_array();
        $totalres = $objCount[0]['Count'];



        //$page = $start/$length + 1;
        //$bil = ($page - 1) * $length + 1;

        //print_r($lst_issue);
        //return;


        $data_issues =  array();
        if($lst_issue){
            foreach($lst_issue as $val_issue){
                $issue_array = array(
                    'id'            =>  $val_issue['id'],
                    'invoice_no'    =>  $val_issue['invoice_no'],
                    'invoice_id'    =>  $val_issue['ref_invoice_id'],
                    'company_name'  =>  $val_issue['company_name'],
                    'company_id'    =>  $val_issue['ref_company_id'],
                    'line_id'       =>  $val_issue['ref_line_id'],
                    'line_name'     =>  $val_issue['line_name'],
                    'line_code'     =>  $val_issue['line_code'],
                    'vessel_name'   =>  $val_issue['vessel_name'],
                    'vessel_code'   =>  $val_issue['vessel_code'],
                    'vessel_id'     =>  $val_issue['ref_vessel_id'],
                    'voy_no'        =>  $val_issue['voy_no'],
                    'contact_name'  =>  $val_issue['contact_name'],
                    'contact_id'    =>  $val_issue['ref_contact_id'],
                    'arrived_date'  =>  $val_issue['arrived_date'],
                    'ported_date'   =>  $val_issue['port_date'],
                    'total_item'    =>  $val_issue['total_item'],
                    'total'         =>  $val_issue['total'],
                    'total_due'     =>  $val_issue['total_due'],
                    'invoice_total' =>  $val_issue['invoice_total'],
                    'invoice_total_due'=>  $val_issue['invoice_total_due'],
                    'payment_status'=>  $val_issue['payment_status'],
                    'description'   =>  $val_issue['description'],
                    'ordering'      =>  $val_issue['ordering'],
                    'created'       =>  $val_issue['created'],
                    'created_by'    =>  $val_issue['created_by'],
                    'modified'      =>  $val_issue['modified'],
                    'modified_by'   =>  $val_issue['modified_by'],
                    'Actions'       =>  '');

                array_push($data_issues, $issue_array);
            }

        }



        $data = array(
            "draw"                  => intval($draw),
            "iTotalRecords"         => $totalres,
            "iTotalDisplayRecords"  => $totalres,
            "sEcho"                 => 0,
            "sColumns"              => "",
            "aaData"                => $data_issues);


        echo json_encode($data);



    }


    function api_type_lst(){


        $keyword = $this->input->post("q");
        $page = $this->input->post("page");
        $start = intval($this->input->post("page"));
        $length = 30;

        $lst_type = $this->container_type_md->get_list($keyword,$length, $start);
        $query = $this->db->query('SELECT FOUND_ROWS() AS `Count`');
        $objCount = $query->result_array();
        $totalres = $objCount[0]['Count'];

        //$page = $start/$length + 1;
        //$bil = ($page - 1) * $length + 1;


        $data_types =  array();
        if($lst_type){
            foreach($lst_type as $val_type){
                $type_array = array(
                    'id'            =>  $val_type['id'],
                    'code'          =>  $val_type['code'],
                    'created'       =>  $val_type['created'],
                    'created_by'    =>  $val_type['created_by'],
                    'modified'      =>  $val_type['modified'],
                    'modified_by'   =>  $val_type['modified_by']
                );

                array_push($data_types,$type_array);
            }

        }


        $data = array(
            'total_count'   =>  $totalres,
            'items'         =>  $data_types
        );


        echo json_encode($data);
    }


    function api_operation_lst(){


        $keyword = $this->input->post("q");
        $page = $this->input->post("page");
        $start = intval($this->input->post("page"));
        $length = 30;

        $lst_operation = $this->container_operation_md->get_list($keyword,"",$length, $start);
        $query = $this->db->query('SELECT FOUND_ROWS() AS `Count`');
        $objCount = $query->result_array();
        $totalres = $objCount[0]['Count'];

        //$page = $start/$length + 1;
        //$bil = ($page - 1) * $length + 1;


        $data_operations =  array();
        if($lst_operation){
            foreach($lst_operation as $val_operation){
                $operation_array = array(
                    'id'            =>  $val_operation['id'],
                    'code'          =>  $val_operation['code'],
                    'created'       =>  $val_operation['created'],
                    'created_by'    =>  $val_operation['created_by'],
                    'modified'      =>  $val_operation['modified'],
                    'modified_by'   =>  $val_operation['modified_by']
                );

                array_push($data_operations,$operation_array);
            }

        }


        $data = array(
            'total_count'   =>  $totalres,
            'items'         =>  $data_operations
        );


        echo json_encode($data);
    }


    function api_line(){
        $line_id = $this->input->post("id");
        $row_line = $this->line_md->get($line_id);
        $data['status'] = 0;
        if($row_line){
            $data['status'] = 1;

            $current_year = date('Y');

            $reference = $row_line['code'].sprintf("%04s", 1);
            $row_ref =  $this->invoice_ref_md->is_existed($row_line['id'],$current_year);
            if($row_ref){
                $reference = $row_line['code'].sprintf("%04s", ($row_ref['reference'] + 1));
            }

            $line_array = array(
                'id'            =>  $row_line['id'],
                'code'          =>  $row_line['code'],
                'name'          =>  $row_line['name'],
                'reference'     =>  $reference,
                'created'       =>  $row_line['created'],
                'created_by'    =>  $row_line['created_by'],
                'modified'      =>  $row_line['modified'],
                'modified_by'   =>  $row_line['modified_by']
            );
            $data['data'] = $line_array;

        }

        echo json_encode($data);
    }


    function api_line_lst(){


        $keyword = $this->input->post("q");
        $page = $this->input->post("page");
        $start = intval($this->input->post("page"));
        $length = 30;

        $lst_line = $this->line_md->get_list($keyword,$length, $start);
        $query = $this->db->query('SELECT FOUND_ROWS() AS `Count`');
        $objCount = $query->result_array();
        $totalres = $objCount[0]['Count'];

        //$page = $start/$length + 1;
        //$bil = ($page - 1) * $length + 1;


        $data_lines =  array();
        if($lst_line){
            foreach($lst_line as $val_line){


                $current_year = date('Y');

                $reference = $val_line['code'].''.sprintf("%04s", 1);
                $row_ref =  $this->invoice_ref_md->is_existed($val_line['id'],$current_year);
                if($row_ref){
                    $reference = $val_line['code'].''.sprintf("%04s", ($row_ref['reference'] + 1));
                }


                $line_array = array(
                    'id'            =>  $val_line['id'],
                    'code'          =>  $val_line['code'],
                    'name'          =>  $val_line['name'],
                    'reference'     =>  $reference,
                    'created'       =>  $val_line['created'],
                    'created_by'    =>  $val_line['created_by'],
                    'modified'      =>  $val_line['modified'],
                    'modified_by'   =>  $val_line['modified_by']
                );

                array_push($data_lines,$line_array);
            }

        }


        $data = array(
            'total_count'   =>  $totalres,
            'items'         =>  $data_lines
        );


        echo json_encode($data);
    }




    function api_vessel(){

        $vessel_id = $this->input->post("id");
        $row_vessel = $this->vessel_md->get($vessel_id);
        $data['status'] = 0;
        if($row_vessel){
            $data['status'] = 1;

            $vessel_array = array(
                'id'            =>  $row_vessel['id'],
                'code'          =>  $row_vessel['code'],
                'name'          =>  $row_vessel['name'],
                'created'       =>  $row_vessel['created'],
                'created_by'    =>  $row_vessel['created_by'],
                'modified'      =>  $row_vessel['modified'],
                'modified_by'   =>  $row_vessel['modified_by']
            );
            $data['data'] = $vessel_array;

        }

        echo json_encode($data);
    }



    function api_vessel_lst(){


        $keyword = $this->input->post("q");
        $page = $this->input->post("page");
        $start = intval($this->input->post("page"));
        $length = 30;

        $lst_vessel = $this->vessel_md->get_list($keyword,$length, $start);
        $query = $this->db->query('SELECT FOUND_ROWS() AS `Count`');
        $objCount = $query->result_array();
        $totalres = $objCount[0]['Count'];

        //$page = $start/$length + 1;
        //$bil = ($page - 1) * $length + 1;


        $data_vessels =  array();
        if($lst_vessel){
            foreach($lst_vessel as $val_vessel){
                $vessel_array = array(
                    'id'            =>  $val_vessel['id'],
                    'code'          =>  $val_vessel['code'],
                    'name'          =>  $val_vessel['name'],
                    'created'       =>  $val_vessel['created'],
                    'created_by'    =>  $val_vessel['created_by'],
                    'modified'      =>  $val_vessel['modified'],
                    'modified_by'   =>  $val_vessel['modified_by']
                );

                array_push($data_vessels,$vessel_array);
            }

        }


        $data = array(
            'total_count'   =>  $totalres,
            'items'         =>  $data_vessels
        );


        echo json_encode($data);
    }

    public function upload_file(){

        //-----------  Upload Image ----------------------------------

        $pathToUpload = AB_PRODUCT;


        if (!file_exists($pathToUpload)) {
            $create = mkdir($pathToUpload, 0777, true);
        }

        $img_name_thumb = strtolower('photo_123' );
        $rs_thumb = $this->do_upload($pathToUpload, 'file', $img_name_thumb);

        if ($rs_thumb['status']) {
            echo json_encode(array('success' => true, 'file' => $rs_thumb['data']['file_name']));

        }else{
            echo json_encode(array('success' => false, 'msg' => $rs_thumb['data']));
        }
    }


    public function file_upload() {

        $this->load->library('excel');
        $this->load->library('FileUpload');
        //$upload_dir = '/upload_files/';
        $upload_dir = './assets/uploads/tmp/food_beverage/';
        $allowedExtensions = array('xls', 'xlsx');
        $sizeLimit = 1 * 1024 * 1024;
        $filename = date("YmdHis");


        $uploader = new FileUpload('file');
        $ext = $uploader->getExtension(); // Get the extension of the uploaded file
        while (file_exists($upload_dir . $filename . '.' . $ext)) {
            $filename .= rand(10, 99);
        }
        $uploader->newFileName = $filename . '.' . $ext;
        $result = $uploader->handleUpload($upload_dir, $allowedExtensions);


        if (!$result) {
            echo json_encode(array('success' => false, 'msg' => $uploader->getErrorMsg()));
        } else {

            $csv = $uploader->getFileName();

            $objPHPExcel = PHPExcel_IOFactory::load($upload_dir . $csv);

            $objWorksheet = $objPHPExcel->setActiveSheetIndex(0);
            $worksheetTitle = $objWorksheet->getTitle();
            $maxRow = $objWorksheet->getHighestRow();
            $highestColumn = $objWorksheet->getHighestColumn();

            $final = array();
            $keys = array(
                'record_no',
                'id',
                'container_no',
                'size',
                'type',
                'type_id',
                'operation',
                'operation_id',
                'line',
                'vessel',
                'voy_no',
                'arrived_date',
                'invoice_line',
                'op_free_day',
                'op_start_count',
                'op_status');

            $j = 1;

            $n_type = array("new"=>0,"exist"=>0);
            $n_operation = array("new"=>0,"exist"=>0);
            $n_line = array("new"=>0,"exist"=>0);
            $n_vessel = array("new"=>0,"exist"=>0);
            $n_total = array("new"=>0,"exist"=>0);

            for ($i = 2; $i <= $maxRow; $i++) {

                $cell_container_no = $objWorksheet->getCellByColumnAndRow(0, $i);
                $cell_size = $objWorksheet->getCellByColumnAndRow(1, $i);
                $cell_type = $objWorksheet->getCellByColumnAndRow(2, $i);
                $cell_op = $objWorksheet->getCellByColumnAndRow(3, $i);
                $cell_line = $objWorksheet->getCellByColumnAndRow(4, $i);
                $cell_vessel = $objWorksheet->getCellByColumnAndRow(5, $i);
                $cell_voy_no = $objWorksheet->getCellByColumnAndRow(6, $i);
                $cell_arrived_date = $objWorksheet->getCellByColumnAndRow(7, $i);
                $cell_invoice_line = $objWorksheet->getCellByColumnAndRow(8, $i);
                $cell_op_free_day = $objWorksheet->getCellByColumnAndRow(9, $i);
                $cell_op_start_count = $objWorksheet->getCellByColumnAndRow(10, $i);
                $cell_op_status = $objWorksheet->getCellByColumnAndRow(11, $i);

                $container_no = $cell_container_no->getValue();
                $size = $cell_size->getValue();
                $type = $cell_type->getValue();
                $operation = $cell_op->getValue();
                $line = $cell_line->getValue();
                $vessel = $cell_vessel->getValue();
                $voy_no = $cell_voy_no->getValue();
                $arrived_date =  date('Y-m-d',PHPExcel_Shared_Date::ExcelToPHP($cell_arrived_date->getValue()));
                $invoice_line = $cell_invoice_line->getValue();
                $op_free_day = $cell_op_free_day->getValue();
                $op_start_count = $cell_op_start_count->getValue();
                $op_status = $cell_op_status->getValue();


                $type_id = 0;
                $operation_id = 0;
                $id = 0;

                $row = $this->container_md->is_existed($container_no,$arrived_date);
                if($row){
                    $id = $row['id'];
                    $n_total['exist']++;
                }else{
                    $n_total['new']++;
                }

                $row_type = $this->container_type_md->is_existed($type);
                if($row_type){
                    $type_id =  $row_type['id'];
                    $n_type['exist']++;

                }else{
                    $n_type['new']++;
                }

                $row_operation = $this->container_operation_md->is_existed($operation);
                if($row_operation){
                    $operation_id = $row_operation['id'];
                    $n_operation['exist']++;
                }else{
                    $n_operation['new']++;
                }

                $value = array(
                    $j++,
                    $id,
                    $container_no,
                    $size,
                    $type,
                    $type_id,
                    $operation,
                    $operation_id,
                    $line,
                    $vessel,
                    $voy_no,
                    $arrived_date,
                    $invoice_line,
                    $op_free_day,
                    $op_start_count,
                    $op_status
                );
                $final[] = array_combine($keys, $value);
            }

            $n_data= array("total"=>$n_total,"type"=>$n_type,"operation"=>$n_operation,"line"=>$n_line,"vessel"=>$n_vessel);


            echo json_encode(array('success' => true, 'file' => $uploader->getFileName(), 'data' =>  $final,'n_data'=>$n_data));
        }
    }


    protected function do_upload($path, $field_name, $filename = "") {
        $this->load->library('upload');
        $config['upload_path'] = $path;
        $config['allowed_types'] = 'xls|xlsx';
        $config['max_size'] = 1024 * 2;
        //$config['remove_spaces'] = TRUE;
        //$config['max_width'] = '120';
        //$config['max_height'] = '120';
        if (!empty($filename)) {
            if (file_exists($path . $filename)) {
                $config['file_name'] = $filename . '_123_' . rand(10, 99);
            } else {
                $config['file_name'] = $filename;
            }
        }


        $this->upload->initialize($config);
        $data = array();
        if (!$this->upload->do_upload($field_name)) {
            $data['status'] = false;
            $data['data'] = $this->upload->display_errors();

            return $data;
        } else {
            $data['status'] = true;
            $data['data'] = $this->upload->data();

            //$this->thumbnail_img(125, 94, $data['data']);
            return $data;
        }
    }
}

?>")); ?>

Function Calls

defined 1
base64_decode 1

Variables

None

Stats

MD5 5cb545a5fc8cac00df321f30597140d5
Eval Count 1
Decode Time 2100 ms