mirror of
https://github.com/snipe/snipe-it.git
synced 2024-12-29 07:29:44 -08:00
934afa036f
Shift automatically applies the Laravel coding style - which uses the PSR-2 coding style as a base with some minor additions. You may customize the adopted coding style by adding your own [PHP CS Fixer][1] `.php_cs` config file to your project root. Feel free to use [Shift's Laravel ruleset][2] to help you get started. [1]: https://github.com/FriendsOfPHP/PHP-CS-Fixer [2]: https://gist.github.com/laravel-shift/cab527923ed2a109dda047b97d53c200
46 lines
1.4 KiB
PHP
46 lines
1.4 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Transformers;
|
|
|
|
use App\Helpers\Helper;
|
|
use App\Models\CustomFieldset;
|
|
use Illuminate\Database\Eloquent\Collection;
|
|
|
|
class CustomFieldsetsTransformer
|
|
{
|
|
public function transformCustomFieldsets(Collection $fieldsets, $total)
|
|
{
|
|
$array = [];
|
|
foreach ($fieldsets as $fieldset) {
|
|
$array[] = self::transformCustomFieldset($fieldset);
|
|
}
|
|
|
|
return (new DatatablesTransformer)->transformDatatables($array, $total);
|
|
}
|
|
|
|
public function transformCustomFieldset(CustomFieldset $fieldset)
|
|
{
|
|
$fields = $fieldset->fields;
|
|
$models = $fieldset->models;
|
|
$modelsArray = [];
|
|
|
|
foreach ($models as $model) {
|
|
$modelsArray[] = [
|
|
'id' => $model->id,
|
|
'name' => e($model->name),
|
|
];
|
|
}
|
|
|
|
$array = [
|
|
'id' => (int) $fieldset->id,
|
|
'name' => e($fieldset->name),
|
|
'fields' => (new CustomFieldsTransformer)->transformCustomFields($fields, $fieldset->fields_count),
|
|
'models' => (new DatatablesTransformer)->transformDatatables($modelsArray, $fieldset->models_count),
|
|
'created_at' => Helper::getFormattedDateObject($fieldset->created_at, 'datetime'),
|
|
'updated_at' => Helper::getFormattedDateObject($fieldset->updated_at, 'datetime'),
|
|
];
|
|
|
|
return $array;
|
|
}
|
|
}
|