From 13a34d2197b001799ef8f0f09e5b48af2add0926 Mon Sep 17 00:00:00 2001 From: lsh <lsh@163.com> Date: 星期一, 15 四月 2024 09:25:31 +0800 Subject: [PATCH] # --- src/main/java/com/zy/crm/manager/controller/WeeklyController.java | 344 +++++++++++++++++++++++++++++++++++++++++++++++++++++--- 1 files changed, 322 insertions(+), 22 deletions(-) diff --git a/src/main/java/com/zy/crm/manager/controller/WeeklyController.java b/src/main/java/com/zy/crm/manager/controller/WeeklyController.java index 5226b02..4b21846 100644 --- a/src/main/java/com/zy/crm/manager/controller/WeeklyController.java +++ b/src/main/java/com/zy/crm/manager/controller/WeeklyController.java @@ -1,19 +1,18 @@ package com.zy.crm.manager.controller; +import com.alibaba.fastjson.JSON; import com.alibaba.fastjson.JSONObject; import com.baomidou.mybatisplus.mapper.EntityWrapper; import com.baomidou.mybatisplus.mapper.Wrapper; import com.baomidou.mybatisplus.plugins.Page; import com.core.common.DateUtils; import com.core.exception.CoolException; -import com.zy.crm.manager.entity.Weekly; -import com.zy.crm.manager.entity.WeeklyDailyPlan; -import com.zy.crm.manager.entity.WeeklyDailyReality; +import com.zy.crm.common.entity.PhoneCodeTypeParam; +import com.zy.crm.common.model.SettleDto; +import com.zy.crm.manager.entity.*; import com.zy.crm.manager.entity.param.CstmrUtilsParam; import com.zy.crm.manager.entity.param.WeeklyDomainParam; -import com.zy.crm.manager.service.WeeklyDailyPlanService; -import com.zy.crm.manager.service.WeeklyDailyRealityService; -import com.zy.crm.manager.service.WeeklyService; +import com.zy.crm.manager.service.*; import com.core.annotations.ManagerAuth; import com.core.common.BaseRes; import com.core.common.Cools; @@ -21,6 +20,8 @@ import com.core.domain.KeyValueVo; import com.zy.crm.common.web.BaseController; import com.zy.crm.manager.utils.TimeCalculatorUtils; +import com.zy.crm.system.entity.User; +import com.zy.crm.system.service.UserService; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.transaction.annotation.Transactional; @@ -38,11 +39,34 @@ private WeeklyDailyPlanService weeklyDailyPlanService; @Autowired private WeeklyDailyRealityService weeklyDailyRealityService; + @Autowired + private UserService userService; + @Autowired + private WeeklyFollService weeklyFollService; + @Autowired + private SmsCodeService smsCodeService; + @Autowired + private CstmrService cstmrService; + + String PZH = " 鈥斺�斺�斺�斺�斺�斺�斺�斺�斺�斺�斺�斺�斺�斺�斺�斺�� "; + Integer PBN = 3; @RequestMapping(value = "/weekly/{id}/auth") @ManagerAuth public R get(@PathVariable("id") String id) { - return R.ok(weeklyService.selectById(String.valueOf(id))); + Weekly weekly = weeklyService.selectById(String.valueOf(id)); + assert weekly != null; + JSONObject resultObj = JSON.parseObject(JSON.toJSONString(weekly)); + if (!Cools.isEmpty(weekly.getForm())) { + JSONObject formObj = JSON.parseObject(weekly.getForm()); + formObj.forEach(resultObj::putIfAbsent); + } + + // 姝ラ鏉$浉鍏� + resultObj.put("step", weekly.getSettle().equals(weekly.getSettleSize()) ? 0 : weekly.getSettle() + 1); + + return R.ok().add(resultObj); +// return R.ok(weeklyService.selectById(String.valueOf(id))); } @RequestMapping(value = "/weekly/list/auth") @@ -93,11 +117,27 @@ @RequestMapping(value = "/weekly/delete/auth") @ManagerAuth - public R delete(@RequestParam(value="ids[]") Long[] ids){ - for (Long id : ids){ - weeklyService.deleteById(id); - } - return R.ok(); + public R delete(@RequestParam() Long[] ids){ + try{ + for (Long id : ids){ + List<WeeklyDailyReality> weeklyDailyRealities = weeklyDailyRealityService.selectList(new EntityWrapper<WeeklyDailyReality>().eq("weekly_id", id)); + for (WeeklyDailyReality weeklyDailyReality:weeklyDailyRealities){ + weeklyDailyRealityService.deleteById(weeklyDailyReality); + } + List<WeeklyDailyPlan> weeklyDailyPlans = weeklyDailyPlanService.selectList(new EntityWrapper<WeeklyDailyPlan>().eq("weekly_id", id)); + for (WeeklyDailyPlan weeklyDailyPlan:weeklyDailyPlans){ + weeklyDailyPlanService.deleteById(weeklyDailyPlan); + } + List<WeeklyFoll> weeklyFolls = weeklyFollService.selectList(new EntityWrapper<WeeklyFoll>().eq("weekly_id", id)); + for (WeeklyFoll weeklyFoll:weeklyFolls){ + weeklyFollService.deleteById(weeklyFoll); + } + weeklyService.deleteById(id); + } + }catch (Exception e){ + throw new CoolException("鍒犻櫎澶辫触锛屽紓甯镐俊鎭細"+e); + } + return R.ok(); } @RequestMapping(value = "/weekly/export/auth") @@ -168,8 +208,6 @@ weekly.setDeptId(getDeptId()); // 鎵�灞為儴闂� weekly.setUserId(getUserId()); // 鎵�灞炰汉鍛� - weekly.setDirector(getUserId()); // 鎵�灞炰汉鍛� - weekly.setCreateBy(getUserId()); weekly.setCreateTime(now); weekly.setUpdateBy(getUserId()); @@ -212,6 +250,34 @@ weekly.setWeeklyNowMonth(TimeCalculatorUtils.WeeklyNowMonthDay(weekly.getStartTime())); weekly.setWeeklyDayMonth(weekly.getWeeklyMonth()+"鏈堢"+weekly.getWeeklyNowMonth()+"鍛�"); + User manager = new User(); + try { + manager = userService.getDeptManager(getHostId(), getUser().getDeptId()); // 鑾峰彇閮ㄩ棬棰嗗 + } catch (Exception e) { + manager = getUser(); + } + // 鑾峰彇涓氬姟鍛� + List<String> initNames = new ArrayList<>(); + initNames.add("鍒涘缓浜嗗鎵�"); + initNames.add("涓氬姟鍛樻彁浜�"); + initNames.add("閮ㄩ棬棰嗗瀹℃牳"); + List<User> users = new ArrayList<>(); + users.add(getUser()); + users.add(getUser()); + users.add(manager); +// users.add(getUser()); + weekly.setSettleMsg(JSON.toJSONString(SettleDto.InItFlowPathTwo(users, initNames, users.size()))); + weekly.setSettleSize(users.size()); + weekly.setSettleCurrent(1); + if (users.size() > 1) { + weekly.setDirector(users.get(1).getId()); + } else { + weekly.setDirector(getUserId()); + } + + + weekly.setSettleSize(users.size()); + List<Date> dates = TimeCalculatorUtils.WeeklyListDays(dateList);//鑾峰彇鍛ㄤ竴鍒板懆鏃ユ棩鏈� try{ @@ -228,7 +294,7 @@ weeklyDailyPlan.setDeptId(getDeptId()); // 鎵�灞為儴闂� weeklyDailyPlan.setUserId(getUserId()); // 鎵�灞炰汉鍛� - weeklyDailyPlan.setDirector(getUserId()); // 鎵�灞炰汉鍛� + weeklyDailyPlan.setDirector(manager.getId()); // 鎵�灞炰汉鍛� weeklyDailyPlan.setCreateBy(getUserId()); weeklyDailyPlan.setCreateTime(now); @@ -248,12 +314,36 @@ } } + try{ + insertWeeklyFoll(users,weekly.getId()); // 鑷姩娣诲姞璺熻繘浜� + }catch (Exception e){ + log.error("鍛ㄦ姤娣诲姞璺熻繘浜哄紓甯革紝寮傚父淇℃伅1锛�"+e); + } + } catch (Exception e){ log.error("鍒涘缓鍛ㄨ鍒掑紓甯革紝寮傚父淇℃伅锛�"+e); throw new CoolException("鍒涘缓鍛ㄨ鍒掑け璐�==>"+e); } return R.ok("鍒涘缓鎴愬姛"); + } + + public void insertWeeklyFoll(List<User> userList,Long weeklyId){ + for (User user:userList){ + try{ + // 鑷姩娣诲姞璺熻繘浜� + List<WeeklyFoll> weeklyFolls = weeklyFollService.selectList(new EntityWrapper<WeeklyFoll>().eq("weekly_id", weeklyId).eq("user_id", user.getId())); + if (weeklyFolls.size()==0){ + WeeklyFoll weeklyFoll = new WeeklyFoll(); + weeklyFoll.setUserId(user.getId()); + weeklyFoll.setWeeklyId(weeklyId); + weeklyFollService.insert(weeklyFoll); + } + }catch (Exception e){ + log.error("鍛ㄦ姤娣诲姞璺熻繘浜哄紓甯革紝寮傚父淇℃伅2锛�"+e); + continue; + } + } } @RequestMapping(value = "/weekly/from/add/auth2") @@ -278,12 +368,37 @@ weekly.setDeptId(getDeptId()); // 鎵�灞為儴闂� weekly.setUserId(getUserId()); // 鎵�灞炰汉鍛� - weekly.setDirector(getUserId()); // 鎵�灞炰汉鍛� - weekly.setCreateBy(getUserId()); weekly.setCreateTime(now); weekly.setUpdateBy(getUserId()); weekly.setUpdateTime(now); + + User manager = new User(); + try { + manager = userService.getDeptManager(getHostId(), getUser().getDeptId()); // 鑾峰彇閮ㄩ棬棰嗗 + } catch (Exception e) { + manager = getUser(); + } + weekly.setDirector(manager.getId()); + + // 鑾峰彇涓氬姟鍛� + List<String> initNames = new ArrayList<>(); + initNames.add("鍒涘缓浜嗗鎵�"); + initNames.add("涓氬姟鍛樻彁浜�"); + initNames.add("閮ㄩ棬棰嗗瀹℃牳"); + List<User> users = new ArrayList<>(); + users.add(getUser()); + users.add(getUser()); + users.add(manager); +// users.add(getUser()); + weekly.setSettleMsg(JSON.toJSONString(SettleDto.InItFlowPathTwo(users, initNames, users.size()))); + weekly.setSettleSize(users.size()); + weekly.setSettleCurrent(1); + if (users.size() > 1) { + weekly.setDirector(users.get(1).getId()); + } else { + weekly.setDirector(getUserId()); + } List<Date> dateList = new ArrayList<>();//鑾峰彇鍛ㄤ竴涓庡懆鏃ユ棩鏈� @@ -338,7 +453,7 @@ weeklyDailyReality.setDeptId(getDeptId()); // 鎵�灞為儴闂� weeklyDailyReality.setUserId(getUserId()); // 鎵�灞炰汉鍛� - weeklyDailyReality.setDirector(getUserId()); // 鎵�灞炰汉鍛� + weeklyDailyReality.setDirector(manager.getId()); // 鎵�灞炰汉鍛� weeklyDailyReality.setCreateBy(getUserId()); weeklyDailyReality.setCreateTime(now); @@ -356,6 +471,12 @@ log.error("鏂板鏃ヨ鍒掑け璐�"+e); throw new CoolException("鏂板鏃ヨ鍒掑け璐�"); } + } + + try{ + insertWeeklyFoll(users,weekly.getId()); // 鑷姩娣诲姞璺熻繘浜� + }catch (Exception e){ + log.error("鍛ㄦ姤娣诲姞璺熻繘浜哄紓甯革紝寮傚父淇℃伅1锛�"+e); } } catch (Exception e){ @@ -378,8 +499,6 @@ throw new CoolException("鍙傛暟涓虹┖锛歐eeklyDailyPlanList"); } else if (Cools.isEmpty(param.getWeeklyId())){ throw new CoolException("鍙傛暟涓虹┖锛歐eeklyId"); - } else if (Cools.isEmpty(param.getWeeklyType())){ - throw new CoolException("鍙傛暟涓虹┖锛歐eeklyDailyPlanList"); } else if (Cools.isEmpty(param.getType())){ throw new CoolException("鍙傛暟涓虹┖锛歍ype"); } else if (Cools.isEmpty(param.getWeeklyType())){ @@ -476,8 +595,6 @@ throw new CoolException("鍙傛暟涓虹┖锛歐eeklyDailyRealityList"); } else if (Cools.isEmpty(param.getWeeklyId())){ throw new CoolException("鍙傛暟涓虹┖锛歐eeklyId"); - } else if (Cools.isEmpty(param.getWeeklyType())){ - throw new CoolException("鍙傛暟涓虹┖锛歐eeklyDailyPlanList"); } else if (Cools.isEmpty(param.getType())){ throw new CoolException("鍙傛暟涓虹┖锛歍ype"); } else if (Cools.isEmpty(param.getWeeklyType())){ @@ -576,4 +693,187 @@ List<WeeklyDailyReality> weeklyDailyRealities = weeklyDailyRealityService.selectList(new EntityWrapper<WeeklyDailyReality>().eq("weekly_id", weeklyId)); return R.ok().add(weeklyDailyRealities); } + + @PostMapping(value = "/weekly/approval/auth") + @ManagerAuth(memo = "瀹℃壒鐢宠鍗�") + public R approval(@RequestParam Long weeklyId, + @RequestParam(required = false) Long plannerId) { + Weekly weekly = weeklyService.selectById(weeklyId); + assert weekly != null; + Long nextUserId = getUserId(); + User director = userService.selectById(weekly.getDirector()); + + if (Cools.isEmpty(getUser()) || Cools.isEmpty(director)) { + return R.error("鎶辨瓑锛屾偍鏃犻渶纭锛侊紒锛�"); + } + + if (!getUserId().equals(director.getId())) { + return R.error("鎶辨瓑锛屾偍鏃犻渶纭锛侊紒锛�"); + } + + // 淇敼 settle 姝ラ鏁版嵁 + List<SettleDto> list = JSON.parseArray(weekly.getSettleMsg(), SettleDto.class); + // 淇敼 settle 姝ラ鏁版嵁 + for (SettleDto dto : list) { + if (dto.getStep().equals(weekly.getSettle())) { + dto.setCurr(Boolean.TRUE); + } else if (dto.getStep().equals(weekly.getSettle() + 1)) { + dto.setCurr(Boolean.TRUE); + if (Cools.isEmpty(dto.getMsg())) { + dto.setMsg(director.getNickname() + "瀹℃壒閫氳繃"); + } else { + dto.setMsg(dto.getMsg() + PZH + DateUtils.convert(new Date()) + " " + director.getNickname() + "瀹℃壒閫氳繃"); + } + dto.setTime(DateUtils.convert(new Date())); + } else if (dto.getStep().equals(weekly.getSettle() + 2)) { + nextUserId = dto.getUserId(); + } + } + weekly.setSettleMsg(JSON.toJSONString(list)); + // 淇敼瑙勫垝鍗曠姸鎬� + weekly.setSettle(weekly.getSettle() + 1); // 瀹℃壒閫氳繃 + + weekly.setUpdateBy(getUserId()); + weekly.setUpdateTime(new Date()); + weekly.setDirector(nextUserId); + + if (!weeklyService.updateById(weekly)) { + throw new CoolException("瀹℃牳澶辫触锛岃鑱旂郴绠$悊鍛�"); + } + if (!weekly.getSettle().equals(weekly.getSettleSize())) { + User phoneUser = userService.selectById(nextUserId); + if (!smsCodeService.sendSmsCodeText(phoneUser.getMobile(), PhoneCodeTypeParam.ALIYUN_M1ABAC630E, getUserId())) { + return R.ok("瀹℃牳鎴愬姛浣嗙煭淇″彂閫佸け璐�!"); + } + } + + return R.ok("瀹℃壒鎴愬姛"); + } + + @PostMapping(value = "/weekly/approvalEnd/auth") + @ManagerAuth(memo = "鎷掔粷鐢宠鍗�") + public R approvalEnd(@RequestParam Long weeklyId, + @RequestParam(required = false) Long plannerId) { + Weekly weekly = weeklyService.selectById(weeklyId); + Date now = new Date(); + Long nextUserId = getUserId(); + Long directorId = weekly.getDirector(); + User director = userService.selectById(directorId); + if (!director.getId().equals(getUserId())) { + return R.error("鎶辨瓑锛屾偍娌℃湁瀹℃牳鐨勬潈闄�"); + } + List<SettleDto> planDtos = JSON.parseArray(weekly.getSettleMsg(), SettleDto.class); + List<SettleDto> planDtoList = new ArrayList<>(); + boolean sign = true; + for (SettleDto dto : planDtos) { + if (dto.getStep().equals(2)) { + nextUserId = dto.getUserId(); + weekly.setDirector(dto.getUserId()); + } + if (sign && dto.getUserId().equals(directorId) && weekly.getSettle() + 1 == dto.getStep()) { + if (Cools.isEmpty(dto.getMsg())) { + dto.setMsg(DateUtils.convert(now) + " " + director.getNickname() + "鍥為��瀹℃壒"); + } else { + dto.setMsg(dto.getMsg() + PZH + DateUtils.convert(now) + " " + director.getNickname() + "鍥為��瀹℃壒"); + } + sign = false; + } + if (sign) { + dto.setMsg(dto.getMsg() + PZH + DateUtils.convert(now) + " " + director.getNickname() + "鍥為��瀹℃壒"); + } + + planDtoList.add(dto); + } + weekly.setStatus(0); + weekly.setSettle(1); + weekly.setSettleMsg(JSON.toJSONString(planDtoList)); + weekly.setUpdateBy(getUserId()); + weekly.setUpdateTime(now); + weeklyService.updateById(weekly); + if (!weekly.getSettle().equals(weekly.getSettleSize())) { + User phoneUser = userService.selectById(nextUserId); + if (!smsCodeService.sendSmsCodeText(phoneUser.getMobile(), PhoneCodeTypeParam.ALIYUN_M1ABAC630E, getUserId())) { + return R.ok("瀹℃牳鎴愬姛浣嗙煭淇″彂閫佸け璐�!"); + } + } + return R.ok("鍥為��鎴愬姛"); + } + + @RequestMapping(value = "/weekly/from/add/phone/auth") + @ManagerAuth(memo = "鍛ㄨ鍒�/鏃ヨ鍒�/鏃ュ疄闄�") + @Transactional + public R formAddModifyPhone(@RequestBody WeeklyDomainParam param){ + try{ + if (Cools.isEmpty(param)){ + throw new CoolException("鍙傛暟涓虹┖锛歐eeklyDomainParam"); + } else if (Cools.isEmpty(param.getWeeklyDailyRealityList()) || param.getWeeklyDailyRealityList().size()==0){ + throw new CoolException("鍙傛暟涓虹┖锛歐eeklyDailyRealityList"); + } else if (Cools.isEmpty(param.getWeeklyId())){ + throw new CoolException("鍙傛暟涓虹┖锛歐eeklyId"); +// } else if (Cools.isEmpty(param.getType())){ +// throw new CoolException("鍙傛暟涓虹┖锛歍ype"); +// } else if (Cools.isEmpty(param.getWeeklyType())){ +// throw new CoolException("鍙傛暟涓虹┖锛歐eekly"); + } + Date now = new Date(); + Weekly weekly = weeklyService.selectById(param.getWeeklyId()); + weekly.setUpdateBy(getUserId()); + weekly.setUpdateTime(now); + + + List<Date> dateList = new ArrayList<>();//鑾峰彇鍛ㄤ竴涓庡懆鏃ユ棩鏈� + dateList = TimeCalculatorUtils.WeeklyMondayAndSundayNow(weekly.getStartTime()); + + List<Date> dates = TimeCalculatorUtils.WeeklyListDays(dateList);//鑾峰彇鍛ㄤ竴鍒板懆鏃ユ棩鏈� + + try{ + weeklyService.updateById(weekly); + } catch (Exception e) { + log.error("鏇存柊鍛ㄨ鍒掍富琛ㄥけ璐ワ紝寮傚父淇℃伅锛�"+e); + throw new CoolException("鏇存柊鍛ㄨ鍒掍富琛ㄥけ璐�"); + } + + List<CstmrUtilsParam> cstmrUtilsParamList = new ArrayList<>(); + for (WeeklyDailyReality weeklyDailyReality: param.getWeeklyDailyRealityList()){ + Cstmr cstmr = null; + if (!Cools.isEmpty(weeklyDailyReality.getCstmrName())){ + cstmr = cstmrService.selectByName(getHostId(), weeklyDailyReality.getCstmrName()); + if(Cools.isEmpty(cstmr)){ + throw new CoolException("鏈煡璇㈠埌鐢叉柟鍗曚綅锛�"); + }else { + weeklyDailyReality.setCstmrId(cstmr.getId()); + } + } + weeklyDailyReality.setHostId(getHostId()); + weeklyDailyReality.setDeptId(getDeptId()); // 鎵�灞為儴闂� + weeklyDailyReality.setUserId(getUserId()); // 鎵�灞炰汉鍛� + + weeklyDailyReality.setDirector(getUserId()); // 鎵�灞炰汉鍛� + + weeklyDailyReality.setCreateBy(getUserId()); + weeklyDailyReality.setCreateTime(now); + weeklyDailyReality.setUpdateBy(getUserId()); + weeklyDailyReality.setUpdateTime(now); + + weeklyDailyReality.setStatus(weekly.getStatus()); + + weeklyDailyReality.setDailyTime(dates.get(weeklyDailyReality.getWeeklyDay()-1)); + weeklyDailyReality.setWeeklyId(weekly.getId()); + + try{ + weeklyDailyRealityService.insert(weeklyDailyReality); + } catch (Exception e){ + log.error("鏂板鏃ヨ鍒掑け璐�"+e); + throw new CoolException("鏂板鏃ヨ鍒掑け璐�"); + } + + } + + } catch (Exception e){ + log.error("鏇存柊鍛ㄨ鍒掑紓甯革紝寮傚父淇℃伅锛�"+e); + throw new CoolException("鏇存柊鍛ㄨ鍒掑け璐�==>"+e); + } + + return R.ok("鏇存柊鎴愬姛"); + } } -- Gitblit v1.9.1