From a57112aee7438f4f550d1dd5a1b93e2a28fb386c Mon Sep 17 00:00:00 2001
From: LSH
Date: 星期五, 24 十一月 2023 17:09:21 +0800
Subject: [PATCH] #

---
 src/main/java/com/zy/crm/manager/controller/PlanController.java |  133 ++++++++++++++++++++++++--------------------
 1 files changed, 72 insertions(+), 61 deletions(-)

diff --git a/src/main/java/com/zy/crm/manager/controller/PlanController.java b/src/main/java/com/zy/crm/manager/controller/PlanController.java
index cae4711..a389b38 100644
--- a/src/main/java/com/zy/crm/manager/controller/PlanController.java
+++ b/src/main/java/com/zy/crm/manager/controller/PlanController.java
@@ -6,12 +6,10 @@
 import com.baomidou.mybatisplus.mapper.Wrapper;
 import com.baomidou.mybatisplus.plugins.Page;
 import com.core.annotations.ManagerAuth;
-import com.core.common.BaseRes;
-import com.core.common.Cools;
-import com.core.common.DateUtils;
-import com.core.common.R;
+import com.core.common.*;
 import com.core.domain.KeyValueVo;
 import com.core.exception.CoolException;
+import com.zy.crm.common.entity.PhoneCodeTypeParam;
 import com.zy.crm.common.model.SettleDto;
 import com.zy.crm.common.service.OssService;
 import com.zy.crm.common.utils.FileSaveExampleUtil;
@@ -118,6 +116,23 @@
         });
     }
 
+    @RequestMapping(value = "/plan/assistantPlan/view/auth")
+    @ManagerAuth(memo = "鏌ョ湅鍓鍒掔敵璇峰崟")
+    @Transactional
+    public R assistantPlanView(@RequestParam Long hostPlanId) {
+        Plan plan = planService.selectById(hostPlanId);
+        if (plan.getAssistantHostSign()==1){
+            EntityWrapper<Plan> wrapper = new EntityWrapper<>();
+            wrapper.eq("id",plan.getHostPlanId());
+            Page<Plan> planPage = planService.selectPage(new Page<>(1, 1), wrapper);
+            return R.ok(planPage);
+        }
+        EntityWrapper<Plan> wrapper = new EntityWrapper<>();
+        wrapper.eq("id",plan.getAssistantPlanId());
+        Page<Plan> planPage = planService.selectPage(new Page<>(1, 1), wrapper);
+        return R.ok(planPage);
+    }
+
     @RequestMapping(value = "/plan/add/auth")
     @ManagerAuth(memo = "娣诲姞瑙勫垝鐢宠鍗�")
     @Transactional
@@ -169,6 +184,11 @@
             manager = getUser();
         }
         PlanType planType = planTypeService.selectById(plan.getPlanType());
+        if (planType.getType().equals(2)) {
+            plan.setStatus2(0);
+        }else {
+            plan.setStatus2(10);
+        }
         User planLeader = planTypeService.findPlanLeader(planType);
         plan.setSettleMsg(JSON.toJSONString(SettleDto.init(plan, manager, planLeader)));
 
@@ -186,6 +206,10 @@
             throw new CoolException("淇濇寔澶辫触锛岃閲嶈瘯");
         }
 
+        if (!smsCodeService.sendSmsCodeText(planLeader.getMobile(), PhoneCodeTypeParam.ALIYUN_M1ABAC630E)) {
+            return R.ok("鍒涘缓鎴愬姛浣嗙煭淇″彂閫佸け璐�!");
+        }
+
         return R.ok();
     }
 
@@ -194,6 +218,13 @@
     @Transactional
     public R assistantPlanAdd(@RequestParam Long hostPlanId) {
         Plan hostPlan = planService.selectById(hostPlanId);
+        if (hostPlan.getAssistantHostSign()!=0){
+            return R.error("姝よ鍒掑崟涓嶉渶瑕佸垱寤哄壇娴佺▼");
+        }
+        PlanType planType2 = planTypeService.selectById(hostPlan.getPlanType());
+        if (planType2.getType()!=2){
+            return R.error("姝よ鍒掑崟涓嶉渶瑕佸垱寤哄壇娴佺▼");
+        }
         if (!Cools.isEmpty(hostPlan.getAssistantPlanId()) && hostPlan.getAssistantPlanId()!=0){
             return R.error("姝よ鍒掑崟宸插瓨鍦ㄥ壇瑙勫垝鍗曪紝id涓�"+hostPlan.getAssistantPlanId());
         }
@@ -264,6 +295,9 @@
         if (!planService.updateById(hostPlan)) {
             throw new CoolException("鏇存柊澶辫触锛岃閲嶈瘯");
         }
+        if (!smsCodeService.sendSmsCodeText(planLeader.getMobile(), PhoneCodeTypeParam.ALIYUN_M1ABAC630E)) {
+            return R.ok("鍒涘缓鎴愬姛浣嗙煭淇″彂閫佸け璐�!");
+        }
         return R.ok("淇濆瓨鎴愬姛");
     }
 
@@ -333,6 +367,7 @@
                  Plan planB = planService.selectById(planA.getHostPlanId());
                  planB.setAssistantPlanId(0L);
                  planB.setHostPlanId(0L);
+                 planB.setStatus2(0);
                  planService.updateById(planB);
              }else {
                  if (!Cools.isEmpty(planA.getAssistantPlanId()) && planA.getAssistantPlanId()!=0){
@@ -345,30 +380,6 @@
              planService.deleteById(id);
         }
         return R.ok();
-    }
-
-    @RequestMapping(value = "/plan/insert/file/auth")
-//    @ManagerAuth
-    public R insertFile(@RequestParam("planId") String planId, @RequestParam("filename") String filename, @RequestParam("filesize") Long filesize) {
-        try {
-//            InputStream inputStream = file.getInputStream();
-//            // 鑾峰彇鏂囦欢鐨勫唴瀹圭被鍨�
-//            String contentType = file.getContentType();
-//            String url = ossService.upload(inputStream, file.getOriginalFilename(), contentType);
-////            String url = "http://tjdt.oss-cn-hangzhou.aliyuncs.com/"+file.getOriginalFilename();
-//            String[] names = url.split("com/");
-//            String name= names[1];
-
-
-            String[] split = planId.split("-");
-            int id = Integer.parseInt(split[1]);
-            String url = "http://zhongyang-ftpserver.oss-cn-hangzhou.aliyuncs.com/" + filename;
-            planService.increasePlanUrl(id, url, filename, filesize);
-            return R.ok();
-        } catch (Exception e) {
-            System.out.println(e);
-            return R.error();
-        }
     }
 
     private String getFileSuffix(String filename) {
@@ -394,31 +405,6 @@
 //        }
 //        return R.ok();
 //    }
-
-    @RequestMapping(value = "/plan/view/file/auth")
-//    @ManagerAuth
-    public R viewFile(@RequestParam("planId") String planId){
-        List<FileSaveExampleUtil.FileDTO> fileDTOS = new ArrayList<>();
-        if (Cools.isEmpty(planId)){
-            return R.ok(fileDTOS);
-        }
-        int id = Integer.parseInt(planId);
-//        String savePath = "D:/crm/plan/file/"+id+"/"; // 鎸囧畾淇濆瓨鏂囦欢鐨勮矾寰�
-        try{
-            List<Integer> ids = planService.selectPlanUrlId(id);
-            for (int id2 : ids){
-                String url = planService.selectPlanUrlPlanIdUrl(id2);
-                String name = planService.selectPlanUrlPlanIdName(id2);
-                Long size = planService.selectPlanUrlPlanIdSize(id2);
-                FileSaveExampleUtil.FileDTO dto = new FileSaveExampleUtil.FileDTO(name,size,url);
-                fileDTOS.add(dto);
-            }
-//            List<FileSaveExampleUtil.FileDTO> fileDTOS = FileSaveExampleUtil.viewFileList(savePath);
-            return R.ok(fileDTOS);
-        }catch (Exception e){
-            return R.error();
-        }
-    }
 
     @RequestMapping(value = "/plan/download/file/auth")
 //    @ManagerAuth
@@ -511,8 +497,7 @@
 //                break;
             case 1:
                 // 鏌ユ壘瑙勫垝缁勯暱
-                PlanType planType = planTypeService.selectById(plan.getPlanType());
-                User planLeader = planTypeService.findPlanLeader(planType);
+                User planLeader = userService.selectById(plan.getDirector());
                 if (Cools.isEmpty(planLeader)) {
                     throw new CoolException("鏈煡鎵惧埌瑙勫垝缁勯暱锛岃鑱旂郴绠$悊鍛�");
                 }
@@ -558,11 +543,6 @@
                 plan.setUpdateBy(getUserId());
                 plan.setUpdateTime(new Date());
 
-                boolean sendSmsCode = smsCodeService.sendSmsCodeText(planner.getMobile());
-                if (!sendSmsCode) {
-                    System.out.println("鐭俊鍙戦�佸け璐ワ紒");
-                }
-
                 if (!planService.updateById(plan)) {
                     throw new CoolException("瀹℃牳澶辫触锛岃鑱旂郴绠$悊鍛�");
                 }
@@ -573,6 +553,10 @@
                 planFoll.setUserId(planner.getId());
                 if (!planFollService.insert(planFoll)) {
                     throw new CoolException("瀹℃牳澶辫触锛岃鑱旂郴绠$悊鍛�");
+                }
+
+                if (!smsCodeService.sendSmsCodeText(planner.getMobile(), PhoneCodeTypeParam.ALIYUN_M6F3C81FE3)) {
+                    return R.ok("瀹℃牳鎴愬姛浣嗙煭淇″彂閫佸け璐�!");
                 }
                 break;
             case 2:
@@ -620,6 +604,9 @@
                 if (!planService.updateById(plan)) {
                     throw new CoolException("瀹℃牳澶辫触锛岃鑱旂郴绠$悊鍛�");
                 }
+                if (!smsCodeService.sendSmsCodeText(salesman.getMobile(), PhoneCodeTypeParam.ALIYUN_M1ABAC630E)) {
+                    return R.ok("瀹℃牳鎴愬姛浣嗙煭淇″彂閫佸け璐�!");
+                }
                 break;
             case 3:
                 // 涓氬姟鍛�
@@ -653,6 +640,12 @@
                 plan.setStatus(1);  // 瀹℃壒閫氳繃
                 plan.setUpdateBy(getUserId());
                 plan.setUpdateTime(new Date());
+
+                if (plan.getAssistantHostSign()==1){
+                    Plan planHost = planService.selectById(plan.getHostPlanId());
+                    planHost.setStatus2(1);
+                    planService.updateById(planHost);
+                }
 
                 if (!planService.updateById(plan)) {
                     throw new CoolException("瀹℃牳澶辫触锛岃鑱旂郴绠$悊鍛�");
@@ -717,6 +710,9 @@
         }
         // 鏌ユ壘瑙勫垝缁勯暱
         PlanType planType = planTypeService.selectById(plan.getPlanType());
+        if (plan.getAssistantHostSign()==1){
+            planType.setType(1);
+        }
         User planLeader = planTypeService.findPlanLeader(planType);
         if (Cools.isEmpty(planLeader)) {
             throw new CoolException("鏈煡鎵惧埌瑙勫垝缁勯暱锛岃鑱旂郴绠$悊鍛�");
@@ -783,6 +779,7 @@
         EntityWrapper<Plan> wrapper = new EntityWrapper<>();
         wrapper.like("name", condition);
         wrapper.eq("status",1);
+        wrapper.eq("assistant_host_sign",0);
 
         List<ProcessPermissions> processPermissionsList = processPermissionsService.selectList(new EntityWrapper<ProcessPermissions>().eq("process_memo", 4).or().eq("process_memo", 5));//2锛氭牳浠锋祦绋�
         int type =0;
@@ -817,6 +814,20 @@
             map.put("value", plan.getName());
             result.add(map);
         }
+        if (type==1){
+            EntityWrapper<Plan> wrapper2 = new EntityWrapper<>();
+            wrapper2.like("name", condition);
+            wrapper2.eq("status",1);
+            wrapper2.eq("assistant_host_sign",1);
+            List<Plan> plan2s = planService.selectList(wrapper2);
+            for (Plan plan : plan2s){
+                Map<String, Object> map = new HashMap<>();
+                map.put("id", plan.getId());
+//            map.put("value", plan.getName()+"---"+plan.getId());
+                map.put("value", plan.getName());
+                result.add(map);
+            }
+        }
         return R.ok(result);
     }
 
@@ -845,7 +856,7 @@
      * excel瀵煎叆
      */
     @PostMapping(value = "/plan/excel/import/auth")
-    @ManagerAuth(memo = "鐢叉柟鍗曚綅Excel瀵煎叆")
+    @ManagerAuth(memo = "瀹㈡埛淇℃伅Excel瀵煎叆")
 //    @Transactional
     public R planExcelImport(MultipartFile file) throws IOException {
         InputStream inStream = file.getInputStream();

--
Gitblit v1.9.1