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/netwerkbrabant/netwerkbrabant.nl/app/KommaApp/Products/Models/Product.php
<?php
/**
 *
 *
 * @author      Komma <info@komma.pro>
 * @copyright   (c) 2012-2016, Komma
 */

namespace App\KommaApp\Products\Models;

use App\KommaApp\Documents\DocumentsTrait;
use App\KommaApp\Documents\Kms\DocumentableInterface;
use App\KommaApp\ProductSignUps\Models\ProductSignUp;
use App\KommaApp\ProductTypes\Models\ProductType;
use App\KommaApp\Kms\Core\AbstractTranslatableModel;
use App\KommaApp\Kms\Core\Entities\DisplayNameTrait;
use App\KommaApp\Languages\Models\Language;
use App\KommaApp\Tags\Models\Tag;
use App\KommaApp\WeFact\WeFactAPI;
use Illuminate\Database\Eloquent\Relations\BelongsTo;
use Illuminate\Database\Eloquent\Relations\BelongsToMany;
use Illuminate\Database\Eloquent\Relations\HasMany;
use Illuminate\Database\Eloquent\Relations\MorphToMany;
use Illuminate\Database\Eloquent\SoftDeletes;
use Illuminate\Support\Str;
use Laravel\Scout\Searchable;

/**
 * Class Product
 *
 * @package App\KommaApp\Products\Models
 * @property-read \Illuminate\Database\Eloquent\Collection|\App\KommaApp\Images\Models\Image[] $images
 * @property-read \Illuminate\Database\Eloquent\Collection|\App\KommaApp\Languages\Models\Language[] $languages
 * @property-read \App\KommaApp\Sites\Models\Site $site
 * @mixin \Eloquent
 * @property int $id
 * @property int $site_id
 * @property int|null $region_id
 * @property int $active
 * @property string $time
 * @property string $location_name
 * @property string $location_postal
 * @property string $location_city
 * @property string $location_address
 * @property \Carbon\Carbon|null $created_at
 * @property \Carbon\Carbon|null $updated_at
 * @property \Carbon\Carbon|null $date
 * @method static \Illuminate\Database\Eloquent\Builder|\App\KommaApp\Products\Models\Product whereActive($value)
 * @method static \Illuminate\Database\Eloquent\Builder|\App\KommaApp\Products\Models\Product whereCreatedAt($value)
 * @method static \Illuminate\Database\Eloquent\Builder|\App\KommaApp\Products\Models\Product whereId($value)
 * @method static \Illuminate\Database\Eloquent\Builder|\App\KommaApp\Products\Models\Product whereSiteId($value)
 * @method static \Illuminate\Database\Eloquent\Builder|\App\KommaApp\Products\Models\Product whereUpdatedAt($value)
 * @method static \Illuminate\Database\Eloquent\Builder|\App\KommaApp\Products\Models\Product whereDate($value)
 */
class Product extends AbstractTranslatableModel implements DocumentableInterface
{
    use DocumentsTrait;
    use DisplayNameTrait;
    use SoftDeletes;

    protected $class = Product::class;

    protected $fillable = ['active',  'price',  'price_amount', 'wefact_code', 'wefact_name', 'wefact_description'];

    protected $dates = ['wefact_modified_at'];

    protected $attributes = [
        'vat_amount' => 21
    ];

    /*
    * Transient properties on Eloquent models
    * These are not saved to database.
    */
    public $thumbnail = false;

    /**
     * Gets the translation models for this model
     *
     * @return HasMany that resolves to AbstractTranslationModel instances
     */
    public function translations(): HasMany
    {
        return $this->hasMany(ProductTranslation::class);
    }

    public function languages(): BelongsToMany
    {
        return $this->belongsToMany(Language::class, 'product_translations')
            ->withPivot('description')
            ->withTimestamps();
    }

    public function getBoxedPriceFormat($withVat = false)
    {
        if($withVat) $priceAmount = $this->price_amount / 100;
        else $priceAmount = WeFactAPI::convertPriceInclToExcl($this->price_amount, $this->vat_amount);

        $price = number_format($priceAmount, 2, ',', '.');
        $explodedPrice = explode(',', $price);

        // If decimals then we return only the full euro's
        if($explodedPrice[1] == '00') return [$explodedPrice[0]];
        else return $explodedPrice;
    }
}