Задача: пользователи магазина могу наполнять корзины, но не доходить до оформления заказа. Такие корзины считаются брошенными. Но, пользователь может вернуться к оформлению через несколько дней и некоторые товары (ранее добавленные в корзину) могут быть сняты с продажи. Однако, такую корзину все равно можно оформить. Нужно автоматически удалить не доступные товары из корзины.
Очистка корзины с помощью API 1С-Битрикс
Все просто: когда пользователь заходит в корзину, нужно запустить скрипт, который пройдется по всем товарам в корзине и удалит недоступные (снятые с продажи, отсутствующие и.т.д.).
В шаблоне корзины находим файл mutator.php и где-нибудь сверху добавляем код:
foreach ($arResult['BASKET_ITEM_RENDER_DATA'] as $basketItem) {
if ($basketItem['NOT_AVAILABLE'] == 1) {
CSaleBasket::Delete($basketItem['ID']);
}
}
Проходимся по всем товарам добавленным в корзину. И если у товара присутсвует ключ ['NOT_AVAILABLE'] (будет равен единице), значит этот товар не доступен и удаляем его методом CSaleBasket::Delete
Не доступные товары удаляться сразу, при открытии пользователем, страницы с корзиной, он даже не заметит что что-то пропало.