mirror of
https://github.com/opensourcepos/opensourcepos.git
synced 2026-01-20 23:37:58 -05:00
database.sql script merged with current ospos one remaining problems in reporting (sale_type to add in sales_temp query?) data model should be refactored to allow more genericity for custom item locations (2+) inventory tracking should be adapted to use multiple locations (instead of duplicating items for different locations)
64 lines
2.3 KiB
PHP
64 lines
2.3 KiB
PHP
<?php
|
|
require_once("report.php");
|
|
class Summary_items extends Report
|
|
{
|
|
function __construct()
|
|
{
|
|
parent::__construct();
|
|
}
|
|
|
|
public function getDataColumns()
|
|
{
|
|
return array($this->lang->line('reports_item'),$this->lang->line('reports_quantity_purchased'), $this->lang->line('reports_subtotal'), $this->lang->line('reports_total'), $this->lang->line('reports_tax'),$this->lang->line('reports_profit'));
|
|
}
|
|
|
|
public function getData(array $inputs)
|
|
{
|
|
$this->db->select('name, sum(quantity_purchased) as quantity_purchased, sum(subtotal) as subtotal, sum(total) as total, sum(tax) as tax, sum(profit) as profit');
|
|
$this->db->from('sales_items_temp');
|
|
$this->db->join('items', 'sales_items_temp.item_id = items.item_id');
|
|
$this->db->where('sale_date BETWEEN "'. $inputs['start_date']. '" and "'. $inputs['end_date'].'"');
|
|
if ($inputs['sale_type'] == 'sales_retail')
|
|
{
|
|
$this->db->where('quantity_purchased > 0');
|
|
$this->db->where('sale_type', 'sale_stock');
|
|
}
|
|
elseif($inputs['sale_type'] == 'sales_wholesale')
|
|
{
|
|
$this->db->where('quantity_purchased > 0');
|
|
$this->db->where('sale_type', 'warehouse');
|
|
}
|
|
elseif ($inputs['sale_type'] == 'returns')
|
|
{
|
|
$this->db->where('quantity_purchased < 0');
|
|
}
|
|
$this->db->group_by('items.item_id');
|
|
$this->db->order_by('name');
|
|
|
|
return $this->db->get()->result_array();
|
|
}
|
|
|
|
public function getSummaryData(array $inputs)
|
|
{
|
|
$this->db->select('sum(subtotal) as subtotal, sum(total) as total, sum(tax) as tax, sum(profit) as profit');
|
|
$this->db->from('sales_items_temp');
|
|
$this->db->join('items', 'sales_items_temp.item_id = items.item_id');
|
|
$this->db->where('sale_date BETWEEN "'. $inputs['start_date']. '" and "'. $inputs['end_date'].'"');
|
|
if ($inputs['sale_type'] == 'sales_retail')
|
|
{
|
|
$this->db->where('quantity_purchased > 0');
|
|
$this->db->where('sale_type = \'sale_stock\'');
|
|
}
|
|
elseif($inputs['sale_type'] == 'sales_wholesale')
|
|
{
|
|
$this->db->where('quantity_purchased > 0');
|
|
$this->db->where('sale_type = \'warehouse\'');
|
|
}
|
|
elseif ($inputs['sale_type'] == 'returns')
|
|
{
|
|
$this->db->where('quantity_purchased < 0');
|
|
}
|
|
return $this->db->get()->row_array();
|
|
}
|
|
}
|
|
?>
|