CutWeldService.cs
10.1 KB
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
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
using ApkInfo;
using Enyim.Caching.Configuration;
using Hh.Mes.Common;
using Hh.Mes.Common.config;
using Hh.Mes.Common.Json;
using Hh.Mes.Common.log;
using Hh.Mes.Common.Redis;
using Hh.Mes.Pojo.System;
using Hh.Mes.POJO.ApiEntity;
using Hh.Mes.POJO.Entity;
using Hh.Mes.POJO.EnumEntitys;
using Hh.Mes.POJO.Response;
using Hh.Mes.POJO.ViewModel;
using Hh.Mes.POJO.WebEntity;
using Hh.Mes.Service.Repository;
using Hh.Mes.Service.SystemAuth;
using SqlSugar;
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Numerics;
using System.Xml;
using static Microsoft.AspNetCore.Hosting.Internal.HostingApplication;
namespace Hh.Mes.Service
{
public class CutWeldService : RepositorySqlSugar<dynamic>
{
/// <summary>
/// 管段工序完工调用
/// </summary>
/// <param name="BarCode">追踪码</param>
/// <param name="processesState">状态</param>
/// <returns></returns>
public async void SendIWPTechnologylineProcess(string BarCode, int processesState)
{
if (string.IsNullOrWhiteSpace(BarCode)) return;
//切割完成处理,ECS完成时会更新套料方案,工单工序,这里只需要组织数据反馈上游
var oprSequenceCode = "";
if (processesState == (int)EnumCutHeadState.已套料)
oprSequenceCode = EnumoprSequenceCode.套料;
if (processesState == (int)EnumCutHeadState.切坡完成)
oprSequenceCode = EnumoprSequenceCode.切割坡口;
if (processesState == (int)EnumCutHeadState.切割完成)
oprSequenceCode = EnumoprSequenceCode.切割;
if (processesState == (int)EnumCutHeadState.坡口完成)
oprSequenceCode = EnumoprSequenceCode.坡口;
if (processesState == (int)EnumCutHeadState.打磨完成)
oprSequenceCode = EnumoprSequenceCode.打磨;
if (processesState == (int)EnumCutHeadState.组对完成)
oprSequenceCode = EnumoprSequenceCode.组对;
if (processesState == (int)EnumCutHeadState.焊接完成)
oprSequenceCode = EnumoprSequenceCode.焊接;
if (processesState == (int)EnumCutHeadState.组焊完成)
oprSequenceCode = EnumoprSequenceCode.组焊;
if (processesState == (int)EnumCutHeadState.弯管完成)
oprSequenceCode = EnumoprSequenceCode.弯管;
if (oprSequenceCode == "") return;
var workOrderDetail = base.Context.Queryable<bus_workOrder_detail>().Where(x => x.oprSequenceCode == oprSequenceCode && x.barCode == BarCode).First();
if (workOrderDetail == null) return;
//更新工单明细
workOrderDetail.workReportStatus = (int)EnumWorkReportStatus.完工已报工;
Context.Updateable(workOrderDetail).UpdateColumns(t => new { t.workReportStatus }).ExecuteCommand();
var data = new
{
Worker = workOrderDetail.createBy,
WorkerJobNo = workOrderDetail.createBy,
WorkStartDate = workOrderDetail.actualStartTime.ToString("yyyy-MM-dd HH:mm:ss"),
WorkEndDate = workOrderDetail.actualEndTime.ToString("yyyy-MM-dd HH:mm:ss"),
Operator = workOrderDetail.createBy,
OperatorJobNo = workOrderDetail.createBy,
OperateTime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"),
WorkstationTypeName = workOrderDetail.oprSequenceCode,
WorkPieceCode = workOrderDetail.barCode,
Status = 1
};
//var data = new
//{
// workOrderCode = workOrderDetail.workOrderCode,//工单
// partCode = workOrderDetail.partCode,//管段号
// barCode = workOrderDetail.barCode,//追踪码(管段码)
// oprSequenceCode = workOrderDetail.oprSequenceCode,//工序
// stationCode = workOrderDetail.stationCode,//工位
// equipmentCode = workOrderDetail.equipmentCode,//生产设备
// actualStartTime = workOrderDetail.actualStartTime,//开始时间
// actualEndTime = workOrderDetail.actualEndTime,// 完成时间
// cutMaterCode = workOrderDetail.cutMaterCode,//管段物料编码
// weldNo = workOrderDetail.weldNo,//组对(焊接)焊口号
// batchNo = workOrderDetail.batchNo,//组对(焊接)批次号
// createBy = workOrderDetail.createBy,//操作人
//};
var url = "";
var workOrder = base.Context.Queryable<base_work_order_head>().Where(x => x.workPieceNo == BarCode).First();
if (workOrder != null && workOrder.extend2 == "XF")
{
url = GetDictionaryDictValue("UrlProcessFeedback", "GetUrl");
}
else
{
url = GetDictionaryDictValue("UrlProcessFeedback_xyz", "GetUrl");
}
//调用上游MES工序完工反馈
HttpManVoid(url, data, EnumLog.调用上游MES工序完工反馈.ToString(), method: "post");
}
/// <summary>
/// PDA,ECS调用,任务号设备完工报工
/// </summary>
/// <param name="taskCode">任务号</param>
/// <param name="equipmentCode">设备编码</param>
/// <returns></returns>
public void SendTaskEnd(string taskCode, string equipmentCode)
{
if (string.IsNullOrWhiteSpace(taskCode) || string.IsNullOrWhiteSpace(equipmentCode)) return;
//查询工序明细
//var workOrderDetail = base.Context.Queryable<bus_workOrder_detail>()
// .Where(x => x.barCode== taskCode&&x.oprSequenceCode == EnumoprSequenceCode.焊接&&x.state== (int)EnumOrderBodyStatus.生产中).ToList();
var workOrderDetail = base.Context.Queryable<bus_workOrder_detail>()
.Where(x => x.barCode == taskCode && x.oprSequenceCode == EnumoprSequenceCode.焊接).ToList();
if (workOrderDetail.Count == 0) return;
//更新工单明细
workOrderDetail.ForEach(x =>
{
x.state = (int)EnumOrderBodyStatus.已完成;
x.equipmentCode = equipmentCode;
x.updateBy = sysUserApi?.Account;
x.workReportStatus = (int)EnumWorkReportStatus.完工已报工;
x.actualEndTime = DateTime.Now;
});
Context.Updateable(workOrderDetail).ExecuteCommand();
var item = workOrderDetail.OrderBy(x => x.serialNumberName).First();
//反馈只需要反馈一次
//foreach (var item in workOrderDetail.OrderBy(x => x.serialNumberName).First())
//{
var data = new
{
Worker = item.createBy,
WorkerJobNo = item.createBy,
WorkStartDate = item.actualStartTime.ToString("yyyy-MM-dd HH:mm:ss"),
WorkEndDate = item.actualEndTime.ToString("yyyy-MM-dd HH:mm:ss"),
Operator = item.createBy,
OperatorJobNo = item.createBy,
OperateTime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss"),
WorkstationTypeName = item.oprSequenceCode,
WorkPieceCode = item.barCode,
Status = 1
};
//调用上游MES工序完工反馈
var url = "";
var workOrder = base.Context.Queryable<base_work_order_head>().Where(x => x.workPieceNo == taskCode).First();
if (workOrder != null && workOrder.extend2 == "XF")
{
url = GetDictionaryDictValue("UrlProcessFeedback", "GetUrl");
}
else
{
url = GetDictionaryDictValue("UrlProcessFeedback_xyz", "GetUrl");
}
HttpManVoid(url, data, EnumLog.调用上游MES工序完工反馈.ToString(), method: "post");
//}
}
/// <summary>
/// 余料反馈发送上游工单系统
/// </summary>
public void OddFeedBack(OddFeelBackModel model)
{
var url = GetDictionaryDictValue("OddFeedBack", "GetUrl");
HttpManVoid(url, model, EnumLog.余料接口.ToString(), method: "post");
}
public dynamic CreateXmlByWorkOrder(string workOrderCode)
{
var response = new POJO.Response.Response();
List<base_work_order_head> work_order = Context.Queryable<base_work_order_head>().Where(x => x.workOrderCode == workOrderCode).ToList();
foreach (var item in work_order)
{
CreateXmlByOrder(item.workPieceNo);
}
return response;
}
public dynamic CreateXmlByOrder(string barCode)
{
var response = new POJO.Response.Response();
base_work_order_head work_order = Context.Queryable<base_work_order_head>().First(x => x.workPieceNo == barCode);
if (work_order == null)
{
return response.ResponseError("未获取到对应的工单数据");
}
base_work_order_flameCut cuts = Context.Queryable<base_work_order_flameCut>().First(x => x.headKeys.Equals(work_order.keys));
if (cuts == null)
{
return response.ResponseError("未获取到对应的切割数据");
}
try
{
bus_flameCut_job model = new bus_flameCut_job();
model.createBy = "sys";
model.createTime = DateTime.Now;
model.workOrderCode = work_order.workOrderCode;
model.lineCode = work_order.lineCode;
model.workPieceNo = work_order.workPieceNo;
model.state = "0";
Context.Insertable(model).ExecuteCommand();
}
catch (Exception ex)
{
return response.ResponseError(ex.Message);
}
return response;
}
}
}