From 4dd78acfe298217ebc5dd247c5b45c6f33deea9b Mon Sep 17 00:00:00 2001
From: wlzboy <66905212@qq.com>
Date: 星期六, 08 十一月 2025 22:43:14 +0800
Subject: [PATCH] feat:医院选择计算

---
 ruoyi-admin/src/main/java/com/ruoyi/web/controller/task/SysTaskAttachmentController.java |   55 ++++++++++++++++++++++++++++++++++++++++++++++++++-----
 1 files changed, 50 insertions(+), 5 deletions(-)

diff --git a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/task/SysTaskAttachmentController.java b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/task/SysTaskAttachmentController.java
index d9e5490..39189cc 100644
--- a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/task/SysTaskAttachmentController.java
+++ b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/task/SysTaskAttachmentController.java
@@ -1,5 +1,6 @@
 package com.ruoyi.web.controller.task;
 
+import java.util.Date;
 import java.util.List;
 import java.io.File;
 import java.io.FileInputStream;
@@ -9,6 +10,11 @@
 import com.ruoyi.common.utils.WechatUtils;
 import com.ruoyi.common.config.WechatConfig;
 import com.ruoyi.system.domain.SysTask;
+import com.ruoyi.system.domain.SysTaskEmergency;
+import com.ruoyi.system.service.ISysTaskEmergencyService;
+import com.ruoyi.system.service.ISysUserService;
+import com.ruoyi.system.service.ITaskAttachmentSyncService;
+import com.ruoyi.system.task.ITaskAttachmentService;
 import org.springframework.security.access.prepost.PreAuthorize;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.web.bind.annotation.GetMapping;
@@ -38,10 +44,24 @@
     
     @Autowired
     private ISysTaskService sysTaskService;
+
+    @Autowired
+    private ISysUserService sysUserService;
+
+    @Autowired
+    private ITaskAttachmentSyncService taskAttachmentSyncService;
+
+    @Autowired
+    private ITaskAttachmentService taskAttachmentService;
     
     @Autowired
     private WechatConfig wechatConfig;
 
+    @Autowired
+    private ISysTaskEmergencyService sysTaskEmergencyService;
+
+    @Autowired
+    private ISysUserService userService;
     /**
      * 鏌ヨ浠诲姟闄勪欢鍒楄〃
      */
@@ -60,10 +80,12 @@
     @PostMapping("/upload/{taskId}")
     public AjaxResult upload(@PathVariable("taskId") Long taskId, 
                             @RequestParam("file") MultipartFile file,
-                            @RequestParam(value = "category", required = false) String category) {
+                            @RequestParam(value = "category", required = true) String category) {
         try {
-            int result = sysTaskService.uploadAttachment(taskId, file, category);
-            if (result > 0) {
+            Long attachmentId= sysTaskService.uploadAttachment(taskId, file, category);
+            if (attachmentId > 0) {
+                //鍦ㄨ繖閲岃繘琛屽悓姝�
+                SyncAttachmentToImageData(taskId,sysTaskService.getTaskDetail(taskId).getCreatorId(),attachmentId);
                 return success("涓婁紶鎴愬姛");
             } else {
                 return error("涓婁紶澶辫触");
@@ -73,6 +95,27 @@
         }
     }
 
+    private void SyncAttachmentToImageData(Long taskId,Long taskCreatorId, Long attachmentId) {
+       Integer oaUserId= sysUserService.selectUserById(taskCreatorId).getOaUserId();
+        SysTaskEmergency taskEmergency= sysTaskEmergencyService.selectSysTaskEmergencyByTaskId(taskId);
+        if(taskEmergency!=null ){
+            Long serviceOrderId= taskEmergency.getLegacyServiceOrdId();
+            Long dispathOrdId=taskEmergency.getLegacyDispatchOrdId();
+
+            if(serviceOrderId!=null && dispathOrdId!=null){
+                SysTaskAttachment attachment=sysTaskService.getAttachmentById(attachmentId);
+               Long imageDataId= taskAttachmentSyncService.syncAttachmentToImageData(attachment, serviceOrderId, dispathOrdId,oaUserId);
+                //鍚屾鎴愬姛
+                if(imageDataId>0){
+                    attachment.setSyncedToImageData(1);
+                    attachment.setSyncTime(new Date());
+                    attachment.setImageDataId(imageDataId);
+                    taskAttachmentService.updateAttachment(attachment);
+                }
+
+            }
+        }
+    }
     /**
      * 鍒犻櫎浠诲姟闄勪欢
      */
@@ -112,8 +155,10 @@
             }
             
             // 閫氳繃mediaId涓婁紶闄勪欢
-            int result = sysTaskService.uploadAttachmentFromWechat(taskId, accessToken, mediaId, category);
-            if (result > 0) {
+            Long attachmentId = sysTaskService.uploadAttachmentFromWechat(taskId, accessToken, mediaId, category);
+            SysTask task=sysTaskService.getTaskDetail(taskId);
+            if (attachmentId > 0) {
+                this.SyncAttachmentToImageData(taskId,task.getCreatorId(),attachmentId);
                 return success("涓婁紶鎴愬姛");
             } else {
                 return error("涓婁紶澶辫触");

--
Gitblit v1.9.1