package com.ruoyi.system.service.impl; import cn.hutool.core.bean.BeanUtil; import cn.hutool.core.collection.CollUtil; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.metadata.IPage; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.ruoyi.common.core.domain.entity.SysDept; import com.ruoyi.common.exception.ServiceException; import com.ruoyi.common.utils.SecurityUtils; import com.ruoyi.common.utils.StringUtils; import com.ruoyi.system.dto.asset.AssetWarehouseDTO; import com.ruoyi.system.mapper.AssetWarehouseMapper; import com.ruoyi.system.mapper.SysDeptMapper; import com.ruoyi.system.model.AssetInventoryRecord; import com.ruoyi.system.model.AssetWarehouse; import com.ruoyi.system.query.AssetWarehousePageQuery; import com.ruoyi.system.service.AssetInventoryRecordService; import com.ruoyi.system.service.AssetWarehouseService; import com.ruoyi.system.vo.asset.AssetWarehouseVO; import lombok.RequiredArgsConstructor; import org.springframework.stereotype.Service; import java.util.List; import java.util.Map; import java.util.Objects; import java.util.stream.Collectors; /** *

* 仓库信息表 服务实现类 *

* * @author WuGuanFengYue * @since 2025-09-15 */ @Service @RequiredArgsConstructor public class AssetWarehouseServiceImpl extends ServiceImpl implements AssetWarehouseService { private final AssetInventoryRecordService assetInventoryRecordService; private final SysDeptMapper sysDeptMapper; @Override public IPage getPageList(AssetWarehousePageQuery pageQuery) { LambdaQueryWrapper queryWrapper = new LambdaQueryWrapper<>(); if (StringUtils.isNotBlank(pageQuery.getKeyword())) { queryWrapper.like(AssetWarehouse::getWarehouseName, pageQuery.getKeyword()) .or() .like(AssetWarehouse::getManagerName, pageQuery.getKeyword()); } Page page = this.page(new Page<>(pageQuery.getPageNum(), pageQuery.getPageSize()), queryWrapper); Page pageVO = new Page<>(); BeanUtil.copyProperties(page, pageVO, "records"); List assetWarehouseVOS = BeanUtil.copyToList(page.getRecords(), AssetWarehouseVO.class); if (CollUtil.isEmpty(assetWarehouseVOS)) { return pageVO; } List warehouseIds = assetWarehouseVOS.stream().map(AssetWarehouseVO::getId).collect(Collectors.toList()); List deptIds = assetWarehouseVOS.stream().map(AssetWarehouseVO::getDeptId).distinct().collect(Collectors.toList()); List sysDepts = sysDeptMapper.selectByIds(deptIds); Map deptMap = sysDepts.stream() .collect(Collectors.toMap(item->item.getDeptId().intValue(), SysDept::getDeptName)); //查询库存数量 Map> inventoryRecordMap = assetInventoryRecordService.lambdaQuery() .in(AssetInventoryRecord::getWarehouseId, warehouseIds) .list().stream().collect(Collectors.groupingBy(AssetInventoryRecord::getWarehouseId)); //计算当前库存 assetWarehouseVOS.forEach(warehouseVO -> { List assetInventoryRecords = inventoryRecordMap.get(warehouseVO.getId()); if (CollUtil.isEmpty(assetInventoryRecords)) { warehouseVO.setCurrentStock(0); } long inStock = assetInventoryRecords.stream().filter(item -> item.getType().equals(0)).count(); long outStock = assetInventoryRecords.stream().filter(item -> item.getType().equals(1)).count(); warehouseVO.setCurrentStock((int) (inStock - outStock)); //设置部门名称 warehouseVO.setDeptName(deptMap.getOrDefault(warehouseVO.getDeptId(), "")); }); pageVO.setRecords(assetWarehouseVOS); return pageVO; } @Override public void add(AssetWarehouseDTO dto) { AssetWarehouse assetWarehouse = BeanUtil.copyProperties(dto, AssetWarehouse.class); String username = SecurityUtils.getUsername(); assetWarehouse.setCreateBy(username); this.save(assetWarehouse); } @Override public void edit(AssetWarehouseDTO dto) { if (Objects.isNull(dto.getId())) { throw new ServiceException("仓库ID不能为空"); } AssetWarehouse assetWarehouse = BeanUtil.copyProperties(dto, AssetWarehouse.class); String username = SecurityUtils.getUsername(); assetWarehouse.setUpdateBy(username); this.updateById(assetWarehouse); } @Override public void delete(Integer id) { if (Objects.isNull(id)) { throw new ServiceException("仓库ID不能为空"); } List list = assetInventoryRecordService.lambdaQuery().eq(AssetInventoryRecord::getWarehouseId, id).list(); if (CollUtil.isNotEmpty(list)) { List inStockIds = list.stream().filter(item -> item.getType().equals(0)).map(AssetInventoryRecord::getAssetMainId).collect(Collectors.toList()); list.stream().filter(item -> item.getType().equals(1)).forEach(item -> { inStockIds.remove(item.getAssetMainId()); }); if (CollUtil.isNotEmpty(inStockIds)) { throw new ServiceException("该仓库存在库存记录,不能删除"); } } this.removeById(id); } }