Reusable enum helpers for status handling (values, options, labels) with Laravel support

Maintainers

Package info

github.com/dhunganaroshan341/StatusEnumComposer

pkg:composer/roshan-dhungana/status

Statistics

Installs: 0

Dependents: 0

Suggesters: 0

Stars: 0

Open Issues: 0

dev-main 2026-04-05 10:50 UTC

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.