|  |  |  | 
|---|
|  |  |  | 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; | 
|---|
|  |  |  | 
|---|
|  |  |  | import com.core.common.Cools; | 
|---|
|  |  |  | 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.PriOnline; | 
|---|
|  |  |  | import com.zy.crm.manager.entity.PriSales; | 
|---|
|  |  |  | import com.zy.crm.manager.service.ItemService; | 
|---|
|  |  |  | import com.zy.crm.manager.service.PriOnlineService; | 
|---|
|  |  |  | import com.zy.crm.manager.service.PriSalesService; | 
|---|
|  |  |  | 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; | 
|---|
|  |  |  | 
|---|
|  |  |  | private PriSalesService priSalesService; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private PriOnlineService priOnlineService; | 
|---|
|  |  |  | private PriOnline2Service priOnline2Service; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private ItemService itemService; | 
|---|
|  |  |  | private PlanService planService; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private PriQuoteBudgetService priQuoteBudgetService; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Autowired | 
|---|
|  |  |  | private UserService userService; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @RequestMapping(value = "/priSales/{id}/auth") | 
|---|
|  |  |  | @ManagerAuth | 
|---|
|  |  |  | public R get(@PathVariable("id") String id) { | 
|---|
|  |  |  | return R.ok(priSalesService.selectById(String.valueOf(id))); | 
|---|
|  |  |  | PriSales priSales = priSalesService.selectById(String.valueOf(id)); | 
|---|
|  |  |  | assert priSales != null; | 
|---|
|  |  |  | JSONObject resultObj = JSON.parseObject(JSON.toJSONString(priSales)); | 
|---|
|  |  |  | // 步骤条相关 | 
|---|
|  |  |  | resultObj.put("step", priSales.getSettle() == 4 ? 0 : priSales.getSettle() + 1); | 
|---|
|  |  |  | return R.ok().add(resultObj); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @RequestMapping(value = "/priSales/list/auth") | 
|---|
|  |  |  | 
|---|
|  |  |  | @RequestParam(required = false)String condition, | 
|---|
|  |  |  | @RequestParam Map<String, Object> param){ | 
|---|
|  |  |  | EntityWrapper<PriSales> 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,update_user_id as updateUserId,update_time as updateTime,in_order_num as inOrderNum,member_id as memberId"); | 
|---|
|  |  |  | wrapper.in("member_id", getUserRoleBelongsToUserId("allopen")); | 
|---|
|  |  |  | wrapper.setSqlSelect("id,title,create_time as createTime,settle,filepath,item_id as itemId,order_num as orderNum,template_name as templateName,user_id as userId,update_user_id as updateUserId,update_time as updateTime,in_order_num as inOrderNum,member_id as memberId"); | 
|---|
|  |  |  | //        wrapper.in("member_id", getUserRoleBelongsToUserId("allopen")); | 
|---|
|  |  |  | excludeTrash(param); | 
|---|
|  |  |  | convert(param, wrapper); | 
|---|
|  |  |  | allLike(PriSales.class, param.keySet(), wrapper, condition); | 
|---|
|  |  |  | wrapper.or().eq("member_id",getUserId()); | 
|---|
|  |  |  | if (!Cools.isEmpty(orderByField)){wrapper.orderBy(humpToLine(orderByField), "asc".equals(orderByType));} | 
|---|
|  |  |  | return R.ok(priSalesService.selectPage(new Page<>(curr, limit), wrapper)); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private <T> void convert(Map<String, Object> map, EntityWrapper<T> wrapper){ | 
|---|
|  |  |  | 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()){ | 
|---|
|  |  |  | 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()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (signHostId){ | 
|---|
|  |  |  | wrapper.or().eq("host_id",1); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @RequestMapping(value = "/priSales/add/auth") | 
|---|
|  |  |  | @ManagerAuth | 
|---|
|  |  |  | @ManagerAuth(memo = "添加产品费用明细") | 
|---|
|  |  |  | public R add(@RequestBody Map<String,Object> map) { | 
|---|
|  |  |  | PriOnline priOnline = priOnlineService.selectById(Long.parseLong(map.get("priOnlineId").toString())); | 
|---|
|  |  |  | PriOnline2 priOnline2 = priOnline2Service.selectById(Long.parseLong(map.get("priOnlineId").toString())); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | PriSales priSales = new PriSales(); | 
|---|
|  |  |  | priSales.setCreateTime(new Date()); | 
|---|
|  |  |  | priSales.setTitle(map.get("title").toString()); | 
|---|
|  |  |  | priSales.setTemplateName(priOnline.getTemplateName()); | 
|---|
|  |  |  | priSales.setTemplateName(priOnline2.getTemplateName()); | 
|---|
|  |  |  | priSales.setSheetData(map.get("sheetData").toString()); | 
|---|
|  |  |  | priSales.setItemId(priOnline.getItemId()); | 
|---|
|  |  |  | priSales.setOrderNum(priOnline.getOrderNum()); | 
|---|
|  |  |  | priSales.setPriOnline2Id(Long.parseLong(map.get("priOnlineId").toString())); | 
|---|
|  |  |  | priSales.setItemId(priOnline2.getItemId()); | 
|---|
|  |  |  | priSales.setOrderNum(priOnline2.getOrderNum()); | 
|---|
|  |  |  | SimpleDateFormat format = new SimpleDateFormat("yyyyMMddHHmmss"); | 
|---|
|  |  |  | priSales.setInOrderNum(format.format(new Date())); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | priSales.setUpdateUserId(getUserId()); | 
|---|
|  |  |  | //更新时间 | 
|---|
|  |  |  | priSales.setUpdateTime(new Date()); | 
|---|
|  |  |  | priSales.setDeptId(getDeptId()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //业务员 | 
|---|
|  |  |  | Item item = itemService.selectById(priSales.getItemId()); | 
|---|
|  |  |  | priSales.setMemberId(item.getMember()); | 
|---|
|  |  |  | Plan plan = planService.selectById(priSales.getItemId()); | 
|---|
|  |  |  | priSales.setMemberId(plan.getUserId()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | priSales.setSettle(0); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | User manager = userService.getDeptManager(getHostId(), getUser().getDeptId());        // 获取部门领导 | 
|---|
|  |  |  | List<String> initNames = new ArrayList<>(); | 
|---|
|  |  |  | initNames.add("创建产品费用明细模板"); | 
|---|
|  |  |  | initNames.add("提交产品费用明细"); | 
|---|
|  |  |  | initNames.add("部门经理审核"); | 
|---|
|  |  |  | initNames.add("业务员确认"); | 
|---|
|  |  |  | priSales.setSettleMsg(JSON.toJSONString(SettleDto.initSalesPricing(manager,getUser(),getUser(),initNames,3))); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //设置项目流程 | 
|---|
|  |  |  | item.setStep(3); | 
|---|
|  |  |  | itemService.updateById(item); | 
|---|
|  |  |  | plan.setStep(3); | 
|---|
|  |  |  | planService.updateById(plan); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | priSalesService.insert(priSales); | 
|---|
|  |  |  | return R.ok(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @RequestMapping(value = "/priSales/addOther/auth") | 
|---|
|  |  |  | @ManagerAuth | 
|---|
|  |  |  | @ManagerAuth(memo = "另存产品费用明细") | 
|---|
|  |  |  | public R addOther(@RequestBody Map<String,Object> map) { | 
|---|
|  |  |  | PriSales online = priSalesService.selectById(Long.parseLong(map.get("id").toString())); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | priSales.setUpdateTime(new Date()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //业务员 | 
|---|
|  |  |  | Item item = itemService.selectById(priSales.getItemId()); | 
|---|
|  |  |  | priSales.setMemberId(item.getMember()); | 
|---|
|  |  |  | Plan plan = planService.selectById(priSales.getItemId()); | 
|---|
|  |  |  | priSales.setMemberId(plan.getUserId()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | priSalesService.insert(priSales); | 
|---|
|  |  |  | return R.ok(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @RequestMapping(value = "/priSales/update/auth") | 
|---|
|  |  |  | @ManagerAuth | 
|---|
|  |  |  | @ManagerAuth(memo = "更新产品费用明细") | 
|---|
|  |  |  | public R update(@RequestBody Map<String,Object> map){ | 
|---|
|  |  |  | PriSales priSales = priSalesService.selectById(Long.parseLong(map.get("id").toString())); | 
|---|
|  |  |  | priSales.setTitle(map.get("title").toString()); | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @RequestMapping(value = "/priSales/updateForm/auth") | 
|---|
|  |  |  | @ManagerAuth | 
|---|
|  |  |  | @ManagerAuth(memo = "更新产品费用明细模板名和标题") | 
|---|
|  |  |  | public R updateForm(Long id,String templateName,String title){ | 
|---|
|  |  |  | PriSales priSales = priSalesService.selectById(id); | 
|---|
|  |  |  | priSales.setTemplateName(templateName); | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @RequestMapping(value = "/priSales/delete/auth") | 
|---|
|  |  |  | @ManagerAuth | 
|---|
|  |  |  | @ManagerAuth(memo = "删除产品费用明细") | 
|---|
|  |  |  | public R delete(Long[] ids){ | 
|---|
|  |  |  | if (Cools.isEmpty(ids)){ | 
|---|
|  |  |  | return R.error(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | for (Long id : ids){ | 
|---|
|  |  |  | int  priQuoteBudget= priQuoteBudgetService.selectCount(new EntityWrapper<PriQuoteBudget>().eq("pri_sales_id", id)); | 
|---|
|  |  |  | if (priQuoteBudget!=0){ | 
|---|
|  |  |  | return R.error("存在关联的报价预算单,禁止删除!!!"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | priSalesService.deleteBatchIds(Arrays.asList(ids)); | 
|---|
|  |  |  | return R.ok(); | 
|---|
|  |  |  | 
|---|
|  |  |  | public R query(String condition) { | 
|---|
|  |  |  | EntityWrapper<PriSales> wrapper = new EntityWrapper<>(); | 
|---|
|  |  |  | wrapper.like("id", condition); | 
|---|
|  |  |  | wrapper.in("member_id", getUserRoleBelongsToUserId("allopen")); | 
|---|
|  |  |  | wrapper.in("user_id", getUserRoleBelongsToUserId("allopen")); | 
|---|
|  |  |  | Page<PriSales> page = priSalesService.selectPage(new Page<>(0, 10), wrapper); | 
|---|
|  |  |  | List<Map<String, Object>> result = new ArrayList<>(); | 
|---|
|  |  |  | for (PriSales priSales : page.getRecords()){ | 
|---|
|  |  |  | Map<String, Object> map = new HashMap<>(); | 
|---|
|  |  |  | map.put("id", priSales.getId()); | 
|---|
|  |  |  | map.put("value", priSales.getInOrderNum() + "/" + priSales.getItemId$() + "/" + priSales.getMemberId$()); | 
|---|
|  |  |  | map.put("value", priSales.getInOrderNum() + "/" + priSales.getPlanId$() + "/" + priSales.getMemberId$()+"/" + priSales.getTemplateName()); | 
|---|
|  |  |  | result.add(map); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return R.ok(result); | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @PostMapping(value = "/priSales/approval/auth") | 
|---|
|  |  |  | @ManagerAuth | 
|---|
|  |  |  | public R approvalBusinessTrip(@RequestParam Long priSalesId, | 
|---|
|  |  |  | @RequestParam(required = false) Long plannerId){ | 
|---|
|  |  |  | PriSales priSales = priSalesService.selectById(priSalesId); | 
|---|
|  |  |  | assert priSales != null; | 
|---|
|  |  |  | Date now = new Date(); | 
|---|
|  |  |  | switch (priSales.getSettle()) { | 
|---|
|  |  |  | case 0: | 
|---|
|  |  |  | User user2 = userService.selectById(priSales.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(priSales.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; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | priSales.setSettleMsg(JSON.toJSONString(list1)); | 
|---|
|  |  |  | // 修改规划单状态 | 
|---|
|  |  |  | priSales.setSettle(1); | 
|---|
|  |  |  | priSales.setUpdateUserId(getUserId()); | 
|---|
|  |  |  | priSales.setUpdateTime(now); | 
|---|
|  |  |  | priSales.setMemberId(manager1.getId()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (!priSalesService.updateById(priSales)) { | 
|---|
|  |  |  | throw new CoolException("提交失败,请联系管理员"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | case 1: | 
|---|
|  |  |  | // 本部门经理审核 | 
|---|
|  |  |  | User user = userService.selectById(priSales.getUserId()); | 
|---|
|  |  |  | User manager = userService.getDeptManager(getHostId(), user.getDeptId()); | 
|---|
|  |  |  | if (manager.getId().equals(getUserId())) { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 修改 settle 步骤数据 | 
|---|
|  |  |  | List<SettleDto> list = JSON.parseArray(priSales.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(now)); | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | default: | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | priSales.setSettleMsg(JSON.toJSONString(list)); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 修改规划单状态 | 
|---|
|  |  |  | priSales.setSettle(2);  // 申请通过 | 
|---|
|  |  |  | priSales.setUpdateTime(now); | 
|---|
|  |  |  | if (!priSalesService.updateById(priSales)) { | 
|---|
|  |  |  | throw new CoolException("审核失败,请联系管理员"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | return R.error("抱歉,您没有审核的权限!!!"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | case 2: | 
|---|
|  |  |  | // 业务员 | 
|---|
|  |  |  | User salesman0 = userService.selectById(priSales.getUserId()); | 
|---|
|  |  |  | if (!getUserId().equals(salesman0.getId())) { | 
|---|
|  |  |  | return R.error("抱歉,您无需确认!!!"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | // 修改 settle 步骤数据 | 
|---|
|  |  |  | List<SettleDto> list2 = JSON.parseArray(priSales.getSettleMsg(), SettleDto.class); | 
|---|
|  |  |  | for (SettleDto dto : list2) { | 
|---|
|  |  |  | switch (dto.getStep()) { | 
|---|
|  |  |  | case 2: | 
|---|
|  |  |  | dto.setCurr(Boolean.TRUE); | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | case 3: | 
|---|
|  |  |  | dto.setCurr(Boolean.TRUE); | 
|---|
|  |  |  | dto.setMsg("业务员" + salesman0.getNickname() + "以确认"); | 
|---|
|  |  |  | dto.setTime(DateUtils.convert(new Date())); | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | default: | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | priSales.setSettleMsg(JSON.toJSONString(list2)); | 
|---|
|  |  |  | // 修改规划单状态 | 
|---|
|  |  |  | priSales.setSettle(3);  // 审批通过 | 
|---|
|  |  |  | priSales.setUpdateTime(new Date()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (!priSalesService.updateById(priSales)) { | 
|---|
|  |  |  | throw new CoolException("确认失败,请联系管理员"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | break; | 
|---|
|  |  |  | default: | 
|---|
|  |  |  | return R.error(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return R.ok("审批成功"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|