From 4ad572c4e51e44e3134def3c70879b3a698ab1d8 Mon Sep 17 00:00:00 2001 From: mitao <2763622819@qq.com> Date: 星期一, 29 九月 2025 19:56:16 +0800 Subject: [PATCH] 资产变更 --- ruoyi-system/src/main/java/com/ruoyi/system/service/impl/OaApprovalApplicationStorageServiceImpl.java | 468 ++++++++++++++++++++++------------------------------------ 1 files changed, 178 insertions(+), 290 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 5bfb9d1..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,5 +1,7 @@ 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; @@ -13,7 +15,6 @@ import com.ruoyi.system.emums.ApprovalTypeEnum; import com.ruoyi.system.emums.AssetTypeEnum; import com.ruoyi.system.mapper.OaApprovalApplicationStorageMapper; -import com.ruoyi.system.model.AssetMain; import com.ruoyi.system.model.AssetWarehouse; import com.ruoyi.system.model.OaApprovalApplicationStorage; import com.ruoyi.system.model.OaApprovalApplicationStorageAsset; @@ -23,10 +24,6 @@ import com.ruoyi.system.model.OaApprovalFlowNode; import com.ruoyi.system.query.ApprovalDetailQuery; import com.ruoyi.system.query.OaApprovalApplicationStoragePageQuery; -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.OaApprovalApplicationStorageAssetPropertyExtService; import com.ruoyi.system.service.OaApprovalApplicationStorageAssetService; @@ -36,22 +33,26 @@ import com.ruoyi.system.service.OaApprovalFlowNodeService; import com.ruoyi.system.service.OaApprovalTodoService; import com.ruoyi.system.service.TDeptService; -import com.ruoyi.system.vo.PurchaseListVO; 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; /** @@ -70,10 +71,6 @@ private final OaApprovalApplicationStorageAssetService oaApprovalApplicationStorageAssetService; private final OaApprovalApplicationStorageAssetPropertyExtService oaApprovalApplicationStorageAssetPropertyExtService; private final OaApprovalApplicationStorageAssetVehicleExtService oaApprovalApplicationStorageAssetVehicleExtService; - private final AssetMainService assetMainService; - private final AssetPropertyExtService assetPropertyExtService; - private final AssetVehicleExtService assetVehicleExtService; - private final AssetTypeService assetTypeService; private final OaApprovalFlowNodeService oaApprovalFlowNodeService; private final OaApprovalTodoService oaApprovalTodoService; private final TDeptService tDeptService; @@ -218,16 +215,9 @@ * 构建通用资产主表数据 */ private OaApprovalApplicationStorageAsset buildAssetMain(OaApprovalApplicationStorageGeneralDTO.GeneralAssetItemDTO item, Integer applicationId, Integer assetTypeId, LocalDate storageDate, OaApprovalApplicationStorageGeneralDTO baseDto) { - OaApprovalApplicationStorageAsset assetMain = new OaApprovalApplicationStorageAsset(); - assetMain.setApprovalApplicationId(applicationId.intValue()); - assetMain.setAssetOriginalCode(item.getAssetOriginalCode()); - assetMain.setAssetName(item.getAssetName()); - assetMain.setCategory(item.getCategory()); - assetMain.setSpecificationModel(item.getSpecificationModel()); + 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() @@ -237,18 +227,9 @@ assetMain.setOwnershipDeptId(ownerDept.getId()); } } - assetMain.setUserName(item.getUserName()); // 根据整单 addressType 写入使用部门ID或仓库ID - applyUseDeptInfoToAssetMain(assetMain, baseDto.getUseDeptName()); + applyAddressToAssetMain(assetMain, item.getAddressType(), item.getUseDeptName(), item.getWarehouseName(), item.getAddress()); assetMain.setAssetMainType(AssetTypeEnum.GENERAL.getCode()); - 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; } @@ -256,16 +237,9 @@ * 构建房产资产主表数据 */ private OaApprovalApplicationStorageAsset buildAssetMainFromProperty(OaApprovalApplicationStoragePropertyDTO.PropertyAssetItemDTO item, Integer applicationId, Integer assetTypeId, LocalDate storageDate, OaApprovalApplicationStoragePropertyDTO baseDto) { - OaApprovalApplicationStorageAsset assetMain = new OaApprovalApplicationStorageAsset(); - assetMain.setApprovalApplicationId(applicationId.intValue()); - assetMain.setAssetOriginalCode(item.getAssetOriginalCode()); - assetMain.setAssetName(item.getAssetName()); - assetMain.setCategory(item.getCategory()); - assetMain.setSpecificationModel(item.getSpecificationModel()); + 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()) @@ -274,17 +248,8 @@ assetMain.setOwnershipDeptId(ownerDept.getId()); } } - assetMain.setUserName(item.getUserName()); - applyUseDeptInfoToAssetMain(assetMain, baseDto.getUseDeptName()); + applyAddressToAssetMain(assetMain, item.getAddressType(), item.getUseDeptName(), item.getWarehouseName(), item.getAddress()); assetMain.setAssetMainType(AssetTypeEnum.HOUSE.getCode()); - 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; } @@ -292,16 +257,9 @@ * 构建车辆资产主表数据 */ private OaApprovalApplicationStorageAsset buildAssetMainFromVehicle(OaApprovalApplicationStorageVehicleDTO.VehicleAssetItemDTO item, Integer applicationId, Integer assetTypeId, LocalDate storageDate, OaApprovalApplicationStorageVehicleDTO baseDto) { - OaApprovalApplicationStorageAsset assetMain = new OaApprovalApplicationStorageAsset(); - assetMain.setApprovalApplicationId(applicationId.intValue()); - assetMain.setAssetOriginalCode(item.getAssetOriginalCode()); - assetMain.setAssetName(item.getAssetName()); - assetMain.setCategory(item.getCategory()); - assetMain.setSpecificationModel(item.getSpecificationModel()); + 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()) @@ -310,59 +268,59 @@ assetMain.setOwnershipDeptId(ownerDept.getId()); } } - assetMain.setUserName(item.getUserName()); - applyUseDeptInfoToAssetMain(assetMain, baseDto.getUseDeptName()); + applyAddressToAssetMain(assetMain, item.getAddressType(), item.getUseDeptName(), item.getWarehouseName(), item.getAddress()); assetMain.setAssetMainType(AssetTypeEnum.VEHICLE.getCode()); - 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 applyUseDeptInfoToAssetMain(OaApprovalApplicationStorageAsset assetMain, String useDeptName) { - // 使用部门 - if (useDeptName != null && !useDeptName.isEmpty()) { - TDept dept = tDeptService.lambdaQuery() - .eq(TDept::getDeptName, useDeptName) - .one(); - if (dept != null) { - assetMain.setUseDeptId(dept.getId()); - } + private void applyAddressToAssetMain(OaApprovalApplicationStorageAsset 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 OaApprovalApplicationStorageAssetPropertyExt buildAssetPropertyExt(OaApprovalApplicationStoragePropertyDTO.PropertyAssetItemDTO item, Integer assetMainId) { - OaApprovalApplicationStorageAssetPropertyExt propertyExt = new OaApprovalApplicationStorageAssetPropertyExt(); + OaApprovalApplicationStorageAssetPropertyExt propertyExt = BeanUtil.copyProperties(item, OaApprovalApplicationStorageAssetPropertyExt.class); propertyExt.setStorageAssetId(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; } @@ -370,17 +328,8 @@ * 构建车辆资产扩展数据 */ private OaApprovalApplicationStorageAssetVehicleExt buildAssetVehicleExt(OaApprovalApplicationStorageVehicleDTO.VehicleAssetItemDTO item, Integer assetMainId) { - OaApprovalApplicationStorageAssetVehicleExt vehicleExt = new OaApprovalApplicationStorageAssetVehicleExt(); + OaApprovalApplicationStorageAssetVehicleExt vehicleExt = BeanUtil.copyProperties(item, OaApprovalApplicationStorageAssetVehicleExt.class); vehicleExt.setStorageAssetId(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; } @@ -407,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; } @@ -449,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; @@ -494,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()); @@ -526,14 +422,15 @@ } @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(); @@ -543,36 +440,35 @@ .eq(OaApprovalApplicationStorageAsset::getApprovalApplicationId, app.getId()) .eq(OaApprovalApplicationStorageAsset::getAssetTypeId, storage.getAssetTypeId()) .list(); - setAddressInfo(vo, mains); - if (!CollectionUtils.isEmpty(mains)) { - // 批量查询权属部门,避免循环内查询 + // 批量查询权属部门 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() + .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); @@ -581,14 +477,15 @@ } @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(); @@ -598,7 +495,6 @@ .eq(OaApprovalApplicationStorageAsset::getApprovalApplicationId, app.getId()) .eq(OaApprovalApplicationStorageAsset::getAssetTypeId, storage.getAssetTypeId()) .list(); - setAddressInfo(vo, mains); if (!CollectionUtils.isEmpty(mains)) { List<Integer> mainIds = mains.stream().map(OaApprovalApplicationStorageAsset::getId).collect(Collectors.toList()); @@ -609,28 +505,30 @@ .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()); + 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()); @@ -658,14 +556,15 @@ } @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(); @@ -675,7 +574,6 @@ .eq(OaApprovalApplicationStorageAsset::getApprovalApplicationId, app.getId()) .eq(OaApprovalApplicationStorageAsset::getAssetTypeId, storage.getAssetTypeId()) .list(); - setAddressInfo(vo, mains); if (!CollectionUtils.isEmpty(mains)) { List<Integer> mainIds = mains.stream().map(OaApprovalApplicationStorageAsset::getId).collect(Collectors.toList()); @@ -686,28 +584,29 @@ .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()); + 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()); @@ -733,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()); @@ -746,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()); @@ -759,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()); @@ -766,51 +668,6 @@ v.setAssetTypeId(storage.getAssetTypeId()); v.setStorageType(storage.getStorageType()); v.setStorageTime(storage.getStorageTime()); - } - } - - private void setAddressInfo(Object vo, List<OaApprovalApplicationStorageAsset> mains) { - if (CollectionUtils.isEmpty(mains)) { - return; - } - OaApprovalApplicationStorageAsset sample = mains.get(0); - Integer addressType = null; - String useDeptName = null; - String warehouseName = null; - String address = null; - switch (sample.getAddressType()) { - case 0: - TDept dept = tDeptService.getById(sample.getUseDeptId()); - useDeptName = dept != null ? dept.getDeptName() : null; - break; - case 1: - AssetWarehouse wh = assetWarehouseService.getById(sample.getWarehouseId()); - warehouseName = wh != null ? wh.getWarehouseName() : null; - break; - case 2: - break; - default: - return; - } - - if (vo instanceof OaApprovalApplicationStorageGeneralDetailVO) { - OaApprovalApplicationStorageGeneralDetailVO v = (OaApprovalApplicationStorageGeneralDetailVO) vo; - v.setAddressType(sample.getAddressType()); - v.setUseDeptName(useDeptName); - v.setWarehouseName(warehouseName); - v.setAddress(sample.getAddress()); - } else if (vo instanceof OaApprovalApplicationStoragePropertyDetailVO) { - OaApprovalApplicationStoragePropertyDetailVO v = (OaApprovalApplicationStoragePropertyDetailVO) vo; - v.setAddressType(sample.getAddressType()); - v.setUseDeptName(useDeptName); - v.setWarehouseName(warehouseName); - v.setAddress(sample.getAddress()); - } else if (vo instanceof OaApprovalApplicationStorageVehicleDetailVO) { - OaApprovalApplicationStorageVehicleDetailVO v = (OaApprovalApplicationStorageVehicleDetailVO) vo; - v.setAddressType(sample.getAddressType()); - v.setUseDeptName(useDeptName); - v.setWarehouseName(warehouseName); - v.setAddress(sample.getAddress()); } } @@ -818,7 +675,38 @@ 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); + } pageInfo.setRecords(list); return pageInfo; } + + @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