dvizh / yii2-cart
yii2-cart it's a simple cart module to collect application models, that implement cart interface + widgets
This package's canonical repository appears to be gone and the package has been frozen as a result.
Installs: 4 458
Dependents: 2
Suggesters: 0
Security: 0
Stars: 21
Watchers: 7
Forks: 10
Open Issues: 9
Type:yii2-extension
Requires
- php: >=5.4.0
- yiisoft/yii2: *
- yiisoft/yii2-bootstrap: *
This package is not auto-updated.
Last update: 2024-10-04 22:30:29 UTC
README
Это модуль корзины для Yii2 фреймворка. Позволяет добавить в корзину любую модель, имплементирующую интерфейс dvizh\cart\interfaces\CartElement
Для добавления функционала заказа можно использовать этот модуль: dvizh/yii2-order.
Установка
Выполнить команду
php composer require dvizh/yii2-cart "@dev"
Или добавить в секцию require composer.json
"dvizh/yii2-cart": "@dev",
И выполнить
php composer update
Далее, мигрируем базу:
php yii migrate --migrationPath=vendor/dvizh/yii2-cart/src/migrations
Подключение и настройка
В конфигурационный файл приложения добавить компонент cart
'components' => [ 'cart' => [ 'class' => 'dvizh\cart\Cart', 'currency' => 'р.', //Валюта 'currencyPosition' => 'after', //after или before (позиция значка валюты относительно цены) 'priceFormat' => [2,'.', ''], //Форма цены ], //... ]
И модуль (если хотите использовать виджеты)
'modules' => [ 'cart' => [ 'class' => 'dvizh\cart\Module', ], //... ]
Использование
Можно добавлять в корзину элементы самостоятельно через компонент, а можно использовать готовые виджеты. Пример эктиона, добавляющего товар в корзину:
//use... class ProductController extends Controller { public function actionAddToCart($id) { //Любая модель $model = $this->findModel($id); //Кладем ее в корзину (в количестве 1, без опций) $cartElement = yii::$app->cart->put($model, 1, []); } }
Положить в корзину можно любую модель, имплемементирующую интерфейс CartElement. Пример модели:
//... class Product extends ActiveRecord implements \dvizh\cart\interfaces\CartElement { //.. public function getCartId() { return $this->id; } public function getCartName() { return $this->name; } public function getCartPrice() { return $this->price; } //Опции продукта для выбора при добавлении в корзину public function getCartOptions() { return [ '1' => [ 'name' => 'Цвет', 'variants' => ['1' => 'Красный', '2' => 'Белый', '3' => 'Синий'], ], '2' => [ 'name' => 'Размер', 'variants' => ['4' => 'XL', '5' => 'XS', '6' => 'XXL'], ] ]; } //.. }
Получить элементы корзины:
//... $elements = yii::$app->cart->elements;
Виджеты
В состав модуля входит несколько виджетов. Все работают аяксом.
<?php use dvizh\cart\widgets\BuyButton; use dvizh\cart\widgets\TruncateButton; use dvizh\cart\widgets\CartInformer; use dvizh\cart\widgets\ElementsList; use dvizh\cart\widgets\DeleteButton; use dvizh\cart\widgets\ChangeCount; use dvizh\cart\widgets\ChangeOptions; ?> <?php /* Выведет кнопку покупки */ ?> <?= BuyButton::widget([ 'model' => $model, 'text' => 'Заказать', 'htmlTag' => 'a', 'cssClass' => 'custom_class' ]) ?> <?php /* Выведет количество товаров и сумму заказа */ ?> <?= CartInformer::widget(['htmlTag' => 'a', 'offerUrl' => '/?r=cart', 'text' => '{c} на {p}']); ?> <?php /* Выведет кнопку очистки корзины */ ?> <?= TruncateButton::widget(); ?> <?php /* Выведет корзину с выпадающими или обычными ('type' => ElementsList::TYPE_FULL) элементами списка. Можно передать перечень дополнительных полей через otherFields (['Остаток' => 'amount']). */ ?> <?=ElementsList::widget(['type' => ElementsList::TYPE_DROPDOWN]);?> <?php /* Выведет кнопку удаления элемента */ ?> <?=DeleteButton::widget(['model' => $item]);?> <?php /* Виджеты ниже позволят выбрать кол-во или опции элемента. Можно передать как модель элемента корзины, так и сам продукт, когда он еще не стал элементом. */ ?> <?=ChangeCount::widget(['model' => $item]);?> <?php /* У ChangeOptions можно изменить вид ('type' => ChangeOptions::TYPE_RADIO) */ ?> <?=ChangeOptions::widget(['model' => $item]);?>
Скидки
Скидки реализуются через поведение и(или) событие. Корзине можно присвоить любое поведение (в конфиге):
'cart' => [ 'class' => 'dvizh\cart\Cart', //... 'as discount' => [ 'class' => 'dvizh\cart\behaviors\Discount', 'percent' => 50, ], ],
Поведение цепляется к событию EVENT_CART_COST и задает скидку (см. dvizh\cart\behaviors\Discount).
Можно подцепиться напрямую к событию:
'cart' => [ 'class' => 'dvizh\cart\Cart', //... 'on cart_cost' => function($event) { $event->cost = ($event->cost*50)/100; } ],
События
Все события корзины:
- EVENT_CART_COST - изменение общей цены
- EVENT_CART_COUNT - изменение количества
- EVENT_CART_TRUNCATE - очищение корзины
- EVENT_CART_PUT - добавление элемента
- EVENT_ELEMENT_COST - изменение цены элемента
- EVENT_ELEMENT_ROUNDING - округление цены элемента