snipe-it/app/Http/Transformers/GroupsTransformer.php
Laravel Shift 934afa036f Adopt Laravel coding style
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
2021-06-10 20:15:52 +00:00

43 lines
1.1 KiB
PHP

<?php
namespace App\Http\Transformers;
use App\Helpers\Helper;
use App\Models\Group;
use Gate;
use Illuminate\Database\Eloquent\Collection;
class GroupsTransformer
{
public function transformGroups(Collection $groups)
{
$array = [];
foreach ($groups as $group) {
$array[] = self::transformGroup($group);
}
return (new DatatablesTransformer)->transformDatatables($array);
}
public function transformGroup(Group $group)
{
$array = [
'id' => (int) $group->id,
'name' => e($group->name),
'permissions' => json_decode($group->permissions),
'users_count' => (int) $group->users_count,
'created_at' => Helper::getFormattedDateObject($group->created_at, 'datetime'),
'updated_at' => Helper::getFormattedDateObject($group->updated_at, 'datetime'),
];
$permissions_array['available_actions'] = [
'update' => Gate::allows('superadmin') ? true : false,
'delete' => Gate::allows('superadmin') ? true : false,
];
$array += $permissions_array;
return $array;
}
}