* @copyright 2007-2011 PrestaShop SA * @version Release: $Revision: 9565 $ * @license http://opensource.org/licenses/osl-3.0.php Open Software License (OSL 3.0) * International Registered Trademark & Property of PrestaShop SA */ /** * @since 1.5.0 */ class AdminStockMvtControllerCore extends AdminController { public function __construct() { $this->context = Context::getContext(); $this->table = 'stock_mvt_reason'; $this->className = 'StockMvtReason'; $this->lang = true; $this->fieldsDisplay = array( 'id_stock_mvt_reason' => array( 'title' => $this->l('ID'), 'align' => 'center', 'width' => 40, 'widthColumn' => 40, 'search' => false, ), 'sign' => array( 'title' => $this->l('Sign'), 'width' => 80, 'widthColumn' => 100, 'align' => 'center', 'type' => 'select', 'filter_key' => 'a!sign', 'select' => array( '1' => $this->l('Increment'), '-1' => $this->l('Decrement'), ), 'icon' => array( -1 => 'arrow_down.png', 1 => 'arrow_up.png' ), 'orderby' => false ), 'name' => array( 'title' => $this->l('Name'), 'filter_key' => 'b!name', 'width' => 500 ), ); $reasons_inc = StockMvtReason::getStockMvtReasonsWithFilter($this->context->language->id, array(Configuration::get('PS_STOCK_MVT_TRANSFER_TO')), 1); $reasons_dec = StockMvtReason::getStockMvtReasonsWithFilter($this->context->language->id, array(Configuration::get('PS_STOCK_MVT_TRANSFER_FROM')), -1); $this->options = array( 'general' => array( 'title' => $this->l('Options'), 'fields' => array( 'PS_STOCK_MVT_INC_REASON_DEFAULT' => array( 'title' => $this->l('Default reason when incrementing stock:'), 'cast' => 'intval', 'type' => 'select', 'list' => $reasons_inc, 'identifier' => 'id_stock_mvt_reason' ), 'PS_STOCK_MVT_DEC_REASON_DEFAULT' => array( 'title' => $this->l('Default reason when decrementing stock:'), 'cast' => 'intval', 'type' => 'select', 'list' => $reasons_dec, 'identifier' => 'id_stock_mvt_reason' ), ), 'submit' => array(), ) ); $this->context->smarty->assign('list_warehouses', array()); parent::__construct(); } /** * AdminController::initForm() override * @see AdminController::initForm() */ public function initForm() { $this->fields_form = array( 'legend' => array( 'title' => $this->l('Stock Movement Reason'), 'image' => '../img/admin/edit.gif' ), 'input' => array( array( 'type' => 'text', 'lang' => true, 'attributeLang' => 'name', 'label' => $this->l('Name:'), 'name' => 'name', 'size' => 50, 'required' => true ), array( 'type' => 'select', 'label' => $this->l('Action:'), 'name' => 'sign', 'required' => true, 'options' => array( 'query' => array( array( 'id' => '1', 'name' => $this->l('Increase stock') ), array( 'id' => '-1', 'name' => $this->l('Decrease stock') ), ), 'id' => 'id', 'name' => 'name' ), 'p' => $this->l('Select the corresponding action : increments or decrements stock.') ), ), 'submit' => array( 'title' => $this->l(' Save '), 'class' => 'button' ) ); return parent::initForm(); } /** * AdminController::initList() override * @see AdminController::initList() */ public function initList() { $this->displayInformation($this->l('This interface allows you to display the stock movements for a selected warehouse.').'
'); $this->displayInformation($this->l('Also, it allows you to add and edit your own stock movement reasons.')); // access if (!($this->tabAccess['add'] === '1')) $this->no_add = true; //no link on list rows $this->list_no_link = true; /* * Manage default list */ $this->addRowAction('edit'); $this->addRowAction('delete'); $this->addRowActionSkipList('edit', array(6, 7)); $this->addRowActionSkipList('delete', array(1, 2, 3, 4, 6, 7)); if (!isset($_GET['addstock_mvt_reason']) || (Tools::isSubmit('submitAddstock_mvt_reason') && Tools::getValue('id_stock_mvt_reason'))) { $first_list = '

'.$this->l('Stock movement reason').'

'; $first_list .= parent::initList(); } /* * Manage second list */ $warehouses = Warehouse::getWarehouseList(true); array_unshift($warehouses, array('id_warehouse' => -1, 'name' => $this->l('All Warehouses'))); $this->context->smarty->assign('list_warehouses', $warehouses); $this->context->smarty->assign('current_warehouse', $this->getCurrentWarehouseId()); // reset actions and query vars $this->actions = array(); unset($this->_select, $this->_join, $this->_group, $this->_filterHaving, $this->_filter); // override table, land, className and identifier for the current controller $this->table = 'stock_mvt'; $this->className = 'StockMvt'; $this->identifier = 'id_stock_mvt'; $this->lang = false; // test if a filter is applied for this list if (Tools::isSubmit('submitFilter'.$this->table) || $this->context->cookie->{'submitFilter'.$this->table} !== false) $this->filter = true; // test if a filter reset request is required for this list if (isset($_POST['submitReset'.$this->table])) $this->action = 'reset_filters'; else $this->action = ''; // redifine fields display $this->fieldsDisplay = array( 'product_name' => array( 'title' => $this->l('Product Name'), 'width' => 200, 'havingFilter' => true ), 'physical_quantity' => array( 'title' => $this->l('Quantity'), 'width' => 40, 'filter_key' => 'a!physical_quantity' ), 'price_te' => array( 'title' => $this->l('Price (TE)'), 'width' => 70, 'align' => 'right', 'price' => true, 'currency' => true, 'filter_key' => 'a!price_te' ), 'reason' => array( 'title' => $this->l('Reason'), 'width' => 200, 'havingFilter' => true ), 'id_order' => array( 'title' => $this->l('ID Order'), 'width' => 40 ), 'employee' => array( 'title' => $this->l('Employee'), 'width' => 100, 'havingFilter' => true ), 'date_add' => array( 'title' => $this->l('Date'), 'width' => 50, 'align' => 'right', 'type' => 'datetime', 'filter_key' => 'a!date_add' ), ); // make new query $this->_select = ' CONCAT(pl.name, \' \', GROUP_CONCAT(IFNULL(al.name, \'\'), \'\')) product_name, CONCAT(e.lastname, \' \', e.firstname) AS employee, mrl.name AS reason, w.id_currency as id_currency'; $this->_join = 'INNER JOIN '._DB_PREFIX_.'stock stock ON a.id_stock = stock.id_stock LEFT JOIN `'._DB_PREFIX_.'product_lang` pl ON ( stock.id_product = pl.id_product AND pl.id_lang = '.(int)$this->context->language->id.$this->context->shop->addSqlRestrictionOnLang('pl').' ) LEFT JOIN `'._DB_PREFIX_.'stock_mvt_reason_lang` mrl ON ( a.id_stock_mvt_reason = mrl.id_stock_mvt_reason AND mrl.id_lang = '.(int)$this->context->language->id.' ) LEFT JOIN `'._DB_PREFIX_.'employee` e ON (e.id_employee = a.id_employee) LEFT JOIN `'._DB_PREFIX_.'warehouse` w ON (w.id_warehouse = stock.id_warehouse) LEFT JOIN `'._DB_PREFIX_.'product_attribute_combination` pac ON (pac.id_product_attribute = stock.id_product_attribute) LEFT JOIN `'._DB_PREFIX_.'attribute_lang` al ON ( al.id_attribute = pac.id_attribute AND al.id_lang = '.(int)$this->context->language->id.' )'; $this->_group = 'GROUP BY a.id_stock_mvt'; $id_warehouse = $this->getCurrentWarehouseId(); if ($id_warehouse > 0) $this->_where = ' AND w.id_warehouse = '.$id_warehouse; // call postProcess() for take care about actions and filters $this->postProcess(); // generate the second list $second_list = parent::initList(); // reset all query vars unset($this->_select, $this->_join, $this->_group, $this->_filterHaving, $this->_filter); // return the two lists return $second_list.$first_list; } /** * Gets the current warehouse for this controller * * @return int warehouse_id */ protected function getCurrentWarehouseId() { static $warehouse = 0; if ($warehouse == 0) { $warehouse = -1; if ((int)Tools::getValue('warehouse')) $warehouse = (int)Tools::getValue('warehouse'); else if ((int)$this->context->cookie->warehouse) $warehouse = (int)$this->context->cookie->warehouse; $this->context->cookie->warehouse = $warehouse; } return $warehouse; } }