Разработка модуля с 24.04.2017 ведется здесь: dvizh/yii2-order. Рекомендую устанавливать модуль из репозитория Dvizh, именно там находится последняя версия.
Это модуль для реализации функцинала заказа на сайте. Сейчас в заказ попадают элементы корзины, советую в качестве сервиса корзины использовать модуль pistol88/yii2-cart.
Функционал:
- Добавление заказа, просмотр и управление заказами в админке
- Управление полями заказа в админке
- Управление способами доставки и оплаты в админке
Выполнить команду
php composer require pistol88/yii2-order "*"
Или добавить в composer.json
"pistol88/yii2-order": "*",
И выполнить
php composer update
Далее, мигрируем базу:
php yii migrate --migrationPath=vendor/pistol88/yii2-order/migrations
Далее, связываем модуль с корзиной. Устанавливаем pistol88/yii2-cart и добавляем в начало конфига вашего приложения:
yii::$container->set('pistol88\order\interfaces\Cart', 'pistol88\order\drivers\Pistol88Cart');
Чтобы связать модуль с другой корзиной:
yii::$container->set('pistol88\order\interfaces\Cart', 'app\objects\Cart');
app\objects\Cart должен содержать класс, имплементирующий \pistol88\order\interfaces\Cart.
Если Вы планируете вносить множество измененией в код, лучшей практикой будет установить расширение как модуль.
Клонируете с Github расширение в нужную папку:
git clone https://github.com/pistol88/yii2-order.git
В composer.json добавляете путь до модуля:
"autoload": {
"psr-4": {
"pistol88\\order\\": "common/modules/order"
}
}
Запускаете update:
php composer update
Делаете миграции:
php yii migrate --migrationPath=common/modules/order/migrations
Добавляете в конфиг:
'bootstrap' => ['pistol88\order\Bootstrap'],
Связываете с корзиной, как описано выше.
В конфигурационный файл приложения добавить модуль order
'modules' => [
'order' => [
'class' => 'pistol88\order\Module',
'layoutPath' => 'frontend\views\layouts',
'successUrl' => '/page/thanks', //Страница, куда попадает пользователь после успешного заказа
'ordersEmail' => '[email protected]', //Мыло для отправки заказов
],
//...
]
Все настройки модуля:
-
orderStatuses - статусы (по умолчанию: 'new' => 'Новый', 'approve' => 'Подтвержден', 'cancel' => 'Отменен', 'process' => 'В обработке', 'done' => 'Выполнен')
-
defaultStatus - статус нового заказа (по умолчанию 'new')
-
successUrl - урл, куда будет перенаправлен покупатель в случае успешной покупки (по умолчанию /order/info/thanks/)
-
ordersEmail - почта администратора, туда уходят письма с заказами
-
robotEmail - e-mail робота (по умолчанию no-reply@localhost)
-
robotName - имя почтового робота (по умолчанию Robot)
-
orderColumns - массмв полей для вывода. Кастомные поля добавляются как массив, содержащий ID и наименование поля: ['field' => 2, 'label' => 'Автомобиль']
-
dateFormat - формат даты (по умолчанию d.m.Y H:i:s)
-
cartService - имя компонента, в которой реализована корзина (по умолчанию cart). Интерфейс смотреть в pistol88/yii2-cart.
-
currency - валюта, по умолчанию рубли
-
currencyPosition - позиция значка валюты относительно цены (before или after)
-
priceFormat - формат цены (по умолчанию [2, '.', ''])
-
adminRoles - список ролей, которые имеют доступ в CRUD заказа (по умолчанию ['admin', 'superadmin'])
Модуль автоматически инжектит в yii2 (в Service locator) компонент order (сервис), который доступен глобально через yii::$app->order и предоставляет следующие сервисы:
- get($id) - получить заказ по ID
- getStatInMoth($month) - получить статистику заказов за месяц
- getStatByDate($date) - получить статичтику заказов за день
- getStatByDatePeriod($dateStart, $dateStop) - получить статистику заказов за период
- getStatByModelAndDatePeriod($model, $dateStart, $dateStop) - получить статистику заказов определенной модели за период
За вывод формы заказа отвечает виджет pistol88\order\widgets\OrderForm
<?=OrderForm::widget();?>
Кнопка "заказ в один клик" - pistol88\order\widgets\OneClick:
<?=OneClick::widget(['model' => $model]);?>
В Module:
- create - создание заказа
- delete_order - удаление заказа
- delete_element - удаление элемента заказа
Пример использования через конфиг:
'order' => [
'class' => 'pistol88\order\Module',
'on create' => function($event) {
send_sms(...); //Отправляем СМС оповещение
},
],
Чтобы добавить способ оплаты, перейдите в ?r=/order/payment-type/index, добавьте новый способ, где в поле "Виджет" укажите класс виджета, который будет отдавать форму оплаты. Виджеты оплаты устанавливаются отдельно.
- Paymaster.ru: pistol88/yii2-paymaster
- Liqpay: pistol88/yii2-liqpay
- Сбербанк: pistol88/yii2-sberbank-payment
Форма заказа Главная панель Поиск по заказам Статистика Добавление заказа