From 60de92280e4cd66a914f41b0681656a62cde346d Mon Sep 17 00:00:00 2001
From: Pu Zhibing <393733352@qq.com>
Date: 星期二, 14 一月 2025 14:50:52 +0800
Subject: [PATCH] 修改bug
---
ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/GoodsEvaluateController.java | 113 +++++++++++++++++++++++++++++++++++++++++++-------------
1 files changed, 87 insertions(+), 26 deletions(-)
diff --git a/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/GoodsEvaluateController.java b/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/GoodsEvaluateController.java
index d16a621..9a6fa18 100644
--- a/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/GoodsEvaluateController.java
+++ b/ruoyi-service/ruoyi-other/src/main/java/com/ruoyi/other/controller/GoodsEvaluateController.java
@@ -3,11 +3,15 @@
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.ruoyi.account.api.feignClient.AppUserClient;
import com.ruoyi.account.api.model.AppUser;
import com.ruoyi.common.core.domain.R;
import com.ruoyi.common.core.utils.StringUtils;
+import com.ruoyi.common.core.web.page.PageInfo;
import com.ruoyi.common.security.service.TokenService;
+import com.ruoyi.order.feignClient.OrderClient;
+import com.ruoyi.order.model.Order;
import com.ruoyi.other.api.domain.Goods;
import com.ruoyi.other.api.domain.GoodsEvaluate;
import com.ruoyi.other.service.GoodsEvaluateService;
@@ -17,10 +21,13 @@
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import io.swagger.annotations.ApiParam;
+import io.swagger.models.auth.In;
import org.springframework.web.bind.annotation.*;
import javax.annotation.Resource;
+import java.util.ArrayList;
import java.util.List;
+import java.util.stream.Collectors;
/**
* <p>
@@ -42,18 +49,28 @@
private GoodsService goodsService;
@Resource
private TokenService tokenService;
+ @Resource
+ private OrderClient orderClient;
+
+
+
@GetMapping("/goodsList")
@ApiOperation(value = "获取商品评价", tags = {"小程序-获取商品评价"})
- public R<List<GoodsEvaluate>> goodsList(@ApiParam("商品id") Integer goodsId){
- List<GoodsEvaluate> list = goodsEvaluateService.lambdaQuery().eq(GoodsEvaluate::getGoodsId, goodsId).list();
- for (GoodsEvaluate goodsEvaluate : list) {
+ public R<PageInfo<GoodsEvaluate>> goodsList(@ApiParam("商品id") Integer goodsId, Integer pageNum, Integer pageSize){
+ PageInfo<GoodsEvaluate> pageInfo = new PageInfo<>(pageNum, pageSize);
+ PageInfo<GoodsEvaluate> page = goodsEvaluateService.lambdaQuery().eq(GoodsEvaluate::getGoodsId, goodsId).eq(GoodsEvaluate::getDelFlag, 0)
+ .eq(GoodsEvaluate::getStatus, 2).isNotNull(GoodsEvaluate::getComment).ne(GoodsEvaluate::getComment, "")
+ .orderByDesc(GoodsEvaluate::getCreateTime).page(pageInfo);
+ for (GoodsEvaluate goodsEvaluate : page.getRecords()) {
AppUser appUserById = appUserClient.getAppUserById(goodsEvaluate.getAppUserId());
- goodsEvaluate.setUserName(appUserById.getName());
- goodsEvaluate.setAvatar(appUserById.getAvatar());
- goodsEvaluate.setIdStr(String.valueOf(goodsEvaluate.getId()));
+ if(null != appUserById){
+ goodsEvaluate.setUserName(appUserById.getName());
+ goodsEvaluate.setAvatar(appUserById.getAvatar());
+ goodsEvaluate.setIdStr(String.valueOf(goodsEvaluate.getId()));
+ }
}
- return R.ok(list);
+ return R.ok(page);
}
/**
@@ -76,6 +93,7 @@
List<GoodsEvaluate> list = goodsEvaluateService.list(new LambdaQueryWrapper<GoodsEvaluate>()
.eq(GoodsEvaluate::getStatus, 2)
.eq(GoodsEvaluate::getAppUserId,loginUserApplet.getUserid())
+ .eq(GoodsEvaluate::getDelFlag, 0)
.eq(GoodsEvaluate::getOrderId, orderId));
for (GoodsEvaluate goodsEvaluate : list) {
Goods goods = goodsService.getById(goodsEvaluate.getGoodsId());
@@ -90,40 +108,83 @@
* 删除评论
*/
@DeleteMapping("/delete/{id}")
- @ApiOperation(value = "删除评论", tags = {"管理后台-商品管理-评价管理-删除评论"})
+ @ApiOperation(value = "删除评论", tags = {"管理后台-商品管理-评价管理"})
public R<Void> delete(@PathVariable("id") Long id){
- goodsEvaluateService.removeById(id);
+ GoodsEvaluate goodsEvaluate = goodsEvaluateService.getById(id);
+ goodsEvaluate.setDelFlag(1);
+ goodsEvaluateService.updateById(goodsEvaluate);
+ //修改订单为待评价
+ Order data = orderClient.getOrderById(goodsEvaluate.getOrderId()).getData();
+ data.setOrderStatus(data.getOldOrderStatus());
+ orderClient.editOrder(data);
return R.ok();
}
+
+
/**
* 评论列表
*/
@GetMapping("/list")
- @ApiOperation(value = "评论列表", tags = {"管理后台-商品管理-评价管理-评论列表"})
- public R<List<GoodsEvaluate>> list(GoodsEvaluate goodsEvaluate){
- List<GoodsEvaluate> list = goodsEvaluateService.lambdaQuery()
- .like(StringUtils.isNotEmpty(goodsEvaluate.getGoodsName()),GoodsEvaluate::getGoodsName, goodsEvaluate.getComment())
- .like(StringUtils.isNotEmpty(goodsEvaluate.getUserName()),GoodsEvaluate::getUserName, goodsEvaluate.getUserName())
- .like(StringUtils.isNotEmpty(goodsEvaluate.getPhone()),GoodsEvaluate::getPhone, goodsEvaluate.getPhone())
- .eq(goodsEvaluate.getStatus()!=null,GoodsEvaluate::getStatus, goodsEvaluate.getStatus())
- .orderByDesc(GoodsEvaluate::getCreateTime)
- .list();
+ @ApiOperation(value = "评论列表", tags = {"管理后台-商品管理-评价管理"})
+ public R<Page<GoodsEvaluate>> list(@ApiParam("页码") @RequestParam Integer pageNum,
+ @ApiParam("每一页数据大小") Integer pageSize,
+ GoodsEvaluate goodsEvaluate){
+ List<Integer> goodsIds = new ArrayList<>();
+ List<Long> usersNameList = new ArrayList<>();
+ List<Long> usersPhoneList = new ArrayList<>();
- list.forEach(this::buildDetail);
+ if (StringUtils.isNotEmpty(goodsEvaluate.getGoodsName())) {
+ goodsIds = goodsService.lambdaQuery()
+ .like(Goods::getName, goodsEvaluate.getGoodsName())
+ .list().stream().map(Goods::getId).collect(Collectors.toList());
+ if (goodsIds.isEmpty()) {
+ return R.ok(new Page<>());
+ }
+ }
+ if (StringUtils.isNotEmpty(goodsEvaluate.getUserName())) {
+ usersNameList = appUserClient.getAppUserByName(goodsEvaluate.getUserName()).getData().stream().map(AppUser::getId).collect(Collectors.toList());
+ if (usersNameList.isEmpty()) {
+ return R.ok(new Page<>());
+ }
- return R.ok(list);
+ }
+ if (StringUtils.isNotEmpty(goodsEvaluate.getPhone())) {
+ usersPhoneList = appUserClient.getAppUserByPhone(goodsEvaluate.getPhone()).getData().stream().map(AppUser::getId).collect(Collectors.toList());
+ if (usersPhoneList.isEmpty()) {
+ return R.ok(new Page<>());
+ }
+ }
+ if (StringUtils.isNotEmpty(goodsEvaluate.getPhone())&&StringUtils.isNotEmpty(goodsEvaluate.getUserName())){
+ // 取交集
+ usersNameList.retainAll(usersPhoneList);
+ if (usersNameList.isEmpty())usersNameList.add(-1L);
+ }else{
+ usersNameList.addAll(usersPhoneList);
+ }
+ Page<GoodsEvaluate> page = goodsEvaluateService.page(Page.of(pageNum, pageSize), new LambdaQueryWrapper<GoodsEvaluate>()
+ .in(!goodsIds.isEmpty(), GoodsEvaluate::getGoodsId, goodsIds)
+ .in(!usersNameList.isEmpty(), GoodsEvaluate::getAppUserId, usersNameList)
+ .eq(goodsEvaluate.getStatus() != null, GoodsEvaluate::getStatus, goodsEvaluate.getStatus())
+ .eq(GoodsEvaluate::getDelFlag, 0)
+ .orderByDesc(GoodsEvaluate::getCreateTime));
+
+
+ page.getRecords().forEach(this::buildDetail);
+
+ return R.ok(page);
}
private void buildDetail(GoodsEvaluate item) {
AppUser appUser = appUserClient.getAppUserById(item.getAppUserId());
- if (appUser == null){
- throw new RuntimeException("获取用户信息失败");
+ if (appUser != null){
+ item.setPhone(appUser.getPhone());
+ item.setUserName(appUser.getName());
}
Goods goods = goodsService.getById(item.getGoodsId());
- item.setGoodsName(goods.getName());
- item.setPhone(appUser.getPhone());
- item.setUserName(appUser.getName());
+ if(null != goods){
+ item.setGoodsName(goods.getName());
+ }
}
/**
@@ -141,7 +202,7 @@
* 评论上/下架
*/
@PutMapping("/changeStatus")
- @ApiOperation(value = "上/下架", tags = {"管理后台-商品管理-评价管理-评论"})
+ @ApiOperation(value = "上/下架", tags = {"管理后台-商品管理-评价管理"})
public R<Void> changeStatus(@RequestBody GoodsEvaluate goodsEvaluate){
goodsEvaluateService.update(new LambdaUpdateWrapper<GoodsEvaluate>()
.eq(GoodsEvaluate::getId, goodsEvaluate.getId())
--
Gitblit v1.7.1