From 7d418bd91417a46e7361ddac77c69c786360a84e Mon Sep 17 00:00:00 2001
From: LSH
Date: 星期三, 23 八月 2023 14:02:32 +0800
Subject: [PATCH] #bug修复

---
 src/main/java/com/zy/crm/manager/controller/ReimburseOnlineController.java |   77 +++++++++++++++++++++++++++++++++-----
 1 files changed, 66 insertions(+), 11 deletions(-)

diff --git a/src/main/java/com/zy/crm/manager/controller/ReimburseOnlineController.java b/src/main/java/com/zy/crm/manager/controller/ReimburseOnlineController.java
index f5d1969..e8f4b5c 100644
--- a/src/main/java/com/zy/crm/manager/controller/ReimburseOnlineController.java
+++ b/src/main/java/com/zy/crm/manager/controller/ReimburseOnlineController.java
@@ -92,12 +92,14 @@
                   @RequestParam(required = false)String condition,
                   @RequestParam Map<String, Object> param){
         EntityWrapper<ReimburseOnline> wrapper = new EntityWrapper<>();
-        wrapper.setSqlSelect("id,title,create_time as createTime,filepath,item_id as itemId,order_num as orderNum,template_name as templateName,user_id as userId,dept_id as deptId,status,update_time as updateTime,check_data as checkData,update_user_id as updateUserId,member_id as memberId");
-        wrapper.in("member_id", getUserRoleBelongsToUserId("allopen"));
+        wrapper.setSqlSelect("id,settle,title,create_time as createTime,filepath,item_id as itemId,order_num as orderNum,template_name as templateName,user_id as userId,dept_id as deptId,status,update_time as updateTime,check_data as checkData,update_user_id as updateUserId,member_id as memberId");
+//        wrapper.in("member_id", getUserRoleBelongsToUserId());
+        wrapper.andNew();
         excludeTrash(param);
         convert(param, wrapper);
         allLike(ReimburseOnline.class, param.keySet(), wrapper, condition);
         if (!Cools.isEmpty(orderByField)){wrapper.orderBy(humpToLine(orderByField), "asc".equals(orderByType));}
+        wrapper.or().eq("member_id",getUserId());
         return R.ok(reimburseOnlineService.selectPage(new Page<>(curr, limit), wrapper));
     }
 
@@ -105,9 +107,13 @@
         Long deptId = getDeptId();
         boolean signUserId = false;
         boolean signDeptId = false;
+        boolean signHostId = false;
         for (Map.Entry<String, Object> entry : map.entrySet()){
             if (entry.getKey().equals("dept_id")){
                 signDeptId = true;
+                if (String.valueOf(entry.getValue()).equals("19")){
+                    signHostId = true;
+                }
             }
         }
         for (Map.Entry<String, Object> entry : map.entrySet()){
@@ -130,6 +136,9 @@
         if (!signUserId && !signDeptId){
             wrapper.eq("user_id", getUserId());
         }
+        if (signHostId){
+            wrapper.or().eq("host_id",1);
+        }
     }
     @RequestMapping(value = "/reimburseOnline/from/add/auth")
     @ManagerAuth(memo = "鎶ラ攢")
@@ -149,7 +158,7 @@
         reimburseOnline.setCheckData(param.getCheckData());
         reimburseOnline.setTemplateName(param.getTemplateName());
 
-        reimburseOnline.setSettle(1);  // 1.寮�濮�
+        reimburseOnline.setSettle(0);  // 0.鍒涘缓
         User manager = userService.getDeptManager(getHostId(), getUser().getDeptId());        // 鑾峰彇閮ㄩ棬棰嗗
 
         ProcessPermissions processPermissions3 = processPermissionsService.selectOne(new EntityWrapper<ProcessPermissions>().eq("process_memo", 3).eq("process", param.getCheckData().equals("鍚�")? "3-1" : "3-2"));//3锛氭姤閿�娴佺▼
@@ -172,9 +181,8 @@
         map.put("orderNo",param.getOrderNo());
         map.put("templateName",param.getTemplateName());
         map.put("checkData",param.getCheckData());
-        map.put("reimburseOnlineDetls",param.getReimburseOnlineDetls());
         reimburseOnline.setForm(JSON.toJSONString(map));
-        reimburseOnline.setMemberId(president3.getId());
+        reimburseOnline.setMemberId(getUser().getId());
 
         if (!reimburseOnlineService.insert(reimburseOnline)){
             return R.error("娣诲姞鎶ラ攢涓绘。澶辫触");
@@ -433,7 +441,7 @@
         return R.ok().add(vos);
     }
 
-    @PostMapping(value = "/reimburseOnline/approval/auth")
+    @PostMapping(value = "/reimburseOnline/approval2/auth")
     @ManagerAuth
     public R approvalReimburseOnline(@RequestParam Long planId,
                               @RequestParam(required = false) Long plannerId){
@@ -441,7 +449,45 @@
         assert reimburseOnline != null;
         Integer settle = reimburseOnline.getSettle();
         String process="";
+        Date now = new Date();
         switch (reimburseOnline.getSettle()) {
+            case 0:
+                User user2 = userService.selectById(reimburseOnline.getUserId());
+                User manager1 = userService.getDeptManager(getHostId(), user2.getDeptId());
+
+                if (Cools.isEmpty(getUser())) {
+                    return R.error("鎶辨瓑锛屾偍娌℃湁鎻愪氦鐨勬潈闄�");
+                }
+                if (!getUserId().equals(getUser().getId())) {
+                    return R.error("鎶辨瓑锛屾偍娌℃湁鎻愪氦鐨勬潈闄�");
+                }
+                // 淇敼 settle 姝ラ鏁版嵁
+                List<SettleDto> list1 = JSON.parseArray(reimburseOnline.getSettleMsg(), SettleDto.class);
+                for (SettleDto dto : list1) {
+                    switch (dto.getStep()) {
+                        case 0:
+                            dto.setCurr(Boolean.FALSE);
+                            break;
+                        case 1:
+                            dto.setCurr(Boolean.TRUE);
+                            dto.setMsg(getUser().getNickname() + "鎻愪氦瀹屾垚");
+                            dto.setTime(DateUtils.convert(now));
+                            break;
+                        default:
+                            break;
+                    }
+                }
+                reimburseOnline.setSettleMsg(JSON.toJSONString(list1));
+                // 淇敼瑙勫垝鍗曠姸鎬�
+                reimburseOnline.setSettle(1);
+                reimburseOnline.setUpdateUserId(getUserId());
+                reimburseOnline.setUpdateTime(now);
+                reimburseOnline.setMemberId(manager1.getId());
+
+                if (!reimburseOnlineService.updateById(reimburseOnline)) {
+                    throw new CoolException("瀹℃牳澶辫触锛岃鑱旂郴绠$悊鍛�");
+                }
+                break;
             case 1:
                 // 鏈儴闂ㄧ粡鐞嗗鏍�
                 User user = userService.selectById(reimburseOnline.getUserId());
@@ -458,7 +504,7 @@
                             case 2:
                                 dto.setCurr(Boolean.TRUE);
                                 dto.setMsg("閮ㄩ棬缁忕悊" + manager.getNickname() + "瀹℃壒閫氳繃");
-                                dto.setTime(DateUtils.convert(new Date()));
+                                dto.setTime(DateUtils.convert(now));
                                 break;
                             default:
                                 break;
@@ -469,7 +515,9 @@
                     // 淇敼瑙勫垝鍗曠姸鎬�
                     reimburseOnline.setSettle(2);  // 鎬昏鍔炲緟瀹�
                     reimburseOnline.setUpdateUserId(getUserId());
-                    reimburseOnline.setUpdateTime(new Date());
+                    reimburseOnline.setUpdateTime(now);
+                    ProcessPermissions processPermissions = processPermissionsService.selectOne(new EntityWrapper<ProcessPermissions>().eq("process_memo", 3).eq("process", reimburseOnline.getCheckData().equals("鍚�") ? "3-1" : "3-2"));//3锛氭姤閿�娴佺▼
+                    reimburseOnline.setMemberId(processPermissions.getUserId());
 
                     if (!reimburseOnlineService.updateById(reimburseOnline)) {
                         throw new CoolException("瀹℃牳澶辫触锛岃鑱旂郴绠$悊鍛�");
@@ -515,7 +563,7 @@
                     }else if (dto.getStep().equals(settle+1)){
                         dto.setCurr(Boolean.TRUE);
                         dto.setMsg("鎶ヤ环娴佺▼鑺傜偣"+process+"纭浜�:"+planLeader.getNickname() + "瀹℃壒閫氳繃");
-                        dto.setTime(DateUtils.convert(new Date()));
+                        dto.setTime(DateUtils.convert(now));
                         break;
                     }else {
                         break;
@@ -525,8 +573,15 @@
                 // 淇敼瑙勫垝鍗曠姸鎬�
                 reimburseOnline.setSettle(settle+1);
                 reimburseOnline.setUpdateUserId(getUserId());
-                reimburseOnline.setUpdateTime(new Date());
-                reimburseOnline.setMemberId(planLeader.getId());
+                reimburseOnline.setUpdateTime(now);
+                String[] split = process.split("-");
+                if (settle!=5){
+                    settle=settle+2;
+                }else {
+                    settle++;
+                }
+                ProcessPermissions processPermissions2 = processPermissionsService.selectOne(new EntityWrapper<ProcessPermissions>().eq("process_memo", 3).eq("process", settle+"-"+split[1]));//3锛氭姤閿�娴佺▼
+                reimburseOnline.setMemberId(processPermissions2.getUserId());
 
                 if (!reimburseOnlineService.updateById(reimburseOnline)) {
                     throw new CoolException("瀹℃牳澶辫触锛岃鑱旂郴绠$悊鍛�");

--
Gitblit v1.9.1