Typer
================
data:image/s3,"s3://crabby-images/e6ddf/e6ddf9bbd209848b5e440c4f41c82e4f5e31d067" alt="Packagist Version"
data:image/s3,"s3://crabby-images/3e582/3e58237d4bdbd4deec6161b8325b7721fd7ddea1" alt="GitHub Workflow Status (with branch)"
[data:image/s3,"s3://crabby-images/081a4/081a44c49f5b5ef2fec1f672039e10057f08227a" alt="Coverage"](https://codecov.io/gh/yzen-dev/typer)
data:image/s3,"s3://crabby-images/cebde/cebdebe9851d59b60047252186771aaef8b7aa9c" alt="License"
data:image/s3,"s3://crabby-images/dc228/dc2286507baebafaa1b5431ff7892484bc6e0528" alt="readthedocs"
data:image/s3,"s3://crabby-images/0eda4/0eda43b557a84bacdea7695cb35f0fa38755d2d8" alt="Packagist Downloads"
data:image/s3,"s3://crabby-images/6b6bb/6b6bbf5a39544ea97b6bf39d69b5d0d8226ac64e" alt="Packagist Downloads"
[data:image/s3,"s3://crabby-images/6daf2/6daf250d8942e7f2083cdf4de1dd4182fa48aabf" alt="Mutation testing badge"](https://dashboard.stryker-mutator.io/reports/github.com/yzen-dev/typer/master)
[data:image/s3,"s3://crabby-images/a690b/a690be9554b58c3bb098ddc2ab0ede1c7c222c3d" alt="type-coverage"](https://shepherd.dev/github/yzen-dev/typer)
[data:image/s3,"s3://crabby-images/e2389/e2389ee17b50ace3d2fc8422598c90fa03dfe677" alt="psalm-level"](https://shepherd.dev/github/yzen-dev/typer)
This is a simple helper package that helps make the code cleaner. Often, when working with data from third-party sources, such as website parsing, you need to write hundreds of lines of code to check for a particular property.
Most likely, you write a lot of if or ternary operators, and your code looks something like this:
```php
$user = new User();
$user->id = isset($dynamicArray['id']) ? (int)$dynamicArray['id'] : null;
$user->email = isset($dynamicArray['email']) ? (string)$dynamicArray['email'] : null;
$user->balance = isset($dynamicArray['balance']) ? (float)$dynamicArray['balance'] : null;
$user->blocked = isset($dynamicArray['blocked']) ? ($dynamicArray['blocked'] === 'true' ? true : false) : null;
```
When using **Typer**, you don't need to worry about a lot of checks and transformations. Simply wrap the code in the `typer` method:
```php
$user = new User();
$user->id = Typer::int($dynamicArray, 'id');
$user->email = Typer::string($dynamicArray, 'email');
$user->balance = Typer::float($dynamicArray, 'balance');
$user->blocked = Typer::bool($dynamicArray, 'blocked');
```
If, in the absence of a parameter, you need to specify a default value other than "null", you can simply pass it as the second argument:
```php
$user->balance = Typer::float($dynamicArray, 'balance', 0.0);
```
## **Installation**
The package can be installed via composer:
```
composer require yzen.dev/plain-to-class
```
.. toctree::
:maxdepth: 2
installation
usage
|