Dictionary.php 2.2 KB
<?php

namespace App\Models;

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

/**
 * App\Models\Dictionary
 *
 * @property int $id
 * @property int $region_id
 * @property int|null $parent_id
 * @property string $name
 * @property string $type
 * @property int|null $token_id
 * @property bool $update
 * @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 \App\Models\Tokens|null $token
 * @property-read \Illuminate\Database\Eloquent\Collection|\App\Models\Variable[] $variables
 * @property-read int|null $variables_count
 * @method static Builder|Dictionary defaultOrderBy()
 * @method static Builder|Dictionary newModelQuery()
 * @method static Builder|Dictionary newQuery()
 * @method static Builder|Dictionary query()
 * @method static Builder|Dictionary whereCreatedAt($value)
 * @method static Builder|Dictionary whereId($value)
 * @method static Builder|Dictionary whereName($value)
 * @method static Builder|Dictionary whereParentId($value)
 * @method static Builder|Dictionary whereRegionId($value)
 * @method static Builder|Dictionary whereTokenId($value)
 * @method static Builder|Dictionary whereType($value)
 * @method static Builder|Dictionary whereUpdate($value)
 * @method static Builder|Dictionary whereUpdatedAt($value)
 * @mixin \Eloquent
 */
class Dictionary extends Model
{
    CONST CITY = 'City';

    protected $fillable = [
      'update',
    ];

    protected $casts = [
        'update' => 'boolean',
    ];

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

    public function token()
    {
        return $this->belongsTo(Tokens::class, 'token_id');
    }

    public function campaigns()
    {
        return $this->belongsToMany(Campaigns::class, 'dictionary_campaigns', 'dictionary_id', 'campaign_id')
            ->using(DictionaryCampaign::class)
            ->withPivot(DictionaryCampaign::getWithPivot())
            ->withTimestamps();
    }

}