Tinkerwell - The PHP Scratchpad

Laravel Enum

bensampo/laravel-enum image

Laravel Enum stats

Downloads
8M
Stars
1,909
Open Issues
5
Forks
158

View on GitHub →

Simple, extensible and powerful enumeration implementation for Laravel.

Laravel Enum Package Summary

Laravel Enum simplifies the use of enumerations in Laravel applications. Authored by Ben Sampson, it enhances the enum utility with a variety of powerful features tailored for the Laravel framework.

Key Features:

  • Simple Enum Classes: Define enums with key-value pairs as class constants.
  • Comprehensive Methods: Includes a full suite of methods to manipulate and query enum instances.
  • Instantiation and Safety: Enums can be instantiated safely, ensuring values are always valid.
  • Flagged/Bitwise Enums: Support for enums that can hold multiple values simultaneously.
  • Attribute Casting: Automatically cast model attributes to enum instances.
  • Validation Rules: Custom validation rules to ensure input adheres to defined enums.
  • Localization: Support for localizing enum descriptions.
  • Artisan Support: Generate enums via Artisan commands and more.
  • Extendability: Can be extended using Laravel's native macro capabilities.

Installation:

Laravel Enum requires PHP 8 and Laravel 9 or 10. Install it using Composer:

composer require bensampo/laravel-enum

Usage:

Create enums using Artisan:

php artisan make:enum UserType

Define enum values directly in the class:

final class UserType extends Enum {
const Administrator = 0;
const Moderator = 1;
const Subscriber = 2;
}

Enums can be instantiated in various ways, including by key, value, or even using static methods:

$admin = UserType::Administrator();

Advanced Features:

  • Bitwise Enums: Useful for sets of permissions, where multiple enum values can be relevant simultaneously.
  • PHPStan and Laravel Nova Integration: Supports static analysis and integration with Laravel Nova.
  • Migration to Native PHP Enums: Guidance on migrating to native PHP enums (PHP 8.1+).

Migrations and Model Integration:

Easily define how enums interact with your database and Eloquent models, including custom casts for model attributes and straightforward migration recommendations.

Localization and Customization:

Localize enum descriptions and customize response outputs easily, enhancing readability and internationalization.

Developer Tools:

Includes a range of Artisan commands to streamline tasks like annotation, conversion to native enums, and more.

This package is ideal for developers looking to utilize enums in a Laravel project, providing robust tools and methods to manage enum values effectively.

BenSampo photo

Full-stack web developer.

Cube

Laravel Newsletter

Join 40k+ other developers and never miss out on new tips, tutorials, and more.


Bensampo Laravel Enum Related Articles

Cache Without Overlapping in Laravel 12.47.0 image

Cache Without Overlapping in Laravel 12.47.0

Read article
Laravel 12.45.1, 12.45.2, and 12.46.0 Released image

Laravel 12.45.1, 12.45.2, and 12.46.0 Released

Read article
A new beta of Laravel Wayfinder just dropped image

A new beta of Laravel Wayfinder just dropped

Read article
JSON:API Resource in Laravel 12.45 image

JSON:API Resource in Laravel 12.45

Read article
Laravel 12.43 Released image

Laravel 12.43 Released

Read article
Translatable Enums image

Translatable Enums

Read article
Laravel Cloud logo

Laravel Cloud

Easily create and manage your servers and deploy your Laravel applications in seconds.

Laravel Cloud
SaaSykit: Laravel SaaS Starter Kit logo

SaaSykit: Laravel SaaS Starter Kit

SaaSykit is a Multi-tenant Laravel SaaS Starter Kit that comes with all features required to run a modern SaaS. Payments, Beautiful Checkout, Admin Panel, User dashboard, Auth, Ready Components, Stats, Blog, Docs and more.

SaaSykit: Laravel SaaS Starter Kit
PhpStorm logo

PhpStorm

The go-to PHP IDE with extensive out-of-the-box support for Laravel and its ecosystem.

PhpStorm
Get expert guidance in a few days with a Laravel code review logo

Get expert guidance in a few days with a Laravel code review

Expert code review! Get clear, practical feedback from two Laravel devs with 10+ years of experience helping teams build better apps.

Get expert guidance in a few days with a Laravel code review
Harpoon: Next generation time tracking and invoicing logo

Harpoon: Next generation time tracking and invoicing

The next generation time-tracking and billing software that helps your agency plan and forecast a profitable future.

Harpoon: Next generation time tracking and invoicing
Bacancy logo

Bacancy

Supercharge your project with a seasoned Laravel developer with 4-6 years of experience for just $3200/month. Get 160 hours of dedicated expertise & a risk-free 15-day trial. Schedule a call now!

Bacancy