package com.ruoyi.stock.service.impl; 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.enums.StockInQualifiedRecordTypeEnum; import com.ruoyi.common.enums.StockInUnQualifiedRecordTypeEnum; import com.ruoyi.common.exception.base.BaseException; import com.ruoyi.common.utils.EnumUtil; import com.ruoyi.common.utils.OrderUtils; import com.ruoyi.common.utils.SecurityUtils; import com.ruoyi.common.utils.StringUtils; import com.ruoyi.common.utils.bean.BeanUtils; import com.ruoyi.common.utils.poi.ExcelUtil; import com.ruoyi.framework.security.LoginUser; import com.ruoyi.stock.dto.StockInRecordDto; import com.ruoyi.stock.execl.StockInRecordExportData; import com.ruoyi.stock.mapper.StockInRecordMapper; import com.ruoyi.stock.mapper.StockInventoryMapper; import com.ruoyi.stock.mapper.StockUninventoryMapper; import com.ruoyi.stock.pojo.StockInRecord; import com.ruoyi.stock.pojo.StockInventory; import com.ruoyi.stock.pojo.StockUninventory; import com.ruoyi.stock.service.StockInRecordService; import com.ruoyi.stock.service.StockInventoryService; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; import javax.servlet.http.HttpServletResponse; import java.math.BigDecimal; import java.time.LocalDateTime; import java.util.List; @Service public class StockInRecordServiceImpl extends ServiceImpl implements StockInRecordService { @Autowired private StockInRecordMapper stockInRecordMapper; @Autowired private StockInventoryMapper stockInventoryMapper; @Autowired private StockUninventoryMapper stockUninventoryMapper; @Autowired private StockInventoryService stockInventoryService; @Override public IPage listPage(Page page, StockInRecordDto stockInRecordDto) { return stockInRecordMapper.listPage(page, stockInRecordDto); } @Override @Transactional(rollbackFor = Exception.class) public Long add(StockInRecordDto stockInRecordDto) { String no = OrderUtils.countTodayByCreateTime(stockInRecordMapper, "RK"); stockInRecordDto.setInboundBatches(no); StockInRecord stockInRecord = new StockInRecord(); BeanUtils.copyProperties(stockInRecordDto, stockInRecord); int insertRows = stockInRecordMapper.insert(stockInRecord); Long insertId = stockInRecord.getId(); return insertRows > 0 ? insertId : null; } @Override @Transactional(rollbackFor = Exception.class) public int update(Long id, StockInRecordDto stockInRecordDto) { StockInRecord stockInRecord = stockInRecordMapper.selectById(id); if (stockInRecord == null) { throw new BaseException("该入库记录不存在,无法更新!!!"); } String[] ignoreProperties = {"id", "inbound_batches"};//排除id属性 BeanUtils.copyProperties(stockInRecordDto, stockInRecord, ignoreProperties); return stockInRecordMapper.updateById(stockInRecord); } @Override @Transactional(rollbackFor = Exception.class) public int batchDelete(List ids) { for (Long id : ids) { StockInRecord stockInRecord = stockInRecordMapper.selectById(id); if ("0".equals(stockInRecord.getType())) { StockInventory stockInventory = findQualifiedInventory(stockInRecord); if (stockInventory == null) { throw new BaseException("库存记录中没有对应的产品,无法删除!!!"); } stockInventory.setQualitity(defaultDecimal(stockInventory.getQualitity()).subtract(defaultDecimal(stockInRecord.getStockInNum()))); stockInventory.setVersion(stockInventory.getVersion() == null ? 1 : stockInventory.getVersion() + 1); stockInventory.setUpdateTime(LocalDateTime.now()); stockInventoryMapper.updateById(stockInventory); } else if ("1".equals(stockInRecord.getType())) { StockUninventory stockUninventory = stockUninventoryMapper.selectOne( new LambdaQueryWrapper() .eq(StockUninventory::getProductModelId, stockInRecord.getProductModelId()) .eq(StockUninventory::getBatchNo, stockInRecord.getBatchNo()) ); if (stockUninventory == null) { throw new BaseException("库存记录中没有对应的产品,无法删除!!!"); } stockUninventory.setQualitity(defaultDecimal(stockUninventory.getQualitity()).subtract(defaultDecimal(stockInRecord.getStockInNum()))); stockUninventory.setVersion(stockUninventory.getVersion() == null ? 1 : stockUninventory.getVersion() + 1); stockUninventory.setUpdateTime(LocalDateTime.now()); stockUninventoryMapper.updateById(stockUninventory); } } return stockInRecordMapper.deleteBatchIds(ids); } @Override public void exportStockInRecord(HttpServletResponse response, StockInRecordDto stockInRecordDto) { List list = stockInRecordMapper.listStockInRecordExportData(stockInRecordDto); for (StockInRecordExportData stockInRecordExportData : list) { if ("0".equals(stockInRecordExportData.getType())) { stockInRecordExportData.setRecordType( EnumUtil.fromCode(StockInQualifiedRecordTypeEnum.class, Integer.parseInt(stockInRecordExportData.getRecordType())).getValue() ); } else { stockInRecordExportData.setRecordType( EnumUtil.fromCode(StockInUnQualifiedRecordTypeEnum.class, Integer.parseInt(stockInRecordExportData.getRecordType())).getValue() ); } } ExcelUtil util = new ExcelUtil<>(StockInRecordExportData.class); util.exportExcel(response, list, "入库记录信息"); } @Override public StockInRecordDto selectByRecord(Long id) { return stockInRecordMapper.selectByRecord(id); } @Override public int updateStockInRecord(StockInRecordDto stockInRecordDto) { LoginUser loginUser = SecurityUtils.getLoginUser(); try { stockInventoryService.addApproveByPurchase(loginUser, stockInRecordDto, stockInRecordDto.getId()); } catch (Exception e) { e.printStackTrace(); } stockInRecordDto.setApproveStatus(1); return stockInRecordMapper.updateById(stockInRecordDto); } // 合格入库回退按与库存合并一致的唯一键查找。 private StockInventory findQualifiedInventory(StockInRecord stockInRecord) { LambdaQueryWrapper queryWrapper = new LambdaQueryWrapper() .eq(StockInventory::getProductModelId, stockInRecord.getProductModelId()) .orderByAsc(StockInventory::getId); String processCategory = StringUtils.trimToEmpty(stockInRecord.getProcessCategory()); String voltage = StringUtils.trimToEmpty(stockInRecord.getVoltage()); if (StringUtils.isNotBlank(processCategory) || StringUtils.isNotBlank(voltage)) { queryWrapper.eq(StockInventory::getProcessCategory, processCategory); queryWrapper.eq(StockInventory::getVoltage, voltage); } List inventories = stockInventoryMapper.selectList(queryWrapper); return inventories.isEmpty() ? null : inventories.get(0); } private BigDecimal defaultDecimal(BigDecimal value) { return value == null ? BigDecimal.ZERO : value; } }