Skip to content

Commit

Permalink
- removed all methods `***AsSelect()
Browse files Browse the repository at this point in the history
- removed `NotBackedEnum` exception
- added support on `***ByValue()` methods also for pure enum using name instead value
  • Loading branch information
trippo committed Jul 2, 2022
1 parent 435aa39 commit 3a90a3d
Show file tree
Hide file tree
Showing 12 changed files with 102 additions and 257 deletions.
80 changes: 36 additions & 44 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
![Enum Helper-Dark](branding/dark.png#gh-dark-mode-only)![Enum Helper-Light](branding/light.png#gh-light-mode-only)
# Enum Helper
[![Latest Version on Packagist](https://img.shields.io/packagist/v/datomatic/enum-helper.svg?style=for-the-badge)](https://packagist.org/packages/datomatic/enum-helper)
[![Pest Tests number](https://img.shields.io/static/v1?label=%23tests&message=233&color=FF88FA&style=for-the-badge&logo=)](https://github.com/datomatic/enum-helper/tree/main/tests)
[![Pest Tests number](https://img.shields.io/static/v1?label=%23tests&message=224&color=FF88FA&style=for-the-badge&logo=)](https://github.com/datomatic/enum-helper/tree/main/tests)
[![GitHub Tests Action Status](https://img.shields.io/github/workflow/status/datomatic/enum-helper/run-tests?label=tests&color=5FE8B3&style=for-the-badge&logo=)](https://github.com/datomatic/enum-helper/actions/workflows/run-tests.yml)
[![GitHub Code Style Action Status](https://img.shields.io/github/workflow/status/datomatic/enum-helper/Check%20&%20fix%20styling?label=code%20style&color=5FE8B3&style=for-the-badge)](https://github.com/datomatic/enum-helper/actions/workflows/php-cs-fixer.yml)
[![Total Downloads](https://img.shields.io/packagist/dt/datomatic/enum-helper.svg?style=for-the-badge)](https://packagist.org/packages/datomatic/enum-helper)
Expand All @@ -13,10 +13,10 @@ This package is framework agnostic, but if you use Laravel consider to use this
- **Invokable cases**: get the value of enum "invoking" it statically
- **Construct enum by name or value**: `from()`, `tryFrom()`, `fromName()`, `tryFromName()`, `fromValue()`, `tryFromValue()` methods
- **Enums Equality**: `is()`, `isNot()`, `in()`, `notIn()` methods
- **Names**: methods to have a list of case names (`names()`, `namesByValue()`, `namesAsSelect()`)
- **Names**: methods to have a list of case names (`names()`, `namesByValue()`)
- **Values**: methods to have a list of case values (`values()`, `valuesByName()`)
- **Unique ID**: get an unique identifier from instance or instance from identifier (`uniqueId()`, `fromUniqueId()`)
- **Descriptions & Translations**: add description to enum with optional translation (`description()`,`descriptions()`,`descriptionsByName()`,`descriptionsByValue()`,`descriptionsAsSelect()`)
- **Descriptions & Translations**: add description to enum with optional translation (`description()`,`descriptions()`,`descriptionsByName()`,`descriptionsByValue()`)

## Installation

Expand Down Expand Up @@ -114,20 +114,20 @@ $task->updateStatus(StatusInt::pending());

#### Examples use static calls to get the primitive value
```php
// pure enum
// Pure Enum
Status::noResponse(); // 'NO_RESPONSE'
Status::NO_RESPONSE(); // 'NO_RESPONSE'
Status::NoResponse(); // 'NO_RESPONSE'

// pure eum with PascalCase
// Pure Enum with PascalCase
StatusPascalCase::noResponse(); // 'NoResponse'
StatusPascalCase::NO_RESPONSE(); // 'NoResponse'
StatusPascalCase::NoResponse(); // 'NoResponse'

// backed int eum
// IntBackedEnum
StatusInt::pending(); // 0

// backed string eum
// StringBackedEnum
StatusString::pending(); // 'P'

```
Expand All @@ -149,8 +149,8 @@ enum Status

### From FromName
This helper adds `from()` and `tryFrom()` to pure enums,
`fromValue()` and `tryFromValue()` (alias of `from()`, and `tryFrom()`) to `BackedEnum`,
and `fromName()` and `tryFromName()` to all enums
`fromValue()` and `tryFromValue()` (alias of `from()` and `tryFrom()`),
`fromName()` and `tryFromName()` to all enums

#### Important Notes:
- `BackedEnum` instances already implement their own `from()` and `tryFrom()` methods, which will not be overridden by this trait.
Expand Down Expand Up @@ -197,24 +197,6 @@ StatusString::tryFromName('MISSING'); // null
```


#### `fromValue()`
```php
// Pure Enum
Status::fromValue('PENDING'); // NotBackedEnum exception
// BackedEnum
StatusString::fromValue('P'); // StatusString::PENDING
StatusString::fromValue('M'); // ValueError Exception
```

#### `tryFromValue()`
```php
// Pure Enum
Status::tryFromValue('PENDING'); // NotBackedEnum exception
// BackedEnum
StatusString::tryFromValue('P'); // StatusString::PENDING
StatusString::tryFromValue('M'); // null
```

### Equality
This helper permits to compare an enum instance (`is()`,`isNot()`) and search if it is present inside an array (`in()`,`notIn()`).

Expand Down Expand Up @@ -265,7 +247,7 @@ StatusString::PENDING->notIn(['A','D']); // true


### Names
This helper offer `names()`, `namesByValue()`, and `namesAsSelect()` methods.
This helper offer `names()` and `namesByValue()` methods.

#### `names()`
This method returns a list of case names in the enum.
Expand All @@ -280,46 +262,38 @@ StatusPascalCase::names([StatusPascalCase::Accepted, StatusPascalCase::Discarded

#### `namesByValue()`

This method returns an associative array of [value => name] on `BackedEnum`, throw `NotBackedEnum` exception otherwise.
This method returns an associative array of [value => name] on `BackedEnum`, [name => name] on pure enum.
```php
Status::namesByValue(); // throw NotBackedEnum exception
StatusString::namesByValue(); // [ 'P'=>'PENDING', 'A'=>'ACCEPTED', 'D'=>'DISCARDED'...
Status::namesByValue(); // [ 'PENDING' => 'PENDING', 'ACCEPTED' => 'ACCEPTED', 'DISCARDED' => 'DISCARDED'...
StatusString::namesByValue(); // [ 'P' => 'PENDING', 'A' => 'ACCEPTED', 'D' => 'DISCARDED'...
StatusInt::namesByValue(); // [ 0=>'PENDING', 1=>'ACCEPTED', 2=>'DISCARDED'...
// Subset
StatusInt::namesByValue([StatusInt::NO_RESPONSE, StatusInt::DISCARDED]); // [ 3=>'NO_RESPONSE', 2=>'DISCARDED']
```

#### `namesAsSelect()`

This method returns an associative array of [value => name] on `BackedEnum`, [name => name] otherwise.
This is useful when you need a general enum select.
```php
Status::namesAsSelect(); // [ 'PENDING'=>'PENDING', 'ACCEPTED'=>'ACCEPTED', 'DISCARDED'=>'DISCARDED'...
StatusString::namesByValue(); // [ 'P'=>'PENDING', 'A'=>'ACCEPTED', 'D'=>'DISCARDED'...
// Subset
Status::namesByValue([Status::NO_RESPONSE, Status::DISCARDED]); // [ 'NO_RESPONSE'=>'NO_RESPONSE', 'DISCARDED'=>'DISCARDED']
StatusInt::namesByValue([StatusInt::NO_RESPONSE, StatusInt::DISCARDED]); // [ 3=>'NO_RESPONSE', 2=>'DISCARDED']
```

### Values
This helper offer `values()` and `valuesByName()` methods.

#### `values()`
This method returns a list of case values for `BackedEnum` or a list of case names for pure enums.
```php
Status::values(); // ['PENDING', 'ACCEPTED', 'DISCARDED', 'NO_RESPONSE']
StatusString::values(); // ['P', 'A', 'D', 'N']
StatusInt::values(); // [0, 1, 2, 3]
// Subset
Status::values([Status::NO_RESPONSE, Status::DISCARDED]); // ['NO_RESPONSE', 'DISCARDED']
StatusString::values([StatusString::NO_RESPONSE, StatusString::DISCARDED]); // ['N', 'D']
StatusInt::values([StatusInt::NO_RESPONSE, StatusInt::DISCARDED]); // [3, 2]
```
#### `valuesByName()`
This method returns a associative array of [case name => case value] on `BackedEnum`, throw `NotBackedEnum` exception otherwise.
This method returns a associative array of [name => value] on `BackedEnum`, [name => name] on pure enum.
```php
Status::valuesByName(); // throw NotBackedEnum exception
Status::valuesByName(); // ['PENDING' => 'PENDING','ACCEPTED' => 'ACCEPTED','DISCARDED' => 'DISCARDED',...]
StatusString::valuesByName(); // ['PENDING' => 'P','ACCEPTED' => 'A','DISCARDED' => 'D','NO_RESPONSE' => 'N']
StatusInt::valuesByName(); // ['PENDING' => 0,'ACCEPTED' => 1,'DISCARDED' => 2,'NO_RESPONSE' => 3]
// Subset
Status::valuesByName([Status::NO_RESPONSE, Status::DISCARDED]); // ['NO_RESPONSE' => 'NO_RESPONSE', 'DISCARDED' => 'DISCARDED']
StatusString::valuesByName([StatusString::NO_RESPONSE, StatusString::DISCARDED]); // ['NO_RESPONSE' => 'N', 'DISCARDED' => 'D']
StatusInt::valuesByName([StatusInt::NO_RESPONSE, StatusInt::DISCARDED]); // ['NO_RESPONSE' => 3, 'DISCARDED' => 2]
```
Expand Down Expand Up @@ -450,4 +424,22 @@ After the implementation of `description` method you can use it
$enum = Status::PENDING;
$enum->description(); // 'Await decision'
$enum->description('it'); // 🇮🇹 'In attesa'
```

#### descriptions()
This method returns a list of case descriptions of enum.
```php
StatusString::descriptions(); // ['Await decision','Recognized valid','No longer useful','No response']
// Subset
StatusString::descriptions([StatusString::ACCEPTED, StatusString::NO_RESPONSE]); // ['Recognized valid','No response']
```

#### descriptionsByValue()
This method returns an associative array of [value => description] on `BackedEnum`, [name => description] on pure enum.
```php
StatusString::descriptionsByValue(); // ['P' => 'Await decision', 'A' => 'Recognized valid',...
Status::descriptionsByValue(); // ['PENDING' => 'Await decision', 'ACCEPTED' => 'Recognized valid',...
// Subset
StatusString::descriptionsByValue([StatusString::DISCARDED, StatusString::ACCEPTED]); // ['D' => 'No longer useful', 'A' => 'Recognized valid']
Status::descriptionsByValue([[Status::PENDING, Status::DISCARDED]); // ['PENDING' => 'Await decision', 'DISCARDED' => 'No longer useful']
```
15 changes: 0 additions & 15 deletions src/Exceptions/NotBackedEnum.php

This file was deleted.

17 changes: 2 additions & 15 deletions src/Traits/EnumDescription.php
Original file line number Diff line number Diff line change
Expand Up @@ -32,8 +32,8 @@ public static function descriptionsByName(?array $cases = null, ?string $lang =
}

/**
* [ONLY for BackedEnum]
* Return as associative array with value => description (all cases or cases passed by param).
* Return as associative array with [name => description] on Pure Enum
* Return as associative array with [value => description] on Backed Enum.
*
* @param null|array<self> $cases
* @return array<string, string>
Expand All @@ -42,17 +42,4 @@ public static function descriptionsByValue(?array $cases = null, ?string $lang =
{
return self::dynamicByKey('value', 'description', $cases, $lang);
}

/**
* Return as associative array with [name => description] on Pure Enum
* Return as associative array with [value => description] on Backed Enum
* of all cases or cases passed by param.
*
* @param null|array<self> $cases
* @return array<string, string>
*/
public static function descriptionsAsSelect(?array $cases = null, ?string $lang = null): array
{
return self::dynamicAsSelect('description', $cases, $lang);
}
}
10 changes: 0 additions & 10 deletions src/Traits/EnumFrom.php
Original file line number Diff line number Diff line change
Expand Up @@ -4,8 +4,6 @@

namespace Datomatic\EnumHelper\Traits;

use BackedEnum;
use Datomatic\EnumHelper\Exceptions\NotBackedEnum;
use ValueError;

trait EnumFrom
Expand Down Expand Up @@ -67,10 +65,6 @@ public static function tryFromName(string $enumName): ?static
*/
public static function fromValue(string|int $value): static
{
if (! is_subclass_of(static::class, BackedEnum::class)) {
throw new NotBackedEnum(static::class);
}

return self::from($value);
}

Expand All @@ -81,10 +75,6 @@ public static function fromValue(string|int $value): static
*/
public static function tryFromValue(string|int $value): ?static
{
if (! is_subclass_of(static::class, BackedEnum::class)) {
throw new NotBackedEnum(static::class);
}

return self::tryFrom($value);
}
}
28 changes: 3 additions & 25 deletions src/Traits/EnumNames.php
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,6 @@

use BackedEnum;
use Datomatic\EnumHelper\Exceptions\EmptyCases;
use Datomatic\EnumHelper\Exceptions\NotBackedEnum;

trait EnumNames
{
Expand All @@ -27,36 +26,15 @@ public static function names(?array $cases = null): array
return array_column($cases, 'name');
}

/**
* [ONLY for BackedEnum]
* Get an associative array of [case value => case name].
*
* @param null|array<self> $cases
* @return array<string|int,string>
* @throws EmptyCases|NotBackedEnum
*/
public static function namesByValue(?array $cases = null): array
{
if (! is_subclass_of(static::class, BackedEnum::class)) {
throw new NotBackedEnum(static::class);
}

$cases ??= static::cases();

if (empty($cases)) {
throw new EmptyCases(static::class);
}

return array_column($cases, 'name', 'value');
}

/**
* Get an associative array of [case value => case name] on pure Enum.
* Get an associative array of [case name => case name] on BackedEnum.
*
* @param null|array<self> $cases
* @return array<string|int,string>
* @throws EmptyCases
*/
public static function namesAsSelect(?array $cases = null): array
public static function namesByValue(?array $cases = null): array
{
$cases ??= static::cases();

Expand Down
19 changes: 3 additions & 16 deletions src/Traits/EnumProperties.php
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,6 @@

use BackedEnum;
use Datomatic\EnumHelper\Exceptions\EmptyCases;
use Datomatic\EnumHelper\Exceptions\NotBackedEnum;

trait EnumProperties
{
Expand All @@ -27,12 +26,13 @@ public static function dynamicList(string $method, ?array $cases = null, ?string
}

/**
* Return as associative array [$key => $method() value]n on Backed Enum.
* Return as associative array [name => $method() value] on Pure Enum
* Return as associative array [value => $method() value] on Backed Enum.
*/
public static function dynamicByKey(string $key, string $method, ?array $cases = null, ?string $lang = null): array
{
if ($key === 'value' && ! is_subclass_of(static::class, BackedEnum::class)) {
throw new NotBackedEnum(static::class);
$key = 'name';
}

$cases ??= static::cases();
Expand All @@ -49,17 +49,4 @@ public static function dynamicByKey(string $key, string $method, ?array $cases =

return $result;
}

/**
* Return as associative array [name => $method() value] on Pure Enum
* Return as associative array [value => $method() value] on Backed Enum.
*/
public static function dynamicAsSelect(string $method, ?array $cases = null, ?string $lang = null): array
{
if (is_subclass_of(static::class, BackedEnum::class)) {
return self::dynamicByKey('value', $method, $cases, $lang);
}

return self::dynamicByKey('name', $method, $cases, $lang);
}
}
18 changes: 8 additions & 10 deletions src/Traits/EnumValues.php
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,6 @@

use BackedEnum;
use Datomatic\EnumHelper\Exceptions\EmptyCases;
use Datomatic\EnumHelper\Exceptions\NotBackedEnum;

trait EnumValues
{
Expand All @@ -18,37 +17,36 @@ trait EnumValues
*/
public static function values(?array $cases = null): array
{
if (! is_subclass_of(static::class, BackedEnum::class)) {
throw new NotBackedEnum(static::class);
}

$cases ??= static::cases();

if (empty($cases)) {
throw new EmptyCases(static::class);
}

if (! is_subclass_of(static::class, BackedEnum::class)) {
return array_column($cases, 'name');
}

return array_column($cases, 'value');
}

/**
* [ONLY for BackedEnum]
* Get an associative array of [case name => case value].
*
* @return array<string,string|int>
*/
public static function valuesByName(?array $cases = null): array
{
if (! is_subclass_of(static::class, BackedEnum::class)) {
throw new NotBackedEnum(static::class);
}

$cases ??= static::cases();

if (empty($cases)) {
throw new EmptyCases(static::class);
}

if (! is_subclass_of(static::class, BackedEnum::class)) {
return array_column($cases, 'name', 'name');
}

return array_column($cases, 'value', 'name');
}
}
Loading

0 comments on commit 3a90a3d

Please sign in to comment.