From 2aa0dd9c34c6be86e70b1d2d939d3660552cb514 Mon Sep 17 00:00:00 2001 From: 无关风月 <443237572@qq.com> Date: 星期三, 17 九月 2025 14:44:23 +0800 Subject: [PATCH] Merge remote-tracking branch 'origin/master' --- ruoyi-system/src/main/java/com/ruoyi/system/service/impl/OaApprovalApplicationPurchaseServiceImpl.java | 143 +++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 143 insertions(+), 0 deletions(-) diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/OaApprovalApplicationPurchaseServiceImpl.java b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/OaApprovalApplicationPurchaseServiceImpl.java index 9734010..7d928d4 100644 --- a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/OaApprovalApplicationPurchaseServiceImpl.java +++ b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/OaApprovalApplicationPurchaseServiceImpl.java @@ -1,10 +1,29 @@ package com.ruoyi.system.service.impl; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import com.ruoyi.common.exception.ServiceException; +import com.ruoyi.system.dto.asset.OaApprovalApplicationPurchaseDTO; +import com.ruoyi.system.emums.ApprovalStatusEnum; import com.ruoyi.system.mapper.OaApprovalApplicationPurchaseMapper; import com.ruoyi.system.model.OaApprovalApplicationPurchase; +import com.ruoyi.system.model.OaApprovalApplicationPurchaseItem; +import com.ruoyi.system.model.OaApprovalApplications; +import com.ruoyi.system.model.OaApprovalFlowNode; +import com.ruoyi.system.service.ISysDeptService; +import com.ruoyi.system.service.ISysUserService; +import com.ruoyi.system.service.OaApprovalApplicationPurchaseItemService; import com.ruoyi.system.service.OaApprovalApplicationPurchaseService; +import com.ruoyi.system.service.OaApprovalApplicationsService; +import com.ruoyi.system.service.OaApprovalFlowNodeService; +import com.ruoyi.system.service.OaApprovalTodoService; +import lombok.RequiredArgsConstructor; import org.springframework.stereotype.Service; +import org.springframework.transaction.annotation.Transactional; +import org.springframework.util.CollectionUtils; + +import java.time.LocalDate; +import java.time.format.DateTimeFormatter; +import java.util.List; /** * <p> @@ -15,6 +34,130 @@ * @since 2025-09-15 */ @Service +@RequiredArgsConstructor public class OaApprovalApplicationPurchaseServiceImpl extends ServiceImpl<OaApprovalApplicationPurchaseMapper, OaApprovalApplicationPurchase> implements OaApprovalApplicationPurchaseService { + private final OaApprovalApplicationsService oaApprovalApplicationsService; + private final OaApprovalApplicationPurchaseItemService oaApprovalApplicationPurchaseItemService; + private final OaApprovalFlowNodeService oaApprovalFlowNodeService; + private final OaApprovalTodoService oaApprovalTodoService; + private final ISysUserService sysUserService; + private final ISysDeptService sysDeptService; + + @Override + @Transactional(rollbackFor = Exception.class) + public void submit(OaApprovalApplicationPurchaseDTO dto) { + // 1. 保存审批申请主表数据 + OaApprovalApplications applications = buildOaApprovalApplications(dto); + + // 2. 如果是提交操作,获取流程节点并创建待办 + OaApprovalFlowNode firstFlowNode = getFirstFlowNode(dto.getApprovalId()); + applications.setCurrentFlowNodeId(firstFlowNode.getId()); + oaApprovalApplicationsService.save(applications); + + // 3. 创建待办事项记录(公共服务) + oaApprovalTodoService.createApprovalTodos(applications.getId(), applications.getApplicationCode(), firstFlowNode, dto.getDeptId()); + + // 4.保存采购资产明细数据 + List<OaApprovalApplicationPurchaseItem> items = buildOaApprovalApplicationPurchaseItems(dto, applications.getId()); + oaApprovalApplicationPurchaseItemService.saveBatch(items); + + // 5. 保存采购申请详情数据 + OaApprovalApplicationPurchase purchase = buildOaApprovalApplicationPurchase(dto, applications.getId()); + save(purchase); + } + /** + * 获取第一个流程节点 + */ + private OaApprovalFlowNode getFirstFlowNode(Integer approvalId) { + // 1. 查询审批流程配置 + List<OaApprovalFlowNode> flowNodes = oaApprovalFlowNodeService.lambdaQuery() + .eq(OaApprovalFlowNode::getApprovalId, approvalId) + .eq(OaApprovalFlowNode::getStatus, 1) // 启用状态 + .orderByAsc(OaApprovalFlowNode::getSortOrder) + .list(); + + if (CollectionUtils.isEmpty(flowNodes)) { + throw new ServiceException("未找到有效的审批流程配置"); + } + + // 2. 获取第一个流程节点 + return flowNodes.get(0); + } + + /** + * 构建审批申请主表数据 + */ + private OaApprovalApplications buildOaApprovalApplications(OaApprovalApplicationPurchaseDTO dto) { + OaApprovalApplications applications = new OaApprovalApplications(); + applications.setApplicationCode(generateApplicationCode()); + applications.setApprovalId(dto.getApprovalId()); + applications.setApplicantUserId(dto.getApplicantUserId()); + applications.setApplicantName(dto.getApplicantName()); + applications.setDeptId(dto.getDeptId()); + applications.setDeptName(dto.getDeptName()); + applications.setApplicationDate(dto.getApplicationDate()); + applications.setApplicationReason(dto.getApplicationReason()); + applications.setAttachmentUrl(dto.getAttachmentUrl()); + applications.setDisabled(0); // 未删除 + applications.setApprovalStatus(ApprovalStatusEnum.PENDING.getCode()); + return applications; + } + + /** + * 构建采购申请详情数据 + */ + private OaApprovalApplicationPurchase buildOaApprovalApplicationPurchase(OaApprovalApplicationPurchaseDTO dto, Integer applicationId) { + OaApprovalApplicationPurchase purchase = new OaApprovalApplicationPurchase(); + purchase.setApprovalApplicationId(applicationId); + // 使用事项标题,而非采购说明 + purchase.setTitle(dto.getTitle()); + // 表结构中无 application_date 字段,此处不再设置 + purchase.setAssetTypeId(dto.getAssetTypeId()); + purchase.setTotalAmount(dto.getTotalAmount()); + + return purchase; + } + + /** + * 构建采购资产明细数据 + */ + private List<OaApprovalApplicationPurchaseItem> buildOaApprovalApplicationPurchaseItems(OaApprovalApplicationPurchaseDTO dto, Integer applicationId) { + return dto.getPurchaseItems().stream() + .map(item -> { + OaApprovalApplicationPurchaseItem purchaseItem = new OaApprovalApplicationPurchaseItem(); + purchaseItem.setApprovalApplicationId(applicationId); + purchaseItem.setAssetName(item.getAssetName()); + purchaseItem.setAssetTypeId(item.getAssetTypeId()); + purchaseItem.setSpec(item.getSpec()); + purchaseItem.setUnit(item.getUnit()); + purchaseItem.setQuantity(item.getQuantity()); + purchaseItem.setPrice(item.getPrice()); + purchaseItem.setTotalAmount(item.getTotalAmount()); + return purchaseItem; + }) + .collect(java.util.stream.Collectors.toList()); + } + + /** + * 生成申请单号 + * 格式:CG + 年月日 + 3位序号 + */ + private String generateApplicationCode() { + String dateStr = LocalDate.now().format(DateTimeFormatter.ofPattern("yyyyMMdd")); + String prefix = "CG" + dateStr; + + // 查询当天已生成的申请单号数量 + Long count = oaApprovalApplicationsService.lambdaQuery() + .like(OaApprovalApplications::getApplicationCode, prefix) + .ge(OaApprovalApplications::getCreateTime, LocalDate.now().atStartOfDay()) + .lt(OaApprovalApplications::getCreateTime, LocalDate.now().plusDays(1).atStartOfDay()) + .count(); + + // 生成3位序号,从001开始 + int sequence = (count != null ? count.intValue() : 0) + 1; + String sequenceStr = String.format("%03d", sequence); + + return prefix + sequenceStr; + } } -- Gitblit v1.7.1