princejohnsantillan / reflect
Clearer API for PHP Attributes and Reflection.
Installs: 4 786
Dependents: 0
Suggesters: 0
Security: 0
Stars: 15
Watchers: 1
Forks: 0
Open Issues: 2
Requires
- php: ^8.1
Requires (Dev)
- laravel/pint: ^1.17
- pestphp/pest: ^3.1
- phpstan/phpstan: ^1.12
- rector/rector: ^1.2
- spatie/ray: ^1.41
README
Requirement
PHP 8.1 or higher
Installation
composer require princejohnsantillan/reflect
Example
BEFORE:
enum Plan: string{ case FREE = 'free'; case HOBBY = 'hobby'; case PRO = 'professional'; case TEAM = 'team'; case ENTERPRISE = 'enterprise'; public function price(): int { return match($this){ static::FREE => 0, static::HOBBY => 10, static::PRO => 20, static::TEAM => 50, static::ENTERPRISE = 200 }; } public function color(): string { return match($this){ static::FREE => 'yellow', static::HOBBY => 'orange', static::PRO => 'blue', static::TEAM => 'silver', static::ENTERPRISE = 'gold' }; } }
AFTER:
use PrinceJohn\Reflect\Traits\HasEnumTarget; #[Attribute(Attribute::TARGET_CLASS_CONSTANT)] class Price{ use HasEnumTarget; public function __construct(public int $price) {} }
use PrinceJohn\Reflect\Traits\HasEnumTarget; #[Attribute(Attribute::TARGET_CLASS_CONSTANT)] class Color{ use HasEnumTarget; public function __construct(public string $color) {} }
use PrinceJohn\Reflect\Enum\Reflect; enum Plan: string{ #[Price(0)] #[Color('yellow')] case FREE = 'free'; #[Price(10)] #[Color('orange')] case HOBBY = 'hobby'; #[Price(20)] #[Color('blue')] case PRO = 'professional'; #[Price(50)] #[Color('silver')] case TEAM = 'team'; #[Price(200)] #[Color('gold')] case ENTERPRISE = 'enterprise'; public function price(): int { // Demonstrating usage via the Reflect class return Reflect::on($this) ->getAttributeInstance(Price::class) ->price; } public function color(): string { // Demonstrating usage via the HasEnumTarget trait return Color::onEnum($this)->color; } }
Note
Alternatively, just return the attribute class, that way you can have more functionality at your disposal.