From b4d10ff7535002dddb63a0b28ddb37fee7ed1e9d Mon Sep 17 00:00:00 2001
From: yangys <y_ys79@sina.com>
Date: 星期三, 03 十二月 2025 16:30:53 +0800
Subject: [PATCH] 增加pdf,xlsx,docx文件预览功能

---
 blade-service/blade-mdm/src/main/java/org/springblade/mdm/flow/service/TaskDispatchService.java |  136 ++++++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 132 insertions(+), 4 deletions(-)

diff --git a/blade-service/blade-mdm/src/main/java/org/springblade/mdm/flow/service/TaskDispatchService.java b/blade-service/blade-mdm/src/main/java/org/springblade/mdm/flow/service/TaskDispatchService.java
index b8914d7..1bf86f9 100644
--- a/blade-service/blade-mdm/src/main/java/org/springblade/mdm/flow/service/TaskDispatchService.java
+++ b/blade-service/blade-mdm/src/main/java/org/springblade/mdm/flow/service/TaskDispatchService.java
@@ -1,15 +1,27 @@
 
 package org.springblade.mdm.flow.service;
 
-import lombok.AllArgsConstructor;
+import com.baomidou.mybatisplus.core.toolkit.Wrappers;
+import com.baomidou.mybatisplus.extension.conditions.query.LambdaQueryChainWrapper;
 import lombok.extern.slf4j.Slf4j;
+import org.apache.commons.lang3.StringUtils;
 import org.springblade.core.mp.base.BizServiceImpl;
+import org.springblade.mdm.commons.service.ParamService;
 import org.springblade.mdm.flow.entity.TaskDispatch;
 import org.springblade.mdm.flow.mapper.TaskDispatchMapper;
 import org.springblade.mdm.flow.vo.TaskAssignVO;
+import org.springblade.mdm.program.entity.DrawingNos;
+import org.springblade.mdm.program.entity.NcNode;
+import org.springblade.mdm.program.entity.NcNodeHis;
+import org.springblade.mdm.program.mapper.DrawingNosMapper;
 import org.springframework.beans.BeanUtils;
+import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
+
+import java.time.LocalDateTime;
+import java.util.List;
+import java.util.Optional;
 
 /**
  * 浠诲姟娲惧伐鏁版嵁 澶勭悊鏈嶅姟
@@ -18,21 +30,137 @@
  */
 @Slf4j
 @Service
-@AllArgsConstructor
 public class TaskDispatchService  extends BizServiceImpl<TaskDispatchMapper, TaskDispatch> {
+	@Autowired
+	private ParamService paramService;
+	@Autowired
+	private DrawingNosMapper drawingNosMapper;
+
 
 	@Transactional(rollbackFor = Exception.class)
-	public long saveTask(TaskAssignVO startVO) {
+	public TaskDispatch saveTask(TaskAssignVO startVO,boolean isDup) {
 		TaskDispatch taskDispatch = new TaskDispatch();
 		BeanUtils.copyProperties(startVO, taskDispatch);
+		if(isDup){
+			taskDispatch.setStatus(TaskDispatch.STATUS_DUP);
+		}
 		this.save(taskDispatch);
 
-		return taskDispatch.getId();
+		addDrawingNos(taskDispatch.getDrawingNo());
+		return taskDispatch;
 	}
 
+	/**
+	 * 鍔爑浜轰笅鎷夋暟鎹�
+	 * @param drawingNo
+	 */
+	public void addDrawingNos(String drawingNo){
+		DrawingNos data = drawingNosMapper.selectById(drawingNo);
+		if(data == null){
+			data = new DrawingNos();
+			data.setDrawingNo(drawingNo);
+			try {
+				drawingNosMapper.insert(data);
+			}catch (Exception e){
+				log.error("鍔犲叆闆剁粍浠跺彿涓嬫媺鏁版嵁閿欒");
+			}
+		}
+	}
+	/*
 	public void updateSuccess(long id, String instId) {
 		TaskDispatch taskDispatch = getById(id);
 		taskDispatch.setProcessInstanceId(instId);
+		taskDispatch.setStatus(TaskDispatch.STATUS_STARTED);
 		this.updateById(taskDispatch);
 	}
+
+	 */
+
+
+	/**
+	 * 妫�鏌ユ槸鍚﹂噸澶嶆淳宸�
+	 * @param startVO
+	 * @return
+	 */
+	public boolean checkIsDuplicate(TaskAssignVO startVO) {
+		if(startVO.isTemporaryFlow()){
+			//璇曞垏琛ュ厖锛屼笉楠岃瘉閲嶅
+			return false;
+		}
+
+		int taskDupDays = paramService.taskDuplicateCheckDays();
+		LocalDateTime checkStartDate = LocalDateTime.now().minusDays(taskDupDays);
+		LambdaQueryChainWrapper<TaskDispatch> q = lambdaQuery().eq(TaskDispatch::getDrawingNo,startVO.getDrawingNo())
+			.eq(TaskDispatch::getProcessNo,startVO.getProcessNo())
+			//.eq(TaskDispatch::getProcessEdition,startVO.getProcessEdition())
+			.eq(TaskDispatch::getMachineCode,startVO.getMachineCode())
+			.gt(TaskDispatch::getCreateTime,checkStartDate);
+
+		long cnt = q.count();
+
+		return cnt > 0;
+	}
+	@Transactional(readOnly = true)
+	public List<String> drawingNoSeletDropList(String drawingNo){
+		return drawingNosMapper.selectDropDownList(drawingNo);
+	}
+
+	@Transactional
+	public void resetDrawingNos() {
+		drawingNosMapper.delete(Wrappers.emptyWrapper());//
+		List<String> dnoList =  baseMapper.distinctAllDrawingNo();
+		for(String dno : dnoList){
+			DrawingNos drawingNos = new DrawingNos();
+			drawingNos.setDrawingNo(dno);
+			drawingNosMapper.insert(drawingNos);
+		}
+
+	}
+
+	/**
+	 * 娓呯悊杩囨湡鐨勫紓甯镐换鍔¤鍒�
+	 */
+	@Transactional
+    public void cleanExpiredExceptionTask() {
+		int expireDays = paramService.getTaskExpireDays();
+		LocalDateTime expiredTime = LocalDateTime.now().minusDays(expireDays);
+		baseMapper.deleteExpiredExceptionTasks(expiredTime);
+    }
+
+	/**
+	 * 鏍规嵁宸ュ簭鍞竴鐮佽幏鍙栨淳宸ユ暟鎹�
+	 * @param operationId 宸ュ簭鍞竴鐮�
+	 * @return
+	 */
+	public TaskDispatch getByOperationId(String operationId) {
+		Optional<TaskDispatch> opt = lambdaQuery().eq(TaskDispatch::getOperationId, operationId).oneOpt();
+		return opt.orElse(null);
+	}
+
+	/**
+	 * 鏍规嵁绋嬪簭鍐呴儴缂栧彿鑾峰彇瀹炰綋
+	 * @param programNo 鍐呴儴缂栧彿
+	 * @return 瀹炰綋
+	 */
+    public TaskDispatch getByProgramNo(String programNo) {
+		return lambdaQuery().eq(TaskDispatch::getProgramNo, programNo).one();
+    }
+
+
+	/**
+	 * 鏌ヨ鍋忕鍗曠殑搴忓彿
+	 * @param programNo 鍋忕鍗曠殑绋嬪簭鍖呭悕鑺傜偣
+	 * @return 搴忓彿
+	 */
+	public long getDeviationSerial(String programNo) {
+		TaskDispatch dispatch = this.getByProgramNo(programNo);
+
+		return lambdaQuery()
+			.eq(TaskDispatch::getDrawingNo,dispatch.getDrawingNo())
+			.eq(TaskDispatch::getProcessNo,dispatch.getProcessNo())
+			.eq(TaskDispatch::getProcessEdition,dispatch.getProcessEdition())
+			.eq(TaskDispatch::getDeviation,dispatch.getDeviation())
+			.le(TaskDispatch::getCreateTime,dispatch.getCreateTime())  //鏃堕棿灏忎簬绛変簬褰撳墠鑺傜偣
+			.count();
+	}
 }

--
Gitblit v1.9.3