PHPackages                             pistol88/yii2-field - 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-field

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

pistol88/yii2-field
===================

yii2-field add fields to your model

15931[1 issues](https://github.com/pistol88/yii2-field/issues)1PHP

Since Apr 24Pushed 9y ago3 watchersCompare

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

READMEChangelogDependenciesVersions (1)Used By (1)

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

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

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

Yii2-field
==========

[](#yii2-field)

С помощью данного модуля можно добавить поля для какой-то модели через веб-интерфейс и потом производить выборки по значению.

Типы полей на данный момент:

- Text
- Numeric
- Date
- Textarea
- Select
- Radio
- Checkbox
- Image (в разработке)

Для select, radio, checkbox можно заранее задавать в настройках варианты.

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

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

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

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

```

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

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

```

И выполнить

```
php composer update

```

Далее, мигрируем базу:

```
php yii migrate --migrationPath=vendor/pistol88/yii2-field/migrations

```

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

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

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

```
    'modules' => [
        //...
        'field' => [
            'class' => 'pistol88\field\Module',
            'relationModels' => [
                'common\models\User' => 'Пользователи',
                'pistol88\shop\models\Product' => 'Продукты',
            ],
            'adminRoles' => ['administrator'],
        ],
        //...
    ]
```

- relationModels - перечень моделей, к которым можно прикрепить поля

Все доступные CRUD для управления полями: ?r=field/defailt/index

Для модели, с которой будут работать поля, добавить поведение:

```
    function behaviors() {
        return [
            'field' => [
                'class' => 'pistol88\field\behaviors\AttachFields',
            ],
        ];
    }
```

Чтобы иметь возможность также фильтровать результаты Find, подменяем Query в модели:

```
    public static function Find()
    {
        $return = new ProductQuery(get_called_class());
        return $return;
    }
```

В ProductQuery должно быть это поведение:

```
    function behaviors()
    {
       return [
           'field' => [
               'class' => 'pistol88\field\behaviors\Filtered',
           ],
       ];
    }
```

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

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

Значение поля для модели вызывается через getField(), которому передается код поля.

```
echo $model->getField('field_name');
```

Выбрать все записи по значению значению поля:

```
$productsFind = Product::find()->field('power', 100)->all(); //Все записи с power=100
$productsFind = Product::find()->field('power', 100, '>')->all(); //Все записи с power>100
$productsFind = Product::find()->field('power', 100, '
