rawnoq / laravel-enum
A comprehensive Laravel package for working with PHP Enums, providing casting, validation, translation, query scopes, and more
Installs: 38
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 0
Open Issues: 0
pkg:composer/rawnoq/laravel-enum
Requires
- php: ^8.2
- illuminate/database: ^11.0|^12.0
- illuminate/support: ^11.0|^12.0
- illuminate/validation: ^11.0|^12.0
Requires (Dev)
- laravel/pint: ^1.0
- orchestra/testbench: ^10.0|^11.0
- phpunit/phpunit: ^11.0
This package is not auto-updated.
Last update: 2025-12-14 07:35:54 UTC
README
A comprehensive Laravel package for working with PHP Enums, providing casting, validation, translation, query scopes, and more.
Features
- ✅ Enum Helpers: Useful methods for working with enums (
values(),names(),random(),fromValue(), etc.) - ✅ Eloquent Casting: Automatic enum casting in Eloquent models
- ✅ Validation Rules: Built-in validation rules for enum values
- ✅ Translation Support: Easy translation of enum labels
- ✅ Query Scopes: Helper scopes for filtering by enum values
- ✅ Type Safety: Full type safety with PHP 8.2+ backed enums
Installation
composer require rawnoq/laravel-enum
Configuration
Publish the config file:
php artisan vendor:publish --tag=enum-config
Usage
Basic Enum with Helpers
use Rawnoq\Enum\Concerns\HasEnumHelpers; enum UserStatus: string { use HasEnumHelpers; case Active = 'active'; case Inactive = 'inactive'; case Pending = 'pending'; } // Get all values UserStatus::values(); // ['active', 'inactive', 'pending'] // Get random case UserStatus::random(); // UserStatus::Active (random) // Get by value UserStatus::fromValue('active'); // UserStatus::Active // Check if value exists UserStatus::hasValue('active'); // true // Get as array UserStatus::toArray(); // ['active' => 'Active', 'inactive' => 'Inactive', ...]
Eloquent Model Casting
use Rawnoq\Enum\Casts\EnumCast; class User extends Model { protected $casts = [ 'status' => EnumCast::class.':'.UserStatus::class, ]; } // Usage $user = User::find(1); $user->status; // UserStatus::Active (enum instance) $user->status = UserStatus::Inactive; // Automatically casts to 'inactive'
Validation
use Rawnoq\Enum\Rules\EnumRule; $request->validate([ 'status' => ['required', new EnumRule(UserStatus::class)], ]);
Translation Support
use Rawnoq\Enum\Concerns\HasEnumTranslation; enum UserStatus: string { use HasEnumTranslation; case Active = 'active'; case Inactive = 'inactive'; } // In your language file (lang/en/enums.php): return [ 'user_status' => [ 'active' => 'Active', 'inactive' => 'Inactive', ], ]; // Usage UserStatus::Active->label(); // 'Active' UserStatus::labels(); // ['active' => 'Active', 'inactive' => 'Inactive']
Query Scopes
use Rawnoq\Enum\Concerns\HasEnumScopes; class User extends Model { use HasEnumScopes; } // Usage User::whereEnum('status', UserStatus::Active)->get(); User::whereEnumIn('status', [UserStatus::Active, UserStatus::Pending])->get(); User::whereEnumNotIn('status', [UserStatus::Inactive])->get();
Helper Facade
use Rawnoq\Enum\Facades\Enum; Enum::isValid(UserStatus::class, 'active'); // true Enum::fromValueOr(UserStatus::class, 'active', UserStatus::Pending); // UserStatus::Active Enum::valuesAsString(UserStatus::class); // 'active, inactive, pending'
Advanced Usage
Combining Multiple Traits
use Rawnoq\Enum\Concerns\HasEnumHelpers; use Rawnoq\Enum\Concerns\HasEnumTranslation; enum UserStatus: string { use HasEnumHelpers, HasEnumTranslation; case Active = 'active'; case Inactive = 'inactive'; case Pending = 'pending'; }
Custom Translation Namespace
enum UserStatus: string { use HasEnumTranslation; case Active = 'active'; public static function translationNamespace(): string { return 'custom.namespace'; } }
Filtering and Mapping
// Filter enum cases $activeCases = UserStatus::filter(fn($case) => $case->value !== 'inactive'); // Map enum cases $labels = UserStatus::map(fn($case) => $case->label());
API Reference
HasEnumHelpers Methods
values()- Get all enum valuesnames()- Get all enum namesfromValue($value)- Get enum by value (nullable)fromValueOrFail($value)- Get enum by value (throws exception)random()- Get random enum casetoArray()- Convert to associative arrayoptions()- Get options for select/dropdownhasValue($value)- Check if value existshasName($name)- Check if name existsfirst()- Get first enum caselast()- Get last enum casefilter($callback)- Filter enum casesmap($callback)- Map enum cases
HasEnumTranslation Methods
label()- Get translated label for current caselabelFor($locale)- Get translated label for specific localelabels()- Get all translated labelslabelsFor($locale)- Get all translated labels for localetranslationKey($case)- Get translation key for casetranslationNamespace()- Get translation namespacetranslationKeyFormat()- Get translation key format
HasEnumScopes Methods (for Models)
whereEnum($column, $value)- Filter by enum valuewhereEnumIn($column, $values)- Filter by multiple enum valueswhereEnumNotIn($column, $values)- Exclude enum values
Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
License
MIT