|
|
|
<?php
|
|
|
|
|
|
|
|
namespace App\Models;
|
|
|
|
|
|
|
|
use Illuminate\Database\Eloquent\Factories\HasFactory;
|
|
|
|
use Illuminate\Database\Eloquent\Model;
|
|
|
|
use Illuminate\Database\Eloquent\SoftDeletes;
|
|
|
|
use Illuminate\Support\Facades\DB;
|
|
|
|
use Spatie\Translatable\HasTranslations;
|
|
|
|
|
|
|
|
class Category extends Model
|
|
|
|
{
|
|
|
|
use HasFactory, HasTranslations, SoftDeletes;
|
|
|
|
|
|
|
|
public $translatable = ['name', 'subtitle', 'description'];
|
|
|
|
|
|
|
|
public function imgUrl()
|
|
|
|
{
|
|
|
|
if ($this->image == null) {
|
|
|
|
return asset('/assets/upload/logo.svg');
|
|
|
|
}
|
|
|
|
|
|
|
|
return \Storage::url('categories/optimized-' . $this->image);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function imgOriginalUrl()
|
|
|
|
{
|
|
|
|
if ($this->image == null) {
|
|
|
|
return asset('/assets/upload/logo.svg');
|
|
|
|
}
|
|
|
|
|
|
|
|
return \Storage::url('categories/' . $this->image);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function bgUrl()
|
|
|
|
{
|
|
|
|
if ($this->bg == null) {
|
|
|
|
return asset('/assets/upload/logo.svg');
|
|
|
|
}
|
|
|
|
|
|
|
|
return \Storage::url('categories/optimized-' . $this->bg);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function bgOriginalUrl()
|
|
|
|
{
|
|
|
|
if ($this->bg == null) {
|
|
|
|
return asset('/assets/upload/logo.svg');
|
|
|
|
}
|
|
|
|
|
|
|
|
return \Storage::url('categories/' . $this->bg);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function parent()
|
|
|
|
{
|
|
|
|
return $this->belongsTo(Category::class, 'parent_id');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function children()
|
|
|
|
{
|
|
|
|
return $this->hasMany(Category::class, 'parent_id');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getRouteKeyName()
|
|
|
|
{
|
|
|
|
return 'slug';
|
|
|
|
}
|
|
|
|
|
|
|
|
public function props()
|
|
|
|
{
|
|
|
|
return $this->belongsToMany(Prop::class);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function attachs()
|
|
|
|
{
|
|
|
|
return $this->morphMany(Attachment::class, 'attachable');
|
|
|
|
}
|
|
|
|
|
|
|
|
public function webUrl()
|
|
|
|
{
|
|
|
|
return fixUrlLang(route('client.category',$this->slug));
|
|
|
|
}
|
|
|
|
|
|
|
|
public function products()
|
|
|
|
{
|
|
|
|
return $this->belongsToMany(Product::class);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
public function published($limit = 10, $order = 'id', $dir = 'DESC')
|
|
|
|
{
|
|
|
|
return $this->products()->where('status', 1)
|
|
|
|
->orderBy($order, $dir)->limit($limit)->get([
|
|
|
|
DB::raw('name as "title"'),
|
|
|
|
'slug'
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function evaluations(){
|
|
|
|
|
|
|
|
return Evaluation::where(function ($query) {
|
|
|
|
$query->whereNull('evaluationable_type')
|
|
|
|
->whereNull('evaluationable_id');
|
|
|
|
})->orWhere(function ($query) {
|
|
|
|
$query->where('evaluationable_type', Category::class)
|
|
|
|
->whereNull('evaluationable_id');
|
|
|
|
})->orWhere(function ($query ) {
|
|
|
|
$query->where('evaluationable_type', Category::class)
|
|
|
|
->where('evaluationable_id',$this->id);
|
|
|
|
})->get();
|
|
|
|
}
|
|
|
|
|
|
|
|
public function parallelCategories($limit = 10){
|
|
|
|
return Category::where('parent_id' , $this->parent_id)->where('id','<>',$this->id)->limit($limit)->get();
|
|
|
|
}
|
|
|
|
}
|