* @copyright 2007-2011 PrestaShop SA * @version Release: $Revision: 8005 $ * @license http://opensource.org/licenses/afl-3.0.php Academic Free License (AFL 3.0) * International Registered Trademark & Property of PrestaShop SA */ if (!defined('_PS_VERSION_')) exit; class StatsStock extends Module { function __construct() { $this->name = 'statsstock'; $this->tab = 'analytics_stats'; $this->version = 1.0; $this->author = 'PrestaShop'; $this->need_instance = 0; parent::__construct(); $this->displayName = $this->l('Stock stats'); $this->description = ''; } public function install() { return (parent::install() && $this->registerHook('AdminStatsModules')); } function hookAdminStatsModules() { global $cookie, $currentIndex; if (Tools::isSubmit('submitCategory')) $cookie->statsstock_id_category = Tools::getValue('statsstock_id_category'); $ru = $currentIndex.'&module='.$this->name.'&token='.Tools::getValue('token'); $currency = new Currency(Configuration::get('PS_CURRENCY_DEFAULT')); $filter = ((int)$cookie->statsstock_id_category ? 'WHERE p.id_product IN (SELECT cp.id_product FROM '._DB_PREFIX_.'category_product cp WHERE cp.id_category = '.(int)$cookie->statsstock_id_category.')' : ''); $products = Db::getInstance()->ExecuteS(' SELECT p.id_product, p.reference, pl.name, IFNULL(( SELECT AVG(pa.wholesale_price) FROM '._DB_PREFIX_.'product_attribute pa WHERE p.id_product = pa.id_product AND wholesale_price != 0 ), p.wholesale_price) as wholesale_price, IFNULL(( SELECT SUM(pa.quantity) FROM '._DB_PREFIX_.'product_attribute pa WHERE p.id_product = pa.id_product ), p.quantity) as quantity, IFNULL(( SELECT SUM(IF(pa.wholesale_price > 0, pa.wholesale_price, p.wholesale_price) * pa.quantity) FROM '._DB_PREFIX_.'product_attribute pa WHERE p.id_product = pa.id_product ), p.wholesale_price * p.quantity) as stockvalue FROM '._DB_PREFIX_.'product p INNER JOIN '._DB_PREFIX_.'product_lang pl ON (p.id_product = pl.id_product AND pl.id_lang = '.(int)$cookie->id_lang.') '.$filter); echo '
'.$this->l('ID').' | '.$this->l('Ref.').' | '.$this->l('Item').' | '.$this->l('Stock').' | '.$this->l('Price*').' | '.$this->l('Value').' |
---|---|---|---|---|---|
'.$product['id_product'].' | '.$product['reference'].' | '.$product['name'].' | '.$product['quantity'].' | '.Tools::displayPrice($product['wholesale_price'], $currency).' | '.Tools::displayPrice($product['stockvalue'], $currency).' |
'.$this->l('Total stock').' | '.$this->l('Avg price').' | '.$this->l('Total value').' | |||
'.$rollup['quantity'].' | '.Tools::displayPrice($rollup['wholesale_price'] / count($products), $currency).' | '.Tools::displayPrice($rollup['stockvalue'], $currency).' |
* '.$this->l('Average price when the product has attributes.').'
'; } } }