Общая сумма по каждому товару в корзине Minishop2

Может быть я просто не нашел более простого способа... Но для того чтобы получить общую сумму (цена*кол-во каждого товара) мне пришлось заморочнуться. Это связанно с тем, что в проекте была необходимость реализовать разные цены в зависимости от кол-ва товаров. А ведь кол-во можно изменить в корзине. Так что не получилось обойтись костылем на скрипте (простым умножение кол-ва на цену), а нужно чтобы вместе с общей суммой мне по аяксу приходили еще и калькуляция цены товара — с умножением на кол-во, ну и единичной тоже.

Для реализации этого функционала мне пришлось поправить несколько системных файлов minishop2.

Решение

Реализовано с версией минишопа 2.4.11

В файле core/components/minishop2/model/minishop2/mscarthandler.class.php находим объявление метода public function status($data = array()), и в нем перед самым return добавляем строку $status['cart'] = $this->cart;. Чтобы получилось так:

    public function status($data = array())
    {
        ...
        $status['cart'] = $this->cart;
        return array_merge($data, $status);
    }

Теперь нужно обработать скриптом эти данные. Находим в файле assets/components/minishop2/js/web/default.js объявление сетода status: function (status) {, и там внутри блока else прописываем цикл. Тут я приведу свой пример, который вам будет необходимо адаптировать под свою верстку.

status: function (status) {
    if (status['total_count'] < 1) {
        location.reload();
    }else{
        ...
        console.log(status);
        $.each(status.cart, function(key,value) {
            $("#"+key).find(".cart_row_price").find("span").text(miniShop2.Utils.formatPrice(value.price));
            $("#"+key).find(".cart_row_price_sum").find("span").text(miniShop2.Utils.formatPrice(value.price*value.count));
        });
        ...
    }
}

На случай если нихренашечки не получилось

Первичная настройка

Вывод данных в консоль
Вслепую работать никак нельзя, и важно понимать что за данные приходят по аяксу. Для этого отредактируем файлик assets/components/minishop2/js/web/default.js, (на 217 строке) там где идет определение функции xhr, и конкретно после строчки }).fail(function () { добавляем строчку console.log(xhr.responseText);. Это нам позволит отобразать "ошибки". Будем это использовать чтобы выводить результаты работы всяких print_r и var_dump.
Также выведем данные уже чистые. Там где объявяется change: function () {, внутри callbacks.change.response.success = function (response) { добавляем строчку console.log(response);.
Ок, "у нас появились глаза")

Методика исследования

Как вы заметили из консоли, скрипт обращается к файлу assets/components/minishop2/action.php, но там вы ничего интересного не найдете. На самом деле это — плагин miniShop2, именно там начинается "дивный путь поиска решения" — "безграничный и удивительный":).

Основной файл минишопа находится тут — core/components/minishop2/model/minishop2/minishop2.class.php. В нем мы находим метод handleRequest, и в частности смотрим на case 'cart/change':.
$this->cart->change говорит нам о том, что в этом файле искать бесполезно, ищем контроллер корзины, и находим его в файле core/components/minishop2/model/minishop2/mscarthandler.class.php. Тут находим метод public function change($key, $count), и, наткнувшись в нем на ...status(... переключаем внимание на этот метод. Он тоже расположен в этом файле. И это то, что нам нужно. дальнейшие действия описаны в первом разделе этой статейки.

Комментарии (3)

  1. Александр 16 февраля 2019, 19:17 # 0
    Спасибо за статью. Хотел уточнить, а после изменения количества товара в корзине динамически сумма поменяется без перезагрузки страницы? у меня только после перезагрузки.
    1. Юрий 31 августа 2019, 16:00 # 0
      А как сделать чтобы цена менялась при изменении количества товара. Сейчас меняется только после перезагрузки
      1. Евгений 05 октября 2019, 13:53 # 0
        Привет!
        Мне нужно было проще. Я сделал на жавике.
        В текстовое содержание элемента ('.item-total-price')
        записывается цена товара('.product-price') * количество ('.product-quantity .quantity')
        Вместо $('#cartTable tr') -соответственно Ваш элемент списка товаров или строка таблицы с товарами.
        Оформление какое угодно, но главное подключаемся ко всем аякс запросам со страницы, и если запрос на нужный адрес и ответ тру значит пересчитываем суммы по товарам

        В любом js файле добавить:

        $(document).ready(function() {
        function getListSums(){
        $('#cartTable tr').each(function(){
        $(this).find('.item-total-price').text(
        $(this).find('.product-price').data('val') * $(this).find('.product-quantity .quantity').val()
        );
        });
        }
        getListSums();//сразу вывод

        //подключаемся к аякс запросам ответственным за работу с корзиной
        $(document).ajaxSuccess(function(event, xhr, settings) {
        if(settings.url === '/assets/components/minishop2/action.php' && xhr.responseJSON.success === true ){ getListSums(); }
        });
        *Комментарий будет опубликован после проверки модератором

        Комментарии easyComm

        Станислав 23 августа 2018, 20:48

        Хорошая статья, почти все получилось, только почему то общая сумма появляется после прибавления и удаления товара, при обновлении страницы сумма исчезает, не подскажете с чем это может быть связано?

        Администратор

        На вывод товаров в корзину эти моменты не особо влияют.
        Сумма в корзину будет попадать вот так: {$product.cost}
        Также, возможно, будет полезна вот эта заметка - https://webstool.ru/izmenit-czenu-na-tovar-minishop2.html

        Николай 03 августа 2018, 09:29

        Благодарю, только у вас нашел эту информацию. Все работает.

        Похожие статьи

        Наш сайт использует куки, нажмите «ОК» если вы не против
        OK