Рекомендуемые товары opencart списком рядом с кнопкой купить на Opencart

Платформа: Opencart 3.0

 class=

DEMO

http://t.joypass.ru/index.php?route=product/category&path=24

Video

Идея реализации

Воспользуемся стандартным функционалом рекомендуемых товаров. В карточке товара админ-панели есть вкладка «связи». Перейти и найти блок

 class=

Все привязанные здесь товары будут загружаться в выпадающий список. Необходимые условия. У товара поле количество должно содержать значение >1, заполнена цена и заполнено описание следующим образом:

 class=
три текстовых блока с обязательным разделителем >

Бекенд

Модель

В файл catalogmodelcatalogproduct.php добавил два метода для получения данных о рекомендуемых товаров

	public function getProductRelatedForChoice($product_id) {
		$product_data = array();
		$query = $this->db->query("SELECT * FROM " . DB_PREFIX . "product_related pr LEFT JOIN " . DB_PREFIX . "product p ON (pr.related_id = p.product_id) LEFT JOIN " . DB_PREFIX . "product_to_store p2s ON (p.product_id = p2s.product_id) WHERE pr.product_id = '" . (int)$product_id . "' AND p.date_available <= NOW() AND p.quantity>0 AND p2s.store_id = '" . (int)$this->config->get('config_store_id') . "'");
		foreach ($query->rows as $result) {
			$product_data[$result['related_id']] = $this->getProductForChoice($result['related_id']);
		}
		return $product_data;
	}
	public function getProductForChoice($product_id) {
		$query = $this->db->query("SELECT DISTINCT * FROM " . DB_PREFIX . "product p LEFT JOIN " . DB_PREFIX . "product_description pd ON (p.product_id = pd.product_id) WHERE p.product_id = '" . (int)$product_id . "' AND pd.language_id = '" . (int)$this->config->get('config_language_id') . "'");
		$result = $query->row;
		$result['price'] = number_format($result['price'],0,'',' ').' р.';
		$descitems = explode('>',strip_tags(html_entity_decode($result['description'])));
 
		$result['type'] =isset($descitems[2]) ?$descitems[2]:'';
		$result['time'] =isset($descitems[1]) ?$descitems[1]:'';
		$result['data'] =isset($descitems[0]) ?$descitems[0]:'';
		return $result;
	}

Контроллер

В файле catalogcontrollerproductcategory.php добавил немного кода для обращения к методу, добавленному выше.

$prelated_info  = $this->model_catalog_product->getProductRelatedForChoice($result['product_id']);

Получаемые данные вкладываем в массив товаров

            $data['products'][] = array(
                /*mycode_>*/'prelated_info'  => $prelated_info,/*<_mycode*/

Лицевая часть (вьюшка на twig)

В файл catalogviewthemedefaulttemplateproductcategory.twig добавляю код визуализации

Стили

<style type="text/css">
	.fm-module-price-choice {
		background-color: #A82682;
		height: 100%;
		text-align: center;
	}
	.fm-module-price-choice,.fm-product-btn-choice {
		position: relative;
		z-index: 99;
	}
	.fm-module-price-choice.__hidden{
		display: none;
	}
	.fm-module-price-choice.unfolded{
	    margin-bottom: 10px;
	    width: 260px;
	    cursor:pointer;
	    flex-direction: column;
	    height: 50px;
		display: flex;
	    flex-wrap: wrap;
	    padding: 5px 0;
	}
	.fm-module-price-choice.unfolded .type img {
		display: none;
	}
	.block-pricies
	{
		position: absolute;
		top: 69px;
		left: -15px;
		z-index:99;
	}
	.fm-module-price-choice.available .block-time,.fm-module-price-choice.available .block-data,
	.fm-module-price-choice.unavailable .block-time,.fm-module-price-choice.unavailable .block-data{
		display: none;
	}
	.fm-category-product-caption>.row>.jp-pr-price>.fm-product-btn-choice {
		width: 47% !important;
	    font-size: 14px !important;
	}
	.product-choice{
		width: 50%;
	    color: #fff;
	    z-index: 99;
	}
	.overlay-choice {
	   z-index:3; 
	   position:fixed; 
	   background-color:#000; 
	   opacity:0.4; 
	   -moz-opacity:0.4; 
	   filter:alpha(opacity=40);
	   width:100%;
	   height:100%;
	   top:0;
	   left:0;
	   cursor:pointer;
	   display:none;
	}
	.fm-module-price-choice.available {
	    cursor:pointer;
	}
	.fm-module-price-choice.available .type img,
	.fm-module-price-choice.unavailable .type img {
	    cursor:pointer;
	    width: 12%;
	    margin: 2px;
	}
	.fm-module-price-choice.unfolded .type img {
		display: none;
	}
/*	.fm-module-price-choice {
	    border-radius: 5px;
	}*/
	.fm-module-price-choice.available .type-text,
	.fm-module-price-choice.unavailable .type-text
	{
	    white-space: nowrap;
	    width: 80%;
	    overflow: hidden;
	    margin: 0 auto;
	    display: inline-flex;
	}
	.fm-category-btn-box.jp-pr-price {
		display: flex;
	}
	.fm-category-btn-box.jp-pr-price > div,.fm-category-btn-box.jp-pr-price > button {
		margin: 2px;
	}
</style>

Javascript

<script type="text/javascript">
	$(document).ready(function() {
		$(document).on('click','.overlay-choice',function() {
			closeChoice($(this));
		});
		$(document).on('click','.fm-module-price-choice.available',function() {
			if($(this).parent().find('.unfolded').length>0){			
				closeChoice($(this));
				return;
			}
			$(this).parent().find('.fm-module-price-choice').removeClass('__hidden').addClass('unfolded');
			$(this).removeClass('unfolded')
			$(this).closest('.fm-module-item').css({'z-index':100});
			$('.overlay-choice').fadeIn(400);
		});
		$(document).on('click','.fm-module-price-choice.unfolded',function() {
			$(this).parent().parent().find('.fm-module-price-choice.available').html($(this).html()).data('relproduct-id',$(this).data('relproduct-id'));
			closeChoice($(this));
		});
		$(document).on('click','.fm-product-btn',function() {
			cart.add($(this).parent().find('.product-choice .available').data('relproduct-id'),1);
		});
		function closeChoice(element) {
			element.parent().find('.fm-module-price-choice.unfolded').removeClass('unfolded').addClass('__hidden');
			element.closest('.fm-module-item').css({'z-index':''});
			$('.overlay-choice').fadeOut(400);
		}
	});
</script>

Html

<div class="product-choice pro-{{product.product_id}}">
										{% set breakLoop = false %}
										{% for relaitem_begin in product.prelated_info if breakLoop == false %}
											<div data-product-id="{{product.product_id}}" data-relproduct-id="{{relaitem_begin.product_id}}" class="fm-module-price-choice available">{{relaitem_begin.price}}
												<div class="type"><div class="type-text">{{relaitem_begin.type}}</div><img src=""></div>
												<div class="block-data">{{relaitem_begin.data}}</div>
												<div class="block-time">{{relaitem_begin.time}}</div>
											</div>
											{% set breakLoop = true %}
										{% endfor %}
											<div class="overlay-choice"></div>
												<div class="block-pricies">
								               	{% for relaitem in product.prelated_info %}
														<div data-product-id="{{product.product_id}}" data-relproduct-id="{{relaitem.product_id}}" class="fm-module-price-choice __hidden">{{relaitem.price}}
															<div class="block-time">{{relaitem.time}}</div>
															<div class="block-data">{{relaitem.data}}</div>
															<div class="type"><div class="type-text">{{relaitem.type}}</div><img src=""></div>
														</div>
								               	{% endfor %}
								                </div>
								             </div>
							                <button type="button" class="fm-product-btn fm-product-btn-choice"><span>КУПИТЬ</span></button>

пометки: подложка кликов, условный цикл twig, img base64, fadein, fadeout, closest поиск предка

guest
0 комментариев
Межтекстовые Отзывы
Посмотреть все комментарии

СТАТЬИ БЛОГА ПО РУБРИКЕ И МЕТКАМ

img

Какие включить доп. функции в плитку тегов

1. добавление тегов с автоподстановкой* через админку

*автоподстановкой названий товаров/категорий

см.видео

2. вывод плитки в любом месте шаблона через селекторы html(class или id)

см.видео

пояснения

подробная инструкция

3. замена дизайна плитки тегов с «карусели»(базовый дизайн) на «таблетки»

скрин (декстопная версия)

скрин (мобильная версия)


3а. замена изначального дизайна на «квадраты»

живой пример

скрины


3b. замена изначального дизайна на цепочку с кнопкой

живой пример

скрины


3c. замена изначального дизайна на дизайн с табами

скрин

живой пример_1

живой пример_2 (с картинками у тегов)

живой_пример_3 (с кнопкой <показать все>)


4. функция «упорядочивание тегов по полкам на витрине».

Подойдёт тем, у кого на одной странице очень много тегов и их нужно как-то упорядочить.

см.скриншот(декстоп)

см.скриншот(смартфон)

видео

живой пример

4а.Вывод плиток тегов в нескольких областях сразу

скриншот

инструкция

5. функция «отобразить плитку во всех товарах категории».

Допустим, у вас в магазине есть категория, в которой 500 товаров, а вам требуется добавить одну и туже плитку тегов в каждом из них. Если подключена данная функция, то достаточно добавить в эксель-файл для импорта только 1 строку и теги появятся на 500 страницах.


5_a. расширение функции №5 на подкатегории.


6. вывод плитки в листинге товаров

см.скрин

7. мультиязычность

с данной функцией отпадает необходимость создавать плитки под каждый язык отдельно

скриншот

8. Самостоятельный генератор тегов из товаров

см.статью


10. выгрузка всех тегов с сайта в эксель-файл

11. добавление тегов непосредственно в админке товара или категории

скрин

инструкция

12. Формирование посадочных страниц  к опциям/атрибутам стандартного фильтра

у страниц стандартного фильтра товаров появится ЧПУ(SEO URL), мета-теги (keywords,description), title (заголовок страницы) и h1.

видео


13. Ранжирование тегов по популярности

Какие включить доп. функции в плитку тегов

1. добавление тегов с автоподстановкой* через админку

*автоподстановкой названий товаров/категорий

см.видео

2. вывод плитки в любом месте шаблона через селекторы html(class или id)

см.видео

пояснения

подробная инструкция

3. замена дизайна плитки тегов с "карусели"(базовый дизайн) на "таблетки"

скрин (декстопная версия)

скрин (мобильная версия)


3а. замена изначального дизайна на "квадраты"

живой пример

скрины


3b. замена изначального дизайна на цепочку с кнопкой

живой пример

скрины


3c. замена изначального дизайна на дизайн с табами

скрин

живой пример_1

живой пример_2 (с картинками у тегов)

живой_пример_3 (с кнопкой <показать все>)


4. функция "упорядочивание тегов по полкам на витрине".

Подойдёт тем, у кого на одной странице очень много тегов и их нужно как-то упорядочить.

см.скриншот(декстоп)

см.скриншот(смартфон)

видео

живой пример

4а.Вывод плиток тегов в нескольких областях сразу

скриншот

инструкция

5. функция "отобразить плитку во всех товарах категории".

Допустим, у вас в магазине есть категория, в которой 500 товаров, а вам требуется добавить одну и туже плитку тегов в каждом из них. Если подключена данная функция, то достаточно добавить в эксель-файл для импорта только 1 строку и теги появятся на 500 страницах.


5_a. расширение функции №5 на подкатегории.


6. вывод плитки в листинге товаров

см.скрин

7. мультиязычность

с данной функцией отпадает необходимость создавать плитки под каждый язык отдельно

скриншот

8. Самостоятельный генератор тегов из товаров

см.статью


10. выгрузка всех тегов с сайта в эксель-файл

11. добавление тегов непосредственно в админке товара или категории

скрин

инструкция

12. Формирование посадочных страниц  к опциям/атрибутам стандартного фильтра

у страниц стандартного фильтра товаров появится ЧПУ(SEO URL), мета-теги (keywords,description), title (заголовок страницы) и h1.

видео


13. Ранжирование тегов по популярности

img

Создание мульти склада в opencart и получение остатков из 1С

  • Реализована возможность работать с несколькими складами в Opencart. Общий остаток товара складывается из остатков на складах.
  • Реализована передача остатков в интернет-магазин (ИМ) из выгрузки 1С.
  • Реализован вывод остатков по складам в карточке товара.

II. Подробное описание модуля

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

— если на «складе 1» товара нет, но на основном складе этот товар есть (или есть на складе 2), то в карточке на витрине будет показываться статус ожидание 1 день
— если нигде товара нет, то в карточке — статус нет в наличии
— если на выбранном складе товара менее Х штук, то статус — мало. (значение Х доступно для корректировки из админ-панели)

2. В модуле опенкарта реализована возможность добавлять/убирать склады и корректировать их настройки.  Чтобы работало обновление остатков из 1С, в настройках модуля требуется складам присвоить GUID из 1с.

3. Списание остатков производится в зависимости от способа доставки в заказе. Например, если выбрана курьерская доставка, то списание товара начнётся с основного склада, продолжится со склада 1 (при отсутствии на основном), далее со склада 2. Если в методе доставки заказа выбран самовывоз со склада 1 или со склада 2, то вначале списание произойдет с выбранного склада, затем с основного склада, и далее с последнего склада, где остались остатки. Приоритеты списания остатков настраиваются в админ-панели модуля.

Создание мульти склада в opencart и получение остатков из 1С

  • Реализована возможность работать с несколькими складами в Opencart. Общий остаток товара складывается из остатков на складах.
  • Реализована передача остатков в интернет-магазин (ИМ) из выгрузки 1С.
  • Реализован вывод остатков по складам в карточке товара.

II. Подробное описание модуля

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

-- если на "складе 1" товара нет, но на основном складе этот товар есть (или есть на складе 2), то в карточке на витрине будет показываться статус ожидание 1 день
-- если нигде товара нет, то в карточке - статус нет в наличии
-- если на выбранном складе товара менее Х штук, то статус - мало. (значение Х доступно для корректировки из админ-панели)

2. В модуле опенкарта реализована возможность добавлять/убирать склады и корректировать их настройки.  Чтобы работало обновление остатков из 1С, в настройках модуля требуется складам присвоить GUID из 1с.

3. Списание остатков производится в зависимости от способа доставки в заказе. Например, если выбрана курьерская доставка, то списание товара начнётся с основного склада, продолжится со склада 1 (при отсутствии на основном), далее со склада 2. Если в методе доставки заказа выбран самовывоз со склада 1 или со склада 2, то вначале списание произойдет с выбранного склада, затем с основного склада, и далее с последнего склада, где остались остатки. Приоритеты списания остатков настраиваются в админ-панели модуля.

img

Переход на https в opencart wordpress

Для wordpress

https://zen.yandex.ru/media/id/5b4ae96b3d0e9500a9a853c7/podkliuchenie-besplatnogo-sslsertifikata-na-hostinge-timeweb-5b5eb4e09bef9e00a82f7564

Для нулевых сайтов на opencart

Переход на https в opencart wordpress

Для wordpress https://zen.yandex.ru/media/id/5b4ae96b3d0e9500a9a853c7/podkliuchenie-besplatnogo-sslsertifikata-na-hostinge-timeweb-5b5eb4e09bef9e00a82f7564 Для нулевых сайтов на opencart
img

Переход на https в opencart wordpress

Для wordpress

https://zen.yandex.ru/media/id/5b4ae96b3d0e9500a9a853c7/podkliuchenie-besplatnogo-sslsertifikata-na-hostinge-timeweb-5b5eb4e09bef9e00a82f7564

Для нулевых сайтов на opencart

Переход на https в opencart wordpress

Для wordpress https://zen.yandex.ru/media/id/5b4ae96b3d0e9500a9a853c7/podkliuchenie-besplatnogo-sslsertifikata-na-hostinge-timeweb-5b5eb4e09bef9e00a82f7564 Для нулевых сайтов на opencart
img

Как наполнить opencart 2.3 fake-заказами

Подключиться к БД другого интернет-магазина и выкачать оттуда заказы с помощью запроса С помощью хранимой процедуры актуализируем заказы, на одну дату по пять заказов Если получились заказы из будущего, то запросом delete удаляем лишнии, в […]

Как наполнить opencart 2.3 fake-заказами

Подключиться к БД другого интернет-магазина и выкачать оттуда заказы с помощью запроса С помощью хранимой процедуры актуализируем заказы, на одну дату по пять заказов Если получились заказы из будущего, то запросом delete удаляем лишнии, в […]
img

Создание pdf с деталями заказа в письме клиенту. Opencart

Сделано в OPENCART 2.3. Скачать библиотеку, зайти в папку с ней через консоль команд и выполнить команды git clone https://github.com/dompdf/dompdf.git cd dompdf git clone https://github.com/PhenX/php-font-lib.git lib/php-font-lib cd lib/php-font-libgit checkout 0.5.1 cd .. git clone https://github.com/PhenX/php-svg-lib.git […]

Создание pdf с деталями заказа в письме клиенту. Opencart

Сделано в OPENCART 2.3. Скачать библиотеку, зайти в папку с ней через консоль команд и выполнить команды git clone https://github.com/dompdf/dompdf.git cd dompdf git clone https://github.com/PhenX/php-font-lib.git lib/php-font-lib cd lib/php-font-libgit checkout 0.5.1 cd .. git clone https://github.com/PhenX/php-svg-lib.git […]
0
Оставьте комментарий! Напишите, что думаете по поводу статьи.x