From ec899ee7e9ead5152bd9b4c2dedd75c79cab6fb0 Mon Sep 17 00:00:00 2001
From: wxw <Administrator@DESKTOP-5BIMHQ3>
Date: 星期三, 28 八月 2024 17:03:44 +0800
Subject: [PATCH] Merge branch 'master' into wxw

---
 Admin.NET/WCS.Application/PLC/PLCJob.cs                         |    1 
 Admin.NET/WCS.Application/Service/WcsTask/WcsTaskService.cs     |   58 ++++
 Admin.NET/WCS.Application/Util/HttpService.cs                   |   28 ++
 .gitignore                                                      |    1 
 Web/src/api/wcs/wcsTask.ts                                      |    8 
 Admin.NET/WCS.Application/Configuration/Logging.json            |    2 
 Admin.NET/WCS.Application/Hub/TaskLogHub.cs                     |   56 ++++
 Web/src/api/log/wcsAlarmLog.ts                                  |   50 +++
 Admin.NET/WCS.Application/Hub/ITaskLogHub.cs                    |   25 +
 Admin.NET/Admin.NET.Core/Logging/LoggingSetup.cs                |    5 
 Web/src/views/wcs/wcsDevice/component/editDialog.vue            |    4 
 Admin.NET/WCS.Application/PLC/PLCService.cs                     |  327 +++++++++++++++++-------
 Web/src/views/wcs/wcsTask/signalR.ts                            |   37 ++
 Admin.NET/WCS.Application/PLC/PLCTaskAction.cs                  |    4 
 Admin.NET/WCS.Application/Service/WcsDevice/Dto/WcsDeviceDto.cs |   10 
 Web/src/views/wcs/wcsTask/index.vue                             |  120 ++++++---
 16 files changed, 583 insertions(+), 153 deletions(-)

diff --git a/.gitignore b/.gitignore
index 10d1295..b1a5d68 100644
--- a/.gitignore
+++ b/.gitignore
@@ -200,6 +200,7 @@
 # except build/, which is used as an MSBuild target.
 !**/[Pp]ackages/build/
 !**/system/log/
+!**/api/log/
 # Uncomment if necessary however generally it will be regenerated when needed
 #!**/[Pp]ackages/repositories.config
 # NuGet v3's project.json files produces more ignorable files
diff --git a/Admin.NET/Admin.NET.Core/Logging/LoggingSetup.cs b/Admin.NET/Admin.NET.Core/Logging/LoggingSetup.cs
index 99e372f..33e1dd2 100644
--- a/Admin.NET/Admin.NET.Core/Logging/LoggingSetup.cs
+++ b/Admin.NET/Admin.NET.Core/Logging/LoggingSetup.cs
@@ -45,7 +45,10 @@
                     options.WithTraceId = true; // 鏄剧ず绾跨▼Id
                     options.WithStackFrame = true; // 鏄剧ず绋嬪簭闆�
                     options.FileNameRule = fileName => string.Format(fileName, DateTime.Now, logLevel.ToString()); // 姣忓ぉ鍒涘缓涓�涓枃浠�
-                    options.WriteFilter = logMsg => logMsg.LogLevel >= logLevel; // 鏃ュ織绾у埆
+                    options.WriteFilter = (logMsg) =>
+                    {
+                        return logMsg.LogLevel >= logLevel && logMsg.LogName != CommonConst.SysLogCategoryName; // 鍙啓LoggingMonitor鏃ュ織
+                    }; // 鏃ュ織绾у埆
                     options.HandleWriteError = (writeError) => // 鍐欏叆澶辫触鏃跺惎鐢ㄥ鐢ㄦ枃浠�
                     {
                         writeError.UseRollbackFileName(Path.GetFileNameWithoutExtension(writeError.CurrentFileName) + "-oops" + Path.GetExtension(writeError.CurrentFileName));
diff --git a/Admin.NET/WCS.Application/Configuration/Logging.json b/Admin.NET/WCS.Application/Configuration/Logging.json
index f1e9833..8e8520c 100644
--- a/Admin.NET/WCS.Application/Configuration/Logging.json
+++ b/Admin.NET/WCS.Application/Configuration/Logging.json
@@ -6,7 +6,7 @@
       "Microsoft.EntityFrameworkCore": "Information"
     },
     "File": {
-      "Enabled": false, // 鍚敤鏂囦欢鏃ュ織
+      "Enabled": true, // 鍚敤鏂囦欢鏃ュ織
       "FileName": "logs/{0:yyyyMMdd}_{1}.log", // 鏃ュ織鏂囦欢
       "Append": true, // 杩藉姞瑕嗙洊
       // "MinimumLevel": "Information", // 鏃ュ織绾у埆
diff --git a/Admin.NET/WCS.Application/Hub/ITaskLogHub.cs b/Admin.NET/WCS.Application/Hub/ITaskLogHub.cs
new file mode 100644
index 0000000..0b0dd6b
--- /dev/null
+++ b/Admin.NET/WCS.Application/Hub/ITaskLogHub.cs
@@ -0,0 +1,25 @@
+锘�
+namespace WCS.Application;
+public interface ITaskLogHub
+{
+    /// <summary>
+    /// 涓嬪彂浠诲姟
+    /// </summary>
+    /// <param name="context"></param>
+    /// <returns></returns>
+    Task PublicTask(WcsTaskOutput context);
+
+    /// <summary>
+    /// 涓嬪彂浠诲姟鏄庣粏
+    /// </summary>
+    /// <param name="context"></param>
+    /// <returns></returns>
+    Task PublicTaskMonitor(WcsTaskMonitorOutput context);
+
+    /// <summary>
+    /// 鎺ユ敹娑堟伅
+    /// </summary>
+    /// <param name="context"></param>
+    /// <returns></returns>
+    Task ReceiveMessage(object context);
+}
diff --git a/Admin.NET/WCS.Application/Hub/TaskLogHub.cs b/Admin.NET/WCS.Application/Hub/TaskLogHub.cs
new file mode 100644
index 0000000..b4d018c
--- /dev/null
+++ b/Admin.NET/WCS.Application/Hub/TaskLogHub.cs
@@ -0,0 +1,56 @@
+锘縰sing Furion.InstantMessaging;
+using Microsoft.AspNetCore.SignalR;
+
+namespace WCS.Application;
+
+/// <summary>
+/// 浠诲姟鏃ュ織闆嗙嚎鍣�
+/// </summary>
+[MapHub("/hubs/TaskLog")]
+public class TaskLogHub : Hub<ITaskLogHub>
+{
+    private readonly IHubContext<TaskLogHub, ITaskLogHub> _taskLogHubContext;
+
+    public TaskLogHub(IHubContext<TaskLogHub, ITaskLogHub> taskLogHubContext)
+    {
+        _taskLogHubContext = taskLogHubContext;
+    }
+
+    /// <summary>
+    /// 杩炴帴
+    /// </summary>
+    /// <returns></returns>
+    public override async Task OnConnectedAsync()
+    {
+        await base.OnConnectedAsync();
+    }
+
+    /// <summary>
+    /// 鏂紑
+    /// </summary>
+    /// <param name="exception"></param>
+    /// <returns></returns>
+    public override async Task OnDisconnectedAsync(Exception exception)
+    {
+        await base.OnDisconnectedAsync(exception);
+    }
+
+    /// <summary>
+    /// 涓嬪彂浠诲姟
+    /// </summary>
+    /// <returns></returns>
+    public async Task PublicTask(WcsTaskOutput context)
+    {
+        await _taskLogHubContext.Clients.All.PublicTask(context);
+    }
+
+    /// <summary>
+    /// 涓嬪彂浠诲姟鏄庣粏
+    /// </summary>
+    /// <returns></returns>
+    public async Task PublicTaskMonitor(WcsTaskMonitorOutput context)
+    {
+        await _taskLogHubContext.Clients.All.PublicTaskMonitor(context);
+    }
+
+}
diff --git a/Admin.NET/WCS.Application/PLC/PLCJob.cs b/Admin.NET/WCS.Application/PLC/PLCJob.cs
index 3927eca..eb66aae 100644
--- a/Admin.NET/WCS.Application/PLC/PLCJob.cs
+++ b/Admin.NET/WCS.Application/PLC/PLCJob.cs
@@ -1,4 +1,5 @@
 锘縰sing Furion.Schedule;
+using Microsoft.AspNetCore.SignalR;
 using Microsoft.Extensions.Logging;
 
 namespace WCS.Application;
diff --git a/Admin.NET/WCS.Application/PLC/PLCService.cs b/Admin.NET/WCS.Application/PLC/PLCService.cs
index cf5a94c..7f56930 100644
--- a/Admin.NET/WCS.Application/PLC/PLCService.cs
+++ b/Admin.NET/WCS.Application/PLC/PLCService.cs
@@ -1,12 +1,19 @@
 锘�
 using Furion.Logging;
 using IoTClient;
+using Microsoft.AspNetCore.SignalR;
 using System.Data;
 
 namespace WCS.Application;
 public static class PLCService
 {
     private static readonly ISqlSugarClient _db = SqlSugarSetup.ITenant.GetConnectionScope(SqlSugarConst.MainConfigId);
+    private static readonly IHubContext<TaskLogHub, ITaskLogHub> _taskLogHubContext;
+
+    static PLCService()
+    {
+        _taskLogHubContext = App.GetService<IHubContext<TaskLogHub, ITaskLogHub>>();
+    }
 
     public static void OnChangeEvent(object sender, EventArgs e)
     {
@@ -107,12 +114,8 @@
                                     modTaskMonitor.InteractiveMsg = "璧峰鍌ㄤ綅涓虹┖!";
 
                                     _db.Insertable(modTaskMonitor).ExecuteCommand();
-
-                                    // 閫氱煡浠诲姟鐣岄潰浠诲姟宸插瓨鍦ㄦ洿鏂� 璇锋洿鏂扮晫闈�
-                                    //if (TaskAction.refresh)
-                                    //{
-                                    //    wSChat.AlarmInformation("1");
-                                    //}
+                                    //涓嬪彂浠诲姟鏃ュ織
+                                    _taskLogHubContext.Clients.All.PublicTaskMonitor(modTaskMonitor.Adapt<WcsTaskMonitorOutput>());
                                     break;
                                 }
                                 //缁橮LC鍐欏叆浠诲姟鏁版嵁
@@ -144,7 +147,7 @@
                                 if (listResult.All(s => s.IsSucceed))
                                 {
                                     // 鍐欏叆璺烘満浠诲姟涓嬪彂瀹屾垚
-                                    plcConn.SetPlcDBValue(modDevice.PosType.Value, modDevice.DbNumber, modDevice.WcsPos, "10");
+                                    plcConn.SetPlcDBValue(modDevice.PosType, modDevice.DbNumber, modDevice.WcsPos, "10");
 
                                     // 灏嗗嚭搴撲换鍔″緟鎵ц鏀逛负姝e湪鎵ц
                                     _db.Updateable<WcsTask>()
@@ -165,11 +168,8 @@
                                         EndLocat = outStationNum,
                                     };
                                     _db.Insertable(modInsertTaskMonitor).ExecuteCommand();
-                                    // 閫氱煡浠诲姟鐣岄潰浠诲姟宸插瓨鍦ㄦ洿鏂� 璇锋洿鏂扮晫闈�
-                                    //if (TaskAction.refresh)
-                                    //{
-                                    //    wSChat.AlarmInformation("1");
-                                    //}
+                                    //涓嬪彂浠诲姟鏃ュ織
+                                    _taskLogHubContext.Clients.All.PublicTaskMonitor(modInsertTaskMonitor.Adapt<WcsTaskMonitorOutput>());
                                     //淇敼led灞忎俊鎭�
                                     //LedDisplay(modDevice.LedIP, "宸ヤ綅:" + modTask.EndLocate, "鍑哄簱涓� " + $"鍌ㄤ綅鍦板潃锛歿modTask.StartLocate}", "鎵樼洏鍙�:" + modTask.PalletNo);
                                 }
@@ -236,11 +236,8 @@
                             Status = TaskStatusEnum.Complete
                         };
                         _db.Insertable(modTaskMonitor).ExecuteCommand();
-                        //閫氱煡浠诲姟鐣岄潰浠诲姟宸插瓨鍦ㄦ洿鏂� 璇锋洿鏂扮晫闈�
-                        //if (TaskAction.refresh)
-                        //{
-                        //    wSChat.AlarmInformation("1");
-                        //}
+                        //涓嬪彂浠诲姟鏃ュ織
+                        _taskLogHubContext.Clients.All.PublicTaskMonitor(modTaskMonitor.Adapt<WcsTaskMonitorOutput>());
 
                     }
                     else if (modTask.TaskType.Value == TaskTypeEnum.Out)
@@ -249,7 +246,7 @@
                         var res = plcConn.SetPlcDBValue(modPosTask.PosType, modDevice.DbNumber, modPosTask.PlcPos, taskNo);
                         if (!res.IsSucceed)
                             break;
-                        res = plcConn.SetPlcDBValue(modDevice.PosType.Value, modDevice.DbNumber, modDevice.WcsPos, "20");
+                        res = plcConn.SetPlcDBValue(modDevice.PosType, modDevice.DbNumber, modDevice.WcsPos, "20");
                         if (!res.IsSucceed)
                             break;
                         // 鏍规嵁璺烘満鍙风‘璁ゅ彇璐у伐浣�
@@ -277,11 +274,8 @@
                             Status = TaskStatusEnum.Complete
                         };
                         _db.Insertable(modTaskMonitor).ExecuteCommand();
-                        //閫氱煡浠诲姟鐣岄潰浠诲姟宸插瓨鍦ㄦ洿鏂� 璇锋洿鏂扮晫闈�
-                        //if (TaskAction.refresh)
-                        //{
-                        //    wSChat.AlarmInformation("1");
-                        //}
+                        //涓嬪彂浠诲姟鏃ュ織
+                        _taskLogHubContext.Clients.All.PublicTaskMonitor(modTaskMonitor.Adapt<WcsTaskMonitorOutput>());
                     }
                 }
                 break;
@@ -310,7 +304,7 @@
                                 var res = plcConn.SetPlcDBValue(modStation.PosType, modDevice.DbNumber, modStation.PlcPos, taskNo);
                                 if (!res.IsSucceed)
                                     break;
-                                res = plcConn.SetPlcDBValue(modDevice.PosType.Value, modDevice.DbNumber, modDevice.WcsPos, "30");
+                                res = plcConn.SetPlcDBValue(modDevice.PosType, modDevice.DbNumber, modDevice.WcsPos, "30");
                                 if (!res.IsSucceed)
                                     break;
                                 //淇敼浠诲姟鐘舵��
@@ -344,11 +338,8 @@
                                         Status = TaskStatusEnum.Complete
                                     };
                                     _db.Insertable(modTaskMonitor).ExecuteCommand();
-                                    // 閫氱煡浠诲姟鐣岄潰浠诲姟宸插瓨鍦ㄦ洿鏂� 璇锋洿鏂扮晫闈�
-                                    //if (TaskAction.refresh)
-                                    //{
-                                    //    wSChat.AlarmInformation("1");
-                                    //}
+                                    //涓嬪彂浠诲姟鏃ュ織
+                                    _taskLogHubContext.Clients.All.PublicTaskMonitor(modTaskMonitor.Adapt<WcsTaskMonitorOutput>());
                                 }
                                 else
                                 {
@@ -363,80 +354,129 @@
                             }
                             break;
                         case TaskTypeEnum.Out://鍑哄簱
-                            // 浠庡嚭搴撲换鍔¤幏鍙栧贩閬撳彿
-                            string num = ""; // 鏀捐揣宸ヤ綅鍙�
-                            if (modTask.StartRoadway == "R01")
                             {
-                                num = "11"; //浜や簰宸ヤ綅
-                            }
-                            else if (modTask.StartRoadway == "R02")
-                            {
-                                num = "7"; //浜や簰宸ヤ綅
-                            }
-                            var modDevice2 = modDevice.listDevice.FirstOrDefault(s => s.StationNum == num);
-                            if (modDevice2 == null)
-                            {
-                                Log.Error($"銆愯泛鏈恒�戞壘涓嶅埌宸ヤ綅{num}璁惧淇℃伅");
-                                break;
-                            }
-                            // 鏍规嵁鐩爣鍙h幏鍙栫洰鏍囧伐浣�
-                            string outCode = modTask.EndLocate.IsNullOrEmpty() ? "-1" : modTask.EndLocate;
-
-                            var listStation = _db.Queryable<WcsPosition>().Where(s => s.DeviceId == modDevice2.Id).ToList();
-                            //缁橮LC鍐欏叆浠诲姟鏁版嵁
-                            var listResult = new List<Result>();
-                            //浠诲姟鍙�
-                            var modPosTask = listStation.FirstOrDefault(s => s.Text == "TaskNo");
-                            listResult.Add(plcConn.SetPlcDBValue(modPosTask.PosType, modDevice.DbNumber, modPosTask.PlcPos, modTask.TaskNo));
-                            //鎵樼洏鍙�
-                            var modPosPalletNo = listStation.FirstOrDefault(s => s.Text == "PalletNo");
-                            listResult.Add(plcConn.SetPlcDBValue(modPosPalletNo.PosType, modDevice.DbNumber, modPosPalletNo.PlcPos, modTask.PalletNo));
-                            //璧峰宸ヤ綅
-                            var modPosLocatNo = listStation.FirstOrDefault(s => s.Text == "StartLocatNo");
-                            listResult.Add(plcConn.SetPlcDBValue(modPosLocatNo.PosType, modDevice.DbNumber, modPosLocatNo.PlcPos, num));
-                            // 鐩爣宸ヤ綅
-                            var modPosEndLocatNo = listStation.FirstOrDefault(s => s.Text == "EndLocatNo");
-                            listResult.Add(plcConn.SetPlcDBValue(modPosEndLocatNo.PosType, modDevice.DbNumber, modPosEndLocatNo.PlcPos, outCode));
-                            //鍏ㄩ儴鍐欏叆鎴愬姛
-                            if (listResult.All(s => s.IsSucceed))
-                            {
-                                // 鍐欏叆宸ヤ綅wcs鎺у埗瀛�
-                                var res = plcConn.SetPlcDBValue(modDevice2.PosType, modDevice2.DbNumber, modDevice2.WcsPos, "120");
-                                if (!res.IsSucceed)
-                                    break;
-                                //鍐欏叆plc浠诲姟鍙�
-                                var modStation = modDevice.listStation.FirstOrDefault(s => s.Text == "TaskNo");
-                                res = plcConn.SetPlcDBValue(modStation.PosType, modDevice.DbNumber, modStation.PlcPos, modTask.TaskNo);
-                                if (!res.IsSucceed)
-                                    break;
-                                //鍐欏叆璺烘満wcs鎺у埗瀛楁祦绋�30 杩斿洖鍨涙満鎵ц瀹屾垚
-                                res = plcConn.SetPlcDBValue(modDevice.PosType.Value, modDevice.DbNumber, modDevice.WcsPos, "30");
-                                if (!res.IsSucceed)
-                                    break;
-                                //璁板綍浠诲姟鏄庣粏
-                                var modTaskMonitor = new WcsTaskMonitor()
+                                // 浠庡嚭搴撲换鍔¤幏鍙栧贩閬撳彿
+                                string num = ""; // 鏀捐揣宸ヤ綅鍙�
+                                if (modTask.StartRoadway == "R01")
                                 {
-                                    TaskNo = modTask.TaskNo,
-                                    PlcId = modDevice2.PlcId,
-                                    PlcName = modDevice2.Text,
-                                    InteractiveMsg = $"鍐欏叆鎸囦护锛氭敹鍒拌泛鏈烘斁璐у畬鎴愶紱鏀捐揣{num}宸ヤ綅===銆媨outCode}鍑哄簱鍙�",
-                                    PalletNo = modTask.PalletNo,
-                                    Status = TaskStatusEnum.Complete,
-                                    StartLocat = num, //璧峰浣嶇疆
-                                    EndLocat = outCode, //鐩爣宸ヤ綅
-                                };
-                                _db.Insertable(modTaskMonitor).ExecuteCommand();
+                                    num = "11"; //浜や簰宸ヤ綅
+                                }
+                                else if (modTask.StartRoadway == "R02")
+                                {
+                                    num = "7"; //浜や簰宸ヤ綅
+                                }
+                                var modDevice2 = modDevice.listDevice.FirstOrDefault(s => s.StationNum == num);
+                                if (modDevice2 == null)
+                                {
+                                    Log.Error($"銆愯泛鏈恒�戞壘涓嶅埌宸ヤ綅{num}璁惧淇℃伅");
+                                    break;
+                                }
+                                // 鏍规嵁鐩爣鍙h幏鍙栫洰鏍囧伐浣�
+                                string outCode = modTask.EndLocate.IsNullOrEmpty() ? "-1" : modTask.EndLocate;
 
-                                // 閫氱煡浠诲姟鐣岄潰浠诲姟宸插瓨鍦ㄦ洿鏂� 璇锋洿鏂扮晫闈�
-                                //if (TaskAction.refresh)
-                                //{
-                                //    wSChat.AlarmInformation("1");
-                                //}
-                                //todo:鍨涙満鍑哄簱涓嶇┖璺�
+                                var listStation = _db.Queryable<WcsPosition>().Where(s => s.DeviceId == modDevice2.Id).ToList();
+                                //缁橮LC鍐欏叆浠诲姟鏁版嵁
+                                var listResult = new List<Result>();
+                                //浠诲姟鍙�
+                                var modPosTask = listStation.FirstOrDefault(s => s.Text == "TaskNo");
+                                listResult.Add(plcConn.SetPlcDBValue(modPosTask.PosType, modDevice.DbNumber, modPosTask.PlcPos, modTask.TaskNo));
+                                //鎵樼洏鍙�
+                                var modPosPalletNo = listStation.FirstOrDefault(s => s.Text == "PalletNo");
+                                listResult.Add(plcConn.SetPlcDBValue(modPosPalletNo.PosType, modDevice.DbNumber, modPosPalletNo.PlcPos, modTask.PalletNo));
+                                //璧峰宸ヤ綅
+                                var modPosLocatNo = listStation.FirstOrDefault(s => s.Text == "StartLocatNo");
+                                listResult.Add(plcConn.SetPlcDBValue(modPosLocatNo.PosType, modDevice.DbNumber, modPosLocatNo.PlcPos, num));
+                                // 鐩爣宸ヤ綅
+                                var modPosEndLocatNo = listStation.FirstOrDefault(s => s.Text == "EndLocatNo");
+                                listResult.Add(plcConn.SetPlcDBValue(modPosEndLocatNo.PosType, modDevice.DbNumber, modPosEndLocatNo.PlcPos, outCode));
+                                //鍏ㄩ儴鍐欏叆鎴愬姛
+                                if (listResult.All(s => s.IsSucceed))
+                                {
+                                    // 鍐欏叆宸ヤ綅wcs鎺у埗瀛�
+                                    var res = plcConn.SetPlcDBValue(modDevice2.PosType, modDevice2.DbNumber, modDevice2.WcsPos, "120");
+                                    if (!res.IsSucceed)
+                                        break;
+                                    //鍐欏叆plc浠诲姟鍙�
+                                    var modStation = modDevice.listStation.FirstOrDefault(s => s.Text == "TaskNo");
+                                    res = plcConn.SetPlcDBValue(modStation.PosType, modDevice.DbNumber, modStation.PlcPos, modTask.TaskNo);
+                                    if (!res.IsSucceed)
+                                        break;
+                                    //鍐欏叆璺烘満wcs鎺у埗瀛楁祦绋�30 杩斿洖鍨涙満鎵ц瀹屾垚
+                                    res = plcConn.SetPlcDBValue(modDevice.PosType, modDevice.DbNumber, modDevice.WcsPos, "30");
+                                    if (!res.IsSucceed)
+                                        break;
+                                    //璁板綍浠诲姟鏄庣粏
+                                    var modTaskMonitor = new WcsTaskMonitor()
+                                    {
+                                        TaskNo = modTask.TaskNo,
+                                        PlcId = modDevice2.PlcId,
+                                        PlcName = modDevice2.Text,
+                                        InteractiveMsg = $"鍐欏叆鎸囦护锛氭敹鍒拌泛鏈烘斁璐у畬鎴愶紱鏀捐揣{num}宸ヤ綅===銆媨outCode}鍑哄簱鍙�",
+                                        PalletNo = modTask.PalletNo,
+                                        Status = TaskStatusEnum.Complete,
+                                        StartLocat = num, //璧峰浣嶇疆
+                                        EndLocat = outCode, //鐩爣宸ヤ綅
+                                    };
+                                    _db.Insertable(modTaskMonitor).ExecuteCommand();
+
+                                    //涓嬪彂浠诲姟鏃ュ織
+                                    _taskLogHubContext.Clients.All.PublicTaskMonitor(modTaskMonitor.Adapt<WcsTaskMonitorOutput>());
+                                    //todo:鍨涙満鍑哄簱涓嶇┖璺�
+                                }
                             }
-
                             break;
                         case TaskTypeEnum.Move:
+                            {
+                                //绉诲簱浠诲姟
+                                var modStation = modDevice.listStation.FirstOrDefault(s => s.Text == "TaskNo");
+                                // 鍐欏叆plc浠诲姟鍙�
+                                var res = plcConn.SetPlcDBValue(modStation.PosType, modDevice.DbNumber, modStation.PlcPos, taskNo);
+                                if (!res.IsSucceed)
+                                    break;
+                                //鍐欏叆plc鎺у埗瀛�
+                                res = plcConn.SetPlcDBValue(modDevice.PosType, modDevice.DbNumber, modDevice.WcsPos, "30");
+                                if (!res.IsSucceed)
+                                    break;
+                                modTask.Status = TaskStatusEnum.Complete;
+                                _db.Updateable(modTask).UpdateColumns(s => s.Status).ExecuteCommand();
+                                var modTaskRequest = modTask.Adapt<TaskRequest>();
+                                HttpService httpService = new HttpService();
+                                var modResponseTask = httpService.RequestTask(modTaskRequest).Result;
+                                if (modResponseTask.StatusCode == "0")
+                                {
+                                    //璇锋眰鎴愬姛
+                                    modTask.IsSuccess = TaskSuccessEnum.Success;
+                                    _db.Updateable(modTask).UpdateColumns(s => s.IsSuccess).ExecuteCommand();
+                                    //todo:淇敼鍌ㄤ綅淇℃伅 浠诲姟绫诲瀷 鎵ц鐘舵�� 璧峰浣嶇疆 鐩爣浣嶇疆
+                                    //
+
+                                    //璁板綍浠诲姟鏄庣粏
+                                    var modTaskMonitor = new WcsTaskMonitor()
+                                    {
+                                        TaskNo = modTask.TaskNo,
+                                        PlcId = modDevice.PlcId,
+                                        PlcName = modDevice.Text,
+                                        InteractiveMsg = "浠诲姟瀹屾垚锛岃繑鍥炵粰WMS浠诲姟瀹屾垚",
+                                        StartLocat = modTask.StartLocate,
+                                        EndLocat = modTask.EndLocate,
+                                        PalletNo = modTask.PalletNo,
+                                        Status = TaskStatusEnum.Complete
+                                    };
+                                    _db.Insertable(modTaskMonitor).ExecuteCommand();
+                                    //涓嬪彂浠诲姟鏃ュ織
+                                    _taskLogHubContext.Clients.All.PublicTaskMonitor(modTaskMonitor.Adapt<WcsTaskMonitorOutput>());
+                                }
+                                else
+                                {
+                                    //璇锋眰澶辫触
+                                    modTask.IsSuccess = TaskSuccessEnum.Fail;
+                                    modTask.Information = modResponseTask.Message;
+                                    _db.Updateable(modTask).UpdateColumns(s => new { s.IsSuccess, s.Information }).ExecuteCommand();
+                                }
+
+                                //todo:LED灞�
+
+                            }
 
                             break;
                         default:
@@ -444,6 +484,99 @@
                     }
                 }
                 break;
+            case "100":
+                {
+                    //绌哄彇璐у紓甯�
+                    var modPosPlcTask = modDevice.listStation.FirstOrDefault(s => s.Text == "PlcTaskNo");
+                    var modPosTask = modDevice.listStation.FirstOrDefault(s => s.Text == "TaskNo");
+                    var (result, TaskNo) = plcConn.GetPlcDBValue(modPosPlcTask.PosType, modDevice.DbNumber, modPosPlcTask.PlcPos);
+                    if (!result.IsSucceed)
+                        break;
+                    string taskNo = Convert.ToString(TaskNo);
+                    var modTask = _db.Queryable<WcsTask>().First(s => s.TaskNo == taskNo && s.Status == TaskStatusEnum.Doing);
+                    if (modTask == null)
+                    {
+                        Log.Error($"銆愯泛鏈恒�戝綋鍓嶄换鍔″彿涓嶅瓨鍦ㄥ搴旂殑浠诲姟锛屼换鍔″彿锛歿modTask.TaskNo}");
+                        break;
+                    }
+                    var res = plcConn.SetPlcDBValue(modPosTask.PosType, modDevice.DbNumber, modPosTask.PlcPos, taskNo);
+                    if (!res.IsSucceed)
+                        break;
+                    res = plcConn.SetPlcDBValue(modDevice.PosType, modDevice.DbNumber, modDevice.WcsPos, "100");
+                    if (!res.IsSucceed)
+                        break;
+                    modTask.Status = TaskStatusEnum.Exception;
+                    _db.Updateable(modTask).UpdateColumns(s => s.Status).ExecuteCommand();
+                    Log.Information($"銆愯泛鏈恒�憌cs浠诲姟鍙樻洿绌哄彇寮傚父锛屼换鍔″彿锛歿modTask.TaskNo}");
+                    var modTaskRequest = modTask.Adapt<TaskRequest>();
+                    HttpService httpService = new HttpService();
+                    var modResponseTask = httpService.RequestEmptyException(modTaskRequest).Result;
+                    if (modResponseTask.StatusCode == "0")
+                    {
+                        //璇锋眰鎴愬姛
+                        modTask.IsSuccess = TaskSuccessEnum.Success;
+                        _db.Updateable(modTask).UpdateColumns(s => s.IsSuccess).ExecuteCommand();
+                        //涓嬪彂浠诲姟鏃ュ織
+                        _taskLogHubContext.Clients.All.PublicTask(modTask.Adapt<WcsTaskOutput>());
+                    }
+                    else
+                    {
+                        //璇锋眰澶辫触
+                        modTask.IsSuccess = TaskSuccessEnum.Fail;
+                        modTask.Information = modResponseTask.Message;
+                        _db.Updateable(modTask).UpdateColumns(s => new { s.IsSuccess, s.Information }).ExecuteCommand();
+                    }
+                    //todo:LED灞�
+                }
+                break;
+            case "101":
+                {
+                    //婊℃斁璐у紓甯�
+                    var modPosPlcTask = modDevice.listStation.FirstOrDefault(s => s.Text == "PlcTaskNo");
+                    var modPosTask = modDevice.listStation.FirstOrDefault(s => s.Text == "TaskNo");
+                    var modPosPalletNo = modDevice.listStation.FirstOrDefault(s => s.Text == "PalletNo");
+                    var (result, TaskNo) = plcConn.GetPlcDBValue(modPosPlcTask.PosType, modDevice.DbNumber, modPosPlcTask.PlcPos);
+                    if (!result.IsSucceed)
+                        break;
+                    string taskNo = Convert.ToString(TaskNo);
+                    var modTask = _db.Queryable<WcsTask>().First(s => s.TaskNo == taskNo && s.Status == TaskStatusEnum.Doing);
+                    if (modTask == null)
+                    {
+                        Log.Error($"銆愯泛鏈恒�戝綋鍓嶄换鍔″彿涓嶅瓨鍦ㄥ搴旂殑浠诲姟锛屼换鍔″彿锛歿modTask.TaskNo}");
+                        break;
+                    }
+                    modTask.Status = TaskStatusEnum.Exception;
+                    _db.Updateable(modTask).UpdateColumns(s => s.Status).ExecuteCommand();
+                    Log.Information($"銆愯泛鏈恒�憌cs浠诲姟鍙樻洿婊″彇寮傚父锛屼换鍔″彿锛歿modTask.TaskNo}");
+                    var modTaskRequest = modTask.Adapt<TaskRequest>();
+                    HttpService httpService = new HttpService();
+                    var modResponseTask = httpService.RequestEmptyException(modTaskRequest).Result;
+                    if (modResponseTask.StatusCode == "0")
+                    {
+                        //璇锋眰鎴愬姛
+                        modTask.IsSuccess = TaskSuccessEnum.Success;
+                        _db.Updateable(modTask).UpdateColumns(s => s.IsSuccess).ExecuteCommand();
+                        var modInsertTask = modResponseTask.TaskList;
+                        modInsertTask.TaskType = TaskTypeEnum.In;
+                        modInsertTask.Origin = "WMS";
+                        modInsertTask.StartLocate = modTask.StartLocate;
+                        modInsertTask.Levels = 1;
+                        _db.Insertable(modInsertTask);
+
+                        //涓嬪彂浠诲姟鏃ュ織
+                        _taskLogHubContext.Clients.All.PublicTask(modInsertTask.Adapt<WcsTaskOutput>());
+                    }
+                    else
+                    {
+                        //璇锋眰澶辫触
+                        modTask.IsSuccess = TaskSuccessEnum.Fail;
+                        modTask.Information = modResponseTask.Message;
+                        _db.Updateable(modTask).UpdateColumns(s => new { s.IsSuccess, s.Information }).ExecuteCommand();
+                    }
+                    //todo:LED灞�
+
+                }
+                break;
             default:
                 break;
         }
diff --git a/Admin.NET/WCS.Application/PLC/PLCTaskAction.cs b/Admin.NET/WCS.Application/PLC/PLCTaskAction.cs
index 0eaf3a5..63086d6 100644
--- a/Admin.NET/WCS.Application/PLC/PLCTaskAction.cs
+++ b/Admin.NET/WCS.Application/PLC/PLCTaskAction.cs
@@ -1,5 +1,5 @@
-锘縰sing Admin.NET.Core.Service;
-using Furion.Logging;
+锘縰sing Furion.Logging;
+using Microsoft.AspNetCore.SignalR;
 
 namespace WCS.Application;
 public static class PLCTaskAction
diff --git a/Admin.NET/WCS.Application/Service/WcsDevice/Dto/WcsDeviceDto.cs b/Admin.NET/WCS.Application/Service/WcsDevice/Dto/WcsDeviceDto.cs
index 96cd826..9a3c42d 100644
--- a/Admin.NET/WCS.Application/Service/WcsDevice/Dto/WcsDeviceDto.cs
+++ b/Admin.NET/WCS.Application/Service/WcsDevice/Dto/WcsDeviceDto.cs
@@ -34,27 +34,27 @@
     /// <summary>
     /// DB鍖哄煙
     /// </summary>
-    public string? DbNumber { get; set; }
+    public string DbNumber { get; set; }
 
     /// <summary>
     /// 宸ヤ綅鍙�
     /// </summary>
-    public string? StationNum { get; set; }
+    public string StationNum { get; set; }
 
     /// <summary>
     /// PLC鍋忕Щ閲�
     /// </summary>
-    public string? PlcPos { get; set; }
+    public string PlcPos { get; set; }
 
     /// <summary>
     /// WCS鍋忕Щ閲�
     /// </summary>
-    public string? WcsPos { get; set; }
+    public string WcsPos { get; set; }
 
     /// <summary>
     /// 娴佺▼瀛楃被鍨�
     /// </summary>
-    public PLCDataTypeEnum? PosType { get; set; }
+    public PLCDataTypeEnum PosType { get; set; }
 
     /// <summary>
     /// 鏄剧ず灞廼p鍦板潃
diff --git a/Admin.NET/WCS.Application/Service/WcsTask/WcsTaskService.cs b/Admin.NET/WCS.Application/Service/WcsTask/WcsTaskService.cs
index 18318cc..6bd9227 100644
--- a/Admin.NET/WCS.Application/Service/WcsTask/WcsTaskService.cs
+++ b/Admin.NET/WCS.Application/Service/WcsTask/WcsTaskService.cs
@@ -1,4 +1,8 @@
 锘�
+using AngleSharp.Dom;
+using Furion.DatabaseAccessor;
+using Microsoft.AspNetCore.SignalR;
+
 namespace WCS.Application;
 
 /// <summary>
@@ -8,9 +12,12 @@
 public class WcsTaskService : IDynamicApiController, ITransient
 {
     private readonly SqlSugarRepository<WcsTask> _wcsTaskRep;
-    public WcsTaskService(SqlSugarRepository<WcsTask> wcsTaskRep)
+    private readonly IHubContext<TaskLogHub, ITaskLogHub> _taskLogHubContext;
+
+    public WcsTaskService(SqlSugarRepository<WcsTask> wcsTaskRep, IHubContext<TaskLogHub, ITaskLogHub> taskLogHubContext)
     {
         _wcsTaskRep = wcsTaskRep;
+        _taskLogHubContext = taskLogHubContext;
     }
 
     /// <summary>
@@ -23,7 +30,7 @@
     [DisplayName("鍒嗛〉鏌ヨ浠诲姟琛�")]
     public async Task<SqlSugarPagedList<WcsTaskOutput>> Page(PageWcsTaskInput input)
     {
-		input.SearchKey = input.SearchKey?.Trim();
+        input.SearchKey = input.SearchKey?.Trim();
         var query = _wcsTaskRep.AsQueryable()
             .WhereIF(!string.IsNullOrEmpty(input.SearchKey), u =>
                 u.TaskNo.Contains(input.SearchKey)
@@ -32,7 +39,7 @@
             .WhereIF(input.TaskType.HasValue, u => u.TaskType == input.TaskType)
             .WhereIF(input.Status.HasValue, u => u.Status == input.Status)
             .Select<WcsTaskOutput>();
-		return await query.OrderBuilder(input).ToPagedListAsync(input.Page, input.PageSize);
+        return await query.OrderBuilder(input).ToPagedListAsync(input.Page, input.PageSize);
     }
 
     /// <summary>
@@ -105,7 +112,50 @@
         return await _wcsTaskRep.AsQueryable().Select<WcsTaskOutput>().ToListAsync();
     }
 
-
+    /// <summary>
+    /// 瀹屾垚/鍙栨秷浠诲姟琛�
+    /// </summary>
+    /// <param name="input"></param>
+    /// <returns></returns>
+    [HttpPost]
+    [ApiDescriptionSettings(Name = "Finsh")]
+    [DisplayName("瀹屾垚/鍙栨秷浠诲姟琛�")]
+    [UnitOfWork]
+    public async Task Finsh(UpdateWcsTaskInput input)
+    {
+        if (input.Status == TaskStatusEnum.Complete || input.Status == TaskStatusEnum.Cancell)
+        {
+            var modTask = await _wcsTaskRep.GetByIdAsync(input.Id);
+            if (modTask.Status > TaskStatusEnum.Doing)
+                throw Oops.Oh("浠诲姟鐘舵�佸紓甯�");
+            if (input.Status == TaskStatusEnum.Complete)
+                modTask.IsSuccess = TaskSuccessEnum.Success;
+            else
+                modTask.IsSuccess = TaskSuccessEnum.Fail;
+            modTask.FinishDate = DateTime.Now;
+            modTask.Status = input.Status;
+            await _wcsTaskRep.Context.Updateable(modTask).UpdateColumns(s => new { s.Status, s.IsSuccess, s.FinishDate, s.UpdateTime,s.UpdateUserId,s.UpdateUserName }).ExecuteCommandAsync();
+            //鍐欏叆浠诲姟鏄庣粏琛�
+            WcsTaskMonitor modTaskMonitor = new WcsTaskMonitor()
+            {
+                TaskNo = modTask.TaskNo,
+                PlcId = 0,
+                PlcName = "",
+                Status = TaskStatusEnum.Complete,
+                StartLocat = modTask.StartLocate,
+                EndLocat = modTask.EndLocate,
+                InteractiveMsg = input.Status == TaskStatusEnum.Complete ? "浠诲姟宸叉墜鍔ㄥ畬鎴�" : "浠诲姟宸叉墜鍔ㄥ彇娑�",
+                PalletNo = modTask.PalletNo
+            };
+            await _wcsTaskRep.Context.Insertable(modTaskMonitor).ExecuteCommandAsync();
+            //await _taskLogHubContext.Clients.All.PublicTask(modTask.Adapt<WcsTaskOutput>());
+            //await _taskLogHubContext.Clients.All.PublicTaskMonitor(modTaskMonitor.Adapt<WcsTaskMonitorOutput>());
+        }
+        else
+        {
+            throw Oops.Oh("浠诲姟鐘舵�佸紓甯�");
+        }
+    }
 
 
 
diff --git a/Admin.NET/WCS.Application/Util/HttpService.cs b/Admin.NET/WCS.Application/Util/HttpService.cs
index cbb5172..cb84eb5 100644
--- a/Admin.NET/WCS.Application/Util/HttpService.cs
+++ b/Admin.NET/WCS.Application/Util/HttpService.cs
@@ -20,7 +20,33 @@
     {
         string url = Urls.WMSAddress + ":" + Urls.WMSPort;
         var result = await (url + "/api/DownAPi/ReceiveWcsSignal").SetBody(model, "application/json", Encoding.UTF8).PostAsAsync<ResponseTasks>();
-        Log.Debug("璋冪敤WMS鎺ュ彛鍙嶉浠诲姟鎺ュ彛" + result.ToJson());
+        Log.Information("璋冪敤WMS鎺ュ彛鍙嶉浠诲姟鎺ュ彛" + result.ToJson());
+        return result;
+    }
+
+    /// <summary>
+    /// 璋冪敤WMS鎺ュ彛鍙嶉绌哄彇寮傚父鎺ュ彛
+    /// </summary>
+    /// <param name="model">浠诲姟淇℃伅</param>
+    /// <returns></returns>
+    public async Task<ResponseTasks> RequestEmptyException(TaskRequest model)
+    {
+        string url = Urls.WMSAddress + ":" + Urls.WMSPort;
+        var result = await (url + "/api/DownAPi/EmptyException").SetBody(model, "application/json", Encoding.UTF8).PostAsAsync<ResponseTasks>();
+        Log.Information("璋冪敤WMS鎺ュ彛鍙嶉绌哄彇寮傚父鎺ュ彛" + result.ToJson());
+        return result;
+    }
+
+    /// <summary>
+    /// 璋冪敤WMS鎺ュ彛鍙嶉婊″彇寮傚父鎺ュ彛
+    /// </summary>
+    /// <param name="model">浠诲姟淇℃伅</param>
+    /// <returns></returns>
+    public async Task<ResponseTasks> RequestFullException(TaskRequest model)
+    {
+        string url = Urls.WMSAddress + ":" + Urls.WMSPort;
+        var result = await (url + "/api/DownAPi/FullException").SetBody(model, "application/json", Encoding.UTF8).PostAsAsync<ResponseTasks>();
+        Log.Information("璋冪敤WMS鎺ュ彛鍙嶉婊″彇寮傚父鎺ュ彛" + result.ToJson());
         return result;
     }
 }
diff --git a/Web/src/api/log/wcsAlarmLog.ts b/Web/src/api/log/wcsAlarmLog.ts
new file mode 100644
index 0000000..b8621a9
--- /dev/null
+++ b/Web/src/api/log/wcsAlarmLog.ts
@@ -0,0 +1,50 @@
+锘縤mport request from '/@/utils/request';
+enum Api {
+  AddWcsAlarmLog = '/api/wcsAlarmLog/add',
+  DeleteWcsAlarmLog = '/api/wcsAlarmLog/delete',
+  UpdateWcsAlarmLog = '/api/wcsAlarmLog/update',
+  PageWcsAlarmLog = '/api/wcsAlarmLog/page',
+  DetailWcsAlarmLog = '/api/wcsAlarmLog/detail',
+}
+
+// 澧炲姞鎶ヨ鏃ュ織
+export const addWcsAlarmLog = (params?: any) =>
+	request({
+		url: Api.AddWcsAlarmLog,
+		method: 'post',
+		data: params,
+	});
+
+// 鍒犻櫎鎶ヨ鏃ュ織
+export const deleteWcsAlarmLog = (params?: any) => 
+	request({
+			url: Api.DeleteWcsAlarmLog,
+			method: 'post',
+			data: params,
+		});
+
+// 缂栬緫鎶ヨ鏃ュ織
+export const updateWcsAlarmLog = (params?: any) => 
+	request({
+			url: Api.UpdateWcsAlarmLog,
+			method: 'post',
+			data: params,
+		});
+
+// 鍒嗛〉鏌ヨ鎶ヨ鏃ュ織
+export const pageWcsAlarmLog = (params?: any) => 
+	request({
+			url: Api.PageWcsAlarmLog,
+			method: 'post',
+			data: params,
+		});
+
+// 璇︽儏鎶ヨ鏃ュ織
+export const detailWcsAlarmLog = (id: any) => 
+	request({
+			url: Api.DetailWcsAlarmLog,
+			method: 'get',
+			data: { id },
+		});
+
+
diff --git a/Web/src/api/wcs/wcsTask.ts b/Web/src/api/wcs/wcsTask.ts
index 54669c5..c98786f 100644
--- a/Web/src/api/wcs/wcsTask.ts
+++ b/Web/src/api/wcs/wcsTask.ts
@@ -5,6 +5,7 @@
   UpdateWcsTask = '/api/wcsTask/update',
   PageWcsTask = '/api/wcsTask/page',
   DetailWcsTask = '/api/wcsTask/detail',
+  FinshWcsTask = '/api/wcsTask/Finsh',
 }
 
 // 澧炲姞浠诲姟琛�
@@ -48,3 +49,10 @@
 		});
 
 
+// 瀹屾垚/鍙栨秷浠诲姟
+export const finshWcsTask = (params?: any) => 
+	request({
+			url: Api.FinshWcsTask,
+			method: 'post',
+			data: params,
+		});
\ No newline at end of file
diff --git a/Web/src/views/wcs/wcsDevice/component/editDialog.vue b/Web/src/views/wcs/wcsDevice/component/editDialog.vue
index fc839f3..0eed749 100644
--- a/Web/src/views/wcs/wcsDevice/component/editDialog.vue
+++ b/Web/src/views/wcs/wcsDevice/component/editDialog.vue
@@ -138,6 +138,10 @@
 const ruleForm = ref<any>({});
 //鑷娣诲姞鍏朵粬瑙勫垯
 const rules = ref<FormRules>({
+	dbNumber: [{ required: true, message: '璇疯緭鍏B鍖哄煙锛�', trigger: 'blur', },],
+	stationNum: [{ required: true, message: '璇疯緭鍏ュ伐浣嶅彿锛�', trigger: 'blur', },],
+	plcPos: [{ required: true, message: '璇疯緭鍏LC鍋忕Щ閲忥紒', trigger: 'blur', },],
+	wcsPos: [{ required: true, message: '璇疯緭鍏CS鍋忕Щ閲忥紒', trigger: 'blur', },],
 });
 
 // 椤甸潰鍔犺浇鏃�
diff --git a/Web/src/views/wcs/wcsTask/index.vue b/Web/src/views/wcs/wcsTask/index.vue
index eac32a8..b68e9e8 100644
--- a/Web/src/views/wcs/wcsTask/index.vue
+++ b/Web/src/views/wcs/wcsTask/index.vue
@@ -4,8 +4,9 @@
       <el-col :span="12" :xs="24" style="display: flex; height: 100%; flex: 1">
         <el-card class="full-table" shadow="hover" ::body-style="{ height: 'calc(100% - 51px)' }">
           <template #header>
-						<el-icon size="16" style="margin-right: 3px; display: inline; vertical-align: middle"><ele-Collection /></el-icon>浠诲姟鏃ュ織
-					</template>
+            <el-icon size="16"
+              style="margin-right: 3px; display: inline; vertical-align: middle"><ele-Collection /></el-icon>浠诲姟鏃ュ織
+          </template>
           <el-form :model="queryParams" ref="queryForm" labelWidth="90">
             <el-row>
               <el-col :xs="24" :sm="12" :md="12" :lg="8" :xl="4" class="mb10">
@@ -53,8 +54,8 @@
               </el-col>
             </el-row>
           </el-form>
-          <el-table :data="tableData" style="width: 100%" v-loading="loading" tooltip-effect="light" row-key="id" @row-click="handleClick"
-            @sort-change="sortChange" border="">
+          <el-table :data="tableData" style="width: 100%" v-loading="loading" tooltip-effect="light" row-key="id"
+            @cell-click="handleClick" @sort-change="sortChange" border="">
             <el-table-column type="index" label="搴忓彿" width="55" align="center" />
             <el-table-column prop="taskNo" label="浠诲姟鍙�" show-overflow-tooltip="" />
             <el-table-column prop="taskType" width="85" label="浠诲姟绫诲瀷" show-overflow-tooltip="">
@@ -79,17 +80,15 @@
                 <ModifyRecord :data="scope.row" />
               </template>
             </el-table-column>
-            <el-table-column label="鎿嶄綔" width="130" align="center" fixed="right" show-overflow-tooltip=""
+            <el-table-column prop="鎿嶄綔" label="鎿嶄綔" width="130" align="center" fixed="right" show-overflow-tooltip=""
               v-if="auth('wcsTask:complete') || auth('wcsTask:cancell')">
               <template #default="scope">
-                <!-- <el-button icon="ele-Edit" size="small" text="" type="primary" @click="openEditWcsTask(scope.row)"
-              v-auth="'wcsTask:update'"> 缂栬緫 </el-button>
-            <el-button icon="ele-Delete" size="small" text="" type="primary" @click="delWcsTask(scope.row)"
-              v-auth="'wcsTask:delete'"> 鍒犻櫎 </el-button> -->
-                <el-button icon="ele-Check" size="small" text="" type="primary" @click="completeTask(scope.row)"
-                  v-auth="'wcsTask:complete'"> 瀹屾垚 </el-button>
-                <el-button icon="ele-Close" size="small" text="" type="primary" @click="cancellTask(scope.row)"
-                  v-auth="'wcsTask:cancell'"> 鍙栨秷 </el-button>
+                <template v-if="scope.row.status <= 1">
+                  <el-button icon="ele-Check" size="small" text="" type="primary" @click="completeTask(scope.row)"
+                    v-auth="'wcsTask:complete'"> 瀹屾垚 </el-button>
+                  <el-button icon="ele-Close" size="small" text="" type="primary" @click="cancellTask(scope.row)"
+                    v-auth="'wcsTask:cancell'"> 鍙栨秷 </el-button>
+                </template>
               </template>
             </el-table-column>
           </el-table>
@@ -104,8 +103,9 @@
       <el-col :span="12" :xs="24" style="display: flex; height: 100%; flex: 1">
         <el-card class="full-table" shadow="hover" :body-style="{ height: 'calc(100% - 51px)' }">
           <template #header>
-						<el-icon size="16" style="margin-right: 3px; display: inline; vertical-align: middle"><ele-Collection /></el-icon>浠诲姟璇︽儏
-					</template>
+            <el-icon size="16"
+              style="margin-right: 3px; display: inline; vertical-align: middle"><ele-Collection /></el-icon>浠诲姟璇︽儏
+          </template>
           <el-form :model="queryParams2" ref="queryForm2" labelWidth="90">
             <el-row>
               <el-col :xs="24" :sm="12" :md="12" :lg="8" :xl="4" class="mb10">
@@ -122,7 +122,8 @@
               </el-col>
             </el-row>
           </el-form>
-          <el-table :data="tableData2" style="width: 100%" v-loading="loading" tooltip-effect="light" row-key="id" border="">
+          <el-table :data="tableData2" style="width: 100%" v-loading="loading" tooltip-effect="light" row-key="id"
+            border="">
             <el-table-column type="index" label="搴忓彿" width="55" align="center" />
             <el-table-column prop="taskNo" label="浠诲姟鍙�" show-overflow-tooltip="" />
             <el-table-column prop="plcId" label="浜や簰宸ヤ綅鍙�" show-overflow-tooltip="" />
@@ -146,22 +147,18 @@
 
 <script lang="ts" setup="" name="wcsTask">
 import ModifyRecord from '/@/components/table/modifyRecord.vue';
-import { ref } from "vue";
+import { onMounted, reactive, ref } from 'vue';
 import { ElMessageBox, ElMessage } from "element-plus";
 import { auth } from '/@/utils/authFunction';
 
 import { getDictDataItem as di, getDictDataList as dl } from '/@/utils/dict-utils';
 import { getDictLabelByVal as dv } from '/@/utils/dict-utils';
-import { formatDate } from '/@/utils/formatTime';
-
 
 import printDialog from '/@/views/system/print/component/hiprint/preview.vue'
 import editDialog from '/@/views/wcs/wcsTask/component/editDialog.vue'
-import { pageWcsTask, deleteWcsTask } from '/@/api/wcs/wcsTask';
+import { pageWcsTask, finshWcsTask } from '/@/api/wcs/wcsTask';
 import { pageWcsMonitorTask } from '/@/api/wcs/wcsTaskMonitor';
-import { getAPI } from '/@/utils/axios-utils';
-import { SysEnumApi } from '/@/api-services/api';
-import commonFunction from '/@/utils/commonFunction';
+import { signalR } from './signalR';
 
 const showAdvanceQueryUI = ref(false);
 const printDialogRef = ref();
@@ -183,7 +180,31 @@
 });
 const printWcsTaskTitle = ref("");
 const editWcsTaskTitle = ref("");
-
+//杩炴帴signalR 鐩戝惉鍚庡彴浠诲姟鏃ュ織鍙樻洿
+onMounted(async () => {
+  signalR.off('PublicTask');
+  signalR.on('PublicTask', (data: any) => {
+    console.log(data)
+    var listTask = tableData.value.filter(t => t.id == data.id);
+    if (listTask.length == 0) {
+      tableData.value.unshift(data)
+    }
+    else {
+      //濡傛灉宸茬粡瀛樺湪灏辨洿鏂版暟鎹�
+      const index = tableData.value.findIndex(t => t.id == data.id);
+      tableData.value.splice(index, 1, data);
+    }
+  });
+  signalR.off('PublicTaskMonitor');
+  signalR.on('PublicTaskMonitor', async (data: any) => {
+    console.log(data);
+    if (queryParams2.value.taskNo == undefined || queryParams2.value.taskNo == data.taskNo) {
+      if (tableData2.value.filter(t => t.id == data.id).length == 0) {
+        tableData2.value.unshift(data)
+      }
+    }
+  });
+});
 // 鏀瑰彉楂樼骇鏌ヨ鐨勬帶浠舵樉绀虹姸鎬�
 const changeAdvanceQueryUI = () => {
   showAdvanceQueryUI.value = !showAdvanceQueryUI.value;
@@ -230,33 +251,48 @@
   editDialogRef.value.openDialog(row);
 };
 //瀹屾垚浠诲姟
-const completeTask = (row: any) => {
-
-}
-//鍙栨秷浠诲姟
-const cancellTask = (row: any) => {
-
-}
-// 鐐瑰嚮琛ㄦ牸
-const handleClick = (row: any, event: any, column: any) => {
-	queryParams2.value.taskNo = row.taskNo;
-	handleQuery2();
-};
-// 鍒犻櫎
-const delWcsTask = (row: any) => {
-  ElMessageBox.confirm(`纭畾瑕佸垹闄ゅ悧?`, "鎻愮ず", {
+const completeTask = async (row: any) => {
+  ElMessageBox.confirm(`纭畾瑕佸畬鎴愪换鍔″悧?`, "鎻愮ず", {
     confirmButtonText: "纭畾",
     cancelButtonText: "鍙栨秷",
     type: "warning",
   })
     .then(async () => {
-      await deleteWcsTask(row);
+      var param = Object.assign(row);
+      param.status = 2;
+      await finshWcsTask(param);
       handleQuery();
-      ElMessage.success("鍒犻櫎鎴愬姛");
+      handleQuery2();
+      ElMessage.success("瀹屾垚浠诲姟鎴愬姛");
     })
     .catch(() => { });
-};
+}
+//鍙栨秷浠诲姟
+const cancellTask = async (row: any) => {
+  ElMessageBox.confirm(`纭畾瑕佸彇娑堜换鍔″悧?`, "鎻愮ず", {
+    confirmButtonText: "纭畾",
+    cancelButtonText: "鍙栨秷",
+    type: "warning",
+  })
+    .then(async () => {
+      var param = Object.assign(row);
+      param.status = 4;
+      await finshWcsTask(param);
+      handleQuery();
+      handleQuery2();
+      ElMessage.success("鍙栨秷浠诲姟鎴愬姛");
+    })
+    .catch(() => { });
 
+}
+// 鐐瑰嚮琛ㄦ牸
+const handleClick = (row, column, cell, event) => {
+  if (column.property === '鎿嶄綔') {
+    return;
+  }
+  queryParams2.value.taskNo = row.taskNo;
+  handleQuery2();
+};
 // 鏀瑰彉椤甸潰瀹归噺
 const handleSizeChange = (val: number) => {
   tableParams.value.pageSize = val;
diff --git a/Web/src/views/wcs/wcsTask/signalR.ts b/Web/src/views/wcs/wcsTask/signalR.ts
new file mode 100644
index 0000000..42c93f8
--- /dev/null
+++ b/Web/src/views/wcs/wcsTask/signalR.ts
@@ -0,0 +1,37 @@
+import * as SignalR from '@microsoft/signalr';
+import { getToken } from '/@/utils/axios-utils';
+
+// 鍒濆鍖朣ignalR瀵硅薄
+const connection = new SignalR.HubConnectionBuilder()
+	.configureLogging(SignalR.LogLevel.Information)
+	.withUrl(`${window.__env__.VITE_API_URL}/hubs/TaskLog?token=${getToken()}`, { transport: SignalR.HttpTransportType.WebSockets, skipNegotiation: true })
+	.withAutomaticReconnect({
+		nextRetryDelayInMilliseconds: () => {
+			return 5000; // 姣�5绉掗噸杩炰竴娆�
+		},
+	})
+	.build();
+
+connection.keepAliveIntervalInMilliseconds = 15 * 1000; // 蹇冭烦妫�娴�15s
+connection.serverTimeoutInMilliseconds = 30 * 60 * 1000; // 瓒呮椂鏃堕棿30m
+
+// 鍚姩杩炴帴
+connection.start().then(() => {
+	console.log('鍚姩杩炴帴task');
+});
+// 鏂紑杩炴帴
+connection.onclose(async () => {
+	console.log('鏂紑杩炴帴task');
+});
+// 閲嶈繛涓�
+connection.onreconnecting(() => {
+	console.log('鏈嶅姟鍣ㄥ凡鏂嚎task');
+});
+// 閲嶈繛鎴愬姛
+connection.onreconnected(() => {
+	console.log('閲嶈繛鎴愬姛task');
+});
+
+connection.on('PublicTask', () => {});
+
+export { connection as signalR };

--
Gitblit v1.8.0