package com.ruoyi.device.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.github.xiaoymin.knife4j.core.util.CollectionUtils; import com.github.xiaoymin.knife4j.core.util.StrUtil; import com.ruoyi.common.enums.FileNameType; import com.ruoyi.common.utils.bean.BeanUtils; import com.ruoyi.common.utils.poi.ExcelUtil; import com.ruoyi.device.dto.DeviceDefectRecordDto; import com.ruoyi.device.dto.DeviceRepairDto; import com.ruoyi.device.execl.DeviceRepairExeclDto; import com.ruoyi.device.mapper.DeviceRepairMapper; import com.ruoyi.device.pojo.DeviceLedger; import com.ruoyi.device.pojo.DeviceRepair; import com.ruoyi.device.service.DeviceDefectRecordService; import com.ruoyi.device.service.IDeviceLedgerService; import com.ruoyi.device.service.IDeviceRepairService; import com.ruoyi.framework.web.domain.AjaxResult; import com.ruoyi.measuringinstrumentledger.mapper.SparePartsMapper; import com.ruoyi.measuringinstrumentledger.pojo.SpareParts; import com.ruoyi.measuringinstrumentledger.pojo.SparePartsRequisitionRecord; import com.ruoyi.measuringinstrumentledger.service.SparePartsRequisitionRecordService; import com.ruoyi.other.pojo.TempFile; import com.ruoyi.other.service.TempFileService; import com.ruoyi.sales.mapper.CommonFileMapper; import com.ruoyi.sales.pojo.CommonFile; import lombok.AllArgsConstructor; import lombok.extern.slf4j.Slf4j; import org.apache.commons.lang3.StringUtils; 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.util.*; import java.util.stream.Collectors; @Service @AllArgsConstructor @Slf4j public class DeviceRepairServiceImpl extends ServiceImpl implements IDeviceRepairService { @Autowired private DeviceDefectRecordService deviceDefectRecordService; @Autowired private DeviceRepairMapper deviceRepairMapper; @Autowired private IDeviceLedgerService deviceLedgerService; @Autowired private SparePartsMapper sparePartsMapper; @Autowired private TempFileService tempFileService; @Autowired private CommonFileMapper commonFileMapper; @Autowired private SparePartsRequisitionRecordService sparePartsRequisitionRecordService; @Override public IPage queryPage(Page page, DeviceRepairDto deviceRepairDto) { IPage deviceRepairDtoIPage = deviceRepairMapper.queryPage(page, deviceRepairDto); List records = deviceRepairDtoIPage.getRecords(); List recordIds = records.stream() .map(DeviceRepairDto::getId) .collect(Collectors.toList()); if (!CollectionUtils.isEmpty(records)) { // 1. 获取所有唯一的备件ID Set allIds = records.stream() .map(DeviceRepairDto::getSparePartsIds) .filter(StrUtil::isNotBlank) .flatMap(ids -> Arrays.stream(StringUtils.split(ids, ","))) .map(String::trim) .filter(StrUtil::isNotBlank) .collect(Collectors.toSet()); if (!allIds.isEmpty()) { // 2. 查询并创建ID到名称的映射 Map idToNameMap = sparePartsMapper.selectBatchIds(new ArrayList<>(allIds)) .stream() .collect(Collectors.toMap( SpareParts::getId, SpareParts::getName, (v1, v2) -> v1 )); // 3. 为每个记录设置备件名称 records.forEach(record -> { String names = Optional.ofNullable(record.getSparePartsIds()) .filter(StrUtil::isNotBlank) .map(ids -> Arrays.stream(StringUtils.split(ids, ",")) .map(String::trim) .map(Long::valueOf) .map(idToNameMap::get) .filter(Objects::nonNull) .collect(Collectors.joining(","))) .orElse(""); record.setSparePartsNames(names); }); } // 处理文件 List commonFiles = commonFileMapper.selectList(new LambdaQueryWrapper().in(CommonFile::getCommonId, recordIds) .eq(CommonFile::getType, FileNameType.DeviceRepair.getValue())); Map> collect = commonFiles.stream() .collect(Collectors.groupingBy(CommonFile::getCommonId)); records.forEach(record -> record.setFileList(collect.get(record.getId()))); } return deviceRepairDtoIPage; } @Override public AjaxResult saveDeviceRepair(DeviceRepair deviceRepair) { DeviceLedger byId = deviceLedgerService.getById(deviceRepair.getDeviceLedgerId()); deviceRepair.setDeviceName(byId.getDeviceName()); deviceRepair.setDeviceModel(byId.getDeviceModel()); if (deviceRepair.getRemark() == null) { deviceRepair.setRemark(""); } boolean save = this.save(deviceRepair); if (save) { if (CollectionUtils.isNotEmpty(deviceRepair.getFileList())) { List fileIds = deviceRepair.getFileList().stream() .map(TempFile::getTempId) .collect(Collectors.toList()); try { tempFileService.migrateTempFilesToFormal(deviceRepair.getId(), fileIds, FileNameType.DeviceRepair.getValue()); } catch (Exception e) { log.error("设备维修文件迁移错误", e); } } return AjaxResult.success(); } return AjaxResult.error(); } @Override @Transactional(rollbackFor = Exception.class) public AjaxResult updateDeviceRepair(DeviceRepair deviceRepair) { DeviceRepair oldDeviceRepair = this.getById(deviceRepair.getId()); // 处理备件使用情况 if (CollectionUtils.isNotEmpty(deviceRepair.getSparePartsUseList())) { List sparePartIds = new ArrayList<>(); for (DeviceRepair.SparePartUse sparePartUse : deviceRepair.getSparePartsUseList()) { // 获取备件信息 SpareParts spareParts = sparePartsMapper.selectById(sparePartUse.getId()); if (spareParts != null) { // 检查数量是否足够 if (spareParts.getQuantity().compareTo(new BigDecimal(sparePartUse.getQuantity())) >= 0) { // 更新数量 spareParts.setQuantity(spareParts.getQuantity().subtract(new BigDecimal(sparePartUse.getQuantity()))); sparePartsMapper.updateById(spareParts); sparePartIds.add(sparePartUse.getId()); // 创建备件领用记录 SparePartsRequisitionRecord record = new SparePartsRequisitionRecord(); record.setSourceType(0); // 0 维修 record.setSourceId(deviceRepair.getId()); record.setDeviceLedgerId(oldDeviceRepair.getDeviceLedgerId()); record.setSparePartsId(sparePartUse.getId()); record.setQuantity(sparePartUse.getQuantity()); sparePartsRequisitionRecordService.save(record); } else { return AjaxResult.error("备件 " + spareParts.getName() + " 数量不足"); } } } // 更新备件IDs字段 if (!sparePartIds.isEmpty()) { deviceRepair.setSparePartsIds(StringUtils.join(sparePartIds, ",")); } } if (this.updateById(deviceRepair)) { if (CollectionUtils.isNotEmpty(deviceRepair.getFileList())) { List fileIds = deviceRepair.getFileList().stream() .map(TempFile::getTempId) .collect(Collectors.toList()); try { tempFileService.migrateTempFilesToFormal(deviceRepair.getId(), fileIds, FileNameType.DeviceRepair.getValue()); } catch (Exception e) { log.error("设备维修文件迁移错误", e); } } Long id = deviceRepair.getId(); // DeviceDefectRecordDto deviceDefectRecordDto = new DeviceDefectRecordDto(); deviceDefectRecordDto.setDeviceLedgerId(id); deviceDefectRecordDto.setStatus("严重缺陷"); List records = deviceDefectRecordService.listPage(new Page<>(1, -1), deviceDefectRecordDto).getRecords(); if (!records.isEmpty()) { records.forEach(deviceDefectRecord -> { deviceDefectRecord.setStatus("正常"); deviceDefectRecordService.updateByDDR(deviceDefectRecord); }); } return AjaxResult.success(); } return AjaxResult.error(); } @Override public void export(HttpServletResponse response, Long[] ids) { if (ids == null || ids.length == 0) { List supplierManageList = this.list(); ArrayList deviceLedgerExeclDtos = new ArrayList<>(); supplierManageList.stream().forEach(deviceRepair -> { DeviceRepairExeclDto deviceRepairExeclDto = new DeviceRepairExeclDto(); BeanUtils.copyProperties(deviceRepair, deviceRepairExeclDto); deviceRepairExeclDto.setStatusStr(deviceRepair.getStatus() == 0 ? "待维修" : deviceRepair.getStatus() == 1 ? "完结" : "失败"); deviceLedgerExeclDtos.add(deviceRepairExeclDto); }); ExcelUtil util = new ExcelUtil(DeviceRepairExeclDto.class); util.exportExcel(response, deviceLedgerExeclDtos, "设备报修导出"); } else { ArrayList arrayList = new ArrayList<>(); Arrays.stream(ids).map(arrayList::add); List supplierManageList = deviceRepairMapper.selectBatchIds(arrayList); ArrayList deviceLedgerExeclDtos = new ArrayList<>(); supplierManageList.stream().forEach(deviceRepair -> { DeviceRepairExeclDto deviceRepairExeclDto = new DeviceRepairExeclDto(); BeanUtils.copyProperties(deviceRepair, deviceRepairExeclDto); deviceRepairExeclDto.setStatusStr(deviceRepair.getStatus() == 0 ? "待维修" : deviceRepair.getStatus() == 1 ? "完结" : "失败"); deviceLedgerExeclDtos.add(deviceRepairExeclDto); }); ExcelUtil util = new ExcelUtil(DeviceRepairExeclDto.class); util.exportExcel(response, deviceLedgerExeclDtos, "设备报修导出"); } } @Override public DeviceRepairDto detailById(Long id) { DeviceRepairDto deviceRepairDto = deviceRepairMapper.detailById(id); LambdaQueryWrapper queryWrapper = new LambdaQueryWrapper() .eq(CommonFile::getCommonId, deviceRepairDto.getId()) // 关联记录ID .eq(CommonFile::getType, FileNameType.DeviceRepair.getValue()); // 文件类型 List commonFiles = commonFileMapper.selectList(queryWrapper); deviceRepairDto.setFileList(commonFiles); return deviceRepairDto; } }