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.
yanzong/app/common/model/Article.php

87 lines
2.3 KiB

1 year ago
<?php
// +----------------------------------------------------------------------
// | 萤火商城系统 [ 致力于通过产品和服务,帮助商家高效化开拓市场 ]
// +----------------------------------------------------------------------
// | Copyright (c) 2017~2023 https://www.yiovo.com All rights reserved.
// +----------------------------------------------------------------------
// | Licensed 这不是一个自由软件,不允许对程序代码以任何形式任何目的的再发行
// +----------------------------------------------------------------------
// | Author: 萤火科技 <admin@yiovo.com>
// +----------------------------------------------------------------------
declare (strict_types=1);
namespace app\common\model;
use cores\BaseModel;
use think\model\relation\BelongsTo;
use think\model\relation\HasOne;
/**
* 文章模型
* Class Article
* @package app\common\model
*/
class Article extends BaseModel
{
// 定义表名
protected $name = 'article';
// 定义主键
protected $pk = 'article_id';
// 追加字段
protected $append = ['show_views'];
/**
* 关联文章封面图
* @return HasOne
*/
public function image(): HasOne
{
return $this->hasOne('UploadFile', 'file_id', 'image_id')
->bind(['image_url' => 'preview_url']);
}
/**
* 关联文章分类表
* @return BelongsTo
*/
public function category(): BelongsTo
{
$module = self::getCalledModule();
return $this->BelongsTo("app\\{$module}\\model\\article\\Category", 'category_id');
}
/**
* 文章详情:HTML实体转换回普通字符
* @param $value
* @return string
*/
public function getContentAttr($value): string
{
return htmlspecialchars_decode($value);
}
/**
* 展示的浏览次数
* @param $value
* @param $data
* @return mixed
*/
public function getShowViewsAttr($value, $data)
{
return $data['virtual_views'] + $data['actual_views'];
}
/**
* 文章详情
* @param int $articleId
* @param array $with
* @return static|array|null
*/
public static function detail(int $articleId, array $with = [])
{
return self::get($articleId, $with);
}
}