From a7426b81b0bd5b4bb1ed68fd6ecb98f405def280 Mon Sep 17 00:00:00 2001
From: yangys <y_ys79@sina.com>
Date: 星期一, 04 八月 2025 17:47:07 +0800
Subject: [PATCH] dnc导出还没测

---
 blade-service/blade-mdm/src/main/java/org/springblade/mdm/program/controller/NcNodeController.java |   76 ++++++++++++++++++++++++++++++++------
 1 files changed, 64 insertions(+), 12 deletions(-)

diff --git a/blade-service/blade-mdm/src/main/java/org/springblade/mdm/program/controller/NcNodeController.java b/blade-service/blade-mdm/src/main/java/org/springblade/mdm/program/controller/NcNodeController.java
index bd6f030..6aa1ec1 100644
--- a/blade-service/blade-mdm/src/main/java/org/springblade/mdm/program/controller/NcNodeController.java
+++ b/blade-service/blade-mdm/src/main/java/org/springblade/mdm/program/controller/NcNodeController.java
@@ -12,12 +12,14 @@
 import lombok.extern.slf4j.Slf4j;
 import org.springblade.core.tenant.annotation.NonDS;
 import org.springblade.core.tool.api.R;
+import org.springblade.core.tool.utils.Func;
 import org.springblade.mdm.basesetting.machine.vo.MachineQueryVO;
 import org.springblade.mdm.basesetting.machine.vo.MachineVO;
+import org.springblade.mdm.program.entity.NcProgram;
 import org.springblade.mdm.program.service.NcNodeService;
-import org.springblade.mdm.program.vo.NcNodeProgramQueryVO;
-import org.springblade.mdm.program.vo.NcNodeProgramVO;
-import org.springblade.mdm.program.vo.NcNodeVO;
+import org.springblade.mdm.program.service.NcProgramService;
+import org.springblade.mdm.program.service.ProgramFlowStatusQueryService;
+import org.springblade.mdm.program.vo.*;
 import org.springframework.web.bind.annotation.*;
 
 import java.util.List;
@@ -34,9 +36,9 @@
 @Tag(name = "绋嬪簭鑺傜偣", description = "绋嬪簭鑺傜偣")
 @Slf4j
 public class NcNodeController {
-
+	private final NcProgramService ncProgramService;
 	private final NcNodeService ncNodeService;
-
+	private final ProgramFlowStatusQueryService programFlowStatusQueryService;
 	/**
 	 * 鏂板
 	 */
@@ -66,16 +68,66 @@
 	@Operation(summary = "鎳掑姞杞藉垪琛�", description = "绋嬪簭鐩綍鏍戝舰缁撴瀯")
 	public R<List<NcNodeVO>> lazyList(Long parentId) {
 		List<NcNodeVO> list = ncNodeService.lazyList(parentId);
+		if(list != null && !list.isEmpty()) {
+			for(NcNodeVO ncNodeVO : list) {
+				if(!"60".equals(ncNodeVO.getNodeType())){
+					break;
+				}
+				ncNodeVO.setFlowStatus(programFlowStatusQueryService.queryFlowStatus(ncNodeVO.getProcessInstanceId()));
+				/*
+				NcProgram program = ncProgramService.getByBindNodeId(ncNodeVO.getId());
+				if(program != null) {
+					ncNodeVO.setProcessEdition(program.getProcessEdition());
+					ncNodeVO.setDrawingNo(program.getDrawingNo());
+					ncNodeVO.setMachineCode(program.getMachineCode());
+					ncNodeVO.setProcessName(program.getProcessName());
+					ncNodeVO.setVersionNumber(program.getVersionNumber());
+
+					//record涓壘涓嶅埌鏃舵湭鍚姩0锛涙壘鍒颁簡闇�瑕佹煡璇㈡祦绋嬪疄渚媔d锛屾槸鍚﹁繍琛屼腑
+					ncNodeVO.setFlowStatus(programFlowStatusQueryService.queryFlowStatus(program.getId()));
+				}*/
+			}
+
+		}
 		return R.data(list);
 	}
 
-	/*
-	@Operation(summary = "绋嬪簭鍒嗛〉鏌ヨ", description = "鐢ㄤ簬鍦ㄧ紪鍒惰妭鐐归�夋嫨娴佺▼瀵瑰簲鐨勭▼搴�")
-	@GetMapping("/programpickpage")
-	public R<IPage<NcNodeProgramVO>> page(NcNodeProgramQueryVO query) {
-		IPage<NcNodeProgramVO> pages = ncNodeService.programPageQuery(query);
-		return R.data(pages);
+	@GetMapping("/search-list")
+	@Operation(summary = "鏌ヨ鏍戠姸鍒楄〃", description = "绋嬪簭鐩綍鏍戝舰缁撴瀯锛堟煡璇笓鐢級")
+	public R<List<NcNodeVO>> searchList(NcNodeQueryVO queryVO) {
+		if(Func.isEmpty(queryVO.getName())){
+			return R.fail("璇疯緭鍏ュ悕绉�");
+		}
+		List<NcNodeVO> list = ncNodeService.searchList(queryVO);
+		/*
+		if(list != null && !list.isEmpty()) {
+			for(NcNodeVO ncNodeVO : list) {
+				if(!"70".equals(ncNodeVO.getNodeType())){
+					break;
+				}
+				NcProgram program = ncProgramService.getByBindNodeId(ncNodeVO.getId());
+				if(program != null) {
+					ncNodeVO.setProcessEdition(program.getProcessEdition());
+					ncNodeVO.setDrawingNo(program.getDrawingNo());
+					ncNodeVO.setMachineCode(program.getMachineCode());
+					ncNodeVO.setProcessName(program.getProcessName());
+					ncNodeVO.setVersionNumber(program.getVersionNumber());
+
+					//record涓壘涓嶅埌鏃舵湭鍚姩0锛涙壘鍒颁簡闇�瑕佹煡璇㈡祦绋嬪疄渚媔d锛屾槸鍚﹁繍琛屼腑
+					ncNodeVO.setFlowStatus(programFlowStatusQueryService.queryFlowStatus(program.getId()));
+				}
+			}
+
+		}
+
+		 */
+		return R.data(list);
 	}
-*/
+
+	@GetMapping("/history-by-nodeid")
+	@Operation(summary = "鏍规嵁缁戝畾鑺傜偣id鑾峰彇鍘嗗彶鍒楄〃", description = "绋嬪簭鍘嗗彶鍒楄〃锛屼粎鈥樼▼搴忓寘鈥欏瓧鍏稿��70鐨勬暟鎹�傜敤浜庢樉绀虹▼搴忕殑鈥樺巻鍙茬増鏈��")
+	public R<List<NcNodeVO>> historyByBindNodeId(@Parameter(description="鑺傜偣ID(nodeType=70鐨勮妭鐐筰d)")@RequestParam Long id) {
+		return R.data(this.ncNodeService.historyByNodeId(id));
+	}
 
 }

--
Gitblit v1.9.3