PlanYearsServiceImpl.java 70 KB

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