Помогите подправить модуль

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

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

    sergei1974 Постоялец

    Регистр.:
    18 ноя 2014
    Сообщения:
    89
    Симпатии:
    18
    Сейчас модуль скрывает все товары с остатком 0. Но при заходе по прямой ссылке, товар можно отправить в корзину, а нужно чтоб кнопка "купить", при остатке "0" и "нет в наличии", была не активной, изменила цвет, статус на кнопке "нет в наличии", и убралось выбор количества, "в избранное", и "сравнить". ocStore 1.5.5.1.2. Или просто убрать кнопку купить, выбор количества, "в избранное", и "сравнить"
    <modification>

    <id><![CDATA[Hide products if not available]]></id>
    <version><![CDATA[OcStore 1.5.5.1-2]]></version>
    <vqmver><![CDATA[]]></vqmver>

    <file name='catalog/model/catalog/product.php'>
    <operation>
    <search position='before'><![CDATA[
    public function getProducts($data = array()) {
    ]]></search>
    <add trim='true'><![CDATA[
    public function getFeaturedProduct($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 < '" . $this->NOW . "') AND (pd2.date_end = '0000-00-00' OR pd2.date_end > '" . $this->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 < '" . $this->NOW . "') AND (ps.date_end = '0000-00-00' OR ps.date_end > '" . $this->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.status = '1' AND p.quantity > 0 AND p.date_available <= '" . $this->NOW . "' AND p2s.store_id = '" . (int)$this->config->get('config_store_id') . "'");

    if ($query->num_rows) {
    return array(
    'seo_title' => $query->row['seo_title'],
    'seo_h1' => $query->row['seo_h1'],
    '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;
    }
    }
    ]]></add>
    </operation>
    <operation>
    <search position='replace' index='3,4,5,6,7,8'><![CDATA[
    p.status = '1'
    ]]></search>
    <add trim='true'><![CDATA[
    p.status = '1' AND p.quantity > 0
    ]]></add>
    </operation>
    </file>

    <file name='catalog/controller/module/featured.php'>
    <operation>
    <search position='replace'><![CDATA[
    $product_info = $this->model_catalog_product->getProduct($product_id)
    ]]></search>
    <add trim='true'><![CDATA[
    $product_info = $this->model_catalog_product->getFeaturedProduct($product_id)
    ]]></add>
    </operation>
    </file>

    <file name='catalog/controller/product/product.php'>
    <operation>
    <search position='after'><![CDATA[
    $product_info = $this->model_catalog_product->getProduct($product_id);
    ]]></search>
    <add><![CDATA[
    $this->data['product_info'] = $product_info;
    ]]></add>
    </operation>
    <operation>
    <search position="after"><![CDATA[
    'price' => $price,
    ]]></search>
    <add><![CDATA[
    'quantity' => $result['quantity'],
    'stock_status'=> $result['stock_status'],
    ]]></add>
    </operation>
    </file>

    <file name='catalog/view/theme/bt_babystore/template/product/product.tpl'>
    <operation>
    <search position='replace'><![CDATA[
    <input type="button" value="<?php echo $button_cart; ?>" id="button-cart" class="button" />
    ]]></search>
    <add><![CDATA[
    <?php if ($product_info['quantity'] <= 0) { ?>
    <input disabled type="button" value="<?php echo $stock; ?>" class="button" />
    <?php } else { ?>
    <input type="button" value="<?php echo $button_cart; ?>" id="button-cart" class="button" />
    <?php } ?>
    ]]></add>
    </operation>
    <operation>
    <search position='replace'><![CDATA[
    <a onclick="addToCart('<?php echo $product['product_id']; ?>');" class="button"><?php echo $button_cart; ?></a></div>
    ]]></search>
    <add><![CDATA[
    <?php if ($product['quantity'] <= 0) { ?>
    <a disabled class="button"><?php echo $product['stock_status']; ?></a></div>
    <?php } else { ?>
    <a onclick="addToCart('<?php echo $product['product_id']; ?>');" class="button"><?php echo $button_cart; ?></a></div>
    <?php } ?>]]></add>
    </operation>
    </file>

    </modification>
     
    Последнее редактирование: 22 сен 2015
  2. SNip

    SNip Создатель

    Регистр.:
    1 окт 2012
    Сообщения:
    19
    Симпатии:
    0
    Ты пользуешься каким именно модулем? Стандартным или сторонним?
     
  3. sergei1974

    sergei1974 Постоялец

    Регистр.:
    18 ноя 2014
    Сообщения:
    89
    Симпатии:
    18
    Стоит модуль "Hide products if not available". Код выложил под сполером
     
  4. runways1

    runways1 Создатель

    Регистр.:
    16 сен 2012
    Сообщения:
    17
    Симпатии:
    0
    <?php if ($product['quantity'] меньше нуля или = 0

    и дописывать там что display:none;
     
  5. sergei1974

    sergei1974 Постоялец

    Регистр.:
    18 ноя 2014
    Сообщения:
    89
    Симпатии:
    18
    А можно подробнее, куда что дописать и куда вставить <?php if ($product['quantity']. А то я в PHP полный 0