1.0.49 合同、项目逻辑优化。合同订单后端接口

dev
yinq 6 days ago
parent 4d6056b2ff
commit 1ddb949da3

@ -82,13 +82,10 @@ public class TemplateVariableAssignServiceImpl implements ITemplateVariableAssig
Map<String, BaseTemplateVariableVo> variableMap = buildVariableMap(allTemplateVariables);
// 2. 查询合同信息
ErpContractInfoBo bo = new ErpContractInfoBo();
bo.setContractId(request.getContractId());
List<ErpContractInfoVo> contractInfoVoList = erpContractInfoService.queryList(bo);
if (contractInfoVoList.isEmpty()) {
ErpContractInfoVo contractInfo = erpContractInfoService.queryById(request.getContractId());
if (StringUtils.isNull(contractInfo)) {
throw new ServiceException("合同信息不存在合同ID" + request.getContractId());
}
ErpContractInfoVo contractInfo = contractInfoVoList.get(0);
// 3. 查询合同物料列表(如果存在需要物料数据的变量)
List<ErpContractMaterialVo> contractMaterials = null;

@ -0,0 +1,79 @@
package org.dromara.oa.erp.controller;
import cn.dev33.satoken.annotation.SaCheckPermission;
import jakarta.validation.constraints.NotNull;
import lombok.RequiredArgsConstructor;
import org.dromara.common.core.domain.R;
import org.dromara.common.core.validate.AddGroup;
import org.dromara.common.core.validate.EditGroup;
import org.dromara.common.idempotent.annotation.RepeatSubmit;
import org.dromara.common.log.annotation.Log;
import org.dromara.common.log.enums.BusinessType;
import org.dromara.common.web.core.BaseController;
import org.dromara.oa.erp.domain.bo.ErpProjectInfoBo;
import org.dromara.oa.erp.domain.vo.ErpProjectInfoVo;
import org.dromara.oa.erp.service.IErpContractOrderService;
import org.springframework.validation.annotation.Validated;
import org.springframework.web.bind.annotation.*;
/**
*
* 访:/oa/erp/contractOrder
*
* @author Yinq
* @date 2025-12-05
*/
@Validated
@RequiredArgsConstructor
@RestController
@RequestMapping("/erp/contractOrder")
public class ErpContractOrderController extends BaseController {
private final IErpContractOrderService erpContractOrderService;
/**
*
*/
@SaCheckPermission("oa/erp:projectInfo:add")
@Log(title = "合同订单", businessType = BusinessType.INSERT)
@RepeatSubmit()
@PostMapping("/save")
public R<ErpProjectInfoVo> save(@Validated(AddGroup.class) @RequestBody ErpProjectInfoBo bo) {
return R.ok(erpContractOrderService.saveContractOrder(bo));
}
/**
*
*/
@SaCheckPermission("oa/erp:projectInfo:add")
@Log(title = "合同订单", businessType = BusinessType.INSERT)
@RepeatSubmit()
@PostMapping("/submitAndFlowStart")
public R<ErpProjectInfoVo> submitAndFlowStart(@Validated(AddGroup.class) @RequestBody ErpProjectInfoBo bo) {
return R.ok(erpContractOrderService.submitContractOrderAndFlowStart(bo));
}
/**
*
*/
@SaCheckPermission("oa/erp:projectInfo:edit")
@Log(title = "合同订单", businessType = BusinessType.UPDATE)
@RepeatSubmit()
@PutMapping()
public R<ErpProjectInfoVo> edit(@Validated(EditGroup.class) @RequestBody ErpProjectInfoBo bo) {
return R.ok(erpContractOrderService.updateContractOrder(bo));
}
/**
*
*
* @param projectId
*/
@SaCheckPermission("oa/erp:projectInfo:query")
@GetMapping("/{projectId}")
public R<ErpProjectInfoVo> getInfo(@NotNull(message = "主键不能为空")
@PathVariable("projectId") Long projectId) {
return R.ok(erpContractOrderService.queryById(projectId));
}
}

@ -4,7 +4,8 @@ import org.dromara.common.tenant.core.TenantEntity;
import com.baomidou.mybatisplus.annotation.*;
import lombok.Data;
import lombok.EqualsAndHashCode;
import java.math.BigDecimal;
import java.util.Date;
import com.fasterxml.jackson.annotation.JsonFormat;
import java.io.Serial;
@ -49,9 +50,44 @@ public class ErpContractPaymentStage extends TenantEntity {
private String collectionStage;
/**
* %
* (%)
*/
private BigDecimal purchasePrice;
private Long repaymentRate;
/**
*
*/
private Date expectRepaymentDate;
/**
*
*/
private Long delayDay;
/**
*
*/
private Date actualRepaymentDate;
/**
* 0 1
*/
private String repaymentFlag;
/**
*
*/
private String reasonsExplanation;
/**
*
*/
private String scheduleRemark;
/**
*
*/
private Long repaymentAmount;
/**
*

@ -49,7 +49,7 @@ public class ErpProjectInfo extends TenantEntity {
private String businessDirection;
/**
* 1 2 3 4
* 1 2 3 4 5
*/
private String projectCategory;

@ -8,7 +8,8 @@ import io.github.linpeilie.annotations.AutoMapper;
import lombok.Data;
import lombok.EqualsAndHashCode;
import jakarta.validation.constraints.*;
import java.math.BigDecimal;
import java.util.Date;
import com.fasterxml.jackson.annotation.JsonFormat;
/**
* erp_contract_payment_stage
@ -46,13 +47,47 @@ public class ErpContractPaymentStageBo extends BaseEntity {
/**
*
*/
@NotBlank(message = "回款阶段不能为空", groups = { AddGroup.class, EditGroup.class })
private String collectionStage;
/**
* %
* (%)
*/
private BigDecimal purchasePrice;
private Long repaymentRate;
/**
*
*/
private Date expectRepaymentDate;
/**
*
*/
private Long delayDay;
/**
*
*/
private Date actualRepaymentDate;
/**
* 0 1
*/
private String repaymentFlag;
/**
*
*/
private String reasonsExplanation;
/**
*
*/
private String scheduleRemark;
/**
*
*/
private Long repaymentAmount;
/**
*

@ -12,6 +12,7 @@ import java.math.BigDecimal;
import java.util.*;
import cn.hutool.core.util.ObjectUtil;
import org.dromara.workflow.api.domain.RemoteFlowInstanceBizExt;
import org.dromara.oa.erp.domain.bo.ErpProjectPlanStageBo;
/**
* erp_project_info
@ -38,7 +39,7 @@ public class ErpProjectInfoBo extends BaseEntity {
/**
*
*/
@NotBlank(message = "项目编号不能为空", groups = { AddGroup.class, EditGroup.class })
// @NotBlank(message = "项目编号不能为空", groups = { AddGroup.class, EditGroup.class })
private String projectCode;
/**
@ -53,9 +54,9 @@ public class ErpProjectInfoBo extends BaseEntity {
private String businessDirection;
/**
* 1 2 3 4
* 1 2 3 4 5
*/
@NotBlank(message = "项目类别1销售实施、物流 2销售备件 3研发 4预投不能为空", groups = { AddGroup.class, EditGroup.class })
@NotBlank(message = "项目类别", groups = { AddGroup.class, EditGroup.class })
private String projectCategory;
/**
@ -158,6 +159,11 @@ public class ErpProjectInfoBo extends BaseEntity {
*/
private RemoteFlowInstanceBizExt bizExt;
/**
*
*/
private List<ErpProjectPlanStageBo> planStageList;
public Map<String, Object> getVariables() {
if (variables == null) {
return new HashMap<>(16);

@ -41,6 +41,11 @@ public class ErpProjectPurchaseBo extends BaseEntity {
@NotBlank(message = "项目号不能为空", groups = { AddGroup.class, EditGroup.class })
private String projectCode;
/**
*
*/
private String projectName;
/**
*
*/
@ -51,6 +56,11 @@ public class ErpProjectPurchaseBo extends BaseEntity {
*/
private Long managerId;
/**
*
*/
private String managerName;
/**
*
*/

@ -1,6 +1,7 @@
package org.dromara.oa.erp.domain.vo;
import java.math.BigDecimal;
import java.util.Date;
import com.fasterxml.jackson.annotation.JsonFormat;
import org.dromara.oa.erp.domain.ErpContractPaymentStage;
import cn.idev.excel.annotation.ExcelIgnoreUnannotated;
import cn.idev.excel.annotation.ExcelProperty;
@ -56,15 +57,59 @@ public class ErpContractPaymentStageVo implements Serializable {
/**
*
*/
@ExcelProperty(value = "回款阶段")
@ExcelProperty(value = "回款阶段", converter = ExcelDictConvert.class)
@ExcelDictFormat(dictType = "collection_stage")
private String collectionStage;
/**
* %
* (%)
*/
@ExcelProperty(value = "回款比例", converter = ExcelDictConvert.class)
@ExcelDictFormat(readConverterExp = "%=")
private BigDecimal purchasePrice;
@ExcelProperty(value = "回款比例(%)")
private Long repaymentRate;
/**
*
*/
@ExcelProperty(value = "预计回款日期")
private Date expectRepaymentDate;
/**
*
*/
@ExcelProperty(value = "回款延期天数")
private Long delayDay;
/**
*
*/
@ExcelProperty(value = "实际回款日期")
private Date actualRepaymentDate;
/**
* 0 1
*/
@ExcelProperty(value = "回款标识", converter = ExcelDictConvert.class)
@ExcelDictFormat(readConverterExp = "0=否,1=是")
private String repaymentFlag;
/**
*
*/
@ExcelProperty(value = "原因说明")
private String reasonsExplanation;
/**
*
*/
@ExcelProperty(value = "进度备注")
private String scheduleRemark;
/**
*
*/
@ExcelProperty(value = "回款金额", converter = ExcelDictConvert.class)
@ExcelDictFormat(readConverterExp = "预=留")
private Long repaymentAmount;
/**
*
@ -78,5 +123,35 @@ public class ErpContractPaymentStageVo implements Serializable {
@ExcelProperty(value = "备注")
private String remark;
/**
*
*/
@ExcelProperty(value = "创建部门")
private Long createDept;
/**
*
*/
@ExcelProperty(value = "创建者")
private Long createBy;
/**
*
*/
@ExcelProperty(value = "创建时间")
private Date createTime;
/**
*
*/
@ExcelProperty(value = "更新者")
private Long updateBy;
/**
*
*/
@ExcelProperty(value = "更新时间")
private Date updateTime;
}

@ -62,7 +62,7 @@ public class ErpProjectInfoVo implements Serializable {
private String businessDirection;
/**
* 1 2 3 4
* 1 2 3 4 5
*/
@ExcelProperty(value = "项目类别", converter = ExcelDictConvert.class)
@ExcelDictFormat(dictType = "project_category")

@ -1,7 +1,6 @@
package org.dromara.oa.erp.mapper;
import java.util.List;
import com.github.yulichang.wrapper.MPJLambdaWrapper;
import com.baomidou.mybatisplus.core.toolkit.Constants;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;

@ -0,0 +1,46 @@
package org.dromara.oa.erp.service;
import org.dromara.oa.erp.domain.vo.ErpProjectInfoVo;
import org.dromara.oa.erp.domain.bo.ErpProjectInfoBo;
/**
* Service
*
* @author Yinq
* @date 2025-12-05
*/
public interface IErpContractOrderService {
/**
*
*
* @param projectId
* @return
*/
ErpProjectInfoVo queryById(Long projectId);
/**
*
*
* @param bo
* @return
*/
ErpProjectInfoVo saveContractOrder(ErpProjectInfoBo bo);
/**
*
*
* @param bo
* @return
*/
ErpProjectInfoVo updateContractOrder(ErpProjectInfoBo bo);
/**
*
*
* @param bo
* @return
*/
ErpProjectInfoVo submitContractOrderAndFlowStart(ErpProjectInfoBo bo);
}

@ -1,6 +1,7 @@
package org.dromara.oa.erp.service.impl;
import cn.hutool.core.convert.Convert;
import cn.hutool.core.convert.NumberChineseFormatter;
import cn.hutool.core.map.MapUtil;
import lombok.extern.slf4j.Slf4j;
import org.apache.dubbo.config.annotation.DubboReference;
@ -240,6 +241,11 @@ public class ErpContractInfoServiceImpl implements IErpContractInfoService {
// if (entity.getContractMaterialList() == null || entity.getContractMaterialList().isEmpty()) {
// throw new ServiceException("请填写合同物料!");
// }
//存储合同大写金额
if (StringUtils.isNotNull(entity.getTotalPrice())) {
String capitalizedAmount = NumberChineseFormatter.format(entity.getTotalPrice().doubleValue(), true, true);
entity.setCapitalizedAmount(capitalizedAmount);
}
}
/**
@ -267,7 +273,6 @@ public class ErpContractInfoServiceImpl implements IErpContractInfoService {
@GlobalTransactional(rollbackFor = Exception.class)
public ErpContractInfoVo contractSubmitAndFlowStart(ErpContractInfoBo bo) {
ErpContractInfo add = MapstructUtils.convert(bo, ErpContractInfo.class);
validEntityBeforeSave(add);
if (StringUtils.isNull(bo.getContractId())) {
this.insertByBo(bo);
} else {

@ -0,0 +1,295 @@
package org.dromara.oa.erp.service.impl;
import cn.hutool.core.collection.CollUtil;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import lombok.RequiredArgsConstructor;
import lombok.extern.slf4j.Slf4j;
import org.apache.seata.spring.annotation.GlobalTransactional;
import org.dromara.common.core.enums.BusinessStatusEnum;
import org.dromara.common.core.enums.OAStatusEnum;
import org.dromara.common.core.exception.ServiceException;
import org.dromara.common.core.utils.MapstructUtils;
import org.dromara.common.core.utils.StringUtils;
import org.dromara.common.tenant.helper.TenantHelper;
import org.dromara.oa.erp.domain.ErpProjectInfo;
import org.dromara.oa.erp.domain.ErpProjectPlan;
import org.dromara.oa.erp.domain.ErpProjectPlanStage;
import org.dromara.oa.erp.domain.bo.ErpProjectInfoBo;
import org.dromara.oa.erp.domain.bo.ErpProjectPlanStageBo;
import org.dromara.oa.erp.domain.vo.ErpProjectInfoVo;
import org.dromara.oa.erp.mapper.ErpProjectInfoMapper;
import org.dromara.oa.erp.mapper.ErpProjectPlanMapper;
import org.dromara.oa.erp.mapper.ErpProjectPlanStageMapper;
import org.dromara.oa.erp.service.IErpContractOrderService;
import org.dromara.system.api.RemoteCodeRuleService;
import org.dromara.workflow.api.RemoteWorkflowService;
import org.dromara.workflow.api.domain.RemoteStartProcess;
import org.dromara.workflow.api.event.ProcessEvent;
import org.springframework.context.event.EventListener;
import org.springframework.stereotype.Service;
import org.apache.dubbo.config.annotation.DubboReference;
import java.util.List;
import java.util.Map;
import java.util.Objects;
import java.util.stream.Collectors;
import cn.hutool.core.map.MapUtil;
import cn.hutool.core.convert.Convert;
/**
* Service
*
* @author Yinq
* @date 2025-12-05
*/
@RequiredArgsConstructor
@Service
@Slf4j
public class ErpContractOrderServiceImpl implements IErpContractOrderService {
private final ErpProjectInfoMapper projectInfoMapper;
private final ErpProjectPlanMapper projectPlanMapper;
private final ErpProjectPlanStageMapper planStageMapper;
@DubboReference(timeout = 30000)
private RemoteWorkflowService remoteWorkflowService;
@DubboReference(timeout = 30000)
private RemoteCodeRuleService remoteCodeRuleService;
/**
*
*
* @param projectId
* @return
*/
@Override
public ErpProjectInfoVo queryById(Long projectId) {
ErpProjectInfo projectInfo = projectInfoMapper.selectById(projectId);
if (projectInfo == null) {
return null;
}
return MapstructUtils.convert(projectInfo, ErpProjectInfoVo.class);
}
/**
*
*
* @param bo
* @return
*/
@Override
@GlobalTransactional(rollbackFor = Exception.class)
public ErpProjectInfoVo saveContractOrder(ErpProjectInfoBo bo) {
// 保存项目信息
ErpProjectInfo projectInfo = MapstructUtils.convert(bo, ErpProjectInfo.class);
validEntityBeforeSave(projectInfo);
if (StringUtils.isNull(bo.getProjectId())) {
// 新增
projectInfoMapper.insert(projectInfo);
bo.setProjectId(projectInfo.getProjectId());
} else {
// 更新
projectInfoMapper.updateById(projectInfo);
}
// 保存项目阶段计划列表
savePlanStageList(projectInfo, bo.getPlanStageList());
return MapstructUtils.convert(projectInfo, ErpProjectInfoVo.class);
}
/**
*
*
* @param bo
* @return
*/
@Override
@GlobalTransactional(rollbackFor = Exception.class)
public ErpProjectInfoVo updateContractOrder(ErpProjectInfoBo bo) {
return saveContractOrder(bo);
}
/**
*
*
* @param bo
* @return
*/
@Override
@GlobalTransactional(rollbackFor = Exception.class)
public ErpProjectInfoVo submitContractOrderAndFlowStart(ErpProjectInfoBo bo) {
// 先保存项目信息和项目阶段计划
ErpProjectInfoVo vo = saveContractOrder(bo);
if (1==1) {
return vo;
}
// 后端发起需要忽略权限
bo.getVariables().put("ignore", true);
RemoteStartProcess startProcess = new RemoteStartProcess();
startProcess.setBusinessId(bo.getProjectId().toString());
startProcess.setFlowCode(bo.getFlowCode());
startProcess.setVariables(bo.getVariables());
startProcess.setBizExt(bo.getBizExt());
bo.getBizExt().setBusinessId(startProcess.getBusinessId());
boolean flagOne = remoteWorkflowService.startCompleteTask(startProcess);
if (!flagOne) {
throw new ServiceException("流程发起异常");
}
return vo;
}
/**
*
*
* @param projectInfo
* @param planStageList
*/
private void savePlanStageList(ErpProjectInfo projectInfo, List<ErpProjectPlanStageBo> planStageList) {
if (projectInfo == null || projectInfo.getProjectId() == null) {
return;
}
// 如果planStageList为null表示前端没有传递该字段不处理
if (planStageList == null) {
return;
}
Long projectId = projectInfo.getProjectId();
// 先获取或创建项目计划
Long projectPlanId = getOrCreateProjectPlan(projectInfo);
// 查询原有的项目阶段计划ID列表根据projectPlanId查询
LambdaQueryWrapper<ErpProjectPlanStage> queryWrapper = new LambdaQueryWrapper<>();
queryWrapper.eq(ErpProjectPlanStage::getProjectPlanId, projectPlanId);
List<ErpProjectPlanStage> existingStages = planStageMapper.selectList(queryWrapper);
List<Long> existingIds = existingStages.stream()
.map(ErpProjectPlanStage::getPlanStageId)
.filter(Objects::nonNull)
.collect(Collectors.toList());
// 收集前端传来的ID列表已存在的记录
List<Long> newIds = planStageList.stream()
.map(ErpProjectPlanStageBo::getPlanStageId)
.filter(Objects::nonNull)
.collect(Collectors.toList());
// 删除不在新列表中的原有记录
List<Long> idsToDelete = existingIds.stream()
.filter(id -> !newIds.contains(id))
.collect(Collectors.toList());
if (CollUtil.isNotEmpty(idsToDelete)) {
planStageMapper.deleteBatchIds(idsToDelete);
}
// 保存或更新项目阶段计划
for (ErpProjectPlanStageBo stageBo : planStageList) {
ErpProjectPlanStage stage = MapstructUtils.convert(stageBo, ErpProjectPlanStage.class);
stage.setProjectId(projectId);
stage.setProjectPlanId(projectPlanId);
if (StringUtils.isNull(stage.getPlanStageId())) {
// 新增
planStageMapper.insert(stage);
} else {
// 更新
planStageMapper.updateById(stage);
}
}
}
/**
*
*
* @param projectInfo
* @return ID
*/
private Long getOrCreateProjectPlan(ErpProjectInfo projectInfo) {
if (projectInfo == null || projectInfo.getProjectId() == null) {
throw new ServiceException("项目信息不存在");
}
Long projectId = projectInfo.getProjectId();
// 查询是否已存在项目计划
LambdaQueryWrapper<ErpProjectPlan> queryWrapper = new LambdaQueryWrapper<>();
queryWrapper.eq(ErpProjectPlan::getProjectId, projectId);
queryWrapper.eq(ErpProjectPlan::getDelFlag, "0");
queryWrapper.orderByDesc(ErpProjectPlan::getCreateTime);
queryWrapper.last("LIMIT 1");
List<ErpProjectPlan> existingPlans = projectPlanMapper.selectList(queryWrapper);
if (CollUtil.isNotEmpty(existingPlans)) {
return existingPlans.get(0).getProjectPlanId();
}
// 不存在则创建新的项目计划
ErpProjectPlan newPlan = new ErpProjectPlan();
newPlan.setProjectId(projectId);
newPlan.setProjectPlanStatus("3");
newPlan.setFlowStatus("finish");
newPlan.setManagerId(projectInfo.getManagerId());
newPlan.setChargeId(projectInfo.getChargeId());
// 生成项目计划编号
String projectPlanCode = remoteCodeRuleService.selectCodeRuleCode("1010");
if (StringUtils.isBlank(projectPlanCode)) {
throw new ServiceException("生成项目计划编号失败");
}
newPlan.setProjectPlanCode(projectPlanCode);
projectPlanMapper.insert(newPlan);
return newPlan.getProjectPlanId();
}
/**
*
*/
private void validEntityBeforeSave(ErpProjectInfo entity) {
//TODO 做一些数据校验,如唯一约束
}
/**
* (: 稿退)
*
* @param processEvent
*/
@EventListener(condition = "#processEvent.flowCode.startsWith('htdd')")
public void processHandler(ProcessEvent processEvent) {
TenantHelper.dynamic(processEvent.getTenantId(), () -> {
log.info("当前任务执行了{}", processEvent.toString());
ErpProjectInfo projectInfo = projectInfoMapper.selectById(
Convert.toLong(processEvent.getBusinessId())
);
if (projectInfo != null) {
projectInfo.setFlowStatus(processEvent.getStatus());
Map<String, Object> params = processEvent.getParams();
if (MapUtil.isNotEmpty(params)) {
// 办理人
if (params.containsKey("handler")) {
// TODO: 处理办理人
}
}
// 更新流程状态
if (Objects.equals(processEvent.getStatus(), BusinessStatusEnum.WAITING.getStatus())) {
projectInfo.setProjectStatus(OAStatusEnum.APPROVING.getStatus());
} else if (Objects.equals(processEvent.getStatus(), BusinessStatusEnum.FINISH.getStatus())) {
projectInfo.setProjectStatus(OAStatusEnum.COMPLETED.getStatus());
} else if (Objects.equals(processEvent.getStatus(), BusinessStatusEnum.INVALID.getStatus())
|| Objects.equals(processEvent.getStatus(), BusinessStatusEnum.TERMINATION.getStatus())) {
projectInfo.setProjectStatus(OAStatusEnum.INVALID.getStatus());
} else if (Objects.equals(processEvent.getStatus(), BusinessStatusEnum.BACK.getStatus())
|| Objects.equals(processEvent.getStatus(), BusinessStatusEnum.CANCEL.getStatus())) {
projectInfo.setProjectStatus(OAStatusEnum.DRAFT.getStatus());
} else if (Objects.equals(processEvent.getStatus(), BusinessStatusEnum.DRAFT.getStatus())) {
projectInfo.setProjectStatus(OAStatusEnum.DRAFT.getStatus());
}
projectInfoMapper.updateById(projectInfo);
}
});
}
}

@ -78,7 +78,14 @@ public class ErpContractPaymentStageServiceImpl implements IErpContractPaymentSt
.eq(bo.getPaymentStageId() != null, ErpContractPaymentStage::getPaymentStageId, bo.getPaymentStageId())
.like(StringUtils.isNotBlank(bo.getStageName()), ErpContractPaymentStage::getStageName, bo.getStageName())
.eq(StringUtils.isNotBlank(bo.getCollectionStage()), ErpContractPaymentStage::getCollectionStage, bo.getCollectionStage())
.eq(bo.getPurchasePrice() != null, ErpContractPaymentStage::getPurchasePrice, bo.getPurchasePrice())
.eq(bo.getRepaymentRate() != null, ErpContractPaymentStage::getRepaymentRate, bo.getRepaymentRate())
.eq(bo.getExpectRepaymentDate() != null, ErpContractPaymentStage::getExpectRepaymentDate, bo.getExpectRepaymentDate())
.eq(bo.getDelayDay() != null, ErpContractPaymentStage::getDelayDay, bo.getDelayDay())
.eq(bo.getActualRepaymentDate() != null, ErpContractPaymentStage::getActualRepaymentDate, bo.getActualRepaymentDate())
.eq(StringUtils.isNotBlank(bo.getRepaymentFlag()), ErpContractPaymentStage::getRepaymentFlag, bo.getRepaymentFlag())
.eq(StringUtils.isNotBlank(bo.getReasonsExplanation()), ErpContractPaymentStage::getReasonsExplanation, bo.getReasonsExplanation())
.eq(StringUtils.isNotBlank(bo.getScheduleRemark()), ErpContractPaymentStage::getScheduleRemark, bo.getScheduleRemark())
.eq(bo.getRepaymentAmount() != null, ErpContractPaymentStage::getRepaymentAmount, bo.getRepaymentAmount())
.eq(bo.getSortOrder() != null, ErpContractPaymentStage::getSortOrder, bo.getSortOrder());
return lqw;
}

@ -110,7 +110,7 @@ public class ErpProjectPurchaseServiceImpl implements IErpProjectPurchaseService
.selectAll(ErpProjectPurchase.class)
.eq(ErpProjectPurchase::getDelFlag, "0")
.eq(bo.getProjectId() != null, ErpProjectPurchase::getProjectId, bo.getProjectId())
.eq(StringUtils.isNotBlank(bo.getProjectCode()), ErpProjectPurchase::getProjectCode, bo.getProjectCode())
.like(StringUtils.isNotBlank(bo.getProjectCode()), ErpProjectPurchase::getProjectCode, bo.getProjectCode())
.eq(bo.getManagerId() != null, ErpProjectPurchase::getManagerId, bo.getManagerId())
.eq(bo.getChargeId() != null, ErpProjectPurchase::getChargeId, bo.getChargeId())
.eq(bo.getDeputyId() != null, ErpProjectPurchase::getDeputyId, bo.getDeputyId())
@ -123,7 +123,11 @@ public class ErpProjectPurchaseServiceImpl implements IErpProjectPurchaseService
.eq(bo.getSortOrder() != null, ErpProjectPurchase::getSortOrder, bo.getSortOrder())
.eq(bo.getRelationId() != null, ErpProjectPurchase::getRelationId, bo.getRelationId())
.eq(StringUtils.isNotBlank(bo.getSpareFlag()), ErpProjectPurchase::getSpareFlag, bo.getSpareFlag())
.eq(StringUtils.isNotBlank(bo.getActiveFlag()), ErpProjectPurchase::getActiveFlag, bo.getActiveFlag());
.like(StringUtils.isNotBlank(bo.getPurchaseCode()), ErpProjectPurchase::getPurchaseCode, bo.getPurchaseCode())
.like(StringUtils.isNotBlank(bo.getManagerName()), "u1.nick_name", bo.getManagerName())
.like(StringUtils.isNotBlank(bo.getProjectName()), "p.project_name", bo.getProjectName())
.eq(StringUtils.isNotBlank(bo.getActiveFlag()), ErpProjectPurchase::getActiveFlag, bo.getActiveFlag())
.orderByDesc(ErpProjectPurchase::getCreateTime);
return lqw;
}
@ -141,6 +145,18 @@ public class ErpProjectPurchaseServiceImpl implements IErpProjectPurchaseService
validEntityBeforeSave(add);
String purchaseCode = remoteCodeRuleService.selectCodeRuleCode("1007");
add.setPurchaseCode(purchaseCode);
MPJLambdaWrapper<ErpProjectPurchase> lqw = JoinWrappers.lambda(ErpProjectPurchase.class)
.selectAll(ErpProjectPurchase.class)
.eq(ErpProjectPurchase::getProjectCode, bo.getProjectCode())
.orderByDesc(ErpProjectPurchase::getVersion);
List<ErpProjectPurchase> purchases = baseMapper.selectList(lqw);
if (purchases.isEmpty()){
add.setVersion(1L);
} else {
add.setVersion(purchases.get(0).getVersion() + 1);
}
boolean flag = baseMapper.insert(add) > 0;
if (flag) {
bo.setProjectPurchaseId(add.getProjectPurchaseId());

@ -13,7 +13,14 @@
payment_stage_id,
stage_name,
collection_stage,
purchase_price,
repayment_rate,
expect_repayment_date,
delay_day,
actual_repayment_date,
repayment_flag,
reasons_explanation,
schedule_remark,
repayment_amount,
sort_order,
remark,
del_flag,

Loading…
Cancel
Save