mirror of
https://github.com/snipe/snipe-it.git
synced 2025-01-12 14:27:33 -08:00
Add last checkin options to report front end
This commit is contained in:
parent
6fc06f2ee1
commit
c332b98456
|
@ -545,6 +545,10 @@ class ReportsController extends Controller
|
||||||
$header[] = trans('admin/hardware/table.checkout_date');
|
$header[] = trans('admin/hardware/table.checkout_date');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ($request->filled('checkin_date')) {
|
||||||
|
$header[] = trans('admin/hardware/table.last_checkin_date');
|
||||||
|
}
|
||||||
|
|
||||||
if ($request->filled('expected_checkin')) {
|
if ($request->filled('expected_checkin')) {
|
||||||
$header[] = trans('admin/hardware/form.expected_checkin');
|
$header[] = trans('admin/hardware/form.expected_checkin');
|
||||||
}
|
}
|
||||||
|
@ -651,6 +655,13 @@ class ReportsController extends Controller
|
||||||
$assets->whereBetween('assets.last_checkout', [$checkout_start, $checkout_end]);
|
$assets->whereBetween('assets.last_checkout', [$checkout_start, $checkout_end]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (($request->filled('checkin_date_start')) && ($request->filled('checkin_date_end'))) {
|
||||||
|
$assets->whereBetween('last_checkin', [
|
||||||
|
Carbon::parse($request->input('checkin_date_start'))->startOfDay(),
|
||||||
|
Carbon::parse($request->input('checkin_date_end'))->endOfDay(),
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
if (($request->filled('expected_checkin_start')) && ($request->filled('expected_checkin_end'))) {
|
if (($request->filled('expected_checkin_start')) && ($request->filled('expected_checkin_end'))) {
|
||||||
$assets->whereBetween('assets.expected_checkin', [$request->input('expected_checkin_start'), $request->input('expected_checkin_end')]);
|
$assets->whereBetween('assets.expected_checkin', [$request->input('expected_checkin_start'), $request->input('expected_checkin_end')]);
|
||||||
}
|
}
|
||||||
|
@ -835,6 +846,12 @@ class ReportsController extends Controller
|
||||||
$row[] = ($asset->last_checkout) ? $asset->last_checkout : '';
|
$row[] = ($asset->last_checkout) ? $asset->last_checkout : '';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ($request->filled('checkin_date')) {
|
||||||
|
$row[] = ($asset->last_checkin)
|
||||||
|
? Carbon::parse($asset->last_checkin)->format('Y-m-d')
|
||||||
|
: '';
|
||||||
|
}
|
||||||
|
|
||||||
if ($request->filled('expected_checkin')) {
|
if ($request->filled('expected_checkin')) {
|
||||||
$row[] = ($asset->expected_checkin) ? $asset->expected_checkin : '';
|
$row[] = ($asset->expected_checkin) ? $asset->expected_checkin : '';
|
||||||
}
|
}
|
||||||
|
|
|
@ -14,6 +14,7 @@ return [
|
||||||
'dl_csv' => 'Download CSV',
|
'dl_csv' => 'Download CSV',
|
||||||
'eol' => 'EOL',
|
'eol' => 'EOL',
|
||||||
'id' => 'ID',
|
'id' => 'ID',
|
||||||
|
'last_checkin_date' => 'Last Checkin Date',
|
||||||
'location' => 'Location',
|
'location' => 'Location',
|
||||||
'purchase_cost' => 'Cost',
|
'purchase_cost' => 'Cost',
|
||||||
'purchase_date' => 'Purchased',
|
'purchase_date' => 'Purchased',
|
||||||
|
|
|
@ -141,6 +141,11 @@
|
||||||
{{ trans('admin/hardware/table.checkout_date') }}
|
{{ trans('admin/hardware/table.checkout_date') }}
|
||||||
</label>
|
</label>
|
||||||
|
|
||||||
|
<label class="form-control">
|
||||||
|
{{ Form::checkbox('checkin_date', '1', '1') }}
|
||||||
|
{{ trans('admin/hardware/table.last_checkin_date') }}
|
||||||
|
</label>
|
||||||
|
|
||||||
<label class="form-control">
|
<label class="form-control">
|
||||||
{{ Form::checkbox('expected_checkin', '1', '1') }}
|
{{ Form::checkbox('expected_checkin', '1', '1') }}
|
||||||
{{ trans('admin/hardware/form.expected_checkin') }}
|
{{ trans('admin/hardware/form.expected_checkin') }}
|
||||||
|
@ -289,6 +294,16 @@
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<!-- Last Checkin Date -->
|
||||||
|
<div class="form-group checkin-range">
|
||||||
|
<label for="checkin_date" class="col-md-3 control-label">{{ trans('admin/hardware/table.last_checkin_date') }}</label>
|
||||||
|
<div class="input-daterange input-group col-md-6" id="datepicker">
|
||||||
|
<input type="text" class="form-control" name="checkin_date_start" aria-label="checkin_date_start">
|
||||||
|
<span class="input-group-addon">{{ strtolower(trans('general.to')) }}</span>
|
||||||
|
<input type="text" class="form-control" name="checkin_date_end" aria-label="checkin_date_end">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
<!-- Expected Checkin Date -->
|
<!-- Expected Checkin Date -->
|
||||||
<div class="form-group expected_checkin-range">
|
<div class="form-group expected_checkin-range">
|
||||||
<label for="expected_checkin_start" class="col-md-3 control-label">{{ trans('admin/hardware/form.expected_checkin') }}</label>
|
<label for="expected_checkin_start" class="col-md-3 control-label">{{ trans('admin/hardware/form.expected_checkin') }}</label>
|
||||||
|
@ -381,6 +396,13 @@
|
||||||
format: 'yyyy-mm-dd'
|
format: 'yyyy-mm-dd'
|
||||||
});
|
});
|
||||||
|
|
||||||
|
$('.checkin-range .input-daterange').datepicker({
|
||||||
|
clearBtn: true,
|
||||||
|
todayHighlight: true,
|
||||||
|
endDate: '0d',
|
||||||
|
format: 'yyyy-mm-dd'
|
||||||
|
});
|
||||||
|
|
||||||
$('.expected_checkin-range .input-daterange').datepicker({
|
$('.expected_checkin-range .input-daterange').datepicker({
|
||||||
clearBtn: true,
|
clearBtn: true,
|
||||||
todayHighlight: true,
|
todayHighlight: true,
|
||||||
|
|
|
@ -107,4 +107,29 @@ class CustomReportTest extends TestCase
|
||||||
->assertDontSeeTextInStreamedResponse('Asset A')
|
->assertDontSeeTextInStreamedResponse('Asset A')
|
||||||
->assertSeeTextInStreamedResponse('Asset B');
|
->assertSeeTextInStreamedResponse('Asset B');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function testCanLimitAssetsByLastCheckIn()
|
||||||
|
{
|
||||||
|
Asset::factory()->create(['name' => 'Asset A', 'last_checkin' => '2023-08-01']);
|
||||||
|
Asset::factory()->create(['name' => 'Asset B', 'last_checkin' => '2023-08-02']);
|
||||||
|
Asset::factory()->create(['name' => 'Asset C', 'last_checkin' => '2023-08-03']);
|
||||||
|
Asset::factory()->create(['name' => 'Asset D', 'last_checkin' => '2023-08-04']);
|
||||||
|
Asset::factory()->create(['name' => 'Asset E', 'last_checkin' => '2023-08-05']);
|
||||||
|
|
||||||
|
$this->actingAs(User::factory()->canViewReports()->create())
|
||||||
|
->post('reports/custom', [
|
||||||
|
'asset_name' => '1',
|
||||||
|
'asset_tag' => '1',
|
||||||
|
'serial' => '1',
|
||||||
|
'checkin_date' => '1',
|
||||||
|
'checkin_date_start' => '2023-08-02',
|
||||||
|
'checkin_date_end' => '2023-08-04',
|
||||||
|
])->assertOk()
|
||||||
|
->assertHeader('content-type', 'text/csv; charset=UTF-8')
|
||||||
|
->assertDontSeeTextInStreamedResponse('Asset A')
|
||||||
|
->assertSeeTextInStreamedResponse('Asset B')
|
||||||
|
->assertSeeTextInStreamedResponse('Asset C')
|
||||||
|
->assertSeeTextInStreamedResponse('Asset D')
|
||||||
|
->assertDontSeeTextInStreamedResponse('Asset E');
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue