mirror of
https://github.com/snipe/snipe-it.git
synced 2024-12-31 16:37:27 -08:00
Merge remote-tracking branch 'origin/develop'
This commit is contained in:
commit
4cb9c25e83
|
@ -136,68 +136,6 @@ class AssetsController extends Controller
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($request->filled('status_id')) {
|
|
||||||
$assets->where('assets.status_id', '=', $request->input('status_id'));
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($request->filled('asset_tag')) {
|
|
||||||
$assets->where('assets.asset_tag', '=', $request->input('asset_tag'));
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($request->filled('serial')) {
|
|
||||||
$assets->where('assets.serial', '=', $request->input('serial'));
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($request->input('requestable') == 'true') {
|
|
||||||
$assets->where('assets.requestable', '=', '1');
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($request->filled('model_id')) {
|
|
||||||
$assets->InModelList([$request->input('model_id')]);
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($request->filled('category_id')) {
|
|
||||||
$assets->InCategory($request->input('category_id'));
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($request->filled('location_id')) {
|
|
||||||
$assets->where('assets.location_id', '=', $request->input('location_id'));
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($request->filled('rtd_location_id')) {
|
|
||||||
$assets->where('assets.rtd_location_id', '=', $request->input('rtd_location_id'));
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($request->filled('supplier_id')) {
|
|
||||||
$assets->where('assets.supplier_id', '=', $request->input('supplier_id'));
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($request->filled('asset_eol_date')) {
|
|
||||||
$assets->where('assets.asset_eol_date', '=', $request->input('asset_eol_date'));
|
|
||||||
}
|
|
||||||
|
|
||||||
if (($request->filled('assigned_to')) && ($request->filled('assigned_type'))) {
|
|
||||||
$assets->where('assets.assigned_to', '=', $request->input('assigned_to'))
|
|
||||||
->where('assets.assigned_type', '=', $request->input('assigned_type'));
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($request->filled('company_id')) {
|
|
||||||
$assets->where('assets.company_id', '=', $request->input('company_id'));
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($request->filled('manufacturer_id')) {
|
|
||||||
$assets->ByManufacturer($request->input('manufacturer_id'));
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($request->filled('depreciation_id')) {
|
|
||||||
$assets->ByDepreciationId($request->input('depreciation_id'));
|
|
||||||
}
|
|
||||||
|
|
||||||
if ($request->filled('byod')) {
|
|
||||||
$assets->where('assets.byod', '=', $request->input('byod'));
|
|
||||||
}
|
|
||||||
|
|
||||||
$request->filled('order_number') ? $assets = $assets->where('assets.order_number', '=', e($request->get('order_number'))) : '';
|
|
||||||
|
|
||||||
// Make sure the offset and limit are actually integers and do not exceed system limits
|
// Make sure the offset and limit are actually integers and do not exceed system limits
|
||||||
$offset = ($request->input('offset') > $assets->count()) ? $assets->count() : abs($request->input('offset'));
|
$offset = ($request->input('offset') > $assets->count()) ? $assets->count() : abs($request->input('offset'));
|
||||||
|
@ -300,6 +238,71 @@ class AssetsController extends Controller
|
||||||
$assets->TextSearch($request->input('search'));
|
$assets->TextSearch($request->input('search'));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Leave these under the TextSearch scope, else the fuzziness will override the specific ID (status ID, etc) requested
|
||||||
|
if ($request->filled('status_id')) {
|
||||||
|
$assets->where('assets.status_id', '=', $request->input('status_id'));
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($request->filled('asset_tag')) {
|
||||||
|
$assets->where('assets.asset_tag', '=', $request->input('asset_tag'));
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($request->filled('serial')) {
|
||||||
|
$assets->where('assets.serial', '=', $request->input('serial'));
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($request->input('requestable') == 'true') {
|
||||||
|
$assets->where('assets.requestable', '=', '1');
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($request->filled('model_id')) {
|
||||||
|
$assets->InModelList([$request->input('model_id')]);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($request->filled('category_id')) {
|
||||||
|
$assets->InCategory($request->input('category_id'));
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($request->filled('location_id')) {
|
||||||
|
$assets->where('assets.location_id', '=', $request->input('location_id'));
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($request->filled('rtd_location_id')) {
|
||||||
|
$assets->where('assets.rtd_location_id', '=', $request->input('rtd_location_id'));
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($request->filled('supplier_id')) {
|
||||||
|
$assets->where('assets.supplier_id', '=', $request->input('supplier_id'));
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($request->filled('asset_eol_date')) {
|
||||||
|
$assets->where('assets.asset_eol_date', '=', $request->input('asset_eol_date'));
|
||||||
|
}
|
||||||
|
|
||||||
|
if (($request->filled('assigned_to')) && ($request->filled('assigned_type'))) {
|
||||||
|
$assets->where('assets.assigned_to', '=', $request->input('assigned_to'))
|
||||||
|
->where('assets.assigned_type', '=', $request->input('assigned_type'));
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($request->filled('company_id')) {
|
||||||
|
$assets->where('assets.company_id', '=', $request->input('company_id'));
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($request->filled('manufacturer_id')) {
|
||||||
|
$assets->ByManufacturer($request->input('manufacturer_id'));
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($request->filled('depreciation_id')) {
|
||||||
|
$assets->ByDepreciationId($request->input('depreciation_id'));
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($request->filled('byod')) {
|
||||||
|
$assets->where('assets.byod', '=', $request->input('byod'));
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($request->filled('order_number')) {
|
||||||
|
$assets->where('assets.order_number', '=', $request->get('order_number'));
|
||||||
|
}
|
||||||
|
|
||||||
// This is kinda gross, but we need to do this because the Bootstrap Tables
|
// This is kinda gross, but we need to do this because the Bootstrap Tables
|
||||||
// API passes custom field ordering as custom_fields.fieldname, and we have to strip
|
// API passes custom field ordering as custom_fields.fieldname, and we have to strip
|
||||||
|
|
|
@ -12,7 +12,10 @@ class AssetImporter extends ItemImporter
|
||||||
public function __construct($filename)
|
public function __construct($filename)
|
||||||
{
|
{
|
||||||
parent::__construct($filename);
|
parent::__construct($filename);
|
||||||
$this->defaultStatusLabelId = Statuslabel::first()->id;
|
|
||||||
|
if (!is_null(Statuslabel::first())) {
|
||||||
|
$this->defaultStatusLabelId = Statuslabel::first()->id;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
protected function handle($row)
|
protected function handle($row)
|
||||||
|
|
|
@ -1566,7 +1566,7 @@ class Asset extends Depreciable
|
||||||
*/
|
*/
|
||||||
public function scopeOrderModelNumber($query, $order)
|
public function scopeOrderModelNumber($query, $order)
|
||||||
{
|
{
|
||||||
return $query->join('models', 'assets.model_id', '=', 'models.id')->orderBy('models.model_number', $order);
|
return $query->leftJoin('models as model_number_sort', 'assets.model_id', '=', 'models.id')->orderBy('models.model_number', $order);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -44,13 +44,13 @@ class AssetAuditPresenter extends Presenter
|
||||||
'visible' => true,
|
'visible' => true,
|
||||||
'formatter' => 'hardwareLinkFormatter',
|
'formatter' => 'hardwareLinkFormatter',
|
||||||
], [
|
], [
|
||||||
'field' => 'image',
|
'field' => 'file',
|
||||||
'searchable' => false,
|
'searchable' => false,
|
||||||
'sortable' => true,
|
'sortable' => true,
|
||||||
'switchable' => true,
|
'switchable' => true,
|
||||||
'title' => trans('admin/hardware/table.image'),
|
'title' => trans('admin/hardware/table.image'),
|
||||||
'visible' => false,
|
'visible' => false,
|
||||||
'formatter' => 'imageFormatter',
|
'formatter' => 'auditImageFormatter',
|
||||||
], [
|
], [
|
||||||
'field' => 'asset_tag',
|
'field' => 'asset_tag',
|
||||||
'searchable' => true,
|
'searchable' => true,
|
||||||
|
|
|
@ -652,11 +652,15 @@
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function auditImageFormatter(value){
|
||||||
|
if (value){
|
||||||
|
return '<a href="' + value.url + '" data-toggle="lightbox" data-type="image"><img src="' + value.url + '" style="max-height: {{ $snipeSettings->thumbnail_max_h }}px; width: auto;" class="img-responsive"></a>'
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
function imageFormatter(value, row) {
|
function imageFormatter(value, row) {
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
if (value) {
|
if (value) {
|
||||||
|
|
||||||
// This is a clunky override to handle unusual API responses where we're presenting a link instead of an array
|
// This is a clunky override to handle unusual API responses where we're presenting a link instead of an array
|
||||||
|
|
|
@ -34,7 +34,7 @@
|
||||||
|
|
||||||
<thead>
|
<thead>
|
||||||
<tr>
|
<tr>
|
||||||
<th class="col-sm-1" data-field="image" data-visible="false" data-formatter="imageFormatter">{{ trans('admin/hardware/table.image') }}</th>
|
<th class="col-sm-1" data-field="file" data-visible="false" data-formatter="auditImageFormatter">{{ trans('admin/hardware/table.image') }}</th>
|
||||||
<th class="col-sm-2" data-field="created_at" data-formatter="dateDisplayFormatter">{{ trans('general.audit') }}</th>
|
<th class="col-sm-2" data-field="created_at" data-formatter="dateDisplayFormatter">{{ trans('general.audit') }}</th>
|
||||||
<th class="col-sm-2" data-field="admin" data-formatter="usersLinkObjFormatter">{{ trans('general.admin') }}</th>
|
<th class="col-sm-2" data-field="admin" data-formatter="usersLinkObjFormatter">{{ trans('general.admin') }}</th>
|
||||||
<th class="col-sm-2" data-field="item" data-formatter="polymorphicItemFormatter">{{ trans('general.item') }}</th>
|
<th class="col-sm-2" data-field="item" data-formatter="polymorphicItemFormatter">{{ trans('general.item') }}</th>
|
||||||
|
|
Loading…
Reference in a new issue