承接 sezer/enum-helpers 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

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

sezer/enum-helpers

最新稳定版本:v1.1.0

Composer 安装命令:

composer require sezer/enum-helpers

包简介

Elegant and extensible helper library for PHP enums: filter, validate, and extend your enums with ease.

README 文档

README

Elegant and lightweight helpers for PHP enums. Adds only(), except(), onlyList(), exceptList(), automatic validation, and custom exceptions — to make working with PHP 8.1+ enums clean and easy.

Installation

description: Install this package via Composer:

composer require sezer/enum-helpers

Usage:

Add the EnumTrait to your enum and use the methods:

use Sezer\EnumHelpers\Traits\EnumTrait;

enum OrderStatus: string {
    use EnumTrait;

  case PENDING  = 'pending';
  case APPROVED = 'approved';
  case REJECTED = 'rejected';
  case COMPLETE = 'complete';
  case RETURNED = 'returned';
}

Examples:

  • Filter with only() Keep only specified cases.
  $result = OrderStatus::only(['PENDING', 'APPROVED']);
  print_r($result);
  output:
      [
      'PENDING'  => OrderStatus::PENDING,
      'APPROVED' => OrderStatus::APPROVED
      ]
  • Exclude with except() Exclude specified cases.
  $result = OrderStatus::except(['REJECTED']);
  print_r($result);
  output:
  [
  'PENDING'  => OrderStatus::PENDING,
  'APPROVED' => OrderStatus::APPROVED
  ]
  • 📜 Get just the values as plain array onlyList();
  OrderStatusEnum::onlyList(['PENDING', 'APPROVED']);
  
    output: ['pending', 'approved']
  • exceptList()
OrderStatusEnum::exceptList(['COMPLETE']);
output: ['pending', 'approved', 'rejected', 'returned']

🎯 With Laravel

✨ If your model has Enum cast:

protected $casts = [
    'order_status' => OrderStatusEnum::class,
];

You can pass Enum cases directly in queries:

Order::whereIn(
    'order_status',
    OrderStatusEnum::except(['COMPLETE'])
)->get();
<select name="status">
@foreach (OrderStatusEnum::except(['COMPLETE']) as $key => $status)
    <option value="{{ $status->value }}">{{ ucfirst(strtolower($key)) }}</option>
@endforeach
</select>

In Validation:

use Illuminate\Validation\Rule;

$request->validate([
    'status' => [
        'required',
        Rule::in(OrderStatusEnum::exceptList(['COMPLETE']))
    ]
]);

✨ If your model does NOT have Enum cast:

You need the ->value of each case:

Order::whereIn(
    'order_status',
    OrderStatusEnum::exceptList(['COMPLETE'])
)->get();

In Blade:

<select name="status">
@foreach (OrderStatusEnum::exceptList(['COMPLETE']) as $status)
    <option value="{{ $status }}">{{ ucfirst($status) }}</option>
@endforeach
</select>

In Validation:

$request->validate([
    'status' => [
        'required',
        Rule::in(OrderStatusEnum::exceptList(['COMPLETE']))
    ]
]);

Errors:

Invalid keys

If you pass an invalid case name to only() or except(), an InvalidEnumKeyException is thrown. example: OrderStatus::only(['INVALID']); Sezer\EnumHelpers\Exceptions\InvalidEnumKeyException: Invalid enum key: INVALID

Test

 vendor/bin/phpunit 

Authors

@sezer

🔗 Links

linkedin

Support

For support, email hussiensezer@gmail.com

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-07-17