1 | <?php |
||
10 | abstract class Enum |
||
11 | { |
||
12 | /** @var string */ |
||
13 | private $value; |
||
14 | |||
15 | /** @var array */ |
||
16 | private static $loaded = []; |
||
17 | |||
18 | /** @var array */ |
||
19 | protected static $values = []; |
||
20 | |||
21 | /** |
||
22 | * @param string $value |
||
23 | 6 | */ |
|
24 | public function __construct($value) |
||
29 | |||
30 | /** |
||
31 | * Return the enumerators values. |
||
32 | * |
||
33 | * @param bool $keys |
||
34 | * @return array |
||
35 | 24 | */ |
|
36 | public static function allValues($keys = false): array |
||
46 | |||
47 | /** |
||
48 | * Return a collection of the declared values. |
||
49 | * |
||
50 | * @param bool $keys |
||
51 | * @return Illuminate\Support\Collection |
||
52 | 3 | */ |
|
53 | public static function collect($keys = false): Collection |
||
57 | |||
58 | /** |
||
59 | * Return an instance of a desired value. |
||
60 | * |
||
61 | * @param string $value |
||
62 | * @return DavidIanBonner\Enumerated\Enum |
||
63 | 6 | */ |
|
64 | public static function ofType($value): self |
||
78 | |||
79 | /** |
||
80 | * Return the value. |
||
81 | * |
||
82 | * @return string |
||
83 | 3 | */ |
|
84 | public function value(): string |
||
88 | |||
89 | /** |
||
90 | * Validate the value. |
||
91 | * |
||
92 | * @param mixed $value |
||
93 | * @throws DavidIanBonner\Enumerated\EnumNotValidException |
||
94 | * @return void |
||
95 | 12 | */ |
|
96 | public static function validateValue($value) |
||
102 | |||
103 | /** |
||
104 | * Check the value is valid and return a bool. |
||
105 | * |
||
106 | * @param mixed $value |
||
107 | * @return bool |
||
108 | 3 | */ |
|
109 | public static function isValid($value): bool |
||
119 | |||
120 | /** |
||
121 | * Get the declared constants. |
||
122 | * |
||
123 | * @return array |
||
124 | 6 | */ |
|
125 | protected static function getDeclaredConstants(): array |
||
131 | |||
132 | /** |
||
133 | * @return array |
||
134 | */ |
||
135 | public static function toSelect(): array |
||
136 | { |
||
137 | return static::collect() |
||
138 | ->mapWithKeys(function ($key) { |
||
139 | $outcome = self::ofType($key); |
||
140 | |||
141 | return [$outcome->value() => $outcome->line()]; |
||
142 | }) |
||
143 | ->toArray(); |
||
144 | } |
||
145 | |||
146 | /** |
||
147 | * @return string |
||
148 | */ |
||
149 | public function line(): string |
||
150 | { |
||
151 | $vendor = $this->vendor() ?: null; |
||
152 | |||
153 | return Lang::get( |
||
154 | ($vendor ? $vendor.'::' : '').'enum.'.$this->langKey().'.'.str_replace('_', '-', $this->value()) |
||
155 | ); |
||
156 | } |
||
157 | |||
158 | public abstract function langKey(): string; |
||
159 | |||
160 | public function vendor() |
||
161 | {} |
||
162 | } |
||
163 |