Телеграм: @bazarow_ru Почта: mihail@bazarow.ru

Смена вида карточек товаров в catalog.section с иммитацией AJAX

Просмотров: 1627

Смену вида карточек товаров, в разделе каталога, можно реализовать с помощью сессии, записывая в нее нужный вида шаблона или режима отображения.

Смена вида карточек товаров в catalog.section с иммитацией AJAX

Предположим что у нас используется один шаблон catalog.section но, внутри него, мы хотим преключать режим отображения по одному товару в ряд или по четыре.

За режим отображения отвечает параметр LIST_PRODUCT_ROW_VARIANTS. Конкретно, в случае по одному или четыре товара отвечают условия case=0 и case=3.

Работаем с сессией в 1С-Битрикс

Нам нужно записать в сессию нужный вид отображения и применить для компонента каталога вызываемого в section.php, комплексного шаблона каталога.

Открываем этот файл и добавялем вывод кнопок переключения, в которых параметр data-wiev содержит интересующие нас режимы отображения:

<div class="catalog_sort_panel_view">
  <button data-wiev="[{'VARIANT':'3','BIG_DATA':false}]">
      <i class="fa fa-th"></i>
  </button>
  <button data-wiev="[{'VARIANT':'0','BIG_DATA':false}]">
     <i class="fa fa-list"></i>
  </button>
</div>

Добравляем js скрипт с POST запросом, который отправляет нужный (нажатый/выбранный) параметр в файл /local/ajax/view_catalog.php и при получении ответа перезагружает страницу в том же месте (страница не промотывается вверх)

$('.catalog_sort_panel_view button').click(function () {
var wievVariant = $(this).data('wiev');
$.post('/local/ajax/view_catalog.php',
  {
        LIST_PRODUCT_ROW_VARIANTS: wievVariant,
  }, function (data) {
        location.reload();
  });
});

В файл /local/ajax/view_catalog.php добавляем работу с сессией, и в ключ LIST_PRODUCT_ROW_VARIANTS записываем переданное js скриптом значение.

require_once($_SERVER['DOCUMENT_ROOT'] . "/bitrix/modules/main/include/prolog_before.php");
$session = \Bitrix\Main\Application::getInstance()->getSession();
// Ставим в ключ сессии LIST_PRODUCT_ROW_VARIANTS вид каталога
$session->set('LIST_PRODUCT_ROW_VARIANTS', $_POST['LIST_PRODUCT_ROW_VARIANTS']);
exit();

В вызове bitrix:catalog.section комплексного шаблона каталога, указываем что параметр PRODUCT_ROW_VARIANTS должен быть применен из ключа сессии LIST_PRODUCT_ROW_VARIANTS. Перед этим нужно задать значение по умолчанию, иначе параметр будет пустым (пока пользователь не выберет нужный ему вид)


$session = \Bitrix\Main\Application::getInstance()->getSession();
if ($session->has('LIST_PRODUCT_ROW_VARIANTS')) {
   // Если ключ есть, берем вид из него
   $LIST_PRODUCT_ROW_VARIANTS = $session['LIST_PRODUCT_ROW_VARIANTS'];
}
if (empty($LIST_PRODUCT_ROW_VARIANTS)) {
    // Если ключ пустой ставим вид по умолчанию
   $LIST_PRODUCT_ROW_VARIANTS = "[{'VARIANT':'3','BIG_DATA':false}]";
}

$intSectionID = $APPLICATION->IncludeComponent(
    "bitrix:catalog.section",
    "section", array(
	... сокращено bitrix:catalog.section ...
	"PAGE_ELEMENT_COUNT" => '40', // по сколько товаров показывать
        "PRODUCT_ROW_VARIANTS" => $LIST_PRODUCT_ROW_VARIANTS,
	... сокращено bitrix:catalog.section ...
),
    $component
);
Михаил Базаров 08.10.2022
С сесcией можно работать и без API битрикс, просто используя
$_SESSION
Код
session_start();
$_SESSION['LIST_PRODUCT_ROW_VARIANTS'] = $_POST['LIST_PRODUCT_ROW_VARIANTS'];
exit();

Так же, этот способ можно использовать и для сортировки товаров:
По новизне, алфавиту, свойствам и так далее.
Таким же образом записываем в сессию параметры и направление SORT для каталога
Vlad 05.11.2022
А в этот блок "Смена вида карточек" есть вариант добавить адекватным методом еще кнопки согласно вашего урока "Создать pdf файл из элемента инфоблока, дать скачать пользователю, поддерживать в актуальном состоянии или отправить на e-mail."
Михаил Базаров 05.11.2022
Да, просто добавляете туда ссылку на скачивание сгенерированной pdf.
Vlad 05.11.2022
Переключение/смена вида карточек товаров: Какой из вариантов будет удобней и практичнее?
Вашим методом или с помощью куки из заметки на форуме: Переключение видов (шаблонов) каталога товара. При выборе варианта шаблона по умолчанию установлен выбор в зависимости условия мобильная/Desctop (разрешения экрана) версия
Михаил Базаров 05.11.2022
Думаю, способ с переключением внутри одного шаблона практичнее.
Не придется поддерживать несколько отдельных шаблонов, если потребуются правки.
Но, исходите из реального проекта - может быть, в вашем случае, реально удобнее переключать шаблоны целиком а не вид внутри шаблона.

Записная книжка разработчика

Примерно с 2013-го года пишу заметки по разработке сайтов на Битрикс.
Вы можете задавать уточняющие вопросы в комментариях- отвечаю или дополняю заметки по возможности.

Цвета торговых предложений из Highload инфоблоков в списке товаров Просмотров: 14905 Подвернулся на доработку очень старый сайт, работал еще на 11-ой версии Битрикс. Выполнили... Автоматическая загрузка каталогов из csv файлов в Битрикс Просмотров: 11797 Если требуется настроить автоматический импорт каталогов из csv файлов, от поставщиков. В... Вывести артикул в печатную форму бланка заказа Просмотров: 1074 Задача: в печатную форму бланка заказа добавить артикулы товаров и данные о пользователе. ... Отсортировать элементы в Битрикс по свойству привязка к разделам Просмотров: 28993 При создании достаточно сложных интернет-магазинов на Битрикс, иногда встает задача помимо... Как работает система сертификации партнеров 1С-Битрикс, уровни партне... Просмотров: 4472 Сертификация от «1С-Битрикс» – это объективная оценка знаний и практических навыков разраб... Показать пользователю накопительную скидку за все сделанные заказы, и... Просмотров: 2623 Задача: показать, текущему авторизованному, пользователю сумму всех выполненных заказов и ... Простые калькуляторы в карточке товара каталога на Битрикс Просмотров: 16178 На одном из создаваемых сайтов было необходимо сделать небольшой калькулятор и предварител... Смена вида карточек товаров в catalog.section с иммитацией AJAX Просмотров: 1627 Смену вида карточек товаров, в разделе каталога, можно реализовать с помощью сессии, запис... Валидация пароля и подтверждения при регистрации в битрикс Просмотров: 15267 Встала задачка сделать валидацию пароля и его подтверждения в стандартной форме регистраци... Получить все товары из всех заказов пользователя. История купленных т... Просмотров: 2217 Задача: нужно создать раздел, в персональном разделе пользователя, с историей всех купленн... Перенос Битрикс сайта с хостинга на хостинг, инструкция Просмотров: 27391 Достаточно часто спрашивают как перенести сайт работающий на 1С Битрикс с одного хостинга ... Простой WEB сервер на ubuntu, для Битрикс Просмотров: 35932 Расскажу как по быстрому сконфигурировать WEB сервер для работы с Битрикс. Безо всяких ngi... XML в формате Commerce ML-2, города России и Мира, для выгрузки в инф... Просмотров: 6961 Подвернулась задачка, создать инфоблок для Битрикс, в котором будут просто города России и... Создание раздела инфоблока при регистрации пользователя в Битрикс Просмотров: 8650 Например вам нужно выводить информацию исключительно для определенного пользователя. Само ... Автоматически отгрузить заказ и сменить статус отгрузки, при выполнен... Просмотров: 951 Проблема: Заказы, на сайте, обрабатываются только в 1С. При этом 1С не работает с отгрузка... Показать только один тип цены в каталоге Битрикс Просмотров: 14955 Достаточно часто, при создании сайта на битрикс, можно столкнуться с такой проблемой: на с... Кастомизация компонента восстановления пароля bitrix:system.auth.forg... Просмотров: 26777 Достаточно часто спрашивают как кастомизировать компонент восстановления пароля пользовате... Пункты меню из разделов инфоблока Битрикс Просмотров: 93237 В принципе это стандартная возможность системы управления битрикс, но почему-то часто спра... Вывести дату окончания скидки в карточке товара Просмотров: 4522 Если нужно вывести информацию о скидке в карточке товара, можно воспользоваться методом Умный фильтр на главной странице Битрикс Просмотров: 22296 Редкая но востребованная задачка- это вывести компонент "умный фильтр" на главную страницу...