rickgoemans/laravel-enum-helpers

A Laravel helper to have nice enum related functions

v3.0.0 2024-03-13 07:59 UTC

This package is auto-updated.

Last update: 2024-04-30 16:52:54 UTC


README

68747470733a2f2f6769746875622d6164732e73332e65752d63656e7472616c2d312e616d617a6f6e6177732e636f6d2f737570706f72742d756b7261696e652e7376673f743d31

A Laravel helper to have nice enum related functions

Latest Version on Packagist GitHub Tests Action Status GitHub Code Style Action Status Total Downloads

This package contains some useful helpers for Laravel and PHP's enums.

Installation

You can install the package via composer:

composer require rickgoemans/laravel-enum-helpers

Usage

Example enum:

<?php

namespace Rickgoemans\LaravelEnumHelpers\Enums;

use Rickgoemans\LaravelEnumHelpers\Traits\HasEnumHelpers;

enum CreditCheckRating: string
{
    use HasEnumHelpers;

    case AAA = 'AAA';
    case AA = 'AA';
    case A = 'A';
    case BBB = 'BBB';
    case BB = 'BB';
    case B = 'B';
    case CCC = 'CCC';
    case CC = 'CC';
    case C = 'C';
    case D = 'D';

    /** @inheritdoc */
    public static function badgeColors(): array
    {
        return [
            self::AAA->label() => 'success',
            self::AA->label()  => 'success',
            self::A->label()   => 'success',
            self::BBB->label() => 'info',
            self::BB->label()  => 'info',
            self::B->label()   => 'info',
            self::CCC->label() => 'info',
            self::CC->label()  => 'info',
            self::C->label()   => 'info',
            self::D->label()   => 'danger',
            self::NR->label()  => 'danger',
            null               => 'danger',
        ];
    }

    /** @inheritdoc */
    public static function order(): array
    {
        return [
            self::AAA,
            self::AA,
            self::A,
            self::BBB,
            self::BB,
            self::B,
            self::CCC,
            self::CC,
            self::C,
            self::D,
            self::NR,
        ];
    }
    
    /** @inheritdoc */
    public function label(): string
    {
        return $this->baseLabel('credit_checks.rating.values.');
    }
}

Example Laravel Nova resource with badge and select fields usage:

<?php

namespace App\Nova;

use Laravel\Nova\Fields\Badge;
use Laravel\Nova\Resource;
use Rickgoemans\LaravelEnumHelpers\Enums\CreditCheckRating;

class CreditCheck extends Resource {
    // ...
    
    public function fields(Request $request): array {
        return [
            // ...
            
            Badge::make(__('credit_checks.rating.label'), 'rating', fn(CreditCheckRating $rating) => $rating->label())
                ->map(CreditCheckRating::badgeColors())
                ->sortable(),
                
            Select::make(__('credit_checks.rating.label'), 'rating')
                ->options(CreditCheckRating::optionsForSelect())
                ->onlyOnForms(),
                
            // ...
        ];       
    }
    
    // ...
}

Testing

composer test

Changelog

Please see CHANGELOG for more information on what has changed recently.

Contributing

Please see CONTRIBUTING for details.

Security Vulnerabilities

Please review our security policy on how to report security vulnerabilities.

Credits

License

The MIT License (MIT). Please see License File for more information.