PlanYearsServiceImpl.java 61 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318
  1. package com.ozs.plan.service.impl;
  2. import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
  3. import com.baomidou.mybatisplus.core.metadata.IPage;
  4. import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
  5. import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
  6. import com.ozs.common.core.domain.AjaxResult;
  7. import com.ozs.common.core.domain.entity.SysDept;
  8. import com.ozs.common.core.domain.entity.SysDictData;
  9. import com.ozs.common.core.domain.entity.SysRole;
  10. import com.ozs.common.core.domain.entity.SysUser;
  11. import com.ozs.common.core.domain.model.LoginUser;
  12. import com.ozs.common.enums.*;
  13. import com.ozs.common.exception.ServiceException;
  14. import com.ozs.common.utils.DateUtils;
  15. import com.ozs.common.utils.SecurityUtils;
  16. import com.ozs.common.utils.StringUtils;
  17. import com.ozs.common.utils.bean.BeanUtils;
  18. import com.ozs.home.domain.vo.HomeToDoQueryResVo;
  19. import com.ozs.plan.doman.PlanQuarter;
  20. import com.ozs.plan.doman.PlanYears;
  21. import com.ozs.plan.doman.ProvisionalPlan;
  22. import com.ozs.plan.doman.vo.requestVo.PlanYearsStandardVo;
  23. import com.ozs.plan.doman.vo.responseVo.PlanQuarterResponseVo;
  24. import com.ozs.plan.doman.vo.responseVo.PlanYearsResponseVo;
  25. import com.ozs.plan.mapper.PlanQuarterMapper;
  26. import com.ozs.plan.mapper.PlanYearsMapper;
  27. import com.ozs.plan.mapper.ProvisionalPlanMapper;
  28. import com.ozs.plan.service.PlanYearsService;
  29. import com.ozs.pm.doman.*;
  30. import com.ozs.pm.doman.vo.requestVo.PmDemandReqVo;
  31. import com.ozs.pm.doman.vo.responseVo.*;
  32. import com.ozs.pm.mapper.PmAuditDeptRefMapper;
  33. import com.ozs.pm.mapper.PmDemandMapper;
  34. import com.ozs.pm.service.*;
  35. import com.ozs.system.domain.SysFileInfo;
  36. import com.ozs.system.domain.SysFileRef;
  37. import com.ozs.system.domain.vo.responseVo.SysDeptResponseVo;
  38. import com.ozs.system.mapper.SysDeptMapper;
  39. import com.ozs.system.mapper.SysFileRefMapper;
  40. import com.ozs.system.mapper.SysRoleMapper;
  41. import com.ozs.system.service.*;
  42. import lombok.extern.slf4j.Slf4j;
  43. import org.springframework.beans.factory.annotation.Autowired;
  44. import org.springframework.stereotype.Service;
  45. import org.springframework.transaction.annotation.Transactional;
  46. import org.springframework.util.ObjectUtils;
  47. import javax.validation.Validator;
  48. import java.math.BigDecimal;
  49. import java.text.ParseException;
  50. import java.text.SimpleDateFormat;
  51. import java.util.ArrayList;
  52. import java.util.Arrays;
  53. import java.util.Calendar;
  54. import java.util.Date;
  55. import java.util.HashMap;
  56. import java.util.LinkedHashMap;
  57. import java.util.List;
  58. import java.util.Map;
  59. import java.util.stream.Collectors;
  60. /**
  61. * @author buzhanyi
  62. */
  63. @Service
  64. @Slf4j
  65. public class PlanYearsServiceImpl extends ServiceImpl<PlanYearsMapper, PlanYears> implements PlanYearsService {
  66. @Autowired
  67. PlanYearsMapper planYearsMapper;
  68. @Autowired
  69. private PlanQuarterMapper planQuarterMapper;
  70. @Autowired
  71. protected Validator validator;
  72. @Autowired
  73. private ISysDictTypeService dictTypeService;
  74. @Autowired
  75. private ISysDeptService deptService;
  76. @Autowired
  77. private SysFileRefMapper sysFileRefMapper;
  78. @Autowired
  79. private SysDeptMapper deptMapper;
  80. @Autowired
  81. private SysFileService fileService;
  82. @Autowired
  83. private SysRoleMapper sysRoleMapper;
  84. @Autowired
  85. private ISysUserService userService;
  86. @Autowired
  87. private PmDemandMapper pmDemandMapper;
  88. @Autowired
  89. private PlanQuarterServiceImpl quartzServiceImpl;
  90. @Autowired
  91. private IPmDemandService demandService;
  92. @Autowired
  93. private ProvisionalPlanMapper provisionalPlanMapper;
  94. @Autowired
  95. private SysFileRefService sysFileRefService;
  96. @Autowired
  97. private PmAuditDeptRefService pmAuditDeptRefService;
  98. @Autowired
  99. private PmAuditDeptRefMapper pmAuditDeptRefMapper;
  100. @Override
  101. public List<PlanYearsResponseVo> selectPlanYearsListEXP(PlanYearsStandardVo vo, LoginUser loginUser) {
  102. List<PlanYears> list = new ArrayList<>();
  103. List<PlanYearsResponseVo> planYearsList = new ArrayList<>();
  104. try {
  105. int num = 1;
  106. int size = 200;
  107. while (size == 200) {
  108. LambdaQueryWrapper<PlanYears> lw = new LambdaQueryWrapper<PlanYears>();
  109. if (!loginUser.getUserId().equals(Long.valueOf("1"))) {
  110. lw.eq(PlanYears::getPurchaseDeptId, loginUser.getDeptId());
  111. }
  112. if (!ObjectUtils.isEmpty(vo.getProjectName())) {
  113. lw.like(PlanYears::getProjectName, vo.getProjectName());
  114. }
  115. if (!ObjectUtils.isEmpty(vo.getPurchaseServices())) {
  116. lw.eq(PlanYears::getPurchaseServices, vo.getPurchaseServices());
  117. }
  118. if (!ObjectUtils.isEmpty(vo.getProjectStatus())) {
  119. lw.eq(PlanYears::getProjectStatus, vo.getProjectStatus());
  120. }
  121. if (!ObjectUtils.isEmpty(vo.getParams())) {
  122. if (!ObjectUtils.isEmpty(vo.getParams().get("beginTime"))) {
  123. lw.ge(PlanYears::getPlanDemandSubTime, vo.getParams().get("beginTime"));
  124. }
  125. if (!ObjectUtils.isEmpty(vo.getParams().get("endTime"))) {
  126. SimpleDateFormat dateFormatT = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss:SSS");
  127. SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd");
  128. Date parse = dateFormatT.parse(dateFormat.format(vo.getParams().get("endTime")) + " 23:59:59:999");
  129. lw.le(PlanYears::getPlanDemandSubTime, parse);
  130. }
  131. }
  132. lw.eq(PlanYears::getDelFlay, DataIsDelete.DataNOTDelete.getCode());
  133. Page<PlanYears> page = planYearsMapper.selectPage(new Page<PlanYears>(num, size, false), lw);
  134. list.addAll(page.getRecords());
  135. size = page.getRecords().size();
  136. num++;
  137. }
  138. planYearsList = changeTo(list);
  139. } catch (Exception e) {
  140. e.printStackTrace();
  141. }
  142. return planYearsList;
  143. }
  144. @Override
  145. public List<PlanYearsResponseVo> selectPlanYearsExamineListEXP(PlanYearsStandardVo vo, LoginUser loginUser) {
  146. List<PlanYears> list = new ArrayList<>();
  147. List<PlanYearsResponseVo> planYearsList = new ArrayList<>();
  148. try {
  149. int num = 1;
  150. int size = 200;
  151. while (size == 200) {
  152. LambdaQueryWrapper<PlanYears> lw = new LambdaQueryWrapper<PlanYears>();
  153. if (!loginUser.getUserId().equals(Long.valueOf("1"))) {
  154. lw.eq(PlanYears::getPurchaseDeptId, loginUser.getDeptId());
  155. }
  156. if (!ObjectUtils.isEmpty(vo.getProjectName())) {
  157. lw.like(PlanYears::getProjectName, vo.getProjectName());
  158. }
  159. if (!ObjectUtils.isEmpty(vo.getPurchaseServices())) {
  160. lw.eq(PlanYears::getPurchaseServices, vo.getPurchaseServices());
  161. }
  162. if (!ObjectUtils.isEmpty(vo.getProjectStatus())) {
  163. lw.eq(PlanYears::getProjectStatus, vo.getProjectStatus());
  164. } else {
  165. lw.in(PlanYears::getProjectStatus, "1,3");
  166. }
  167. if (!ObjectUtils.isEmpty(vo.getParams())) {
  168. if (!ObjectUtils.isEmpty(vo.getParams().get("beginTime"))) {
  169. String beginTime = vo.getParams().get("beginTime").toString();
  170. Date date = new Date();
  171. date.setYear(Integer.parseInt(beginTime.substring(0, 4)));
  172. date.setMonth(Integer.parseInt(beginTime.substring(5, 7)));
  173. SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM");
  174. Date ofMonth = dateFormat.parse(date + "-01");
  175. lw.ge(PlanYears::getPlanDemandSubTime, ofMonth);
  176. }
  177. if (!ObjectUtils.isEmpty(vo.getParams().get("endTime"))) {
  178. SimpleDateFormat dateFormatT = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss:SSS");
  179. SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd");
  180. Date ofMonth = DateUtils.getLastDayOfMonth(dateFormat.parse(vo.getParams().get("endTime").toString()));
  181. Date parse = dateFormatT.parse(dateFormat.format(ofMonth) + " 23:59:59:999");
  182. lw.le(PlanYears::getPlanDemandSubTime, parse);
  183. }
  184. }
  185. lw.eq(PlanYears::getDelFlay, DataIsDelete.DataNOTDelete);
  186. Page<PlanYears> page = planYearsMapper.selectPage(new Page<PlanYears>(num, size, false), lw);
  187. list.addAll(page.getRecords());
  188. size = page.getRecords().size();
  189. num++;
  190. }
  191. planYearsList = changeTo(list);
  192. } catch (Exception e) {
  193. e.printStackTrace();
  194. }
  195. return planYearsList;
  196. }
  197. @Transactional
  198. @Override
  199. public AjaxResult insertPlanYears(PlanYearsStandardVo yearsStandardVo) {
  200. if (planYearsMapper.countProjectName(yearsStandardVo.getProjectName()) > 0) {
  201. return AjaxResult.error("该项目名称已经存在");
  202. }
  203. PlanYears ofYears = new PlanYears();
  204. try {
  205. BeanUtils.copyProperties(yearsStandardVo, ofYears);
  206. } catch (Exception e) {
  207. e.printStackTrace();
  208. }
  209. //判断是否为超额计划
  210. ofYears.setProjectStatus(ProjectStatus.PLANWAITCOMMIT.getCode());
  211. ofYears.setCreateTime(new Date());
  212. planYearsMapper.insertPlanYears(ofYears);
  213. log.info("id:{}", ofYears.getPlanYearId());
  214. List<SysFileRef> sysFileRefs = yearsStandardVo.getSysFileRefs();
  215. if (!ObjectUtils.isEmpty(sysFileRefs)) {
  216. for (SysFileRef ref : sysFileRefs) {
  217. ref.setRedId(ofYears.getPlanYearId());
  218. ref.setType(SysFileRefEnum.PLAN_YEAR.getType());
  219. ref.setCreated(ofYears.getCreated());
  220. ref.setCreateTime(new Date());
  221. ref.setUpdated(ofYears.getCreated());
  222. ref.setUpdateTime(new Date());
  223. sysFileRefMapper.insert(ref);
  224. }
  225. }
  226. return AjaxResult.success();
  227. }
  228. @Override
  229. public AjaxResult deletePlanYearsByIds(Long[] planIds) {
  230. planYearsMapper.deletePlanYearsByIds(planIds);
  231. return AjaxResult.success();
  232. }
  233. @Override
  234. public AjaxResult deletePlanYearsById(Long planId) {
  235. planYearsMapper.deletePlanYearsById(planId);
  236. return AjaxResult.success();
  237. }
  238. @Override
  239. public AjaxResult view(PlanYearsStandardVo yearsStandardVo) {
  240. PlanYearsResponseVo responseVo = new PlanYearsResponseVo();
  241. PlanYears byId = planYearsMapper.getById(yearsStandardVo.getPlanYearId());
  242. byId.getPlanYearId();
  243. if (byId == null) {
  244. return AjaxResult.error("数据查询失败");
  245. }
  246. SysDeptResponseVo sysDeptResponseVo = (SysDeptResponseVo) deptService.selectDeptById(Long.valueOf(byId.getPurchaseDeptId())).get("sysDept");
  247. byId.setPurchaseDeptName(sysDeptResponseVo.getDeptName());
  248. LambdaQueryWrapper<SysFileRef> lw = new LambdaQueryWrapper<>();
  249. lw.eq(SysFileRef::getRedId, yearsStandardVo.getPlanYearId());
  250. lw.in(SysFileRef::getType, Arrays.asList(SysFileRefEnum.PLAN_YEAR.getType(), SysFileRefEnum.PLAN_YEAR_EXAMINE.getType()));
  251. List<SysFileRef> fileRefs = sysFileRefMapper.selectList(lw);
  252. List<SysFileInfo> fileInfos = new ArrayList<>();
  253. BeanUtils.copyProperties(byId, responseVo);
  254. if (!ObjectUtils.isEmpty(fileRefs)) {
  255. for (SysFileRef ref : fileRefs) {
  256. SysFileInfo fileInfo = fileService.getById(ref.getFileId());
  257. fileInfos.add(fileInfo);
  258. }
  259. responseVo.setFileInfos(fileInfos);
  260. }
  261. return AjaxResult.success(responseVo);
  262. }
  263. @Transactional
  264. @Override
  265. public AjaxResult update(PlanYearsStandardVo yearsStandardVo) {
  266. if (planYearsMapper.countProjectNameOther(yearsStandardVo.getProjectName(), String.valueOf(yearsStandardVo.getPlanYearId())) > 0) {
  267. return AjaxResult.error("该项目名称已经存在");
  268. }
  269. PlanYears ofYears = new PlanYears();
  270. try {
  271. BeanUtils.copyProperties(yearsStandardVo, ofYears);
  272. } catch (Exception e) {
  273. e.printStackTrace();
  274. }
  275. ofYears.setUpdateTime(new Date());
  276. planYearsMapper.updateById(ofYears);
  277. List<SysFileRef> sysFileRefs = yearsStandardVo.getSysFileRefs();
  278. if (!ObjectUtils.isEmpty(sysFileRefs)) {
  279. // 删关联
  280. LambdaQueryWrapper<SysFileRef> lw = new LambdaQueryWrapper<>();
  281. lw.eq(SysFileRef::getRedId, ofYears.getPlanYearId());
  282. lw.eq(SysFileRef::getType, SysFileRefEnum.PLAN_YEAR.getType());
  283. sysFileRefMapper.delete(lw);
  284. for (SysFileRef ref : sysFileRefs) {
  285. ref.setRedId(ofYears.getPlanYearId());
  286. ref.setType(SysFileRefEnum.PLAN_YEAR.getType());
  287. ref.setCreated(yearsStandardVo.getUpdated());
  288. ref.setCreateTime(new Date());
  289. ref.setUpdated(yearsStandardVo.getUpdated());
  290. ref.setUpdateTime(new Date());
  291. sysFileRefMapper.insert(ref);
  292. }
  293. }
  294. return AjaxResult.success();
  295. }
  296. //是否在提报时间内
  297. public Boolean isBetweenValue(PlanYears planYear) {
  298. //获取年度计划提报时间的阈值
  299. List<SysDictData> supTime = dictTypeService.selectDictDataByType("sys_annual_plan");
  300. HashMap<String, String> thresholdMap = new LinkedHashMap<>();
  301. //年度提报时间的阈值
  302. for (SysDictData dictData : supTime) {
  303. // 字段名称----阈值
  304. thresholdMap.put(dictData.getDictLabel(), dictData.getDictValue());
  305. }
  306. SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd");
  307. Date subTime = planYear.getPlanDemandSubTime();
  308. try {
  309. Date thresholdTimeStart = dateFormat.parse(thresholdMap.get("起止时间开始"));
  310. Date thresholdTimeEnd = dateFormat.parse(thresholdMap.get("起止时间结束"));
  311. ;
  312. if (!ObjectUtils.isEmpty(thresholdTimeStart) && !ObjectUtils.isEmpty(thresholdTimeEnd)) {
  313. if (subTime.before(thresholdTimeStart) || subTime.after(thresholdTimeEnd)) {
  314. return false;
  315. }
  316. }
  317. } catch (ParseException e) {
  318. e.printStackTrace();
  319. }
  320. return true;
  321. }
  322. @Transactional
  323. @Override
  324. public String importPlanYears(List<PlanYearsStandardVo> planYears, boolean isUpdateSupport, LoginUser loginUser) {
  325. //获取字典数据
  326. HashMap<String, HashMap<String, String>> planEnums = dictTypeService.getAboutEnums();
  327. //项目属性
  328. HashMap<String, String> projectAttributes = planEnums.get("projectAttributes");
  329. //项目类型
  330. HashMap<String, String> projectTypesMap = planEnums.get("projectTypes");
  331. //预算科目
  332. HashMap<String, String> budgetAccountMap = planEnums.get("budgetAccount");
  333. //采购服务站
  334. HashMap<String, String> purchaseServicesMap = planEnums.get("purchaseServices");
  335. if (StringUtils.isNull(planYears) || planYears.size() == 0) {
  336. throw new ServiceException("导入年度计划数据不能为空!");
  337. }
  338. List<PlanYears> plans = new ArrayList<>();
  339. for (PlanYearsStandardVo yearsStandardVo : planYears) {
  340. PlanYears ofYears = new PlanYears();
  341. BeanUtils.copyProperties(yearsStandardVo, ofYears);
  342. ofYears.setPurchaseDeptName(yearsStandardVo.getPurchaseDeptId());
  343. plans.add(ofYears);
  344. }
  345. int successNum = 0;
  346. int failureNum = 0;
  347. StringBuilder successMsg = new StringBuilder();
  348. StringBuilder failureMsg = new StringBuilder();
  349. //deptService
  350. for (PlanYears ofYear : plans) {
  351. try {
  352. //验证项目名称是否重复导入
  353. //将录入信息中的值更改为要保存的数据
  354. if (planYearsMapper.countProjectName(ofYear.getProjectName()) == 0) {
  355. //采购单位
  356. SysDept info = deptMapper.checkDeptNameOnlyOne(ofYear.getPurchaseDeptName());
  357. if (!ObjectUtils.isEmpty(info)) {
  358. ofYear.setPurchaseDeptId(String.valueOf(info.getDeptId()));
  359. } else {
  360. ++failureNum;
  361. failureMsg.append("*" + failureNum + "*采购单位“" + ofYear.getPurchaseDeptName() + "”不存在");
  362. }
  363. ofYear.setProjectType(projectTypesMap.get(ofYear.getProjectType()));
  364. ofYear.setPurchaseServices(purchaseServicesMap.get(ofYear.getPurchaseServices()));
  365. ofYear.setBudgetAccount(budgetAccountMap.get(ofYear.getBudgetAccount()));
  366. ofYear.setProjectStatus(ProjectStatus.PLANWAITCOMMIT.getCode());
  367. //项目属性是多选字段
  368. StringBuilder builder = new StringBuilder();
  369. if (ofYear.getProjectAttr().contains(",")) {
  370. String[] split = ofYear.getProjectAttr().split(",");
  371. for (String s : split) {
  372. if (!ofYear.getProjectAttr().endsWith(s)) {
  373. builder.append(projectAttributes.get(s) + ",");
  374. } else {
  375. builder.append(projectAttributes.get(s));
  376. }
  377. }
  378. } else {
  379. builder.append(projectAttributes.get(ofYear.getProjectAttr()));
  380. }
  381. ofYear.setProjectAttr(builder.toString());
  382. ofYear.setCreated(String.valueOf(loginUser.getUserId()));
  383. ofYear.setCreateTime(new Date());
  384. planYearsMapper.insertPlanYears(ofYear);
  385. successNum++;
  386. successMsg.append("*" + successNum + "、项目 " + ofYear.getProjectName() + " 导入成功!");
  387. } else {
  388. failureNum++;
  389. failureMsg.append(failureNum + "*项目 " + ofYear.getProjectName() + " 已存在!/n");
  390. }
  391. } catch (Exception exc) {
  392. failureNum++;
  393. String msg = "*" + successNum + "*项目 " + ofYear.getProjectName() + " 导入失败";
  394. failureMsg.append(msg + exc.getMessage());
  395. log.error(msg, exc);
  396. }
  397. }
  398. if (failureNum > 0) {
  399. failureMsg.insert(0, "导入失败!共 " + failureNum + " 条数据格式不正确:");
  400. throw new ServiceException(failureMsg.toString());
  401. } else {
  402. successMsg.insert(0, "导入成功!共 " + successNum + " 条。");
  403. }
  404. return successMsg.toString();
  405. }
  406. @Override
  407. @Transactional
  408. public AjaxResult commit(PlanYearsStandardVo yearsStandardVo) {
  409. PlanYears byId = planYearsMapper.getById(yearsStandardVo.getPlanYearId());
  410. if (!isBetweenValue(byId)) {
  411. return AjaxResult.error("所创计划不在提报日期内!");
  412. }
  413. //申请修改之后再次提交,先清除上一次提交后的审核记录
  414. PmAuditDeptRef ref = new PmAuditDeptRef();
  415. ref.setRefId(byId.getPlanYearId()).setRefType("0").setProjectType(byId.getProjectType()).setEvaluation(byId.getEvaluation());
  416. PlanQuarterServiceImpl.refIsExist(ref, pmAuditDeptRefMapper);
  417. PlanQuarterServiceImpl.insertAuditDeptRef(userService, pmAuditDeptRefService, ref);
  418. int commit = planYearsMapper.commit(yearsStandardVo.getPlanYearId());
  419. if (commit != 1) {
  420. return AjaxResult.error("项目状态数据异常");
  421. }
  422. return AjaxResult.success();
  423. }
  424. @Override
  425. @Transactional
  426. public AjaxResult reviewTo(PlanYearsStandardVo vo) {
  427. SysUser sysUser = userService.selectUserById(SecurityUtils.getUserId());
  428. Long deptId = sysUser.getDeptId();
  429. SysDept sysDept = deptMapper.selectDeptById(deptId);
  430. String[] ancestors = sysDept.getAncestors().split(",");
  431. String deptLevel = null;
  432. if (ancestors.length == 2) { //C级
  433. deptLevel = "C";
  434. } else if (ancestors.length == 3) { //B级
  435. deptLevel = "B";
  436. } else if (ancestors.length == 4) { //A级
  437. deptLevel = "A";
  438. }
  439. LambdaQueryWrapper<PmAuditDeptRef> lw = new LambdaQueryWrapper();
  440. lw.eq(PmAuditDeptRef::getRefId, vo.getPlanYearId());
  441. lw.eq(PmAuditDeptRef::getRefType, "0");
  442. List<PmAuditDeptRef> list = pmAuditDeptRefService.list(lw);
  443. boolean flay = true;
  444. if (!ObjectUtils.isEmpty(list)) {
  445. for (PmAuditDeptRef pmAuditDeptRef : list) {
  446. // 判断 deptLevel 是否还有更高的 且是 待审核的数据
  447. if (pmAuditDeptRef.getDeptLevel().compareTo(deptLevel) > 0
  448. && pmAuditDeptRef.getStatus().equals(Integer.parseInt("0"))) {
  449. flay = false;
  450. }
  451. // 更新当前 deptLevel 级别的审核状态
  452. if (pmAuditDeptRef.getDeptLevel().compareTo(deptLevel) == 0) {
  453. pmAuditDeptRef.setStatus(1);
  454. pmAuditDeptRefService.updateById(pmAuditDeptRef);
  455. }
  456. }
  457. }
  458. realReviewTo(vo, flay);
  459. return AjaxResult.success();
  460. }
  461. @Transactional
  462. public AjaxResult realReviewTo(PlanYearsStandardVo vo, boolean flay) {
  463. if (flay) {
  464. //赋予项目状态已审核
  465. vo.setProjectStatus(ProjectStatus.PLANTOEXAMINE.getCode());
  466. return review(vo);
  467. }
  468. return AjaxResult.success("成功");
  469. }
  470. @Override
  471. @Transactional
  472. public AjaxResult reviewReturn(PlanYearsStandardVo vo) {
  473. vo.setProjectStatus(ProjectStatus.PLANTOBACK.getCode());
  474. return review(vo);
  475. }
  476. private AjaxResult review(PlanYearsStandardVo vo) {
  477. Date now = new Date();
  478. //上传审核文件
  479. List<SysFileRef> sysFileRefuses = vo.getSysFileRefs();
  480. if (!ObjectUtils.isEmpty(sysFileRefuses)) {
  481. for (SysFileRef ref : sysFileRefuses) {
  482. ref.setRedId(vo.getPlanYearId());
  483. ref.setType(SysFileRefEnum.PLAN_YEAR_EXAMINE.getType());
  484. ref.setCreated(vo.getUpdated());
  485. ref.setCreateTime(now);
  486. ref.setUpdated(vo.getUpdated());
  487. ref.setUpdateTime(now);
  488. sysFileRefMapper.insert(ref);
  489. }
  490. }
  491. int review = planYearsMapper.review(vo);
  492. if (review != 1) {
  493. return AjaxResult.error("项目状态数据异常");
  494. }
  495. return AjaxResult.success();
  496. }
  497. @Override
  498. public AjaxResult sendLetter(PlanYearsStandardVo yearsStandardVo) {
  499. PlanYears plan = new PlanYears();
  500. BeanUtils.copyProperties(yearsStandardVo, plan);
  501. plan.setSendLetter("1");
  502. plan.setLetterTime(new Date());
  503. int review = planYearsMapper.updateById(plan);
  504. if (review != 1) {
  505. return AjaxResult.error("项目状态数据异常");
  506. }
  507. return AjaxResult.success();
  508. }
  509. @Override
  510. public AjaxResult upLoadPlanFile(PlanYearsStandardVo yearsStandardVo) {
  511. List<SysFileRef> sysFileRefs = yearsStandardVo.getSysFileRefs();
  512. if (!ObjectUtils.isEmpty(sysFileRefs)) {
  513. for (SysFileRef ref : sysFileRefs) {
  514. ref.setRedId(yearsStandardVo.getPlanYearId());
  515. ref.setType(SysFileRefEnum.PLAN_YEAR.getType());
  516. sysFileRefMapper.insert(ref);
  517. }
  518. }
  519. return AjaxResult.success();
  520. }
  521. @Override
  522. public AjaxResult downLoadPlanFile(PlanYearsStandardVo yearsStandardVo) {
  523. return AjaxResult.success();
  524. }
  525. /**
  526. * 需求单位--首页--计划管理总数
  527. *
  528. * @return
  529. */
  530. @Override
  531. public AjaxResult demandUnitPlanManagementTotal() {
  532. // List<PlanYears> planYears = new ArrayList<>();
  533. Long count = null;
  534. try {
  535. // 通过用户ID查询角色
  536. List<SysRole> sysRoles = sysRoleMapper.selectRolePermissionByUserId(SecurityUtils.getUserId());
  537. // 获取角色权限 demand_unit
  538. List<SysRole> sysRoleList = sysRoles.stream().filter(tdto -> tdto.getRoleKey().equals("demand_unit")).collect(Collectors.toList());
  539. if (sysRoleList.size() > 0) {
  540. // 获取用户
  541. SysUser sysUser = userService.selectUserById(SecurityUtils.getUserId());
  542. // 获取部门
  543. SysDept sysDept = deptMapper.selectDeptById(sysUser.getDeptId());
  544. // 查询年度计划
  545. LambdaQueryWrapper<PlanYears> queryWrapper = new LambdaQueryWrapper<>();
  546. queryWrapper.eq(PlanYears::getPurchaseDeptId, sysDept.getDeptId());
  547. queryWrapper.eq(PlanYears::getDelFlay, DataIsDelete.DataNOTDelete.getCode());
  548. // planYears = planYearsMapper.selectList(queryWrapper);
  549. count = planYearsMapper.selectCount(queryWrapper);
  550. }
  551. // 获取角色权限 admin
  552. List<SysRole> sysRoleList2 = sysRoles.stream().filter(tdto -> tdto.getRoleKey().equals("admin")).collect(Collectors.toList());
  553. if (sysRoleList2.size() > 0) {
  554. LambdaQueryWrapper<PlanYears> queryWrapper = new LambdaQueryWrapper<>();
  555. queryWrapper.eq(PlanYears::getDelFlay, DataIsDelete.DataNOTDelete.getCode());
  556. // planYears = planYearsMapper.selectList(queryWrapper);
  557. count = planYearsMapper.selectCount(queryWrapper);
  558. }
  559. } catch (Exception e) {
  560. e.printStackTrace();
  561. }
  562. return AjaxResult.success(count);
  563. }
  564. @Override
  565. public AjaxResult purchasingManagementPurchasingManagementTotal() {
  566. // List<PlanYears> planYears = new ArrayList<>();
  567. // try {
  568. // List<SysRole> sysRoles = sysRoleMapper.selectRolePermissionByUserId(SecurityUtils.getUserId());
  569. // List<SysRole> sysRoleList = sysRoles.stream().filter(tdto -> tdto.getRoleKey().equals("purchasing_management")).collect(Collectors.toList());
  570. // if (sysRoleList.size() > 0) {
  571. // SysUser sysUser = userService.selectUserById(SecurityUtils.getUserId());
  572. // SysDept sysDept = deptMapper.selectDeptById(sysUser.getDeptId());
  573. // LambdaQueryWrapper<PlanYears> queryWrapper = new LambdaQueryWrapper<>();
  574. // queryWrapper.eq(PlanYears::getPurchaseDeptId, sysDept.getDeptId())
  575. // .in(PlanYears::getProjectStatus, ProjectStatus.PLANWAIEXAMINE.getCode(), ProjectStatus.PLANTOEXAMINE.getCode());
  576. // planYears = planYearsMapper.selectList(queryWrapper);
  577. // }
  578. // List<SysRole> sysRoleList2 = sysRoles.stream().filter(tdto -> tdto.getRoleKey().equals("admin")).collect(Collectors.toList());
  579. // if (sysRoleList2.size() > 0) {
  580. // LambdaQueryWrapper<PlanYears> queryWrapper = new LambdaQueryWrapper<>();
  581. // queryWrapper.in(PlanYears::getProjectStatus, ProjectStatus.PLANWAIEXAMINE.getCode(), ProjectStatus.PLANTOEXAMINE.getCode());
  582. // planYears = planYearsMapper.selectList(queryWrapper);
  583. // }
  584. // } catch (Exception e) {
  585. // e.printStackTrace();
  586. // }
  587. LoginUser loginUser = SecurityUtils.getLoginUser();
  588. PlanYearsStandardVo vo = new PlanYearsStandardVo();
  589. vo.setPurchaseDeptId(String.valueOf(loginUser.getDeptId()));
  590. vo.setCreated(String.valueOf(loginUser.getUserId()));
  591. List<PlanYears> planYears = planYearsMapper.query(vo);
  592. return AjaxResult.success(planYears.size());
  593. }
  594. /**
  595. * 需求单位--首页--需求管理总数
  596. *
  597. * @return
  598. */
  599. @Override
  600. public AjaxResult demandUnitDemandManagementTotal() {
  601. List<PmDemand> pmDemands = new ArrayList<>();
  602. try {
  603. // 通过用户ID 查询角色
  604. List<SysRole> sysRoles = sysRoleMapper.selectRolePermissionByUserId(SecurityUtils.getUserId());
  605. // 获取角色权限 demand_unit
  606. List<SysRole> sysRoleList = sysRoles.stream().filter(tdto -> tdto.getRoleKey().equals("demand_unit")).collect(Collectors.toList());
  607. if (sysRoleList.size() > 0) {
  608. SysUser sysUser = userService.selectUserById(SecurityUtils.getUserId());
  609. SysDept sysDept = deptMapper.selectDeptById(sysUser.getDeptId());
  610. LambdaQueryWrapper<PmDemand> queryWrapper = new LambdaQueryWrapper<>();
  611. queryWrapper.in(PmDemand::getPurchaseDeptId, sysDept.getDeptId());
  612. pmDemands = pmDemandMapper.selectList(queryWrapper);
  613. }
  614. List<SysRole> sysRoleList2 = sysRoles.stream().filter(tdto -> tdto.getRoleKey().equals("admin")).collect(Collectors.toList());
  615. if (sysRoleList2.size() > 0) {
  616. LambdaQueryWrapper<PmDemand> queryWrapper = new LambdaQueryWrapper<>();
  617. pmDemands = pmDemandMapper.selectList(queryWrapper);
  618. }
  619. } catch (Exception e) {
  620. e.printStackTrace();
  621. }
  622. return AjaxResult.success(pmDemands.size());
  623. }
  624. @Override
  625. public AjaxResult purchasingManagementDemandManagementTotal() {
  626. long ii = selectPmDemandCount(1);
  627. return AjaxResult.success(ii);
  628. }
  629. public long selectPmDemandCount(int reqType) {
  630. LambdaQueryWrapper<PmDemand> lw = new LambdaQueryWrapper<>();
  631. // 4 (合同信息管理)、 0(需求单位管理) 、 5(项目建设管理) 需求单位
  632. // 1(需求需求审核) 、2 (任务下达管理) 采购管理部门
  633. // 3(采购执行管理) 采购办
  634. List<PmAuditDeptRef> list = new ArrayList<>();
  635. LambdaQueryWrapper<PmAuditDeptRef> l = new LambdaQueryWrapper<>();
  636. l.eq(PmAuditDeptRef::getDeptId, SecurityUtils.getDeptId());
  637. l.eq(PmAuditDeptRef::getRefType, "2");
  638. list = pmAuditDeptRefService.list(l);
  639. if (Arrays.asList(1, 2, 3).contains(reqType)) {
  640. if (!ObjectUtils.isEmpty(list) && !SecurityUtils.getUserId().equals(Integer.parseInt("1"))) {
  641. lw.in(PmDemand::getDemandId, list.stream().map(PmAuditDeptRef::getRefId).collect(Collectors.toList()));
  642. }
  643. } else {
  644. lw.eq(PmDemand::getPurchaseDeptId, SecurityUtils.getDeptId());
  645. }
  646. if (reqType == 1) { //需求审核单位列表
  647. lw.apply("(project_status = 6 or project_status = 8 )");
  648. } else if (reqType == 2) { //任务下达列表
  649. lw.apply("(project_status = 8 or project_status = 9 )");
  650. } else if (reqType == 3) { //采购执行列表
  651. lw.apply("(project_status = 9 or project_status = 10 or project_status = 11 or project_status = 12 or project_status = 13 or project_status = 14 or project_status = 15)");
  652. } else if (reqType == 4) { //合同信息列表
  653. lw.apply("(project_status = 15 or project_status = 16 )");
  654. } else if (reqType == 5) { //项目建设列表
  655. lw.apply("(project_status = 16 or project_status = 17 )");
  656. }
  657. lw.last(" order by project_status, plan_demand_sub_time");
  658. long count = demandService.count(lw);
  659. return count;
  660. }
  661. @Override
  662. public AjaxResult demandUnitContractManagementTotal() {
  663. List<PmDemand> pmDemands = new ArrayList<>();
  664. try {
  665. List<SysRole> sysRoles = sysRoleMapper.selectRolePermissionByUserId(SecurityUtils.getUserId());
  666. List<SysRole> sysRoleList = sysRoles.stream().filter(tdto -> tdto.getRoleKey().equals("demand_unit")).collect(Collectors.toList());
  667. if (sysRoleList.size() > 0) {
  668. SysUser sysUser = userService.selectUserById(SecurityUtils.getUserId());
  669. SysDept sysDept = deptMapper.selectDeptById(sysUser.getDeptId());
  670. LambdaQueryWrapper<PmDemand> queryWrapper = new LambdaQueryWrapper<>();
  671. queryWrapper.eq(PmDemand::getPurchaseDeptId, sysDept.getDeptId());
  672. queryWrapper.in(PmDemand::getProjectStatus, PmProjectStatus.CONTRACT_WAIT_FILL.getCode(), PmProjectStatus.UNDER_CONSTRUCTION.getCode());
  673. pmDemands = pmDemandMapper.selectList(queryWrapper);
  674. }
  675. List<SysRole> sysRoleList2 = sysRoles.stream().filter(tdto -> tdto.getRoleKey().equals("admin")).collect(Collectors.toList());
  676. if (sysRoleList2.size() > 0) {
  677. LambdaQueryWrapper<PmDemand> queryWrapper = new LambdaQueryWrapper<>();
  678. queryWrapper.in(PmDemand::getProjectStatus, PmProjectStatus.CONTRACT_WAIT_FILL.getCode(), PmProjectStatus.UNDER_CONSTRUCTION.getCode());
  679. pmDemands = pmDemandMapper.selectList(queryWrapper);
  680. }
  681. } catch (Exception e) {
  682. e.printStackTrace();
  683. }
  684. return AjaxResult.success(pmDemands.size());
  685. }
  686. @Override
  687. public AjaxResult demandUnitConstructionManagementTotal() {
  688. List<PmDemand> pmDemands = new ArrayList<>();
  689. try {
  690. List<SysRole> sysRoles = sysRoleMapper.selectRolePermissionByUserId(SecurityUtils.getUserId());
  691. List<SysRole> sysRoleList = sysRoles.stream().filter(tdto -> tdto.getRoleKey().equals("demand_unit")).collect(Collectors.toList());
  692. if (sysRoleList.size() > 0) {
  693. SysUser sysUser = userService.selectUserById(SecurityUtils.getUserId());
  694. SysDept sysDept = deptMapper.selectDeptById(sysUser.getDeptId());
  695. LambdaQueryWrapper<PmDemand> queryWrapper = new LambdaQueryWrapper<>();
  696. queryWrapper.eq(PmDemand::getPurchaseDeptId, sysDept.getDeptId());
  697. queryWrapper.in(PmDemand::getProjectStatus, PmProjectStatus.UNDER_CONSTRUCTION.getCode(), PmProjectStatus.COMPLETION_CONSTRUCTION.getCode());
  698. pmDemands = pmDemandMapper.selectList(queryWrapper);
  699. }
  700. List<SysRole> sysRoleList2 = sysRoles.stream().filter(tdto -> tdto.getRoleKey().equals("admin")).collect(Collectors.toList());
  701. if (sysRoleList2.size() > 0) {
  702. LambdaQueryWrapper<PmDemand> queryWrapper = new LambdaQueryWrapper<>();
  703. queryWrapper.in(PmDemand::getProjectStatus, PmProjectStatus.UNDER_CONSTRUCTION.getCode(), PmProjectStatus.COMPLETION_CONSTRUCTION.getCode());
  704. pmDemands = pmDemandMapper.selectList(queryWrapper);
  705. }
  706. } catch (Exception e) {
  707. e.printStackTrace();
  708. }
  709. return AjaxResult.success(pmDemands.size());
  710. }
  711. @Override
  712. public AjaxResult purchasingManagementTaskReleaseTotal() {
  713. long ii = selectPmDemandCount(2);
  714. return AjaxResult.success(ii);
  715. }
  716. @Override
  717. public AjaxResult procurementOfficeProcurementExecutionTotal() {
  718. PmDemandReqVo pmDemandReqVo = new PmDemandReqVo();
  719. pmDemandReqVo.setPageNum(1L);
  720. pmDemandReqVo.setPageSize(10L);
  721. pmDemandReqVo.setUserId(SecurityUtils.getUserId());
  722. pmDemandReqVo.setIsAdmin(SysUser.isAdmin(SecurityUtils.getUserId()));
  723. pmDemandReqVo.setDeptId(SecurityUtils.getDeptId());
  724. pmDemandReqVo.setPurchaseDeptId(Math.toIntExact(SecurityUtils.getDeptId()));
  725. IPage<PmDemandResVo> page = demandService.selectPmDemandList(pmDemandReqVo, 3);
  726. return AjaxResult.success(page.getTotal());
  727. }
  728. @Override
  729. public AjaxResult procurementOfficeWinningTheBidTotal() {
  730. List<PmDemand> pmDemands = new ArrayList<>();
  731. try {
  732. List<SysRole> sysRoles = sysRoleMapper.selectRolePermissionByUserId(SecurityUtils.getUserId());
  733. List<SysRole> sysRoleList = sysRoles.stream().filter(tdto -> tdto.getRoleKey().equals("procurement_office")).collect(Collectors.toList());
  734. if (sysRoleList.size() > 0) {
  735. SysUser sysUser = userService.selectUserById(SecurityUtils.getUserId());
  736. SysDept sysDept = deptMapper.selectDeptById(sysUser.getDeptId());
  737. LambdaQueryWrapper<PmDemand> queryWrapper = new LambdaQueryWrapper<>();
  738. queryWrapper.eq(PmDemand::getPurchaseDeptId, sysDept.getDeptId())
  739. .lt(PmDemand::getProjectStatus, PmProjectStatus.CONTRACT_WAIT_FILL.getCode());
  740. pmDemands = pmDemandMapper.selectList(queryWrapper);
  741. }
  742. List<SysRole> sysRoleList2 = sysRoles.stream().filter(tdto -> tdto.getRoleKey().equals("admin")).collect(Collectors.toList());
  743. if (sysRoleList2.size() > 0) {
  744. LambdaQueryWrapper<PmDemand> queryWrapper = new LambdaQueryWrapper<>();
  745. queryWrapper.lt(PmDemand::getProjectStatus, PmProjectStatus.CONTRACT_WAIT_FILL.getCode());
  746. pmDemands = pmDemandMapper.selectList(queryWrapper);
  747. }
  748. } catch (Exception e) {
  749. e.printStackTrace();
  750. }
  751. return AjaxResult.success(pmDemands.size());
  752. }
  753. @Override
  754. public AjaxResult procurementOfficeFailureToWinTheBidTotal() {
  755. List<PmDemand> pmDemands = new ArrayList<>();
  756. try {
  757. List<SysRole> sysRoles = sysRoleMapper.selectRolePermissionByUserId(SecurityUtils.getUserId());
  758. List<SysRole> sysRoleList = sysRoles.stream().filter(tdto -> tdto.getRoleKey().equals("procurement_office")).collect(Collectors.toList());
  759. if (sysRoleList.size() > 0) {
  760. SysUser sysUser = userService.selectUserById(SecurityUtils.getUserId());
  761. SysDept sysDept = deptMapper.selectDeptById(sysUser.getDeptId());
  762. LambdaQueryWrapper<PmDemand> queryWrapper = new LambdaQueryWrapper<>();
  763. queryWrapper.eq(PmDemand::getPurchaseDeptId, sysDept.getDeptId())
  764. .gt(PmDemand::getProjectStatus, PmProjectStatus.CONTRACT_WAIT_FILL.getCode());
  765. pmDemands = pmDemandMapper.selectList(queryWrapper);
  766. }
  767. List<SysRole> sysRoleList2 = sysRoles.stream().filter(tdto -> tdto.getRoleKey().equals("admin")).collect(Collectors.toList());
  768. if (sysRoleList2.size() > 0) {
  769. LambdaQueryWrapper<PmDemand> queryWrapper = new LambdaQueryWrapper<>();
  770. queryWrapper.gt(PmDemand::getProjectStatus, PmProjectStatus.CONTRACT_WAIT_FILL.getCode());
  771. pmDemands = pmDemandMapper.selectList(queryWrapper);
  772. }
  773. } catch (Exception e) {
  774. e.printStackTrace();
  775. }
  776. return AjaxResult.success(pmDemands.size());
  777. }
  778. /**
  779. * 查询需求单位待办事项(计划待提交)
  780. *
  781. * @return
  782. */
  783. @Override
  784. public List<PlanQuarterResponseVo> planWaitCommit() {
  785. return getListByProjectStatus(ProjectStatus.PLANWAITCOMMIT.getCode());
  786. }
  787. /**
  788. * 采购管理部门首页待办事项(计划待审核)
  789. *
  790. * @return
  791. */
  792. @Override
  793. public List<PlanQuarterResponseVo> planWaitExamine() {
  794. return getListByProjectStatus(ProjectStatus.PLANWAIEXAMINE.getCode());
  795. }
  796. /**
  797. * 需求单位待办事项
  798. */
  799. @Override
  800. public AjaxResult demandUnitWillManipulateTotal() {
  801. List<HomeToDoQueryResVo> homeRes = new ArrayList<>();
  802. //计划待提交,需求待提交,合同待填制,项目建设待完成
  803. List<PlanQuarterResponseVo> planRes = getListByProjectStatus(ProjectStatus.PLANWAITCOMMIT.getCode());
  804. List<PmDemandResVo> demandRes = demandService.demandWaitCommit();
  805. demandRes.addAll(demandService.contractWaitFilled());
  806. demandRes.addAll(demandService.projectWaitFinish());
  807. //转为首页table展示数据
  808. if (!ObjectUtils.isEmpty(planRes) && planRes.size() > 0) {
  809. for (PlanQuarterResponseVo planVo : planRes) {
  810. HomeToDoQueryResVo home = new HomeToDoQueryResVo();
  811. BeanUtils.copyProperties(planVo, home);
  812. homeRes.add(home);
  813. }
  814. }
  815. if (!ObjectUtils.isEmpty(demandRes) && demandRes.size() > 0) {
  816. for (PmDemandResVo demandResVo : demandRes) {
  817. HomeToDoQueryResVo home = new HomeToDoQueryResVo();
  818. home.setEvaluation(BigDecimal.valueOf(demandResVo.getEvaluation()));
  819. BeanUtils.copyProperties(demandResVo, home);
  820. homeRes.add(home);
  821. }
  822. }
  823. return AjaxResult.success(homeRes);
  824. }
  825. @Override
  826. public AjaxResult purchasingManagementWillManipulateTotal() {
  827. List<HomeToDoQueryResVo> homeRes = new ArrayList<>();
  828. //计划待审核,需求待审核,任务待下达
  829. List<PlanQuarterResponseVo> planRes = getListByProjectStatus(ProjectStatus.PLANWAIEXAMINE.getCode());
  830. List<PmDemandResVo> demandRes = demandService.demandWaitExamine();
  831. demandRes.addAll(demandService.taskWaitRelease());
  832. //转为首页table展示数据
  833. if (!ObjectUtils.isEmpty(planRes) && planRes.size() > 0) {
  834. for (PlanQuarterResponseVo planVo : planRes) {
  835. HomeToDoQueryResVo home = new HomeToDoQueryResVo();
  836. BeanUtils.copyProperties(planVo, home);
  837. homeRes.add(home);
  838. }
  839. }
  840. if (!ObjectUtils.isEmpty(demandRes) && demandRes.size() > 0) {
  841. for (PmDemandResVo demandResVo : demandRes) {
  842. HomeToDoQueryResVo home = new HomeToDoQueryResVo();
  843. home.setEvaluation(BigDecimal.valueOf(demandResVo.getEvaluation()));
  844. BeanUtils.copyProperties(demandResVo, home);
  845. homeRes.add(home);
  846. }
  847. }
  848. return AjaxResult.success(homeRes);
  849. }
  850. /**
  851. * 通过年度ID,查询季度、临时计划详情,通过季度、临时计划ID查询项目
  852. *
  853. * @param yearsStandardVo
  854. * @return
  855. */
  856. @Override
  857. public AjaxResult projectDetails(PlanYearsStandardVo yearsStandardVo) {
  858. Map<String, Object> returnMap = new HashMap<>();
  859. // 通过年度ID查询年度详情
  860. PlanYears byId = planYearsMapper.getById(yearsStandardVo.getPlanYearId());
  861. if (StringUtils.isNull(byId)) {
  862. return AjaxResult.error("没有查到相关数据!");
  863. }
  864. // 通过年度ID查询季度、临时计划详情
  865. ProvisionalPlan provisionalPlan = provisionalPlanMapper.selectProvisionalPlanByYearId(yearsStandardVo.getPlanYearId().intValue());
  866. if (StringUtils.isNull(provisionalPlan)) {
  867. return AjaxResult.error("没有查到相关数据!");
  868. }
  869. // 通过季度、临时计划ID查询项目数据
  870. PmDemand pmDemand = demandService.selectByPlanId(provisionalPlan.getPlanPracticalId());
  871. if (StringUtils.isNotNull(pmDemand)) {
  872. String detailType = "";
  873. if (StringUtils.isNotNull(yearsStandardVo.getDetailType())) {
  874. detailType = yearsStandardVo.getDetailType();
  875. } else {
  876. // 详情类型(1项目计划,2需求建档,3任务下达,4中标信息,5合同信息,6建设情况)
  877. // 项目计划 4之前(包括4)
  878. // 需求建党 4之后(不包括4)
  879. // 任务下达 8之后(不包括8)
  880. // 采购执行 9之后(不包括9)
  881. // 合同信息 19之后(不包括19)
  882. // 项目建设 21
  883. Integer projectStatus = Integer.valueOf(pmDemand.getProjectStatus());
  884. if (projectStatus <= 4 || projectStatus == 18) {
  885. detailType = "1";
  886. } else if (4 < projectStatus && projectStatus <= 8) {
  887. detailType = "2";
  888. } else if (8 < projectStatus && projectStatus <= 9) {
  889. detailType = "3";
  890. } else if (9 < projectStatus && projectStatus <= 19 && projectStatus != 18) {
  891. detailType = "4";
  892. } else if (19 < projectStatus && projectStatus < 21) {
  893. detailType = "5";
  894. } else if (projectStatus == 21) {
  895. detailType = "6";
  896. }
  897. }
  898. PmDemandResVo vo = demandService.selectPmDemandByDemandId(pmDemand.getDemandId(), detailType);
  899. return AjaxResult.success(vo);
  900. } else {
  901. if (StringUtils.isNotNull(provisionalPlan)) {
  902. return AjaxResult.success(provisionalPlan);
  903. } else {
  904. if (StringUtils.isNotNull(byId)) {
  905. return AjaxResult.success(byId);
  906. }
  907. }
  908. }
  909. return AjaxResult.error("没有查到相关数据!");
  910. }
  911. @Override
  912. public List<PlanYears> queryPage(PlanYearsStandardVo vo) {
  913. List<PlanYears> planYears = planYearsMapper.query(vo);
  914. if (!ObjectUtils.isEmpty(planYears)) {
  915. planYears.stream().map(o -> {
  916. // 当前年度计划的所有关联审核数据
  917. LambdaQueryWrapper<PmAuditDeptRef> lw = new LambdaQueryWrapper();
  918. lw.eq(PmAuditDeptRef::getRefId, o.getPlanYearId());
  919. lw.eq(PmAuditDeptRef::getRefType, "0");
  920. List<PmAuditDeptRef> list = pmAuditDeptRefService.list(lw);
  921. boolean fl = true;
  922. if (!ObjectUtils.isEmpty(list) && list.size() > 0) {
  923. // 当地 年度计划 当前部门 的 审核数据
  924. List<PmAuditDeptRef> collect = list.stream()
  925. .filter(f -> f.getDeptId().equals(Long.valueOf(vo.getPurchaseDeptId())))
  926. .collect(Collectors.toList());
  927. if (ObjectUtils.isEmpty(collect)) {
  928. fl = false;
  929. } else {
  930. String deptLevel = collect.get(0).getDeptLevel();
  931. fl = collect.get(0).getStatus().equals(Integer.parseInt("1")) ? false : true;
  932. for (PmAuditDeptRef pmAuditDeptRef : list) {
  933. if (pmAuditDeptRef.getDeptLevel().compareTo(deptLevel) == -1
  934. && pmAuditDeptRef.getStatus().equals(Integer.parseInt("0"))) {
  935. fl = false;
  936. }
  937. }
  938. }
  939. /*
  940. * String s1="A";
  941. String s2="B";
  942. System.out.println(s1.compareTo(s2));
  943. * -1
  944. * */
  945. }
  946. if (vo.getCreated().equals("1")) {
  947. fl = false;
  948. }
  949. o.setFlag(fl);
  950. return o;
  951. }).collect(Collectors.toList());
  952. }
  953. return planYears;
  954. }
  955. private List<SysFileInfo> getSysFileInfoList(Long redId, Integer type) {
  956. HashMap<String, Object> map = new HashMap<>();
  957. map.put("red_id", redId);
  958. map.put("type", type);
  959. List<SysFileRef> fileRefs = sysFileRefService.listByMap(map);
  960. if (!ObjectUtils.isEmpty(fileRefs)) {
  961. List<SysFileInfo> fileInfos = new ArrayList<>();
  962. for (SysFileRef ref : fileRefs) {
  963. SysFileInfo fileInfo = fileService.getById(ref.getFileId());
  964. fileInfos.add(fileInfo);
  965. }
  966. return fileInfos;
  967. } else {
  968. return null;
  969. }
  970. }
  971. /**
  972. * 查询已被催告发函的计划
  973. *
  974. * @return
  975. */
  976. @Override
  977. public List<PlanQuarterResponseVo> willSendLetter() {
  978. LambdaQueryWrapper<PlanYears> yearsLp = new LambdaQueryWrapper<PlanYears>();
  979. yearsLp.eq(PlanYears::getDelFlay, DataIsDelete.DataNOTDelete.getCode());
  980. yearsLp.eq(PlanYears::getSendLetter, "1");
  981. List<PlanYears> planYears = planYearsMapper.selectList(yearsLp);
  982. LambdaQueryWrapper<PlanQuarter> quarterLp = new LambdaQueryWrapper<PlanQuarter>();
  983. quarterLp.eq(PlanQuarter::getDelFlay, DataIsDelete.DataNOTDelete.getCode());
  984. quarterLp.eq(PlanQuarter::getSendLetter, "1");
  985. List<PlanQuarter> planQuarters = planQuarterMapper.selectList(quarterLp);
  986. //融合一起
  987. List<PlanQuarterResponseVo> vos = planComplex(planYears, planQuarters);
  988. return vos;
  989. }
  990. public List<PlanQuarterResponseVo> getListByProjectStatus(String projectStatus) {
  991. LambdaQueryWrapper<PlanYears> yearsLp = new LambdaQueryWrapper<PlanYears>();
  992. yearsLp.eq(PlanYears::getDelFlay, DataIsDelete.DataNOTDelete.getCode());
  993. yearsLp.eq(PlanYears::getProjectStatus, projectStatus);
  994. List<PlanYears> planYears = planYearsMapper.selectList(yearsLp);
  995. LambdaQueryWrapper<PlanQuarter> quarterLp = new LambdaQueryWrapper<PlanQuarter>();
  996. quarterLp.eq(PlanQuarter::getDelFlay, DataIsDelete.DataNOTDelete.getCode());
  997. quarterLp.eq(PlanQuarter::getProjectStatus, projectStatus);
  998. List<PlanQuarter> planQuarters = planQuarterMapper.selectList(quarterLp);
  999. //融合一起
  1000. List<PlanQuarterResponseVo> vos = planComplex(planYears, planQuarters);
  1001. return vos;
  1002. }
  1003. /**
  1004. * 年度计划与季度数据一起
  1005. *
  1006. * @return
  1007. */
  1008. public List<PlanQuarterResponseVo> planComplex(List<PlanYears> planYears, List<PlanQuarter> planQuarters) {
  1009. List<PlanYearsResponseVo> yearsRes = changeTo(planYears);
  1010. List<PlanQuarterResponseVo> quarterRes = quartzServiceImpl.changeTo(planQuarters);
  1011. if (!ObjectUtils.isEmpty(yearsRes) && yearsRes.size() > 0) {
  1012. for (PlanYearsResponseVo yearsRe : yearsRes) {
  1013. PlanQuarterResponseVo responseVo = new PlanQuarterResponseVo();
  1014. BeanUtils.copyProperties(yearsRe, responseVo);
  1015. quarterRes.add(responseVo);
  1016. }
  1017. }
  1018. return quarterRes;
  1019. }
  1020. //字段赋值对应的名称
  1021. @Override
  1022. public List<PlanYearsResponseVo> changeTo(List<PlanYears> planYears) {
  1023. //获取年度计划提报时间的阈值
  1024. List<SysDictData> supTime = dictTypeService.selectDictDataByType("sys_annual_plan");
  1025. HashMap<String, String> thresholdMap = new LinkedHashMap<>();
  1026. //年度提报时间的阈值
  1027. for (SysDictData dictData : supTime) {
  1028. // 字段名称----阈值
  1029. thresholdMap.put(dictData.getDictLabel(), dictData.getDictValue());
  1030. }
  1031. //提前或延后*天进行提醒
  1032. List<SysDictData> alertTime = dictTypeService.selectDictDataByType("alert_time_setting");
  1033. HashMap<String, String> alertTimeMap = new LinkedHashMap<>();
  1034. //根据时间类别设定的提醒时间
  1035. for (SysDictData dictData : alertTime) {
  1036. // 字段名称----阈值
  1037. alertTimeMap.put(dictData.getDictLabel(), dictData.getDictValue());
  1038. }
  1039. //获取字典数据
  1040. HashMap<String, HashMap<String, String>> planEnums = dictTypeService.getAboutEnums();
  1041. //项目属性
  1042. HashMap<String, String> projectAttributes = planEnums.get("projectAttributes");
  1043. //项目审核状态
  1044. HashMap<String, String> projectStatusMap = planEnums.get("projectStatus");
  1045. //项目类型
  1046. HashMap<String, String> projectTypesMap = planEnums.get("projectTypes");
  1047. //预算科目
  1048. HashMap<String, String> budgetAccountMap = planEnums.get("budgetAccount");
  1049. //采购服务站
  1050. HashMap<String, String> purchaseServicesMap = planEnums.get("purchaseServices");
  1051. List<PlanYearsResponseVo> list = new ArrayList<PlanYearsResponseVo>();
  1052. for (PlanYears planYear : planYears) {
  1053. PlanYearsResponseVo responseVo = new PlanYearsResponseVo();
  1054. SysDeptResponseVo sysDeptResponseVo = (SysDeptResponseVo) deptService.selectDeptById(Long.valueOf(planYear.getPurchaseDeptId())).get("sysDept");
  1055. planYear.setPurchaseDeptName(sysDeptResponseVo.getDeptName());
  1056. //预算科目
  1057. for (Map.Entry<String, String> entry : budgetAccountMap.entrySet()) {
  1058. if (!ObjectUtils.isEmpty(planYear.getBudgetAccount()) && planYear.getBudgetAccount().equals(entry.getValue())) {
  1059. planYear.setBudgetAccountStr(entry.getKey());
  1060. break;
  1061. }
  1062. }
  1063. //采购服务站
  1064. for (Map.Entry<String, String> entry : purchaseServicesMap.entrySet()) {
  1065. if (!ObjectUtils.isEmpty(planYear.getPurchaseServices()) && planYear.getPurchaseServices().equals(entry.getValue())) {
  1066. planYear.setPurchaseServicesStr(entry.getKey());
  1067. break;
  1068. }
  1069. }
  1070. //项目审核状态
  1071. for (Map.Entry<String, String> entry : projectStatusMap.entrySet()) {
  1072. if (!ObjectUtils.isEmpty(planYear.getProjectStatus()) && planYear.getProjectStatus().equals(entry.getValue())) {
  1073. planYear.setProjectStatusStr(entry.getKey());
  1074. break;
  1075. }
  1076. }
  1077. //项目类型
  1078. for (Map.Entry<String, String> entry : projectTypesMap.entrySet()) {
  1079. if (!ObjectUtils.isEmpty(planYear.getProjectType()) && planYear.getProjectType().equals(entry.getValue())) {
  1080. planYear.setProjectTypeStr(entry.getKey());
  1081. break;
  1082. }
  1083. }
  1084. //项目属性为value拼接
  1085. if (!ObjectUtils.isEmpty(planYear.getProjectAttr())) {
  1086. if (planYear.getProjectAttr().length() > 1) {
  1087. StringBuilder builder = new StringBuilder();
  1088. String[] split = planYear.getProjectAttr().split(",");
  1089. for (String s : split) {
  1090. for (Map.Entry<String, String> entry : projectAttributes.entrySet()) {
  1091. if (s.equals(entry.getValue())) {
  1092. if (!planYear.getProjectAttr().endsWith(s)) {
  1093. builder.append(entry.getKey() + ",");
  1094. } else {
  1095. builder.append(entry.getKey());
  1096. }
  1097. break;
  1098. }
  1099. }
  1100. }
  1101. planYear.setProjectAttrName(builder.toString());
  1102. } else {
  1103. for (Map.Entry<String, String> entry : projectAttributes.entrySet()) {
  1104. if (planYear.getProjectAttr().equals(entry.getValue())) {
  1105. planYear.setProjectAttrName(entry.getKey());
  1106. break;
  1107. }
  1108. }
  1109. }
  1110. }
  1111. //机关业务指导处(科)为id拼接
  1112. String organDivision = planYear.getOrganDivision();
  1113. if (!ObjectUtils.isEmpty(organDivision)) {
  1114. int length = organDivision.split(",").length;
  1115. SysDept sysDept = new SysDept();
  1116. if (length > 1) {
  1117. StringBuilder builder = new StringBuilder();
  1118. String[] split = organDivision.split(",");
  1119. for (String s : split) {
  1120. sysDept = deptService.selectById(Long.valueOf(s));
  1121. if (!ObjectUtils.isEmpty(sysDept)) {
  1122. if (!organDivision.endsWith(s)) {
  1123. builder.append(sysDept.getDeptName() + ",");
  1124. } else {
  1125. builder.append(sysDept.getDeptName());
  1126. }
  1127. }
  1128. }
  1129. planYear.setOrganDivisionStr(builder.toString());
  1130. } else if (length == 1) {
  1131. sysDept = deptService.selectById(Long.valueOf(organDivision));
  1132. if (!ObjectUtils.isEmpty(sysDept)) {
  1133. planYear.setOrganDivisionStr(sysDept.getDeptName());
  1134. }
  1135. }
  1136. }
  1137. //是否可以申请撤销
  1138. //需求待填制可以申请,需求建档就不能申请
  1139. PlanQuarter byPlanYearId = planQuarterMapper.getByPlanYearId(planYear.getPlanYearId());
  1140. if (!ObjectUtils.isEmpty(byPlanYearId)) {
  1141. PmDemand demand = demandService.selectByPlanId(byPlanYearId.getPlanPracticalId());
  1142. if (!ObjectUtils.isEmpty(demand) && !demand.getProjectStatus().equals(PmProjectStatus.DEMAND_WAIT_FILL.getCode())) {
  1143. planYear.setAppDeleteDo("false");
  1144. } else if (!ObjectUtils.isEmpty(planYear.getAppDelete()) && planYear.getAppDelete().equals("true")) {
  1145. //申请过的不能再申请
  1146. planYear.setAppDeleteDo("false");
  1147. } else {
  1148. planYear.setAppDeleteDo("true");
  1149. }
  1150. } else if (!planYear.getProjectStatus().equals("0")) {
  1151. //提交后可以申请撤销
  1152. planYear.setAppDeleteDo("true");
  1153. }
  1154. BeanUtils.copyProperties(planYear, responseVo);
  1155. try {
  1156. responseVo.setTipsMessage(planYearsGetTips(responseVo, thresholdMap, alertTimeMap));
  1157. } catch (ParseException e) {
  1158. e.printStackTrace();
  1159. }
  1160. list.add(responseVo);
  1161. }
  1162. return list;
  1163. }
  1164. @Override
  1165. @Transactional
  1166. public AjaxResult adPurchaseServices(PlanYearsStandardVo yearsStandardVo) {
  1167. PlanYears years = new PlanYears();
  1168. BeanUtils.copyProperties(yearsStandardVo, years);
  1169. if (planYearsMapper.updateById(years) == 1) {
  1170. return AjaxResult.success("成功");
  1171. }
  1172. return AjaxResult.success("成功");
  1173. }
  1174. @Override
  1175. public AjaxResult appDelete(PlanYearsStandardVo yearsStandardVo) {
  1176. PlanQuarter byPlanYearId = planQuarterMapper.getByPlanYearId(yearsStandardVo.getPlanYearId());
  1177. //需求待填制可以申请,需求建档就不能申请
  1178. if (!ObjectUtils.isEmpty(byPlanYearId)) {
  1179. PmDemand demand = demandService.selectByPlanId(byPlanYearId.getPlanPracticalId());
  1180. if (!ObjectUtils.isEmpty(demand) && !demand.getProjectStatus().equals(PmProjectStatus.DEMAND_WAIT_FILL.getCode())) {
  1181. return AjaxResult.error("改需求已建档,不可进行撤销");
  1182. }
  1183. }
  1184. PlanYears years = new PlanYears();
  1185. BeanUtils.copyProperties(yearsStandardVo, years);
  1186. years.setAppDelete("true");
  1187. planYearsMapper.updateById(years);
  1188. return AjaxResult.success("申请成功");
  1189. }
  1190. @Override
  1191. public AjaxResult handleApp(PlanYearsStandardVo yearsStandardVo) {
  1192. //getProjectAttr传值1为同意。-1为拒绝
  1193. if ("1".equals(yearsStandardVo.getProjectAttr())) {
  1194. planYearsMapper.deletePlanYearsById(yearsStandardVo.getPlanYearId());
  1195. //年度计划撤销后季度计划也同步撤销
  1196. PlanQuarter byPlanYearId = planQuarterMapper.getByPlanYearId(yearsStandardVo.getPlanYearId());
  1197. if (!ObjectUtils.isEmpty(byPlanYearId)) {
  1198. planQuarterMapper.deletePlanQuarterById(byPlanYearId.getPlanPracticalId());
  1199. }
  1200. return AjaxResult.success("已成功进行撤销");
  1201. }
  1202. PlanYears years = new PlanYears();
  1203. BeanUtils.copyProperties(yearsStandardVo, years);
  1204. years.setAppDelete("false");
  1205. planYearsMapper.updateById(years);
  1206. return AjaxResult.success("已拒绝改申请");
  1207. }
  1208. @Override
  1209. public List<Integer> idNotInQuarter() {
  1210. return planYearsMapper.idNotInQuarter();
  1211. }
  1212. /**
  1213. * 根据年度计划提报时间的阈值进行提示
  1214. *
  1215. * @return
  1216. */
  1217. public String planYearsGetTips(PlanYearsResponseVo responseVo, HashMap<String, String> thresholdMap, HashMap<String, String> alertTimeMap) throws ParseException {
  1218. //提示信息:定义距离结束时间*天内提示
  1219. int alertDay = Integer.parseInt(alertTimeMap.get("计划提报时间"));
  1220. Integer remindTime = 1000 * 60 * 60 * 24 * alertDay;
  1221. //提报时间的结束时间阈值
  1222. SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd");
  1223. Date thresholdTime = dateFormat.parse(thresholdMap.get("起止时间结束"));
  1224. Date date = new Date();
  1225. thresholdTime.setYear(date.getYear());
  1226. double surplus = thresholdTime.getTime() - date.getTime();
  1227. //少于设定天数便提醒
  1228. if (surplus < remindTime && surplus > 0) {
  1229. //剩余天数(向上取整)
  1230. int i = new Double(Math.ceil(surplus / 1000 / 60 / 60 / 24)).intValue();
  1231. if (i > 0) {
  1232. return "距离计划提报时间不足" + i + "天";
  1233. }
  1234. }
  1235. //距离计划完成采购时间一周内提醒
  1236. Integer alertTime = 1000 * 60 * 60 * 24 * 7;
  1237. double surplusTwo = responseVo.getPlanPurchaseFinishTime().getTime() - System.currentTimeMillis();
  1238. //少于设定阈值便提醒
  1239. if (surplusTwo < alertTime && surplusTwo > 0) {
  1240. //剩余天数(向上取整)
  1241. int i = new Double(Math.ceil(surplusTwo / 1000 / 60 / 60 / 24)).intValue();
  1242. if (i > 0) {
  1243. return "距离计划完成采购时间不足" + i + "天";
  1244. }
  1245. }
  1246. return "";
  1247. }
  1248. }