GoalKeyword.php 2.67 KB
<?php

namespace App\Models\Pivots;

use App\Models\Keyword;
use Illuminate\Database\Eloquent\Builder;
use Illuminate\Database\Eloquent\Relations\Pivot;
use Illuminate\Support\Collection;

class GoalKeyword extends Pivot
{

    protected $table = 'goal_keywords';

    protected $fillable = [
        'external_id',
        'goal_ad_group_external_id',
        'dictionary_campaign_external_id',
        'goal_ad_group_id',
        'dictionary_campaign_id',
        'keyword_id',
        'external_upload_at',
        'external_updated_at',
        'updated_need',
    ];

    protected $casts = [
        'external_upload_at' => 'datetime',
        'external_updated_at' => 'datetime',
        'updated_need' => 'datetime',
    ];

    static public function getWithPivot()
    {
        return [
            'id',
            'external_id',
            'goal_ad_group_external_id',
            'dictionary_campaign_external_id',
            'goal_ad_group_id',
            'dictionary_campaign_id',
            'keyword_id',
            'external_upload_at',
            'external_updated_at',
            'updated_need',
        ];
    }

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

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

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

                return [
                    $property_name => $value
                ];
            })
            ->collapse()
            ->put('keyword_id', $keyword[GoalKeyword::getModel()->getKeyName()])
            ->all();
    }

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

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

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

    public function keyword()
    {
        return $this->belongsTo(Keyword::class, 'keyword_id');
    }

}