From baa98c7a04e13ac1630696b532add9c3e7f0d907 Mon Sep 17 00:00:00 2001
From: Junjie <fallin.jie@qq.com>
Date: 星期五, 10 十一月 2023 15:30:56 +0800
Subject: [PATCH] #
---
src/main/java/com/zy/crm/manager/controller/ContractController.java | 259 +++++++++++++++++++++++++++++++++++++++++++++++----
1 files changed, 237 insertions(+), 22 deletions(-)
diff --git a/src/main/java/com/zy/crm/manager/controller/ContractController.java b/src/main/java/com/zy/crm/manager/controller/ContractController.java
index 94b934b..573a275 100644
--- a/src/main/java/com/zy/crm/manager/controller/ContractController.java
+++ b/src/main/java/com/zy/crm/manager/controller/ContractController.java
@@ -1,15 +1,15 @@
package com.zy.crm.manager.controller;
-import com.alibaba.fastjson.JSONArray;
+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.common.model.SettleDto;
import com.zy.crm.common.service.OssService;
-import com.zy.crm.manager.entity.Contract;
-import com.zy.crm.manager.entity.ContractSales;
-import com.zy.crm.manager.entity.PriOnline;
+import com.zy.crm.manager.entity.*;
import com.zy.crm.manager.service.ContractSalesService;
import com.zy.crm.manager.service.ContractService;
import com.core.annotations.ManagerAuth;
@@ -18,20 +18,19 @@
import com.core.common.R;
import com.core.domain.KeyValueVo;
import com.zy.crm.common.web.BaseController;
+import com.zy.crm.manager.service.ProcessPermissionsService;
import com.zy.crm.manager.utils.ChineseNumberUtils;
import com.zy.crm.manager.utils.WordUtils;
+import com.zy.crm.system.entity.User;
+import com.zy.crm.system.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.core.io.InputStreamResource;
-import org.springframework.http.HttpHeaders;
-import org.springframework.http.MediaType;
import org.springframework.http.ResponseEntity;
import org.springframework.util.ClassUtils;
import org.springframework.web.bind.annotation.*;
import org.springframework.web.multipart.MultipartFile;
-import java.io.ByteArrayInputStream;
-import java.io.File;
-import java.io.IOException;
+import java.io.*;
import java.text.SimpleDateFormat;
import java.util.*;
@@ -44,11 +43,20 @@
private ContractSalesService contractSalesService;
@Autowired
private OssService ossService;
+ @Autowired
+ private UserService userService;
+ @Autowired
+ private ProcessPermissionsService processPermissionsService;
- @RequestMapping(value = "/contract/{id}/auth")
+ @RequestMapping(value = "/contract/{id}/auth2")
@ManagerAuth
public R get(@PathVariable("id") String id) {
- return R.ok(contractService.selectById(String.valueOf(id)));
+ Contract contract = contractService.selectById(String.valueOf(id));
+ assert contract != null;
+ JSONObject resultObj = JSON.parseObject(JSON.toJSONString(contract));
+ // 姝ラ鏉$浉鍏�
+ resultObj.put("step", contract.getSettle() == 5 ? 0 : contract.getSettle() + 1);
+ return R.ok().add(resultObj);
}
@RequestMapping(value = "/contract/list/auth")
@@ -68,25 +76,78 @@
}
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){
+ if (getRole().getId()==1){
+ wrapper.or().eq("host_id",1);
+ }else if (getRole().getId()==2){
+ wrapper.eq("dept_id",getDeptId());
+ }else {
+ wrapper.eq("user_id", getUserId());
+ }
+ }
+ if (signHostId){
+ wrapper.or().eq("host_id",1);
}
}
@RequestMapping(value = "/contract/add/auth")
@ManagerAuth(memo = "娣诲姞鍚堝悓")
public R add(Contract contract) {
+ Date now = new Date();
contract.setUserId(getUserId());
//鍒涘缓浜哄憳閮ㄩ棬
contract.setDeptId(getDeptId());
- contract.setCreateTime(new Date());
+ contract.setCreateTime(now);
+
+ contract.setSettle(1);
+
+ User manager = new User();
+ try{
+ manager = userService.getDeptManager(getHostId(), getUser().getDeptId()); // 鑾峰彇閮ㄩ棬棰嗗
+ }catch (Exception e){
+ manager = getUser();
+ }
+ contract.setDirector(manager.getId());
+ List<String> initNames = new ArrayList<>();
+ initNames.add("鍒涘缓鍚堝悓妯℃澘");
+ initNames.add("鎻愪氦鍚堝悓");
+ initNames.add("閮ㄩ棬缁忕悊瀹℃牳");
+ ProcessPermissions processPermissions = processPermissionsService.selectOne(new EntityWrapper<ProcessPermissions>().eq("process_memo", 7).eq("process", "3-1" ));//7锛氬悎鍚岀鐞�
+ User president = userService.selectById(processPermissions.getUserId());
+ initNames.add("鎬荤粡鍔�"+president.getNickname()+"瀹℃牳");
+ initNames.add("涓氬姟鍛樼‘璁�");
+ contract.setSettleMsg(JSON.toJSONString(SettleDto.initContract(manager,getUser(),president,initNames,4)));
+
+ contract.setUpdateTime(now);
+ contract.setUpdateBy(getUserId());
contractService.insert(contract);
return R.ok();
}
@@ -185,7 +246,11 @@
/////////////////////////鐢熸垚Tab琛ㄦ牸鏁版嵁/////////////////////////
String fileName = this.getClass().getClassLoader().getResource("contractTemplate/" + contractTemplate + ".docx").getPath();//鑾峰彇鏂囦欢璺緞
- return WordUtils.generate(fileName, map, tabParam);
+
+// String outPdfPath = fileName.split("\\.")[0]+".pdf";
+ ResponseEntity<InputStreamResource> generate = WordUtils.generate(fileName, map, tabParam);
+// WordUtils.documents4jWordToPdf(fileName,outPdfPath);
+ return generate;
} catch (Exception e) {
return null;
}
@@ -206,7 +271,7 @@
//鏂囦欢鍚庣紑鍚�
String suffix = file.getOriginalFilename().substring(file.getOriginalFilename().lastIndexOf("."));
//涓婁紶鏂囦欢鍚�
- String filename = format.format(new Date()) + suffix;
+ String filename = format.format(new Date()) + "_" + file.getOriginalFilename();
//鏈�缁堟枃浠惰矾寰�
String filepath = path + "/" + filename;
//OSS鏂囦欢瀛樺偍璺緞
@@ -234,20 +299,17 @@
@RequestMapping(value = "/contract/download/auth")
@ManagerAuth(memo = "涓嬭浇鍚堝悓")
- public ResponseEntity<InputStreamResource> download(@RequestParam("id") Integer id) {
+ public R download(@RequestParam("id") Integer id) {
Contract contract = contractService.selectById(id);
if (contract == null) {
- return null;
+ return R.error();
}
if (Cools.isEmpty(contract.getFilepath())) {
- return null;
+ return R.error();
}
- try {
- return ossService.downloadFile(contract.getFilepath());//浠嶰SS涓笅杞芥枃浠�
- } catch (Exception e) {
- return null;
- }
+ String download = ossService.download(contract.getFilepath());//鑾峰彇OSS涓存椂涓嬭浇URL
+ return R.ok().add(download);
}
@RequestMapping(value = "/contract/export/auth")
@@ -296,4 +358,157 @@
return R.ok().add(vos);
}
+ @PostMapping(value = "/contract/approval/auth")
+ @ManagerAuth
+ public R approvalBusinessTrip(@RequestParam Long contractId,
+ @RequestParam(required = false) Long plannerId){
+ Contract contract = contractService.selectById(contractId);
+ assert contract != null;
+ Date now = new Date();
+ switch (contract.getSettle()) {
+ case 0:
+ if (Cools.isEmpty(getUser())) {
+ return R.error("鎶辨瓑锛屾偍娌℃湁鎻愪氦鐨勬潈闄�");
+ }
+ if (!getUserId().equals(getUser().getId())) {
+ return R.error("鎶辨瓑锛屾偍娌℃湁鎻愪氦鐨勬潈闄�");
+ }
+ // 淇敼 settle 姝ラ鏁版嵁
+ List<SettleDto> list1 = JSON.parseArray(contract.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;
+ case 2:
+ contract.setDirector(dto.getUserId());
+ break;
+ default:
+ break;
+ }
+ }
+ contract.setSettleMsg(JSON.toJSONString(list1));
+ // 淇敼瑙勫垝鍗曠姸鎬�
+ contract.setSettle(1);
+ contract.setUpdateTime(now);
+
+ if (!contractService.updateById(contract)) {
+ throw new CoolException("鎻愪氦澶辫触锛岃鑱旂郴绠$悊鍛�");
+ }
+ break;
+ case 1:
+ // 鏈儴闂ㄧ粡鐞嗗鏍�
+ User manager = userService.selectById(contract.getDirector());
+
+ if (manager.getId().equals(getUserId())) {
+
+ // 淇敼 settle 姝ラ鏁版嵁
+ List<SettleDto> list = JSON.parseArray(contract.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;
+ case 3:
+ contract.setDirector(dto.getUserId());
+ break;
+ default:
+ break;
+ }
+ }
+ contract.setSettleMsg(JSON.toJSONString(list));
+
+ // 淇敼瑙勫垝鍗曠姸鎬�
+ contract.setSettle(2); // 鐢宠閫氳繃
+ contract.setUpdateTime(now);
+ if (!contractService.updateById(contract)) {
+ throw new CoolException("瀹℃牳澶辫触锛岃鑱旂郴绠$悊鍛�");
+ }
+ } else {
+ return R.error("鎶辨瓑锛屾偍娌℃湁瀹℃牳鐨勬潈闄愶紒锛侊紒");
+ }
+ break;
+ case 2:
+ User planLeader = userService.selectById(contract.getDirector());
+
+ if (planLeader.getId().equals(getUserId())) {
+
+ // 淇敼 settle 姝ラ鏁版嵁
+ List<SettleDto> list = JSON.parseArray(contract.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(now));
+ break;
+ case 4:
+ contract.setDirector(dto.getUserId());
+ break;
+ default:
+ break;
+ }
+ }
+ contract.setSettleMsg(JSON.toJSONString(list));
+
+ // 淇敼瑙勫垝鍗曠姸鎬�
+ contract.setSettle(3); // 鐢宠閫氳繃
+ contract.setUpdateTime(now);
+ if (!contractService.updateById(contract)) {
+ throw new CoolException("瀹℃牳澶辫触锛岃鑱旂郴绠$悊鍛�");
+ }
+ } else {
+ return R.error("鎶辨瓑锛屾偍娌℃湁瀹℃牳鐨勬潈闄愶紒锛侊紒");
+ }
+ break;
+ case 3:
+ // 涓氬姟鍛�
+ User salesman0 = userService.selectById(contract.getUserId());
+ if (!getUserId().equals(salesman0.getId())) {
+ return R.error("鎶辨瓑锛屾偍鏃犻渶纭锛侊紒锛�");
+ }
+ // 淇敼 settle 姝ラ鏁版嵁
+ List<SettleDto> list2 = JSON.parseArray(contract.getSettleMsg(), SettleDto.class);
+ for (SettleDto dto : list2) {
+ switch (dto.getStep()) {
+ case 3:
+ dto.setCurr(Boolean.TRUE);
+ break;
+ case 4:
+ dto.setCurr(Boolean.TRUE);
+ dto.setMsg("涓氬姟鍛�" + salesman0.getNickname() + "浠ョ‘璁�");
+ dto.setTime(DateUtils.convert(new Date()));
+ break;
+ default:
+ break;
+ }
+ }
+ contract.setSettleMsg(JSON.toJSONString(list2));
+ // 淇敼瑙勫垝鍗曠姸鎬�
+ contract.setSettle(4); // 瀹℃壒閫氳繃
+ contract.setUpdateTime(new Date());
+
+ if (!contractService.updateById(contract)) {
+ throw new CoolException("纭澶辫触锛岃鑱旂郴绠$悊鍛�");
+ }
+ break;
+ default:
+ return R.error();
+ }
+ return R.ok("瀹℃壒鎴愬姛");
+ }
+
}
--
Gitblit v1.9.1