roshan-dhungana/status 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

roshan-dhungana/status

Composer 安装命令:

composer require roshan-dhungana/status

包简介

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

README 文档

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.
some changes may apply
---

## ✨ 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.

统计信息

  • 总下载量: 0
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 6
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-04-05

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固