You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
xshop/app/Models/Group.php

110 lines
2.6 KiB
PHTML

9 months ago
<?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;
9 months ago
class Group extends Model
{
use HasFactory, SoftDeletes, HasTranslations;
public $translatable = ['name', 'subtitle', 'description'];
public function posts()
{
return $this->belongsToMany(Post::class);
}
//
public function parent()
{
return $this->belongsTo(Group::class, 'parent_id');
}
public function children()
{
return $this->hasMany(Group::class, 'parent_id');
}
public function getRouteKeyName()
{
return 'slug';
}
public function author()
{
return $this->belongsTo(\App\Models\User::class);
}
public function imgUrl()
{
if ($this->image == null) {
return asset('/assets/upload/logo.svg');
}
return \Storage::url('groups/optimized-' . $this->image);
}
public function imgOriginalUrl()
{
if ($this->image == null) {
return asset('/assets/upload/logo.svg');
}
return \Storage::url('groups/' . $this->image);
}
public function bgUrl()
{
if ($this->bg == null) {
return asset('/assets/upload/logo.svg');
}
return \Storage::url('groups/optimized-' . $this->bg);
}
public function bgOriginalUrl()
{
if ($this->bg == null) {
return asset('/assets/upload/logo.svg');
}
return \Storage::url('groups/' . $this->bg);
}
public function attachs()
{
return $this->morphMany(Attachment::class, 'attachable');
}
public function webUrl()
{
return fixUrlLang(route('client.group',$this->slug));
}
public function published($limit = 10, $order = 'id', $dir = 'DESC')
{
return $this->posts()->where('status', 1)
->orderBy($order, $dir)->limit($limit)->get(['title', 'slug', 'icon']);
}
public function evaluations(){
return Evaluation::where(function ($query) {
$query->whereNull('evaluationable_type')
->whereNull('evaluationable_id');
})->orWhere(function ($query) {
$query->where('evaluationable_type', Group::class)
->whereNull('evaluationable_id');
})->orWhere(function ($query ) {
$query->where('evaluationable_type', Group::class)
->where('evaluationable_id',$this->id);
})->get();
}
9 months ago
}