Перейти к содержанию
Denyelle

Доставка и бесплатная доставка

Рекомендуемые сообщения

Добрый день.

Нужна помощь экспертов)

Вопрос про выбор доставки. Я в админке активировал 2 вида доставки - с фиксированной стоимостью и бесплатную. Они одновременно показываются в корзине.

Мне надо сделать так, чтобы бесплатная доставка показывалась только вт ом случае, если в таблице oc_product в поле free_ship стояло значение 1.

То есть если значение стоит, то вместо фиксированной стоимости показывать Бесплатную доставку иначе показывать доставку с фиксированной стоимостью.

 

Подскажите как такое можно сделать?

 

Спасибо.

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты
21 минуту назад, Denyelle сказал:

Добрый день.

Нужна помощь экспертов)

Вопрос про выбор доставки. Я в админке активировал 2 вида доставки - с фиксированной стоимостью и бесплатную. Они одновременно показываются в корзине.

Мне надо сделать так, чтобы бесплатная доставка показывалась только вт ом случае, если в таблице oc_product в поле free_ship стояло значение 1.

То есть если значение стоит, то вместо фиксированной стоимости показывать Бесплатную доставку иначе показывать доставку с фиксированной стоимостью.

 

Подскажите как такое можно сделать?

 

Спасибо.

А как же микс? Когда в корзине товар с free_shipping [true] и free_shipping [false] ?

 

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты
5 минут назад, Eldaeron сказал:

А как же микс? Когда в корзине товар с free_shipping [true] и free_shipping [false] ?

 

Тогда оставлять только бесплатную доставку.

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты
2 минуты назад, Denyelle сказал:

Тогда оставлять только бесплатную доставку.

Править контроллер catalog/controller/checkout/shipping_metod.php (от отвечает за отображение методов доставки)

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Добавить условие в модель каждой из доставок
Для бесплатной тут catalog\model\shipping\free.php
Для фиксированной тут catalog\model\shipping\flat.php

Изменено пользователем thentru

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Спасибо. Буду пробовать ковырять.

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты
3 часа назад, thentru сказал:

Добавить условие в модель каждой из доставок
Для бесплатной тут catalog\model\shipping\free.php
Для фиксированной тут catalog\model\shipping\flat.php

Я так понимаю вы говорите про эту строку?

    $query = $this->db->query("SELECT * FROM " . DB_PREFIX . "zone_to_geo_zone WHERE geo_zone_id = '" . (int)$this->config->get('free_geo_zone_id') . "' AND country_id = '" . (int)$address['country_id'] . "' AND (zone_id = '" . (int)$address['zone_id'] . "' OR zone_id = '0')");

 

Как правильно добавить что free_ship = 1 в oc_product?

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты
$implode = array();

foreach ($this->cart->getProducts() as $product) {
  $implode[$product['product_id']] = "product_id = '" . (int)$product['product_id'] . "'";
}

if ($implode) {
  $query = $this->db->query("SELECT COUNT(*) AS total FROM " . DB_PREFIX . "product WHERE free_ship = '1' AND (" . implode(' OR ', $implode) . ")");
    
  if (!$query->num_rows) {
    $status = false;
  }
}

так, например, для бесплатной доставки


т.е. берете id товаров и проверяете запросом есть ли среди них товары с бесплатной доставкой.
Если нет - модуль выводить не нужно

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты
19 минут назад, thentru сказал:

$implode = array();

foreach ($this->cart->getProducts() as $product) {
  $implode[$product['product_id']] = "product_id = '" . (int)$product['product_id'] . "'";
}

if ($implode) {
  $query = $this->db->query("SELECT COUNT(*) AS total FROM " . DB_PREFIX . "product WHERE free_ship = '1' AND (" . implode(' OR ', $implode) . ")");
    
  if (!$query->num_rows) {
    $status = false;
  }
}

так, например, для бесплатной доставки


т.е. берете id товаров и проверяете запросом есть ли среди них товары с бесплатной доставкой.
Если нет - модуль выводить не нужно

 Спасибо за предложенный вариант.

 

А в эту строку можно как-то указать? А то не знаю куда именно вставить ваш код в shipping\free.php

 

$query = $this->db->query("SELECT * FROM " . DB_PREFIX . "zone_to_geo_zone WHERE geo_zone_id = '" . (int)$this->config->get('free_geo_zone_id') . "' AND country_id = '" . (int)$address['country_id'] . "' AND (zone_id = '" . (int)$address['zone_id'] . "' OR zone_id = '0')");

 

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Для публикации сообщений создайте учётную запись или авторизуйтесь

Вы должны быть пользователем, чтобы оставить комментарий

Создать учетную запись

Зарегистрируйте новую учётную запись в нашем сообществе. Это очень просто!

Регистрация нового пользователя

Войти

Уже есть аккаунт? Войти в систему.

Войти

  • Последние посетители   0 пользователей онлайн

    Ни одного зарегистрированного пользователя не просматривает данную страницу

×

Важная информация

На нашем сайте используются файлы cookie и происходит обработка некоторых персональных данных пользователей, чтобы улучшить пользовательский интерфейс. Чтобы узнать для чего и какие персональные данные мы обрабатываем перейдите по ссылке. Если Вы нажмете «Я даю согласие», это означает, что Вы понимаете и принимаете все условия, указанные в этом Уведомлении о Конфиденциальности.