Files
orico-official-website/app/admin/model/v1/ArticleModel.php

71 lines
1.6 KiB
PHP

<?php
declare (strict_types = 1);
namespace app\admin\model\v1;
use app\common\model\ArticleBaseModel;
use think\model\concern\SoftDelete;
/**
* @mixin \think\Model
*/
class ArticleModel extends ArticleBaseModel
{
// 启用软删除
use SoftDelete;
// 软删除标记数据字段
protected $deleteTime = 'deleted_at';
// 关联分类
public function category()
{
return $this->belongsTo(ArticleCategoryModel::class, 'category_id', 'id');
}
// 搜索名称
public function searchTitleAttr($query, $value, $data)
{
$query->where('title', 'like', '%' . $value . '%');
}
// 搜索发布时间
public function searchCreatedAtAttr($query, $value, $data)
{
if (is_array($value)) {
if (count($value) == 2) {
$query->whereBetweenTime('created_at', $value[0], $value[1]);
} else {
$query->whereTime('created_at', '>=', $value[0]);
}
}
}
// 语言查询
public function scopeLanguage($query, $value)
{
if (is_null($value)) {
return;
}
$query->where('language_id', '=', $value);
}
// 分类查询
public function scopeCategory($query, $value)
{
$query->where('category_id', '=', $value);
}
public function scopeCategoryNullable($query, $value)
{
if (is_null($value)) {
return;
}
$query->where('category_id', '=', $value);
}
// 已启用的查询
public function scopeEnabled($query)
{
$query->where('enabled', '=', 1);
}
}