From 89e45c96fe64bb09dcae3d3b62f2fe0ed2b4fee4 Mon Sep 17 00:00:00 2001 From: SadElephant Date: Mon, 18 Sep 2023 10:28:17 +0300 Subject: [PATCH] Example for Enum --- docs/en/docs/field.md | 154 ++++++++++++++++++++++++++++++++++++++++++ docs/ru/docs/field.md | 153 ++++++++++++++++++++++++++++++++++++++++- 2 files changed, 306 insertions(+), 1 deletion(-) diff --git a/docs/en/docs/field.md b/docs/en/docs/field.md index dfe1eee6a..cd6d3bef3 100644 --- a/docs/en/docs/field.md +++ b/docs/en/docs/field.md @@ -278,6 +278,36 @@ Select::make('user') This will use the `uuid` field as the key for each option, rather than the default primary key. +Enum as source: + +```php +namespace App\Casts; + +enum Type: string +{ + case General = 'general'; + case Account = 'account'; + case SecurityAndPrivacy = 'security-and-privacy'; + + /** + * @return string + */ + public function title(): string + { + return match ($this) { + Type::General => __('types.general.title'), + Type::Account => __('types.account.title'), + Type::SecurityAndPrivacy => __('types.security-and-privacy.title'), + }; + } +} +``` + +```php +Select::make('type') + ->fromEnum(Type::class); +``` + If you want to provide an option that represents an unselected state, you can use the `empty()` method: ```php @@ -317,6 +347,63 @@ Select::make('type') ]); ``` + +Enum Casting +```php +namespace App\Models; + +use Illuminate\Database\Eloquent\Model; +use App\Casts\Type; + +class Question extends Model +{ + + /** + * The attributes that should be cast. + * + * @var array + */ + protected $casts = [ + 'type' => Type::class, + ]; +} +```` + +Screen +````php +use App\Casts\Type; +use App\Models\Question; + +public function query(Question $question): array +{ + return [ + 'question' => $question, + ]; +} + + +public function types(): array +{ + return collect(Type::cases()) + ->mapWithKeys( fn ( Type $type ) => [ $type->value => $type->title() ] ) + ->all(); +} +```` + +Usage: +```php +Select::make('question.type') + ->fromEnum(Type::class); +``` + +Or: + +````php +Select::make('question.type') + ->options($this->types()) + ->title('Тип'), +```` + ## Relation @@ -427,6 +514,73 @@ Relation::make('users.') ->title('Select users'); ``` +Enum Casting +```php +namespace App\Models; + +use Illuminate\Database\Eloquent\Model; +use App\Casts\Type; + +class Section extends Model +{ + + /** + * The attributes that should be cast. + * + * @var array + */ + protected $casts = [ + 'type' => Type::class, + ]; +} +```` + +```php +namespace App\Models; + +use Illuminate\Database\Eloquent\Model; +use App\Casts\Type; + +class Question extends Model +{ + + /** + * The attributes that should be cast. + * + * @var array + */ + protected $casts = [ + 'type' => Type::class, + ]; +} +```` + +Screen +````php +use App\Casts\Type; +use App\Models\Question; + +public function query(Question $question): array +{ + return [ + 'question' => $question, + ]; +} +```` + +Usage: +```php +Relation::make('question.section') + ->fromModel(Section::class, 'type') + +``` + +```php +Relation::make('question.type') + ->fromModel(Section::class, 'type', 'type') + +``` + ## DateTime diff --git a/docs/ru/docs/field.md b/docs/ru/docs/field.md index add609d61..fe4e50487 100644 --- a/docs/ru/docs/field.md +++ b/docs/ru/docs/field.md @@ -239,6 +239,37 @@ Select::make('user') ->fromModel(User::class, 'email', 'uuid'); ``` +Enum в качестве источника: + +```php +namespace App\Casts; + +enum Type: string +{ + case General = 'general'; + case Account = 'account'; + case SecurityAndPrivacy = 'security-and-privacy'; + + /** + * @return string + */ + public function title(): string + { + return match ($this) { + Type::General => __('types.general.title'), + Type::Account => __('types.account.title'), + Type::SecurityAndPrivacy => __('types.security-and-privacy.title'), + }; + } +} +``` + +```php +Select::make('type') + ->fromEnum(Type::class); +``` + + Возможны ситуации, когда необходимо добавить некоторое значение, которое означает, что поле не выбрано. Для этого можно использовать метод `empty`: @@ -270,8 +301,62 @@ Select::make('user') ]); ``` -## Relation +Enum Casting +```php +namespace App\Models; + +use Illuminate\Database\Eloquent\Model; +use App\Casts\Type; + +class Question extends Model +{ + + /** + * The attributes that should be cast. + * + * @var array + */ + protected $casts = [ + 'type' => Type::class, + ]; +} +```` + +В экране +````php +use App\Casts\Type; +use App\Models\Question; + +public function query(Question $question): array +{ + return [ + 'question' => $question, + ]; +} + + +public function types(): array +{ + return collect(Type::cases()) + ->mapWithKeys( fn ( Type $type ) => [ $type->value => $type->title() ] ) + ->all(); +} +```` +Использование: +```php +Select::make('question.type') + ->fromEnum(Type::class); +``` +Или + +````php +Select::make('question.type') + ->options($this->types()) + ->title('Тип'), +```` + +## Relation Поля отношения могут подгружать динамические данные, это хорошее решение, если вам нужны связи. @@ -315,6 +400,7 @@ class Idea extends Model } ``` + ```php Relation::make('idea') ->fromModel(Idea::class, 'name') @@ -376,6 +462,71 @@ Relation::make('users.') ->title('Select users'); ``` +Enum Casting +```php +namespace App\Models; + +use Illuminate\Database\Eloquent\Model; +use App\Casts\Type; + +class Section extends Model +{ + + /** + * The attributes that should be cast. + * + * @var array + */ + protected $casts = [ + 'type' => Type::class, + ]; +} +```` +```php +namespace App\Models; + +use Illuminate\Database\Eloquent\Model; +use App\Casts\Type; + +class Question extends Model +{ + + /** + * The attributes that should be cast. + * + * @var array + */ + protected $casts = [ + 'type' => Type::class, + ]; +} +```` + +В экране +````php +use App\Casts\Type; +use App\Models\Question; + +public function query(Question $question): array +{ + return [ + 'question' => $question, + ]; +} +```` + +Использование: +```php +Relation::make('question.section') + ->fromModel(Section::class, 'type') + +``` + +```php +Relation::make('question.type') + ->fromModel(Section::class, 'type', 'type') + +``` ## DateTime