Additional consistencies

Signed-off-by: snipe <snipe@snipe.net>
This commit is contained in:
snipe 2024-09-19 17:20:56 +01:00
parent 02a29c71ef
commit bbce7b40ca
10 changed files with 37 additions and 28 deletions

View file

@ -80,7 +80,7 @@ class AssetMaintenancesController extends Controller
switch ($sort) { switch ($sort) {
case 'created_by': case 'created_by':
$maintenances = $maintenances->OrderAdmin($order); $maintenances = $maintenances->OrderByCreatedBy($order);
break; break;
case 'supplier': case 'supplier':
$maintenances = $maintenances->OrderBySupplier($order); $maintenances = $maintenances->OrderBySupplier($order);

View file

@ -23,9 +23,8 @@ class GroupsController extends Controller
$this->authorize('superadmin'); $this->authorize('superadmin');
$this->authorize('view', Group::class); $this->authorize('view', Group::class);
$allowed_columns = ['id', 'name', 'created_at', 'users_count'];
$groups = Group::select('id', 'name', 'permissions', 'created_at', 'updated_at', 'created_by')->with('admin')->withCount('users as users_count'); $groups = Group::select('id', 'name', 'permissions', 'created_at', 'updated_at', 'created_by')->with('adminuser')->withCount('users as users_count');
if ($request->filled('search')) { if ($request->filled('search')) {
$groups = $groups->TextSearch($request->input('search')); $groups = $groups->TextSearch($request->input('search'));
@ -35,13 +34,29 @@ class GroupsController extends Controller
$groups->where('name', '=', $request->input('name')); $groups->where('name', '=', $request->input('name'));
} }
// Make sure the offset and limit are actually integers and do not exceed system limits
$offset = ($request->input('offset') > $groups->count()) ? $groups->count() : app('api_offset_value'); $offset = ($request->input('offset') > $groups->count()) ? $groups->count() : app('api_offset_value');
$limit = app('api_limit_value'); $limit = app('api_limit_value');
$order = $request->input('order') === 'asc' ? 'asc' : 'desc'; $order = $request->input('order') === 'asc' ? 'asc' : 'desc';
switch ($request->input('sort')) {
case 'created_by':
$groups = $groups->OrderByCreatedBy($order);
break;
default:
// This array is what determines which fields should be allowed to be sorted on ON the table itself.
// These must match a column on the consumables table directly.
$allowed_columns = [
'id',
'name',
'created_at',
'users_count',
];
$sort = in_array($request->input('sort'), $allowed_columns) ? $request->input('sort') : 'created_at'; $sort = in_array($request->input('sort'), $allowed_columns) ? $request->input('sort') : 'created_at';
$groups->orderBy($sort, $order); $groups = $groups->orderBy($sort, $order);
break;
}
$total = $groups->count(); $total = $groups->count();
$groups = $groups->skip($offset)->take($limit)->get(); $groups = $groups->skip($offset)->take($limit)->get();

View file

@ -87,7 +87,7 @@ class ReportsController extends Controller
switch ($request->input('sort')) { switch ($request->input('sort')) {
case 'created_by': case 'created_by':
$actionlogs->OrderAdmin($order); $actionlogs->OrderByCreatedBy($order);
break; break;
default: default:
$sort = in_array($request->input('sort'), $allowed_columns) ? e($request->input('sort')) : 'created_at'; $sort = in_array($request->input('sort'), $allowed_columns) ? e($request->input('sort')) : 'created_at';

View file

@ -26,7 +26,10 @@ class GroupsTransformer
'name' => e($group->name), 'name' => e($group->name),
'permissions' => json_decode($group->permissions), 'permissions' => json_decode($group->permissions),
'users_count' => (int) $group->users_count, 'users_count' => (int) $group->users_count,
'created_by' => ($group->admin) ? e($group->admin->present()->fullName) : null, 'created_by' => ($group->adminuser) ? [
'id' => (int) $group->adminuser->id,
'name'=> e($group->adminuser->present()->fullName()),
] : null,
'created_at' => Helper::getFormattedDateObject($group->created_at, 'datetime'), 'created_at' => Helper::getFormattedDateObject($group->created_at, 'datetime'),
'updated_at' => Helper::getFormattedDateObject($group->updated_at, 'datetime'), 'updated_at' => Helper::getFormattedDateObject($group->updated_at, 'datetime'),
]; ];

View file

@ -374,7 +374,7 @@ class Actionlog extends SnipeModel
$this->source = $source; $this->source = $source;
} }
public function scopeOrderAdmin($query, $order) public function scopeOrderByCreatedBy($query, $order)
{ {
return $query->leftJoin('users as admin_sort', 'action_logs.created_by', '=', 'admin_sort.id')->select('action_logs.*')->orderBy('admin_sort.first_name', $order)->orderBy('admin_sort.last_name', $order); return $query->leftJoin('users as admin_sort', 'action_logs.created_by', '=', 'admin_sort.id')->select('action_logs.*')->orderBy('admin_sort.first_name', $order)->orderBy('admin_sort.last_name', $order);
} }

View file

@ -207,20 +207,6 @@ class AssetMaintenance extends Model implements ICompanyableChild
} }
/**
* Query builder scope to order on admin user
*
* @param \Illuminate\Database\Query\Builder $query Query builder instance
* @param string $order Order
*
* @return \Illuminate\Database\Query\Builder Modified query builder
*/
public function scopeOrderAdmin($query, $order)
{
return $query->leftJoin('users', 'asset_maintenances.user_id', '=', 'users.id')
->orderBy('users.first_name', $order)
->orderBy('users.last_name', $order);
}
/** /**
* Query builder scope to order on asset tag * Query builder scope to order on asset tag

View file

@ -65,7 +65,7 @@ class Group extends SnipeModel
* @since [v6.3.0] * @since [v6.3.0]
* @return \Illuminate\Database\Eloquent\Relations\Relation * @return \Illuminate\Database\Eloquent\Relations\Relation
*/ */
public function admin() public function adminuser()
{ {
return $this->belongsTo(\App\Models\User::class, 'created_by'); return $this->belongsTo(\App\Models\User::class, 'created_by');
} }
@ -81,4 +81,9 @@ class Group extends SnipeModel
{ {
return json_decode($this->permissions, true); return json_decode($this->permissions, true);
} }
public function scopeOrderByCreatedBy($query, $order)
{
return $query->leftJoin('users as admin_sort', 'permission_groups.created_by', '=', 'admin_sort.id')->select('permission_groups.*')->orderBy('admin_sort.first_name', $order)->orderBy('admin_sort.last_name', $order);
}
} }

View file

@ -232,7 +232,7 @@ trait Loggable
$params = [ $params = [
'item' => $log->item, 'item' => $log->item,
'filename' => $log->filename, 'filename' => $log->filename,
'admin' => $log->admin, 'admin' => $log->adminuser,
'location' => ($location) ? $location->name : '', 'location' => ($location) ? $location->name : '',
'note' => $note, 'note' => $note,
]; ];

View file

@ -7,7 +7,7 @@ namespace App\Presenters;
*/ */
class ActionlogPresenter extends Presenter class ActionlogPresenter extends Presenter
{ {
public function admin() public function adminuser()
{ {
if ($user = $this->model->user) { if ($user = $this->model->user) {
if (empty($user->deleted_at)) { if (empty($user->deleted_at)) {

View file

@ -45,7 +45,7 @@
<th data-switchable="true" data-sortable="true" data-field="name" data-formatter="groupsAdminLinkFormatter" data-visible="true">{{ trans('admin/groups/table.name') }}</th> <th data-switchable="true" data-sortable="true" data-field="name" data-formatter="groupsAdminLinkFormatter" data-visible="true">{{ trans('admin/groups/table.name') }}</th>
<th data-switchable="true" data-sortable="true" data-field="users_count" data-visible="true"><x-icon type="user" /><span class="sr-only">{{ trans('admin/groups/table.users') }}</span></th> <th data-switchable="true" data-sortable="true" data-field="users_count" data-visible="true"><x-icon type="user" /><span class="sr-only">{{ trans('admin/groups/table.users') }}</span></th>
<th data-switchable="true" data-sortable="true" data-field="created_at" data-visible="true" data-formatter="dateDisplayFormatter">{{ trans('general.created_at') }}</th> <th data-switchable="true" data-sortable="true" data-field="created_at" data-visible="true" data-formatter="dateDisplayFormatter">{{ trans('general.created_at') }}</th>
<th data-switchable="false" data-searchable="false" data-sortable="false" data-field="created_by" data-formatter="usersLinkFormatter">{{ trans('general.created_by') }}</th> <th data-switchable="false" data-searchable="false" data-sortable="true" data-field="created_by" data-formatter="usersLinkObjFormatter">{{ trans('general.created_by') }}</th>
<th data-switchable="false" data-searchable="false" data-sortable="false" data-field="actions" data-formatter="groupsActionsFormatter">{{ trans('table.actions') }}</th> <th data-switchable="false" data-searchable="false" data-sortable="false" data-field="actions" data-formatter="groupsActionsFormatter">{{ trans('table.actions') }}</th>
</tr> </tr>