snipe-it/app/Models/ReportTemplate.php

144 lines
3.8 KiB
PHP
Raw Normal View History

2023-08-23 16:32:19 -07:00
<?php
namespace App\Models;
use Illuminate\Database\Eloquent\Builder;
2023-08-23 16:32:19 -07:00
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model;
2024-01-17 16:25:28 -08:00
use Illuminate\Database\Eloquent\Relations\BelongsTo;
2023-12-11 16:20:36 -08:00
use Watson\Validating\ValidatingTrait;
2023-08-23 16:32:19 -07:00
2023-12-18 12:55:48 -08:00
class ReportTemplate extends Model
2023-08-23 16:32:19 -07:00
{
use HasFactory;
2023-12-11 16:20:36 -08:00
use ValidatingTrait;
2023-08-24 11:32:37 -07:00
/**
* The attributes that should be cast.
*
* @var array
*/
protected $casts = [
'options' => 'array',
];
2023-08-28 16:26:31 -07:00
protected $fillable = [
'user_id',
'name',
'options',
];
2023-12-11 16:20:36 -08:00
protected $rules = [
2023-12-18 12:55:48 -08:00
'name' => 'required|unique:report_templates,name',
2023-12-11 16:20:36 -08:00
'options' => 'array',
];
2023-12-11 14:19:03 -08:00
protected static function booted()
{
// Scope to current user
static::addGlobalScope('current_user', function (Builder $builder) {
if (auth()->check()) {
$builder->where('user_id', auth()->id());
}
});
}
2024-01-17 16:25:28 -08:00
public function user(): BelongsTo
{
return $this->belongsTo(User::class);
}
2023-12-11 11:27:56 -08:00
public function checkmarkValue(string $property): string
{
// Assuming we're using the null object pattern,
// return the default value if the object is not saved yet.
if (is_null($this->id)) {
return '1';
}
// Return the property's value if it exists
// and return the default value if not.
return $this->options[$property] ?? '0';
}
2023-12-21 18:07:46 -08:00
public function radioValue(string $property, $value, $isDefault = false): bool
{
// @todo: this method feels more like "radioShouldBeChecked" or something...
2023-12-11 11:27:56 -08:00
// @todo: improve the variable names...
2023-12-21 18:07:46 -08:00
$propertyExists = array_has($this->options, $property);
if (!$propertyExists && $isDefault) {
return true;
}
if ($propertyExists && $this->options[$property] === $value) {
return true;
2023-12-21 12:02:54 -08:00
}
2023-12-21 18:07:46 -08:00
return false;
}
public function selectValue(string $property, string $model = null)
2023-11-30 16:57:21 -08:00
{
if (!isset($this->options[$property])) {
return null;
}
2024-01-11 13:34:20 -08:00
$value = $this->options[$property];
if (is_array($value)) {
$value = $value[0];
}
// If a model is provided then we should ensure we only return
// the value if the model still exists.
if ($model) {
2024-01-11 13:34:20 -08:00
$foundModel = $model::find($value);
return $foundModel ? $foundModel->id : null;
}
2024-01-11 13:34:20 -08:00
return $value;
2023-11-30 16:57:21 -08:00
}
public function selectValues(string $property, string $model = null): iterable
2023-11-30 16:57:21 -08:00
{
if (!isset($this->options[$property])) {
return [];
2023-11-30 16:57:21 -08:00
}
2023-12-21 14:27:31 -08:00
// @todo: I think this was added to support the null object pattern
// @todo: Check if this is still needed and if so, add a test for it (testParsingSelectValues()).
2023-12-21 18:07:46 -08:00
// if ($this->options[$property] === [null]) {
// return null;
// }
2023-11-30 16:57:21 -08:00
// If a model is provided then we should ensure we only return
// the ids of models that exist and are not deleted.
if ($model) {
return $model::findMany($this->options[$property])->pluck('id');
}
2023-12-21 17:02:44 -08:00
// Wrap the value in an array if needed.
if (!is_array($this->options[$property])) {
return [$this->options[$property]];
}
2023-11-30 16:57:21 -08:00
return $this->options[$property];
}
2023-12-11 11:27:56 -08:00
public function textValue(string $property): string
{
// Assuming we're using the null object pattern,
// return the default value if the object is not saved yet.
if (is_null($this->id)) {
return '';
}
// Return the property's value if it exists
// and return the default value if not.
return $this->options[$property] ?? '';
}
2023-08-23 16:32:19 -07:00
}