Merge pull request #19158 from grokability/added-qr-codes-to-non-assets
QR Codes: Added QR codes for non-assets
This commit is contained in:
@@ -358,7 +358,7 @@ class AssetsController extends Controller
|
||||
|
||||
$qr_code = (object) [
|
||||
'display' => $settings->qr_code == '1',
|
||||
'url' => route('qr_code/hardware', $asset),
|
||||
'url' => route('qr_code/common', ['object_type' => 'hardware', 'id' => $asset->id]),
|
||||
];
|
||||
|
||||
$total_maintenance_cost = $asset->maintenances?->sum('cost');
|
||||
|
||||
@@ -0,0 +1,66 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Controllers;
|
||||
|
||||
use App\Helpers\Helper;
|
||||
use App\Models\Setting;
|
||||
use Com\Tecnick\Barcode\Barcode;
|
||||
use Illuminate\Http\Response;
|
||||
use Symfony\Component\HttpFoundation\BinaryFileResponse;
|
||||
|
||||
class QrCodeController extends Controller
|
||||
{
|
||||
public static $map_show_route = [
|
||||
'accessories' => 'accessories.show',
|
||||
'assets' => 'hardware.show',
|
||||
'companies' => 'companies.show',
|
||||
'components' => 'components.show',
|
||||
'consumables' => 'consumables.show',
|
||||
'hardware' => 'hardware.show',
|
||||
'licenses' => 'licenses.show',
|
||||
'locations' => 'locations.show',
|
||||
'models' => 'models.show',
|
||||
'users' => 'users.show',
|
||||
];
|
||||
|
||||
public function show($object_type, $id): Response|BinaryFileResponse|string|bool
|
||||
{
|
||||
$settings = Setting::getSettings();
|
||||
|
||||
if ($settings->label2_2d_type === 'none') {
|
||||
return false;
|
||||
}
|
||||
|
||||
if (! array_key_exists($object_type, self::$map_show_route)) {
|
||||
return $object_type.' is not a valid type.';
|
||||
}
|
||||
|
||||
$object = self::$map_object_type[$object_type]::withTrashed()->find($id);
|
||||
|
||||
if (! $object) {
|
||||
return 'That item is invalid';
|
||||
}
|
||||
|
||||
$this->authorize('view', $object);
|
||||
|
||||
$size = Helper::barcodeDimensions($settings->label2_2d_type);
|
||||
$qr_file = public_path().'/uploads/barcodes/qr-'.str_slug($object_type).'-'.str_slug($id).'.png';
|
||||
|
||||
if (file_exists($qr_file)) {
|
||||
return response()->file($qr_file, ['Content-type' => 'image/png']);
|
||||
}
|
||||
|
||||
$barcode = new Barcode;
|
||||
$barcode_obj = $barcode->getBarcodeObj(
|
||||
$settings->label2_2d_type,
|
||||
route(self::$map_show_route[$object_type], $id),
|
||||
$size['height'],
|
||||
$size['width'],
|
||||
'black',
|
||||
[-2, -2, -2, -2]
|
||||
);
|
||||
file_put_contents($qr_file, $barcode_obj->getPngData());
|
||||
|
||||
return response($barcode_obj->getPngData())->header('Content-type', 'image/png');
|
||||
}
|
||||
}
|
||||
@@ -26,6 +26,7 @@ class AccessoriesTransformer
|
||||
'id' => $accessory->id,
|
||||
'name' => e($accessory->name),
|
||||
'image' => ($accessory->image) ? Storage::disk('public')->url('accessories/'.e($accessory->image)) : null,
|
||||
'qr_code_url' => route('qr_code/common', ['object_type' => 'accessories', 'id' => $accessory->id]),
|
||||
'company' => ($accessory->company) ? [
|
||||
'id' => $accessory->company->id,
|
||||
'name' => e($accessory->company->name),
|
||||
|
||||
@@ -48,6 +48,7 @@ class AssetModelsTransformer
|
||||
'tag_color' => ($assetmodel->manufacturer->tag_color) ? e($assetmodel->manufacturer->tag_color) : null,
|
||||
] : null,
|
||||
'image' => ($assetmodel->image != '') ? Storage::disk('public')->url('models/'.e($assetmodel->image)) : null,
|
||||
'qr_code_url' => route('qr_code/common', ['object_type' => 'models', 'id' => $assetmodel->id]),
|
||||
'model_number' => ($assetmodel->model_number ? e($assetmodel->model_number) : null),
|
||||
'min_amt' => ($assetmodel->min_amt) ? (int) $assetmodel->min_amt : null,
|
||||
|
||||
|
||||
@@ -98,6 +98,7 @@ class AssetsTransformer
|
||||
'tag_color' => ($asset->defaultLoc->tag_color) ? e($asset->defaultLoc->tag_color) : null,
|
||||
] : null,
|
||||
'image' => ($asset->getImageUrl()) ? $asset->getImageUrl() : null,
|
||||
'qr_code_url' => route('qr_code/common', ['object_type' => 'hardware', 'id' => $asset->id]),
|
||||
'qr' => ($setting->qr_code == '1') ? Storage::disk('public')->url('barcodes/qr-'.str_slug($asset->asset_tag).'-'.str_slug($asset->id).'.png') : null,
|
||||
'alt_barcode' => ($setting->alt_barcode_enabled == '1') ? Storage::disk('public')->url('barcodes/'.str_slug($setting->alt_barcode).'-'.str_slug($asset->asset_tag).'.png') : null,
|
||||
'assigned_to' => $this->transformAssignedTo($asset),
|
||||
|
||||
@@ -30,6 +30,7 @@ class CompaniesTransformer
|
||||
'fax' => ($company->fax != '') ? e($company->fax) : null,
|
||||
'email' => ($company->email != '') ? e($company->email) : null,
|
||||
'image' => ($company->image) ? Storage::disk('public')->url('companies/'.e($company->image)) : null,
|
||||
'qr_code_url' => route('qr_code/common', ['object_type' => 'companies', 'id' => $company->id]),
|
||||
'assets_count' => (int) $company->assets_count,
|
||||
'licenses_count' => (int) $company->licenses_count,
|
||||
'accessories_count' => (int) $company->accessories_count,
|
||||
|
||||
@@ -26,6 +26,7 @@ class ComponentsTransformer
|
||||
'id' => (int) $component->id,
|
||||
'name' => e($component->name),
|
||||
'image' => ($component->image) ? Storage::disk('public')->url('components/'.e($component->image)) : null,
|
||||
'qr_code_url' => route('qr_code/common', ['object_type' => 'components', 'id' => $component->id]),
|
||||
'serial' => ($component->serial) ? e($component->serial) : null,
|
||||
'location' => ($component->location) ? [
|
||||
'id' => (int) $component->location->id,
|
||||
|
||||
@@ -25,6 +25,7 @@ class ConsumablesTransformer
|
||||
'id' => (int) $consumable->id,
|
||||
'name' => e($consumable->name),
|
||||
'image' => ($consumable->getImageUrl()) ? ($consumable->getImageUrl()) : null,
|
||||
'qr_code_url' => route('qr_code/common', ['object_type' => 'consumables', 'id' => $consumable->id]),
|
||||
'category' => ($consumable->category) ? [
|
||||
'id' => $consumable->category->id,
|
||||
'name' => e($consumable->category->name),
|
||||
|
||||
@@ -24,6 +24,7 @@ class LicensesTransformer
|
||||
$array = [
|
||||
'id' => (int) $license->id,
|
||||
'name' => e($license->name),
|
||||
'qr_code_url' => route('qr_code/common', ['object_type' => 'licenses', 'id' => $license->id]),
|
||||
'company' => ($license->company) ? ['id' => (int) $license->company->id, 'name' => e($license->company->name)] : null,
|
||||
'manufacturer' => ($license->manufacturer) ? [
|
||||
'id' => (int) $license->manufacturer->id,
|
||||
|
||||
@@ -39,6 +39,7 @@ class LocationsTransformer
|
||||
'id' => (int) $location->id,
|
||||
'name' => e($location->name),
|
||||
'image' => ($location->image) ? Storage::disk('public')->url('locations/'.e($location->image)) : null,
|
||||
'qr_code_url' => route('qr_code/common', ['object_type' => 'locations', 'id' => $location->id]),
|
||||
'address' => ($location->address) ? e($location->address) : null,
|
||||
'address2' => ($location->address2) ? e($location->address2) : null,
|
||||
'city' => ($location->city) ? e($location->city) : null,
|
||||
|
||||
@@ -21,7 +21,6 @@ class UsersTransformer
|
||||
|
||||
public function transformUser(User $user)
|
||||
{
|
||||
|
||||
$role = null;
|
||||
if ($user->isSuperUser()) {
|
||||
$role = 'superadmin';
|
||||
@@ -31,6 +30,7 @@ class UsersTransformer
|
||||
$array = [
|
||||
'id' => (int) $user->id,
|
||||
'avatar' => e($user->present()->gravatar) ?? null,
|
||||
'qr_code_url' => route('qr_code/common', ['object_type' => 'users', 'id' => $user->id]),
|
||||
'name' => e($user->getFullNameAttribute()) ?? null,
|
||||
'first_name' => e($user->first_name) ?? null,
|
||||
'last_name' => e($user->last_name) ?? null,
|
||||
|
||||
@@ -216,6 +216,11 @@ class Setting extends Model
|
||||
return $custom_css;
|
||||
}
|
||||
|
||||
public function isQrEnabled(): bool
|
||||
{
|
||||
return $this->qr_code == '1' || $this->label2_2d_type !== 'none';
|
||||
}
|
||||
|
||||
/**
|
||||
* Converts bytes into human readable file size.
|
||||
*
|
||||
|
||||
Reference in New Issue
Block a user