杨张扬
2025-05-15 ba51d2ed8f5d96c7d86da68ef2c966d9c17f299f
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
using HH.WCS.Mobox3.DoubleCoin.dispatch;
using HH.WCS.Mobox3.DoubleCoin.models;
using HH.WCS.Mobox3.DoubleCoin.util;
using System;
using static HH.WCS.Mobox3.DoubleCoin.api.ApiModel;
 
namespace HH.WCS.Mobox3.DoubleCoin.wms
{
    /// <summary>
    /// wms管到作业
    /// </summary>
    internal class WMSHelper
    {
        /// <summary>
        /// 人工手动PDA取消任务:1=发给AGV取消任务
        /// </summary>
        /// <param name="model"></param>
        /// <returns></returns>
        internal static SimpleResult PDACancleTask(CancleTaskInfo model)
        {
            SimpleResult simpleResult = new SimpleResult();
            var db = new SqlHelper<object>().GetInstance();
            try
            {
                if (model.taskNO.Length > 0)
                {
                    var task = db.Queryable<TN_Task>().First(a => a.S_CODE == model.taskNO);
                    if (task != null && task.S_B_STATE != "完成")
                    {
                        if (NDCApi.CancelOrder(model.taskNO).err_code == 0)
                        {
                            task.S_B_STATE = "错误";
                            task.N_B_STATE = 4;
                            if (db.Updateable<TN_Task>(task).ExecuteCommand() > 0)
                            {
                                simpleResult.resultCode = 0;
                                simpleResult.resultMsg = $"通知AGV取消该任务号,成功,{model.taskNO}";
                                LogHelper.Info(simpleResult.resultMsg);
                                return simpleResult;
                            }
                            else
                            {
                                simpleResult.resultCode = 4;
                                simpleResult.resultMsg = $"更新任务状态信息失败{model.taskNO}";
                                LogHelper.Info(simpleResult.resultMsg);
                                return simpleResult;
                            }
                        }
                        else
                        {
                            simpleResult.resultCode = 1;
                            simpleResult.resultMsg = $"通知AGV取消该任务号,失败,{model.taskNO}";
                            LogHelper.Info(simpleResult.resultMsg);
                            return simpleResult;
                        }
 
                    }
                    else
                    {
                        simpleResult.resultCode = 2;
                        simpleResult.resultMsg = $"未找到该任务号或该任务号已完成,无需通知AGV取消";
                        LogHelper.Info(simpleResult.resultMsg);
                        return simpleResult;
                    }
 
                }
                else
                {
                    simpleResult.resultCode = 3;
                    simpleResult.resultMsg = $"人工手动PDA取消任务:1=发给AGV取消任务,参数无效";
                    LogHelper.Info(simpleResult.resultMsg);
                    return simpleResult;
                }
            }
            catch (Exception ex)
            {
                simpleResult.resultCode = -1;
                simpleResult.resultMsg = $"发生了异常{ex.Message}";
                LogHelper.Info(simpleResult.resultMsg);
                return simpleResult;
            }
        }
 
        /// <summary>
        /// 插入操作员信息
        /// </summary>
        /// <param name="staff"></param>
        /// <param name="type"></param>
        /// <param name="cntrCode"></param>
        /// <param name="qty"></param>
        public static void InsertOpInfo(string staff, string type , string cntrCode ="",int qty = 0)
        {
            try
            {
                if(string.IsNullOrEmpty(staff))
                {
                    LogHelper.Info($"操作员信息为空,{staff}");
                    return;
                }
 
                var db = new SqlHelper<object>().GetInstance();
                var target = new TN_Operator_Info() 
                {
                    S_STAFF = staff,
                    S_SNTR_CODE = cntrCode,
                    F_QTY = qty,
                    S_TYPE = type
                };
 
                if(db.Insertable<TN_Operator_Info>(target).ExecuteCommand() > 0)
                {
                    LogHelper.Info($"插入操作员信息成功,{staff}");
                }
                else
                {
                    LogHelper.Info($"插入操作员信息失败,{staff}");
                }
            }
            catch(Exception ex)
            {
                LogHelper.Error($"插入操作员信息,发生了异常,{ex.Message}",ex);
            }
        }
 
       
    }
}