worksome / number
A package for handling numbers in Laravel
Fund package maintenance!
worksome
Installs: 349 759
Dependents: 0
Suggesters: 0
Security: 0
Stars: 6
Watchers: 11
Forks: 1
Open Issues: 1
pkg:composer/worksome/number
Requires
- php: ^8.4
- brick/math: ^0.12 || ^0.13 || ^0.14
- nuwave/lighthouse: ^6.54
- webonyx/graphql-php: ^15.19
Requires (Dev)
- larastan/larastan: ^3.8
- nunomaduro/collision: ^8.8.3
- orchestra/testbench: ^10.7
- pestphp/pest: ^4.1
- worksome/coding-style: ^3.3
README
A package for handling numbers in Laravel.
Installation
You can install the package via composer:
composer require worksome/number
Usage
use Worksome\Number\Number; $number = Number::of(100); $number->mul(Number::of(5)); echo $number; // 500
Casting
This package allows you to easily cast attributes on your Eloquent models to number types.
use Illuminate\Database\Eloquent\Model; use Worksome\Number\Casts\NumberFromCents; use Worksome\Number\Casts\NumberFromDecimal; use Worksome\Number\MonetaryAmount; use Worksome\Number\Percentage; use Worksome\Number\Number; class Product extends Model { protected $casts = [ 'a' => NumberFromCents::class, 'b' => NumberFromDecimal::class, 'c' => NumberFromDecimal::using(2, MonetaryAmount::class), // Cast to a specialised Number-class 'd' => NumberFromDecimal::using(2, Percentage::class), // Cast to a specialised Number-class 'e' => NumberFromDecimal::using(3), // Three decimal places - default is 2 ]; }
Available Number Types
The following Number types are available out of the box:
Number- The base number type, with two decimal places. Can be configured to use a different default scale.MonetaryAmount- A number type for handling monetary amounts. Always uses two decimal places. Rounds automatically in all operations.Percentage- A number type for handling percentages. Makes it clear that the number represents a percentage, not an amount. Adds % on to string representations.
GraphQL
This package also provides GraphQL scalar types for the WebOnyx GraphQL PHP package / Lighthouse.
These will be auto-registered by Worksome\Number\Providers\NumberServiceProvider, however if you want to do this manually, they can be registered in the type registry using:
// In Lighthouse (https://lighthouse-php.com) $typeRegistry->register(new \Worksome\Number\GraphQL\Scalars\DecimalTwoType()); $typeRegistry->register(new \Worksome\Number\GraphQL\Scalars\PercentageType()); $typeRegistry->register(new \Worksome\Number\GraphQL\Scalars\StrictPercentageType());
Testing
composer test
Updating snapshots
To update Pest snapshots, run the following:
vendor/bin/pest -d --update-snapshots
Changelog
Please see GitHub Releases for more information on what has changed recently.
Credits
License
The MIT License (MIT). Please see License File for more information.