mirror of
https://github.com/snipe/snipe-it.git
synced 2025-01-11 13:57:41 -08:00
Additional consistencies
Signed-off-by: snipe <snipe@snipe.net>
This commit is contained in:
parent
02a29c71ef
commit
bbce7b40ca
|
@ -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);
|
||||||
|
|
|
@ -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();
|
||||||
|
|
|
@ -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';
|
||||||
|
|
|
@ -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'),
|
||||||
];
|
];
|
||||||
|
|
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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,
|
||||||
];
|
];
|
||||||
|
|
|
@ -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)) {
|
||||||
|
|
|
@ -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>
|
||||||
|
|
Loading…
Reference in a new issue