104 lines
3.6 KiB
PHP
Executable File
104 lines
3.6 KiB
PHP
Executable File
<?php
|
||
// +----------------------------------------------------------------------
|
||
// | likeshop开源商城系统
|
||
// +----------------------------------------------------------------------
|
||
// | 欢迎阅读学习系统程序代码,建议反馈是我们前进的动力
|
||
// | gitee下载:https://gitee.com/likeshop_gitee
|
||
// | github下载:https://github.com/likeshop-github
|
||
// | 访问官网:https://www.likeshop.cn
|
||
// | 访问社区:https://home.likeshop.cn
|
||
// | 访问手册:http://doc.likeshop.cn
|
||
// | 微信公众号:likeshop技术社区
|
||
// | likeshop系列产品在gitee、github等公开渠道开源版本可免费商用,未经许可不能去除前后端官方版权标识
|
||
// | likeshop系列产品收费版本务必购买商业授权,购买去版权授权后,方可去除前后端官方版权标识
|
||
// | 禁止对系统程序代码以任何目的,任何形式的再发布
|
||
// | likeshop团队版权所有并拥有最终解释权
|
||
// +----------------------------------------------------------------------
|
||
// | author: likeshop.cn.team
|
||
// +----------------------------------------------------------------------
|
||
|
||
namespace app\shopapi\lists;
|
||
|
||
|
||
use app\common\enum\OrderEnum;
|
||
use app\common\model\coach\Coach;
|
||
use app\common\model\goods\GoodsComment;
|
||
use app\common\model\order\Order;
|
||
use app\common\model\order\OrderGoods;
|
||
use app\common\model\user\User;
|
||
use app\common\service\FileService;
|
||
|
||
class CommentGoodsLists extends BaseShopApiDataLists
|
||
{
|
||
/**
|
||
* @notes 搜索条件
|
||
* @return array
|
||
* @author ljj
|
||
* @date 2022/2/18 2:25 下午
|
||
*/
|
||
public function setWhere()
|
||
{
|
||
$shopId = $this->shopId;
|
||
$where = [];
|
||
$id = $this->params['id'] ?? 0;
|
||
switch ($id){
|
||
case 1:
|
||
$goodsCommentId = GoodsComment::alias('GC')
|
||
->where(['shop_id'=>$shopId])
|
||
->join('goods_comment_image GCI','GC.id = GCI.comment_id')
|
||
->column('GC.id') ?: [];
|
||
empty($goodsCommentId) && $goodsCommentId = [];
|
||
$where[] = ['id','in',implode(',',$goodsCommentId)];
|
||
break;
|
||
case 2:
|
||
$where[] = ['service_comment','>',3];
|
||
break;
|
||
case 3:
|
||
$where[] = ['service_comment','<=',3];
|
||
break;
|
||
}
|
||
return $where;
|
||
}
|
||
|
||
/**
|
||
* @notes 评价商品列表
|
||
* @return array
|
||
* @author ljj
|
||
* @date 2022/2/21 5:59 下午
|
||
*/
|
||
public function lists(): array
|
||
{
|
||
$lists = GoodsComment::where(['shop_id'=>$this->shopId])
|
||
->where($this->setWhere())
|
||
->with(['goods_comment_image'])
|
||
->field('id,user_id,service_comment,comment,reply,create_time')
|
||
->order('id desc')
|
||
->limit($this->limitOffset, $this->limitLength)
|
||
->select()->toArray();
|
||
$userIds = array_column($lists,'user_id');
|
||
$userLists = [];
|
||
if($userIds){
|
||
$userLists = User::where(['id'=>$userIds])->field('id,nickname,avatar')->select()->toArray();
|
||
$userLists = array_column($userLists,null,'id');
|
||
}
|
||
foreach ($lists as $key => $goodsComment){
|
||
$lists[$key]['nickname'] = $userLists[$goodsComment['user_id']]['nickname'];
|
||
$lists[$key]['avatar'] = $userLists[$goodsComment['user_id']]['avatar'];
|
||
}
|
||
return $lists;
|
||
}
|
||
|
||
/**
|
||
* @notes 评价商品总数
|
||
* @return int
|
||
* @author ljj
|
||
* @date 2022/2/21 5:59 下午
|
||
*/
|
||
public function count(): int
|
||
{
|
||
return GoodsComment::where(['shop_id'=>$this->shopId])
|
||
->where($this->setWhere())
|
||
->count();
|
||
}
|
||
|
||
} |