toutpratique/controllers/admin/AdminTrackingController.php

348 lines
13 KiB
PHP
Raw Normal View History

2015-07-06 16:58:50 +02:00
<?php
/*
* 2007-2015 PrestaShop
*
* NOTICE OF LICENSE
*
* This source file is subject to the Open Software License (OSL 3.0)
* that is bundled with this package in the file LICENSE.txt.
* It is also available through the world-wide-web at this URL:
* http://opensource.org/licenses/osl-3.0.php
* If you did not receive a copy of the license and are unable to
* obtain it through the world-wide-web, please send an email
* to license@prestashop.com so we can send you a copy immediately.
*
* DISCLAIMER
*
* Do not edit or add to this file if you wish to upgrade PrestaShop to newer
* versions in the future. If you wish to customize PrestaShop for your
* needs please refer to http://www.prestashop.com for more information.
*
* @author PrestaShop SA <contact@prestashop.com>
* @copyright 2007-2015 PrestaShop SA
* @license http://opensource.org/licenses/osl-3.0.php Open Software License (OSL 3.0)
* International Registered Trademark & Property of PrestaShop SA
*/
/**
* @property Product|Category $object
*/
class AdminTrackingControllerCore extends AdminController
{
2015-09-22 18:22:11 +02:00
public $bootstrap = true;
/** @var HelperList */
protected $_helper_list;
public function postprocess()
{
if (Tools::getValue('id_product') && Tools::isSubmit('statusproduct')) {
$this->table = 'product';
$this->identifier = 'id_product';
$this->action = 'status';
$this->className = 'Product';
} elseif (Tools::getValue('id_category') && Tools::isSubmit('statuscategory')) {
$this->table = 'category';
$this->identifier = 'id_category';
$this->action = 'status';
$this->className = 'Category';
}
$this->list_no_link = true;
parent::postprocess();
}
public function initContent()
{
$this->initTabModuleList();
$this->initPageHeaderToolbar();
if ($id_category = Tools::getValue('id_category') && Tools::getIsset('viewcategory')) {
Tools::redirectAdmin($this->context->link->getAdminLink('AdminProducts').'&id_category='.(int)$id_category.'&viewcategory');
}
$this->_helper_list = new HelperList();
if (!Configuration::get('PS_STOCK_MANAGEMENT')) {
$this->warnings[] = $this->l('List of products without available quantities for sale are not displayed because stock management is disabled.');
}
$methods = get_class_methods($this);
$tpl_vars['arrayList'] = array();
foreach ($methods as $method_name) {
if (preg_match('#getCustomList(.+)#', $method_name, $matches)) {
$this->clearListOptions();
$this->content .= call_user_func(array($this, $matches[0]));
}
}
$this->context->smarty->assign(array(
'content' => $this->content,
'url_post' => self::$currentIndex.'&token='.$this->token,
'show_page_header_toolbar' => $this->show_page_header_toolbar,
'page_header_toolbar_title' => $this->page_header_toolbar_title,
'page_header_toolbar_btn' => $this->page_header_toolbar_btn
));
}
public function getCustomListCategoriesEmpty()
{
$this->table = 'category';
$this->list_id = 'empty_categories';
$this->lang = true;
$this->className = 'Category';
$this->identifier = 'id_category';
$this->_orderBy = 'id_category';
$this->_orderWay = 'DESC';
$this->_list_index = 'index.php?controller=AdminCategories';
$this->_list_token = Tools::getAdminTokenLite('AdminCategories');
$this->addRowAction('edit');
$this->addRowAction('view');
$this->addRowAction('delete');
$this->addRowActionSkipList('delete', array((int)Configuration::get('PS_ROOT_CATEGORY')));
$this->addRowActionSkipList('edit', array((int)Configuration::get('PS_ROOT_CATEGORY')));
$this->fields_list = (array(
'id_category' => array('title' => $this->l('ID'), 'class' => 'fixed-width-xs', 'align' => 'center'),
'name' => array('title' => $this->l('Name'), 'filter_key' => 'b!name'),
'description' => array('title' => $this->l('Description'), 'callback' => 'getDescriptionClean'),
'active' => array('title' => $this->l('Status'), 'type' => 'bool', 'active' => 'status', 'align' => 'center', 'class' => 'fixed-width-xs')
));
$this->clearFilters();
$this->_join = Shop::addSqlAssociation('category', 'a');
$this->_filter = ' AND NOT EXISTS (
2015-07-06 16:58:50 +02:00
SELECT 1
FROM `'._DB_PREFIX_.'category_product` cp
WHERE a.`id_category` = cp.id_category
)
AND a.`id_category` != '.(int)Configuration::get('PS_ROOT_CATEGORY');
2015-09-22 18:22:11 +02:00
$this->toolbar_title = $this->l('List of empty categories:');
return $this->renderList();
}
public function getCustomListProductsAttributesNoStock()
{
if (!Configuration::get('PS_STOCK_MANAGEMENT')) {
return;
}
$this->table = 'product';
$this->list_id = 'no_stock_products_attributes';
$this->lang = true;
$this->identifier = 'id_product';
$this->_orderBy = 'id_product';
$this->_orderWay = 'DESC';
$this->className = 'Product';
$this->_list_index = 'index.php?controller=AdminProducts';
$this->_list_token = Tools::getAdminTokenLite('AdminProducts');
$this->show_toolbar = false;
$this->addRowAction('edit');
$this->addRowAction('delete');
$this->fields_list = array(
'id_product' => array('title' => $this->l('ID'), 'class' => 'fixed-width-xs', 'align' => 'center'),
'reference' => array('title' => $this->l('Reference')),
'name' => array('title' => $this->l('Name'), 'filter_key' => 'b!name'),
'active' => array('title' => $this->l('Status'), 'type' => 'bool', 'active' => 'status', 'align' => 'center', 'class' => 'fixed-width-xs')
);
$this->clearFilters();
$this->_join = Shop::addSqlAssociation('product', 'a');
$this->_filter = 'AND EXISTS (
2015-07-06 16:58:50 +02:00
SELECT 1
FROM `'._DB_PREFIX_.'product` p
'.Product::sqlStock('p').'
WHERE a.id_product = p.id_product AND EXISTS (
SELECT 1
FROM `'._DB_PREFIX_.'product_attribute` WHERE `'._DB_PREFIX_.'product_attribute`.id_product = p.id_product
)
AND IFNULL(stock.quantity, 0) <= 0
)';
2015-09-22 18:22:11 +02:00
$this->toolbar_title = $this->l('List of products with attributes but without available quantities for sale:');
return $this->renderList();
}
public function getCustomListProductsNoStock()
{
if (!Configuration::get('PS_STOCK_MANAGEMENT')) {
return;
}
$this->table = 'product';
$this->list_id = 'no_stock_products';
$this->className = 'Product';
$this->lang = true;
$this->identifier = 'id_product';
$this->_orderBy = 'id_product';
$this->_orderWay = 'DESC';
$this->show_toolbar = false;
$this->_list_index = 'index.php?controller=AdminProducts';
$this->_list_token = Tools::getAdminTokenLite('AdminProducts');
$this->addRowAction('edit');
$this->addRowAction('delete');
$this->fields_list = array(
'id_product' => array('title' => $this->l('ID'), 'class' => 'fixed-width-xs', 'align' => 'center'),
'reference' => array('title' => $this->l('Reference')),
'name' => array('title' => $this->l('Name')),
'active' => array('title' => $this->l('Status'), 'type' => 'bool', 'active' => 'status', 'align' => 'center', 'class' => 'fixed-width-xs')
);
$this->clearFilters();
$this->_join = Shop::addSqlAssociation('product', 'a');
$this->_filter = 'AND EXISTS (
2015-07-06 16:58:50 +02:00
SELECT 1
FROM `'._DB_PREFIX_.'product` p
'.Product::sqlStock('p').'
WHERE a.id_product = p.id_product AND NOT EXISTS (
SELECT 1
FROM `'._DB_PREFIX_.'product_attribute` pa WHERE pa.id_product = p.id_product
)
AND IFNULL(stock.quantity, 0) <= 0
)';
2015-09-22 18:22:11 +02:00
$this->toolbar_title = $this->l('List of products without attributes and without available quantities for sale:');
return $this->renderList();
}
public function getCustomListProductsDisabled()
{
$this->table = 'product';
$this->list_id = 'disabled_products';
$this->className = 'Product';
$this->lang = true;
$this->identifier = 'id_product';
$this->_orderBy = 'id_product';
$this->_orderWay = 'DESC';
$this->_filter = 'AND product_shop.`active` = 0';
$this->show_toolbar = false;
$this->_list_index = 'index.php?controller=AdminProducts';
$this->_list_token = Tools::getAdminTokenLite('AdminProducts');
$this->addRowAction('edit');
$this->addRowAction('delete');
$this->fields_list = array(
'id_product' => array('title' => $this->l('ID'), 'class' => 'fixed-width-xs', 'align' => 'center'),
'reference' => array('title' => $this->l('Reference')),
'name' => array('title' => $this->l('Name'), 'filter_key' => 'b!name')
);
$this->clearFilters();
$this->_join = Shop::addSqlAssociation('product', 'a');
$this->toolbar_title = $this->l('List of disabled products:');
return $this->renderList();
}
public function renderList()
{
$this->processFilter();
if (!($this->fields_list && is_array($this->fields_list))) {
return false;
}
$this->getList($this->context->language->id);
$helper = new HelperList();
// Empty list is ok
if (!is_array($this->_list)) {
$this->displayWarning($this->l('Bad SQL query', 'Helper').'<br />'.htmlspecialchars($this->_list_error));
return false;
}
$this->setHelperDisplay($helper);
$helper->tpl_vars = $this->tpl_list_vars;
$helper->tpl_delete_link_vars = $this->tpl_delete_link_vars;
// For compatibility reasons, we have to check standard actions in class attributes
foreach ($this->actions_available as $action) {
if (!in_array($action, $this->actions) && isset($this->$action) && $this->$action) {
$this->actions[] = $action;
}
}
$helper->is_cms = $this->is_cms;
$list = $helper->generateList($this->_list, $this->fields_list);
return $list;
}
public function displayEnableLink($token, $id, $value, $active, $id_category = null, $id_product = null)
{
$this->_helper_list->currentIndex = $this->_list_index;
$this->_helper_list->identifier = $this->identifier;
$this->_helper_list->table = $this->table;
return $this->_helper_list->displayEnableLink($this->_list_token, $id, $value, $active, $id_category, $id_product);
}
public function displayDeleteLink($token = null, $id, $name = null)
{
$this->_helper_list->currentIndex = $this->_list_index;
$this->_helper_list->identifier = $this->identifier;
$this->_helper_list->table = $this->table;
return $this->_helper_list->displayDeleteLink($this->_list_token, $id, $name);
}
public function displayEditLink($token = null, $id, $name = null)
{
$this->_helper_list->currentIndex = $this->_list_index;
$this->_helper_list->identifier = $this->identifier;
$this->_helper_list->table = $this->table;
return $this->_helper_list->displayEditLink($this->_list_token, $id, $name);
}
protected function clearFilters()
{
if (Tools::isSubmit('submitResetempty_categories')) {
$this->processResetFilters('empty_categories');
}
if (Tools::isSubmit('submitResetno_stock_products_attributes')) {
$this->processResetFilters('no_stock_products_attributes');
}
if (Tools::isSubmit('submitResetno_stock_products')) {
$this->processResetFilters('no_stock_products');
}
if (Tools::isSubmit('submitResetdisabled_products')) {
$this->processResetFilters('disabled_products');
}
}
public function clearListOptions()
{
$this->table = '';
$this->actions = array();
$this->list_skip_actions = array();
$this->lang = false;
$this->identifier = '';
$this->_orderBy = '';
$this->_orderWay = '';
$this->_filter = '';
$this->_group = '';
$this->_where = '';
$this->list_title = $this->l('Product disabled');
}
public function getList($id_lang, $order_by = null, $order_way = null, $start = 0, $limit = null, $id_lang_shop = false)
{
parent::getList($id_lang, $order_by, $order_way, $start, $limit, Context::getContext()->shop->id);
}
public static function getDescriptionClean($description)
{
return Tools::getDescriptionClean($description);
}
2015-07-06 16:58:50 +02:00
}