定制 azimkordpour/power-enum 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

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

azimkordpour/power-enum

最新稳定版本:v1.2

Composer 安装命令:

composer require azimkordpour/power-enum

包简介

This light package provides some methods to your Enum classes to make the most of them.

README 文档

README

This lightweight package provides a Trait that allows you to fully utilize Enum classes in your PHP projects, particularly in modern PHP frameworks like Laravel.

Installation

NOTE: As Enum was introduced in PHP 8.1, this package requires a minimum PHP version of 8.1.

You can install the package via composer:

composer require azimkordpour/power-enum

Usage Instructions

To use the PowerEnum trait in your Enum class, simply import it like this:

<?php

use AzimKordpour\PowerEnum\Traits\PowerEnum;

enum PostStatus: string
{
    use PowerEnum;

    case Active = 'active';
    case Inactive = 'inactive';
}

Now, let's take a closer look at the methods.


In Laravel

Eloquent allows you to cast your attribute values to PHP Enums.

 <?php
 
namespace App\Models;

use App\Enums\PostStatus; 
use Illuminate\Database\Eloquent\Model;

class Post extends Model
{
    /**
     * The attributes that should be cast.
     *
     * @var array
     */
    protected $casts = [
        'status' => PostStatus::class,
    ];
}

Then, you can use it like the below examples.

Check if the status of the model is active:

$post = Post::find(1);

// The status is active.
$post->status->isActive();

Returns boolean:

true

Check if the status of the model equals the given value:

$post = Post::find(1);

// The status is active.
$post->status->equals(PostStatus::Active);

Returns boolean:

false

This method works like equals:

$post = Post::find(1);

// The status is active.
$post->status->is(PostStatus::Active);

Returns boolean:

false

Get the label of the status:

$post = Post::find(1);

// The status is active.
$post->status->label();

Returns the value of the case if you have not set labels:

"active"

For setting custom labels and Seeing all methods in PHP projects, take a look at the next section.


All Methods

Get the values of PostStatus statically:

PostStatus::values();

Returns an array:

[
    'active',
    'inactive'
]

Get the names of PostStatus statically:

PostStatus::names();

Returns an array:

[
    'Active',
    'Inactive'
]

Get the names and values of PostStatus statically:

PostStatus::list();

Returns an array:

[
    'Active' => 'active',
    'Inactive' => 'inactive'
]

Check if the case is the active one:

PostStatus::from('active')->isActive();

Returns boolean:

true

Check if the case equals the given value:

PostStatus::Active->equals(AnotherEnum::Example);

Returns boolean:

false

This method works like equals:

PostStatus::Active->is(AnotherEnum::Example);

Returns boolean:

false

Initiate the class from name:

PostStatus::fromName('Active');

Returns the Enum object:

PostStatus::Active

Get the label of the case:

PostStatus::Active->label();

Returns the value of the case if you have not set labels:

"active"

Get the labels of the cases:

PostStatus::Active->getLabels();

Returns the values of the cases if you have not set labels:

[
    'active' => 'active',
    'inactive' => 'inactive'
]

You can write custom label for the cases in your Enum class:

/**
 * Set the labels of all the cases.
 */
 public static function setLabels(): array
 {
    return [
        self::Active->value => 'published post',
        self::Inactive->value => 'draft post',
    ];
 }

Then, the method of label:

PostStatus::Active->label();

Returns:

"published post"

And the method of getLabels:

PostStatus::Active->getLables();

Returns:

[
    'active' => 'published post',
    'inactive' => 'draft post'
]

Testing

composer test

统计信息

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

GitHub 信息

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

其他信息

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