You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

90 lines
1.9 KiB

<?php
namespace App\Models;
use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\Relations\BelongsTo;
use Illuminate\Database\Eloquent\Relations\BelongsToMany;
class Item extends Model
{
use HasFactory;
protected $fillable = [
'uuid',
'name',
'url',
'description',
'price',
'image',
'category_id',
];
public function category(): BelongsTo
{
return $this->belongsTo(Category::class);
}
public function carts(): BelongsToMany
{
return $this->belongsToMany(Cart::class, 'carts_items', 'item_id', 'cart_id');
}
public function getCategory(): Category
{
$category = Category::where('id', $this->category_id)->first();
return $category;
}
public function getCompany()
{
$category = $this->getCategory();
if($category == null)
return null;
$company = Company::where('id', $category->company_id)->first();
return $company;
}
public function isBelong(Company $company): bool
{
$category = $this->getCategory();
if($category == null)
return false;
$its_company = $this->getCompany();
if($its_company == null or $company == null)
return false;
return $its_company->id == $company->id;
}
public static function validate_with_name(string $name)
{
$name = $name ?? '';
if($name == '')
return [
'error' => 'The item name is empty, please, write the name!!!'
];
$item = Item::where('name', $name)->first();
if(!$item)
return [
'error' => 'A item with the name does not exist!!!'
];
return [
'ok' => 'A item with the name is valid.'
];
}
}