From 40e4ce58f634598fafd205dfe54cb90e8b63b6f2 Mon Sep 17 00:00:00 2001 From: liding <756868258@qq.com> Date: 星期五, 20 六月 2025 17:30:15 +0800 Subject: [PATCH] 生产加工 --- main-business/src/main/java/com/ruoyi/business/service/impl/ProductionMasterServiceImpl.java | 239 +++++++++++++++++++++++++++++++++++------------------------ 1 files changed, 140 insertions(+), 99 deletions(-) diff --git a/main-business/src/main/java/com/ruoyi/business/service/impl/ProductionMasterServiceImpl.java b/main-business/src/main/java/com/ruoyi/business/service/impl/ProductionMasterServiceImpl.java index 0a9dcc1..4d3b647 100644 --- a/main-business/src/main/java/com/ruoyi/business/service/impl/ProductionMasterServiceImpl.java +++ b/main-business/src/main/java/com/ruoyi/business/service/impl/ProductionMasterServiceImpl.java @@ -5,20 +5,14 @@ import com.baomidou.mybatisplus.core.toolkit.CollectionUtils; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import com.ruoyi.basic.entity.CoalInfo; +import com.ruoyi.basic.mapper.CoalInfoMapper; import com.ruoyi.business.dto.ProductionMasterDto; -import com.ruoyi.business.entity.OfficialInventory; -import com.ruoyi.business.entity.Production; -import com.ruoyi.business.entity.ProductionInventory; -import com.ruoyi.business.entity.ProductionMaster; -import com.ruoyi.business.mapper.OfficialInventoryMapper; -import com.ruoyi.business.mapper.ProductionInventoryMapper; -import com.ruoyi.business.mapper.ProductionMapper; -import com.ruoyi.business.mapper.ProductionMasterMapper; +import com.ruoyi.business.entity.*; +import com.ruoyi.business.mapper.*; import com.ruoyi.business.service.ProductionMasterService; -import com.ruoyi.common.core.domain.entity.SysUser; import com.ruoyi.common.exception.base.BaseException; import com.ruoyi.common.utils.bean.BeanUtils; -import com.ruoyi.system.mapper.SysUserMapper; import lombok.RequiredArgsConstructor; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; @@ -47,7 +41,9 @@ private final OfficialInventoryMapper officialInventoryMapper; - private final SysUserMapper sysUserMapper; + private final CoalInfoMapper coalInfoMapper; + + private final PendingInventoryMapper pendingInventoryMapper; @Override public IPage<ProductionMasterDto> selectPMList(Page page, ProductionMasterDto productionMasterDto) { @@ -119,113 +115,158 @@ @Override @Transactional - public int addOrEditPM(ProductionMasterDto productionMasterDto) { - // 1. 鐩存帴璁$畻鑱氬悎鍊硷紝閬垮厤鍒涘缓澶氫綑鍒楄〃 - BigDecimal totalPurchasePrice = BigDecimal.ZERO; - BigDecimal totalLaborCost = BigDecimal.ZERO; - BigDecimal totalEnergyConsumptionCost = BigDecimal.ZERO; - BigDecimal totalTotalCost = BigDecimal.ZERO; - BigDecimal totalEquipmentDepreciation = BigDecimal.ZERO; - int totalProductionQuantity = 0; - StringBuilder coalBuilder = new StringBuilder(); + public int addOrEditPM(ProductionMasterDto dto) { + Long masterId = dto.getId(); - for (Production production : productionMasterDto.getProductionList()) { - totalPurchasePrice = totalPurchasePrice.add(production.getPurchasePrice()); - totalLaborCost = totalLaborCost.add(production.getLaborCost()); - totalEnergyConsumptionCost = totalEnergyConsumptionCost.add(production.getEnergyConsumptionCost()); - totalTotalCost = totalTotalCost.add(production.getTotalCost()); - totalEquipmentDepreciation = totalEquipmentDepreciation.add(production.getEquipmentDepreciation()); - totalProductionQuantity += production.getProductionQuantity(); - if (coalBuilder.length() > 0) { - coalBuilder.append(","); // 鍦ㄥ厓绱犱箣闂存坊鍔犻�楀彿 - } - coalBuilder.append(production.getCoal()); + // 缂栬緫鍦烘櫙锛氬洖婊氭棫搴撳瓨骞跺垹闄ゆ棫璁板綍 + if (masterId != null) { + rollbackOldInventory(masterId); + deleteChildRecords(masterId); } - String coalStr = coalBuilder.toString(); // 鐩存帴鑾峰彇鎷兼帴缁撴灉 - // 2. 鍒涘缓涓昏〃瀵硅薄 - ProductionMaster productionMaster = new ProductionMaster(); - productionMaster.setProductionQuantity(totalProductionQuantity); - productionMaster.setTotalCost(totalTotalCost); - productionMaster.setEquipmentDepreciation(totalEquipmentDepreciation); - productionMaster.setEnergyConsumptionCost(totalEnergyConsumptionCost); - productionMaster.setLaborCost(totalLaborCost); - productionMaster.setCoal(coalStr); + // 鏍¢獙浣跨敤閲忓苟鍑忓皯搴撳瓨 + validateAndReduceInventory(dto.getProductionInventoryList()); - Long masterId = productionMasterDto.getId(); - productionMaster.setId(masterId); + // 鏋勯�犱富琛ㄥ疄浣撳璞� + ProductionMaster master = buildProductionMaster(dto); - // 3. 缁熶竴瀛愯〃澶勭悊閫昏緫 - Long producerId = productionMasterDto.getProducerId(); - if (producerId == null) { - throw new BaseException("璇烽�夋嫨鐢熶骇鑰�"); - } - SysUser sysUser = sysUserMapper.selectUserById(producerId); - productionMaster.setProducer(sysUser.getUserName()); + // 鎻掑叆鎴栨洿鏂颁富琛� if (masterId == null) { - productionMasterMapper.insert(productionMaster); - masterId = productionMaster.getId(); // 鑾峰彇鏂扮敓鎴愮殑ID + productionMasterMapper.insert(master); + masterId = master.getId(); } else { - // 鍒犻櫎鍏宠仈瀛愯〃鏁版嵁 - productionMapper.delete(new LambdaQueryWrapper<Production>() - .eq(Production::getProductionMasterId, masterId)); - - productionInventoryMapper.delete(new LambdaQueryWrapper<ProductionInventory>() - .eq(ProductionInventory::getProductionMasterId, masterId)); - - productionMasterMapper.updateById(productionMaster); + master.setId(masterId); + productionMasterMapper.updateById(master); } - //搴撳瓨鏇存柊 - for (ProductionInventory productionInventory : productionMasterDto.getProductionInventoryList()) { - OfficialInventory officialInventory = officialInventoryMapper.selectById(productionInventory.getOfficialId()); - BigDecimal subtract = officialInventory.getInventoryQuantity().subtract(new BigDecimal(productionInventory.getUsedQuantity())); - if (subtract.compareTo(BigDecimal.ZERO) < 0) { - throw new BaseException("搴撳瓨涓嶈冻"); - } - officialInventory.setInventoryQuantity(subtract); - officialInventoryMapper.updateById(officialInventory); - } - - // 4. 鎵归噺鎻掑叆瀛愯〃鏁版嵁 - batchInsertProductions(masterId, productionMasterDto.getProductionList()); - batchInsertInventories(masterId, productionMasterDto.getProductionInventoryList()); + + // 鎵归噺鎻掑叆鐢熶骇璁板綍涓庡簱瀛樿褰� + batchInsertProductions(masterId, dto.getProductionList()); + batchInsertInventories(masterId, dto.getProductionInventoryList()); + + // 鎻掑叆寰呭叆搴撴暟鎹� + insertPendingInventory(dto.getProductionList()); return 1; } - // 鎵归噺鎻掑叆鐢熶骇鏁版嵁 - private void batchInsertProductions(Long masterId, List<Production> productions) { - List<Production> insertList = productions.stream() - .peek(p -> { - p.setId(null); - p.setProductionMasterId(masterId); - }) - .collect(Collectors.toList()); + /** + * 鍥炴粴鏃х殑搴撳瓨鏁版嵁锛堝皢搴撳瓨鏁伴噺杩樺師锛� + */ + private void rollbackOldInventory(Long masterId) { + List<ProductionInventory> oldInventories = productionInventoryMapper.selectList( + new LambdaQueryWrapper<ProductionInventory>().eq(ProductionInventory::getProductionMasterId, masterId)); - if (!insertList.isEmpty()) { - for (Production production : productions) { - production.setId(null); - production.setProductionMasterId(masterId); - productionMapper.insert(production); + for (ProductionInventory oldInv : oldInventories) { + OfficialInventory inv = officialInventoryMapper.selectById(oldInv.getOfficialId()); + if (inv != null) { + inv.setInventoryQuantity(inv.getInventoryQuantity().add(new BigDecimal(oldInv.getUsedQuantity()))); + officialInventoryMapper.updateById(inv); } } } - // 鎵归噺鎻掑叆搴撳瓨鏁版嵁 - private void batchInsertInventories(Long masterId, List<ProductionInventory> inventories) { - List<ProductionInventory> insertList = inventories.stream() - .peek(inv -> { - inv.setId(null); - inv.setProductionMasterId(masterId); - }) - .collect(Collectors.toList()); + /** + * 鍒犻櫎鏃х殑瀛愯〃鏁版嵁鍙婂緟鍏ュ簱鏁版嵁 + */ + private void deleteChildRecords(Long masterId) { + productionMapper.delete(new LambdaQueryWrapper<Production>().eq(Production::getProductionMasterId, masterId)); + productionInventoryMapper.delete(new LambdaQueryWrapper<ProductionInventory>().eq(ProductionInventory::getProductionMasterId, masterId)); + pendingInventoryMapper.delete(new LambdaQueryWrapper<PendingInventory>().eq(PendingInventory::getMasterId, masterId)); + } - if (!insertList.isEmpty()) { - for (ProductionInventory inventory : inventories) { - inventory.setId(null); - inventory.setProductionMasterId(masterId); - productionInventoryMapper.insert(inventory); + /** + * 鏍¢獙姣忔潯浣跨敤閲忔槸鍚﹁冻澶燂紝骞跺噺灏戞寮忓簱瀛樻暟閲� + */ + private void validateAndReduceInventory(List<ProductionInventory> inventoryList) { + for (ProductionInventory inv : inventoryList) { + OfficialInventory official = officialInventoryMapper.selectById(inv.getOfficialId()); + BigDecimal used = new BigDecimal(inv.getUsedQuantity()); + if (official.getInventoryQuantity().compareTo(used) < 0) { + throw new BaseException("搴撳瓨涓嶈冻"); } + official.setInventoryQuantity(official.getInventoryQuantity().subtract(used)); + officialInventoryMapper.updateById(official); + } + } + + /** + * 鏋勯�犱富琛ㄥ璞″苟鑱氬悎瀛楁鍊硷紙濡傛�绘垚鏈�佺叅绉嶇瓑锛� + */ + private ProductionMaster buildProductionMaster(ProductionMasterDto dto) { + BigDecimal totalPurchase = BigDecimal.ZERO; + BigDecimal totalLabor = BigDecimal.ZERO; + BigDecimal totalEnergy = BigDecimal.ZERO; + BigDecimal totalCost = BigDecimal.ZERO; + BigDecimal totalDepreciation = BigDecimal.ZERO; + BigDecimal totalQuantity = BigDecimal.ZERO; + + List<Long> coalIds = new ArrayList<>(); + + for (Production p : dto.getProductionList()) { + totalPurchase = totalPurchase.add(p.getPurchasePrice()); + totalLabor = totalLabor.add(p.getLaborCost()); + totalEnergy = totalEnergy.add(p.getEnergyConsumptionCost()); + totalCost = totalCost.add(p.getTotalCost()); + totalDepreciation = totalDepreciation.add(p.getEquipmentDepreciation()); + totalQuantity = totalQuantity.add(p.getProductionQuantity()); + coalIds.add(p.getCoalId()); + } + + List<CoalInfo> coalInfos = coalInfoMapper.selectList(new LambdaQueryWrapper<CoalInfo>().in(CoalInfo::getId, coalIds)); + + ProductionMaster master = new ProductionMaster(); + master.setProductionQuantity(totalQuantity); + master.setTotalCost(totalCost); + master.setLaborCost(totalLabor); + master.setEnergyConsumptionCost(totalEnergy); + master.setEquipmentDepreciation(totalDepreciation); + master.setCoal(coalInfos.stream().map(CoalInfo::getCoal).collect(Collectors.joining(","))); + master.setCoalId(coalIds.stream().map(String::valueOf).collect(Collectors.joining(","))); + + return master; + } + + /** + * 鎵归噺鎻掑叆鐢熶骇瀛愯〃鏁版嵁 + */ + private void batchInsertProductions(Long masterId, List<Production> list) { + if (list.isEmpty()) return; + + for (Production p : list) { + Production copy = new Production(); + BeanUtils.copyProperties(p, copy); + copy.setId(null); + copy.setProductionMasterId(masterId); + productionMapper.insert(copy); + } + } + + /** + * 鎵归噺鎻掑叆搴撳瓨浣跨敤瀛愯〃鏁版嵁 + */ + private void batchInsertInventories(Long masterId, List<ProductionInventory> list) { + if (list.isEmpty()) return; + + for (ProductionInventory p : list) { + p.setId(null); + p.setProductionMasterId(masterId); + productionInventoryMapper.insert(p); + } + } + + /** + * 灏嗗姞宸ヤ骇鐢熺殑浜у搧璁板綍鍒板緟鍏ュ簱琛� + */ + private void insertPendingInventory(List<Production> list) { + for (Production p : list) { + PendingInventory pending = new PendingInventory(); + pending.setCoalId(p.getCoalId()); + pending.setInventoryQuantity(p.getProductionQuantity()); + pending.setSupplierName("鐢熶骇鍔犲伐鍏ュ簱"); + pending.setTotalPriceIncludingTax(p.getTotalCost()); + pending.setPriceIncludingTax(p.getPurchasePrice()); + pending.setPriceIncludingTax(p.getPurchasePrice()); + pendingInventoryMapper.insert(pending); } } -- Gitblit v1.9.3