Variable.php 2.47 KB
<?php

namespace App\Models;

use App\Models\Pivots\DictionaryCampaign;
use App\Models\Pivots\DictionaryCampaignVariable;
use Illuminate\Database\Eloquent\Builder;

/**
 * App\Models\Variable
 *
 * @property int $id
 * @property string $name
 * @property string $default_value
 * @property \Illuminate\Support\Carbon|null $created_at
 * @property \Illuminate\Support\Carbon|null $updated_at
 * @property-read \Illuminate\Database\Eloquent\Collection|\App\Models\Campaigns[] $campaigns
 * @property-read int|null $campaigns_count
 * @property-read \Illuminate\Database\Eloquent\Collection|DictionaryCampaignVariable[] $values
 * @property-read int|null $values_count
 * @method static Builder|Variable defaultOrderBy()
 * @method static Builder|Variable newModelQuery()
 * @method static Builder|Variable newQuery()
 * @method static Builder|Variable query()
 * @method static Builder|Variable whereCreatedAt($value)
 * @method static Builder|Variable whereId($value)
 * @method static Builder|Variable whereName($value)
 * @method static Builder|Variable whereDefaultValue($value)
 * @method static Builder|Variable whereUpdatedAt($value)
 * @mixin \Eloquent
 */
class Variable extends Model
{
    protected $fillable = [
        'name',
        'default_value',
    ];

    public static function getListVariablesByDictionaryCampaign(DictionaryCampaign $dictionaryCampaign, $variables = null)
    {
        $variable_list = [
            'vars' => [],
            'values' => [],
        ];

        if (!$variables) {
            $variables = Variable::all();
        }

        foreach ($variables as $variable) {
            $dictionaryCampaignVariable = $variable->findValue($dictionaryCampaign->getKey());

            $value = (
            $dictionaryCampaignVariable
                ? $dictionaryCampaignVariable->value
                : $variable->default_value
            );

            $variable_list['vars'][] = $variable->name;
            $variable_list['values'][] = $value;
        }

        return $variable_list;
    }

    /**
     * @param Builder $query
     * @return Builder
     */
    public function scopeDefaultOrderBy($query)
    {
        return $query->orderBy('name');
    }

    public function findValue($dictionary_campaign_id)
    {
        return $this->values()
            ->where('dictionary_campaign_id', $dictionary_campaign_id)
            ->first();
    }

    public function values()
    {
        return $this->hasMany(DictionaryCampaignVariable::class, 'variable_id');
    }

}