PlanYearsServiceImpl.java 71 KB

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