mirror of
https://github.com/opensourcepos/opensourcepos.git
synced 2026-01-02 22:47:50 -05:00
200 lines
7.0 KiB
PHP
200 lines
7.0 KiB
PHP
<?php if ( ! defined('BASEPATH')) exit('No direct script access allowed');
|
|
|
|
require_once("Report.php");
|
|
|
|
class Specific_customer extends Report
|
|
{
|
|
public function create(array $inputs)
|
|
{
|
|
//Create our temp tables to work with the data in our report
|
|
$this->Sale->create_temp_table($inputs);
|
|
}
|
|
|
|
public function getDataColumns()
|
|
{
|
|
return array(
|
|
'summary' => array(
|
|
array('id' => $this->lang->line('reports_sale_id')),
|
|
array('type_code' => $this->lang->line('reports_code_type')),
|
|
array('sale_date' => $this->lang->line('reports_date'), 'sortable' => FALSE),
|
|
array('quantity' => $this->lang->line('reports_quantity')),
|
|
array('employee_name' => $this->lang->line('reports_sold_by')),
|
|
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('payment_type' => $this->lang->line('reports_payment_type'), 'sortable' => FALSE),
|
|
array('comment' => $this->lang->line('reports_comments'))),
|
|
'details' => array(
|
|
$this->lang->line('reports_name'),
|
|
$this->lang->line('reports_category'),
|
|
$this->lang->line('reports_item_number'),
|
|
$this->lang->line('reports_description'),
|
|
$this->lang->line('reports_quantity'),
|
|
$this->lang->line('reports_subtotal'),
|
|
$this->lang->line('reports_tax'),
|
|
$this->lang->line('reports_total'),
|
|
$this->lang->line('reports_cost'),
|
|
$this->lang->line('reports_profit'),
|
|
$this->lang->line('reports_discount')),
|
|
'details_rewards' => array(
|
|
$this->lang->line('reports_used'),
|
|
$this->lang->line('reports_earned'))
|
|
);
|
|
}
|
|
|
|
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_date) AS sale_date,
|
|
SUM(quantity_purchased) AS items_purchased,
|
|
MAX(employee_name) AS employee_name,
|
|
SUM(subtotal) AS subtotal,
|
|
SUM(tax) AS tax,
|
|
SUM(total) AS total,
|
|
SUM(cost) AS cost,
|
|
SUM(profit) AS profit,
|
|
MAX(payment_type) AS payment_type,
|
|
MAX(comment) AS comment');
|
|
$this->db->from('sales_items_temp');
|
|
|
|
$this->db->where('customer_id', $inputs['customer_id']);
|
|
|
|
if($inputs['payment_type'] == 'invoices')
|
|
{
|
|
$this->db->where('sale_type', SALE_TYPE_INVOICE);
|
|
}
|
|
elseif($inputs['payment_type'] != 'all')
|
|
{
|
|
$this->db->like('payment_type', $this->lang->line('sales_'.$inputs['payment_type']));
|
|
}
|
|
|
|
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('sale_id');
|
|
$this->db->order_by('MAX(sale_date)');
|
|
|
|
$data = array();
|
|
$data['summary'] = $this->db->get()->result_array();
|
|
$data['details'] = array();
|
|
$data['rewards'] = array();
|
|
|
|
foreach($data['summary'] as $key=>$value)
|
|
{
|
|
$this->db->select('name, category, item_number, description, quantity_purchased, subtotal, tax, total, cost, profit, discount, discount_type');
|
|
$this->db->from('sales_items_temp');
|
|
$this->db->where('sale_id', $value['sale_id']);
|
|
$data['details'][$key] = $this->db->get()->result_array();
|
|
$this->db->select('used, earned');
|
|
$this->db->from('sales_reward_points');
|
|
$this->db->where('sale_id', $value['sale_id']);
|
|
$data['rewards'][$key] = $this->db->get()->result_array();
|
|
}
|
|
|
|
return $data;
|
|
}
|
|
|
|
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('customer_id', $inputs['customer_id']);
|
|
|
|
if($inputs['payment_type'] == 'invoices')
|
|
{
|
|
$this->db->where('sale_type', SALE_TYPE_INVOICE);
|
|
}
|
|
elseif ($inputs['payment_type'] != 'all')
|
|
{
|
|
$this->db->like('payment_type', $this->lang->line('sales_'.$inputs['payment_type']));
|
|
}
|
|
|
|
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();
|
|
}
|
|
}
|
|
?>
|