mirror of
https://github.com/opensourcepos/opensourcepos.git
synced 2026-01-26 10:17:59 -05:00
Set bc-operation style scale globally Add location filtering in graphical and summary reports (#742)
87 lines
3.2 KiB
PHP
87 lines
3.2 KiB
PHP
<?php
|
|
require_once("Report.php");
|
|
class Summary_taxes extends Report
|
|
{
|
|
function __construct()
|
|
{
|
|
parent::__construct();
|
|
}
|
|
|
|
public function getDataColumns()
|
|
{
|
|
return array($this->lang->line('reports_tax_percent'), $this->lang->line('reports_count'), $this->lang->line('reports_subtotal'), $this->lang->line('reports_total'), $this->lang->line('reports_tax'));
|
|
}
|
|
|
|
public function getData(array $inputs)
|
|
{
|
|
$quantity_cond = '';
|
|
if ($inputs['sale_type'] == 'sales')
|
|
{
|
|
$quantity_cond = 'and quantity_purchased > 0';
|
|
}
|
|
elseif ($inputs['sale_type'] == 'returns')
|
|
{
|
|
$quantity_cond = 'and quantity_purchased < 0';
|
|
}
|
|
|
|
if ($inputs['location_id'] != 'all')
|
|
{
|
|
$quantity_cond .= 'and item_location = '. $this->db->escape($inputs['location_id']);
|
|
}
|
|
|
|
if ($this->config->item('tax_included'))
|
|
{
|
|
$total = "1";
|
|
$subtotal = "(100/(100+percent))";
|
|
$tax = "(1 - (100/(100 +percent)))";
|
|
}
|
|
else
|
|
{
|
|
$tax = "(percent/100)";
|
|
$total = "(1+(percent/100))";
|
|
$subtotal = "1";
|
|
}
|
|
|
|
$decimals = totals_decimals();
|
|
|
|
$query = $this->db->query("SELECT percent, count(*) AS count, SUM(subtotal) AS subtotal, SUM(total) AS total, SUM(tax) AS tax
|
|
FROM (SELECT name, CONCAT(ROUND(percent, $decimals), '%') AS percent,
|
|
ROUND((item_unit_price * quantity_purchased - item_unit_price * quantity_purchased * discount_percent /100) * $subtotal, $decimals) AS subtotal,
|
|
ROUND((item_unit_price * quantity_purchased - item_unit_price * quantity_purchased * discount_percent /100) * $total, $decimals) AS total,
|
|
ROUND((item_unit_price * quantity_purchased - item_unit_price * quantity_purchased * discount_percent /100) * $tax, $decimals) AS tax
|
|
FROM ".$this->db->dbprefix('sales_items_taxes')."
|
|
JOIN ".$this->db->dbprefix('sales_items')." ON "
|
|
.$this->db->dbprefix('sales_items').'.sale_id='.$this->db->dbprefix('sales_items_taxes').'.sale_id'." AND "
|
|
.$this->db->dbprefix('sales_items').'.item_id='.$this->db->dbprefix('sales_items_taxes').'.item_id'." AND "
|
|
.$this->db->dbprefix('sales_items').'.line='.$this->db->dbprefix('sales_items_taxes').'.line'
|
|
." JOIN ".$this->db->dbprefix('sales')." ON ".$this->db->dbprefix('sales_items_taxes').".sale_id=".$this->db->dbprefix('sales').".sale_id
|
|
WHERE date(sale_time) BETWEEN " . $this->db->escape($inputs['start_date']) . " AND " . $this->db->escape($inputs['end_date']) . " $quantity_cond) AS temp_taxes
|
|
GROUP BY percent");
|
|
|
|
return $query->result_array();
|
|
}
|
|
|
|
public function getSummaryData(array $inputs)
|
|
{
|
|
$this->db->select('SUM(subtotal) AS subtotal, SUM(total) AS total, SUM(tax) AS tax, SUM(cost) AS cost, SUM(profit) AS profit');
|
|
$this->db->from('sales_items_temp');
|
|
$this->db->where("sale_date BETWEEN " . $this->db->escape($inputs['start_date']) . " AND " . $this->db->escape($inputs['end_date']));
|
|
|
|
if ($inputs['location_id'] != 'all')
|
|
{
|
|
$this->db->where('item_location', $inputs['location_id']);
|
|
}
|
|
|
|
if ($inputs['sale_type'] == 'sales')
|
|
{
|
|
$this->db->where('quantity_purchased > 0');
|
|
}
|
|
elseif ($inputs['sale_type'] == 'returns')
|
|
{
|
|
$this->db->where('quantity_purchased < 0');
|
|
}
|
|
|
|
return $this->db->get()->row_array();
|
|
}
|
|
}
|
|
?>
|