Получить и вывести все цены товара в 1С-Битрикс

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

Задача: получить и вывести все цены товара по его ID в каталоге 1С-Битрикс (например, в детальной карточке catalog.element), независимо от того, разрешен ли просмотр цены конкретной группе пользователей.

Получить и вывести все цены товара в 1С-Битрикс

Для получения всех цен товара в Битрикс вы можете использовать метод GetList класса \Bitrix\Catalog\PriceTable.

Использования метода PriceTable::getList

Наиболее правильным способом получения этих данных является использование файла result_modifier.php и дозаполнение массива $arResult.

$allProductPrices = \Bitrix\Catalog\PriceTable::getList([
    "select" => ["*"],
    "filter" => [
        "=PRODUCT_ID" => $arResult['ID'],
    ],
])->fetchAll();

foreach ($allProductPrices as $allProductPrice) {
    $arResult['ALL_PRICES'][] = $allProductPrice;
}

В этом примере мы передаем ID товара в фильтр и получаем список всех цен для этого товара. Затем мы перебираем результаты и добавляем их в массив $arResult['ALL_PRICES'].

Массив $arResult['ALL_PRICES'] будет содержать все данные о ценах, которые можно использовать в шаблоне.

Использование метода CPrice::GetList

use Bitrix\Catalog\PriceTable;

$prices = \CPrice::GetList([], [
    'PRODUCT_ID' => $arResult['ID']
]);

while ($price = $prices->Fetch()) {
    $arResult['ALL_PRICES'][] = $price;
}

В этом примере используется класс CPrice и метод GetList, в котором передается фильтр по PRODUCT_ID для получения цен, связанных с определенным товаром. Затем, аналогично первому примеру, мы добавляем полученные цены в массив $arResult['ALL_PRICES'].

Сравнение двух типов цен для иммитации системы скидок

Исходя из этих примеров, можно реализовать имитацию системы скидок, фактически не создавая скидок. Пример:

// result_modifier.php =======================
$allProductPrices = \Bitrix\Catalog\PriceTable::getList([
    "select" => [
    	"PRICE" // Нужна только цена
    ],
    "filter" => [
        "=PRODUCT_ID" => $arResult['ID'],
    ],
    "order" => [
            "PRICE" => "DESC" // Сортируем по уменьшению цены
    ]
])->fetchAll();

foreach ($allProductPrices as $allProductPrice) {
    $arResult['ALL_PRICES'][] = $allProductPrice;
}

// template.php ===============================
// Старая зачеркнутая цена
echo $arResult['ALL_PRICES']['0']['PRICE'];

// Цена покупки
echo $arResult['ALL_PRICES']['1']['PRICE'];

// Расчет процента (для вывода в лейбле, можно округлить с float)
echo $arResult['ALL_PRICES']['1']['PRICE'] * 100 / $arResult['ALL_PRICES']['0']['PRICE'];

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

Гость 10.09.2024
чет братан ты попутался в тексте. проверь код и заголовки еще раз
Гость 10.09.2024
и GetCatalogProductPriceList - функция является устаревшей
Михаил Базаров 11.09.2024
Чот да, братан, не уследил.
Раньше заметка была с использованием старого метода, код освежил, а заголовки с абзацами продинамил.
Поправил все.
Спс что заметил и написал

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

Основные функции вывода в шаблонах Битрикс

Знаю, что все их знают. Но иногда не бывает лишним собрать все самое используемое в одну кучку. Ведь у каждого бывают мо...

Input Type File, множественный с дропзоной и показом превью

Задача: Сделать возможность загрузки файлов в множественный input type="file" c помощью drag&drop и показом превью загру...

Увидеть файл заказов который передаст Битрикс в 1С

Для диагностики обмена заказов, интернет-магазина на 1С Битрикс с 1С Управление Торговлей, нужно увидеть xml файл с зака...

Работа с HTTP-запросами в Bitrix: Обзор возможностей класса \Bitrix\Main\HttpRequest

Класс \Bitrix\Main\HttpRequest, является наследником класса Request, представляет собой мощный инструмент для работы с д...

AJAX корзина с отправкой количества из раздела каталога

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

Вывести артикул в печатную форму бланка заказа

Задача: в печатную форму бланка заказа добавить артикулы товаров и данные о пользователе.

Ajax форма обратной связи, реализация в битрикс

Иногда, на сайте требуется создать форму обратной связи, которая будет писать все данные в инфоблок. Способов реализации...

Получить и вывести все цены товара в 1С-Битрикс

Задача: получить и вывести все цены товара по его ID в каталоге 1С-Битрикс (например, в детальной карточке catalog.e...

Сортировка элементов по индексу сортировки значений типа список

Внутри любого компонента есть заранее заложенные поля для сортировки элементов. Можно сортировать элементы в разных напр...