2016-01-04 12:49:26 +01:00
|
|
|
<?php
|
2016-05-23 17:35:57 +02:00
|
|
|
include_once(_PS_ROOT_DIR_.'/modules/privatesales/Sale.php');
|
2016-01-04 12:49:26 +01:00
|
|
|
class AdminStatsLogistic extends AdminTab {
|
|
|
|
public function __construct() {
|
|
|
|
$this->table = 'stats_logistic';
|
|
|
|
$this->lang = false;
|
|
|
|
$this->date_begin = date('Y-m-d');
|
|
|
|
$this->date_end = date('Y-m-d');
|
2016-05-20 17:13:05 +02:00
|
|
|
$this->date_stock = date('Y-m-d');
|
2016-05-23 14:53:47 +02:00
|
|
|
$this->date_export_begin = date('Y-m-d');
|
|
|
|
$this->date_export_end = date('Y-m-d');
|
2016-01-04 12:49:26 +01:00
|
|
|
|
|
|
|
if (!empty($_GET['date_begin'])) {
|
|
|
|
$this->date_begin = $_GET['date_begin'];
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!empty($_GET['date_end'])){
|
|
|
|
$this->date_end = $_GET['date_end'];
|
|
|
|
}
|
2016-05-20 17:13:05 +02:00
|
|
|
|
|
|
|
if (!empty($_GET['date_stock'])){
|
|
|
|
$this->date_stock = $_GET['date_stock'];
|
|
|
|
}
|
2016-05-23 14:53:47 +02:00
|
|
|
|
2016-01-04 12:49:26 +01:00
|
|
|
parent::__construct();
|
|
|
|
}
|
2016-05-23 17:35:57 +02:00
|
|
|
|
|
|
|
public function postProcess()
|
|
|
|
{
|
|
|
|
global $currentIndex, $cookie;
|
|
|
|
if (Tools::getValue('submitExport')) {
|
|
|
|
$this->date_export_begin = Tools::getValue('date_export_begin', $this->date_export_begin);
|
|
|
|
$this->date_export_end = Tools::getValue('date_export_end', $this->date_export_end);
|
|
|
|
$sale_ids = $this->getSales();
|
|
|
|
|
|
|
|
if ($sale_ids) {
|
|
|
|
foreach ($sale_ids as $sale) {
|
|
|
|
$ps = new Sale((int)$sale['id_sale']);
|
|
|
|
$product_ids = $ps->getProducts();
|
|
|
|
$products = $this->getSaleDetails($product_ids);
|
2016-05-23 18:05:11 +02:00
|
|
|
$reasons= array();
|
|
|
|
|
2016-05-23 17:35:57 +02:00
|
|
|
if ($products) {
|
|
|
|
$result[(int)$sale['id_sale']] = array(
|
|
|
|
'ca_ttc' => 0,
|
|
|
|
'ca_refund' => 0,
|
|
|
|
'percent_ca_refund' => 0,
|
|
|
|
'quantity_sold' => 0,
|
|
|
|
'quantity_refund' => 0,
|
|
|
|
'percent_refund' => 0
|
|
|
|
);
|
|
|
|
foreach($products as $row) {
|
|
|
|
$price = (isset($row['product_quantity_discount']) && $row['product_quantity_discount']!=0)?(float)$row['product_quantity_discount']:(float)$row['product_price'];
|
|
|
|
$result[(int)$sale['id_sale']]['ca_ttc'] += (((int)$row['product_quantity'] - (int)$row['product_quantity_reinjected'])*$price);
|
|
|
|
$result[(int)$sale['id_sale']]['quantity_sold'] += ((int)$row['product_quantity'] - (int)$row['product_quantity_reinjected']);
|
2016-05-23 18:05:11 +02:00
|
|
|
|
2016-05-23 17:35:57 +02:00
|
|
|
if ($row['product_quantity_refunded']>0) {
|
2016-05-23 18:05:11 +02:00
|
|
|
$result[(int)$sale['id_sale']]['quantity_refund'] += (int)$row['product_quantity_refunded'];
|
2016-05-23 17:35:57 +02:00
|
|
|
$result[(int)$sale['id_sale']]['ca_refund'] += ((int)$row['product_quantity_refunded']*$price);
|
|
|
|
|
|
|
|
|
|
|
|
if (!isset($row['id_reason'])) {
|
|
|
|
$row['id_reason'] = 99;
|
|
|
|
}
|
|
|
|
if(!in_array((int)$row['id_reason'], $reasons)) {
|
|
|
|
$reasons[] = (int) $row['id_reason'];
|
|
|
|
}
|
|
|
|
|
|
|
|
if(!isset($result[(int)$sale['id_sale']][(int)$row['id_reason']])) {
|
|
|
|
$result[(int)$sale['id_sale']][(int)$row['id_reason']] = array(
|
|
|
|
'ca_refund' => 0,
|
|
|
|
'percent_ca_refund' => 0,
|
|
|
|
'quantity_refund' => 0,
|
|
|
|
'percent_refund' => 0,
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
$result[(int)$sale['id_sale']][(int)$row['id_reason']]['ca_refund'] += ((int)$row['product_quantity_refunded']*$price);
|
|
|
|
$result[(int)$sale['id_sale']][(int)$row['id_reason']]['quantity_refund'] += (int)$row['product_quantity_refunded'];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$result[(int)$sale['id_sale']]['percent_ca_refund'] = ($result[(int)$sale['id_sale']]['ca_refund'] / $result[(int)$sale['id_sale']]['ca_ttc'])*100;
|
|
|
|
$result[(int)$sale['id_sale']]['percent_refund'] = ($result[(int)$sale['id_sale']]['quantity_refund'] / $result[(int)$sale['id_sale']]['quantity_sold'])*100;
|
|
|
|
|
|
|
|
foreach ($reasons as $key => $reason_id) {
|
2016-05-24 14:48:22 +02:00
|
|
|
if (isset($result[(int)$sale['id_sale']][$reason_id])) {
|
|
|
|
$result[(int)$sale['id_sale']][$reason_id]['percent_ca_refund'] += ($result[(int)$sale['id_sale']][$reason_id]['ca_refund'] / $result[(int)$sale['id_sale']]['ca_ttc'])*100;
|
|
|
|
$result[(int)$sale['id_sale']][$reason_id]['percent_refund'] += ($result[(int)$sale['id_sale']][$reason_id]['quantity_refund'] / $result[(int)$sale['id_sale']]['quantity_sold'])*100;
|
2016-05-23 18:05:11 +02:00
|
|
|
}
|
2016-05-23 17:35:57 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
echo "<pre>";var_dump($result);echo "</pre>";die();
|
2016-05-25 15:59:27 +02:00
|
|
|
if ($result) {
|
|
|
|
$this->exportCSV($result);
|
|
|
|
}
|
2016-05-23 17:35:57 +02:00
|
|
|
} else {
|
|
|
|
die('pas de vente trouvée');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2016-01-04 12:49:26 +01:00
|
|
|
|
|
|
|
public function display() {
|
|
|
|
global $currentIndex, $cookie;
|
|
|
|
|
|
|
|
$date = Configuration::get('MAJ_STAT_LOGISTIC');
|
|
|
|
|
|
|
|
echo '
|
|
|
|
<style type="text/css">
|
|
|
|
.ui-datepicker .ui-datepicker-prev span, .ui-datepicker .ui-datepicker-next span {
|
|
|
|
font-size: 0px;
|
|
|
|
}
|
|
|
|
|
|
|
|
#ui-timepicker-div-day {
|
|
|
|
display: none;
|
|
|
|
}
|
|
|
|
|
2016-05-20 17:13:05 +02:00
|
|
|
#date_begin, #date_end, #date_stock {
|
|
|
|
width: 115px;
|
2016-01-04 12:49:26 +01:00
|
|
|
text-align: right;
|
|
|
|
padding: 2px;
|
|
|
|
}
|
|
|
|
label {
|
|
|
|
float: none;
|
|
|
|
display: inline-block;
|
|
|
|
margin-right: 5px;
|
|
|
|
}
|
|
|
|
.button {
|
|
|
|
margin-left: 10px;
|
|
|
|
cursor: pointer;
|
|
|
|
}
|
|
|
|
fieldset label {
|
|
|
|
width: 160px;
|
|
|
|
}
|
|
|
|
span.date {
|
|
|
|
margin-left: 30px;
|
|
|
|
}
|
|
|
|
</style>
|
|
|
|
|
|
|
|
<script type="text/javascript" src="'.__PS_BASE_URI__.'modules/privatesales_livestats/jquery-ui-1.8.20.custom.min.js"></script>
|
|
|
|
<script type="text/javascript" src="'.__PS_BASE_URI__.'modules/privatesales/jquery-ui-timepicker-addon.js"></script>
|
|
|
|
<script type="text/javascript">
|
|
|
|
$(document).ready(function() {
|
2016-05-24 14:48:22 +02:00
|
|
|
$("input[name=date_end], input[name=date_begin]").datepicker({
|
2016-01-04 12:49:26 +01:00
|
|
|
showTime: false,
|
|
|
|
dateFormat: "yy-mm-dd",
|
|
|
|
formattedDate: "yy-mm-dd",
|
|
|
|
maxDate: new Date,
|
|
|
|
minDate: new Date(2014, 1, 1)
|
|
|
|
});
|
2016-05-24 14:48:22 +02:00
|
|
|
$("input[name=date_stock]").datepicker({
|
2016-05-23 18:05:11 +02:00
|
|
|
showTime: false,
|
|
|
|
dateFormat: "yy-mm-dd",
|
|
|
|
formattedDate: "yy-mm-dd",
|
|
|
|
maxDate: null,
|
|
|
|
minDate: new Date(2014, 1, 1)
|
|
|
|
});
|
2016-01-04 12:49:26 +01:00
|
|
|
});
|
|
|
|
</script>
|
|
|
|
<script type="text/javascript" src="'.__PS_BASE_URI__.'modules/privatesales_livestats/jquery-ui-fr.js"></script>';
|
|
|
|
|
|
|
|
echo
|
|
|
|
'<fieldset>
|
|
|
|
<form method="GET" action="'.$currentIndex.'">'
|
|
|
|
.'<span class="form-group">'
|
|
|
|
.'<label style="float: none;" class="control-label" for="date_begin">Date de début :</label>'
|
|
|
|
.'<input type="date" name="date_begin" value="'.pSQl($this->date_begin).'" id="date_begin" class="form-control" />'
|
|
|
|
.'</span>'
|
|
|
|
.'<span class="form-group">'
|
|
|
|
.'<label style="float: none;" class="control-label" for="date_end">Date de fin :</label>'
|
|
|
|
.'<input type="date" name="date_end" value="'.pSQl($this->date_end).'" id="date_end" class="form-control" />'
|
|
|
|
.'</span>'
|
|
|
|
.'<input type="hidden" name="token" value="'.Tools::getAdminTokenLite(__CLASS__).'" />'
|
|
|
|
.'<input type="hidden" name="tab" value="'.__CLASS__.'" />'
|
|
|
|
.'<button type="submit" class="button">Filtrer</button>
|
|
|
|
<span class="date">Dernière mise à jour : <b>'.$date.'</b></span>'
|
|
|
|
.'</form>
|
|
|
|
</fieldset>'
|
|
|
|
;
|
|
|
|
|
|
|
|
$stats = $this->getStats();
|
2016-05-20 15:42:50 +02:00
|
|
|
$poles = array();
|
|
|
|
for ($i=0; $i < 6; $i++) {
|
|
|
|
$poles[] = array(
|
|
|
|
'recap' => array(
|
|
|
|
'quantity' => 0,
|
|
|
|
'nb_package' => 0
|
|
|
|
),
|
|
|
|
'employee' => array(),
|
|
|
|
);
|
|
|
|
}
|
|
|
|
$poles[0]['name'] = 'Pôle 1 : Petites marques';
|
|
|
|
$poles[1]['name'] = 'Pôle 2 : Marques moyenne';
|
|
|
|
$poles[2]['name'] = 'Pôle 3 : Grosses marques';
|
|
|
|
$poles[3]['name'] = 'Pôle 4 : Postes complementaires';
|
|
|
|
$poles[4]['name'] = 'Pôle 5 : Multi';
|
|
|
|
$poles[5]['name'] = 'Pôle 6 : Autre';
|
|
|
|
foreach ($stats as $key => $stat) {
|
2016-05-20 17:13:05 +02:00
|
|
|
if (!isset($stat['id_employee'])) {
|
|
|
|
continue;
|
|
|
|
}
|
2016-05-20 15:42:50 +02:00
|
|
|
switch ($stat['id_employee']) {
|
|
|
|
case '52':
|
|
|
|
$poles[0]['recap']['quantity'] += $stat['quantity'];
|
|
|
|
$poles[0]['recap']['nb_package'] += $stat['nb_package'];
|
|
|
|
$poles[0]['employee'][] = $stat;
|
|
|
|
break;
|
|
|
|
case '22':
|
|
|
|
case '24':
|
|
|
|
$poles[1]['recap']['quantity'] += $stat['quantity'];
|
|
|
|
$poles[1]['recap']['nb_package'] += $stat['nb_package'];
|
|
|
|
$poles[1]['employee'][] = $stat;
|
|
|
|
break;
|
|
|
|
case '25':
|
|
|
|
case '44':
|
|
|
|
$poles[2]['recap']['quantity'] += $stat['quantity'];
|
|
|
|
$poles[2]['recap']['nb_package'] += $stat['nb_package'];
|
|
|
|
$poles[2]['employee'][] = $stat;
|
|
|
|
break;
|
|
|
|
case '47':
|
|
|
|
case '48':
|
|
|
|
$poles[3]['recap']['quantity'] += $stat['quantity'];
|
|
|
|
$poles[3]['recap']['nb_package'] += $stat['nb_package'];
|
|
|
|
$poles[3]['employee'][] = $stat;
|
|
|
|
break;
|
|
|
|
case '35':
|
|
|
|
case '36':
|
|
|
|
$poles[4]['recap']['quantity'] += $stat['quantity'];
|
|
|
|
$poles[4]['recap']['nb_package'] += $stat['nb_package'];
|
|
|
|
$poles[4]['employee'][] = $stat;
|
|
|
|
break;
|
|
|
|
case '28':
|
2016-05-20 15:45:11 +02:00
|
|
|
default:
|
2016-05-20 15:42:50 +02:00
|
|
|
$poles[5]['recap']['quantity'] += $stat['quantity'];
|
|
|
|
$poles[5]['recap']['nb_package'] += $stat['nb_package'];
|
|
|
|
$poles[5]['employee'][] = $stat;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
$total_quantity += $stat['quantity'];
|
|
|
|
}
|
2016-01-04 12:49:26 +01:00
|
|
|
$total_colis = $this->getTotalColis();
|
|
|
|
$total_quantity = 0;
|
|
|
|
echo '
|
|
|
|
<h2 style="margin-top:15px">Stats de la logistique</h2>
|
|
|
|
<table class="table" style="width:100%; margin-top:15px">
|
|
|
|
<thead>
|
|
|
|
<tr>
|
|
|
|
<th>Id Employee</th>
|
|
|
|
<th>Prénom</th>
|
|
|
|
<th>Nom</th>
|
|
|
|
<th>Email</th>
|
|
|
|
<th>Quantité</th>
|
|
|
|
<th>Nombre de colis</th>
|
|
|
|
<th>% total</th>
|
|
|
|
</tr>
|
|
|
|
</thead>
|
|
|
|
<tbody>';
|
2016-05-20 15:42:50 +02:00
|
|
|
foreach ($poles as $k => $pole) {
|
2016-05-23 17:35:57 +02:00
|
|
|
echo '<tr style="background:#99cef7;">
|
2016-05-20 15:42:50 +02:00
|
|
|
<td colspan="4" style="color:#fff;">'.$pole['name'].'</td>
|
|
|
|
<td style="color:#fff;">'.$pole['recap']['quantity'].'</td>
|
|
|
|
<td style="color:#fff;">'.$pole['recap']['nb_package'].'</td>
|
|
|
|
<td style="color:#fff;">'. number_format(($pole['recap']['nb_package']* 100 / $total_colis), 2) .' %</td>
|
|
|
|
</tr>';
|
|
|
|
foreach ($pole['employee'] as $key => $stat) {
|
|
|
|
echo '<tr>
|
|
|
|
<td>'.$stat['id_employee'].'</td>
|
|
|
|
<td>'.$stat['firstname'].'</td>
|
|
|
|
<td>'.$stat['lastname'].'</td>
|
|
|
|
<td>'.$stat['email'].'</td>
|
|
|
|
<td>'.$stat['quantity'].'</td>
|
|
|
|
<td>'.$stat['nb_package'].'</td>
|
|
|
|
<td>'. number_format(($stat['nb_package']* 100 / $total_colis), 2) .' %</td>
|
|
|
|
</tr>';
|
|
|
|
}
|
2016-01-04 12:49:26 +01:00
|
|
|
}
|
|
|
|
echo '<tbody>
|
|
|
|
<tfoot style="font-weight:bold">
|
|
|
|
<tr>
|
|
|
|
<td colspan="4">Total :</td>
|
|
|
|
<td style="background:#f1f1f1;">'.$total_quantity.'</td>
|
|
|
|
<td style="background:#f1f1f1;">'.$total_colis.'</td>
|
|
|
|
<td style="background:#f1f1f1;">100 %</td>
|
|
|
|
</tr>
|
|
|
|
</tfoot>
|
|
|
|
</table>';
|
2016-05-20 17:13:05 +02:00
|
|
|
|
|
|
|
$reports = array(
|
|
|
|
'25' => array(
|
|
|
|
'name' => 'Nb commandes > 25j',
|
|
|
|
'payment' => $this->getReport(25,2),
|
|
|
|
'partial' => $this->getReport(25,17)
|
|
|
|
),
|
|
|
|
'21' => array(
|
|
|
|
'name' => 'Nb commandes > 21j',
|
|
|
|
'payment' => $this->getReport(21,2),
|
|
|
|
'partial' => $this->getReport(21,17)
|
|
|
|
),
|
|
|
|
'18' => array(
|
|
|
|
'name' => 'Nb commandes > 18j',
|
|
|
|
'payment' => $this->getReport(18,2),
|
|
|
|
'partial' => $this->getReport(18,17)
|
|
|
|
),
|
|
|
|
'2' => array(
|
|
|
|
'name' => 'Nb commandes > 2j',
|
|
|
|
'payment' => $this->getReport(2,2),
|
|
|
|
'partial' => $this->getReport(2,17)
|
|
|
|
)
|
|
|
|
);
|
|
|
|
|
|
|
|
echo '<br><br><h2 style="margin-top:15px">Report Stock</h2>
|
|
|
|
<fieldset>
|
|
|
|
<form method="GET" action="'.$currentIndex.'">'
|
|
|
|
.'<span class="form-group">'
|
|
|
|
.'<label style="float: none;" class="control-label" for="date_stock">Date :</label>'
|
|
|
|
.'<input type="date" name="date_stock" value="'.pSQl($this->date_stock).'" id="date_stock" class="form-control" />'
|
|
|
|
.'<input type="hidden" name="date_begin" value="'.pSQl($this->date_begin).'" class="form-control" />'
|
|
|
|
.'<input type="hidden" name="date_end" value="'.pSQl($this->date_end).'" class="form-control" />'
|
|
|
|
.'</span>'
|
|
|
|
.'<input type="hidden" name="token" value="'.Tools::getAdminTokenLite(__CLASS__).'" />'
|
|
|
|
.'<input type="hidden" name="tab" value="'.__CLASS__.'" />'
|
|
|
|
.'<button type="submit" class="button">Filtrer</button>'
|
|
|
|
.'</form>
|
|
|
|
</fieldset>'
|
|
|
|
;
|
|
|
|
|
|
|
|
echo '<table class="table" style="width:100%; margin-top:15px">
|
|
|
|
<thead>
|
|
|
|
<tr>
|
|
|
|
<th colspan="2"></th>
|
|
|
|
<th>Paiement accepté</th>
|
|
|
|
<th>Commande partiellement expédiée</th>
|
|
|
|
</tr>
|
|
|
|
</thead>
|
|
|
|
<tbody>';
|
|
|
|
foreach ($reports as $k => $report) {
|
|
|
|
echo '<tr">
|
|
|
|
<td>'.$report['name'].'</td>
|
|
|
|
<td>'.date('Y-m-d', strtotime($this->date_stock. ' - '.$k.' days')).'</td>
|
|
|
|
<td>'.$report['payment'].'</td>
|
|
|
|
<td>'.$report['partial'].'</td>
|
|
|
|
</tr>';
|
|
|
|
}
|
|
|
|
echo '<tbody>
|
|
|
|
</table>';
|
2016-05-23 13:14:55 +02:00
|
|
|
|
2016-05-23 14:53:47 +02:00
|
|
|
/*echo '<br><br><h2 style="margin-top:15px">Export Remboursemments</h2>
|
|
|
|
<fieldset>
|
2016-05-23 17:35:57 +02:00
|
|
|
<form method="POST" action="'.$currentIndex.'" >'
|
2016-05-23 14:53:47 +02:00
|
|
|
.'<span class="form-group">'
|
|
|
|
.'<label style="float: none;" class="control-label" for="date_export_begin">Date de début :</label>'
|
|
|
|
.'<input type="date" name="date_export_begin" value="'.pSQl($this->date_export_begin).'" id="date_export_begin" class="form-control" />'
|
|
|
|
.'</span>'
|
|
|
|
.'<span class="form-group">'
|
|
|
|
.'<label style="float: none;" class="control-label" for="date_export_end">Date de fin :</label>'
|
|
|
|
.'<input type="date" name="date_export_end" value="'.pSQl($this->date_export_end).'" id="date_export_end" class="form-control" />'
|
|
|
|
.'</span>'
|
|
|
|
.'<input type="hidden" name="token" value="'.Tools::getAdminTokenLite(__CLASS__).'" />'
|
|
|
|
.'<input type="hidden" name="tab" value="'.__CLASS__.'" />'
|
2016-05-23 17:35:57 +02:00
|
|
|
.'<input type="submit" class="button" name="submitExport" value="Exporter les Remboursemments" />'
|
2016-05-23 14:53:47 +02:00
|
|
|
.'</form>
|
|
|
|
</fieldset>'
|
|
|
|
;*/
|
|
|
|
|
2016-01-04 12:49:26 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
public function getStats() {
|
|
|
|
return Db::getInstance()->executeS('
|
|
|
|
SELECT
|
|
|
|
e.`id_employee`,
|
|
|
|
e.`email`,
|
|
|
|
e.`lastname`,
|
|
|
|
e.`firstname`,
|
|
|
|
SUM(s.`nb_product`) AS `nb_product`,
|
|
|
|
SUM(s.`quantity`) AS `quantity`,
|
|
|
|
SUM(s.`nb_package`) AS `nb_package`
|
|
|
|
FROM `'._DB_PREFIX_.'stats_logistic` s
|
|
|
|
LEFT JOIN `'._DB_PREFIX_.'employee` e USING(`id_employee`)
|
|
|
|
WHERE s.`date` BETWEEN "'.pSQL($this->date_begin).'" AND "'.pSQL($this->date_end).'"
|
|
|
|
GROUP BY s.`id_employee`
|
|
|
|
');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getTotalColis() {
|
|
|
|
return Db::getInstance()->getValue('
|
|
|
|
SELECT
|
|
|
|
SUM(s.`nb_package`) AS `nb_package`
|
2016-05-20 17:13:05 +02:00
|
|
|
FROM `'._DB_PREFIX_.'stats_logistic` s
|
|
|
|
WHERE s.`date` BETWEEN "'.pSQL($this->date_begin).'" AND "'.pSQL($this->date_end).'"
|
|
|
|
');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getReport($day = 25, $state = 2) {
|
|
|
|
return Db::getInstance()->getValue('
|
|
|
|
SELECT COUNT(o.`id_order`)
|
|
|
|
FROM `'._DB_PREFIX_.'orders` o
|
2016-05-23 17:51:11 +02:00
|
|
|
LEFT JOIN `'._DB_PREFIX_.'order_history` oh ON (oh.`id_order` = o.`id_order`)
|
2016-05-25 16:06:25 +02:00
|
|
|
WHERE o.`date_add` < DATE_SUB("'.pSQL($this->date_stock).'",INTERVAL '.((int)$day-1).' DAY)
|
2016-05-23 17:51:11 +02:00
|
|
|
AND oh.`id_order_state` = '.(int)$state.'
|
|
|
|
AND oh.`id_order_history` = (SELECT MAX(`id_order_history`) FROM `'._DB_PREFIX_.'order_history` moh WHERE moh.`id_order` = o.`id_order` GROUP BY moh.`id_order`)
|
|
|
|
-- AND
|
|
|
|
-- (
|
|
|
|
-- SELECT `id_order_state`
|
|
|
|
-- FROM '._DB_PREFIX_.'order_history oh
|
|
|
|
-- WHERE o.id_order = oh.id_order
|
|
|
|
-- ORDER BY id_order_history DESC
|
|
|
|
-- LIMIT 1
|
|
|
|
-- ) = '.(int)$state.'
|
2016-01-04 12:49:26 +01:00
|
|
|
');
|
|
|
|
}
|
2016-05-23 17:35:57 +02:00
|
|
|
|
|
|
|
public function getSaleDetails($product_ids) {
|
|
|
|
return Db::getInstance()->ExecuteS('
|
|
|
|
SELECT od.*, rr.`id_reason`
|
|
|
|
FROM `'._DB_PREFIX_.'order_detail` od
|
|
|
|
LEFT JOIN `'._DB_PREFIX_.'order_slip` os ON (os.`id_order` = od.`id_order`)
|
|
|
|
LEFT JOIN `'._DB_PREFIX_.'refundreason` rr ON (rr.`id_order_slip` = os.`id_order_slip`)
|
|
|
|
WHERE od.`product_id` IN ('.implode(',', $product_ids).')
|
|
|
|
-- AND od.`product_quantity_refunded`>0
|
|
|
|
ORDER BY rr.`id_reason`
|
|
|
|
');
|
|
|
|
return Db::getInstance()->ExecuteS('
|
|
|
|
SELECT od.*
|
|
|
|
FROM `'._DB_PREFIX_.'order_detail` od
|
|
|
|
WHERE od.`product_id` IN ('.implode(',', $product_ids).')
|
|
|
|
|
|
|
|
');
|
|
|
|
}
|
|
|
|
|
2016-05-25 15:59:27 +02:00
|
|
|
public function getSales() {
|
2016-05-23 17:35:57 +02:00
|
|
|
return Db::getInstance()->ExecuteS('
|
|
|
|
SELECT `id_sale`
|
|
|
|
FROM `'._DB_PREFIX_.'privatesale`
|
|
|
|
WHERE `date_start` BETWEEN "'.pSQL($this->date_export_begin).'" AND "'.pSQL($this->date_export_end).'"
|
|
|
|
');
|
|
|
|
}
|
|
|
|
|
2016-05-25 15:59:27 +02:00
|
|
|
public function getProducts($id_sale) {
|
2016-05-23 17:35:57 +02:00
|
|
|
return Db::getInstance()->ExecuteS('
|
|
|
|
SELECT `id_product`
|
|
|
|
FROM `'._DB_PREFIX_.'product_ps_cache`
|
|
|
|
WHERE `id_sale`='.(int)$id_sale.'
|
|
|
|
');
|
|
|
|
}
|
2016-05-25 15:59:27 +02:00
|
|
|
|
|
|
|
public function exportCSV () {
|
|
|
|
$fp = fopen("php://output", 'w+');
|
|
|
|
$delim = ';';
|
|
|
|
|
|
|
|
$row_1 = array("","","","","","","","");
|
|
|
|
|
|
|
|
$data=array();
|
|
|
|
foreach ($row_definition as $col) {
|
|
|
|
$data[] = $col;
|
|
|
|
}
|
|
|
|
fputcsv ($fp,$data,$delim);
|
|
|
|
foreach ($items as $item) {
|
|
|
|
$data = array();
|
|
|
|
foreach ($row_definition as $key => $col) {
|
|
|
|
$data[] = (isset($item->$key) ? $item->$key : '');
|
|
|
|
}
|
|
|
|
fputcsv ($fp,array_map('utf8_decode',array_values($data)),$delim);
|
|
|
|
}
|
|
|
|
fclose($fp);
|
|
|
|
}
|
2016-01-04 12:49:26 +01:00
|
|
|
}
|