Comment.php 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127
  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\store\model;
  13. use app\common\library\helper;
  14. use app\common\model\Comment as CommentModel;
  15. use app\store\model\CommentImage as CommentImageModel;
  16. /**
  17. * 商品评价模型
  18. * Class Comment
  19. * @package app\store\model
  20. */
  21. class Comment extends CommentModel
  22. {
  23. /**
  24. * 获取评价列表
  25. * @param array $param
  26. * @return iterable|\think\model\Collection|\think\Paginator
  27. */
  28. public function getList(array $param = [])
  29. {
  30. // 检索查询条件
  31. $query = $this->setQueryFilter($param);
  32. // 查询列表数据
  33. return $query->with(['user.avatar', 'orderGoods' => ['image']])
  34. ->alias($this->name)
  35. ->field(["$this->name.*"])
  36. ->join('goods', "goods.goods_id = {$this->name}.goods_id")
  37. ->join('order', "order.order_id = {$this->name}.order_id")
  38. ->join('user', "user.user_id = {$this->name}.user_id")
  39. ->where("{$this->name}.is_delete", '=', 0)
  40. ->order(["{$this->name}.sort" => 'asc', "{$this->name}.create_time" => 'desc'])
  41. ->paginate(15);
  42. }
  43. /**
  44. * 检索查询条件
  45. * @param array $param
  46. * @return \think\db\BaseQuery
  47. */
  48. private function setQueryFilter(array $param): \think\db\BaseQuery
  49. {
  50. // 实例化查询对象
  51. $query = $this->getNewQuery();
  52. // 查询参数
  53. $params = $this->setQueryDefaultValue($param, [
  54. 'score' => 0, // 评分 (10好评 20中评 30差评)
  55. 'goodsName' => '', // 商品名称/编码
  56. 'orderNo' => '', // 订单号
  57. 'userId' => 0, // 用户id
  58. 'status' => -1 // 评价状态 -1全部
  59. ]);
  60. // 评分
  61. $params['score'] > 0 && $query->where("{$this->name}.score", '=', $params['score']);
  62. // 商品名称/编码
  63. !empty($params['goodsName']) && $query->where('goods.goods_name|goods.goods_no', 'like', "%{$params['goodsName']}%");
  64. // 订单号
  65. !empty($params['orderNo']) && $query->where('order.order_no', 'like', "%{$params['orderNo']}%");
  66. // 用户id
  67. $params['userId'] > 0 && $query->where("{$this->name}.user_id", '=', $params['userId']);
  68. // 评价状态
  69. $params['status'] > -1 && $query->where("{$this->name}.status", '=', $params['status']);
  70. return $query;
  71. }
  72. /**
  73. * 获取评价详情
  74. * @param int $commentId
  75. * @return Comment|array|null
  76. */
  77. public function getDetail(int $commentId)
  78. {
  79. // 评价详情
  80. $detail = static::detail($commentId, ['images.file']);
  81. // 图片ID集
  82. $detail['imageIds'] = helper::getArrayColumn($detail['images'], 'image_id');
  83. // 图片列表
  84. $detail['imageList'] = helper::getArrayColumn($detail['images'], 'file');
  85. return $detail;
  86. }
  87. /**
  88. * 更新记录
  89. * @param array $data
  90. * @return bool
  91. */
  92. public function edit(array $data): bool
  93. {
  94. return $this->transaction(function () use ($data) {
  95. // 更新商品图片记录
  96. CommentImageModel::updates((int)$this['comment_id'], $data['imageIds']);
  97. // 是否为图片评价
  98. $data['is_picture'] = !empty($data['imageIds']);
  99. // 更新评论记录
  100. return $this->save($data);
  101. });
  102. }
  103. /**
  104. * 软删除
  105. * @return bool
  106. */
  107. public function setDelete(): bool
  108. {
  109. return $this->save(['is_delete' => 1]);
  110. }
  111. /**
  112. * 获取评价总数量
  113. * @return int
  114. */
  115. public function getCommentTotal(): int
  116. {
  117. return $this->where(['is_delete' => 0])->count();
  118. }
  119. }