package com.ruoyi.system.service.impl; 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.ruoyi.common.core.domain.entity.TDept; import com.ruoyi.common.exception.ServiceException; import com.ruoyi.system.dto.asset.OaApprovalApplicationStorageGeneralDTO; import com.ruoyi.system.dto.asset.OaApprovalApplicationStoragePropertyDTO; import com.ruoyi.system.dto.asset.OaApprovalApplicationStorageVehicleDTO; import com.ruoyi.system.emums.ApprovalStatusEnum; import com.ruoyi.system.emums.ApprovalTypeEnum; import com.ruoyi.system.emums.AssetTypeEnum; import com.ruoyi.system.mapper.OaApprovalApplicationStorageMapper; import com.ruoyi.system.model.AssetGeneralExt; import com.ruoyi.system.model.AssetMain; import com.ruoyi.system.model.AssetPropertyExt; import com.ruoyi.system.model.AssetVehicleExt; import com.ruoyi.system.model.AssetWarehouse; import com.ruoyi.system.model.OaApprovalApplicationStorage; import com.ruoyi.system.model.OaApprovalApplications; import com.ruoyi.system.model.OaApprovalFlowNode; import com.ruoyi.system.query.OaApprovalApplicationStoragePageQuery; import com.ruoyi.system.service.AssetGeneralExtService; import com.ruoyi.system.service.AssetMainService; import com.ruoyi.system.service.AssetPropertyExtService; import com.ruoyi.system.service.AssetTypeService; import com.ruoyi.system.service.AssetVehicleExtService; import com.ruoyi.system.service.AssetWarehouseService; import com.ruoyi.system.service.ISysDeptService; import com.ruoyi.system.service.ISysUserService; import com.ruoyi.system.service.OaApprovalApplicationStorageService; import com.ruoyi.system.service.OaApprovalApplicationsService; import com.ruoyi.system.service.OaApprovalFlowNodeService; import com.ruoyi.system.service.OaApprovalTodoService; import com.ruoyi.system.service.TDeptService; import com.ruoyi.system.vo.asset.OaApprovalApplicationStorageGeneralDetailVO; import com.ruoyi.system.vo.asset.OaApprovalApplicationStoragePageVO; import com.ruoyi.system.vo.asset.OaApprovalApplicationStoragePropertyDetailVO; import com.ruoyi.system.vo.asset.OaApprovalApplicationStorageVehicleDetailVO; import lombok.RequiredArgsConstructor; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; import org.springframework.util.CollectionUtils; import java.math.BigDecimal; import java.time.LocalDate; import java.time.format.DateTimeFormatter; import java.util.ArrayList; import java.util.List; import java.util.Map; import java.util.stream.Collectors; /** *

* 资产入库申请明细表 服务实现类 *

* * @author WuGuanFengYue * @since 2025-09-15 */ @Service @RequiredArgsConstructor public class OaApprovalApplicationStorageServiceImpl extends ServiceImpl implements OaApprovalApplicationStorageService { private final OaApprovalApplicationsService oaApprovalApplicationsService; private final AssetMainService assetMainService; private final AssetGeneralExtService assetGeneralExtService; private final AssetPropertyExtService assetPropertyExtService; private final AssetVehicleExtService assetVehicleExtService; private final AssetTypeService assetTypeService; private final OaApprovalFlowNodeService oaApprovalFlowNodeService; private final OaApprovalTodoService oaApprovalTodoService; private final ISysUserService sysUserService; private final ISysDeptService sysDeptService; private final TDeptService tDeptService; private final AssetWarehouseService assetWarehouseService; @Override @Transactional(rollbackFor = Exception.class) public void submitGeneralAssetStorage(OaApprovalApplicationStorageGeneralDTO dto) { // 1. 保存审批申请主表数据 OaApprovalApplications applications = buildOaApprovalApplications(dto); // 2. 获取流程节点并创建待办 OaApprovalFlowNode firstFlowNode = getFirstFlowNode(ApprovalTypeEnum.IN_STOCK.getCode()); applications.setCurrentFlowNodeId(firstFlowNode.getId()); oaApprovalApplicationsService.save(applications); // 3. 创建待办事项记录(公共服务) oaApprovalTodoService.createApprovalTodos(applications.getId(), applications.getApplicationCode(), firstFlowNode, dto.getDeptId()); // 4. 保存资产入库申请明细数据 OaApprovalApplicationStorage storage = buildOaApprovalApplicationStorage(dto, applications.getId()); save(storage); // 5. 保存通用资产数据 saveGeneralAssets(dto.getAssetItems(), applications.getId(), dto.getAssetTypeId(), dto.getStorageTime(), dto); } @Override @Transactional(rollbackFor = Exception.class) public void submitPropertyAssetStorage(OaApprovalApplicationStoragePropertyDTO dto) { // 1. 保存审批申请主表数据 OaApprovalApplications applications = buildOaApprovalApplications(dto); // 2. 获取流程节点并创建待办 OaApprovalFlowNode firstFlowNode = getFirstFlowNode(ApprovalTypeEnum.IN_STOCK.getCode()); applications.setCurrentFlowNodeId(firstFlowNode.getId()); oaApprovalApplicationsService.save(applications); // 3. 创建待办事项记录(公共服务) oaApprovalTodoService.createApprovalTodos(applications.getId(), applications.getApplicationCode(), firstFlowNode, dto.getDeptId()); // 4. 保存资产入库申请明细数据 OaApprovalApplicationStorage storage = buildOaApprovalApplicationStorage(dto, applications.getId()); save(storage); // 5. 保存房产资产数据 savePropertyAssets(dto.getAssetItems(), applications.getId(), dto.getAssetTypeId(), dto.getStorageTime(), dto); } @Override @Transactional(rollbackFor = Exception.class) public void submitVehicleAssetStorage(OaApprovalApplicationStorageVehicleDTO dto) { // 1. 保存审批申请主表数据 OaApprovalApplications applications = buildOaApprovalApplications(dto); // 2. 获取流程节点并创建待办 OaApprovalFlowNode firstFlowNode = getFirstFlowNode(ApprovalTypeEnum.IN_STOCK.getCode()); applications.setCurrentFlowNodeId(firstFlowNode.getId()); oaApprovalApplicationsService.save(applications); // 3. 创建待办事项记录(公共服务) oaApprovalTodoService.createApprovalTodos(applications.getId(), applications.getApplicationCode(), firstFlowNode, dto.getDeptId()); // 4. 保存资产入库申请明细数据 OaApprovalApplicationStorage storage = buildOaApprovalApplicationStorage(dto, applications.getId()); save(storage); // 5. 保存车辆资产数据 saveVehicleAssets(dto.getAssetItems(), applications.getId(), dto.getAssetTypeId(), dto.getStorageTime(), dto); } /** * 保存通用资产数据 */ private void saveGeneralAssets(List assetItems, Integer applicationId, Integer assetTypeId, LocalDate storageDate, OaApprovalApplicationStorageGeneralDTO baseDto) { List allAssetMains = new ArrayList<>(); for (OaApprovalApplicationStorageGeneralDTO.GeneralAssetItemDTO item : assetItems) { // 根据数量创建对应数量的资产记录 int quantity = item.getQuantity().intValue(); for (int i = 0; i < quantity; i++) { AssetMain assetMain = buildAssetMain(item, applicationId, assetTypeId, storageDate, baseDto); assetMain.setAssetMainType(AssetTypeEnum.GENERAL.getCode()); assetMain.setQuantity(BigDecimal.ONE); // 每个资产记录数量为1 assetMain.setTotalValue(item.getUnitPrice()); // 总价值等于单价 allAssetMains.add(assetMain); } } // 批量保存资产主表数据 assetMainService.saveBatch(allAssetMains); } /** * 保存房产资产数据 */ private void savePropertyAssets(List assetItems, Integer applicationId, Integer assetTypeId, LocalDate storageDate, OaApprovalApplicationStoragePropertyDTO baseDto) { List allAssetMains = new ArrayList<>(); List allPropertyExts = new ArrayList<>(); for (OaApprovalApplicationStoragePropertyDTO.PropertyAssetItemDTO item : assetItems) { // 根据数量创建对应数量的资产记录 int quantity = item.getQuantity().intValue(); for (int i = 0; i < quantity; i++) { AssetMain assetMain = buildAssetMainFromProperty(item, applicationId, assetTypeId, storageDate, baseDto); assetMain.setAssetMainType(AssetTypeEnum.HOUSE.getCode()); assetMain.setQuantity(BigDecimal.ONE); // 每个资产记录数量为1 assetMain.setTotalValue(item.getUnitPrice()); // 总价值等于单价 allAssetMains.add(assetMain); } } // 批量保存资产主表数据 assetMainService.saveBatch(allAssetMains); // 为每个资产主表记录创建对应的扩展信息 int assetMainIndex = 0; for (OaApprovalApplicationStoragePropertyDTO.PropertyAssetItemDTO item : assetItems) { int quantity = item.getQuantity().intValue(); for (int i = 0; i < quantity; i++) { AssetPropertyExt propertyExt = buildAssetPropertyExt(item, allAssetMains.get(assetMainIndex).getId()); allPropertyExts.add(propertyExt); assetMainIndex++; } } assetPropertyExtService.saveBatch(allPropertyExts); } /** * 保存车辆资产数据 */ private void saveVehicleAssets(List assetItems, Integer applicationId, Integer assetTypeId, LocalDate storageDate, OaApprovalApplicationStorageVehicleDTO baseDto) { List allAssetMains = new ArrayList<>(); List allVehicleExts = new ArrayList<>(); for (OaApprovalApplicationStorageVehicleDTO.VehicleAssetItemDTO item : assetItems) { // 根据数量创建对应数量的资产记录 int quantity = item.getQuantity().intValue(); for (int i = 0; i < quantity; i++) { AssetMain assetMain = buildAssetMainFromVehicle(item, applicationId, assetTypeId, storageDate, baseDto); assetMain.setAssetMainType(AssetTypeEnum.VEHICLE.getCode()); assetMain.setQuantity(BigDecimal.ONE); // 每个资产记录数量为1 assetMain.setTotalValue(item.getUnitPrice()); // 总价值等于单价 allAssetMains.add(assetMain); } } // 批量保存资产主表数据 assetMainService.saveBatch(allAssetMains); // 为每个资产主表记录创建对应的扩展信息 int assetMainIndex = 0; for (OaApprovalApplicationStorageVehicleDTO.VehicleAssetItemDTO item : assetItems) { int quantity = item.getQuantity().intValue(); for (int i = 0; i < quantity; i++) { AssetVehicleExt vehicleExt = buildAssetVehicleExt(item, allAssetMains.get(assetMainIndex).getId()); allVehicleExts.add(vehicleExt); assetMainIndex++; } } assetVehicleExtService.saveBatch(allVehicleExts); } /** * 构建通用资产主表数据 */ private AssetMain buildAssetMain(OaApprovalApplicationStorageGeneralDTO.GeneralAssetItemDTO item, Integer applicationId, Integer assetTypeId, LocalDate storageDate, OaApprovalApplicationStorageGeneralDTO baseDto) { AssetMain assetMain = new AssetMain(); assetMain.setApprovalApplicationId(applicationId.intValue()); assetMain.setAssetOriginalCode(item.getAssetOriginalCode()); assetMain.setAssetCode(generateAssetCode(assetTypeId, storageDate)); // 系统生成资产编码 assetMain.setAssetName(item.getAssetName()); assetMain.setCategory(item.getCategory()); assetMain.setSpecificationModel(item.getSpecificationModel()); assetMain.setAssetTypeId(assetTypeId); assetMain.setMeasurementUnit(item.getMeasurementUnit()); assetMain.setUnitPrice(item.getUnitPrice()); assetMain.setUsefulLife(item.getUsefulLife()); // 根据权属单位/部门名称填充ID if (item.getOwnershipDeptName() != null && !item.getOwnershipDeptName().isEmpty()) { TDept ownerDept = tDeptService.lambdaQuery() .eq(TDept::getDeptName, item.getOwnershipDeptName()) .one(); if (ownerDept != null) { assetMain.setOwnershipDeptId(ownerDept.getId()); } } assetMain.setUserName(item.getUserName()); // 根据整单 addressType 写入使用部门ID或仓库ID applyAddressToAssetMain(assetMain, baseDto.getAddressType(), baseDto.getUseDeptName(), baseDto.getWarehouseName(), baseDto.getAddress()); assetMain.setAssetMainType(baseDto.getAddressType()); assetMain.setAssetStatus(item.getAssetStatus()); assetMain.setRemarks(item.getRemarks()); assetMain.setAccountingStatus(item.getAccountingStatus()); assetMain.setAccountingDate(item.getAccountingDate()); assetMain.setAccountingVoucherNo(item.getAccountingVoucherNo()); assetMain.setAccountingSubject(item.getAccountingSubject()); assetMain.setAccountingAmount(item.getAccountingAmount()); assetMain.setDisabled(false); return assetMain; } /** * 构建房产资产主表数据 */ private AssetMain buildAssetMainFromProperty(OaApprovalApplicationStoragePropertyDTO.PropertyAssetItemDTO item, Integer applicationId, Integer assetTypeId, LocalDate storageDate, OaApprovalApplicationStoragePropertyDTO baseDto) { AssetMain assetMain = new AssetMain(); assetMain.setApprovalApplicationId(applicationId.intValue()); assetMain.setAssetOriginalCode(item.getAssetOriginalCode()); assetMain.setAssetCode(generateAssetCode(assetTypeId, storageDate)); assetMain.setAssetName(item.getAssetName()); assetMain.setCategory(item.getCategory()); assetMain.setSpecificationModel(item.getSpecificationModel()); assetMain.setAssetTypeId(assetTypeId); assetMain.setMeasurementUnit(item.getMeasurementUnit()); assetMain.setUnitPrice(item.getUnitPrice()); assetMain.setUsefulLife(item.getUsefulLife()); if (item.getOwnershipDeptName() != null && !item.getOwnershipDeptName().isEmpty()) { TDept ownerDept = tDeptService.lambdaQuery() .eq(TDept::getDeptName, item.getOwnershipDeptName()) .one(); if (ownerDept != null) { assetMain.setOwnershipDeptId(ownerDept.getId()); } } assetMain.setUserName(item.getUserName()); applyAddressToAssetMain(assetMain, baseDto.getAddressType(), baseDto.getUseDeptName(), baseDto.getWarehouseName(), baseDto.getAddress()); assetMain.setAssetMainType(baseDto.getAddressType()); assetMain.setAssetStatus(item.getAssetStatus()); assetMain.setRemarks(item.getRemarks()); assetMain.setAccountingStatus(item.getAccountingStatus()); assetMain.setAccountingDate(item.getAccountingDate()); assetMain.setAccountingVoucherNo(item.getAccountingVoucherNo()); assetMain.setAccountingSubject(item.getAccountingSubject()); assetMain.setAccountingAmount(item.getAccountingAmount()); assetMain.setDisabled(false); return assetMain; } /** * 构建车辆资产主表数据 */ private AssetMain buildAssetMainFromVehicle(OaApprovalApplicationStorageVehicleDTO.VehicleAssetItemDTO item, Integer applicationId, Integer assetTypeId, LocalDate storageDate, OaApprovalApplicationStorageVehicleDTO baseDto) { AssetMain assetMain = new AssetMain(); assetMain.setApprovalApplicationId(applicationId.intValue()); assetMain.setAssetOriginalCode(item.getAssetOriginalCode()); assetMain.setAssetCode(generateAssetCode(assetTypeId, storageDate)); assetMain.setAssetName(item.getAssetName()); assetMain.setCategory(item.getCategory()); assetMain.setSpecificationModel(item.getSpecificationModel()); assetMain.setAssetTypeId(assetTypeId); assetMain.setMeasurementUnit(item.getMeasurementUnit()); assetMain.setUnitPrice(item.getUnitPrice()); assetMain.setUsefulLife(item.getUsefulLife()); if (item.getOwnershipDeptName() != null && !item.getOwnershipDeptName().isEmpty()) { TDept ownerDept = tDeptService.lambdaQuery() .eq(TDept::getDeptName, item.getOwnershipDeptName()) .one(); if (ownerDept != null) { assetMain.setOwnershipDeptId(ownerDept.getId()); } } assetMain.setUserName(item.getUserName()); applyAddressToAssetMain(assetMain, baseDto.getAddressType(), baseDto.getUseDeptName(), baseDto.getWarehouseName(), baseDto.getAddress()); assetMain.setAssetMainType(baseDto.getAddressType()); assetMain.setAssetStatus(item.getAssetStatus()); assetMain.setRemarks(item.getRemarks()); assetMain.setAccountingStatus(item.getAccountingStatus()); assetMain.setAccountingDate(item.getAccountingDate()); assetMain.setAccountingVoucherNo(item.getAccountingVoucherNo()); assetMain.setAccountingSubject(item.getAccountingSubject()); assetMain.setAccountingAmount(item.getAccountingAmount()); assetMain.setDisabled(false); return assetMain; } /** * 按整单地址类型设置资产主表位置信息(使用部门ID或仓库ID或地址) */ private void applyAddressToAssetMain(AssetMain assetMain, Integer addressType, String useDeptName, String warehouseName, String address) { if (addressType == null) { return; } switch (addressType) { case 0: // 使用部门 if (useDeptName != null && !useDeptName.isEmpty()) { TDept dept = tDeptService.lambdaQuery() .eq(TDept::getDeptName, useDeptName) .one(); if (dept != null) { assetMain.setUseDeptId(dept.getId()); } } break; case 1: if (warehouseName != null && !warehouseName.isEmpty()) { AssetWarehouse warehouse = assetWarehouseService.lambdaQuery() .eq(AssetWarehouse::getWarehouseName, warehouseName) .one(); if (warehouse != null) { assetMain.setWarehouseId(warehouse.getId()); assetMain.setWarehouseName(warehouse.getWarehouseName()); } } break; case 2: if (address != null && !address.isEmpty()) { assetMain.setAddress(address); } break; default: // ignore } } /** * 构建通用资产扩展数据 */ private AssetGeneralExt buildAssetGeneralExt(OaApprovalApplicationStorageGeneralDTO.GeneralAssetItemDTO item, Integer assetMainId) { AssetGeneralExt generalExt = new AssetGeneralExt(); generalExt.setAssetMainId(assetMainId); generalExt.setDisabled(false); return generalExt; } /** * 构建房产资产扩展数据 */ private AssetPropertyExt buildAssetPropertyExt(OaApprovalApplicationStoragePropertyDTO.PropertyAssetItemDTO item, Integer assetMainId) { AssetPropertyExt propertyExt = new AssetPropertyExt(); propertyExt.setAssetMainId(assetMainId); propertyExt.setRegion(item.getRegion()); propertyExt.setDesignPurpose(item.getDesignPurpose()); propertyExt.setBuilding(item.getBuilding()); propertyExt.setRoomNumber(item.getRoomNumber()); propertyExt.setConstructionArea(item.getConstructionArea()); propertyExt.setStructureType(item.getStructureType()); propertyExt.setCertificateNumber(item.getCertificateNumber()); propertyExt.setCompletionDate(item.getCompletionDate()); propertyExt.setDetailedLocation(item.getDetailedLocation()); propertyExt.setProvincialPlatformValue(item.getProvincialPlatformValue()); propertyExt.setResettlementSituation(item.getResettlementSituation()); propertyExt.setMortgaged(item.getMortgaged()); propertyExt.setTenantName(item.getTenantName()); propertyExt.setRentalAmount(item.getRentalAmount()); propertyExt.setLeaseStartDate(item.getLeaseStartDate()); propertyExt.setLeaseEndDate(item.getLeaseEndDate()); propertyExt.setDisabled(false); return propertyExt; } /** * 构建车辆资产扩展数据 */ private AssetVehicleExt buildAssetVehicleExt(OaApprovalApplicationStorageVehicleDTO.VehicleAssetItemDTO item, Integer assetMainId) { AssetVehicleExt vehicleExt = new AssetVehicleExt(); vehicleExt.setAssetMainId(assetMainId); vehicleExt.setLicensePlate(item.getLicensePlate()); vehicleExt.setVinCode(item.getVinCode()); vehicleExt.setEngineNumber(item.getEngineNumber()); vehicleExt.setDisplacement(item.getDisplacement()); vehicleExt.setStaffingSituation(item.getStaffingSituation()); vehicleExt.setOrigin(item.getOrigin()); vehicleExt.setAcquisitionDate(item.getAcquisitionDate()); vehicleExt.setPropertyRightForm(item.getPropertyRightForm()); vehicleExt.setDisabled(false); return vehicleExt; } /** * 获取第一个流程节点 */ private OaApprovalFlowNode getFirstFlowNode(Integer approvalId) { List flowNodes = oaApprovalFlowNodeService.lambdaQuery() .eq(OaApprovalFlowNode::getApprovalId, approvalId) .eq(OaApprovalFlowNode::getStatus, 1) .orderByAsc(OaApprovalFlowNode::getSortOrder) .list(); if (CollectionUtils.isEmpty(flowNodes)) { throw new ServiceException("未找到有效的审批流程配置"); } return flowNodes.get(0); } /** * 构建审批申请主表数据 */ private OaApprovalApplications buildOaApprovalApplications(Object dto) { OaApprovalApplications applications = new OaApprovalApplications(); applications.setApprovalId(ApprovalTypeEnum.IN_STOCK.getCode()); applications.setApplicationDate(LocalDate.now()); if (dto instanceof OaApprovalApplicationStorageGeneralDTO) { OaApprovalApplicationStorageGeneralDTO generalDTO = (OaApprovalApplicationStorageGeneralDTO) dto; applications.setApplicantUserId(generalDTO.getApplicantUserId()); applications.setApplicantName(generalDTO.getApplicantName()); applications.setDeptId(generalDTO.getDeptId()); applications.setDeptName(generalDTO.getDeptName()); applications.setApplicationDate(LocalDate.now()); applications.setApplicationReason(generalDTO.getApplicationReason()); applications.setAttachmentUrl(generalDTO.getAttachmentUrl()); } else if (dto instanceof OaApprovalApplicationStoragePropertyDTO) { OaApprovalApplicationStoragePropertyDTO propertyDTO = (OaApprovalApplicationStoragePropertyDTO) dto; applications.setApplicantUserId(propertyDTO.getApplicantUserId()); applications.setApplicantName(propertyDTO.getApplicantName()); applications.setDeptId(propertyDTO.getDeptId()); applications.setDeptName(propertyDTO.getDeptName()); applications.setApplicationDate(LocalDate.now()); applications.setApplicationReason(propertyDTO.getApplicationReason()); applications.setAttachmentUrl(propertyDTO.getAttachmentUrl()); } else if (dto instanceof OaApprovalApplicationStorageVehicleDTO) { OaApprovalApplicationStorageVehicleDTO vehicleDTO = (OaApprovalApplicationStorageVehicleDTO) dto; applications.setApplicantUserId(vehicleDTO.getApplicantUserId()); applications.setApplicantName(vehicleDTO.getApplicantName()); applications.setDeptId(vehicleDTO.getDeptId()); applications.setDeptName(vehicleDTO.getDeptName()); applications.setApplicationDate(LocalDate.now()); applications.setApplicationReason(vehicleDTO.getApplicationReason()); applications.setAttachmentUrl(vehicleDTO.getAttachmentUrl()); } applications.setApplicationCode(generateApplicationCode()); applications.setDisabled(0); applications.setApprovalStatus(ApprovalStatusEnum.PENDING.getCode()); return applications; } /** * 构建资产入库申请明细数据 */ private OaApprovalApplicationStorage buildOaApprovalApplicationStorage(Object dto, Integer applicationId) { OaApprovalApplicationStorage storage = new OaApprovalApplicationStorage(); storage.setApprovalApplicationId(applicationId.intValue()); if (dto instanceof OaApprovalApplicationStorageGeneralDTO) { OaApprovalApplicationStorageGeneralDTO generalDTO = (OaApprovalApplicationStorageGeneralDTO) dto; storage.setTitle(generalDTO.getTitle()); storage.setAssetTypeId(generalDTO.getAssetTypeId()); storage.setStorageType(generalDTO.getStorageType()); storage.setStorageTime(generalDTO.getStorageTime()); } else if (dto instanceof OaApprovalApplicationStoragePropertyDTO) { OaApprovalApplicationStoragePropertyDTO propertyDTO = (OaApprovalApplicationStoragePropertyDTO) dto; storage.setTitle(propertyDTO.getTitle()); storage.setAssetTypeId(propertyDTO.getAssetTypeId()); storage.setStorageType(propertyDTO.getStorageType()); storage.setStorageTime(propertyDTO.getStorageTime()); } else if (dto instanceof OaApprovalApplicationStorageVehicleDTO) { OaApprovalApplicationStorageVehicleDTO vehicleDTO = (OaApprovalApplicationStorageVehicleDTO) dto; storage.setTitle(vehicleDTO.getTitle()); storage.setAssetTypeId(vehicleDTO.getAssetTypeId()); storage.setStorageType(vehicleDTO.getStorageType()); storage.setStorageTime(vehicleDTO.getStorageTime()); } return storage; } /** * 生成申请单号 * 格式:RK + 年月日 + 3位序号 */ private String generateApplicationCode() { String dateStr = LocalDate.now().format(DateTimeFormatter.ofPattern("yyyyMMdd")); String prefix = "RK" + dateStr; Long count = oaApprovalApplicationsService.lambdaQuery() .like(OaApprovalApplications::getApplicationCode, prefix) .ge(OaApprovalApplications::getCreateTime, LocalDate.now().atStartOfDay()) .lt(OaApprovalApplications::getCreateTime, LocalDate.now().plusDays(1).atStartOfDay()) .count(); int sequence = (count != null ? count.intValue() : 0) + 1; String sequenceStr = String.format("%03d", sequence); return prefix + sequenceStr; } /** * 生成资产编码 * 格式:资产类型一级分类简写+资产类型子类简写+入库日期+【-】+数量顺序编号(4位) * 例如:GDFC20250917-0001 */ private String generateAssetCode(Integer assetTypeId, LocalDate storageDate) { // 根据资产类型ID获取资产编码前缀 String typeCodePrefix = assetTypeService.getAssetCodePrefix(assetTypeId); String dateStr = storageDate.format(DateTimeFormatter.ofPattern("yyyyMMdd")); String prefix = typeCodePrefix + dateStr + "-"; // 查询当天该类型资产的数量 Long count = assetMainService.lambdaQuery() .like(AssetMain::getAssetCode, prefix) .ge(AssetMain::getCreateTime, storageDate.atStartOfDay()) .lt(AssetMain::getCreateTime, storageDate.plusDays(1).atStartOfDay()) .count(); int sequence = (count != null ? count.intValue() : 0) + 1; String sequenceStr = String.format("%04d", sequence); return prefix + sequenceStr; } @Override public IPage getPageList(OaApprovalApplicationStoragePageQuery pageQuery) { Page page = new Page<>(pageQuery.getPageNum(), pageQuery.getPageSize()); return this.baseMapper.selectApplicationStoragePage(page, pageQuery); } @Override public OaApprovalApplicationStorageGeneralDetailVO getGeneralDetail(Integer storageId) { OaApprovalApplicationStorage storage = this.getById(storageId); if (storage == null) { throw new ServiceException("入库申请不存在"); } OaApprovalApplications app = oaApprovalApplicationsService.getById(storage.getApprovalApplicationId()); if (app == null) { throw new ServiceException("审批主记录不存在"); } OaApprovalApplicationStorageGeneralDetailVO vo = new OaApprovalApplicationStorageGeneralDetailVO(); fillBaseFields(vo, app, storage); List mains = assetMainService.lambdaQuery() .eq(AssetMain::getApprovalApplicationId, app.getId()) .eq(AssetMain::getAssetTypeId, storage.getAssetTypeId()) .list(); setAddressInfo(vo, mains); if (!CollectionUtils.isEmpty(mains)) { List mainIds = mains.stream().map(AssetMain::getId).collect(Collectors.toList()); // 批量查询权属部门,避免循环内查询 List ownerIds = mains.stream().map(AssetMain::getOwnershipDeptId) .filter(id -> id != null).distinct().collect(Collectors.toList()); Map ownerDeptMap = ownerIds.isEmpty() ? java.util.Collections.emptyMap() : tDeptService.listByIds(ownerIds).stream().collect(Collectors.toMap(TDept::getId, d -> d)); List items = mains.stream().map(m -> { OaApprovalApplicationStorageGeneralDetailVO.GeneralAssetItemVO item = new OaApprovalApplicationStorageGeneralDetailVO.GeneralAssetItemVO(); item.setAssetOriginalCode(m.getAssetOriginalCode()); item.setAssetName(m.getAssetName()); item.setSpecificationModel(m.getSpecificationModel()); item.setMeasurementUnit(m.getMeasurementUnit()); item.setQuantity(m.getQuantity()); item.setUnitPrice(m.getUnitPrice()); item.setUsefulLife(m.getUsefulLife()); if (m.getOwnershipDeptId() != null) { TDept dept = ownerDeptMap.get(m.getOwnershipDeptId()); item.setOwnerShipDeptName(dept != null ? dept.getDeptName() : null); } item.setUserName(m.getUserName()); item.setAssetStatus(m.getAssetStatus()); item.setRemarks(m.getRemarks()); item.setAccountingStatus(m.getAccountingStatus()); item.setAccountingDate(m.getAccountingDate()); item.setAccountingVoucherNo(m.getAccountingVoucherNo()); item.setAccountingSubject(m.getAccountingSubject()); item.setAccountingAmount(m.getAccountingAmount()); return item; }).collect(Collectors.toList()); vo.setAssetItems(items); } return vo; } @Override public OaApprovalApplicationStoragePropertyDetailVO getPropertyDetail(Integer storageId) { OaApprovalApplicationStorage storage = this.getById(storageId); if (storage == null) { throw new ServiceException("入库申请不存在"); } OaApprovalApplications app = oaApprovalApplicationsService.getById(storage.getApprovalApplicationId()); if (app == null) { throw new ServiceException("审批主记录不存在"); } OaApprovalApplicationStoragePropertyDetailVO vo = new OaApprovalApplicationStoragePropertyDetailVO(); fillBaseFields(vo, app, storage); List mains = assetMainService.lambdaQuery() .eq(AssetMain::getApprovalApplicationId, app.getId()) .eq(AssetMain::getAssetTypeId, storage.getAssetTypeId()) .list(); setAddressInfo(vo, mains); if (!CollectionUtils.isEmpty(mains)) { List mainIds = mains.stream().map(AssetMain::getId).collect(Collectors.toList()); List exts = assetPropertyExtService.lambdaQuery().in(AssetPropertyExt::getAssetMainId, mainIds).list(); Map extMap = exts.stream().collect(Collectors.toMap(AssetPropertyExt::getAssetMainId, e -> e)); // 批量查询权属部门 List ownerIds = mains.stream().map(AssetMain::getOwnershipDeptId) .filter(id -> id != null).distinct().collect(Collectors.toList()); Map ownerDeptMap = ownerIds.isEmpty() ? java.util.Collections.emptyMap() : tDeptService.listByIds(ownerIds).stream().collect(Collectors.toMap(TDept::getId, d -> d)); List items = mains.stream().map(m -> { OaApprovalApplicationStoragePropertyDetailVO.PropertyAssetItemVO item = new OaApprovalApplicationStoragePropertyDetailVO.PropertyAssetItemVO(); item.setAssetOriginalCode(m.getAssetOriginalCode()); item.setAssetName(m.getAssetName()); item.setSpecificationModel(m.getSpecificationModel()); item.setMeasurementUnit(m.getMeasurementUnit()); item.setQuantity(m.getQuantity()); item.setUnitPrice(m.getUnitPrice()); item.setUsefulLife(m.getUsefulLife()); if (m.getOwnershipDeptId() != null) { TDept dept = ownerDeptMap.get(m.getOwnershipDeptId()); item.setOwnerShipDeptName(dept != null ? dept.getDeptName() : null); } item.setUserName(m.getUserName()); item.setAssetStatus(m.getAssetStatus()); item.setRemarks(m.getRemarks()); item.setAccountingStatus(m.getAccountingStatus()); item.setAccountingDate(m.getAccountingDate()); item.setAccountingVoucherNo(m.getAccountingVoucherNo()); item.setAccountingSubject(m.getAccountingSubject()); item.setAccountingAmount(m.getAccountingAmount()); AssetPropertyExt ext = extMap.get(m.getId()); if (ext != null) { item.setRegion(ext.getRegion()); item.setDesignPurpose(ext.getDesignPurpose()); item.setBuilding(ext.getBuilding()); item.setRoomNumber(ext.getRoomNumber()); item.setConstructionArea(ext.getConstructionArea()); item.setStructureType(ext.getStructureType()); item.setCertificateNumber(ext.getCertificateNumber()); item.setCompletionDate(ext.getCompletionDate()); item.setDetailedLocation(ext.getDetailedLocation()); item.setProvincialPlatformValue(ext.getProvincialPlatformValue()); item.setResettlementSituation(ext.getResettlementSituation()); item.setMortgaged(ext.getMortgaged()); item.setTenantName(ext.getTenantName()); item.setRentalAmount(ext.getRentalAmount()); item.setLeaseStartDate(ext.getLeaseStartDate()); item.setLeaseEndDate(ext.getLeaseEndDate()); } return item; }).collect(Collectors.toList()); vo.setAssetItems(items); } return vo; } @Override public OaApprovalApplicationStorageVehicleDetailVO getVehicleDetail(Integer storageId) { OaApprovalApplicationStorage storage = this.getById(storageId); if (storage == null) { throw new ServiceException("入库申请不存在"); } OaApprovalApplications app = oaApprovalApplicationsService.getById(storage.getApprovalApplicationId()); if (app == null) { throw new ServiceException("审批主记录不存在"); } OaApprovalApplicationStorageVehicleDetailVO vo = new OaApprovalApplicationStorageVehicleDetailVO(); fillBaseFields(vo, app, storage); List mains = assetMainService.lambdaQuery() .eq(AssetMain::getApprovalApplicationId, app.getId()) .eq(AssetMain::getAssetTypeId, storage.getAssetTypeId()) .list(); setAddressInfo(vo, mains); if (!CollectionUtils.isEmpty(mains)) { List mainIds = mains.stream().map(AssetMain::getId).collect(Collectors.toList()); List exts = assetVehicleExtService.lambdaQuery().in(AssetVehicleExt::getAssetMainId, mainIds).list(); Map extMap = exts.stream().collect(Collectors.toMap(AssetVehicleExt::getAssetMainId, e -> e)); // 批量查询权属部门 List ownerIds = mains.stream().map(AssetMain::getOwnershipDeptId) .filter(id -> id != null).distinct().collect(Collectors.toList()); Map ownerDeptMap = ownerIds.isEmpty() ? java.util.Collections.emptyMap() : tDeptService.listByIds(ownerIds).stream().collect(Collectors.toMap(TDept::getId, d -> d)); List items = mains.stream().map(m -> { OaApprovalApplicationStorageVehicleDetailVO.VehicleAssetItemVO item = new OaApprovalApplicationStorageVehicleDetailVO.VehicleAssetItemVO(); item.setAssetOriginalCode(m.getAssetOriginalCode()); item.setAssetName(m.getAssetName()); item.setSpecificationModel(m.getSpecificationModel()); item.setMeasurementUnit(m.getMeasurementUnit()); item.setQuantity(m.getQuantity()); item.setUnitPrice(m.getUnitPrice()); item.setUsefulLife(m.getUsefulLife()); if (m.getOwnershipDeptId() != null) { TDept dept = ownerDeptMap.get(m.getOwnershipDeptId()); item.setOwnerShipDeptName(dept != null ? dept.getDeptName() : null); } item.setUserName(m.getUserName()); item.setAssetStatus(m.getAssetStatus()); item.setRemarks(m.getRemarks()); item.setAccountingStatus(m.getAccountingStatus()); item.setAccountingDate(m.getAccountingDate()); item.setAccountingVoucherNo(m.getAccountingVoucherNo()); item.setAccountingSubject(m.getAccountingSubject()); item.setAccountingAmount(m.getAccountingAmount()); AssetVehicleExt ext = extMap.get(m.getId()); if (ext != null) { item.setLicensePlate(ext.getLicensePlate()); item.setVinCode(ext.getVinCode()); item.setEngineNumber(ext.getEngineNumber()); item.setDisplacement(ext.getDisplacement()); item.setStaffingSituation(ext.getStaffingSituation()); item.setOrigin(ext.getOrigin()); item.setAcquisitionDate(ext.getAcquisitionDate()); item.setPropertyRightForm(ext.getPropertyRightForm()); } return item; }).collect(Collectors.toList()); vo.setAssetItems(items); } return vo; } private void fillBaseFields(Object vo, OaApprovalApplications app, OaApprovalApplicationStorage storage) { if (vo instanceof OaApprovalApplicationStorageGeneralDetailVO) { OaApprovalApplicationStorageGeneralDetailVO v = (OaApprovalApplicationStorageGeneralDetailVO) vo; v.setDeptId(app.getDeptId()); v.setDeptName(app.getDeptName()); v.setApplicantUserId(app.getApplicantUserId()); v.setApplicantName(app.getApplicantName()); v.setApplicationDate(app.getApplicationDate()); v.setApplicationReason(app.getApplicationReason()); v.setAttachmentUrl(app.getAttachmentUrl()); v.setTitle(storage.getTitle()); v.setAssetTypeId(storage.getAssetTypeId()); v.setStorageType(storage.getStorageType()); v.setStorageTime(storage.getStorageTime()); } else if (vo instanceof OaApprovalApplicationStoragePropertyDetailVO) { OaApprovalApplicationStoragePropertyDetailVO v = (OaApprovalApplicationStoragePropertyDetailVO) vo; v.setDeptId(app.getDeptId()); v.setDeptName(app.getDeptName()); v.setApplicantUserId(app.getApplicantUserId()); v.setApplicantName(app.getApplicantName()); v.setApplicationDate(app.getApplicationDate()); v.setApplicationReason(app.getApplicationReason()); v.setAttachmentUrl(app.getAttachmentUrl()); v.setTitle(storage.getTitle()); v.setAssetTypeId(storage.getAssetTypeId()); v.setStorageType(storage.getStorageType()); v.setStorageTime(storage.getStorageTime()); } else if (vo instanceof OaApprovalApplicationStorageVehicleDetailVO) { OaApprovalApplicationStorageVehicleDetailVO v = (OaApprovalApplicationStorageVehicleDetailVO) vo; v.setDeptId(app.getDeptId()); v.setDeptName(app.getDeptName()); v.setApplicantUserId(app.getApplicantUserId()); v.setApplicantName(app.getApplicantName()); v.setApplicationDate(app.getApplicationDate()); v.setApplicationReason(app.getApplicationReason()); v.setAttachmentUrl(app.getAttachmentUrl()); v.setTitle(storage.getTitle()); v.setAssetTypeId(storage.getAssetTypeId()); v.setStorageType(storage.getStorageType()); v.setStorageTime(storage.getStorageTime()); } } private void setAddressInfo(Object vo, List mains) { if (CollectionUtils.isEmpty(mains)) { return; } AssetMain sample = mains.get(0); Integer addressType = null; String useDeptName = null; String warehouseName = null; String address = null; if (sample.getUseDeptId() != null) { addressType = 0; TDept dept = tDeptService.getById(sample.getUseDeptId()); useDeptName = dept != null ? dept.getDeptName() : null; } else if (sample.getWarehouseId() != null) { addressType = 1; AssetWarehouse wh = assetWarehouseService.getById(sample.getWarehouseId()); warehouseName = wh != null ? wh.getWarehouseName() : null; } else if (sample.getAddress() != null && !sample.getAddress().isEmpty()) { addressType = 2; address = sample.getAddress(); } if (vo instanceof OaApprovalApplicationStorageGeneralDetailVO) { OaApprovalApplicationStorageGeneralDetailVO v = (OaApprovalApplicationStorageGeneralDetailVO) vo; v.setAddressType(addressType); v.setUseDeptName(useDeptName); v.setWarehouseName(warehouseName); v.setAddress(address); } else if (vo instanceof OaApprovalApplicationStoragePropertyDetailVO) { OaApprovalApplicationStoragePropertyDetailVO v = (OaApprovalApplicationStoragePropertyDetailVO) vo; v.setAddressType(addressType); v.setUseDeptName(useDeptName); v.setWarehouseName(warehouseName); v.setAddress(address); } else if (vo instanceof OaApprovalApplicationStorageVehicleDetailVO) { OaApprovalApplicationStorageVehicleDetailVO v = (OaApprovalApplicationStorageVehicleDetailVO) vo; v.setAddressType(addressType); v.setUseDeptName(useDeptName); v.setWarehouseName(warehouseName); v.setAddress(address); } } }