Merge pull request #14587 from Godmartinz/License-export-button

Added a License Export function and button
This commit is contained in:
snipe 2024-04-24 04:42:56 +01:00 committed by GitHub
commit 2439758ef3
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
6 changed files with 135 additions and 3 deletions

View file

@ -11,6 +11,7 @@ use App\Models\User;
use Illuminate\Http\Request; use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth; use Illuminate\Support\Facades\Auth;
use Illuminate\Support\Facades\DB; use Illuminate\Support\Facades\DB;
use Symfony\Component\HttpFoundation\StreamedResponse;
/** /**
* This controller handles all actions related to Licenses for * This controller handles all actions related to Licenses for
@ -289,4 +290,106 @@ class LicensesController extends Controller
->with('item', $license) ->with('item', $license)
->with('maintained_list', $maintained_list); ->with('maintained_list', $maintained_list);
} }
/**
* Exports Licenses to CSV
*
* @author [G. Martinez]
* @since [v6.3]
* @return StreamedResponse
* @throws \Illuminate\Auth\Access\AuthorizationException
*/
public function getExportLicensesCsv()
{
$this->authorize('view', License::class);
\Debugbar::disable();
$response = new StreamedResponse(function () {
// Open output stream
$handle = fopen('php://output', 'w');
$licenses= License::with('company',
'manufacturer',
'category',
'supplier',
'adminuser',
'assignedusers')
->orderBy('created_at', 'DESC');
Company::scopeCompanyables($licenses)
->chunk(500, function ($licenses) use ($handle) {
$headers = [
// strtolower to prevent Excel from trying to open it as a SYLK file
strtolower(trans('general.id')),
trans('general.company'),
trans('general.name'),
trans('general.serial_number'),
trans('general.purchase_date'),
trans('general.purchase_cost'),
trans('general.order_number'),
trans('general.licenses_available'),
trans('admin/licenses/table.seats'),
trans('general.created_by'),
trans('general.depreciation'),
trans('general.updated_at'),
trans('admin/licenses/table.deleted_at'),
trans('general.email'),
trans('admin/hardware/form.fully_depreciated'),
trans('general.supplier'),
trans('admin/licenses/form.expiration'),
trans('admin/licenses/form.purchase_order'),
trans('admin/licenses/form.termination_date'),
trans('admin/licenses/form.maintained'),
trans('general.manufacturer'),
trans('general.category'),
trans('general.min_amt'),
trans('admin/licenses/form.reassignable'),
trans('general.notes'),
trans('general.created_at'),
];
fputcsv($handle, $headers);
foreach ($licenses as $license) {
// Add a new row with data
$values = [
$license->id,
$license->company ? $license->company->name: '',
$license->name,
$license->serial,
$license->purchase_date,
$license->purchase_cost,
$license->order_number,
$license->free_seat_count,
$license->seats,
$license->adminuser->present()->fullName(),
$license->depreciation ? $license->depreciation->name: '',
$license->updated_at,
$license->deleted_at,
$license->email,
( $license->depreciate == '1') ? trans('general.yes') : trans('general.no'),
($license->supplier) ? $license->supplier->name: '',
$license->expiration_date,
$license->purchase_order,
$license->termination_date,
( $license->maintained == '1') ? trans('general.yes') : trans('general.no'),
$license->manufacturer ? $license->manufacturer->name: '',
$license->category ? $license->category->name: '',
$license->min_amt,
( $license->reassignable == '1') ? trans('general.yes') : trans('general.no'),
$license->notes,
$license->created_at,
];
fputcsv($handle, $values);
}
});
// Close the output stream
fclose($handle);
}, 200, [
'Content-Type' => 'text/csv; charset=UTF-8',
'Content-Disposition' => 'attachment; filename="licenses-'.date('Y-m-d-his').'.csv"',
]);
return $response;
}
} }

View file

@ -81,6 +81,7 @@ class License extends Depreciable
'serial', 'serial',
'supplier_id', 'supplier_id',
'termination_date', 'termination_date',
'free_seat_count',
'user_id', 'user_id',
'min_amt', 'min_amt',
]; ];
@ -114,6 +115,7 @@ class License extends Depreciable
'category' => ['name'], 'category' => ['name'],
'depreciation' => ['name'], 'depreciation' => ['name'],
]; ];
protected $appends = ['free_seat_count'];
/** /**
* Update seat counts when the license is updated * Update seat counts when the license is updated
@ -280,6 +282,16 @@ class License extends Depreciable
} }
$this->attributes['termination_date'] = $value; $this->attributes['termination_date'] = $value;
} }
/**
* Sets free_seat_count attribute
*
* @author G. Martinez
* @since [v6.3]
* @return mixed
*/
public function getFreeSeatCountAttribute(){
return $this->attributes['free_seat_count'] = $this->remaincount();
}
/** /**
* Establishes the license -> company relationship * Establishes the license -> company relationship
@ -502,7 +514,13 @@ class License extends Depreciable
->whereNull('deleted_at') ->whereNull('deleted_at')
->count(); ->count();
} }
/**
* Returns the available seats remaining
*
* @author A. Gianotto <snipe@snipe.net>
* @since [v2.0]
* @return int
*/
/** /**
* Returns the number of total available seats for this license * Returns the number of total available seats for this license
@ -579,7 +597,7 @@ class License extends Depreciable
$taken = $this->assigned_seats_count; $taken = $this->assigned_seats_count;
$diff = ($total - $taken); $diff = ($total - $taken);
return $diff; return (int) $diff;
} }
/** /**

View file

@ -4,6 +4,7 @@ return array(
'assigned_to' => 'Assigned To', 'assigned_to' => 'Assigned To',
'checkout' => 'In/Out', 'checkout' => 'In/Out',
'deleted_at' => 'Deleted at',
'id' => 'ID', 'id' => 'ID',
'license_email' => 'License Email', 'license_email' => 'License Email',
'license_name' => 'Licensed To', 'license_name' => 'Licensed To',

View file

@ -176,7 +176,7 @@ return [
'last_name' => 'Last Name', 'last_name' => 'Last Name',
'license' => 'License', 'license' => 'License',
'license_report' => 'License Report', 'license_report' => 'License Report',
'licenses_available' => 'licenses available', 'licenses_available' => 'Licenses available',
'licenses' => 'Licenses', 'licenses' => 'Licenses',
'list_all' => 'List All', 'list_all' => 'List All',
'loading' => 'Loading... please wait....', 'loading' => 'Loading... please wait....',

View file

@ -13,6 +13,9 @@
{{ trans('general.create') }} {{ trans('general.create') }}
</a> </a>
@endcan @endcan
@can('view', \App\Models\License::class)
<a class="btn btn-default pull-right" href="{{ route('licenses.export') }}" style="margin-right: 5px;">{{ trans('general.export') }}</a>
@endcan
@stop @stop
{{-- Page content --}} {{-- Page content --}}

View file

@ -48,6 +48,13 @@ Route::group(['prefix' => 'licenses', 'middleware' => ['auth']], function () {
'{licenseId}/showfile/{fileId}/{download?}', '{licenseId}/showfile/{fileId}/{download?}',
[Licenses\LicenseFilesController::class, 'show'] [Licenses\LicenseFilesController::class, 'show']
)->name('show.licensefile'); )->name('show.licensefile');
Route::get(
'export',
[
Licenses\LicensesController::class,
'getExportLicensesCsv'
]
)->name('licenses.export');
}); });
Route::resource('licenses', Licenses\LicensesController::class, [ Route::resource('licenses', Licenses\LicensesController::class, [