From de04015a9eaf4a9928a1cba6cdfceed03146a720 Mon Sep 17 00:00:00 2001
From: xiangpei <xiangpei@timesnew.cn>
Date: 星期五, 29 十一月 2024 20:06:07 +0800
Subject: [PATCH] 项目启动流程、变更流程逻辑调整

---
 business/src/main/java/com/ycl/service/impl/ProjectProcessServiceImpl.java |   70 ++++++++++++++++++++++-------------
 1 files changed, 44 insertions(+), 26 deletions(-)

diff --git a/business/src/main/java/com/ycl/service/impl/ProjectProcessServiceImpl.java b/business/src/main/java/com/ycl/service/impl/ProjectProcessServiceImpl.java
index 3dd0831..92336c5 100644
--- a/business/src/main/java/com/ycl/service/impl/ProjectProcessServiceImpl.java
+++ b/business/src/main/java/com/ycl/service/impl/ProjectProcessServiceImpl.java
@@ -85,52 +85,69 @@
     }
 
     @Override
+    @Transactional(rollbackFor = Exception.class)
     public Result projectSetProcess(ProjectProcessForm form) {
         // 鏌ヨ璇ラ」鐩槸鍚﹀凡缁忕粦瀹氳繃娴佺▼浜嗭紝妫�鏌ョ粦瀹氱殑娴佺▼鏄惁鍦ㄨ繍琛岋紝鍦ㄨ繍琛屽氨鍒犱簡
         ProjectProcess pp = new LambdaQueryChainWrapper<>(baseMapper)
                 .eq(ProjectProcess::getProjectId, form.getProjectId())
                 .one();
-        if (Objects.nonNull(pp)) {
-            // TODO 澶勭悊涔嬪墠缁戝畾杩囩殑娴佺▼鏁版嵁
-            new LambdaUpdateChainWrapper<>(baseMapper)
-                    .eq(ProjectProcess::getProjectId, form.getProjectId())
-                    .set(ProjectProcess::getProcessDefId, form.getProcessDefId())
-                    .update();
-        } else {
-            ProjectProcess entity = ProjectProcessForm.getEntityByForm(form, null);
-            baseMapper.insert(entity);
+        if (Objects.isNull(pp)) {
+            throw new RuntimeException("璇ラ」鐩湭缁戝畾娴佺▼");
         }
+        if (Objects.nonNull(pp.getProcessInsId())) {
+            HistoricProcessInstance historicProcessInstance =
+                    historyService.createHistoricProcessInstanceQuery().processInstanceId(pp.getProcessInsId()).singleResult();
+            // 鍒犻櫎涔嬪墠娴佺▼鐨勬暟鎹�
+            if (historicProcessInstance.getEndTime() != null) {
+                historyService.deleteHistoricProcessInstance(historicProcessInstance.getId());
+            } else {
+                // 鍒犻櫎娴佺▼瀹炰緥
+                runtimeService.deleteProcessInstance(pp.getProcessInsId(), "");
+                // 鍒犻櫎鍘嗗彶娴佺▼瀹炰緥
+                historyService.deleteHistoricProcessInstance(pp.getProcessInsId());
+            }
+        }
+        String processInsId = this.startPro(form.getProjectId(), form.getProcessDefId());
+        new LambdaUpdateChainWrapper<>(baseMapper)
+                .eq(ProjectProcess::getProjectId, form.getProjectId())
+                .set(ProjectProcess::getProcessDefId, form.getProcessDefId())
+                .set(ProjectProcess::getProcessInsId, processInsId)
+                .update();
         return Result.ok("娴佺▼鍙樻洿鎴愬姛");
     }
 
     @Override
     @Transactional(rollbackFor = Exception.class)
-    public Result startProcess(String projectId, String processDefId) {
+    public Result startProcess(Long projectId, String processDefId) {
+        String processInsId = this.startPro(projectId, processDefId);
+        ProjectProcess entity = new ProjectProcess();
+        entity.setProjectId(projectId);
+        entity.setProcessDefId(processDefId);
+        entity.setProcessInsId(processInsId);
+        baseMapper.insert(entity);
+        return Result.ok("娴佺▼鍚姩鎴愬姛");
+    }
+
+    /**
+     * 鍚姩娴佺▼
+     *
+     * @param projectId
+     * @param processDefId
+     * @return
+     */
+    private String startPro(Long projectId, String processDefId) {
         ProcessDefinition processDefinition = repositoryService.createProcessDefinitionQuery().processDefinitionId(processDefId)
                 .latestVersion().singleResult();
         if (Objects.nonNull(processDefinition) && processDefinition.isSuspended()) {
-            return Result.error("璇ユ祦绋嬪凡琚寕璧�,璇峰厛婵�娲绘祦绋�");
+            throw new RuntimeException("璇ユ祦绋嬪凡琚寕璧�,璇峰厛婵�娲绘祦绋�");
         }
         Map<String, Object> variables = new HashMap<>(2);
         // 璁剧疆娴佺▼鍙戣捣浜篒d鍒版祦绋嬩腑
         SysUser sysUser = SecurityUtils.getLoginUser().getUser();
         identityService.setAuthenticatedUserId(sysUser.getUserId().toString());
         variables.put(ProcessConstants.PROCESS_INITIATOR, sysUser.getUserId());
-        ProcessInstance processInstance = runtimeService.startProcessInstanceById(processDefId, projectId, variables);
-//        // 娴佺▼鍙戣捣鏃� 璺宠繃鍙戣捣浜鸿妭鐐�
-//        // 缁欑涓�姝ョ敵璇蜂汉鑺傜偣璁剧疆浠诲姟鎵ц浜哄拰鎰忚
-//        Task task = taskService.createTaskQuery().processInstanceId(processInstance.getProcessInstanceId()).singleResult();
-//        if (Objects.nonNull(task)) {
-//            taskService.addComment(task.getId(), processInstance.getProcessInstanceId(), FlowComment.NORMAL.getType(), sysUser.getNickName() + "鍙戣捣娴佺▼鐢宠");
-//            taskService.complete(task.getId(), variables);
-//        }
-        // 椤圭洰娴佺▼鍏宠仈娴佺▼瀹炰緥id
-        new LambdaUpdateChainWrapper<>(baseMapper)
-                .eq(ProjectProcess::getProjectId, projectId)
-                .eq(ProjectProcess::getProcessDefId, processDefId)
-                .set(ProjectProcess::getProcessInsId, processInstance.getProcessInstanceId())
-                .update();
-        return Result.ok("娴佺▼鍚姩鎴愬姛");
+        ProcessInstance processInstance = runtimeService.startProcessInstanceById(processDefId, projectId + "", variables);
+        return processInstance.getId();
     }
 
     /**
@@ -458,6 +475,7 @@
      * @param identityLinkInfos 濡傛灉鏄凡瀹屾垚鐨勪换鍔★紝鐢ㄨ繖涓幓鍙栧叧鑱旂殑鐢ㄦ埛/鐢ㄦ埛缁�
      */
     private void setPromoterAndHandler(CustomerTaskVO taskVO, List<? extends IdentityLinkInfo> identityLinkInfos) {
+        // TODO 鍙戣捣浜烘槸鍚﹀簲涓轰笂涓�鑺傜偣鐨勫鐞嗕汉
         // 娴佺▼鍙戣捣浜轰俊鎭�
         HistoricProcessInstance historicProcessInstance = historyService.createHistoricProcessInstanceQuery()
                 .processInstanceId(taskVO.getProcessInsId())

--
Gitblit v1.8.0