Sale->create_temp_table($inputs); } public function getDataColumns() { return array( array('id' => $this->lang->line('reports_sale_id')), array('type_code' => $this->lang->line('reports_code_type')), array('sale_time' => $this->lang->line('reports_date'), 'sortable' => FALSE), array('name' => $this->lang->line('reports_name')), array('category' => $this->lang->line('reports_category')), array('item_number' => $this->lang->line('reports_item_number')), array('quantity' => $this->lang->line('reports_quantity')), array('subtotal' => $this->lang->line('reports_subtotal'), 'sorter' => 'number_sorter'), array('tax' => $this->lang->line('reports_tax'), 'sorter' => 'number_sorter'), array('total' => $this->lang->line('reports_total'), 'sorter' => 'number_sorter'), array('cost' => $this->lang->line('reports_cost'), 'sorter' => 'number_sorter'), array('profit' => $this->lang->line('reports_profit'), 'sorter' => 'number_sorter'), array('discount' => $this->lang->line('reports_discount')) ); } public function getData(array $inputs) { $this->db->select('sale_id, MAX(CASE WHEN sale_type = ' . SALE_TYPE_POS . ' && sale_status = ' . COMPLETED . ' THEN \'' . $this->lang->line('reports_code_pos') . '\' WHEN sale_type = ' . SALE_TYPE_INVOICE . ' && sale_status = ' . COMPLETED . ' THEN \'' . $this->lang->line('reports_code_invoice') . '\' WHEN sale_type = ' . SALE_TYPE_WORK_ORDER . ' && sale_status = ' . SUSPENDED . ' THEN \'' . $this->lang->line('reports_code_work_order') . '\' WHEN sale_type = ' . SALE_TYPE_QUOTE . ' && sale_status = ' . SUSPENDED . ' THEN \'' . $this->lang->line('reports_code_quote') . '\' WHEN sale_type = ' . SALE_TYPE_RETURN . ' && sale_status = ' . COMPLETED . ' THEN \'' . $this->lang->line('reports_code_return') . '\' WHEN sale_status = ' . CANCELED . ' THEN \'' . $this->lang->line('reports_code_canceled') . '\' ELSE \'\' END) AS type_code, MAX(sale_status) as sale_status, MAX(sale_time) AS sale_time, MAX(name) AS name, MAX(category) AS category, MAX(item_number) AS item_number, SUM(quantity_purchased) AS items_purchased, SUM(subtotal) AS subtotal, SUM(tax) AS tax, SUM(total) AS total, SUM(cost) AS cost, SUM(profit) AS profit, MAX(discount_type) AS discount_type, MAX(discount) AS discount'); $this->db->from('sales_items_temp'); $this->db->where('supplier_id', $inputs['supplier_id']); if($inputs['sale_type'] == 'complete') { $this->db->where('sale_status', COMPLETED); $this->db->group_start(); $this->db->where('sale_type', SALE_TYPE_POS); $this->db->or_where('sale_type', SALE_TYPE_INVOICE); $this->db->or_where('sale_type', SALE_TYPE_RETURN); $this->db->group_end(); } elseif($inputs['sale_type'] == 'sales') { $this->db->where('sale_status', COMPLETED); $this->db->group_start(); $this->db->where('sale_type', SALE_TYPE_POS); $this->db->or_where('sale_type', SALE_TYPE_INVOICE); $this->db->group_end(); } elseif($inputs['sale_type'] == 'quotes') { $this->db->where('sale_status', SUSPENDED); $this->db->where('sale_type', SALE_TYPE_QUOTE); } elseif($inputs['sale_type'] == 'work_orders') { $this->db->where('sale_status', SUSPENDED); $this->db->where('sale_type', SALE_TYPE_WORK_ORDER); } elseif($inputs['sale_type'] == 'canceled') { $this->db->where('sale_status', CANCELED); } elseif($inputs['sale_type'] == 'returns') { $this->db->where('sale_status', COMPLETED); $this->db->where('sale_type', SALE_TYPE_RETURN); } $this->db->group_by('item_id'); $this->db->order_by('sale_id'); return $this->db->get()->result_array(); } public function getSummaryData(array $inputs) { $this->db->select('SUM(subtotal) AS subtotal, SUM(tax) AS tax, SUM(total) AS total, SUM(cost) AS cost, SUM(profit) AS profit'); $this->db->from('sales_items_temp'); $this->db->where('supplier_id', $inputs['supplier_id']); if($inputs['sale_type'] == 'complete') { $this->db->where('sale_status', COMPLETED); $this->db->group_start(); $this->db->where('sale_type', SALE_TYPE_POS); $this->db->or_where('sale_type', SALE_TYPE_INVOICE); $this->db->or_where('sale_type', SALE_TYPE_RETURN); $this->db->group_end(); } elseif($inputs['sale_type'] == 'sales') { $this->db->where('sale_status', COMPLETED); $this->db->group_start(); $this->db->where('sale_type', SALE_TYPE_POS); $this->db->or_where('sale_type', SALE_TYPE_INVOICE); $this->db->group_end(); } elseif($inputs['sale_type'] == 'quotes') { $this->db->where('sale_status', SUSPENDED); $this->db->where('sale_type', SALE_TYPE_QUOTE); } elseif($inputs['sale_type'] == 'work_orders') { $this->db->where('sale_status', SUSPENDED); $this->db->where('sale_type', SALE_TYPE_WORK_ORDER); } elseif($inputs['sale_type'] == 'canceled') { $this->db->where('sale_status', CANCELED); } elseif($inputs['sale_type'] == 'returns') { $this->db->where('sale_status', COMPLETED); $this->db->where('sale_type', SALE_TYPE_RETURN); } return $this->db->get()->row_array(); } } ?>