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

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

Queue-Wide Inspection Methods in Laravel 13.8.0 image

Queue-Wide Inspection Methods in Laravel 13.8.0

Read article
Interruptible Jobs in Laravel 13.7.0 image

Interruptible Jobs in Laravel 13.7.0

Read article
Redis Cluster Support for Queues in Laravel 13.5.0 image

Redis Cluster Support for Queues in Laravel 13.5.0

Read article
UnitTest Attribute and More in Laravel 13.3.0 image

UnitTest Attribute and More in Laravel 13.3.0

Read article
New Expressive Model Attributes in Laravel 13.2.0 image

New Expressive Model Attributes in Laravel 13.2.0

Read article
Model::withoutRelation() in Laravel 12.54.0 image

Model::withoutRelation() in Laravel 12.54.0

Read article
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
Celebian logo

Celebian

Celebian is a social media marketing agency specializing in helping their clients go viral on TikTok. Whether you're looking to reach a bigger audience or gain more Tiktok followers, likes, and views, they've got you covered.

Celebian
Kirschbaum logo

Kirschbaum

Providing innovation and stability to ensure your web application succeeds.

Kirschbaum
Laravel Cloud logo

Laravel Cloud

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

Laravel Cloud
Tighten logo

Tighten

We help companies turn great ideas into amazing apps, products, and services.

Tighten
Tinkerwell logo

Tinkerwell

The must-have code runner for Laravel developers. Tinker with AI, autocompletion and instant feedback on local and production environments.

Tinkerwell