decodelabs / enumerable
Helper traits for enums
Installs: 1 391
Dependents: 3
Suggesters: 0
Security: 0
Stars: 1
Watchers: 2
Forks: 0
Open Issues: 0
Requires
- php: ^8.1
- decodelabs/coercion: ^0.2.9
- decodelabs/exceptional: ^0.4.5
Requires (Dev)
- decodelabs/phpstan-decodelabs: ^0.6.8
README
Helper traits for enums
Enumerable provides a simple structure of interfaces and traits to unlock the full power of PHP enums.
Get news and updates on the DecodeLabs blog.
Installation
Install via Composer:
composer require decodelabs/enumerable
Usage
Enumerable defines a powerful top level Enum interface that expands the range of functionality enums provide whilst consolidating the same functionality across both UnitEnum
and BackedEnum
types.
All Enumerable enums implement a type specific interface and use an accompanying trait. Each form dictates a type for a key
, value
and label
property, where the key is used as the index in lists and the label is used for display purposes.
Unit enums
Named UnitEnum
use DecodeLabs\Enumerable\Unit\Named; use DecodeLabs\Enumerable\Unit\NamedTrait; enum MyNamedUnitEnum implements Named { use NamedTrait; const OptionOne; const OptionTwo; const OptionThree; } MyNamedUnitEnum::OptionOne->getName(); // 'OptionOne' MyNamedUnitEnum::OptionOne->getKey(); // 'OptionOne' MyNamedUnitEnum::OptionOne->getLabel(); // 'Option One' MyNamedUnitEnum::OptionOne->getValue(); // 'OptionOne'
Indexed UnitEnum
use DecodeLabs\Enumerable\Unit\Indexed; use DecodeLabs\Enumerable\Unit\IndexedTrait; enum MyIndexedUnitEnum implements Indexed { use IndexedTrait; const OptionOne; const OptionTwo; const OptionThree; } MyNamedUnitEnum::OptionOne->getName(); // 'OptionOne' MyNamedUnitEnum::OptionOne->getKey(); // 0 MyNamedUnitEnum::OptionOne->getLabel(); // 'Option One' MyNamedUnitEnum::OptionOne->getValue(); // 'OptionOne'
Backed enums
Named String BackedEnum
use DecodeLabs\Enumerable\Backed\NamedString; use DecodeLabs\Enumerable\Backed\NamedStringTrait; enum MyNamedStringBackedEnum : string implements NamedString { use NamedStringTrait; const OptionOne = 'one'; const OptionTwo = 'two'; const OptionThree = 'three'; } MyNamedStringBackedEnum::OptionOne->getName(); // 'OptionOne' MyNamedStringBackedEnum::OptionOne->getKey(); // 'OptionOne' MyNamedStringBackedEnum::OptionOne->getLabel(); // 'Option One' MyNamedStringBackedEnum::OptionOne->getValue(); // 'one'
Labelled String BackedEnum
use DecodeLabs\Enumerable\Backed\LabelledString; use DecodeLabs\Enumerable\Backed\LabelledStringTrait; enum MyLabelledStringBackedEnum : string implements LabelledString { use LabelledStringTrait; const OptionOne = 'one'; const OptionTwo = 'two'; const OptionThree = 'three'; } MyLabelledStringBackedEnum::OptionOne->getName(); // 'OptionOne' MyLabelledStringBackedEnum::OptionOne->getKey(); // 'OptionOne' MyLabelledStringBackedEnum::OptionOne->getLabel(); // 'one' MyLabelledStringBackedEnum::OptionOne->getValue(); // 'one'
Value String BackedEnum
use DecodeLabs\Enumerable\Backed\ValueString; use DecodeLabs\Enumerable\Backed\ValueStringTrait; enum MyValueStringBackedEnum : string implements ValueString { use ValueStringTrait; const OptionOne = 'one'; const OptionTwo = 'two'; const OptionThree = 'three'; } MyValueStringBackedEnum::OptionOne->getName(); // 'OptionOne' MyValueStringBackedEnum::OptionOne->getKey(); // 'one' MyValueStringBackedEnum::OptionOne->getLabel(); // 'Option One' MyValueStringBackedEnum::OptionOne->getValue(); // 'one'
Named Int BackedEnum
use DecodeLabs\Enumerable\Backed\NamedInt; use DecodeLabs\Enumerable\Backed\NamedIntTrait; enum MyNamedIntBackedEnum : int implements NamedInt { use NamedIntTrait; const OptionOne = 1; const OptionTwo = 2; const OptionThree = 3; } MyNamedIntBackedEnum::OptionOne->getName(); // 'OptionOne' MyNamedIntBackedEnum::OptionOne->getKey(); // 'OptionOne' MyNamedIntBackedEnum::OptionOne->getLabel(); // 'Option One' MyNamedIntBackedEnum::OptionOne->getValue(); // 1
Value Int BackedEnum
use DecodeLabs\Enumerable\Backed\ValueInt; use DecodeLabs\Enumerable\Backed\ValueIntTrait; enum MyValueIntBackedEnum : int implements ValueInt { use ValueIntTrait; const OptionOne = 1; const OptionTwo = 2; const OptionThree = 3; } MyValueIntBackedEnum::OptionOne->getName(); // 'OptionOne' MyValueIntBackedEnum::OptionOne->getKey(); // 1 MyValueIntBackedEnum::OptionOne->getLabel(); // 'Option One' MyValueIntBackedEnum::OptionOne->getValue(); // 1
Instantiation
All enum types can be instantiaed with the following methods:
MyEnum::fromKey('<key>'); MyEnum::fromValue('<value>'); MyEnum::fromName('<name>'); MyEnum::fromIndex('<index>'); // or MyEnum::tryFromKey('<key>'); MyEnum::tryFromValue('<value>'); MyEnum::tryFromName('<name>'); MyEnum::tryFromIndex('<index>');
Lists
Enumerable provides three main ways of listing cases:
// Key to label map MyEnum::getOptions() => [ '<key>' => '<label>', ]; // Key to value map MyEnum::getValues() => [ '<key>' => '<value>', ]; // Alias to cases() MyEnum::getCases() => [ '<key>' => '[MyEnum::<name>]', ];
Licensing
Enumerable is licensed under the MIT License. See LICENSE for the full license text.