image == null) { return asset('/assets/upload/logo.svg'); } return \Storage::url('categories/optimized-' . $this->image); } public function svgUrl() { if ($this->svg == null) { return asset('/assets/upload/logo.svg'); } return \Storage::url('categories/' . $this->svg); } 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([ 'name', 'slug', ])->map(function ($item) { // Change 'name' to 'title' $item->title = $item->name; // Add title property unset($item->name); // Remove the old name property return $item; // Return the modified item }); } 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(); } }