package com.ruoyi.measuringinstrumentledger.service.impl; 
 | 
  
 | 
  
 | 
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.measuringinstrumentledger.dto.SparePartsDto; 
 | 
import com.ruoyi.measuringinstrumentledger.mapper.SparePartsMapper; 
 | 
import com.ruoyi.measuringinstrumentledger.pojo.SpareParts; 
 | 
import com.ruoyi.measuringinstrumentledger.service.SparePartsService; 
 | 
import org.springframework.beans.factory.annotation.Autowired; 
 | 
import org.springframework.stereotype.Service; 
 | 
  
 | 
import java.util.ArrayList; 
 | 
import java.util.HashMap; 
 | 
import java.util.List; 
 | 
import java.util.Map; 
 | 
  
 | 
@Service 
 | 
public class SparePartsServiceImpl extends ServiceImpl<SparePartsMapper, SpareParts> implements SparePartsService { 
 | 
    @Autowired 
 | 
    private SparePartsMapper sparePartsMapper; 
 | 
    @Override 
 | 
    public IPage<SparePartsDto> listPage(Page page, SpareParts spareParts) { 
 | 
        return sparePartsMapper.listPage(page,spareParts); 
 | 
    } 
 | 
  
 | 
    @Override 
 | 
    public List<SparePartsDto> getTree() { 
 | 
        SpareParts spareParts = new SpareParts(); 
 | 
        IPage<SparePartsDto> sparePartsDtoIPage = sparePartsMapper.listPage(new Page<>(1, -1), spareParts); 
 | 
        List<SparePartsDto> records = sparePartsDtoIPage.getRecords(); 
 | 
        return buildTree(records); 
 | 
    } 
 | 
  
 | 
  
 | 
    /** 
 | 
     * 将扁平结构数据转换为树形结构 
 | 
     * @param flatData 扁平节点列表 
 | 
     * @return 树形结构根节点列表 
 | 
     */ 
 | 
    public static List<SparePartsDto> buildTree(List<SparePartsDto> flatData) { 
 | 
        List<SparePartsDto> result = new ArrayList<>(); 
 | 
        if (flatData == null || flatData.isEmpty()) { 
 | 
            return result;  // 空输入直接返回空列表 
 | 
        } 
 | 
  
 | 
        // 1. 创建节点映射表,存储所有节点并初始化子节点列表 
 | 
        Map<Long, SparePartsDto> nodeMap = new HashMap<>(); 
 | 
        for (SparePartsDto node : flatData) { 
 | 
            // 确保子节点列表初始化(避免空指针异常) 
 | 
            if (node.getChildren() == null) { 
 | 
                node.setChildren(new ArrayList<>()); 
 | 
            } 
 | 
            nodeMap.put(node.getId(), node); 
 | 
        } 
 | 
  
 | 
        // 2. 构建树形结构 
 | 
        for (SparePartsDto node : flatData) { 
 | 
            Long parentId = node.getParentId(); 
 | 
            if (parentId == null || !nodeMap.containsKey(parentId)) { 
 | 
                // 无父节点或父节点不存在,作为根节点 
 | 
                result.add(node); 
 | 
            } else { 
 | 
                // 有父节点,添加到父节点的子节点列表 
 | 
                SparePartsDto parentNode = nodeMap.get(parentId); 
 | 
                parentNode.getChildren().add(node); 
 | 
            } 
 | 
        } 
 | 
  
 | 
        return result; 
 | 
    } 
 | 
} 
 |