Spaces:
Running
Running
File size: 1,821 Bytes
0c117c4 | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 | <?php
namespace App\Models;
use App\Services\ChapterServices;
use App\Services\HashtagServices;
use App\Services\TaggedServices;
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Support\Facades\Schema;
use Spatie\Sluggable\HasSlug;
use Spatie\Sluggable\SlugOptions;
use App\Models\Traits\SearchableTraitExtend;
class Benefit extends BaseModel
{
protected $table = "benefits";
protected $hidden = ['pivot'];
protected $fillable =[
'price',
'description',
'name',
'created_by',
'updated_by',
'created_at',
'updated_at',
];
const TIME = [
'application_date',
'attendance_start_at',
'attendance_end_at',
'approved_at'
];
public static function boot()
{
parent::boot();
static::deleting(function ($model) {
$packetBenefits = $model->packetBenefits;
if($packetBenefits->isEmpty()){
$model->packetBenefits()->delete();
}else{
return false;
}
});
}
// public function getSlugOptions() : SlugOptions
// {
// return SlugOptions::create()
// ->generateSlugsFrom('comic_name')
// ->saveSlugsTo('slug');
// }
protected function columns(){
return Schema::getColumnListing('benefits');
}
public function scopeExclude($query, $value = array())
{
return $query->select( array_diff( $this->columns(), $value) );
}
public function packets()
{
return $this->belongsToMany(Packet::class, 'packet_benefit', 'benefit_id','packet_id');
}
public function packetBenefits()
{
return $this->hasMany(PacketBenefit::class, 'benefit_id');
}
}
|