Вывести минимальную цену самого дешевого торгового предложения

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

Если у товара несколько торговых предложений и у каждого предложения разные цены, иногда требуется вывести минимальную цену торговых предложений, отсортировав ее из всех торговых предложений. Можно воспользоваться API Битрикс обратившись к CCatalogSKU::GetInfoByProductIBlock

Сделать это просто, нужно добавить вот такой код в catalog.section:

$mxResult = CCatalogSKU::GetInfoByProductIBlock(
    $arParams['IBLOCK_ID']
);
if (is_array($mxResult)) {
    $rsOffers = CIBlockElement::GetList(
        array(
            "catalog_PRICE_1" => "ASC" // Сортируем по цене, ID нужной
        ),
        array(
            'IBLOCK_ID' => $mxResult['IBLOCK_ID'],
            'PROPERTY_' . $mxResult['SKU_PROPERTY_ID'] => $arElement["ID"]
        ),
        false,
        array(
            'nTopCount' => 1 // Получаем один элемент
        ),
        array(
            'ID'
        )
    );
    while ($arOffer = $rsOffers->Fetch()) {
        $ar_price = GetCatalogProductPrice($arOffer["ID"], 1);
        echo "

от " . $ar_price["PRICE"] . " руб.

"; break; } }
  • С помщью CCatalogSKU::GetInfoByProductIBlock получили информацию о инфоблоке торговых предложений, зная инфоблок торгового каталога (из параметра $arParams['IBLOCK_ID'])
  • Далее с помощью CIBlockElement::GetList получили список связанных с товаром торговых предложений: отсортировали его по возрастанию цены и ограничились одним (самым дешевым)
  • Вывели цену этого, одного, торгового предложения.

Усложненный вариант вывода:

Если нужно помимо минимальной стоимости показать еще и цены отдельных предложений, плюс дать возможность отправить заказ конкретного предложения в корзину. Можно использовать вот такой код:

 <?if(is_array($arElement["OFFERS"]) && !empty($arElement["OFFERS"])):?> 
 <!-- Показываем наименьшую для от --> 
 		<div class="pricebl"> 
 				<? 
 					$intIBlockID = 32; 
 					$mxResult = CCatalogSKU::GetInfoByProductIBlock( 
 					$intIBlockID 
 					); 
 					if (is_array($mxResult)) 
 						{ 
 							$rsOffers = CIBlockElement::GetList(array("PRICE"=>"ASC"),array('IBLOCK_ID' => $mxResult['IBLOCK_ID'], 'PROPERTY_'.$mxResult['SKU_PROPERTY_ID'] => $arElement["ID"])); 
 							while ($arOffer = $rsOffers->GetNext()) 
 								{ 
 									$ar_price = GetCatalogProductPrice($arOffer["ID"], 7); 
 									echo "<p>от " .$ar_price["PRICE"]. " руб.</p>" ; 
 									break; 
 								} 
 						} 
 			 ?> 
 		 </div> 
 <!-- Показываем предложения товаров --> 
 		<div class="offers"> 
 		<table class="offerstb" width="100%" cellspacing="0" cellpadding="0"> 
 				<?foreach($arElement["OFFERS"] as $arOffer):?> 
 					<tr> 
 					<?foreach($arOffer["PRICES"] as $code=>$arPrice):?> 
 						<?if($arPrice["CAN_ACCESS"]):?> 
 							<td><b><?=$arPrice["PRINT_VALUE"]?></b></td> 
 						<?endif;?> 
 					<?endforeach;?> 
 					<td width="100"><p>/ 
 					<?foreach($arOffer["DISPLAY_PROPERTIES"] as $pid=>$arProperty):?> 
 							<? 
 							if(is_array($arProperty["DISPLAY_VALUE"])) 
 								echo implode("&nbsp;/&nbsp;", $arProperty["DISPLAY_VALUE"]); 
 							else 
 								echo $arProperty["DISPLAY_VALUE"]; 
 							?> 
 						кг.</p> 
 					<?endforeach?> 
 					</td><td> 
 							<form action="<?=POST_FORM_ACTION_URI?>" method="post" enctype="multipart/form-data"> 
 								<input type="text" name="<?echo $arParams["PRODUCT_QUANTITY_VARIABLE"]?>" value="1" size="5" style="display:none;"> 
 								<input type="hidden" name="<?echo $arParams["ACTION_VARIABLE"]?>" value="BUY"> 
 								<input type="hidden" name="<?echo $arParams["PRODUCT_ID_VARIABLE"]?>" value="<?echo $arOffer["ID"]?>"> 
 								<input type="submit" name="<?echo $arParams["ACTION_VARIABLE"]."BUY"?>" value="Купить" style="display:none;"> 
 								<input type="submit" name="<?echo $arParams["ACTION_VARIABLE"]."ADD2BASKET"?>" value="В корзину"> 
 							</form> 
 					</td></tr> 
 				<?endforeach;?> 
 		</table> 
 		</div> 
 <?else:?><!-- Если у товара предложений вообще нет --> 
 	<?foreach($arElement["PRICES"] as $code=>$arPrice):?> 
 		<?if($arPrice["CAN_ACCESS"]):?> 
 			<div class="nooffers"> 
 			<?if($arPrice["DISCOUNT_VALUE"] < $arPrice["VALUE"]):?> 
 				<s><?=$arPrice["PRINT_VALUE"]?></s> <?=$arPrice["PRINT_DISCOUNT_VALUE"]?> 
 			<?else:?> 
 				<p><?=$arPrice["PRINT_VALUE"]?></p> 
 			<?endif;?> 
 			<noindex> 
 			     <a href="<?echo $arElement["ADD_URL"]?>" rel="nofollow">В корзину</a> 
 			</noindex> 
 			</div> 
 		<?endif;?> 
 	<?endforeach;?> 
 <?endif?> 

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

Шаблон списка элементов как у битрикс

И напоследок, модернизация данного решения до вида похожего на список элементов как в типовом шаблоне битрикс Одежда+, но более простого для чтения и внесения правок (на основе описанного выше метода). Суть в том, что вывод торговых предложений представлен в виде табов. Скачать

Выглядит вот так:

Михаил Базаров 14.06.2018
Цитата
Антон Сурнин написал:
Добрый день!
Подскажите пожалуйста как вывести цену и название.
Использую ред. Старт.
Цена хранится в созданом мной поле price.

В старте нет модуля sale (магазина). Если цена просто в свойстве, выводите как простое свойство- типа строка

<? echo $arResult['DISPLAY_PROPERTIES']['КОД_СВОЙСТВА']['~VALUE'];?>
Артур 08.08.2018
Добрый день, мы используем несколько видов цен,
подскажите пожалуйста как Вывести минимальную цену(тип цены Опт id=3) торговых предложений.
спс)
Михаил Базаров 08.08.2018
Цитата
Артур пишет:
$ar_price
Распечатайте массив $ar_price

Код
echo '<pre>'; 
print_r($ar_price); 
echo '</pre>'; 

Там увидите, в массиве, в каком параметре передается нужная цена
Вячеслав 19.07.2019
Михаил, насколько я понял ["SKU_PROPERTY_ID"] - это ID свойства привязки предложения к товару.
И соответственно выводится не минимальная цена СКУ, а цена у которого ID наименьший среди других. На моем примере это видно (см.скрин). https://yadi.sk/i/w1yKStmgcMKAUQ
Так как сделать сортировку именно по цене?
Михаил Базаров 19.07.2019
Цитата
Вячеслав пишет:
Михаил, насколько я понял ["SKU_PROPERTY_ID"] - это ID свойства привязки предложения к товару.
И соответственно выводится не минимальная цена СКУ, а цена у которого ID наименьший среди других. На моем примере это видно (см.скрин). https://yadi.sk/i/w1yKStmgcMKAUQ
Так как сделать сортировку именно по цене?
Вот это правило сортировки, должно вывести именно наименьшую цену
"PRICE"=>"ASC"
Вячеслав 22.07.2019
Разобрался.
В новой версии модуля catalog (начиная с версии 18.6.200) изменились поля.
Теперь для сортировки по цене нужно в getlist передавать параметр catalog_PRICE_типцены.
То-есть вместо "PRICE"=>"ASC" указываем "catalog_PRICE_1"=>"ASC".
https://dev.1c-bitrix.ru/learning/course/index.php?COURSE_ID=43&LESSON_ID=12183#iblock_18_6_200
В старой версии модуля будет работать старый метод.
Johnny Po 19.12.2019
Михаил спасибо за ваши статьи и помощь начинающим.

Как исключить неактивные торг. предложения ?
Johnny Po 19.12.2019
Цитата
Johnny Po написал:
Как исключить неактивные торг. предложения ?

разобрался сам,  добавил в фильтр   'ACTIVE' => 'Y'
Код
$mxResult['IBLOCK_ID'], 'ACTIVE' => 'Y', 'PROPERTY_'.$mxResult['SKU_PROPERTY_ID'] => $arItem["ID"])
Гость 15.07.2024
    Всё отлично!
   
   опечатка 1: "зная инфоблок торговго"
   опечатка 2: "отсортировали его по возрвстанию"
   опечатка 3: "этого, одного, торогового"
Михаил Базаров 15.07.2024
Еще сам 4 опечатки нашел  :)  
Спасибо

Блог-note: заметки разработчика

Вывести товары из того же раздела в карточке товара

Немножко топорный, но все же вполне действенный способ по выводу внутри подробной карточки товара, элементов того же раз...

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

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

XML в формате Commerce ML-2, города России и Мира, для выгрузки в инфоблок Битрикс

Подвернулась задачка, создать инфоблок для Битрикс, в котором будут просто города России и мира в виде элементов инфобло...

Получить и вывести данные из профиля покупателя в кабинете пользователя 1С-Битрикс

Задача: вывести пользователю информацию по всем, его, профилям покупателя в компоненте sale.personal.profile.list без пе...

Вывести множественное свойство типа файл с названием и весом файла в Битрикс

В этой заметке расскажу как красиво вывести множественное свойство типа файл в инфоблоке 1С-Битрикс. С показом оригиналь...

Получение доступа к железу устройства из Битрикс мобильное приложение

Документация к мобильному приложению 1С-Битрикс очень куцая. В основном описывает функционал добавляемый BXMobileApp. ...

Как подобрать редакцию Битрикс под задачи

Последнее время, все чаще, при общении с заказчиками, сталкиваюсь с вопросом "— Какая редакция 1С-Битрикс нужна дл...

Вывести свойство отдельно ото всех или исключить из всех

Иногда, на сайте, под управлением 1С-Битрикс, нужно вывести какое-то конкретное свойство отдельно ото всех, или вообще н...

Мобильные версии страниц и поисковые системы

Согласно требования поисковых систем: Яндекс и Google, в случае если у вашего сайта имеется мобильная версия, нужно увед...