From 1442f149019ee0590389abd7a88a79c4d9b59034 Mon Sep 17 00:00:00 2001
From: 无关风月 <443237572@qq.com>
Date: 星期二, 27 五月 2025 18:23:34 +0800
Subject: [PATCH] bug修改

---
 ruoyi-service/ruoyi-admin/src/main/java/com/ruoyi/admin/controller/EvaluateController.java |   98 ++++++++++++++++++++++++++++++++++++++++---------
 1 files changed, 80 insertions(+), 18 deletions(-)

diff --git a/ruoyi-service/ruoyi-admin/src/main/java/com/ruoyi/admin/controller/EvaluateController.java b/ruoyi-service/ruoyi-admin/src/main/java/com/ruoyi/admin/controller/EvaluateController.java
index 4c1bc37..5937adf 100644
--- a/ruoyi-service/ruoyi-admin/src/main/java/com/ruoyi/admin/controller/EvaluateController.java
+++ b/ruoyi-service/ruoyi-admin/src/main/java/com/ruoyi/admin/controller/EvaluateController.java
@@ -1,13 +1,21 @@
 package com.ruoyi.admin.controller;
 
 
-import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
-import com.ruoyi.admin.entity.Evaluate;
-import com.ruoyi.admin.service.EvaluateService;
-import com.ruoyi.admin.vo.EvaluatePageVO;
+import com.ruoyi.admin.entity.Franchisee;
+import com.ruoyi.admin.entity.User;
+import com.ruoyi.admin.service.FranchiseeService;
+import com.ruoyi.admin.service.UserService;
 import com.ruoyi.common.core.domain.R;
+import com.ruoyi.common.core.utils.StringUtils;
+import com.ruoyi.common.security.annotation.Logical;
 import com.ruoyi.common.security.annotation.RequiresPermissions;
+import com.ruoyi.common.security.service.TokenService;
+import com.ruoyi.order.api.entity.Evaluate;
+import com.ruoyi.order.api.entity.EvaluatePageVO;
+import com.ruoyi.order.api.feignClient.EvaluateClient;
+import com.ruoyi.order.api.request.EvaluatePageRequest;
+import com.ruoyi.system.api.model.LoginUser;
 import io.swagger.annotations.Api;
 import io.swagger.annotations.ApiImplicitParam;
 import io.swagger.annotations.ApiImplicitParams;
@@ -18,6 +26,7 @@
 import org.springframework.web.bind.annotation.RestController;
 
 import javax.annotation.Resource;
+import java.util.ArrayList;
 import java.util.Arrays;
 import java.util.List;
 import java.util.stream.Collectors;
@@ -36,15 +45,20 @@
 public class EvaluateController {
 
     @Resource
-    private EvaluateService evaluateService;
-
+    private EvaluateClient evaluateClient;
+    @Resource
+    private TokenService tokenService;
+    @Resource
+    private UserService userService;
+    @Resource
+    private FranchiseeService franchiseeService;
     /**
      * 订单评价分页列表
      *
      * @param pageNum  页码
      * @param pageSize 每页显示条数
      */
-    @RequiresPermissions("order_evaluate")
+    @RequiresPermissions(value = {"user_detail", "order_evaluate"}, logical = Logical.OR)
     @ApiOperation(value = "订单评价分页查询列表", tags = {"后台-系统设置-订单评价管理"})
     @GetMapping(value = "/page")
     @ApiImplicitParams({
@@ -54,10 +68,61 @@
             @ApiImplicitParam(value = "页码", name = "pageNum", dataType = "Integer", required = true),
             @ApiImplicitParam(value = "每页条数", name = "pageSize", dataType = "Integer", required = true)
     })
-    public R<IPage<EvaluatePageVO>> queryPageList(String userNo, String orderNumber, String workerName,
-                                                  @RequestParam(name = "pageNum", defaultValue = "1") Integer pageNum,
-                                                  @RequestParam(name = "pageSize", defaultValue = "10") Integer pageSize) {
-        return R.ok(evaluateService.queryPageList(userNo, orderNumber, workerName, Page.of(pageNum, pageSize)));
+    public R<Page<EvaluatePageVO>> queryPageList(String userNo, String orderNumber, String workerName,
+                                                 @RequestParam(name = "pageNum", defaultValue = "1") Integer pageNum,
+                                                 @RequestParam(name = "pageSize", defaultValue = "10") Integer pageSize) {
+        LoginUser loginUser = tokenService.getLoginUser();
+        if (null == loginUser) {
+            return R.loginExpire("登录失效!");
+        }
+        List<String> cityList = new ArrayList<>();
+        if (loginUser.getIsFranchisee()) {
+            cityList = loginUser.getCityList();
+        }
+        List<User> userList;
+        if (StringUtils.isNotBlank(userNo)) {
+            userList = userService.lambdaQuery().like(User::getNickname, userNo).list();
+            if (userList.isEmpty()){
+                Page<EvaluatePageVO> page = new Page<>();
+            return   R.ok(page);
+            }
+        } else {
+            userList = new ArrayList<>();
+        }
+        List<Integer> userIdList = userList.stream().map(User::getId).collect(Collectors.toList());
+        EvaluatePageRequest evaluatePageRequest = new EvaluatePageRequest();
+        evaluatePageRequest.setUserNo(userNo);
+        evaluatePageRequest.setOrderNumber(orderNumber);
+        evaluatePageRequest.setWorkerName(workerName);
+        evaluatePageRequest.setCityList(cityList);
+        evaluatePageRequest.setPageNum(pageNum);
+        evaluatePageRequest.setPageSize(pageSize);
+        evaluatePageRequest.setUserIdList(userIdList);
+
+        Integer franchiseeId = loginUser.getSysUser().getFranchiseeId();
+        String[] siteIds = new String[0];
+        if (franchiseeId!=null) {
+            Franchisee byId = franchiseeService.getById(franchiseeId);
+            siteIds  = byId.getSiteIds().split(",");
+            evaluatePageRequest.setSiteIds(Arrays.asList(siteIds));
+            if (loginUser.getIsFranchisee() && siteIds.length == 0) {
+                return R.ok(new Page<>());
+            }
+        }
+
+
+
+        R<Page<EvaluatePageVO>> r = evaluateClient.queryPageList(evaluatePageRequest);
+        if (!r.getData().getRecords().isEmpty()) {
+            for (EvaluatePageVO record : r.getData().getRecords()) {
+                Integer userId = record.getUserId();
+                User user = userService.getById(userId);
+                if (null != user) {
+                    record.setUserNo(user.getNickname());
+                }
+            }
+        }
+        return r;
     }
 
     /**
@@ -65,14 +130,14 @@
      *
      * @param id 订单评价id
      */
-    @RequiresPermissions("order_evaluate")
+    @RequiresPermissions(value = {"user_detail", "evaluate_detail"}, logical = Logical.OR)
     @ApiOperation(value = "订单评价详情", tags = {"后台-系统设置-订单评价管理"})
     @GetMapping(value = "/detail")
     @ApiImplicitParams({
             @ApiImplicitParam(value = "订单评价id", name = "id", dataType = "Integer", required = true)
     })
     public R<Evaluate> detail(@RequestParam Integer id) {
-        return R.ok(evaluateService.getById(id));
+        return evaluateClient.detail(id);
     }
 
     /**
@@ -80,17 +145,14 @@
      *
      * @param ids 订单评价多条id拼接
      */
-    @RequiresPermissions("order_evaluate")
+    @RequiresPermissions(value = {"user_detail", "evaluate_delete"}, logical = Logical.OR)
     @ApiOperation(value = "批量删除订单评价", tags = {"后台-系统设置-订单评价管理"})
     @GetMapping(value = "/batchDelete")
     @ApiImplicitParams({
             @ApiImplicitParam(value = "多条订单评价id ',' 拼接", name = "ids", dataType = "String", required = true)
     })
     public R<String> batchDelete(@RequestParam String ids) {
-        List<String> idList = Arrays.stream(ids.split(",")).collect(Collectors.toList());
-        List<Evaluate> list = evaluateService.lambdaQuery().in(Evaluate::getId, idList).list();
-        list.forEach(data -> data.setIsDelete(1));
-        return evaluateService.updateBatchById(list) ? R.ok() : R.fail();
+        return evaluateClient.batchDelete(ids);
     }
 
 

--
Gitblit v1.7.1