olivernybroe / lighthouse-math-scalars
A collection of custom scalar types for usage with https://github.com/webonyx/graphql-php
Installs: 2 416
Dependents: 0
Suggesters: 0
Security: 0
Stars: 8
Watchers: 3
Forks: 0
Open Issues: 0
Requires
- php: ^7.4|^8.0
- brick/math: ^0.9.1
- nuwave/lighthouse: ^5.0
Requires (Dev)
- pestphp/pest: ^1.0
README
A collection of custom scalar types for usage with Lighthouse.
Installation
composer require olivernybroe/lighthouse-math-scalars
Usage
You can use the provided scalars just like any other type in your schema definition.
The scalars are automatically registered in Lighthouse.
type Battle { id: ID! attacker: User! defender: User! gold_stolen_ratio: Percentage! gold_stolen: BigInteger! }
Scalars
BigInteger
This scalar represents an integer with a size up to 2^63
whereas the built-in Int
type is limited to 2^31
.
The value is represented as an integer, not a string when returned.
BigIntegerString
This scalar represents an integer with unlimited size. It is always returning the value as a string.
BigInteger
will always return an integer, but is limited to 2^63
, however BigIntegerString
is great for
the cases where bigger values than that is required.
BigIntegerDynamic
This scalar represents an integer which is bigger than the built-in Int
type.
The built-in type is limited to 2^31
, however this type has unlimited size as it can use strings to represent it.
It will return the result from you query as an integer, as long as your integer is smaller than 2^63
.
If your integer is bigger than that, it will be returned as a string instead.
Percentage
Converts an integer value to a percentage.
Normally many of us stores percentages as an integer value and divide it by 100 to get it as a percentage.
This Scalar will do this conversion for you. If used as an input type, it will do the same conversion.
This scalar is useful for quickly identify for the users of your API, that the type is a percentage.
Casts
A set of casts which can be used in a Laravel model to cast attributes.
BigInteger (OliverNybroe\LighthouseMathScalars\Casts\BigInteger
)
When dealing with integers of bigger than 2^63
, a class is needed for doing all the mathematical calculations.
For doing that, this package relies on \Brick\Math\BigInteger
underneath.
This cast will cast a value into the BigInteger
class for you.
use OliverNybroe\LighthouseMathScalars\Casts\BigInteger as BigIntegerCast; use Brick\Math\BigInteger; use Illuminate\Foundation\Auth\User as Authenticatable; /** * @property BigInteger $gold */ class User extends Authenticatable { protected $casts = [ 'gold' => BigIntegerCast::class, ];