GoalAdImage.php 1.45 KB
<?php

namespace App\Models\Pivots;

use App\Models\AdImage;
use Illuminate\Database\Eloquent\Builder;
use Illuminate\Database\Eloquent\Relations\Pivot;
use Illuminate\Database\Eloquent\SoftDeletes;

class GoalAdImage extends Pivot
{
    use SoftDeletes;

    protected $table = 'goal_ad_images';

    protected $fillable = [
        'hash',
        'ad_image_id',
        'token_id',
        'external_upload_at',
        'reserve_create_at',
    ];

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

    public $incrementing = true;

    static public function getWithPivot()
    {
        return [
            'id',
            'hash',
            'ad_image_id',
            'token_id',
            'external_upload_at',
            'reserve_create_at',
        ];
    }

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

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

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

    public function adImage()
    {
        return $this->belongsTo(AdImage::class, 'ad_image_id');
    }

}