Может быть я просто не нашел более простого способа... Но для того чтобы получить общую сумму (цена*кол-во каждого товара) мне пришлось заморочнуться. Это связанно с тем, что в проекте была необходимость реализовать разные цены в зависимости от кол-ва товаров. А ведь кол-во можно изменить в корзине. Так что не получилось обойтись костылем на скрипте (простым умножение кол-ва на цену), а нужно чтобы вместе с общей суммой мне по аяксу приходили еще и калькуляция цены товара — с умножением на кол-во, ну и единичной тоже.
Для реализации этого функционала мне пришлось поправить несколько системных файлов 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(...
переключаем внимание на этот метод. Он тоже расположен в этом файле. И это то, что нам нужно. дальнейшие действия описаны в первом разделе этой статейки.
Мне нужно было проще. Я сделал на жавике.
В текстовое содержание элемента ('.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(); }
});