Adding Dept to license seats (#7609)

* Adding Dept to license seats

* Added query scope to order by department

* Make license seat department sortable

* Disable license seat internal search - this never actually worked
This commit is contained in:
snipe 2019-11-21 22:03:56 -08:00 committed by GitHub
parent d8049209ca
commit 88cf456386
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
6 changed files with 57 additions and 7 deletions

View file

@ -228,14 +228,21 @@ class LicensesController extends Controller
$this->authorize('view', $license); $this->authorize('view', $license);
$seats = LicenseSeat::where('license_id', $licenseId)->with('license', 'user', 'asset'); $seats = LicenseSeat::where('license_seats.license_id', $licenseId)
->with('license', 'user', 'asset', 'user.department');
$offset = (($seats) && (request('offset') > $seats->count())) ? 0 : request('offset', 0);
$limit = request('limit', 50);
$order = $request->input('order') === 'asc' ? 'asc' : 'desc'; $order = $request->input('order') === 'asc' ? 'asc' : 'desc';
if ($request->input('sort')=='department') {
$seats->OrderDepartments($order);
} else {
$seats->orderBy('id', $order);
}
$total = $seats->count(); $total = $seats->count();
$offset = (($seats) && (request('offset') > $total)) ? 0 : request('offset', 0);
$limit = request('limit', 50);
$seats = $seats->skip($offset)->take($limit)->get(); $seats = $seats->skip($offset)->take($limit)->get();
if ($seats) { if ($seats) {

View file

@ -29,7 +29,14 @@ class LicenseSeatsTransformer
'name' => 'Seat '.$seat_count, 'name' => 'Seat '.$seat_count,
'assigned_user' => ($seat->user) ? [ 'assigned_user' => ($seat->user) ? [
'id' => (int) $seat->user->id, 'id' => (int) $seat->user->id,
'name'=> e($seat->user->present()->fullName) 'name'=> e($seat->user->present()->fullName),
'department'=>
($seat->user->department) ?
[
"id" => (int) $seat->user->department->id,
"name" => e($seat->user->department->name)
] : null
] : null, ] : null,
'assigned_asset' => ($seat->asset) ? [ 'assigned_asset' => ($seat->asset) ? [
'id' => (int) $seat->asset->id, 'id' => (int) $seat->asset->id,

View file

@ -55,4 +55,23 @@ class LicenseSeat extends Model implements ICompanyableChild
return false; return false;
} }
/**
* Query builder scope to order on department
*
* @param \Illuminate\Database\Query\Builder $query Query builder instance
* @param text $order Order
*
* @return \Illuminate\Database\Query\Builder Modified query builder
*/
public function scopeOrderDepartments($query, $order)
{
return $query->leftJoin('users as license_seat_users', 'license_seats.assigned_to', '=', 'license_seat_users.id')
->leftJoin('departments as license_user_dept', 'license_user_dept.id', '=', 'license_seat_users.department_id')
->orderBy('license_user_dept.name', $order);
}
} }

View file

@ -176,6 +176,15 @@ class LicensePresenter extends Presenter
"visible" => true, "visible" => true,
"formatter" => "usersLinkObjFormatter" "formatter" => "usersLinkObjFormatter"
], [ ], [
"field" => "department",
"searchable" => false,
"sortable" => true,
"switchable" => true,
"title" => trans('general.department'),
"visible" => false,
"formatter" => "departmentNameLinkFormatter"
],
[
"field" => "assigned_asset", "field" => "assigned_asset",
"searchable" => false, "searchable" => false,
"sortable" => false, "sortable" => false,
@ -191,7 +200,8 @@ class LicensePresenter extends Presenter
"title" => trans('general.location'), "title" => trans('general.location'),
"visible" => true, "visible" => true,
"formatter" => "locationsLinkObjFormatter" "formatter" => "locationsLinkObjFormatter"
], [ ],
[
"field" => "checkincheckout", "field" => "checkincheckout",
"searchable" => false, "searchable" => false,
"sortable" => false, "sortable" => false,

View file

@ -48,7 +48,7 @@
data-id-table="seatsTable-{{ $license->id }}" data-id-table="seatsTable-{{ $license->id }}"
id="seatsTable-{{$license->id}}" id="seatsTable-{{$license->id}}"
data-pagination="true" data-pagination="true"
data-search="true" data-search="false"
data-side-pagination="server" data-side-pagination="server"
data-show-columns="true" data-show-columns="true"
data-show-export="true" data-show-export="true"

View file

@ -447,6 +447,13 @@
} }
function departmentNameLinkFormatter(value, row) {
if ((row.assigned_user) && (row.assigned_user.department) && (row.assigned_user.department.name)) {
return '<a href="{{ url('/') }}/department/' + row.assigned_user.department.id + '"> ' + row.assigned_user.department.name + '</a>';
}
}
function assetNameLinkFormatter(value, row) { function assetNameLinkFormatter(value, row) {
if ((row.asset) && (row.asset.name)) { if ((row.asset) && (row.asset.name)) {
return '<a href="{{ url('/') }}/hardware/' + row.asset.id + '"> ' + row.asset.name + '</a>'; return '<a href="{{ url('/') }}/hardware/' + row.asset.id + '"> ' + row.asset.name + '</a>';