2017-01-24 18:57:33 -08:00
|
|
|
<?php
|
|
|
|
namespace App\Http\Transformers;
|
|
|
|
|
|
|
|
use App\Models\License;
|
2017-02-08 18:24:55 -08:00
|
|
|
use Gate;
|
2017-01-24 18:57:33 -08:00
|
|
|
use Illuminate\Database\Eloquent\Collection;
|
2017-02-10 18:43:30 -08:00
|
|
|
use App\Helpers\Helper;
|
2017-01-24 18:57:33 -08:00
|
|
|
|
|
|
|
class LicensesTransformer
|
|
|
|
{
|
|
|
|
|
|
|
|
public function transformLicenses (Collection $licenses, $total)
|
|
|
|
{
|
|
|
|
$array = array();
|
|
|
|
foreach ($licenses as $license) {
|
|
|
|
$array[] = self::transformLicense($license);
|
|
|
|
}
|
|
|
|
return (new DatatablesTransformer)->transformDatatables($array, $total);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function transformLicense (License $license)
|
|
|
|
{
|
|
|
|
$array = [
|
2017-07-25 23:40:30 -07:00
|
|
|
'id' => (int) $license->id,
|
2017-01-24 19:24:47 -08:00
|
|
|
'name' => e($license->name),
|
2017-07-25 23:40:30 -07:00
|
|
|
'company' => ($license->company) ? ['id' => (int) $license->company->id,'name'=> e($license->company->name)] : null,
|
|
|
|
'manufacturer' => ($license->manufacturer) ? ['id' => (int) $license->manufacturer->id,'name'=> e($license->manufacturer->name)] : null,
|
2017-02-10 18:43:30 -08:00
|
|
|
'product_key' => e($license->serial),
|
|
|
|
'order_number' => e($license->order_number),
|
|
|
|
'purchase_order' => e($license->purchase_order),
|
2017-03-03 17:53:42 -08:00
|
|
|
'purchase_date' => Helper::getFormattedDateObject($license->purchase_date, 'date'),
|
2017-01-24 19:24:47 -08:00
|
|
|
'purchase_cost' => e($license->purchase_cost),
|
|
|
|
'notes' => e($license->notes),
|
2017-03-03 17:53:42 -08:00
|
|
|
'expiration_date' => Helper::getFormattedDateObject($license->expiration_date, 'date'),
|
2017-09-25 21:40:43 -07:00
|
|
|
'total_seats' => (int) $license->seats,
|
2017-11-02 18:20:42 -07:00
|
|
|
'remaining_qty' => (int) ($license->seats - $license->licenseseats_count),
|
2017-03-11 02:52:50 -08:00
|
|
|
'license_name' => e($license->license_name),
|
2017-01-24 19:24:47 -08:00
|
|
|
'license_email' => e($license->license_email),
|
|
|
|
'maintained' => ($license->maintained == 1) ? true : false,
|
2017-07-25 23:40:30 -07:00
|
|
|
'supplier' => ($license->supplier) ? ['id' => (int) $license->supplier->id,'name'=> e($license->supplier->name)] : null,
|
2017-03-03 17:53:42 -08:00
|
|
|
'created_at' => Helper::getFormattedDateObject($license->created_at, 'datetime'),
|
|
|
|
'updated_at' => Helper::getFormattedDateObject($license->updated_at, 'datetime'),
|
2017-11-02 18:20:42 -07:00
|
|
|
'user_can_checkout' => (bool) (($license->seats - $license->licenseseats_count) > 0),
|
2017-01-24 18:57:33 -08:00
|
|
|
];
|
|
|
|
|
2017-02-08 18:24:55 -08:00
|
|
|
$permissions_array['available_actions'] = [
|
|
|
|
'checkout' => Gate::allows('checkout', License::class) ? true : false,
|
|
|
|
'checkin' => Gate::allows('checkin', License::class) ? true : false,
|
2017-07-07 18:45:49 -07:00
|
|
|
'clone' => Gate::allows('create', License::class) ? true : false,
|
2017-02-08 18:24:55 -08:00
|
|
|
'update' => Gate::allows('update', License::class) ? true : false,
|
|
|
|
'delete' => Gate::allows('delete', License::class) ? true : false,
|
|
|
|
];
|
|
|
|
|
|
|
|
$array += $permissions_array;
|
|
|
|
|
2017-01-24 18:57:33 -08:00
|
|
|
return $array;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function transformAssetsDatatable($licenses) {
|
|
|
|
return (new DatatablesTransformer)->transformDatatables($licenses);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}
|