necrox87 / yii2-custom-field
yii2-custom-field add fields to your model
Installs: 11
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 4
Type:yii2-extension
Requires
- php: >=5.4.0
- 2amigos/yii2-grid-view-library: *
- asofter/yii2-imperavi-redactor: ^0.0.3
- kartik-v/yii2-grid: *
- kartik-v/yii2-widget-select2: *
- yiisoft/yii2: *
- yiisoft/yii2-bootstrap: *
- zelenin/yii2-slug-behavior: ~1.5.1
Requires (Dev)
This package is auto-updated.
Last update: 2024-11-19 20:48:53 UTC
README
Fork of package dvizh/yii2-field
С помощью данного модуля можно добавить поля для какой-то модели через веб-интерфейс и потом производить выборки по значению.
Типы полей на данный момент:
- Text
- Numeric
- Date
- Textarea
- Select
- Radio
- Checkbox
- Image (в разработке)
Для select, radio, checkbox можно заранее задавать в настройках варианты.
Установка
Выполнить команду
php composer require dvizh/yii2-field "@dev"
Или добавить в composer.json
"dvizh/yii2-field": "@dev",
И выполнить
php composer update
Далее, мигрируем базу:
php yii migrate --migrationPath=vendor/dvizh/yii2-field/src/migrations
Подключение и настройка
В конфигурационный файл приложения добавить модуль field, настроив его
'modules' => [ //... 'field' => [ 'class' => 'dvizh\field\Module', 'relationModels' => [ 'common\models\User' => 'Пользователи', 'dvizh\shop\models\Product' => 'Продукты', ], 'adminRoles' => ['administrator'], ], //... ]
- relationModels - перечень моделей, к которым можно прикрепить поля
Все доступные CRUD для управления полями: ?r=field/defailt/index
Для модели, с которой будут работать поля, добавить поведение:
function behaviors() { return [ 'field' => [ 'class' => 'dvizh\field\behaviors\AttachFields', ], ]; }
Чтобы иметь возможность также фильтровать результаты Find, подменяем Query в модели:
public static function Find() { $return = new ProductQuery(get_called_class()); return $return; }
В ProductQuery должно быть это поведение:
function behaviors() { return [ 'field' => [ 'class' => 'dvizh\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, '<')->all(); //Все записи с power<100
Виджеты
Блок выбора значений для для полей модели $model (вставлять в админке, рядом с формой редактирования):
<?=\dvizh\field\widgets\Choice::widget(['model' => $model]);?>
Вывести все поля модели со значениями:
<?=dvizh\field\widgets\Show::widget(['model' => $model]);?>