123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127 |
- <?php
- // +----------------------------------------------------------------------
- // | 萤火商城系统 [ 致力于通过产品和服务,帮助商家高效化开拓市场 ]
- // +----------------------------------------------------------------------
- // | Copyright (c) 2017~2024 https://www.yiovo.com All rights reserved.
- // +----------------------------------------------------------------------
- // | Licensed 这不是一个自由软件,不允许对程序代码以任何形式任何目的的再发行
- // +----------------------------------------------------------------------
- // | Author: 萤火科技 <admin@yiovo.com>
- // +----------------------------------------------------------------------
- declare (strict_types=1);
- namespace app\store\model;
- use app\common\library\helper;
- use app\common\model\Comment as CommentModel;
- use app\store\model\CommentImage as CommentImageModel;
- /**
- * 商品评价模型
- * Class Comment
- * @package app\store\model
- */
- class Comment extends CommentModel
- {
- /**
- * 获取评价列表
- * @param array $param
- * @return iterable|\think\model\Collection|\think\Paginator
- */
- public function getList(array $param = [])
- {
- // 检索查询条件
- $query = $this->setQueryFilter($param);
- // 查询列表数据
- return $query->with(['user.avatar', 'orderGoods' => ['image']])
- ->alias($this->name)
- ->field(["$this->name.*"])
- ->join('goods', "goods.goods_id = {$this->name}.goods_id")
- ->join('order', "order.order_id = {$this->name}.order_id")
- ->join('user', "user.user_id = {$this->name}.user_id")
- ->where("{$this->name}.is_delete", '=', 0)
- ->order(["{$this->name}.sort" => 'asc', "{$this->name}.create_time" => 'desc'])
- ->paginate(15);
- }
- /**
- * 检索查询条件
- * @param array $param
- * @return \think\db\BaseQuery
- */
- private function setQueryFilter(array $param): \think\db\BaseQuery
- {
- // 实例化查询对象
- $query = $this->getNewQuery();
- // 查询参数
- $params = $this->setQueryDefaultValue($param, [
- 'score' => 0, // 评分 (10好评 20中评 30差评)
- 'goodsName' => '', // 商品名称/编码
- 'orderNo' => '', // 订单号
- 'userId' => 0, // 用户id
- 'status' => -1 // 评价状态 -1全部
- ]);
- // 评分
- $params['score'] > 0 && $query->where("{$this->name}.score", '=', $params['score']);
- // 商品名称/编码
- !empty($params['goodsName']) && $query->where('goods.goods_name|goods.goods_no', 'like', "%{$params['goodsName']}%");
- // 订单号
- !empty($params['orderNo']) && $query->where('order.order_no', 'like', "%{$params['orderNo']}%");
- // 用户id
- $params['userId'] > 0 && $query->where("{$this->name}.user_id", '=', $params['userId']);
- // 评价状态
- $params['status'] > -1 && $query->where("{$this->name}.status", '=', $params['status']);
- return $query;
- }
- /**
- * 获取评价详情
- * @param int $commentId
- * @return Comment|array|null
- */
- public function getDetail(int $commentId)
- {
- // 评价详情
- $detail = static::detail($commentId, ['images.file']);
- // 图片ID集
- $detail['imageIds'] = helper::getArrayColumn($detail['images'], 'image_id');
- // 图片列表
- $detail['imageList'] = helper::getArrayColumn($detail['images'], 'file');
- return $detail;
- }
- /**
- * 更新记录
- * @param array $data
- * @return bool
- */
- public function edit(array $data): bool
- {
- return $this->transaction(function () use ($data) {
- // 更新商品图片记录
- CommentImageModel::updates((int)$this['comment_id'], $data['imageIds']);
- // 是否为图片评价
- $data['is_picture'] = !empty($data['imageIds']);
- // 更新评论记录
- return $this->save($data);
- });
- }
- /**
- * 软删除
- * @return bool
- */
- public function setDelete(): bool
- {
- return $this->save(['is_delete' => 1]);
- }
- /**
- * 获取评价总数量
- * @return int
- */
- public function getCommentTotal(): int
- {
- return $this->where(['is_delete' => 0])->count();
- }
- }
|