roshan-dhungana / status
Reusable enum helpers for status handling (values, options, labels) with Laravel support
dev-main
2026-04-05 10:50 UTC
Requires
- php: ^8.1
- illuminate/support: ^10.0|^11.0|^12.0|^13.0
This package is auto-updated.
Last update: 2026-04-05 10:56:47 UTC
README
# Status Enum Package A lightweight, reusable PHP 8.1+ package that standardizes enum usage for dropdowns, validation, and display logicโespecially useful in Laravel applications. --- ## โจ Features - Enum value extraction for validation - Dropdown-friendly options - Clean label formatting - Built-in validation rule - Instance helper methods (`is`, `label`) - Laravel-ready (framework-agnostic core) --- ## ๐ฅ Installation ```bash composer require roshan-dhungana/status
โ๏ธ Requirements
- PHP 8.1+
- Laravel 10+ (optional)
๐ Quick Start
Create your Enum
namespace App\Enums; use RoshanDhungana\Status\Contracts\EnumContract; use RoshanDhungana\Status\Traits\HasEnumHelpers; enum ProjectStatus: string implements EnumContract { use HasEnumHelpers; case ACTIVE = 'active'; case INACTIVE = 'inactive'; case DRAFT = 'draft'; }
๐ Usage
Get values (for validation)
ProjectStatus::values();
Returns:
['active', 'inactive', 'draft']
Validation (Laravel)
use Illuminate\Validation\Rule; 'status' => ProjectStatus::rule(),
Dropdown options
ProjectStatus::options();
Returns:
[
'active' => 'Active',
'inactive' => 'Inactive',
'draft' => 'Draft',
]
Blade Example
@foreach(ProjectStatus::options() as $value => $label) <option value="{{ $value }}">{{ $label }}</option> @endforeach
Get label from enum instance
$status->label();
Compare values safely
if ($status->is(ProjectStatus::ACTIVE)) { // logic here }
or
$status->is('active');
Parse from raw value
$status = ProjectStatus::fromValue('active');
๐ง Why Use This Package?
Without this package, enum usage is often scattered:
- Hardcoded arrays in validation
- Duplicate dropdown mappings
- Inconsistent label formatting
This package centralizes everything into a single source of truth, improving:
- Maintainability
- Readability
- Consistency across your app
๐ Architecture
- Contracts โ define behavior
- Traits โ reusable enum logic
- Enums โ domain-specific states
The core is framework-agnostic while supporting Laravel seamlessly.
๐ Example: Eloquent Casting (Laravel)
protected $casts = [ 'status' => ProjectStatus::class, ];
๐ง Extending
Create additional enums easily:
enum OrderStatus: string implements EnumContract { use HasEnumHelpers; case PENDING = 'pending'; case COMPLETED = 'completed'; }
๐ค Contributing
Contributions, issues, and feature requests are welcome.