mirror of
https://github.com/Dolibarr/dolibarr.git
synced 2025-02-20 13:46:52 +01:00
246 lines
7.3 KiB
PHP
246 lines
7.3 KiB
PHP
<?php
|
|
/* Copyright (C) 2003-2004 Rodolphe Quiedeville <rodolphe@quiedeville.org>
|
|
* Copyright (C) 2004-2007 Laurent Destailleur <eldy@users.sourceforge.net>
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation; either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
/**
|
|
* \file htdocs/boutique/index.php
|
|
* \ingroup boutique
|
|
* \brief Main page of shop zone
|
|
*/
|
|
|
|
require '../main.inc.php';
|
|
|
|
$langs->load("shop");
|
|
$langs->load("orders");
|
|
|
|
require_once DOL_DOCUMENT_ROOT.'/boutique/osc_master.inc.php';
|
|
|
|
llxHeader("",$langs->trans("OSCommerceShop"),"");
|
|
|
|
print_fiche_titre($langs->trans("OSCommerceShop"));
|
|
|
|
print '<table width="100%" class="notopnoleftnoright">';
|
|
|
|
print '<tr><td valign="top" width="40%" class="notopnoleft">';
|
|
|
|
|
|
/*
|
|
* Turnover
|
|
*/
|
|
|
|
print_titre($langs->trans('SalesTurnover'));
|
|
|
|
print '<table class="noborder" cellspacing="0" cellpadding="3" width="100%">';
|
|
print '<tr class="liste_titre"><td>'.$langs->trans("Month").'</td>';
|
|
print '<td align="right">'.$langs->trans("Total").'</td></tr>';
|
|
|
|
$now=dol_now();
|
|
|
|
$sql = "SELECT SUM(t.value) as value, MONTH(o.date_purchased) as month";
|
|
$sql.= " FROM ".$conf->global->OSC_DB_NAME.".".$conf->global->OSC_DB_TABLE_PREFIX."orders_total as t";
|
|
$sql.= " JOIN ".$conf->global->OSC_DB_NAME.".".$conf->global->OSC_DB_TABLE_PREFIX."orders as o ON o.orders_id = t.orders_id";
|
|
//$sql.= " WHERE t.class = 'ot_subtotal' AND YEAR(o.date_purchased) = YEAR(".$dbosc->idate($now).")";
|
|
$sql.= " WHERE t.class = 'ot_subtotal' AND YEAR(o.date_purchased) = YEAR('".$db->idate($now)."')";
|
|
$sql.= " GROUP BY month";
|
|
$sql.= " ORDER BY month";
|
|
//print $sql;exit;
|
|
|
|
$result=$dbosc->query($sql);
|
|
if ($result)
|
|
{
|
|
$num = $dbosc->num_rows($result);
|
|
|
|
$var=True;
|
|
$i=0;
|
|
if ($num > 0)
|
|
{
|
|
while ($i < $num)
|
|
{
|
|
$objp = $dbosc->fetch_object($result);
|
|
$var=!$var;
|
|
print "<tr ".$bc[$var].">";
|
|
print '<td align="left">'.$objp->mois.'</td>';
|
|
print '<td align="right">'.price($objp->value).'</td>';
|
|
|
|
print "</tr>\n";
|
|
$i++;
|
|
}
|
|
}
|
|
|
|
$dbosc->free();
|
|
}
|
|
else
|
|
{
|
|
dol_print_error($dbosc);
|
|
}
|
|
|
|
|
|
print "</table>";
|
|
print '</td><td valign="top" width="60%" class="notopnoleftnoright">';
|
|
print_titre($langs->trans("Orders"));
|
|
|
|
/*
|
|
* Last 5 successful commands
|
|
select o.orders_id, o.customers_id, o.customers_name, o.date_purchased, o.payement_method, o.status, t.value
|
|
from orders_total as t
|
|
join orders as o on o.orders_id = t.orders_id where t.class = 'ot_subtotal' order by o.date_purchased desc
|
|
*/
|
|
$sql = "SELECT o.orders_id, o.customers_name, o.date_purchased, t.value, o.payment_method";
|
|
$sql .= " FROM ".$conf->global->OSC_DB_NAME.".".$conf->global->OSC_DB_TABLE_PREFIX."orders_total as t JOIN ".$conf->global->OSC_DB_NAME.".".$conf->global->OSC_DB_TABLE_PREFIX."orders as o on o.orders_id = t.orders_id ";
|
|
$sql .= " WHERE t.class = 'ot_subtotal' ORDER BY o.date_purchased desc";
|
|
|
|
$resql=$dbosc->query($sql);
|
|
if ($resql)
|
|
{
|
|
$langs->load("orders");
|
|
$num = $dbosc->num_rows($resql);
|
|
if ($num > 0)
|
|
{
|
|
$i = 0;
|
|
print '<table class="noborder" width="100%">';
|
|
print '<tr class="liste_titre">';
|
|
print '<td colspan="4">'.$langs->trans("LastOrders").'</td></tr>';
|
|
|
|
$num = min($num,OSC_MAXNBCOM);
|
|
while ($i < $num)
|
|
{
|
|
|
|
$obj = $dbosc->fetch_object($resql);
|
|
print "<tr><td>".$obj->orders_id."</td><td>".$obj->customers_name."</td><td>".price($obj->value)."</td><td>".$obj->payment_method."</td></tr>";
|
|
$i++;
|
|
}
|
|
print "</table><br>";
|
|
}
|
|
}
|
|
else
|
|
{
|
|
dol_print_error($dbosc);
|
|
}
|
|
|
|
/*
|
|
* Last 5 orders on hold
|
|
*/
|
|
$sql = "SELECT o.orders_id, o.customers_name, o.date_purchased, t.value, o.payment_method";
|
|
$sql .= " FROM ".$conf->global->OSC_DB_NAME.".".$conf->global->OSC_DB_TABLE_PREFIX."orders_total as t JOIN ".$conf->global->OSC_DB_NAME.".".$conf->global->OSC_DB_TABLE_PREFIX."orders as o on o.orders_id = t.orders_id ";
|
|
$sql .= " WHERE t.class = 'ot_subtotal' and o.orders_status = 5 order by o.date_purchased desc";
|
|
|
|
$resql=$dbosc->query($sql);
|
|
if ($resql)
|
|
{
|
|
$langs->load("orders");
|
|
$num = $dbosc->num_rows($resql);
|
|
if ($num > 0)
|
|
{
|
|
$i = 0;
|
|
print '<table class="noborder" width="100%">';
|
|
print '<tr class="liste_titre">';
|
|
print '<td colspan="4">'.$langs->trans("En Attente").'</td></tr>';
|
|
|
|
$num = min($num,OSC_MAXNBCOM);
|
|
while ($i < $num)
|
|
{
|
|
|
|
$obj = $dbosc->fetch_object($resql);
|
|
print "<tr><td>$obj->orders_id</td><td>$obj->customers_name</td><td>".price($obj->value)."</td><td>$obj->payment_method</td></tr>";
|
|
$i++;
|
|
}
|
|
print "</table><br>";
|
|
}
|
|
}
|
|
else
|
|
{
|
|
dol_print_error($dbosc);
|
|
}
|
|
|
|
/*
|
|
* Commands to treat
|
|
*/
|
|
$sql = "SELECT o.orders_id, o.customers_name, o.date_purchased, t.value, o.payment_method";
|
|
$sql .= " FROM ".$conf->global->OSC_DB_NAME.".".$conf->global->OSC_DB_TABLE_PREFIX."orders_total as t JOIN ".$conf->global->OSC_DB_NAME.".".$conf->global->OSC_DB_TABLE_PREFIX."orders as o on o.orders_id = t.orders_id ";
|
|
$sql .= " WHERE t.class = 'ot_subtotal' and o.orders_status = 2 order by o.date_purchased desc";
|
|
|
|
$resql=$dbosc->query($sql);
|
|
if ($resql)
|
|
{
|
|
$langs->load("orders");
|
|
$num = $dbosc->num_rows($resql);
|
|
if ($num > 0)
|
|
{
|
|
$i = 0;
|
|
print '<table class="noborder" width="100%">';
|
|
print '<tr class="liste_titre">';
|
|
print '<td colspan="4">'.$langs->trans("TreatmentInProgress").'</td></tr>';
|
|
|
|
$num = min($num,OSC_MAXNBCOM);
|
|
while ($i < $num)
|
|
{
|
|
|
|
$obj = $dbosc->fetch_object($resql);
|
|
print "<tr><td>$obj->orders_id</td><td>$obj->customers_name</td><td>".price($obj->value)."</td><td>$obj->payment_method</td></tr>";
|
|
$i++;
|
|
}
|
|
print "</table><br>";
|
|
}
|
|
}
|
|
else
|
|
{
|
|
dol_print_error($dbosc);
|
|
}
|
|
|
|
|
|
print '</td></tr><tr>';
|
|
/*
|
|
* Last customers who ordered
|
|
*/
|
|
$sql = "SELECT o.orders_id, o.customers_name, o.delivery_country, o.date_purchased, t.value, s.orders_status_name as statut";
|
|
$sql .= " FROM ".$conf->global->OSC_DB_NAME.".".$conf->global->OSC_DB_TABLE_PREFIX."orders_total as t JOIN ".$conf->global->OSC_DB_NAME.".".$conf->global->OSC_DB_TABLE_PREFIX."orders as o on o.orders_id = t.orders_id ";
|
|
$sql .= " JOIN ".$conf->global->OSC_DB_NAME.".".$conf->global->OSC_DB_TABLE_PREFIX."orders_status as s on o.orders_status = s.orders_status_id and s.language_id = 1";
|
|
$sql .= " WHERE t.class = 'ot_subtotal' order by o.date_purchased desc";
|
|
|
|
$resql=$dbosc->query($sql);
|
|
if ($resql)
|
|
{
|
|
$langs->load("orders");
|
|
$num = $dbosc->num_rows($resql);
|
|
if ($num > 0)
|
|
{
|
|
$i = 0;
|
|
print '<table class="noborder" width="100%">';
|
|
print '<tr class="liste_titre">';
|
|
print '<td colspan="7">'.$langs->trans("Derniers clients").'</td></tr>';
|
|
|
|
$num = min($num,OSC_MAXNBCOM);
|
|
while ($i < $num)
|
|
{
|
|
$obj = $dbosc->fetch_object($resql);
|
|
print "<tr><td>$obj->date_purchased</td><td>$obj->customers_name</td><td>$obj->delivery_country</td><td>".price($obj->value)."</td><td>$obj->payment_method</td><td>$obj->orders_id</td><td>$obj->statut</td></tr>";
|
|
$i++;
|
|
}
|
|
print "</table><br>";
|
|
}
|
|
}
|
|
else
|
|
{
|
|
dol_print_error($dbosc);
|
|
}
|
|
print '</tr></table>';
|
|
|
|
|
|
llxFooter();
|
|
|
|
$dbosc->close();
|