D7net
Home
Console
Upload
information
Create File
Create Folder
About
Tools
:
/
home
/
forge
/
mikyal.online
/
app
/
Models
/
Filename :
ProductVariation.php
back
Copy
<?php namespace App\Models; use App\Enums\Status; use Illuminate\Database\Eloquent\Model; use Staudenmeir\LaravelAdjacencyList\Eloquent\HasRecursiveRelationships; class ProductVariation extends Model { use HasRecursiveRelationships; protected $table = "product_variations"; protected $fillable = [ 'product_id', 'product_attribute_id', 'product_attribute_option_id', 'price', 'sku', 'parent_id', 'order' ]; protected $casts = [ 'id' => 'integer', 'product_id' => 'integer', 'product_attribute_id' => 'integer', 'product_attribute_option_id' => 'integer', 'price' => 'decimal:6', 'sku' => 'string', 'parent_id' => 'integer', 'order' => 'integer' ]; public function product(): \Illuminate\Database\Eloquent\Relations\BelongsTo { return $this->belongsTo(Product::class); } public function productAttribute(): \Illuminate\Database\Eloquent\Relations\BelongsTo { return $this->belongsTo(ProductAttribute::class); } public function productAttributeOption(): \Illuminate\Database\Eloquent\Relations\BelongsTo { return $this->belongsTo(ProductAttributeOption::class); } public function stocks(): \Illuminate\Database\Eloquent\Relations\MorphMany { return $this->morphMany(Stock::class, 'item'); } public function stockItems(): \Illuminate\Database\Eloquent\Relations\MorphMany { return $this->stocks()->where('status', Status::ACTIVE); } }