Faryshta Yii2 Enum
, (*1)
Faryshta Yii2 Enum extension provides support for the ussage of enumarions in Yii2 models and forms., (*2)
Installation
The preferred way to install this extension is through composer. Check the composer.json for this extension's requirements and dependencies., (*3)
To install, either run, (*4)
$ php composer.phar require faryshta/yii2-enum "@dev"
or add, (*5)
"faryshta/yii2-enum": "@dev "
to the require
section of your composer.json
file., (*6)
Usage
EnumTrait
use faryshta\base\EnumTrait;
class Person extends \yii\base\Model
{
use EnumTrait;
public static function enums()
{
return [
// this is the name of the enum.
'gender' => [
// here it follows the `'index' => 'desc'` notation
'F' => 'Female',
'M' => 'Male',
],
];
}
// optional magic method to access the value quickly
public function getGenderDesc()
{
// method provided in the EnumTrait to get the description of the value
// of the attribute
return $this->getAttributeDesc('gender');
}
}
EnumValidator
use faryshta\base\EnumTrait;
use faryshta\validators\EnumValidator;
class Person extends \yii\base\Model
{
use EnumTrait;
public $gender;
public static function enums()
{
return [
// this is the name of the enum.
'gender' => [
// here it follows the `'index' => 'desc'` notation
'F' => 'Female',
'M' => 'Male',
],
];
}
public function rules()
{
return [
[
['gender'],
EnumValidator::className(),
// optional, if you want to use a diferent class than the
// class of the current model
// 'enumClass' => Person::className()
// optional, if you want to use a diferent enum name than the
// name of the attribute being validated
// 'enumName' => 'gender'
],
];
}
}
In a view file, (*7)
use faryshta\widgets\EnumDropdown;
use faryshta\widgets\EnumRadio;
/**
* @var Person $model
* @var ActiveForm $form
*/
// with ActiveForm
echo $form->field($person, 'gender')->widget(EnumDropdown::className());
// without ActiveForm and with model.
echo EnumDropdown::widget([
'model' => $person,
'attribute' => 'gender',
]);
// without Model
echo EnumDropdown::widget([
'name' => 'gender',
'enumClass' => Person::className(),
'enumName' => 'gender',
]);
// The same applies for the EnumRadio widget if you want to render a
// list of radio buttons
echo $form->field($person, 'gender')->widget(EnumRadio::className());
EnumColumn
In a view file, (*8)
use faryshta\data\EnumColumn;
use yii\widgets\GridView;
echo GridView::widget([
'searchModel' => $personSearch,
'dataProvider' => $personDataProvider,
'columns' => [
'class' => EnumColumn::className(),
'attribute' => 'gender',
// optional, if you want to use a diferent class than the
// class of the current model
// 'enumClass' => Person::className()
// optional, if you want to use a diferent enum name than the
// name of the attribute being validated
// 'enumName' => 'gender'
],
]);
License
Faryshta Yii2 Enum is released under the BSD 3-Clause License. See the bundled LICENSE.md
for details., (*9)