mirror of
https://github.com/snipe/snipe-it.git
synced 2025-01-13 06:47:46 -08:00
Merge remote-tracking branch 'origin/develop'
This commit is contained in:
commit
3af7c66de7
|
@ -27,9 +27,23 @@ class AccessoriesController extends Controller
|
||||||
public function index(Request $request)
|
public function index(Request $request)
|
||||||
{
|
{
|
||||||
$this->authorize('view', Accessory::class);
|
$this->authorize('view', Accessory::class);
|
||||||
$allowed_columns = ['id','name','model_number','eol','notes','created_at','min_amt','company_id'];
|
|
||||||
|
|
||||||
$accessories = Accessory::with('category', 'company', 'manufacturer', 'users', 'location');
|
// This array is what determines which fields should be allowed to be sorted on ON the table itself, no relations
|
||||||
|
// Relations will be handled in query scopes a little further down.
|
||||||
|
$allowed_columns =
|
||||||
|
[
|
||||||
|
'id',
|
||||||
|
'name',
|
||||||
|
'model_number',
|
||||||
|
'eol',
|
||||||
|
'notes',
|
||||||
|
'created_at',
|
||||||
|
'min_amt',
|
||||||
|
'company_id'
|
||||||
|
];
|
||||||
|
|
||||||
|
|
||||||
|
$accessories = Accessory::with('category', 'company', 'manufacturer', 'users', 'location', 'supplier');
|
||||||
|
|
||||||
if ($request->filled('search')) {
|
if ($request->filled('search')) {
|
||||||
$accessories = $accessories->TextSearch($request->input('search'));
|
$accessories = $accessories->TextSearch($request->input('search'));
|
||||||
|
@ -62,23 +76,31 @@ class AccessoriesController extends Controller
|
||||||
// Check to make sure the limit is not higher than the max allowed
|
// Check to make sure the limit is not higher than the max allowed
|
||||||
((config('app.max_results') >= $request->input('limit')) && ($request->filled('limit'))) ? $limit = $request->input('limit') : $limit = config('app.max_results');
|
((config('app.max_results') >= $request->input('limit')) && ($request->filled('limit'))) ? $limit = $request->input('limit') : $limit = config('app.max_results');
|
||||||
|
|
||||||
|
|
||||||
$order = $request->input('order') === 'asc' ? 'asc' : 'desc';
|
$order = $request->input('order') === 'asc' ? 'asc' : 'desc';
|
||||||
$sort = in_array($request->input('sort'), $allowed_columns) ? $request->input('sort') : 'created_at';
|
$sort_override = $request->input('sort');
|
||||||
|
$column_sort = in_array($sort_override, $allowed_columns) ? $sort_override : 'created_at';
|
||||||
|
|
||||||
switch ($sort) {
|
switch ($sort_override) {
|
||||||
case 'category':
|
case 'category':
|
||||||
$accessories = $accessories->OrderCategory($order);
|
$accessories = $accessories->OrderCategory($order);
|
||||||
break;
|
break;
|
||||||
case 'company':
|
case 'company':
|
||||||
$accessories = $accessories->OrderCompany($order);
|
$accessories = $accessories->OrderCompany($order);
|
||||||
break;
|
break;
|
||||||
|
case 'location':
|
||||||
|
$accessories = $accessories->OrderLocation($order);
|
||||||
|
break;
|
||||||
|
case 'manufacturer':
|
||||||
|
$accessories = $accessories->OrderManufacturer($order);
|
||||||
|
break;
|
||||||
|
case 'supplier':
|
||||||
|
$accessories = $accessories->OrderSupplier($order);
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
$accessories = $accessories->orderBy($sort, $order);
|
$accessories = $accessories->orderBy($column_sort, $order);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
$accessories->orderBy($sort, $order);
|
|
||||||
|
|
||||||
$total = $accessories->count();
|
$total = $accessories->count();
|
||||||
$accessories = $accessories->skip($offset)->take($limit)->get();
|
$accessories = $accessories->skip($offset)->take($limit)->get();
|
||||||
|
|
|
@ -26,8 +26,25 @@ class ComponentsController extends Controller
|
||||||
public function index(Request $request)
|
public function index(Request $request)
|
||||||
{
|
{
|
||||||
$this->authorize('view', Component::class);
|
$this->authorize('view', Component::class);
|
||||||
|
|
||||||
|
// This array is what determines which fields should be allowed to be sorted on ON the table itself, no relations
|
||||||
|
// Relations will be handled in query scopes a little further down.
|
||||||
|
$allowed_columns =
|
||||||
|
[
|
||||||
|
'id',
|
||||||
|
'name',
|
||||||
|
'min_amt',
|
||||||
|
'order_number',
|
||||||
|
'serial',
|
||||||
|
'purchase_date',
|
||||||
|
'purchase_cost',
|
||||||
|
'qty',
|
||||||
|
'image',
|
||||||
|
];
|
||||||
|
|
||||||
|
|
||||||
$components = Company::scopeCompanyables(Component::select('components.*')
|
$components = Company::scopeCompanyables(Component::select('components.*')
|
||||||
->with('company', 'location', 'category'));
|
->with('company', 'location', 'category', 'assets'));
|
||||||
|
|
||||||
if ($request->filled('search')) {
|
if ($request->filled('search')) {
|
||||||
$components = $components->TextSearch($request->input('search'));
|
$components = $components->TextSearch($request->input('search'));
|
||||||
|
@ -52,11 +69,12 @@ class ComponentsController extends Controller
|
||||||
// Check to make sure the limit is not higher than the max allowed
|
// Check to make sure the limit is not higher than the max allowed
|
||||||
((config('app.max_results') >= $request->input('limit')) && ($request->filled('limit'))) ? $limit = $request->input('limit') : $limit = config('app.max_results');
|
((config('app.max_results') >= $request->input('limit')) && ($request->filled('limit'))) ? $limit = $request->input('limit') : $limit = config('app.max_results');
|
||||||
|
|
||||||
$allowed_columns = ['id','name','min_amt','order_number','serial','purchase_date','purchase_cost','company','category','qty','location','image'];
|
|
||||||
$order = $request->input('order') === 'asc' ? 'asc' : 'desc';
|
|
||||||
$sort = in_array($request->input('sort'), $allowed_columns) ? $request->input('sort') : 'created_at';
|
|
||||||
|
|
||||||
switch ($sort) {
|
$order = $request->input('order') === 'asc' ? 'asc' : 'desc';
|
||||||
|
$sort_override = $request->input('sort');
|
||||||
|
$column_sort = in_array($sort_override, $allowed_columns) ? $sort_override : 'created_at';
|
||||||
|
|
||||||
|
switch ($sort_override) {
|
||||||
case 'category':
|
case 'category':
|
||||||
$components = $components->OrderCategory($order);
|
$components = $components->OrderCategory($order);
|
||||||
break;
|
break;
|
||||||
|
@ -67,7 +85,7 @@ class ComponentsController extends Controller
|
||||||
$components = $components->OrderCompany($order);
|
$components = $components->OrderCompany($order);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
$components = $components->orderBy($sort, $order);
|
$components = $components->orderBy($column_sort, $order);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -25,6 +25,26 @@ class ConsumablesController extends Controller
|
||||||
public function index(Request $request)
|
public function index(Request $request)
|
||||||
{
|
{
|
||||||
$this->authorize('index', Consumable::class);
|
$this->authorize('index', Consumable::class);
|
||||||
|
|
||||||
|
// This array is what determines which fields should be allowed to be sorted on ON the table itself, no relations
|
||||||
|
// Relations will be handled in query scopes a little further down.
|
||||||
|
$allowed_columns =
|
||||||
|
[
|
||||||
|
'id',
|
||||||
|
'name',
|
||||||
|
'order_number',
|
||||||
|
'min_amt',
|
||||||
|
'purchase_date',
|
||||||
|
'purchase_cost',
|
||||||
|
'company',
|
||||||
|
'category',
|
||||||
|
'model_number',
|
||||||
|
'item_no',
|
||||||
|
'qty',
|
||||||
|
'image',
|
||||||
|
];
|
||||||
|
|
||||||
|
|
||||||
$consumables = Company::scopeCompanyables(
|
$consumables = Company::scopeCompanyables(
|
||||||
Consumable::select('consumables.*')
|
Consumable::select('consumables.*')
|
||||||
->with('company', 'location', 'category', 'users', 'manufacturer')
|
->with('company', 'location', 'category', 'users', 'manufacturer')
|
||||||
|
@ -62,12 +82,14 @@ class ConsumablesController extends Controller
|
||||||
// Check to make sure the limit is not higher than the max allowed
|
// Check to make sure the limit is not higher than the max allowed
|
||||||
((config('app.max_results') >= $request->input('limit')) && ($request->filled('limit'))) ? $limit = $request->input('limit') : $limit = config('app.max_results');
|
((config('app.max_results') >= $request->input('limit')) && ($request->filled('limit'))) ? $limit = $request->input('limit') : $limit = config('app.max_results');
|
||||||
|
|
||||||
$allowed_columns = ['id','name','order_number','min_amt','purchase_date','purchase_cost','company','category','model_number', 'item_no', 'manufacturer','location','qty','image'];
|
|
||||||
$order = $request->input('order') === 'asc' ? 'asc' : 'desc';
|
$order = $request->input('order') === 'asc' ? 'asc' : 'desc';
|
||||||
$sort = in_array($request->input('sort'), $allowed_columns) ? $request->input('sort') : 'created_at';
|
|
||||||
|
$sort_override = $request->input('sort');
|
||||||
|
$column_sort = in_array($sort_override, $allowed_columns) ? $sort_override : 'created_at';
|
||||||
|
|
||||||
|
|
||||||
switch ($sort) {
|
switch ($sort_override) {
|
||||||
case 'category':
|
case 'category':
|
||||||
$consumables = $consumables->OrderCategory($order);
|
$consumables = $consumables->OrderCategory($order);
|
||||||
break;
|
break;
|
||||||
|
@ -81,7 +103,7 @@ class ConsumablesController extends Controller
|
||||||
$consumables = $consumables->OrderCompany($order);
|
$consumables = $consumables->OrderCompany($order);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
$consumables = $consumables->orderBy($sort, $order);
|
$consumables = $consumables->orderBy($column_sort, $order);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -378,4 +378,17 @@ class Accessory extends SnipeModel
|
||||||
{
|
{
|
||||||
return $query->leftJoin('manufacturers', 'accessories.manufacturer_id', '=', 'manufacturers.id')->orderBy('manufacturers.name', $order);
|
return $query->leftJoin('manufacturers', 'accessories.manufacturer_id', '=', 'manufacturers.id')->orderBy('manufacturers.name', $order);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Query builder scope to order on supplier
|
||||||
|
*
|
||||||
|
* @param \Illuminate\Database\Query\Builder $query Query builder instance
|
||||||
|
* @param text $order Order
|
||||||
|
*
|
||||||
|
* @return \Illuminate\Database\Query\Builder Modified query builder
|
||||||
|
*/
|
||||||
|
public function scopeOrderSupplier($query, $order)
|
||||||
|
{
|
||||||
|
return $query->leftJoin('suppliers', 'accessories.supplier_id', '=', 'suppliers.id')->orderBy('suppliers.name', $order);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue