denismitr / enum
PHP Enum
v1.0
2020-09-04 21:10 UTC
Requires
- php: ^7.2
- ext-json: *
Requires (Dev)
- phpunit/phpunit: ^8.0
This package is auto-updated.
Last update: 2024-11-05 06:12:08 UTC
README
Install
composer require denismitr/enum
Examples
Create your enum
use Denismitr\Enum\Enum; /** * @method static OrderStatus PENDING * @method static OrderStatus COMPLETED * @method static OrderStatus CANCELED * @method static OrderStatus BEING_DELIVERED * * @method bool isPending() * @method bool isCompleted() * @method bool isCanceled() * @method bool isBeingDelivered() */ class OrderStatus extends Enum { protected static function states(): array { return [ 'PENDING' => 1, 'COMPLETED' => 2, 'CANCELED' => 3, 'BEING_DELIVERED' => 4, ]; } }
Instantiate and use it
$pending = OrderStatus::PENDING(); $this->assertInstanceOf(OrderStatus::class, $pending); $this->assertEquals(1, $pending->value()); $this->assertEquals('PENDING', $pending->key()); $this->assertTrue($pending->isPending()); $this->assertFalse($pending->isCanceled());
Instantiate from key
$beingDelivered = OrderStatus::fromKey('BEING_DELIVERED');
Instantiate from key
$completed = OrderStatus::fromValue(2);
Enumerate all
OrderStatus::enumerate(); // [ // 'PENDING' => 1, // 'COMPLETED' => 2, // 'CANCELED' => 3, // 'BEING_DELIVERED' => 4, // ];
Validate values and keys
OrderStatus::isValidKey('PENDING'); // true OrderStatus::isValidValue(1); // true OrderStatus::isValidKey('FOO'); // false OrderStatus::isValidValue(5); // false
Extract keys or values
// all keys OrderStatus::keys(); // ['PENDING', 'COMPLETED', 'CANCELED', 'BEING_DELIVERED'] // all keys except except PENDING and CANCELED OrderStatus::keys(OrderStatus::PENDING(), OrderStatus::CANCELED()); // ['COMPLETED', 'BEING_DELIVERED'] // all values OrderStatus::values(); // [1,2,3,4] // all values except PENDING and CANCELED OrderStatus::values(OrderStatus::PENDING(), OrderStatus::CANCELED()); // [2,4]
Non associative states
/** * @method static IOTA PENDING * @method static IOTA READY * @method static IOTA FAILED * * @method bool isPending() * @method bool isReady() * @method bool isFailed() */ class Iota extends Enum { protected static function states(): array { return ['PENDING', 'READY', 'FAILED']; } } $ready = Iota::READY(); $this->assertEquals(1, $ready->value()); $this->assertEquals('READY', $ready->key()); $pending = Iota::PENDING(); $this->assertEquals(0, $pending->value()); $this->assertEquals('PENDING', $pending->key()); $failed = Iota::FAILED(); $this->assertEquals(2, $failed->value()); $this->assertEquals('FAILED', $failed->key()); $this->assertEquals([ 'PENDING' => 0, 'READY' => 1, 'FAILED' => 2, ], Iota::enumerate());