Article.php 2.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | 萤火商城系统 [ 致力于通过产品和服务,帮助商家高效化开拓市场 ]
  4. // +----------------------------------------------------------------------
  5. // | Copyright (c) 2017~2024 https://www.yiovo.com All rights reserved.
  6. // +----------------------------------------------------------------------
  7. // | Licensed 这不是一个自由软件,不允许对程序代码以任何形式任何目的的再发行
  8. // +----------------------------------------------------------------------
  9. // | Author: 萤火科技 <admin@yiovo.com>
  10. // +----------------------------------------------------------------------
  11. declare (strict_types=1);
  12. namespace app\common\model;
  13. use cores\BaseModel;
  14. use think\model\relation\BelongsTo;
  15. use think\model\relation\HasOne;
  16. /**
  17. * 文章模型
  18. * Class Article
  19. * @package app\common\model
  20. */
  21. class Article extends BaseModel
  22. {
  23. // 定义表名
  24. protected $name = 'article';
  25. // 定义主键
  26. protected $pk = 'article_id';
  27. // 追加字段
  28. protected $append = ['show_views'];
  29. /**
  30. * 关联文章封面图
  31. * @return HasOne
  32. */
  33. public function image(): HasOne
  34. {
  35. return $this->hasOne('UploadFile', 'file_id', 'image_id')
  36. ->bind(['image_url' => 'preview_url']);
  37. }
  38. /**
  39. * 关联文章分类表
  40. * @return BelongsTo
  41. */
  42. public function category(): BelongsTo
  43. {
  44. $module = self::getCalledModule();
  45. return $this->BelongsTo("app\\{$module}\\model\\article\\Category", 'category_id');
  46. }
  47. /**
  48. * 文章详情:HTML实体转换回普通字符
  49. * @param $value
  50. * @return string
  51. */
  52. public function getContentAttr($value): string
  53. {
  54. return htmlspecialchars_decode($value);
  55. }
  56. /**
  57. * 展示的浏览次数
  58. * @param $value
  59. * @param $data
  60. * @return mixed
  61. */
  62. public function getShowViewsAttr($value, $data)
  63. {
  64. return $data['virtual_views'] + $data['actual_views'];
  65. }
  66. /**
  67. * 文章详情
  68. * @param int $articleId
  69. * @param array $with
  70. * @return static|array|null
  71. */
  72. public static function detail(int $articleId, array $with = [])
  73. {
  74. return self::get($articleId, $with);
  75. }
  76. }