PHPackages                             pistol88/yii2-promocode - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [Utility &amp; Helpers](/categories/utility)
4. /
5. pistol88/yii2-promocode

ActiveYii2-extension[Utility &amp; Helpers](/categories/utility)

pistol88/yii2-promocode
=======================

Добавление функционала промокодов (купонов) на сайт, работает с pistol88/cart и pistol88/order

55471PHP

Since Mar 10Pushed 9y ago5 watchersCompare

[ Source](https://github.com/pistol88/yii2-promocode)[ Packagist](https://packagist.org/packages/pistol88/yii2-promocode)[ RSS](/packages/pistol88-yii2-promocode/feed)WikiDiscussions master Synced 2mo ago

READMEChangelogDependenciesVersions (2)Used By (0)

Внимание!
=========

[](#внимание)

Разработка модуля с 24.04.2017 ведется здесь: [dvizh/yii2-promocode](https://github.com/dvizh/yii2-promocode). Рекомендую устанавливать модуль из репозиторий Dvizh, именно там находится последняя версия.

Yii2-promocode
==============

[](#yii2-promocode)

Добавление функционала скидок (промокодов, купонов) на сайт, стабильно работает с [pistol88/cart](http://github.com/pistol88/yii2-cart).

Модуль умеет через Behavior динамически менять цену заказа, исходя из вида примененного купона: накопительный, "процент скидки", "сумма скидки".

Установка
---------

[](#установка)

Выполнить команду

```
php composer require pistol88/yii2-promocode "*"

```

Или добавить в composer.json

```
"pistol88/yii2-promocode": "*",

```

И выполнить

```
php composer update

```

Миграция:

php yii migrate --migrationPath=vendor/pistol88/yii2-promocode/migrations

Подключение и настройка
-----------------------

[](#подключение-и-настройка)

В конфигурационный файл приложения добавить модуль promocode

В targetModelList указать модели для привязки промокода

```
    'modules' => [
        //..
        'promocode' => [
            'class' => 'pistol88\promocode\Module',
            'informer' => 'pistol88\cart\widgets\CartInformer', // namespace to custom cartInformer widget
            'informerSettings' => [], //settings for custom cartInformer widget
            'usesModel' => 'dektrium\user\models\User', //Модель пользователей
            //Указываем модели, к которым будем привязывать промокод
            'targetModelList' => [
                'Категории' => [
                    'model' => 'pistol88\service\models\Category',
                    'searchModel' => 'pistol88\service\models\category\CategorySearch'
                ],
                'Продукты' => [
                    'model' => 'pistol88\shop\models\Product',
                    'searchModel' => 'pistol88\shop\models\product\ProductSearch'
                ],
            ],
        ],
        //..
    ]

```

Использование
-------------

[](#использование)

Чтобы управлять промокодами, нужно перейти к контроллеру модуля: ?r=promocode/promo-code

Добавление промокода для текущего пользователя:

```
yii::$app->promocode->enter($promocode);

```

Очистить текущий промокод пользователя:

```
yii::$app->promocode->clear()

```

Проверить, введен ли промокод:

```
if(yii::$app->promocode->has())

```

Получить текущий промокод:

```
yii::$app->promocode->getCode()

```

Получить процент скидки текущий:

```
$persent = yii::$app->promocode->get()->promocode->discount;

```

Чтобы скидка применялась для [pistol88/cart](http://github.com/pistol88/yii2-cart), необходимо добавить поведение pistol88\\promocode\\behaviors\\Discount для cart при подключении cart в конфиге:

```
    'cart' => [
        'class' => 'pistol88\cart\Cart',
        'as PromoDiscount' => ['class' => 'pistol88\promocode\behaviors\Discount'],
    ]

```

Чтобы скидка применялась для отдельных моделей необходимо добавить поведение pistol88\\promocode\\behaviors\\DiscountToElement для cart при подключении компонента в конфиге:

```
    'cart' => [
        'class' => 'pistol88\cart\Cart',
        //'as PromoDiscount' => ['class' => 'pistol88\promocode\behaviors\Discount'],
        'as ElementDiscount' => ['class' => 'pistol88\promocode\behaviors\DiscountToElement'],
    ]

```

Виджеты
-------

[](#виджеты)

Вывод формы ввода промокода для пользователя:

Целую, пока!

###  Health Score

25

—

LowBetter than 37% of packages

Maintenance20

Infrequent updates — may be unmaintained

Popularity18

Limited adoption so far

Community13

Small or concentrated contributor base

Maturity43

Maturing project, gaining track record

 Bus Factor1

Top contributor holds 54.5% of commits — single point of failure

How is this calculated?**Maintenance (25%)** — Last commit recency, latest release date, and issue-to-star ratio. Uses a 2-year decay window.

**Popularity (30%)** — Total and monthly downloads, GitHub stars, and forks. Logarithmic scaling prevents top-heavy scores.

**Community (15%)** — Contributors, dependents, forks, watchers, and maintainers. Measures real ecosystem engagement.

**Maturity (30%)** — Project age, version count, PHP version support, and release stability.

### Community

Maintainers

![](https://www.gravatar.com/avatar/30aa23b0866557cfaf8fba075bde99f331f4cc0c4eae50b37af0fe78b2c862b6?d=identicon)[pistol88](/maintainers/pistol88)

---

Top Contributors

[![pistol88](https://avatars.githubusercontent.com/u/8104605?v=4)](https://github.com/pistol88 "pistol88 (36 commits)")[![usesgraphcrt](https://avatars.githubusercontent.com/u/17561572?v=4)](https://github.com/usesgraphcrt "usesgraphcrt (28 commits)")[![halumein](https://avatars.githubusercontent.com/u/5361342?v=4)](https://github.com/halumein "halumein (2 commits)")

### Embed Badge

![Health badge](/badges/pistol88-yii2-promocode/health.svg)

```
[![Health](https://phpackages.com/badges/pistol88-yii2-promocode/health.svg)](https://phpackages.com/packages/pistol88-yii2-promocode)
```

###  Alternatives

[antares/accessible

PHP library that allows you to define your class' getters, setters and constructor with docblock annotations.

123.9k1](/packages/antares-accessible)

PHPackages © 2026

[Directory](/)[Categories](/categories)[Trending](/trending)[Changelog](/changelog)[Analyze](/analyze)
