Add username and custom fields option to custom report

This commit is contained in:
snipe 2016-08-02 15:04:10 -07:00
parent 098e7e4feb
commit 75e0c5565c
2 changed files with 47 additions and 3 deletions

View file

@ -6,7 +6,6 @@ use App\Models\Actionlog;
use App\Models\Asset; use App\Models\Asset;
use App\Models\AssetMaintenance; use App\Models\AssetMaintenance;
use Carbon\Carbon; use Carbon\Carbon;
use Category;
use App\Models\Company; use App\Models\Company;
use Illuminate\Support\Facades\Lang; use Illuminate\Support\Facades\Lang;
use Illuminate\Support\Facades\Log; use Illuminate\Support\Facades\Log;
@ -17,6 +16,7 @@ use League\Csv\Reader;
use App\Models\License; use App\Models\License;
use App\Models\Location; use App\Models\Location;
use App\Models\AssetModel; use App\Models\AssetModel;
use App\Models\CustomField;
use Redirect; use Redirect;
use App\Models\Setting; use App\Models\Setting;
use App\Models\User; use App\Models\User;
@ -415,8 +415,8 @@ class ReportsController extends Controller
*/ */
public function getCustomReport() public function getCustomReport()
{ {
$customfields = CustomField::get();
return View::make('reports/custom'); return View::make('reports/custom')->with('customfields',$customfields);
} }
/** /**
@ -430,6 +430,7 @@ class ReportsController extends Controller
public function postCustom() public function postCustom()
{ {
$assets = Asset::orderBy('created_at', 'DESC')->get(); $assets = Asset::orderBy('created_at', 'DESC')->get();
$customfields = CustomField::get();
$rows = [ ]; $rows = [ ];
$header = [ ]; $header = [ ];
@ -484,6 +485,13 @@ class ReportsController extends Controller
$header[] = 'Diff'; $header[] = 'Diff';
} }
foreach ($customfields as $customfield) {
if (e(Input::get($customfield->db_column_name())) == '1') {
$header[] = $customfield->name;
}
}
$header = array_map('trim', $header); $header = array_map('trim', $header);
$rows[] = implode($header, ','); $rows[] = implode($header, ',');
@ -562,6 +570,16 @@ class ReportsController extends Controller
$row[] = ''; // Empty string if unassigned $row[] = ''; // Empty string if unassigned
} }
} }
if (e(Input::get('username')) == '1') {
if ($asset->assigned_to > 0) {
$user = User::find($asset->assigned_to);
$row[] = '"' .e($user-username). '"';
} else {
$row[] = ''; // Empty string if unassigned
}
}
if (e(Input::get('status')) == '1') { if (e(Input::get('status')) == '1') {
if (( $asset->status_id == '0' ) && ( $asset->assigned_to == '0' )) { if (( $asset->status_id == '0' ) && ( $asset->assigned_to == '0' )) {
$row[] = trans('general.ready_to_deploy'); $row[] = trans('general.ready_to_deploy');
@ -588,6 +606,15 @@ class ReportsController extends Controller
$row[] = '"' . number_format($depreciation, 2) . '"'; $row[] = '"' . number_format($depreciation, 2) . '"';
$row[] = '"' . number_format($asset->purchase_cost - $depreciation, 2) . '"'; $row[] = '"' . number_format($asset->purchase_cost - $depreciation, 2) . '"';
} }
foreach ($customfields as $customfield) {
$column_name = $customfield->db_column_name();
if (e(Input::get($customfield->db_column_name())) == '1') {
$row[] = $asset->$column_name;
}
}
$rows[] = implode($row, ','); $rows[] = implode($row, ',');
} }

View file

@ -101,6 +101,14 @@
{{ trans('admin/licenses/table.assigned_to') }} {{ trans('admin/licenses/table.assigned_to') }}
</label> </label>
</div> </div>
<div class="checkbox col-md-12">
<label>
{{ Form::checkbox('username', '1') }}
{{ trans('admin/users/table.username') }}
</label>
</div>
<div class="checkbox col-md-12"> <div class="checkbox col-md-12">
<label> <label>
{{ Form::checkbox('status', '1') }} {{ Form::checkbox('status', '1') }}
@ -119,6 +127,15 @@
{{ trans('general.depreciation') }} {{ trans('general.depreciation') }}
</label> </label>
</div> </div>
@foreach ($customfields as $customfield)
<div class="checkbox col-md-12">
<label>
{{ Form::checkbox($customfield->db_column_name(), '1') }}
{{ $customfield->name }}
</label>
</div>
@endforeach
</div> </div>