GoalAdGroup.php 3.27 KB
<?php

namespace App\Models\Pivots;

use App\Models\AdGroup;
use App\Models\Campaigns;
use App\Models\Variable;
use Illuminate\Database\Eloquent\Builder;
use Illuminate\Database\Eloquent\Relations\Pivot;
use Illuminate\Support\Collection;

class GoalAdGroup extends Pivot
{

    protected $table = 'goal_ad_groups';

    protected $fillable = [
        'external_id',
        'campaign_external_id',
        'dictionary_campaign_id',
        'name',
        'negative_keywords',
        'external_upload_at',
        'external_updated_at',
        'updated_need',
        'updated_self',
    ];

    protected $casts = [
        'dictionary_campaign_id' => 'int',
        'external_id' => 'int',
        'campaign_external_id' => 'int',
        'negative_keywords' => 'array',
        'external_upload_at' => 'datetime',
        'external_updated_at' => 'datetime',
        'updated_need' => 'datetime',
        'updated_self' => 'datetime',
    ];

    static public function getWithPivot()
    {
        return [
            'id',
            'external_id',
            'campaign_external_id',
            'dictionary_campaign_id',
            'name',
            'negative_keywords',
            'external_upload_at',
            'external_updated_at',
            'updated_self',
            'updated_need',
        ];
    }

    /**
     * @return Collection
     */
    static public function getPropertiesCopyWithPivot()
    {
        return collect([
            'name',
            'negative_keywords',
        ]);
    }

    /**
     * @param AdGroup|array $ad_group
     */
    static public function copyPropertyFromMain($ad_group)
    {
        return self::getPropertiesCopyWithPivot()
            ->transform(function ($property_name) use ($ad_group) {
                $value = null;

                if ($ad_group instanceof AdGroup) {
                    $value = $ad_group->{$property_name};
                } elseif (is_array($ad_group) && isset($ad_group[$property_name])) {
                    $value = $ad_group[$property_name];
                }

                return [
                    $property_name => $value
                ];
            })->flatMap(function ($val) {
                return $val;
            })->all();
    }

    public function scopeForExternal(Builder $query)
    {
        return $query->whereNotNull('external_id');
    }

    public function scopeForNotExternal(Builder $query)
    {
        return $query->whereNull('external_id');
    }

    public function scopeNeedUpdated(Builder $query)
    {
        return $query->whereNotNull('updated_need');
    }

    public function scopeForUpdatedSelf(Builder $query)
    {
        $query->whereNotNull('updated_self');
    }

    public function dictionaryCampaign()
    {
        return $this->belongsTo(Campaigns::class, 'dictionary_campaign_id');
    }

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

    public function variables()
    {
        return $this->belongsToMany(Variable::class, 'dictionary_campaign_variables', 'dictionary_campaign_id', 'variable_id')
            ->using(DictionaryCampaignVariable::class)
            ->withPivot(DictionaryCampaignVariable::getWithPivot())
            ->withTimestamps();
    }

}