mirror of
https://github.com/InvoiceShelf/InvoiceShelf.git
synced 2026-04-07 13:41:23 +00:00
* Convert string references to `::class` PHP 5.5.9 adds the new static `class` property which provides the fully qualified class name. This is preferred over using strings for class names since the `class` property references are checked by PHP. * Use Faker methods Accessing Faker properties was deprecated in Faker 1.14. * Convert route options to fluent methods Laravel 8 adopts the tuple syntax for controller actions. Since the old options array is incompatible with this syntax, Shift converted them to use modern, fluent methods. * Adopt class based routes * Remove default `app` files * Shift core files * Streamline config files * Set new `ENV` variables * Default new `bootstrap/app.php` * Re-register HTTP middleware * Consolidate service providers * Re-register service providers * Re-register routes * Re-register scheduled commands * Bump Composer dependencies * Use `<env>` tags for configuration `<env>` tags have a lower precedence than system environment variables making it easier to overwrite PHPUnit configuration values in additional environments, such a CI. Review this blog post for more details on configuration precedence when testing Laravel: https://jasonmccreary.me/articles/laravel-testing-configuration-precedence/ * Adopt anonymous migrations * Rename `password_resets` table * Convert `$casts` property to method * Adopt Laravel type hints * Mark base controller as `abstract` * Remove `CreatesApplication` testing trait * Shift cleanup * Fix shift first issues * Updating Rules for laravel 11, sanctum config and pint * Fix Carbon issue on dashboard * Temporary fix for tests while migration is issue fixed on laravel side * Carbon needs numerical values, not strings * Minimum php version * Fix domain installation step not fetching the correct company_id * Fix Role Policy wasn't properly registered ---------
83 lines
2.2 KiB
PHP
83 lines
2.2 KiB
PHP
<?php
|
|
|
|
namespace App\Traits;
|
|
|
|
use App\Models\CustomField;
|
|
use Illuminate\Database\Eloquent\Relations\MorphMany;
|
|
|
|
trait HasCustomFieldsTrait
|
|
{
|
|
public function fields(): MorphMany
|
|
{
|
|
return $this->morphMany(\App\Models\CustomFieldValue::class, 'custom_field_valuable');
|
|
}
|
|
|
|
protected static function booted()
|
|
{
|
|
static::deleting(function ($data) {
|
|
if ($data->fields()->exists()) {
|
|
$data->fields()->delete();
|
|
}
|
|
});
|
|
}
|
|
|
|
public function addCustomFields($customFields)
|
|
{
|
|
foreach ($customFields as $field) {
|
|
if (! is_array($field)) {
|
|
$field = (array) $field;
|
|
}
|
|
$customField = CustomField::find($field['id']);
|
|
|
|
$customFieldValue = [
|
|
'type' => $customField->type,
|
|
'custom_field_id' => $customField->id,
|
|
'company_id' => $customField->company_id,
|
|
getCustomFieldValueKey($customField->type) => $field['value'],
|
|
];
|
|
|
|
$this->fields()->create($customFieldValue);
|
|
}
|
|
}
|
|
|
|
public function updateCustomFields($customFields)
|
|
{
|
|
foreach ($customFields as $field) {
|
|
if (! is_array($field)) {
|
|
$field = (array) $field;
|
|
}
|
|
|
|
$customField = CustomField::find($field['id']);
|
|
$customFieldValue = $this->fields()->firstOrCreate([
|
|
'custom_field_id' => $customField->id,
|
|
'type' => $customField->type,
|
|
'company_id' => $this->company_id,
|
|
]);
|
|
|
|
$type = getCustomFieldValueKey($customField->type);
|
|
$customFieldValue->$type = $field['value'];
|
|
$customFieldValue->save();
|
|
}
|
|
}
|
|
|
|
public function getCustomFieldBySlug($slug)
|
|
{
|
|
return $this->fields()
|
|
->with('customField')
|
|
->whereHas('customField', function ($query) use ($slug) {
|
|
$query->where('slug', $slug);
|
|
})->first();
|
|
}
|
|
|
|
public function getCustomFieldValueBySlug($slug)
|
|
{
|
|
$value = $this->getCustomFieldBySlug($slug);
|
|
|
|
if ($value) {
|
|
return $value->defaultAnswer;
|
|
}
|
|
|
|
return null;
|
|
}
|
|
}
|