HEX
Server: Microsoft-IIS/8.5
System: Windows NT YDAWBH120 6.3 build 9600 (Windows Server 2012 R2 Standard Edition) AMD64
User: tentjecom_web (0)
PHP: 7.4.14
Disabled: NONE
Upload Files
File: D:/HostingSpaces/SBogers10/shop.komma.nl/app/Orders/ProductComposite/OrderedProductComposite.php
<?php

namespace App\Orders\ProductComposite;

use Komma\KMS\Core\Attributes\Models\Traits\HasThumbnailInterface;
use Komma\KMS\Core\Attributes\Models\Traits\HasThumbnailTrait;
use App\Orders\Models\Order;
use App\Orders\OrderedProductableInterface;
use App\Orders\ProductGroup\HasOrderedProductGroups;
use App\Orders\ProductGroup\HasOrderedProductGroupsInterface;
use App\Orders\ProductGroup\OrderedProductGroup;
use App\Products\ProductComposite\ProductComposite;
use App\Products\ProductGroup\ProductGroup;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\Relations\BelongsTo;
use Illuminate\Database\Eloquent\Relations\MorphMany;

/**
 * App\Orders\ProductComposite\OrderedProductComposite
 *
 * @property int $id
 * @property int $order_id
 * @property int $product_composite_id
 * @property int $active
 * @property int $quantity
 * @property \Illuminate\Support\Carbon|null $created_at
 * @property \Illuminate\Support\Carbon|null $updated_at
 * @property-read int $price
 * @property-read \Illuminate\Database\Eloquent\Collection|ProductGroup[] $groups
 * @property-read int|null $groups_count
 * @property-read Order $order
 * @property-read \Illuminate\Database\Eloquent\Collection|OrderedProductGroup[] $orderedGroups
 * @property-read int|null $ordered_groups_count
 * @property-read ProductComposite $productComposite
 * @method static \Illuminate\Database\Eloquent\Builder|OrderedProductComposite newModelQuery()
 * @method static \Illuminate\Database\Eloquent\Builder|OrderedProductComposite newQuery()
 * @method static \Illuminate\Database\Eloquent\Builder|OrderedProductComposite query()
 * @method static \Illuminate\Database\Eloquent\Builder|OrderedProductComposite whereActive($value)
 * @method static \Illuminate\Database\Eloquent\Builder|OrderedProductComposite whereCreatedAt($value)
 * @method static \Illuminate\Database\Eloquent\Builder|OrderedProductComposite whereId($value)
 * @method static \Illuminate\Database\Eloquent\Builder|OrderedProductComposite whereOrderId($value)
 * @method static \Illuminate\Database\Eloquent\Builder|OrderedProductComposite whereProductCompositeId($value)
 * @method static \Illuminate\Database\Eloquent\Builder|OrderedProductComposite whereQuantity($value)
 * @method static \Illuminate\Database\Eloquent\Builder|OrderedProductComposite whereUpdatedAt($value)
 * @mixin \Eloquent
 */
class OrderedProductComposite extends Model implements HasThumbnailInterface, HasOrderedProductGroupsInterface, OrderedProductableInterface
{
    use HasThumbnailTrait;
    use HasOrderedProductGroups;

    /**
     * The attributes that are mass assignable.
     *
     * @var array
     */
    protected $fillable = ['name', 'active'];

    public function groups()
    {
        return $this->belongsToMany(ProductGroup::class);
    }

    /**
     * Return the order
     *
     * @return BelongsTo
     */
    public function productComposite():BelongsTo
    {
        return $this->belongsTo(ProductComposite::class);
    }

    /**
     * Return the order
     *
     * @return BelongsTo
     */
    public function order():BelongsTo
    {
        return $this->belongsTo(Order::class);
    }

    /**
     * @return float
     */
    public function getPrice(): float
    {
        return $this->getPriceAttribute();
    }

    /**
     * @return int
     */
    public function getPriceAttribute(): int
    {
        $price = $this->orderedGroups()->get()->map(function (OrderedProductGroup $orderedProductGroup) {
            return $orderedProductGroup->price;
        })->sum();

        if(!$price) return 0;
        return $price;
    }

}