1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006 |
- package com.ozs.pm.service.impl;
- import java.util.*;
- import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
- import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
- import com.baomidou.mybatisplus.core.metadata.IPage;
- import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
- import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
- import com.ozs.base.domain.BaseExpert;
- import com.ozs.base.service.BaseExpertService;
- import com.ozs.common.enums.*;
- import com.ozs.common.utils.DateUtils;
- import com.ozs.common.utils.RandomUtil;
- import com.ozs.common.utils.StringUtils;
- import com.ozs.common.utils.bean.BeanUtils;
- import com.ozs.pm.doman.*;
- import com.ozs.pm.doman.vo.requestVo.*;
- import com.ozs.pm.doman.vo.responseVo.*;
- import com.ozs.pm.mapper.PmDemandMapper;
- import com.ozs.pm.service.*;
- import com.ozs.system.domain.SysFileInfo;
- import com.ozs.system.domain.SysFileRef;
- import com.ozs.system.domain.vo.responseVo.SysDeptResponseVo;
- import com.ozs.system.service.ISysDeptService;
- import com.ozs.system.service.ISysDictDataService;
- import com.ozs.system.service.SysFileRefService;
- import com.ozs.system.service.SysFileService;
- import org.springframework.beans.factory.annotation.Autowired;
- import org.springframework.stereotype.Service;
- import org.springframework.transaction.annotation.Transactional;
- import org.springframework.util.CollectionUtils;
- import org.springframework.util.ObjectUtils;
- /**
- * 采购需求Service业务层处理
- *
- * @author ruoyi
- * @date 2023-01-16
- */
- @Service
- public class PmDemandServiceImpl extends ServiceImpl<PmDemandMapper, PmDemand> implements IPmDemandService {
- @Autowired
- private IPmDemandEquipService iPmDemandEquipService;
- @Autowired
- private IPmDemandMaterialsService iPmDemandMaterialsService;
- @Autowired
- private IPmDemandServeService iPmDemandServeService;
- @Autowired
- private IPmDemandEngineeringService iPmDemandEngineeringService;
- @Autowired
- private ISysDeptService deptService;
- @Autowired
- private ISysDictDataService dictDataService;
- @Autowired
- private SysFileService fileService;
- @Autowired
- private SysFileRefService sysFileRefService;
- @Autowired
- private IPmFlowChartService iPmFlowChartService;
- @Autowired
- private PmReleaseAnnouncementService pmReleaseAnnouncementService;
- @Autowired
- private BaseExpertService baseExpertService;
- @Autowired
- private PmDemandExpertRefService pmDemandExpertRefService;
- @Autowired
- private PmBidOpeningService pmBidOpeningService;
- @Autowired
- private PmBidWinningService pmBidWinningService;
- @Autowired
- private PmBidFailureService pmBidFailureService;
- /**
- * 查询采购需求
- *
- * @param demandId 采购需求主键
- * @return 采购需求
- */
- @Override
- public PmDemandResVo selectPmDemandByDemandId(Long demandId,String detailType) {
- PmDemand pmDemand = this.getById(demandId);
- if(pmDemand != null){
- PmDemandResVo vo = new PmDemandResVo();
- vo.setDemandId(demandId);
- if("1".equals(detailType)) { //项目计划
- BeanUtils.copyProperties(pmDemand, vo);
- SysDeptResponseVo sysDeptResponseVo = (SysDeptResponseVo) deptService.selectDeptById(vo.getPurchaseDeptId()).get("sysDept");
- if(sysDeptResponseVo != null){
- vo.setPurchaseDeptName(sysDeptResponseVo.getDeptName());
- }
- String purchaseServicesName = dictDataService.selectDictLabel("purchase_services", vo.getPurchaseServices());
- if(StringUtils.isNotEmpty(purchaseServicesName)){
- vo.setPurchaseServicesName(purchaseServicesName);
- }
- //采购需求附件
- HashMap<String, String> demandFileMap = getFileMap(vo.getDemandId(),SysFileRefEnum.PM_DEMAND.getType());
- if(demandFileMap != null){
- vo.setDemandFileMap(demandFileMap);
- }
- //项目类型
- for (ProjectTypes value : ProjectTypes.values()) {
- if (vo.getProjectType() != null && vo.getProjectType().equals(value.getCode())) {
- vo.setProjectTypeName(value.getInfo());
- break;
- }
- }
- //是否为超限额计划
- for (IsExcess value : IsExcess.values()) {
- if (vo.getIsExcess() != null && vo.getIsExcess().equals(value.getCode())) {
- vo.setIsExcessName(value.getInfo());
- break;
- }
- }
- //采购方式
- for (PlanPurchaseMode value : PlanPurchaseMode.values()) {
- if (vo.getPurchaseMode() != null && vo.getPurchaseMode().equals(value.getCode())) {
- vo.setPurchaseModeName(value.getInfo());
- break;
- }
- }
- //项目属性
- for (ProjectAttribute value : ProjectAttribute.values()) {
- if (vo.getProjectAttr() != null && vo.getProjectAttr().equals(value.getCode())) {
- vo.setProjectAttrName(value.getInfo());
- break;
- }
- }
- //预警状态
- for (WarnStatus value : WarnStatus.values()) {
- if (vo.getWarnStatus() != null && vo.getWarnStatus().equals(value.getCode())) {
- vo.setWarnStatusName(value.getInfo());
- break;
- }
- }
- //项目状态
- for (PmProjectStatus value : PmProjectStatus.values()) {
- if (vo.getProjectStatus() != null && vo.getProjectStatus().equals(value.getCode())) {
- vo.setProjectStatusName(value.getInfo());
- break;
- }
- }
- } else if("2".equals(detailType)) { //需求建档
- //采购需求审核文件
- HashMap<String, String> auditFileMap = getFileMap(vo.getDemandId(),SysFileRefEnum.PM_DEMAND_EXAMINE.getType());
- if(auditFileMap != null){
- vo.setAuditFileMap(auditFileMap);
- }
- if(ProjectTypes.EQUIPMENTTYPE.getCode().equals(pmDemand.getProjectType())){//装备类
- LambdaQueryWrapper<PmDemandEquip> lambdaQueryWrapper = new LambdaQueryWrapper<>();
- lambdaQueryWrapper.eq(PmDemandEquip::getDemandId,demandId);
- PmDemandEquip pmDemandEquip = iPmDemandEquipService.getOne(lambdaQueryWrapper);
- if(pmDemandEquip != null){
- PmDemandEquipResVo responseVo = new PmDemandEquipResVo();
- BeanUtils.copyProperties(pmDemandEquip,responseVo);
- //采购方式建议
- for (ProcurementMethodSuggest value : ProcurementMethodSuggest.values()) {
- if (responseVo.getProcurementMethodSuggest() != null && responseVo.getProcurementMethodSuggest().equals(value.getCode())) {
- responseVo.setProcurementMethodSuggestName(value.getInfo());
- break;
- }
- }
- HashMap<String, String> fileMap1 = getFileMap(demandId,SysFileRefEnum.PM_DEMAND_EQUIP.getType());
- if(fileMap1 != null){
- responseVo.setFileMap(fileMap1);
- }
- vo.setPmDemandEquipResVo(responseVo);
- }
- } else if(ProjectTypes.MATERIALTYPE.getCode().equals(pmDemand.getProjectType())){ //物资类
- LambdaQueryWrapper<PmDemandMaterials> lambdaQueryWrapper = new LambdaQueryWrapper<>();
- lambdaQueryWrapper.eq(PmDemandMaterials::getDemandId,demandId);
- PmDemandMaterials pmDemandMaterials = iPmDemandMaterialsService.getOne(lambdaQueryWrapper);
- if(pmDemandMaterials != null){
- PmDemandMaterialsResVo responseVo = new PmDemandMaterialsResVo();
- BeanUtils.copyProperties(pmDemandMaterials,responseVo);
- //采购方式建议
- for (ProcurementMethodSuggest value : ProcurementMethodSuggest.values()) {
- if (responseVo.getProcurementMethodSuggest() != null && responseVo.getProcurementMethodSuggest().equals(value.getCode())) {
- responseVo.setProcurementMethodSuggestName(value.getInfo());
- break;
- }
- }
- HashMap<String, String> fileMap2 = getFileMap(demandId,SysFileRefEnum.PM_DEMAND_MATERIALS.getType());
- if(fileMap2 != null){
- responseVo.setFileMap(fileMap2);
- }
- vo.setPmDemandMaterialsResVo(responseVo);
- }
- } else if(ProjectTypes.SERVICESTYPE.getCode().equals(pmDemand.getProjectType())){//服务类
- LambdaQueryWrapper<PmDemandServe> lambdaQueryWrapper = new LambdaQueryWrapper<>();
- lambdaQueryWrapper.eq(PmDemandServe::getDemandId,demandId);
- PmDemandServe pmDemandServe = iPmDemandServeService.getOne(lambdaQueryWrapper);
- if(pmDemandServe != null){
- PmDemandServeResVo responseVo = new PmDemandServeResVo();
- BeanUtils.copyProperties(pmDemandServe,responseVo);
- //采购方式建议
- for (ProcurementMethodSuggest value : ProcurementMethodSuggest.values()) {
- if (responseVo.getProcurementMethodSuggest() != null && responseVo.getProcurementMethodSuggest().equals(value.getCode())) {
- responseVo.setProcurementMethodSuggestName(value.getInfo());
- break;
- }
- }
- HashMap<String, String> fileMap3 = getFileMap(demandId,SysFileRefEnum.PM_DEMAND_SERVE.getType());
- if(fileMap3 != null){
- responseVo.setFileMap(fileMap3);
- }
- vo.setPmDemandServeResVo(responseVo);
- }
- } else if(ProjectTypes.PLANTOEXAMINETYPE.getCode().equals(pmDemand.getProjectType())){//工程类
- LambdaQueryWrapper<PmDemandEngineering> lambdaQueryWrapper = new LambdaQueryWrapper<>();
- lambdaQueryWrapper.eq(PmDemandEngineering::getDemandId,demandId);
- PmDemandEngineering pmDemandEngineering = iPmDemandEngineeringService.getOne(lambdaQueryWrapper);
- if(pmDemandEngineering != null){
- PmDemandEngineeringResVo responseVo = new PmDemandEngineeringResVo();
- BeanUtils.copyProperties(pmDemandEngineering,responseVo);
- //采购方式建议
- for (ProcurementMethodSuggest value : ProcurementMethodSuggest.values()) {
- if (responseVo.getProcurementMethodSuggest() != null && responseVo.getProcurementMethodSuggest().equals(value.getCode())) {
- responseVo.setProcurementMethodSuggestName(value.getInfo());
- break;
- }
- }
- //项目类别
- for (EngineeringProjectCategory value : EngineeringProjectCategory.values()) {
- if (responseVo.getProjectCategory() != null && responseVo.getProjectCategory().equals(value.getCode())) {
- responseVo.setProjectCategoryName(value.getInfo());
- break;
- }
- }
- //承包方式
- for (EngineeringContractingMode value : EngineeringContractingMode.values()) {
- if (responseVo.getContractingMode() != null && responseVo.getContractingMode().equals(value.getCode())) {
- responseVo.setContractingModeName(value.getInfo());
- break;
- }
- }
- //施工图是否完成
- for (ConstructionDrawing value : ConstructionDrawing.values()) {
- if (responseVo.getConstructionDrawing() != null && responseVo.getConstructionDrawing().equals(value.getCode())) {
- responseVo.setConstructionDrawingName(value.getInfo());
- break;
- }
- }
- HashMap<String, String> fileMap4 = getFileMap(demandId,SysFileRefEnum.PM_DEMAND_ENGINEERING.getType());
- if(fileMap4 != null){
- responseVo.setFileMap(fileMap4);
- }
- vo.setPmDemandEngineeringResVo(responseVo);
- }
- }
- } else if("3".equals(detailType)) { //任务下达
- //任务下达文件
- HashMap<String, String> taskReleaseFileMap = getFileMap(vo.getDemandId(),SysFileRefEnum.PM_TAST_RELEASE.getType());
- if(taskReleaseFileMap != null){
- vo.setTaskReleaseFileMap(taskReleaseFileMap);
- }
- } else if("4".equals(detailType)) { //中标信息
- } else if("5".equals(detailType)) { //合同信息
- } else if("6".equals(detailType)) { //建设情况
- }
- return vo;
- } else {
- return null;
- }
- }
- /**
- * 查询采购需求列表
- *
- * @param pmDemandReqVo
- * @return 采购需求
- */
- @Override
- public IPage<PmDemandResVo> selectPmDemandList(PmDemandReqVo pmDemandReqVo, int reqType) {
- LambdaQueryWrapper<PmDemand> lw = new LambdaQueryWrapper<>();
- if (!StringUtils.isBlank(pmDemandReqVo.getProjectName())) {
- lw.like(PmDemand::getProjectName, "%" + pmDemandReqVo.getProjectName() + "%");
- }
- if (!StringUtils.isBlank(pmDemandReqVo.getPurchaseServices())) {
- lw.eq(PmDemand::getPurchaseServices, pmDemandReqVo.getPurchaseServices());
- }
- if (pmDemandReqVo.getProjectStatus() != null) {
- lw.eq(PmDemand::getProjectStatus, pmDemandReqVo.getProjectStatus());
- }
- if (pmDemandReqVo.getIsExcess() != null) {
- lw.eq(PmDemand::getIsExcess, pmDemandReqVo.getIsExcess());
- }
- if (!StringUtils.isBlank(pmDemandReqVo.getBeginDate())) {
- lw.apply("(plan_demand_sub_time >= '" + pmDemandReqVo.getBeginDate() +"' or plan_purchase_finish_time >= '" + pmDemandReqVo.getBeginDate() + "' or plan_deliver_time >= '" + pmDemandReqVo.getBeginDate() +"' )");
- }
- if (!StringUtils.isBlank(pmDemandReqVo.getEndDate())) {
- lw.apply("(plan_demand_sub_time <= '" + pmDemandReqVo.getEndDate() +"' or plan_purchase_finish_time <= '" + pmDemandReqVo.getEndDate() + "' or plan_deliver_time <= '" + pmDemandReqVo.getEndDate() +"' )");
- }
- if(reqType== 1) { //需求审核单位列表
- lw.eq(PmDemand::getProjectStatus, PmProjectStatus.DEMAND_WAIT_AUDIT.getCode());
- } else if(reqType== 2) { //任务下达列表
- lw.apply("(project_status = 8 or project_status = 9 )");
- } else if(reqType== 3) { //采购执行列表
- lw.apply("(project_status = 9 or project_status = 10 )");
- } else if(reqType== 4) { //合同信息列表
- lw.apply("(project_status = 10 or project_status = 11 )");
- } else if(reqType== 5) { //项目建设列表
- lw.apply("(project_status = 11 or project_status = 12 )");
- }
- IPage<PmDemand> pageRes = this.page(new Page<>(pmDemandReqVo.getPageNum(), pmDemandReqVo.getPageSize()), lw);
- IPage<PmDemandResVo> results = new Page<>(pageRes.getCurrent(), pageRes.getSize(), pageRes.getTotal());
- if(pageRes.getRecords() != null && pageRes.getRecords().size() > 0){
- List<PmDemandResVo> pmDemandResponseVoList = new ArrayList<>();
- for(PmDemand pmDemand1 : pageRes.getRecords()){
- PmDemandResVo vo = new PmDemandResVo();
- BeanUtils.copyProperties(pmDemand1,vo);
- if(vo.getPurchaseDeptId() != null){
- Map<String, Object> deptMap = deptService.selectDeptById(vo.getPurchaseDeptId());
- if(deptMap!= null){
- SysDeptResponseVo sysDeptResponseVo = (SysDeptResponseVo)deptMap.get("sysDept");
- if(sysDeptResponseVo != null){
- vo.setPurchaseDeptName(sysDeptResponseVo.getDeptName());
- }
- }
- }
- String purchaseServicesName = dictDataService.selectDictLabel("purchase_services",vo.getPurchaseServices());
- if(StringUtils.isNotEmpty(purchaseServicesName)){
- vo.setPurchaseServicesName(purchaseServicesName);
- }
- //项目类型
- for (ProjectTypes value : ProjectTypes.values()) {
- if (vo.getProjectType() != null && vo.getProjectType().equals(value.getCode())) {
- vo.setProjectTypeName(value.getInfo());
- break;
- }
- }
- //是否为超限额计划
- for (IsExcess value : IsExcess.values()) {
- if (vo.getIsExcess() != null && vo.getIsExcess().equals(value.getCode())) {
- vo.setIsExcessName(value.getInfo());
- break;
- }
- }
- //采购方式
- for (PlanPurchaseMode value : PlanPurchaseMode.values()) {
- if (vo.getPurchaseMode() != null && vo.getPurchaseMode().equals(value.getCode())) {
- vo.setPurchaseModeName(value.getInfo());
- break;
- }
- }
- //项目属性
- for (ProjectAttribute value : ProjectAttribute.values()) {
- if (vo.getProjectAttr() != null && vo.getProjectAttr().equals(value.getCode())) {
- vo.setProjectAttrName(value.getInfo());
- break;
- }
- }
- //预警状态
- for (WarnStatus value : WarnStatus.values()) {
- if (vo.getWarnStatus() != null && vo.getWarnStatus().equals(value.getCode())) {
- vo.setWarnStatusName(value.getInfo());
- break;
- }
- }
- //项目状态
- for (PmProjectStatus value : PmProjectStatus.values()) {
- if (vo.getProjectStatus() != null && vo.getProjectStatus().equals(value.getCode())) {
- vo.setProjectStatusName(value.getInfo());
- break;
- }
- }
- pmDemandResponseVoList.add(vo);
- }
- results.setRecords(pmDemandResponseVoList);
- }
- return results;
- }
- /**
- * 需求建档
- *
- * @param vo 采购需求
- * @return 结果
- */
- @Override
- public boolean bookBuilding(PmBookBuildingReqVo vo) {
- PmDemand pmDemand = this.getById(vo.getDemandId());
- String projectType = pmDemand.getProjectType();
- if(ProjectTypes.EQUIPMENTTYPE.getCode().equals(projectType)){ //装备类
- PmDemandEquipReqVo pmDemandEquipReqVo = vo.getPmDemandEquipReqVo();
- LambdaQueryWrapper<PmDemandEquip> lambdaQueryWrapper = new LambdaQueryWrapper<>();
- lambdaQueryWrapper.eq(PmDemandEquip::getDemandId,vo.getDemandId());
- PmDemandEquip pmDemandEquip = iPmDemandEquipService.getOne(lambdaQueryWrapper);
- if(pmDemandEquip != null){
- pmDemandEquipReqVo.setDemandEquipId(pmDemandEquip.getDemandEquipId());
- BeanUtils.copyProperties(pmDemandEquipReqVo,pmDemandEquip);
- pmDemandEquip.setUpdateBy(vo.getUpdateBy());
- pmDemandEquip.setUpdateTime(new Date());
- iPmDemandEquipService.updateById(pmDemandEquip);
- } else {
- pmDemandEquip = new PmDemandEquip();
- BeanUtils.copyProperties(pmDemandEquipReqVo,pmDemandEquip);
- pmDemandEquip.setCreateBy(vo.getUpdateBy());
- pmDemandEquip.setCreateTime(new Date());
- pmDemandEquip.setUpdateBy(vo.getUpdateBy());
- pmDemandEquip.setUpdateTime(pmDemandEquip.getCreateTime());
- iPmDemandEquipService.save(pmDemandEquip);
- }
- List<SysFileRef> sysFileRefs = pmDemandEquipReqVo.getSysFileRefs();
- uploadFile(pmDemandEquip.getDemandEquipId(),SysFileRefEnum.PM_DEMAND_EQUIP.getType(),sysFileRefs,vo.getUpdateBy());
- } else if(ProjectTypes.MATERIALTYPE.getCode().equals(projectType)) { //物资类
- PmDemandMaterialsReqVo pmDemandMaterialsReqVo = vo.getPmDemandMaterialsReqVo();
- LambdaQueryWrapper<PmDemandMaterials> lambdaQueryWrapper = new LambdaQueryWrapper<>();
- lambdaQueryWrapper.eq(PmDemandMaterials::getDemandId,vo.getDemandId());
- PmDemandMaterials pmDemandMaterials = iPmDemandMaterialsService.getOne(lambdaQueryWrapper);
- if(pmDemandMaterials != null){
- pmDemandMaterialsReqVo.setDemandMaterialsId(pmDemandMaterials.getDemandMaterialsId());
- BeanUtils.copyProperties(pmDemandMaterialsReqVo,pmDemandMaterials);
- pmDemandMaterials.setUpdateBy(vo.getUpdateBy());
- pmDemandMaterials.setUpdateTime(new Date());
- iPmDemandMaterialsService.updateById(pmDemandMaterials);
- } else {
- pmDemandMaterials = new PmDemandMaterials();
- BeanUtils.copyProperties(pmDemandMaterialsReqVo,pmDemandMaterials);
- pmDemandMaterials.setCreateBy(vo.getUpdateBy());
- pmDemandMaterials.setCreateTime(new Date());
- pmDemandMaterials.setUpdateBy(vo.getUpdateBy());
- pmDemandMaterials.setUpdateTime(pmDemandMaterials.getCreateTime());
- iPmDemandMaterialsService.save(pmDemandMaterials);
- }
- List<SysFileRef> sysFileRefs = pmDemandMaterialsReqVo.getSysFileRefs();
- uploadFile(pmDemandMaterials.getDemandMaterialsId(),SysFileRefEnum.PM_DEMAND_MATERIALS.getType(),sysFileRefs,vo.getUpdateBy());
- } else if(ProjectTypes.SERVICESTYPE.getCode().equals(projectType)) { //服务类
- PmDemandServeReqVo pmDemandServeReqVo = vo.getPmDemandServeReqVo();
- LambdaQueryWrapper<PmDemandServe> lambdaQueryWrapper = new LambdaQueryWrapper<>();
- lambdaQueryWrapper.eq(PmDemandServe::getDemandId,vo.getDemandId());
- PmDemandServe pmDemandServe = iPmDemandServeService.getOne(lambdaQueryWrapper);
- if(pmDemandServe != null){
- pmDemandServeReqVo.setDemandServeId(pmDemandServe.getDemandServeId());
- BeanUtils.copyProperties(pmDemandServeReqVo,pmDemandServe);
- pmDemandServe.setUpdateBy(vo.getUpdateBy());
- pmDemandServe.setUpdateTime(new Date());
- iPmDemandServeService.updateById(pmDemandServe);
- } else {
- pmDemandServe = new PmDemandServe();
- BeanUtils.copyProperties(pmDemandServeReqVo,pmDemandServe);
- pmDemandServe.setCreateBy(vo.getUpdateBy());
- pmDemandServe.setCreateTime(new Date());
- pmDemandServe.setUpdateBy(vo.getUpdateBy());
- pmDemandServe.setUpdateTime(pmDemandServe.getCreateTime());
- iPmDemandServeService.save(pmDemandServe);
- }
- List<SysFileRef> sysFileRefs = pmDemandServeReqVo.getSysFileRefs();
- uploadFile(pmDemandServe.getDemandServeId(),SysFileRefEnum.PM_DEMAND_SERVE.getType(),sysFileRefs,vo.getUpdateBy());
- } else if(ProjectTypes.PLANTOEXAMINETYPE.getCode().equals(projectType)) { //工程类
- PmDemandEngineeringReqVo pmDemandEngineeringReqVo = vo.getPmDemandEngineeringReqVo();
- LambdaQueryWrapper<PmDemandEngineering> lambdaQueryWrapper = new LambdaQueryWrapper<>();
- lambdaQueryWrapper.eq(PmDemandEngineering::getDemandId,vo.getDemandId());
- PmDemandEngineering pmDemandEngineering = iPmDemandEngineeringService.getOne(lambdaQueryWrapper);
- if(pmDemandEngineering != null){
- pmDemandEngineeringReqVo.setDemandEngineeringId(pmDemandEngineering.getDemandEngineeringId());
- BeanUtils.copyProperties(pmDemandEngineeringReqVo,pmDemandEngineering);
- pmDemandEngineering.setUpdateBy(vo.getUpdateBy());
- pmDemandEngineering.setUpdateTime(new Date());
- iPmDemandEngineeringService.updateById(pmDemandEngineering);
- } else {
- pmDemandEngineering = new PmDemandEngineering();
- BeanUtils.copyProperties(pmDemandEngineeringReqVo,pmDemandEngineering);
- pmDemandEngineering.setCreateBy(vo.getUpdateBy());
- pmDemandEngineering.setCreateTime(new Date());
- pmDemandEngineering.setUpdateBy(vo.getUpdateBy());
- pmDemandEngineering.setUpdateTime(pmDemandEngineering.getCreateTime());
- iPmDemandEngineeringService.save(pmDemandEngineering);
- }
- List<SysFileRef> sysFileRefs = pmDemandEngineeringReqVo.getSysFileRefs();
- uploadFile(pmDemandEngineering.getDemandEngineeringId(),SysFileRefEnum.PM_DEMAND_ENGINEERING.getType(),sysFileRefs,vo.getUpdateBy());
- }
- pmDemand.setUpdateBy(vo.getUpdateBy());
- pmDemand.setUpdateTime(DateUtils.getNowDate());
- return this.updateById(pmDemand);
- }
- private HashMap<String, String> getFileMap(Long redId,Integer type){
- HashMap<String, Object> map = new HashMap<>();
- map.put("red_id", redId);
- map.put("type", type);
- List<SysFileRef> fileRefs = sysFileRefService.listByMap(map);
- if (!ObjectUtils.isEmpty(fileRefs)) {
- HashMap<String, String> fileMap = new HashMap<>();
- for (SysFileRef ref : fileRefs) {
- SysFileInfo fileInfo = fileService.getById(ref.getFileId());
- fileMap.put(fileInfo.getFileUrl(), fileInfo.getFileName());
- }
- return fileMap;
- } else {
- return null;
- }
- }
- /**
- * 查看流程图
- *
- * @param demandId 采购需求主键
- * @return 采购需求
- */
- @Override
- public Object viewFlowChart(Long demandId) {
- PmDemand pmDemand = this.getById(demandId);
- String projectStatus = String.valueOf(pmDemand.getProjectStatus());
- String moduleName = null;
- if (PmProjectStatus.DEMAND_WAIT_FILL.getCode().equals(projectStatus) || PmProjectStatus.DEMAND_AUDIT_RETURN.getCode().equals(projectStatus)) {
- moduleName = "需求填制";
- } else if(PmProjectStatus.DEMAND_WAIT_COMMIT.getCode().equals(projectStatus)) {
- moduleName = "需求提交";
- } else if(PmProjectStatus.DEMAND_WAIT_AUDIT.getCode().equals(projectStatus)) {
- moduleName = "需求审核";
- } else if(PmProjectStatus.TASK_WAIT_RELEASE.getCode().equals(projectStatus)) {
- moduleName = "任务下达";
- } else if(PmProjectStatus.WAIT_SELECT_AGENT.getCode().equals(projectStatus)) {
- moduleName = "选取代理";
- } else if(PmProjectStatus.WAIT_UPLOAD_BID_FILE.getCode().equals(projectStatus)) {
- moduleName = "上传招标文件";
- } else if(PmProjectStatus.WAIT_ANNOUNCEMENT.getCode().equals(projectStatus)) {
- moduleName = "发布公告";
- } else if(PmProjectStatus.WAIT_OPEN_BID.getCode().equals(projectStatus)) {
- moduleName = "填写专家信息,填写开标信息";
- } else if(PmProjectStatus.WAIT_BID_ANNOUNCEMENT.getCode().equals(projectStatus)) {
- moduleName = "填写中标信息";
- } else if(PmProjectStatus.BIDDING_PUBLICITY.getCode().equals(projectStatus)) {
- moduleName = "质疑处理,上传中标通知书";
- } else if(PmProjectStatus.CONTRACT_WAIT_FILL.getCode().equals(projectStatus)) {
- moduleName = "合同填制";
- } else if(PmProjectStatus.UNDER_CONSTRUCTION.getCode().equals(projectStatus)) {
- moduleName = "建设文档填制";
- } else if(PmProjectStatus.COMPLETION_CONSTRUCTION.getCode().equals(projectStatus)) {
- moduleName = "项目归档";
- }
- return moduleName;
- }
- public PmFlowChartResVo getModuleInfo(Long demandId,String moduleName){
- PmDemand pmDemand = this.getById(demandId);
- String projectType = pmDemand.getProjectType();
- LambdaQueryWrapper<PmFlowChart> lambdaQueryWrapper = new LambdaQueryWrapper<>();
- lambdaQueryWrapper.eq(PmFlowChart::getModuleName,moduleName);
- PmFlowChart pmFlowChart = iPmFlowChartService.getOne(lambdaQueryWrapper);
- if(pmFlowChart == null){
- return null;
- }
- PmFlowChartResVo vo = new PmFlowChartResVo();
- BeanUtils.copyProperties(pmFlowChart, vo);
- if("需求填制".equals(moduleName)) {
- HashMap<String, String> fileMap = getFileMap(demandId,SysFileRefEnum.PM_DEMAND.getType());
- if(fileMap != null){
- vo.setFileMap(fileMap);
- }
- } else if("需求提交".equals(moduleName)) {
- if(ProjectTypes.EQUIPMENTTYPE.getCode().equals(projectType)){ //装备类
- LambdaQueryWrapper<PmDemandEquip> pmDemandEquipLambdaQueryWrapper = new LambdaQueryWrapper<>();
- pmDemandEquipLambdaQueryWrapper.eq(PmDemandEquip::getDemandId,demandId);
- PmDemandEquip pmDemandEquip = iPmDemandEquipService.getOne(pmDemandEquipLambdaQueryWrapper);
- if(pmDemandEquip != null){
- HashMap<String, String> fileMap = getFileMap(pmDemandEquip.getDemandEquipId(),SysFileRefEnum.PM_DEMAND_EQUIP.getType());
- if(fileMap != null){
- vo.setFileMap(fileMap);
- }
- }
- } else if(ProjectTypes.MATERIALTYPE.getCode().equals(projectType)) { //物资类
- LambdaQueryWrapper<PmDemandMaterials> pmDemandMaterialsLambdaQueryWrapper = new LambdaQueryWrapper<>();
- pmDemandMaterialsLambdaQueryWrapper.eq(PmDemandMaterials::getDemandId,demandId);
- PmDemandMaterials pmDemandMaterials = iPmDemandMaterialsService.getOne(pmDemandMaterialsLambdaQueryWrapper);
- if(pmDemandMaterials != null){
- HashMap<String, String> fileMap = getFileMap(pmDemandMaterials.getDemandMaterialsId(),SysFileRefEnum.PM_DEMAND_MATERIALS.getType());
- if(fileMap != null){
- vo.setFileMap(fileMap);
- }
- }
- } else if(ProjectTypes.SERVICESTYPE.getCode().equals(projectType)) { //服务类
- LambdaQueryWrapper<PmDemandServe> pmDemandServeLambdaQueryWrapper = new LambdaQueryWrapper<>();
- pmDemandServeLambdaQueryWrapper.eq(PmDemandServe::getDemandId,demandId);
- PmDemandServe pmDemandServe = iPmDemandServeService.getOne(pmDemandServeLambdaQueryWrapper);
- if(pmDemandServe != null){
- HashMap<String, String> fileMap = getFileMap(pmDemandServe.getDemandServeId(),SysFileRefEnum.PM_DEMAND_SERVE.getType());
- if(fileMap != null){
- vo.setFileMap(fileMap);
- }
- }
- } else if(ProjectTypes.PLANTOEXAMINETYPE.getCode().equals(projectType)) { //工程类
- LambdaQueryWrapper<PmDemandEngineering> pmDemandEngineeringLambdaQueryWrapper = new LambdaQueryWrapper<>();
- pmDemandEngineeringLambdaQueryWrapper.eq(PmDemandEngineering::getDemandId,demandId);
- PmDemandEngineering pmDemandEngineering = iPmDemandEngineeringService.getOne(pmDemandEngineeringLambdaQueryWrapper);
- if(pmDemandEngineering != null){
- HashMap<String, String> fileMap = getFileMap(pmDemandEngineering.getDemandEngineeringId(),SysFileRefEnum.PM_DEMAND_ENGINEERING.getType());
- if(fileMap != null){
- vo.setFileMap(fileMap);
- }
- }
- }
- } else if("需求审核".equals(moduleName)) {
- HashMap<String, String> fileMap = getFileMap(demandId,SysFileRefEnum.PM_DEMAND_EXAMINE.getType());
- if(fileMap != null){
- vo.setFileMap(fileMap);
- }
- } else if("任务下达".equals(moduleName)) {
- //todo
- }
- return vo;
- }
- /**
- * 提交采购需求
- *
- * @param pmDemandReqVo
- * @return 结果
- */
- @Override
- public boolean commit(PmDemandReqVo pmDemandReqVo) {
- PmDemand pmDemand = new PmDemand();
- pmDemand.setDemandId(pmDemandReqVo.getDemandId());
- pmDemand.setProjectStatus(Long.parseLong(PmProjectStatus.DEMAND_WAIT_AUDIT.getCode()));
- pmDemand.setUpdateBy(pmDemandReqVo.getUpdateBy());
- pmDemand.setUpdateTime(DateUtils.getNowDate());
- return this.updateById(pmDemand);
- }
- /**
- * 审核采购需求通过
- *
- * @param pmDemandReqVo
- * @return 结果
- */
- @Override
- public boolean reviewTo(PmDemandReqVo pmDemandReqVo) {
- PmDemand pmDemand = new PmDemand();
- pmDemand.setDemandId(pmDemandReqVo.getDemandId());
- pmDemand.setProjectStatus(Long.parseLong(PmProjectStatus.TASK_WAIT_RELEASE.getCode()));
- List<SysFileRef> sysFileRefs = pmDemandReqVo.getSysFileRefs();
- uploadFile(pmDemandReqVo.getDemandId(),SysFileRefEnum.PM_DEMAND_EXAMINE.getType(),sysFileRefs,pmDemandReqVo.getUpdateBy());
- pmDemand.setUpdateBy(pmDemandReqVo.getUpdateBy());
- pmDemand.setUpdateTime(DateUtils.getNowDate());
- pmDemand.setAuditTime(DateUtils.getNowDate());
- return this.updateById(pmDemand);
- }
- /**
- * 审核采购需求退回
- *
- * @param pmDemandReqVo
- * @return 结果
- */
- @Override
- public boolean reviewReturn(PmDemandReqVo pmDemandReqVo) {
- PmDemand pmDemand = new PmDemand();
- pmDemand.setDemandId(pmDemandReqVo.getDemandId());
- pmDemand.setProjectStatus(Long.parseLong(PmProjectStatus.DEMAND_WAIT_COMMIT.getCode()));
- pmDemand.setAdjustReason(pmDemandReqVo.getRefuseReason());
- pmDemand.setUpdateBy(pmDemandReqVo.getUpdateBy());
- pmDemand.setUpdateTime(DateUtils.getNowDate());
- pmDemand.setAuditTime(DateUtils.getNowDate());
- return this.updateById(pmDemand);
- }
- /**
- * 下达任务
- *
- * @param pmDemandReqVo
- * @return 结果
- */
- @Override
- public boolean releaseTask(PmDemandReqVo pmDemandReqVo) {
- PmDemand pmDemand = new PmDemand();
- pmDemand.setDemandId(pmDemandReqVo.getDemandId());
- pmDemand.setProjectStatus(Long.parseLong(PmProjectStatus.WAIT_SELECT_AGENT.getCode()));
- List<SysFileRef> sysFileRefs = pmDemandReqVo.getSysFileRefs();
- uploadFile(pmDemandReqVo.getDemandId(),SysFileRefEnum.PM_TAST_RELEASE.getType(),sysFileRefs,pmDemandReqVo.getUpdateBy());
- pmDemand.setUpdateBy(pmDemandReqVo.getUpdateBy());
- pmDemand.setUpdateTime(DateUtils.getNowDate());
- pmDemand.setAuditTime(DateUtils.getNowDate());
- return this.updateById(pmDemand);
- }
- public boolean uploadFile(Long redId,Integer fileType, List<SysFileRef> sysFileRefs,String upateBy){
- if (!ObjectUtils.isEmpty(sysFileRefs)) {
- for (SysFileRef ref : sysFileRefs) {
- if(ref.getFileId() == null){
- continue;
- }
- QueryWrapper<SysFileRef> queryWrapper = new QueryWrapper<>();
- queryWrapper.lambda().eq(SysFileRef::getFileId,ref.getFileId())
- .eq(SysFileRef::getRedId,redId)
- .eq(SysFileRef::getType,fileType);
- List<SysFileRef> sysFileRefList = sysFileRefService.list(queryWrapper);
- if(!CollectionUtils.isEmpty(sysFileRefList)){
- sysFileRefService.remove(queryWrapper);
- }
- ref.setRedId(redId);
- ref.setType(fileType);
- ref.setCreated(upateBy);
- ref.setCreateTime(new Date());
- ref.setUpdated(upateBy);
- ref.setUpdateTime(ref.getCreateTime());
- sysFileRefService.save(ref);
- }
- return true;
- } else {
- return false;
- }
- }
- public boolean insertPmReleaseAnnouncement(PmReleaseAnnouncementReqVo pmReleaseAnnouncementReqVo) throws Exception {
- PmReleaseAnnouncement pmReleaseAnnouncement = new PmReleaseAnnouncement();
- BeanUtils.copyProperties(pmReleaseAnnouncementReqVo,pmReleaseAnnouncement);
- if(pmReleaseAnnouncementService.save(pmReleaseAnnouncement)){
- if (uploadFile(pmReleaseAnnouncement.getId(), SysFileRefEnum.PM_ANNOUNCEMENT_FILE.getType(),pmReleaseAnnouncementReqVo.getSysFileRefs(),pmReleaseAnnouncementReqVo.getUpdateBy())) {
- PmDemand pmDemandUpdate = new PmDemand();
- pmDemandUpdate.setDemandId(pmReleaseAnnouncementReqVo.getDemandId());
- pmDemandUpdate.setProjectStatus(Long.parseLong(PmProjectStatus.WAIT_OPEN_BID.getCode()));
- pmDemandUpdate.setUpdateTime(pmReleaseAnnouncementReqVo.getUpdateTime());
- pmDemandUpdate.setUpdateBy(pmReleaseAnnouncementReqVo.getUpdateBy());
- return this.updateById(pmDemandUpdate);
- //TODO 发布公告生成后,会默认将该数据同步到公告管理和首页中
- } else {
- return false;
- }
- } else {
- return false;
- }
- }
- @Transactional(rollbackFor = Exception.class)
- public boolean insertExpertBatch(PmBaseExpertFillReqVo pmBaseExpertFillReqVo) throws Exception {
- PmDemand pmDemand = this.getById(pmBaseExpertFillReqVo.getDemandId());
- if(ObjectUtils.isEmpty(pmDemand)){
- throw new Exception("参数错误");
- }
- List<BaseExpert> baseExpertList = pmBaseExpertFillReqVo.getBaseExpertList();
- List<PmDemandExpertRef> pmDemandExpertRefList = new ArrayList<>();
- Date now = new Date();
- for (BaseExpert baseExpert : baseExpertList) {
- if(baseExpert.getStatus().equals(NameListType.WHITE.getCode())){
- throw new Exception("该专家(身份证号:" +baseExpert.getIdNumber() + ")属于黑名单");
- }
- if(pmDemand.getProjectType().equals(baseExpert.getVarietyPurchase())){
- throw new Exception("该专家(身份证号:" +baseExpert.getIdNumber() + ")所属采购品种和项目类型不匹配");
- }
- if(ObjectUtils.isEmpty(baseExpert.getCreated())){
- baseExpert.setCreated(pmBaseExpertFillReqVo.getCreateBy());
- baseExpert.setCreateTime(now);
- }
- if(ObjectUtils.isEmpty(baseExpert.getUpdated())){
- baseExpert.setUpdated(pmBaseExpertFillReqVo.getUpdateBy());
- baseExpert.setUpdateTime(now);
- }
- PmDemandExpertRef pmDemandExpertRef = new PmDemandExpertRef();
- pmDemandExpertRef.setDemandId(pmDemand.getDemandId());
- pmDemandExpertRef.setExpertId(baseExpert.getId().longValue());
- pmDemandExpertRef.setCreateBy(pmBaseExpertFillReqVo.getCreateBy());
- pmDemandExpertRef.setAccessTime(DateUtils.parseDate(pmBaseExpertFillReqVo.getAccessTime()));
- pmDemandExpertRef.setCreateTime(now);
- pmDemandExpertRef.setUpdateBy(pmBaseExpertFillReqVo.getCreateBy());
- pmDemandExpertRef.setUpdateTime(pmDemandExpertRef.getCreateTime());
- pmDemandExpertRefList.add(pmDemandExpertRef);
- }
- if (baseExpertService.saveOrUpdateBatch(baseExpertList)){
- return pmDemandExpertRefService.saveBatch(pmDemandExpertRefList);
- } else {
- return false;
- }
- }
- public boolean extractExpertBatch(PmBaseExpertExtractReqVo pmBaseExpertExtractReqVo) throws Exception {
- Integer technicalExpertNumber = pmBaseExpertExtractReqVo.getTechnicalExpertNumber();
- if(technicalExpertNumber== null){
- technicalExpertNumber = 0;
- }
- Integer economicExpertNumber = pmBaseExpertExtractReqVo.getEconomicExpertNumber();
- if(economicExpertNumber == null){
- economicExpertNumber = 0;
- }
- Integer legalAffairsExpertNumber = pmBaseExpertExtractReqVo.getLegalAffairsExpertNumber();
- if(legalAffairsExpertNumber == null){
- legalAffairsExpertNumber = 0;
- }
- Integer spareExpertNumber = pmBaseExpertExtractReqVo.getSpareExpertNumber();
- if(spareExpertNumber == null){
- spareExpertNumber = 0;
- }
- String professional = pmBaseExpertExtractReqVo.getProfessional();
- if(spareExpertNumber > 0 && ObjectUtils.isEmpty(professional)){
- throw new Exception("抽取备用专家必须选择专家专业");
- }
- String localArea = pmBaseExpertExtractReqVo.getLocalArea();
- if(spareExpertNumber > 0 && ObjectUtils.isEmpty(localArea)){
- throw new Exception("抽取备用专家必须选择所在区域");
- }
- PmDemand pmDemand = this.getById(pmBaseExpertExtractReqVo.getDemandId());
- if(ObjectUtils.isEmpty(pmDemand)){
- throw new Exception("参数错误");
- }
- LambdaQueryWrapper<BaseExpert> lw = new LambdaQueryWrapper<BaseExpert>();
- lw.eq(BaseExpert::getVarietyPurchase,pmDemand.getProjectType())
- .eq(BaseExpert::getStatus,NameListType.WHITE.getCode());
- List<BaseExpert> baseExpertList = baseExpertService.list(lw);
- if(ObjectUtils.isEmpty(baseExpertList)){
- throw new Exception("没抽取到符合条件的专家");
- }
- List<BaseExpert> technicalExpertList = new ArrayList<>();
- List<BaseExpert> economicExpertList = new ArrayList<>();
- List<BaseExpert> legalAffairsExpertList = new ArrayList<>();
- List<BaseExpert> spareExpertList = new ArrayList<>();
- for(BaseExpert baseExpert : baseExpertList){
- if(technicalExpertNumber > 0) {
- if(ExpertType.TECHNICAL_EXPERT.getCode().equals(baseExpert.getExpertType())){
- technicalExpertList.add(baseExpert);
- }
- }
- if(economicExpertNumber > 0) {
- if(ExpertType.ECONOMIC_EXPERT.getCode().equals(baseExpert.getExpertType())){
- economicExpertList.add(baseExpert);
- }
- }
- if (legalAffairsExpertNumber > 0) {
- if(ExpertType.LEGALAFFAIRS_EXPERT.getCode().equals(baseExpert.getExpertType())){
- legalAffairsExpertList.add(baseExpert);
- }
- }
- if (spareExpertNumber > 0) {
- String[] arr = professional.split(",");
- List<String> professionalList = Arrays.asList(arr);
- String majorType = baseExpert.getMajorType();
- //TODO 所在区域判读
- if(!ObjectUtils.isEmpty(majorType)){
- if(professionalList.contains(majorType)){
- spareExpertList.add(baseExpert);
- }
- }
- }
- }
- List<BaseExpert> alltExpertList = new ArrayList<>();
- if(!ObjectUtils.isEmpty(technicalExpertList)){
- alltExpertList.addAll(RandomUtil.getRandomList(technicalExpertList,technicalExpertNumber));
- }
- if(!ObjectUtils.isEmpty(economicExpertList)){
- alltExpertList.addAll(RandomUtil.getRandomList(economicExpertList,economicExpertNumber));
- }
- if(!ObjectUtils.isEmpty(legalAffairsExpertList)){
- alltExpertList.addAll(RandomUtil.getRandomList(legalAffairsExpertList,legalAffairsExpertNumber));
- }
- if(!ObjectUtils.isEmpty(spareExpertList)){
- alltExpertList.addAll(RandomUtil.getRandomList(spareExpertList,spareExpertNumber));
- }
- if(ObjectUtils.isEmpty(alltExpertList)){
- throw new Exception("没抽取到符合条件的专家");
- } else {
- List<PmDemandExpertRef> pmDemandExpertRefList = new ArrayList<>();
- for(BaseExpert baseExpert :alltExpertList ) {
- PmDemandExpertRef pmDemandExpertRef = new PmDemandExpertRef();
- pmDemandExpertRef.setDemandId(pmDemand.getDemandId());
- pmDemandExpertRef.setExpertId(baseExpert.getId().longValue());
- pmDemandExpertRef.setCreateBy(pmBaseExpertExtractReqVo.getCreateBy());
- pmDemandExpertRef.setAccessTime(DateUtils.parseDate(pmBaseExpertExtractReqVo.getAccessTime()));
- pmDemandExpertRef.setCreateTime(new Date());
- pmDemandExpertRef.setUpdateBy(pmBaseExpertExtractReqVo.getCreateBy());
- pmDemandExpertRef.setUpdateTime(pmDemandExpertRef.getCreateTime());
- pmDemandExpertRefList.add(pmDemandExpertRef);
- }
- return pmDemandExpertRefService.saveBatch(pmDemandExpertRefList);
- }
- }
- @Transactional(rollbackFor = Exception.class)
- public boolean insertBidOpeningBatch(PmBidOpeningFillReqVo pmBidOpeningFillReqVo) throws Exception {
- PmDemand pmDemand = this.getById(pmBidOpeningFillReqVo.getDemandId());
- if(ObjectUtils.isEmpty(pmDemand)){
- throw new Exception("参数错误");
- }
- Date now = new Date();
- List<PmBidOpening> pmBidOpeningList = pmBidOpeningFillReqVo.getPmBidOpeningList();
- for (PmBidOpening pmBidOpening : pmBidOpeningList) {
- if(ObjectUtils.isEmpty(pmBidOpening.getBidderName())){
- throw new Exception("投标人名称不能为空");
- }
- if(ObjectUtils.isEmpty(pmBidOpening.getScore())){
- throw new Exception("分数不能为空");
- }
- pmBidOpening.setDemandId(pmBidOpeningFillReqVo.getDemandId());
- pmBidOpening.setOpenBidTime(now); //TODO
- pmBidOpening.setCreateBy(pmBidOpeningFillReqVo.getCreateBy());
- pmBidOpening.setCreateTime(now);
- pmBidOpening.setUpdateBy(pmBidOpeningFillReqVo.getUpdateBy());
- pmBidOpening.setUpdateTime(now);
- }
- if(pmBidOpeningService.saveBatch(pmBidOpeningList)) {
- PmDemand pmDemandUpdate = new PmDemand();
- pmDemandUpdate.setDemandId(pmDemand.getDemandId());
- pmDemandUpdate.setProjectStatus(Long.parseLong(PmProjectStatus.WAIT_BID_ANNOUNCEMENT.getCode()));
- pmDemandUpdate.setUpdateTime(now);
- pmDemandUpdate.setUpdateBy(pmBidOpeningFillReqVo.getUpdateBy());
- return this.updateById(pmDemandUpdate);
- } else {
- return false;
- }
- }
- public boolean insertPmBidWinning(PmBidWinningReqVo pmBidWinningReqVo) throws Exception {
- uploadFile(pmBidWinningReqVo.getId(), SysFileRefEnum.PM_BID_WINNING_FILE.getType(),pmBidWinningReqVo.getSysFileRefs(),pmBidWinningReqVo.getUpdateBy());
- PmBidWinning pmBidWinning = new PmBidWinning();
- BeanUtils.copyProperties(pmBidWinningReqVo,pmBidWinning);
- if(pmBidWinningService.save(pmBidWinning)){
- if(uploadFile(pmBidWinning.getId(), SysFileRefEnum.PM_BID_WINNING_FILE.getType(),pmBidWinningReqVo.getSysFileRefs(),pmBidWinningReqVo.getUpdateBy())) {
- PmDemand pmDemandUpdate = new PmDemand();
- pmDemandUpdate.setDemandId(pmBidWinningReqVo.getDemandId());
- pmDemandUpdate.setProjectStatus(Long.parseLong(PmProjectStatus.BIDDING_PUBLICITY.getCode()));
- pmDemandUpdate.setUpdateTime(pmBidWinningReqVo.getUpdateTime());
- pmDemandUpdate.setUpdateBy(pmBidWinningReqVo.getUpdateBy());
- return this.updateById(pmDemandUpdate);
- } else {
- return false;
- }
- } else {
- return false;
- }
- }
- public boolean insertPmBidFailure(PmBidFailureReqVo pmBidFailureReqVo) throws Exception {
- PmBidFailure pmBidFailure = new PmBidFailure();
- BeanUtils.copyProperties(pmBidFailureReqVo,pmBidFailure);
- if(pmBidFailureService.save(pmBidFailure)){
- return uploadFile(pmBidFailure.getId(), SysFileRefEnum.PM_BID_FAILURE_FILE.getType(),pmBidFailureReqVo.getSysFileRefs(),pmBidFailureReqVo.getUpdateBy());
- } else {
- return false;
- }
- }
- }
|