|  | @@ -4860,7 +4860,7 @@ public class WbsTreeContractServiceImpl extends BaseServiceImpl<WbsTreeContractM
 | 
											
												
													
														|  |                  .collect(Collectors.toList());
 |  |                  .collect(Collectors.toList());
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |          if (!leafNodes.isEmpty()) {
 |  |          if (!leafNodes.isEmpty()) {
 | 
											
												
													
														|  | -            return leafNodes;
 |  | 
 | 
											
												
													
														|  | 
 |  | +            return sortLeafNodes(leafNodes);
 | 
											
												
													
														|  |          }
 |  |          }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |          // 2. 如果没有子分项,找分项工程 (节点类型4)
 |  |          // 2. 如果没有子分项,找分项工程 (节点类型4)
 | 
											
										
											
												
													
														|  | @@ -4869,7 +4869,7 @@ public class WbsTreeContractServiceImpl extends BaseServiceImpl<WbsTreeContractM
 | 
											
												
													
														|  |                  .collect(Collectors.toList());
 |  |                  .collect(Collectors.toList());
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |          if (!leafNodes.isEmpty()) {
 |  |          if (!leafNodes.isEmpty()) {
 | 
											
												
													
														|  | -            return leafNodes;
 |  | 
 | 
											
												
													
														|  | 
 |  | +            return sortLeafNodes(leafNodes);
 | 
											
												
													
														|  |          }
 |  |          }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |          // 3. 如果没有分项,找子分部工程 (节点类型3)
 |  |          // 3. 如果没有分项,找子分部工程 (节点类型3)
 | 
											
										
											
												
													
														|  | @@ -4878,7 +4878,7 @@ public class WbsTreeContractServiceImpl extends BaseServiceImpl<WbsTreeContractM
 | 
											
												
													
														|  |                  .collect(Collectors.toList());
 |  |                  .collect(Collectors.toList());
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |          if (!leafNodes.isEmpty()) {
 |  |          if (!leafNodes.isEmpty()) {
 | 
											
												
													
														|  | -            return leafNodes;
 |  | 
 | 
											
												
													
														|  | 
 |  | +            return sortLeafNodes(leafNodes);
 | 
											
												
													
														|  |          }
 |  |          }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |          // 4. 如果没有子分部,找分部工程 (节点类型2)
 |  |          // 4. 如果没有子分部,找分部工程 (节点类型2)
 | 
											
										
											
												
													
														|  | @@ -4887,13 +4887,30 @@ public class WbsTreeContractServiceImpl extends BaseServiceImpl<WbsTreeContractM
 | 
											
												
													
														|  |                  .collect(Collectors.toList());
 |  |                  .collect(Collectors.toList());
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |          if (!leafNodes.isEmpty()) {
 |  |          if (!leafNodes.isEmpty()) {
 | 
											
												
													
														|  | -            return leafNodes;
 |  | 
 | 
											
												
													
														|  | 
 |  | +            return sortLeafNodes(leafNodes);
 | 
											
												
													
														|  |          }
 |  |          }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |          // 5. 最后找单位工程 (节点类型18)
 |  |          // 5. 最后找单位工程 (节点类型18)
 | 
											
												
													
														|  | -        return projects.stream()
 |  | 
 | 
											
												
													
														|  | 
 |  | +        leafNodes = projects.stream()
 | 
											
												
													
														|  |                  .filter(item -> item.getNodeType() == 18)
 |  |                  .filter(item -> item.getNodeType() == 18)
 | 
											
												
													
														|  |                  .collect(Collectors.toList());
 |  |                  .collect(Collectors.toList());
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +        return sortLeafNodes(leafNodes);
 | 
											
												
													
														|  | 
 |  | +    }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +    // 排序方法:先按pId排序,pId相同则按sort排序(null值排在最后)
 | 
											
												
													
														|  | 
 |  | +    private List<WbsTreeContract> sortLeafNodes(List<WbsTreeContract> nodes) {
 | 
											
												
													
														|  | 
 |  | +        return nodes.stream()
 | 
											
												
													
														|  | 
 |  | +                .sorted(Comparator
 | 
											
												
													
														|  | 
 |  | +                        .comparing(WbsTreeContract::getPId)
 | 
											
												
													
														|  | 
 |  | +                        .thenComparing(
 | 
											
												
													
														|  | 
 |  | +                                Comparator.comparing(
 | 
											
												
													
														|  | 
 |  | +                                        WbsTreeContract::getSort,
 | 
											
												
													
														|  | 
 |  | +                                        Comparator.nullsLast(Comparator.naturalOrder())
 | 
											
												
													
														|  | 
 |  | +                                )
 | 
											
												
													
														|  | 
 |  | +                        )
 | 
											
												
													
														|  | 
 |  | +                )
 | 
											
												
													
														|  | 
 |  | +                .collect(Collectors.toList());
 | 
											
												
													
														|  |      }
 |  |      }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |      // 根据叶子节点类型填充工程数据
 |  |      // 根据叶子节点类型填充工程数据
 |