From 419de9e1681475c89356439f30849951af8bb98a Mon Sep 17 00:00:00 2001 From: LSH Date: 星期一, 14 八月 2023 08:59:49 +0800 Subject: [PATCH] #报价单审核机制 --- src/main/java/com/zy/crm/manager/controller/PriQuoteController.java | 270 +++++++++++++++++++++++++++++++++++++++++++++++++++-- 1 files changed, 256 insertions(+), 14 deletions(-) diff --git a/src/main/java/com/zy/crm/manager/controller/PriQuoteController.java b/src/main/java/com/zy/crm/manager/controller/PriQuoteController.java index 1de6b71..002ed96 100644 --- a/src/main/java/com/zy/crm/manager/controller/PriQuoteController.java +++ b/src/main/java/com/zy/crm/manager/controller/PriQuoteController.java @@ -1,5 +1,6 @@ package com.zy.crm.manager.controller; +import com.alibaba.fastjson.JSON; import com.alibaba.fastjson.JSONArray; import com.alibaba.fastjson.JSONObject; import com.baomidou.mybatisplus.mapper.EntityWrapper; @@ -11,13 +12,13 @@ import com.core.common.DateUtils; import com.core.common.R; import com.core.domain.KeyValueVo; +import com.core.exception.CoolException; +import com.zy.crm.common.model.SettleDto; import com.zy.crm.common.web.BaseController; -import com.zy.crm.manager.entity.Item; -import com.zy.crm.manager.entity.PriQuote; -import com.zy.crm.manager.entity.PriQuoteBudget; -import com.zy.crm.manager.service.ItemService; -import com.zy.crm.manager.service.PriQuoteBudgetService; -import com.zy.crm.manager.service.PriQuoteService; +import com.zy.crm.manager.entity.*; +import com.zy.crm.manager.service.*; +import com.zy.crm.system.entity.User; +import com.zy.crm.system.service.UserService; import org.apache.poi.xssf.usermodel.XSSFSheet; import org.apache.poi.xssf.usermodel.XSSFWorkbook; import org.springframework.beans.factory.annotation.Autowired; @@ -37,15 +38,33 @@ private PriQuoteService priQuoteService; @Autowired - private ItemService itemService; + private PlanService planService; + + @Autowired + private UserService userService; @Autowired private PriQuoteBudgetService priQuoteBudgetService; + @Autowired + private PlanTypeService planTypeService; + @RequestMapping(value = "/priQuote/{id}/auth") @ManagerAuth public R get(@PathVariable("id") String id) { - return R.ok(priQuoteService.selectById(String.valueOf(id))); + PriQuote priQuote = priQuoteService.selectById(String.valueOf(id)); + assert priQuote != null; + JSONObject resultObj = JSON.parseObject(JSON.toJSONString(priQuote)); + if (!Cools.isEmpty(priQuote.getForm())) { + JSONObject formObj = JSON.parseObject(priQuote.getForm()); + formObj.forEach(resultObj::putIfAbsent); + } + + // 姝ラ鏉$浉鍏� + resultObj.put("step", priQuote.getSettle() == 5 ? 0 : priQuote.getSettle() + 1); + + return R.ok().add(resultObj); +// return R.ok(priQuoteService.selectById(String.valueOf(id))); } @RequestMapping(value = "/priQuote/list/auth") @@ -67,15 +86,33 @@ } private <T> void convert(Map<String, Object> map, EntityWrapper<T> wrapper){ + Long deptId = getDeptId(); + boolean signUserId = false; + boolean signDeptId = false; + for (Map.Entry<String, Object> entry : map.entrySet()){ + if (entry.getKey().equals("dept_id")){ + signDeptId = true; + } + } for (Map.Entry<String, Object> entry : map.entrySet()){ String val = String.valueOf(entry.getValue()); if (val.contains(RANGE_TIME_LINK)){ String[] dates = val.split(RANGE_TIME_LINK); wrapper.ge(entry.getKey(), DateUtils.convert(dates[0])); wrapper.le(entry.getKey(), DateUtils.convert(dates[1])); + } else if (entry.getKey().equals("dept_id")){ + if (!val.equals("19")){ + wrapper.eq(entry.getKey(), val); + } + } else if (entry.getKey().equals("user_id") && !signDeptId){ + signUserId = true; + wrapper.eq(entry.getKey(), val); } else { wrapper.like(entry.getKey(), val); } + } + if (!signUserId && !signDeptId){ + wrapper.eq("user_id", getUserId()); } } @@ -102,12 +139,18 @@ priQuote.setUpdateTime(new Date()); //涓氬姟鍛� - Item item = itemService.selectById(priQuote.getItemId()); - priQuote.setMemberId(item.getMember()); + Plan plan = planService.selectById(priQuote.getItemId()); + priQuote.setMemberId(plan.getUserId()); //璁剧疆椤圭洰娴佺▼ - item.setStep(5); - itemService.updateById(item); + plan.setStep(5); + + priQuote.setForm(JSON.toJSONString(map)); // 鑷畾涔夎〃鍗曞唴瀹� + priQuote.setSettle(1); // 1.寮�濮� + User manager = userService.getDeptManager(getHostId(), getUser().getDeptId()); // 鑾峰彇閮ㄩ棬棰嗗 + priQuote.setSettleMsg(JSON.toJSONString(SettleDto.initPriQuote(plan, manager))); + + planService.updateById(plan); priQuoteService.insert(priQuote); return R.ok(); @@ -137,8 +180,8 @@ priQuote.setUpdateTime(new Date()); //涓氬姟鍛� - Item item = itemService.selectById(priQuote.getItemId()); - priQuote.setMemberId(item.getMember()); + Plan plan = planService.selectById(priQuote.getItemId()); + priQuote.setMemberId(plan.getUserId()); priQuoteService.insert(priQuote); return R.ok(); @@ -374,4 +417,203 @@ } } + @PostMapping(value = "/priQuote/approval/auth") + @ManagerAuth + public R approvalPriQuote(@RequestParam Long planId, + @RequestParam(required = false) Long plannerId){return null;} +// PriQuote priQuote = priQuoteService.selectById(planId); +// assert priQuote != null; +// +// switch (priQuote.getSettle()) { +// case 1: +// // 鏈儴闂ㄧ粡鐞嗗鏍� +// User user = userService.selectById(priQuote.getUserId()); +// User manager = userService.getDeptManager(getHostId(), user.getDeptId()); +// if (manager.getId().equals(getUserId())) { +// +// +// // 鏌ユ壘鎬昏鍔� +// PlanType planType = planTypeService.selectById(priQuote.getPlanType()); +// User planLeader = planTypeService.findPlanLeader(planType); +// if (Cools.isEmpty(planLeader)) { +// throw new CoolException("鏈煡鎵惧埌鎬昏鍔烇紝璇疯仈绯荤鐞嗗憳"); +// } +// +// // 淇敼 settle 姝ラ鏁版嵁 +// List<SettleDto> list = JSON.parseArray(priQuote.getSettleMsg(), SettleDto.class); +// for (SettleDto dto : list) { +// switch (dto.getStep()) { +// case 1: +// dto.setCurr(Boolean.FALSE); +// break; +// case 2: +// dto.setCurr(Boolean.TRUE); +// dto.setMsg("閮ㄩ棬缁忕悊" + manager.getNickname() + "瀹℃壒閫氳繃"); +// dto.setTime(DateUtils.convert(new Date())); +// break; +// case 3: +// dto.setUserId(planLeader.getId()); +// dto.setUsername(planLeader.getNickname()); +// break; +// default: +// break; +// } +// } +// priQuote.setSettleMsg(JSON.toJSONString(list)); +// +// // 淇敼瑙勫垝鍗曠姸鎬� +// priQuote.setSettle(2); // 瑙勫垝缁勯暱寰呭 +// priQuote.setUpdateUserId(getUserId()); +// priQuote.setUpdateTime(new Date()); +// +// if (!priQuoteService.updateById(priQuote)) { +// throw new CoolException("瀹℃牳澶辫触锛岃鑱旂郴绠$悊鍛�"); +// } +// +// // 娣诲姞瑙勫垝缁勯暱璺熻繘浜� +// PlanFoll planFoll = new PlanFoll(); +// planFoll.setPlanId(priQuote.getId()); +// planFoll.setUserId(planLeader.getId()); +// if (!planFollService.insert(planFoll)) { +// throw new CoolException("瀹℃牳澶辫触锛岃鑱旂郴绠$悊鍛�"); +// } +// +// } else { +// return R.error("鎶辨瓑锛屾偍娌℃湁瀹℃牳鐨勬潈闄�"); +// } +// break; +// case 2: +// // 鏌ユ壘瑙勫垝缁勯暱 +// PlanType planType = planTypeService.selectById(priQuote.getPlanType()); +// User planLeader = planTypeService.findPlanLeader(planType); +// if (Cools.isEmpty(planLeader)) { +// throw new CoolException("鏈煡鎵惧埌瑙勫垝缁勯暱锛岃鑱旂郴绠$悊鍛�"); +// } +// if (Cools.isEmpty(planLeader)) { +// throw new CoolException("鏈煡鎵惧埌瑙勫垝缁勯暱锛岃鑱旂郴绠$悊鍛�"); +// } +// if (!getUserId().equals(planLeader.getId())) { +// return R.error("鎶辨瓑锛屾偍娌℃湁瀹℃牳鐨勬潈闄�"); +// } +// if (Cools.isEmpty(plannerId)) { +// return R.error("鎸囧畾瑙勫垝鍛樹笉鑳戒负绌�"); +// } +// User planner = userService.selectById(plannerId); +// // 淇敼 settle 姝ラ鏁版嵁 +// List<SettleDto> list = JSON.parseArray(priQuote.getSettleMsg(), SettleDto.class); +// for (SettleDto dto : list) { +// switch (dto.getStep()) { +// case 2: +// dto.setCurr(Boolean.FALSE); +// break; +// case 3: +// dto.setCurr(Boolean.TRUE); +// dto.setMsg("鍞墠缁勯暱" + planLeader.getNickname() + "瀹℃壒閫氳繃"); +// dto.setTime(DateUtils.convert(new Date())); +// break; +// case 4: +// dto.setUserId(planner.getId()); +// dto.setUsername(planner.getNickname()); +// break; +// default: +// break; +// } +// } +// priQuote.setSettleMsg(JSON.toJSONString(list)); +// // 淇敼瑙勫垝鍗曠姸鎬� +// priQuote.setSettle(3); // 瑙勫垝鍛樺緟瀹� +// priQuote.setPlanner(planner.getId()); +// priQuote.setUpdateUserId(getUserId()); +// priQuote.setUpdateTime(new Date()); +// +// if (!priQuoteService.updateById(priQuote)) { +// throw new CoolException("瀹℃牳澶辫触锛岃鑱旂郴绠$悊鍛�"); +// } +// +// // 娣诲姞瑙勫垝鍛樿窡杩涗汉 +// PlanFoll planFoll = new PlanFoll(); +// planFoll.setPlanId(priQuote.getId()); +// planFoll.setUserId(planner.getId()); +// if (!planFollService.insert(planFoll)) { +// throw new CoolException("瀹℃牳澶辫触锛岃鑱旂郴绠$悊鍛�"); +// } +// break; +// case 3: +// User plannerUser = userService.selectById(priQuote.getPlanner()); +// if (Cools.isEmpty(plannerUser)) { +// return R.error("鏈壘鍒拌鍒掑憳"); +// } +// if (!getUserId().equals(plannerUser.getId())) { +// return R.error("鎶辨瓑锛屾偍娌℃湁瀹℃牳鐨勬潈闄�"); +// } +// // 涓氬姟鍛� +// User salesman = userService.selectById(priQuote.getUserId()); +// // 淇敼 settle 姝ラ鏁版嵁 +// List<SettleDto> list0 = JSON.parseArray(priQuote.getSettleMsg(), SettleDto.class); +// for (SettleDto dto : list0) { +// switch (dto.getStep()) { +// case 3: +// dto.setCurr(Boolean.FALSE); +// break; +// case 4: +// dto.setCurr(Boolean.TRUE); +// dto.setMsg("瑙勫垝鍛�" + plannerUser.getNickname() + "瀹℃壒閫氳繃"); +// dto.setTime(DateUtils.convert(new Date())); +// break; +// case 5: +// dto.setUserId(salesman.getId()); +// dto.setUsername(salesman.getNickname()); +// break; +// default: +// break; +// } +// } +// priQuote.setSettleMsg(JSON.toJSONString(list0)); +// // 淇敼瑙勫垝鍗曠姸鎬� +// priQuote.setSettle(4); // 瀹℃壒閫氳繃 +// priQuote.setUpdateUserId(getUserId()); +// priQuote.setUpdateTime(new Date()); +// +// if (!planService.updateById(priQuote)) { +// throw new CoolException("瀹℃牳澶辫触锛岃鑱旂郴绠$悊鍛�"); +// } +// break; +// case 4: +// // 涓氬姟鍛� +// User salesman0 = userService.selectById(priQuote.getUserId()); +// if (!getUserId().equals(salesman0.getId())) { +// return R.error("鎶辨瓑锛屾偍娌℃湁瀹℃牳鐨勬潈闄�"); +// } +// // 淇敼 settle 姝ラ鏁版嵁 +// List<SettleDto> list1 = JSON.parseArray(priQuote.getSettleMsg(), SettleDto.class); +// for (SettleDto dto : list1) { +// switch (dto.getStep()) { +// case 4: +// dto.setCurr(Boolean.TRUE); +// break; +// case 5: +// dto.setCurr(Boolean.TRUE); +// dto.setMsg("涓氬姟鍛�" + salesman0.getNickname() + "瀹℃壒閫氳繃"); +// dto.setTime(DateUtils.convert(new Date())); +// break; +// default: +// break; +// } +// } +// priQuote.setSettleMsg(JSON.toJSONString(list1)); +// // 淇敼瑙勫垝鍗曠姸鎬� +// priQuote.setSettle(5); // 瀹℃壒閫氳繃 +// priQuote.setUpdateUserId(getUserId()); +// priQuote.setUpdateTime(new Date()); +// +// if (!planService.updateById(priQuote)) { +// throw new CoolException("瀹℃牳澶辫触锛岃鑱旂郴绠$悊鍛�"); +// } +// break; +// default: +// return R.error(); +// } +// return R.ok("瀹℃壒鎴愬姛"); +// } + } -- Gitblit v1.9.1