Files
opensem/app/Models/Shop/PriceList.php
Ludovic CANDELLIER b1a2e70d12 Add deep relations
2022-01-14 00:03:21 +01:00

60 lines
1.3 KiB
PHP

<?php
namespace App\Models\Shop;
use Illuminate\Database\Eloquent\Model;
use Znck\Eloquent\Traits\BelongsToThrough;
use App\Traits\Model\HasComments;
class PriceList extends Model
{
use BelongsToThrough, HasComments;
protected $guarded = ['id'];
protected $table = 'shop_price_lists';
public function tariff()
{
return $this->belongsTo(Tariff::class);
}
public function offers()
{
return $this->hasManyThrough(Offer::class, Tariff::class, 'id', 'tariff_id', 'id', 'id');
}
public function sale_channel()
{
return $this->belongsTo(SaleChannel::class);
}
public function price_list_values()
{
return $this->hasMany(PriceListValue::class);
}
public function scopeByTariff($query, $id)
{
return $query->where($this->table . '.tariff_id', $id);
}
public function scopeBySaleChannel($query, $id)
{
return $query->where($this->table . '.sale_channel_id', $id);
}
public function scopeByStatus($query, $id)
{
return $query->where($this->table . '.status_id', $id);
}
public function scopeByOffer($query, $id)
{
return $query->whereHas('offers', function ($query) use ($id) {
$query->byOffer($id);
});
}
}