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.
64 lines
2.5 KiB
64 lines
2.5 KiB
<?php
|
|
|
|
namespace App\Models;
|
|
|
|
use Encore\Admin\Traits\AdminBuilder;
|
|
use Encore\Admin\Traits\ModelTree;
|
|
use Illuminate\Database\Eloquent\Model;
|
|
|
|
/**
|
|
* App\Models\Category
|
|
*
|
|
* @property int $id
|
|
* @property string $title
|
|
* @property string|null $icon 分类的图标
|
|
* @property string $thumb 分类的缩略图
|
|
* @property string|null $description 分类的描述
|
|
* @property int $parent_id 兼容插件的字段
|
|
* @property int $order 排序字段
|
|
* @property \Illuminate\Support\Carbon|null $created_at
|
|
* @property \Illuminate\Support\Carbon|null $updated_at
|
|
* @property-read \Illuminate\Database\Eloquent\Collection|\App\Models\Category[] $children
|
|
* @property-read \App\Models\Category $parent
|
|
* @property-read \Illuminate\Database\Eloquent\Collection|\App\Models\Product[] $products
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\Category newModelQuery()
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\Category newQuery()
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\Category query()
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\Category whereCreatedAt($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\Category whereDescription($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\Category whereIcon($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\Category whereId($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\Category whereOrder($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\Category whereParentId($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\Category whereThumb($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\Category whereTitle($value)
|
|
* @method static \Illuminate\Database\Eloquent\Builder|\App\Models\Category whereUpdatedAt($value)
|
|
* @method static \App\Models\Category findOrFail($id)
|
|
* @mixin \Eloquent
|
|
*/
|
|
class Category extends Model
|
|
{
|
|
use ModelTree, AdminBuilder;
|
|
|
|
protected $table = 'categories';
|
|
|
|
protected $fillable = ['title', 'icon', 'parent_id', 'description', 'thumb'];
|
|
|
|
|
|
public function products()
|
|
{
|
|
return $this->hasMany(Product::class);
|
|
}
|
|
|
|
|
|
public static function orderAll()
|
|
{
|
|
return self::query()->orderBy('order')->latest()->get();
|
|
}
|
|
|
|
public static function selectOrderAll()
|
|
{
|
|
return self::query()->orderBy('order')->latest()->pluck('title', 'id');
|
|
}
|
|
}
|