From bb5ce8ef60a63815f222716c40111bd045464689 Mon Sep 17 00:00:00 2001 From: mitao <2763622819@qq.com> Date: 星期二, 30 九月 2025 18:32:10 +0800 Subject: [PATCH] 资产维修记录列表查询接口 --- ruoyi-system/src/main/java/com/ruoyi/system/service/impl/OaApprovalApplicationStorageServiceImpl.java | 594 +++++++++++++++++++++------------------------------------- 1 files changed, 216 insertions(+), 378 deletions(-) diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/OaApprovalApplicationStorageServiceImpl.java b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/OaApprovalApplicationStorageServiceImpl.java index a197e1c..97d8f45 100644 --- a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/OaApprovalApplicationStorageServiceImpl.java +++ b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/OaApprovalApplicationStorageServiceImpl.java @@ -1,8 +1,11 @@ package com.ruoyi.system.service.impl; +import cn.hutool.core.bean.BeanUtil; +import cn.hutool.core.collection.CollUtil; 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.basic.PageInfo; import com.ruoyi.common.core.domain.entity.TDept; import com.ruoyi.common.exception.ServiceException; import com.ruoyi.system.dto.asset.OaApprovalApplicationStorageGeneralDTO; @@ -12,43 +15,44 @@ 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.OaApprovalApplicationStorageAsset; +import com.ruoyi.system.model.OaApprovalApplicationStorageAssetPropertyExt; +import com.ruoyi.system.model.OaApprovalApplicationStorageAssetVehicleExt; import com.ruoyi.system.model.OaApprovalApplications; import com.ruoyi.system.model.OaApprovalFlowNode; +import com.ruoyi.system.query.ApprovalDetailQuery; 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.OaApprovalApplicationStorageAssetPropertyExtService; +import com.ruoyi.system.service.OaApprovalApplicationStorageAssetService; +import com.ruoyi.system.service.OaApprovalApplicationStorageAssetVehicleExtService; 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.StorageListVO; 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.beans.BeanUtils; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; import org.springframework.util.CollectionUtils; import java.math.BigDecimal; +import java.math.RoundingMode; import java.time.LocalDate; import java.time.format.DateTimeFormatter; import java.util.ArrayList; +import java.util.Collections; import java.util.List; import java.util.Map; +import java.util.Objects; import java.util.stream.Collectors; /** @@ -64,15 +68,11 @@ public class OaApprovalApplicationStorageServiceImpl extends ServiceImpl<OaApprovalApplicationStorageMapper, OaApprovalApplicationStorage> 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 OaApprovalApplicationStorageAssetService oaApprovalApplicationStorageAssetService; + private final OaApprovalApplicationStorageAssetPropertyExtService oaApprovalApplicationStorageAssetPropertyExtService; + private final OaApprovalApplicationStorageAssetVehicleExtService oaApprovalApplicationStorageAssetVehicleExtService; private final OaApprovalFlowNodeService oaApprovalFlowNodeService; private final OaApprovalTodoService oaApprovalTodoService; - private final ISysUserService sysUserService; - private final ISysDeptService sysDeptService; private final TDeptService tDeptService; private final AssetWarehouseService assetWarehouseService; @@ -146,111 +146,78 @@ * 保存通用资产数据 */ private void saveGeneralAssets(List<OaApprovalApplicationStorageGeneralDTO.GeneralAssetItemDTO> assetItems, Integer applicationId, Integer assetTypeId, LocalDate storageDate, OaApprovalApplicationStorageGeneralDTO baseDto) { - List<AssetMain> allAssetMains = new ArrayList<>(); + List<OaApprovalApplicationStorageAsset> storageAssets = 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); - } + OaApprovalApplicationStorageAsset assetMain = buildAssetMain(item, applicationId, assetTypeId, storageDate, baseDto); + assetMain.setAssetMainType(AssetTypeEnum.GENERAL.getCode()); + storageAssets.add(assetMain); } - // 批量保存资产主表数据 - assetMainService.saveBatch(allAssetMains); + oaApprovalApplicationStorageAssetService.saveBatch(storageAssets); } /** * 保存房产资产数据 */ private void savePropertyAssets(List<OaApprovalApplicationStoragePropertyDTO.PropertyAssetItemDTO> assetItems, Integer applicationId, Integer assetTypeId, LocalDate storageDate, OaApprovalApplicationStoragePropertyDTO baseDto) { - List<AssetMain> allAssetMains = new ArrayList<>(); - List<AssetPropertyExt> allPropertyExts = new ArrayList<>(); + List<OaApprovalApplicationStorageAsset> allAssetMains = new ArrayList<>(); + List<OaApprovalApplicationStorageAssetPropertyExt> 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); - } + OaApprovalApplicationStorageAsset assetMain = buildAssetMainFromProperty(item, applicationId, assetTypeId, storageDate, baseDto); + assetMain.setAssetMainType(AssetTypeEnum.HOUSE.getCode()); + allAssetMains.add(assetMain); } // 批量保存资产主表数据 - assetMainService.saveBatch(allAssetMains); + oaApprovalApplicationStorageAssetService.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()); + for (OaApprovalApplicationStorageAsset allAssetMain : allAssetMains) { + for (OaApprovalApplicationStoragePropertyDTO.PropertyAssetItemDTO item : assetItems) { + OaApprovalApplicationStorageAssetPropertyExt propertyExt = buildAssetPropertyExt(item, allAssetMain.getId()); allPropertyExts.add(propertyExt); - assetMainIndex++; } } - - assetPropertyExtService.saveBatch(allPropertyExts); + oaApprovalApplicationStorageAssetPropertyExtService.saveBatch(allPropertyExts); } /** * 保存车辆资产数据 */ private void saveVehicleAssets(List<OaApprovalApplicationStorageVehicleDTO.VehicleAssetItemDTO> assetItems, Integer applicationId, Integer assetTypeId, LocalDate storageDate, OaApprovalApplicationStorageVehicleDTO baseDto) { - List<AssetMain> allAssetMains = new ArrayList<>(); - List<AssetVehicleExt> allVehicleExts = new ArrayList<>(); - + List<OaApprovalApplicationStorageAsset> allAssetMains = new ArrayList<>(); + List<OaApprovalApplicationStorageAssetVehicleExt> 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); - } + OaApprovalApplicationStorageAsset assetMain = buildAssetMainFromVehicle(item, applicationId, assetTypeId, storageDate, baseDto); + assetMain.setAssetMainType(AssetTypeEnum.VEHICLE.getCode()); + allAssetMains.add(assetMain); } // 批量保存资产主表数据 - assetMainService.saveBatch(allAssetMains); + oaApprovalApplicationStorageAssetService.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()); + for (OaApprovalApplicationStorageAsset allAssetMain : allAssetMains) { + for (OaApprovalApplicationStorageVehicleDTO.VehicleAssetItemDTO item : assetItems) { + OaApprovalApplicationStorageAssetVehicleExt vehicleExt = buildAssetVehicleExt(item, allAssetMain.getId()); allVehicleExts.add(vehicleExt); - assetMainIndex++; } + } - - assetVehicleExtService.saveBatch(allVehicleExts); + oaApprovalApplicationStorageAssetVehicleExtService.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()); + private OaApprovalApplicationStorageAsset buildAssetMain(OaApprovalApplicationStorageGeneralDTO.GeneralAssetItemDTO item, Integer applicationId, Integer assetTypeId, LocalDate storageDate, OaApprovalApplicationStorageGeneralDTO baseDto) { + OaApprovalApplicationStorageAsset assetMain = BeanUtil.copyProperties(item, OaApprovalApplicationStorageAsset.class); + assetMain.setApprovalApplicationId(applicationId); 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() @@ -260,36 +227,19 @@ 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); + applyAddressToAssetMain(assetMain, item.getAddressType(), item.getUseDeptName(), item.getWarehouseName(), item.getAddress()); + assetMain.setAssetMainType(AssetTypeEnum.GENERAL.getCode()); 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()); + private OaApprovalApplicationStorageAsset buildAssetMainFromProperty(OaApprovalApplicationStoragePropertyDTO.PropertyAssetItemDTO item, Integer applicationId, Integer assetTypeId, LocalDate storageDate, OaApprovalApplicationStoragePropertyDTO baseDto) { + OaApprovalApplicationStorageAsset assetMain = BeanUtil.copyProperties(item, OaApprovalApplicationStorageAsset.class); + assetMain.setApprovalApplicationId(applicationId); 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()) @@ -298,35 +248,18 @@ 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); + applyAddressToAssetMain(assetMain, item.getAddressType(), item.getUseDeptName(), item.getWarehouseName(), item.getAddress()); + assetMain.setAssetMainType(AssetTypeEnum.HOUSE.getCode()); 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()); + private OaApprovalApplicationStorageAsset buildAssetMainFromVehicle(OaApprovalApplicationStorageVehicleDTO.VehicleAssetItemDTO item, Integer applicationId, Integer assetTypeId, LocalDate storageDate, OaApprovalApplicationStorageVehicleDTO baseDto) { + OaApprovalApplicationStorageAsset assetMain = BeanUtil.copyProperties(item, OaApprovalApplicationStorageAsset.class); + assetMain.setApprovalApplicationId(applicationId); 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()) @@ -335,24 +268,15 @@ 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); + applyAddressToAssetMain(assetMain, item.getAddressType(), item.getUseDeptName(), item.getWarehouseName(), item.getAddress()); + assetMain.setAssetMainType(AssetTypeEnum.VEHICLE.getCode()); return assetMain; } /** * 按整单地址类型设置资产主表位置信息(使用部门ID或仓库ID或地址) */ - private void applyAddressToAssetMain(AssetMain assetMain, Integer addressType, String useDeptName, String warehouseName, String address) { + private void applyAddressToAssetMain(OaApprovalApplicationStorageAsset assetMain, Integer addressType, String useDeptName, String warehouseName, String address) { if (addressType == null) { return; } @@ -389,57 +313,23 @@ } } - /** - * 构建通用资产扩展数据 - */ - 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); + private OaApprovalApplicationStorageAssetPropertyExt buildAssetPropertyExt(OaApprovalApplicationStoragePropertyDTO.PropertyAssetItemDTO item, Integer assetMainId) { + OaApprovalApplicationStorageAssetPropertyExt propertyExt = BeanUtil.copyProperties(item, OaApprovalApplicationStorageAssetPropertyExt.class); + propertyExt.setStorageAssetId(assetMainId); 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); + private OaApprovalApplicationStorageAssetVehicleExt buildAssetVehicleExt(OaApprovalApplicationStorageVehicleDTO.VehicleAssetItemDTO item, Integer assetMainId) { + OaApprovalApplicationStorageAssetVehicleExt vehicleExt = BeanUtil.copyProperties(item, OaApprovalApplicationStorageAssetVehicleExt.class); + vehicleExt.setStorageAssetId(assetMainId); return vehicleExt; } @@ -466,39 +356,20 @@ */ 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()); + BeanUtils.copyProperties(generalDTO, applications); } 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()); + BeanUtils.copyProperties(propertyDTO, applications); } 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()); + BeanUtils.copyProperties(vehicleDTO, applications); } - + applications.setApprovalId(ApprovalTypeEnum.IN_STOCK.getCode()); + applications.setApplicationDate(LocalDate.now()); applications.setApplicationCode(generateApplicationCode()); - applications.setDisabled(0); applications.setApprovalStatus(ApprovalStatusEnum.PENDING.getCode()); return applications; } @@ -508,26 +379,17 @@ */ private OaApprovalApplicationStorage buildOaApprovalApplicationStorage(Object dto, Integer applicationId) { OaApprovalApplicationStorage storage = new OaApprovalApplicationStorage(); - storage.setApprovalApplicationId(applicationId.intValue()); + storage.setApprovalApplicationId(applicationId); if (dto instanceof OaApprovalApplicationStorageGeneralDTO) { OaApprovalApplicationStorageGeneralDTO generalDTO = (OaApprovalApplicationStorageGeneralDTO) dto; - storage.setTitle(generalDTO.getTitle()); - storage.setAssetTypeId(generalDTO.getAssetTypeId()); - storage.setStorageType(generalDTO.getStorageType()); - storage.setStorageTime(generalDTO.getStorageTime()); + BeanUtils.copyProperties(generalDTO, storage); } 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()); + BeanUtils.copyProperties(propertyDTO, storage); } 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()); + BeanUtils.copyProperties(vehicleDTO, storage); } return storage; @@ -553,31 +415,6 @@ 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<OaApprovalApplicationStoragePageVO> getPageList(OaApprovalApplicationStoragePageQuery pageQuery) { Page<OaApprovalApplicationStoragePageVO> page = new Page<>(pageQuery.getPageNum(), pageQuery.getPageSize()); @@ -585,54 +422,53 @@ } @Override - public OaApprovalApplicationStorageGeneralDetailVO getGeneralDetail(Integer storageId) { - OaApprovalApplicationStorage storage = this.getById(storageId); - if (storage == null) { - throw new ServiceException("入库申请不存在"); - } - OaApprovalApplications app = oaApprovalApplicationsService.getById(storage.getApprovalApplicationId()); + public OaApprovalApplicationStorageGeneralDetailVO getGeneralDetail(Integer approvalApplicationId) { + OaApprovalApplications app = oaApprovalApplicationsService.getById(approvalApplicationId); if (app == null) { throw new ServiceException("审批主记录不存在"); + } + OaApprovalApplicationStorage storage = this.lambdaQuery() + .eq(OaApprovalApplicationStorage::getApprovalApplicationId, approvalApplicationId).one(); + if (storage == null) { + throw new ServiceException("入库申请不存在"); } OaApprovalApplicationStorageGeneralDetailVO vo = new OaApprovalApplicationStorageGeneralDetailVO(); fillBaseFields(vo, app, storage); - List<AssetMain> mains = assetMainService.lambdaQuery() - .eq(AssetMain::getApprovalApplicationId, app.getId()) - .eq(AssetMain::getAssetTypeId, storage.getAssetTypeId()) + List<OaApprovalApplicationStorageAsset> mains = oaApprovalApplicationStorageAssetService.lambdaQuery() + .eq(OaApprovalApplicationStorageAsset::getApprovalApplicationId, app.getId()) + .eq(OaApprovalApplicationStorageAsset::getAssetTypeId, storage.getAssetTypeId()) .list(); - setAddressInfo(vo, mains); - if (!CollectionUtils.isEmpty(mains)) { - List<Integer> mainIds = mains.stream().map(AssetMain::getId).collect(Collectors.toList()); - // 批量查询权属部门,避免循环内查询 - List<Integer> ownerIds = mains.stream().map(AssetMain::getOwnershipDeptId) - .filter(id -> id != null).distinct().collect(Collectors.toList()); - Map<Integer, TDept> ownerDeptMap = ownerIds.isEmpty() ? java.util.Collections.emptyMap() + // 批量查询权属部门 + List<Integer> ownerIds = mains.stream().map(OaApprovalApplicationStorageAsset::getOwnershipDeptId) + .filter(Objects::nonNull).distinct().collect(Collectors.toList()); + Map<Integer, TDept> ownerDeptMap = ownerIds.isEmpty() ? Collections.emptyMap() : tDeptService.listByIds(ownerIds).stream().collect(Collectors.toMap(TDept::getId, d -> d)); - + // 批量查询使用部门 + List<Integer> useDeptIds = mains.stream().map(OaApprovalApplicationStorageAsset::getUseDeptId) + .filter(Objects::nonNull).distinct().collect(Collectors.toList()); + Map<Integer, TDept> useDeptMap = useDeptIds.isEmpty() ? Collections.emptyMap() + : tDeptService.listByIds(useDeptIds).stream().collect(Collectors.toMap(TDept::getId, d -> d)); + // 批量查询仓库 + List<Integer> warehouseIds = mains.stream().map(OaApprovalApplicationStorageAsset::getWarehouseId) + .filter(Objects::nonNull).distinct().collect(Collectors.toList()); + Map<Integer, AssetWarehouse> warehouseMap = warehouseIds.isEmpty() ? Collections.emptyMap() + : assetWarehouseService.listByIds(warehouseIds).stream().collect(Collectors.toMap(AssetWarehouse::getId, d -> d)); List<OaApprovalApplicationStorageGeneralDetailVO.GeneralAssetItemVO> 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()); + OaApprovalApplicationStorageGeneralDetailVO.GeneralAssetItemVO item = BeanUtil.copyProperties(m, OaApprovalApplicationStorageGeneralDetailVO.GeneralAssetItemVO.class); if (m.getOwnershipDeptId() != null) { TDept dept = ownerDeptMap.get(m.getOwnershipDeptId()); - item.setOwnerShipDeptName(dept != null ? dept.getDeptName() : null); + 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()); + if (m.getAddressType().equals(0) && m.getUseDeptId() != null) { + TDept dept = useDeptMap.get(m.getUseDeptId()); + item.setUseDeptName(dept != null ? dept.getDeptName() : null); + } else if (m.getAddressType().equals(1) && m.getWarehouseId() != null){ + AssetWarehouse assetWarehouse = warehouseMap.get(m.getWarehouseId()); + item.setWarehouseName(assetWarehouse != null ? assetWarehouse.getWarehouseName() : null); + } return item; }).collect(Collectors.toList()); vo.setAssetItems(items); @@ -641,57 +477,59 @@ } @Override - public OaApprovalApplicationStoragePropertyDetailVO getPropertyDetail(Integer storageId) { - OaApprovalApplicationStorage storage = this.getById(storageId); - if (storage == null) { - throw new ServiceException("入库申请不存在"); - } - OaApprovalApplications app = oaApprovalApplicationsService.getById(storage.getApprovalApplicationId()); + public OaApprovalApplicationStoragePropertyDetailVO getPropertyDetail(Integer approvalApplicationId) { + OaApprovalApplications app = oaApprovalApplicationsService.getById(approvalApplicationId); if (app == null) { throw new ServiceException("审批主记录不存在"); + } + OaApprovalApplicationStorage storage = this.lambdaQuery() + .eq(OaApprovalApplicationStorage::getApprovalApplicationId, approvalApplicationId).one(); + if (storage == null) { + throw new ServiceException("入库申请不存在"); } OaApprovalApplicationStoragePropertyDetailVO vo = new OaApprovalApplicationStoragePropertyDetailVO(); fillBaseFields(vo, app, storage); - List<AssetMain> mains = assetMainService.lambdaQuery() - .eq(AssetMain::getApprovalApplicationId, app.getId()) - .eq(AssetMain::getAssetTypeId, storage.getAssetTypeId()) + List<OaApprovalApplicationStorageAsset> mains = oaApprovalApplicationStorageAssetService.lambdaQuery() + .eq(OaApprovalApplicationStorageAsset::getApprovalApplicationId, app.getId()) + .eq(OaApprovalApplicationStorageAsset::getAssetTypeId, storage.getAssetTypeId()) .list(); - setAddressInfo(vo, mains); if (!CollectionUtils.isEmpty(mains)) { - List<Integer> mainIds = mains.stream().map(AssetMain::getId).collect(Collectors.toList()); - List<AssetPropertyExt> exts = assetPropertyExtService.lambdaQuery().in(AssetPropertyExt::getAssetMainId, mainIds).list(); - Map<Integer, AssetPropertyExt> extMap = exts.stream().collect(Collectors.toMap(AssetPropertyExt::getAssetMainId, e -> e)); + List<Integer> mainIds = mains.stream().map(OaApprovalApplicationStorageAsset::getId).collect(Collectors.toList()); + List<OaApprovalApplicationStorageAssetPropertyExt> exts = oaApprovalApplicationStorageAssetPropertyExtService.lambdaQuery().in(OaApprovalApplicationStorageAssetPropertyExt::getStorageAssetId, mainIds).list(); + Map<Integer, OaApprovalApplicationStorageAssetPropertyExt> extMap = exts.stream().collect(Collectors.toMap(OaApprovalApplicationStorageAssetPropertyExt::getStorageAssetId, e -> e)); // 批量查询权属部门 - List<Integer> ownerIds = mains.stream().map(AssetMain::getOwnershipDeptId) + List<Integer> ownerIds = mains.stream().map(OaApprovalApplicationStorageAsset::getOwnershipDeptId) .filter(id -> id != null).distinct().collect(Collectors.toList()); Map<Integer, TDept> ownerDeptMap = ownerIds.isEmpty() ? java.util.Collections.emptyMap() : tDeptService.listByIds(ownerIds).stream().collect(Collectors.toMap(TDept::getId, d -> d)); + // 批量查询使用部门 + List<Integer> useDeptIds = mains.stream().map(OaApprovalApplicationStorageAsset::getUseDeptId) + .filter(Objects::nonNull).distinct().collect(Collectors.toList()); + Map<Integer, TDept> useDeptMap = useDeptIds.isEmpty() ? Collections.emptyMap() + : tDeptService.listByIds(useDeptIds).stream().collect(Collectors.toMap(TDept::getId, d -> d)); + // 批量查询仓库 + List<Integer> warehouseIds = mains.stream().map(OaApprovalApplicationStorageAsset::getWarehouseId) + .filter(Objects::nonNull).distinct().collect(Collectors.toList()); + Map<Integer, AssetWarehouse> warehouseMap = warehouseIds.isEmpty() ? Collections.emptyMap() + : assetWarehouseService.listByIds(warehouseIds).stream().collect(Collectors.toMap(AssetWarehouse::getId, d -> d)); List<OaApprovalApplicationStoragePropertyDetailVO.PropertyAssetItemVO> 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()); + OaApprovalApplicationStoragePropertyDetailVO.PropertyAssetItemVO item = BeanUtil.copyProperties(m, OaApprovalApplicationStoragePropertyDetailVO.PropertyAssetItemVO.class); if (m.getOwnershipDeptId() != null) { TDept dept = ownerDeptMap.get(m.getOwnershipDeptId()); - item.setOwnerShipDeptName(dept != null ? dept.getDeptName() : null); + 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 (m.getAddressType().equals(0) && m.getUseDeptId() != null) { + TDept dept = useDeptMap.get(m.getUseDeptId()); + item.setUseDeptName(dept != null ? dept.getDeptName() : null); + } else if (m.getAddressType().equals(1) && m.getWarehouseId() != null){ + AssetWarehouse assetWarehouse = warehouseMap.get(m.getWarehouseId()); + item.setWarehouseName(assetWarehouse != null ? assetWarehouse.getWarehouseName() : null); + } + OaApprovalApplicationStorageAssetPropertyExt ext = extMap.get(m.getId()); if (ext != null) { item.setRegion(ext.getRegion()); item.setDesignPurpose(ext.getDesignPurpose()); @@ -718,57 +556,58 @@ } @Override - public OaApprovalApplicationStorageVehicleDetailVO getVehicleDetail(Integer storageId) { - OaApprovalApplicationStorage storage = this.getById(storageId); - if (storage == null) { - throw new ServiceException("入库申请不存在"); - } - OaApprovalApplications app = oaApprovalApplicationsService.getById(storage.getApprovalApplicationId()); + public OaApprovalApplicationStorageVehicleDetailVO getVehicleDetail(Integer approvalApplicationId) { + OaApprovalApplications app = oaApprovalApplicationsService.getById(approvalApplicationId); if (app == null) { throw new ServiceException("审批主记录不存在"); + } + OaApprovalApplicationStorage storage = this.lambdaQuery() + .eq(OaApprovalApplicationStorage::getApprovalApplicationId, approvalApplicationId).one(); + if (storage == null) { + throw new ServiceException("入库申请不存在"); } OaApprovalApplicationStorageVehicleDetailVO vo = new OaApprovalApplicationStorageVehicleDetailVO(); fillBaseFields(vo, app, storage); - List<AssetMain> mains = assetMainService.lambdaQuery() - .eq(AssetMain::getApprovalApplicationId, app.getId()) - .eq(AssetMain::getAssetTypeId, storage.getAssetTypeId()) + List<OaApprovalApplicationStorageAsset> mains = oaApprovalApplicationStorageAssetService.lambdaQuery() + .eq(OaApprovalApplicationStorageAsset::getApprovalApplicationId, app.getId()) + .eq(OaApprovalApplicationStorageAsset::getAssetTypeId, storage.getAssetTypeId()) .list(); - setAddressInfo(vo, mains); if (!CollectionUtils.isEmpty(mains)) { - List<Integer> mainIds = mains.stream().map(AssetMain::getId).collect(Collectors.toList()); - List<AssetVehicleExt> exts = assetVehicleExtService.lambdaQuery().in(AssetVehicleExt::getAssetMainId, mainIds).list(); - Map<Integer, AssetVehicleExt> extMap = exts.stream().collect(Collectors.toMap(AssetVehicleExt::getAssetMainId, e -> e)); + List<Integer> mainIds = mains.stream().map(OaApprovalApplicationStorageAsset::getId).collect(Collectors.toList()); + List<OaApprovalApplicationStorageAssetVehicleExt> exts = oaApprovalApplicationStorageAssetVehicleExtService.lambdaQuery().in(OaApprovalApplicationStorageAssetVehicleExt::getStorageAssetId, mainIds).list(); + Map<Integer, OaApprovalApplicationStorageAssetVehicleExt> extMap = exts.stream().collect(Collectors.toMap(OaApprovalApplicationStorageAssetVehicleExt::getStorageAssetId, e -> e)); // 批量查询权属部门 - List<Integer> ownerIds = mains.stream().map(AssetMain::getOwnershipDeptId) + List<Integer> ownerIds = mains.stream().map(OaApprovalApplicationStorageAsset::getOwnershipDeptId) .filter(id -> id != null).distinct().collect(Collectors.toList()); Map<Integer, TDept> ownerDeptMap = ownerIds.isEmpty() ? java.util.Collections.emptyMap() : tDeptService.listByIds(ownerIds).stream().collect(Collectors.toMap(TDept::getId, d -> d)); - + // 批量查询使用部门 + List<Integer> useDeptIds = mains.stream().map(OaApprovalApplicationStorageAsset::getUseDeptId) + .filter(Objects::nonNull).distinct().collect(Collectors.toList()); + Map<Integer, TDept> useDeptMap = useDeptIds.isEmpty() ? Collections.emptyMap() + : tDeptService.listByIds(useDeptIds).stream().collect(Collectors.toMap(TDept::getId, d -> d)); + // 批量查询仓库 + List<Integer> warehouseIds = mains.stream().map(OaApprovalApplicationStorageAsset::getWarehouseId) + .filter(Objects::nonNull).distinct().collect(Collectors.toList()); + Map<Integer, AssetWarehouse> warehouseMap = warehouseIds.isEmpty() ? Collections.emptyMap() + : assetWarehouseService.listByIds(warehouseIds).stream().collect(Collectors.toMap(AssetWarehouse::getId, d -> d)); List<OaApprovalApplicationStorageVehicleDetailVO.VehicleAssetItemVO> 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()); + OaApprovalApplicationStorageVehicleDetailVO.VehicleAssetItemVO item = BeanUtil.copyProperties(m, OaApprovalApplicationStorageVehicleDetailVO.VehicleAssetItemVO.class); if (m.getOwnershipDeptId() != null) { TDept dept = ownerDeptMap.get(m.getOwnershipDeptId()); - item.setOwnerShipDeptName(dept != null ? dept.getDeptName() : null); + 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 (m.getAddressType().equals(0) && m.getUseDeptId() != null) { + TDept dept = useDeptMap.get(m.getUseDeptId()); + item.setUseDeptName(dept != null ? dept.getDeptName() : null); + } else if (m.getAddressType().equals(1) && m.getWarehouseId() != null){ + AssetWarehouse assetWarehouse = warehouseMap.get(m.getWarehouseId()); + item.setWarehouseName(assetWarehouse != null ? assetWarehouse.getWarehouseName() : null); + } + OaApprovalApplicationStorageAssetVehicleExt ext = extMap.get(m.getId()); if (ext != null) { item.setLicensePlate(ext.getLicensePlate()); item.setVinCode(ext.getVinCode()); @@ -793,6 +632,7 @@ v.setDeptName(app.getDeptName()); v.setApplicantUserId(app.getApplicantUserId()); v.setApplicantName(app.getApplicantName()); + v.setApprovalStatus(app.getApprovalStatus()); v.setApplicationDate(app.getApplicationDate()); v.setApplicationReason(app.getApplicationReason()); v.setAttachmentUrl(app.getAttachmentUrl()); @@ -806,6 +646,7 @@ v.setDeptName(app.getDeptName()); v.setApplicantUserId(app.getApplicantUserId()); v.setApplicantName(app.getApplicantName()); + v.setApprovalStatus(app.getApprovalStatus()); v.setApplicationDate(app.getApplicationDate()); v.setApplicationReason(app.getApplicationReason()); v.setAttachmentUrl(app.getAttachmentUrl()); @@ -819,6 +660,7 @@ v.setDeptName(app.getDeptName()); v.setApplicantUserId(app.getApplicantUserId()); v.setApplicantName(app.getApplicantName()); + v.setApprovalStatus(app.getApprovalStatus()); v.setApplicationDate(app.getApplicationDate()); v.setApplicationReason(app.getApplicationReason()); v.setAttachmentUrl(app.getAttachmentUrl()); @@ -829,46 +671,42 @@ } } - private void setAddressInfo(Object vo, List<AssetMain> mains) { - if (CollectionUtils.isEmpty(mains)) { - return; + @Override + public PageInfo<StorageListVO> pageList(ApprovalDetailQuery query) { + PageInfo<StorageListVO> pageInfo = new PageInfo<>(query.getPageNum(), query.getPageSize()); + List<StorageListVO> list = this.baseMapper.pageList(query,pageInfo); + for (StorageListVO storageListVO : list) { + BigDecimal value = new BigDecimal(storageListVO.getQuantity()).multiply(storageListVO.getUnitPrice()).setScale(2, RoundingMode.HALF_UP); + storageListVO.setTotalValue(value); } - 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(); - } + pageInfo.setRecords(list); + return pageInfo; + } - 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); + @Transactional(rollbackFor = Exception.class) + @Override + public void removeByApplicationId(Integer id) { + //删除入库申请相关数据 + this.lambdaUpdate().eq(OaApprovalApplicationStorage::getApprovalApplicationId, id).remove(); + List<OaApprovalApplicationStorageAsset> list = oaApprovalApplicationStorageAssetService.lambdaQuery() + .eq(OaApprovalApplicationStorageAsset::getApprovalApplicationId, id).list(); + List<Integer> storageAssetIds = list.stream().map(OaApprovalApplicationStorageAsset::getId).collect(Collectors.toList()); + if (CollUtil.isNotEmpty(storageAssetIds)) { + //删除资产申请扩展表数据 + OaApprovalApplicationStorageAsset oaApprovalApplicationStorageAsset = list.get(0); + if (oaApprovalApplicationStorageAsset.getAssetMainType().equals(AssetTypeEnum.HOUSE.getCode())) { + oaApprovalApplicationStorageAssetPropertyExtService.lambdaUpdate() + .in(OaApprovalApplicationStorageAssetPropertyExt::getStorageAssetId, storageAssetIds).remove(); + + }else if (oaApprovalApplicationStorageAsset.getAssetMainType().equals(AssetTypeEnum.VEHICLE.getCode())) { + oaApprovalApplicationStorageAssetVehicleExtService.lambdaUpdate() + .in(OaApprovalApplicationStorageAssetVehicleExt::getStorageAssetId, storageAssetIds).remove(); + } } + //删除资产申请主表数据 + oaApprovalApplicationStorageAssetService.lambdaUpdate() + .eq(OaApprovalApplicationStorageAsset::getApprovalApplicationId, id).remove(); + //删除入库申请单 + oaApprovalApplicationsService.removeById(id); } } -- Gitblit v1.7.1