Yii2-field
С помощью данного модуля можно добавить поля для какой-то модели через веб-интерфейс и потом производить выборки по значению., (*1)
Типы полей на данный момент:, (*2)
- Text
- Numeric
- Date
- Textarea
- Select
- Radio
- Checkbox
- Image (в разработке)
Для select, radio, checkbox можно заранее задавать в настройках варианты., (*3)
Установка
Выполнить команду, (*4)
php composer require dvizh/yii2-field "@dev"
Или добавить в composer.json, (*5)
"dvizh/yii2-field": "@dev",
И выполнить, (*6)
php composer update
Далее, мигрируем базу:, (*7)
php yii migrate --migrationPath=vendor/dvizh/yii2-field/src/migrations
Подключение и настройка
В конфигурационный файл приложения добавить модуль field, настроив его, (*8)
'modules' => [
//...
'field' => [
'class' => 'dvizh\field\Module',
'relationModels' => [
'common\models\User' => 'Пользователи',
'dvizh\shop\models\Product' => 'Продукты',
],
'adminRoles' => ['administrator'],
],
//...
]
- relationModels - перечень моделей, к которым можно прикрепить поля
Все доступные CRUD для управления полями: ?r=field/defailt/index, (*9)
Для модели, с которой будут работать поля, добавить поведение:, (*10)
function behaviors() {
return [
'field' => [
'class' => 'dvizh\field\behaviors\AttachFields',
],
];
}
Чтобы иметь возможность также фильтровать результаты Find, подменяем Query в модели:, (*11)
public static function Find()
{
$return = new ProductQuery(get_called_class());
return $return;
}
В ProductQuery должно быть это поведение:, (*12)
function behaviors()
{
return [
'field' => [
'class' => 'dvizh\field\behaviors\Filtered',
],
];
}
Использование
Значение поля для модели вызывается через getField(), которому передается код поля., (*13)
echo $model->getField('field_name');
Выбрать все записи по значению значению поля:, (*14)
$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 (вставлять в админке, рядом с формой редактирования):, (*15)
<?=\dvizh\field\widgets\Choice::widget(['model' => $model]);?>
Вывести все поля модели со значениями:, (*16)
<?=dvizh\field\widgets\Show::widget(['model' => $model]);?>