mirror of
https://github.com/snipe/snipe-it.git
synced 2024-11-13 17:14:10 -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
102 lines
4.5 KiB
PHP
102 lines
4.5 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Transformers;
|
|
|
|
use App\Helpers\Helper;
|
|
use App\Models\User;
|
|
use Gate;
|
|
use Illuminate\Database\Eloquent\Collection;
|
|
|
|
class UsersTransformer
|
|
{
|
|
public function transformUsers(Collection $users, $total)
|
|
{
|
|
$array = [];
|
|
foreach ($users as $user) {
|
|
$array[] = self::transformUser($user);
|
|
}
|
|
|
|
return (new DatatablesTransformer)->transformDatatables($array, $total);
|
|
}
|
|
|
|
public function transformUser(User $user)
|
|
{
|
|
$array = [
|
|
'id' => (int) $user->id,
|
|
'avatar' => e($user->present()->gravatar),
|
|
'name' => e($user->first_name).' '.e($user->last_name),
|
|
'first_name' => e($user->first_name),
|
|
'last_name' => e($user->last_name),
|
|
'username' => e($user->username),
|
|
'locale' => ($user->locale) ? e($user->locale) : null,
|
|
'employee_num' => e($user->employee_num),
|
|
'manager' => ($user->manager) ? [
|
|
'id' => (int) $user->manager->id,
|
|
'name'=> e($user->manager->username),
|
|
] : null,
|
|
'jobtitle' => ($user->jobtitle) ? e($user->jobtitle) : null,
|
|
'phone' => ($user->phone) ? e($user->phone) : null,
|
|
'website' => ($user->website) ? e($user->website) : null,
|
|
'address' => ($user->address) ? e($user->address) : null,
|
|
'city' => ($user->city) ? e($user->city) : null,
|
|
'state' => ($user->state) ? e($user->state) : null,
|
|
'country' => ($user->country) ? e($user->country) : null,
|
|
'zip' => ($user->zip) ? e($user->zip) : null,
|
|
'email' => e($user->email),
|
|
'department' => ($user->department) ? [
|
|
'id' => (int) $user->department->id,
|
|
'name'=> e($user->department->name),
|
|
] : null,
|
|
'location' => ($user->userloc) ? [
|
|
'id' => (int) $user->userloc->id,
|
|
'name'=> e($user->userloc->name),
|
|
] : null,
|
|
'notes'=> e($user->notes),
|
|
'permissions' => $user->decodePermissions(),
|
|
'activated' => ($user->activated == '1') ? true : false,
|
|
'ldap_import' => ($user->ldap_import == '1') ? true : false,
|
|
'two_factor_activated' => ($user->two_factor_active()) ? true : false,
|
|
'two_factor_enrolled' => ($user->two_factor_active_and_enrolled()) ? true : false,
|
|
'assets_count' => (int) $user->assets_count,
|
|
'licenses_count' => (int) $user->licenses_count,
|
|
'accessories_count' => (int) $user->accessories_count,
|
|
'consumables_count' => (int) $user->consumables_count,
|
|
'company' => ($user->company) ? ['id' => (int) $user->company->id, 'name'=> e($user->company->name)] : null,
|
|
'created_at' => Helper::getFormattedDateObject($user->created_at, 'datetime'),
|
|
'updated_at' => Helper::getFormattedDateObject($user->updated_at, 'datetime'),
|
|
'last_login' => Helper::getFormattedDateObject($user->last_login, 'datetime'),
|
|
'deleted_at' => ($user->deleted_at) ? Helper::getFormattedDateObject($user->deleted_at, 'datetime') : null,
|
|
];
|
|
|
|
$permissions_array['available_actions'] = [
|
|
'update' => (Gate::allows('update', User::class) && ($user->deleted_at == '')),
|
|
'delete' => (Gate::allows('delete', User::class) && ($user->assets_count == 0) && ($user->licenses_count == 0) && ($user->accessories_count == 0) && ($user->consumables_count == 0)),
|
|
'clone' => (Gate::allows('create', User::class) && ($user->deleted_at == '')),
|
|
'restore' => (Gate::allows('create', User::class) && ($user->deleted_at != '')),
|
|
];
|
|
|
|
$array += $permissions_array;
|
|
|
|
$numGroups = $user->groups->count();
|
|
if ($numGroups > 0) {
|
|
$groups['total'] = $numGroups;
|
|
foreach ($user->groups as $group) {
|
|
$groups['rows'][] = [
|
|
'id' => (int) $group->id,
|
|
'name' => e($group->name),
|
|
];
|
|
}
|
|
$array['groups'] = $groups;
|
|
} else {
|
|
$array['groups'] = null;
|
|
}
|
|
|
|
return $array;
|
|
}
|
|
|
|
public function transformUsersDatatable($users)
|
|
{
|
|
return (new DatatablesTransformer)->transformDatatables($users);
|
|
}
|
|
}
|