Помощь Отключенные товары вернуть на сайт, но не в категорию

Тема в разделе "Opencart", создана пользователем wwizard, 1 апр 2015.

Информация :
Внимание форумчане! При создании тем, или выкладывании какой-либо информации проверьте в какой ветке форума вы находитесь! Не путайте Opencart и Opencart2. При несоблюдении данного условия выносится соответствующее наказание! И потом не говорите что вас НЕ ПРЕДУПРЕЖДАЛИ! По возможности используйте обменники mail, yandex, google, dropbox, rghost Дабы избежать просьб перезалить и проблем с рекламой!
Модераторы: ZiX
  1. wwizard

    wwizard

    Регистр.:
    20 июл 2009
    Сообщения:
    418
    Симпатии:
    12
    Я отключаю товары на сайте - если товар отключен и ты переходишь по ссылке - то его просто нет., и в категории он не отображается.
    А как сделать так, чтобы отключенный товар - ссылка работала, а вот в категории он все равно не отображался.?

    Как тут: ссылка не подходит, бо в списке категорий тогда тоже начинает светиться товар
     
    Последнее редактирование: 1 апр 2015
  2. drozd22

    drozd22

    Регистр.:
    17 июн 2011
    Сообщения:
    362
    Симпатии:
    283
    Можно и по быстрому, в модели сделать клон getProduct($product_id), например назвав getProductNotStatus($product_id), в котором убираешь проверку AND p.status = '1'. В контроллере product.php меняешь вызываемую функцию, т.е. в этом месте
    Код:
            $product_info = $this->model_catalog_product->getProduct($product_id);
    
            if ($product_info) {
                $url = '';
    делаешь так
    Код:
            $product_info = $this->model_catalog_product->getProductNotStatus($product_id);
    
            if ($product_info) {
                $url = '';
    При этом стоит сделать в контроллере и шабе обработку поля status, чтобы в карточке выводить типа "Под заказ" и т.д.
     
    wwizard нравится это.
  3. ibcom

    ibcom Постоялец

    Регистр.:
    5 ноя 2014
    Сообщения:
    53
    Симпатии:
    10
    Все можно сделать значительно проще, без внесения изменения в код:
    1. Создаете категорию - к примеру "Нет в наличии" Статус: Отключено.
    2. В карточке товара привязываете данный товар к вышеуказанной категории.
    Все. Товар можно будет найти как по поиску на сайте, так и перейти по ссылке. Т.к. Категория отключена, в категориях их видно не будет
     
  4. wwizard

    wwizard

    Регистр.:
    20 июл 2009
    Сообщения:
    418
    Симпатии:
    12
    Мне нравиться - только я не совсем понял
     
  5. ioh

    ioh

    Регистр.:
    24 сен 2013
    Сообщения:
    181
    Симпатии:
    4
    в файле catalog/controller/catalog/product.php удаляется строка AND p.status = '1' (ищите поиском по файлу удалите первую найденную)
    И ставьте модуль sold out
     
  6. drozd22

    drozd22

    Регистр.:
    17 июн 2011
    Сообщения:
    362
    Симпатии:
    283
    Ok. Подробно на примере для OpenCart 1.5.6.4 (что оказалось сейчас у меня под рукой).
    Открываешь файл модели /catalog/model/catalog/product.php и пред строкой
    Код:
        public function getProduct($product_id) {
    вставляешь
    Код:
        public function getProductNotStatus($product_id) {
            if ($this->customer->isLogged()) {
                $customer_group_id = $this->customer->getCustomerGroupId();
            } else {
                $customer_group_id = $this->config->get('config_customer_group_id');
            }   
    
            $query = $this->db->query("SELECT DISTINCT *, pd.name AS name, p.image, m.name AS manufacturer, (SELECT price FROM " . DB_PREFIX . "product_discount pd2 WHERE pd2.product_id = p.product_id AND pd2.customer_group_id = '" . (int)$customer_group_id . "' AND pd2.quantity = '1' AND ((pd2.date_start = '0000-00-00' OR pd2.date_start < NOW()) AND (pd2.date_end = '0000-00-00' OR pd2.date_end > NOW())) ORDER BY pd2.priority ASC, pd2.price ASC LIMIT 1) AS discount, (SELECT price FROM " . DB_PREFIX . "product_special ps WHERE ps.product_id = p.product_id AND ps.customer_group_id = '" . (int)$customer_group_id . "' AND ((ps.date_start = '0000-00-00' OR ps.date_start < NOW()) AND (ps.date_end = '0000-00-00' OR ps.date_end > NOW())) ORDER BY ps.priority ASC, ps.price ASC LIMIT 1) AS special, (SELECT points FROM " . DB_PREFIX . "product_reward pr WHERE pr.product_id = p.product_id AND customer_group_id = '" . (int)$customer_group_id . "') AS reward, (SELECT ss.name FROM " . DB_PREFIX . "stock_status ss WHERE ss.stock_status_id = p.stock_status_id AND ss.language_id = '" . (int)$this->config->get('config_language_id') . "') AS stock_status, (SELECT wcd.unit FROM " . DB_PREFIX . "weight_class_description wcd WHERE p.weight_class_id = wcd.weight_class_id AND wcd.language_id = '" . (int)$this->config->get('config_language_id') . "') AS weight_class, (SELECT lcd.unit FROM " . DB_PREFIX . "length_class_description lcd WHERE p.length_class_id = lcd.length_class_id AND lcd.language_id = '" . (int)$this->config->get('config_language_id') . "') AS length_class, (SELECT AVG(rating) AS total FROM " . DB_PREFIX . "review r1 WHERE r1.product_id = p.product_id AND r1.status = '1' GROUP BY r1.product_id) AS rating, (SELECT COUNT(*) AS total FROM " . DB_PREFIX . "review r2 WHERE r2.product_id = p.product_id AND r2.status = '1' GROUP BY r2.product_id) AS reviews, p.sort_order FROM " . DB_PREFIX . "product p LEFT JOIN " . DB_PREFIX . "product_description pd ON (p.product_id = pd.product_id) LEFT JOIN " . DB_PREFIX . "product_to_store p2s ON (p.product_id = p2s.product_id) LEFT JOIN " . DB_PREFIX . "manufacturer m ON (p.manufacturer_id = m.manufacturer_id) WHERE p.product_id = '" . (int)$product_id . "' AND pd.language_id = '" . (int)$this->config->get('config_language_id') . "' AND p.date_available <= NOW() AND p2s.store_id = '" . (int)$this->config->get('config_store_id') . "'");
    
            if ($query->num_rows) {
                return array(
                    'product_id'       => $query->row['product_id'],
                    'name'             => $query->row['name'],
                    'description'      => $query->row['description'],
                    'meta_description' => $query->row['meta_description'],
                    'meta_keyword'     => $query->row['meta_keyword'],
                    'tag'              => $query->row['tag'],
                    'model'            => $query->row['model'],
                    'sku'              => $query->row['sku'],
                    'upc'              => $query->row['upc'],
                    'ean'              => $query->row['ean'],
                    'jan'              => $query->row['jan'],
                    'isbn'             => $query->row['isbn'],
                    'mpn'              => $query->row['mpn'],
                    'location'         => $query->row['location'],
                    'quantity'         => $query->row['quantity'],
                    'stock_status'     => $query->row['stock_status'],
                    'image'            => $query->row['image'],
                    'manufacturer_id'  => $query->row['manufacturer_id'],
                    'manufacturer'     => $query->row['manufacturer'],
                    'price'            => ($query->row['discount'] ? $query->row['discount'] : $query->row['price']),
                    'special'          => $query->row['special'],
                    'reward'           => $query->row['reward'],
                    'points'           => $query->row['points'],
                    'tax_class_id'     => $query->row['tax_class_id'],
                    'date_available'   => $query->row['date_available'],
                    'weight'           => $query->row['weight'],
                    'weight_class_id'  => $query->row['weight_class_id'],
                    'length'           => $query->row['length'],
                    'width'            => $query->row['width'],
                    'height'           => $query->row['height'],
                    'length_class_id'  => $query->row['length_class_id'],
                    'subtract'         => $query->row['subtract'],
                    'rating'           => round($query->row['rating']),
                    'reviews'          => $query->row['reviews'] ? $query->row['reviews'] : 0,
                    'minimum'          => $query->row['minimum'],
                    'sort_order'       => $query->row['sort_order'],
                    'status'           => $query->row['status'],
                    'date_added'       => $query->row['date_added'],
                    'date_modified'    => $query->row['date_modified'],
                    'viewed'           => $query->row['viewed']
                );
            } else {
                return false;
            }
        }
    Это копия getProduct($product_id) но с вырезанным условием AND p.status = '1' из SELECT
    Далее в контроллере /catalog/controller/product/product.php находишь
    Код:
            $this->load->model('catalog/product');
    
            $product_info = $this->model_catalog_product->getProduct($product_id);
    и меняешь на
    Код:
            $this->load->model('catalog/product');
    
            $product_info = $this->model_catalog_product->getProductNotStatus($product_id);
    Всё работает, конфликты с другими сторонними модулями маловероятны.
     
    wwizard нравится это.
  7. drozd22

    drozd22

    Регистр.:
    17 июн 2011
    Сообщения:
    362
    Симпатии:
    283
    Как-то длинновато получается, разбиваю на два поста.
    Чтобы получить возможность в product.tpl внедрить доп. условия для отправки в корзину, может что-бы и цену не показывать, добавляешь в контроллере еще одну переменную. Например после строки
    Код:
    $this->data['points'] = $product_info['points'];
    вставляешь строку
    Код:
    $this->data['product_status'] = $product_info['status'];
    Теперь в product.tpl через $product_status можно сделать изменения для карточек выключенных товаров.
     
    wwizard нравится это.
  8. Афоня

    Афоня Постоялец

    Регистр.:
    8 апр 2013
    Сообщения:
    97
    Симпатии:
    87
    Посмотрите модуль Архивный товар для OpenCart
     
    wwizard нравится это.