You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

1115 lines
77 KiB
C#

using Khd.Core.Domain.Dto.TaskType;
1 year ago
using Khd.Core.Domain.Dto.waring;
using Khd.Core.Domain.Dto.webapi;
using Khd.Core.Domain.Models;
using Khd.Core.EntityFramework;
2 years ago
using Khd.Core.Library;
2 years ago
using Khd.Core.Library.Mapper;
2 years ago
using Khd.Core.Plc.S7;
using Khd.Core.Wcs.Global;
2 years ago
using Masuit.Tools;
1 year ago
using Microsoft.AspNetCore.Razor.Language;
1 year ago
using Microsoft.EntityFrameworkCore;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Hosting;
2 years ago
using Newtonsoft.Json;
2 years ago
using Z.EntityFramework.Plus;
namespace Khd.Core.Wcs.Wcs
{
/// <summary>
/// 五楼AGV调度
/// </summary>
public class FiveFloorAGV
{
2 years ago
private readonly LoggerUtils _logger = new LoggerUtils();
private readonly IHost _host;
2 years ago
private readonly BasePlcpoint LineSignal;
int FloorNo { get; set; }
2 years ago
int agvID = 28;
2 years ago
public FiveFloorAGV(IHost host, int floor)
{
this._host = host;
FloorNo = floor;
2 years ago
this.LineSignal = StaticData.BasePlcpointList.First(t => t.plcpointNo == "linesignal05");
}
/// <summary>
/// 启动上件扫描监听
/// </summary>
public void StartPoint()
{
2 years ago
Thread FlowPointThread = new(MonitorInLocatorPoint);
2 years ago
FlowPointThread.IsBackground = true;
FlowPointThread.Name = "FiveFloorAGV";
FlowPointThread.Start();
2 years ago
Console.WriteLine(DateTime.Now + ":五楼AGV上件扫描监听启动成功");
2 years ago
_logger.Info("五楼AGV上件扫描监听启动成功");
}
public void MonitorInLocatorPoint()
{
using var scope = _host.Services.CreateScope();
using var dbContext = scope.ServiceProvider.GetRequiredService<DefaultDbContext>();
2 years ago
BaseEquip baseEquip = StaticData.BaseEquip.First(t => t.objid == agvID);
while (true)
{
try
{
1 year ago
dbContext.ChangeTracker.Clear();
2 years ago
var taskList = dbContext.WcsTask
.Where(t => t.useFlag == 1)
2 years ago
.Where(t => t.IsDelete == 0 || t.IsDelete == null)
2 years ago
.Where(t => t.nextPointId == agvID).OrderBy(t => t.createTime).ToList();
foreach (var item in taskList)
{
2 years ago
if (taskList.Where(t => t.taskStatus > 0).Where(t => t.objid != item.objid).Any())
{
2 years ago
_logger.Info($"5楼AGV线程有其他任务正在执行跳过当前任务{item.objid}");
2 years ago
continue;
}
2 years ago
item.updateTime = DateTime.Now;
2 years ago
if (item.taskStatus == 0)//下发任务
{
2 years ago
BaseDictionary baseDictionary = StaticData.BaseDictionary.First(t => t.objid == item.taskType);
2 years ago
if (item.taskType == StaticTaskType.FiveProductOut)//出库任务
2 years ago
{
2 years ago
BaseEquip lineEquip = dbContext.BaseEquip.First(t => t.objid == 5);
if (lineEquip.equipStatus == 0)
2 years ago
{
2 years ago
bool canSend = dbContext.WcsTask.Where(t => t.nextPointId == lineEquip.objid && t.taskStatus > 0).Any();
if (lineEquip.equipStatus == 1)
{
2 years ago
_logger.Info("五楼AGV:接驳位有任务,无法下发出库任务");
2 years ago
continue;
}
2 years ago
if (Convert.ToInt32(StaticData.PlcDic[0].Read(LineSignal.plcpointAddress)) == 1 && !canSend)
2 years ago
{
Console.WriteLine($"{DateTime.Now}:5楼接驳位上有货无法下发Agv出库任务");
continue;
}
BaseEquip nextEquip = StaticData.BaseEquip.First(t => t.floorNo == 5 && t.equipType == 1);
2 years ago
RequestAGVTaskDto agvTask = new()
2 years ago
{
2 years ago
reqCode = StaticData.SnowId.NextId().ToString(),
2 years ago
positionCodePath = new List<Position>
2 years ago
{
2 years ago
new ()
{
2 years ago
positionCode=item.currPointNo,
2 years ago
type="00"
},
new ()
{
2 years ago
positionCode=nextEquip.agvPositionCode,
2 years ago
type="00"
}
2 years ago
},
2 years ago
taskTyp = baseDictionary.dicValue,
ctnrTyp = "2"
};
2 years ago
2 years ago
string message = JsonConvert.SerializeObject(agvTask);
string result = HttpHelper.SendPostMessage(baseEquip.serverIp, baseEquip.serverPort.Value, "rcms/services/rest/hikRpcService/genAgvSchedulingTask", message);
var reponseMessage = JsonConvert.DeserializeObject<ReponseMessage>(result);
if (reponseMessage != null && reponseMessage.message == "成功")
{
2 years ago
_logger.Info("五楼Agv下发任务成功" + message);
2 years ago
Console.WriteLine(DateTime.Now + ":五楼Agv下发任务成功" + item.currPointNo + "," + nextEquip.agvPositionCode);
2 years ago
item.taskCode = reponseMessage.data;
2 years ago
item.taskStatus = 1;
lineEquip.equipStatus = 1;
dbContext.Update(lineEquip);
dbContext.Update(item);
dbContext.WcsTaskLog.Where(t => t.objid == item.objid).Update(t => new WcsTaskLog { taskStatus = 1 });
dbContext.SaveChanges();
}
else
{
2 years ago
_logger.Info("五楼Agv下发任务失败" + item.taskType + result);
2 years ago
}
2 years ago
2 years ago
}
1 year ago
else
{
continue;
}
2 years ago
}
1 year ago
else if (item.taskType == StaticTaskType.FiveStockReturnTask)//退库任务
1 year ago
{
BaseEquip lineEquip = dbContext.BaseEquip.First(t => t.objid == 5);
if (lineEquip.equipStatus == 0)
{
bool canSend = dbContext.WcsTask.Where(t => t.nextPointId == lineEquip.objid && t.taskStatus > 0).Any();
if (lineEquip.equipStatus == 1)
{
_logger.Info("五楼AGV:接驳位有任务,无法下发出库任务");
continue;
}
if (Convert.ToInt32(StaticData.PlcDic[0].Read(LineSignal.plcpointAddress)) == 1 && !canSend)
{
Console.WriteLine($"{DateTime.Now}:5楼接驳位上有货无法下发Agv出库任务");
continue;
}
BaseEquip nextEquip = StaticData.BaseEquip.First(t => t.floorNo == 5 && t.equipType == 1);
RequestAGVTaskDto agvTask = new()
{
reqCode = StaticData.SnowId.NextId().ToString(),
positionCodePath = new List<Position>
{
new ()
{
positionCode=item.currPointNo,
type="00"
},
new ()
{
positionCode=nextEquip.agvPositionCode,
type="00"
}
},
taskTyp = baseDictionary.dicValue,
ctnrTyp = "2"
};
string message = JsonConvert.SerializeObject(agvTask);
string result = HttpHelper.SendPostMessage(baseEquip.serverIp, baseEquip.serverPort.Value, "rcms/services/rest/hikRpcService/genAgvSchedulingTask", message);
var reponseMessage = JsonConvert.DeserializeObject<ReponseMessage>(result);
if (reponseMessage != null && reponseMessage.message == "成功")
{
_logger.Info("五楼Agv下发任务成功" + message);
Console.WriteLine(DateTime.Now + ":五楼Agv下发任务成功" + item.currPointNo + "," + nextEquip.agvPositionCode);
item.taskCode = reponseMessage.data;
item.taskStatus = 1;
lineEquip.equipStatus = 1;
dbContext.Update(lineEquip);
dbContext.Update(item);
dbContext.WcsTaskLog.Where(t => t.objid == item.objid).Update(t => new WcsTaskLog { taskStatus = 1 });
dbContext.SaveChanges();
}
else
{
_logger.Info("五楼Agv下发任务失败" + item.taskType + result);
}
}
1 year ago
else
{
continue;
}
1 year ago
}
2 years ago
else if (item.taskType == StaticTaskType.FiveRawToBack)//原材料到背板安装
2 years ago
{
BaseEquip endEquip = StaticData.BaseEquip.First(t => t.objid == 30);
RequestAGVTaskDto agvTask = new()
{
2 years ago
reqCode = StaticData.SnowId.NextId().ToString(),
2 years ago
positionCodePath = new List<Position>
{
new ()
{
2 years ago
positionCode=item.currPointNo,
2 years ago
type="00"
},
new ()
{
2 years ago
positionCode= endEquip.agvPositionCode,
2 years ago
type="00"
}
},
2 years ago
taskTyp = baseDictionary.dicValue,
2 years ago
ctnrTyp = "2"
};
string message = JsonConvert.SerializeObject(agvTask);
string result = HttpHelper.SendPostMessage(baseEquip.serverIp, baseEquip.serverPort.Value, "rcms/services/rest/hikRpcService/genAgvSchedulingTask", message);
var reponseMessage = JsonConvert.DeserializeObject<ReponseMessage>(result);
if (reponseMessage != null && reponseMessage.message == "成功")
{
2 years ago
_logger.Info("五楼Agv下发任务成功" + message);
2 years ago
Console.WriteLine(DateTime.Now + ":五楼Agv下发任务成功" + item.currPointNo + "," + endEquip.agvPositionCode);
2 years ago
item.taskCode = reponseMessage.data;
2 years ago
item.taskStatus = 1;
dbContext.Update(item);
dbContext.WcsTaskLog.Where(t => t.objid == item.objid).Update(t => new WcsTaskLog { taskStatus = 1 });
dbContext.SaveChanges();
}
else
{
2 years ago
_logger.Info("五楼Agv下发任务失败" + item.taskType + result);
2 years ago
}
}
2 years ago
else if (item.taskType == StaticTaskType.FiveHalfIn)//背板安装到半成品
2 years ago
{
BaseEquip currentEquip = StaticData.BaseEquip.First(t => t.objid == 30);
var agvTask = new RequestAGVTaskDto
{
2 years ago
reqCode = StaticData.SnowId.NextId().ToString(),
2 years ago
positionCodePath = new List<Position>
{
new ()
{
2 years ago
positionCode=currentEquip.agvPositionCode,
2 years ago
type="00"
},
new ()
{
2 years ago
positionCode=item.endPointNo,
2 years ago
type="00"
}
},
2 years ago
taskTyp = baseDictionary.dicValue,
2 years ago
ctnrTyp = "2",
};
string message = JsonConvert.SerializeObject(agvTask);
string result = HttpHelper.SendPostMessage(baseEquip.serverIp, baseEquip.serverPort.Value, "rcms/services/rest/hikRpcService/genAgvSchedulingTask", message);
var reponseMessage = JsonConvert.DeserializeObject<ReponseMessage>(result);
if (reponseMessage != null && reponseMessage.message == "成功")
{
2 years ago
_logger.Info("五楼Agv下发任务成功" + message);
2 years ago
Console.WriteLine(DateTime.Now + ":五楼Agv下发任务成功" + currentEquip.agvPositionCode + "," + item.endPointNo);
2 years ago
item.taskCode = reponseMessage.data;
2 years ago
item.taskStatus = 1;
dbContext.Update(item);
dbContext.WcsTaskLog.Where(t => t.objid == item.objid).Update(t => new WcsTaskLog() { taskStatus = 1 });
dbContext.SaveChanges();
}
else
{
2 years ago
_logger.Info("五楼Agv下发任务失败" + item.taskType + result);
2 years ago
}
}
2 years ago
else if (item.taskType == StaticTaskType.FiveRawToSplit)//原材料到拆分区
2 years ago
{
BaseEquip currentEquip = StaticData.BaseEquip.First(t => t.objid == 29);
2 years ago
RequestAGVTaskDto agvTask = new()
{
2 years ago
reqCode = StaticData.SnowId.NextId().ToString(),
2 years ago
positionCodePath = new List<Position>
{
new ()
{
2 years ago
positionCode=item.currPointNo,
2 years ago
type="00"
2 years ago
},
new ()
{
2 years ago
positionCode=currentEquip.agvPositionCode,
2 years ago
type="00"
2 years ago
}
},
2 years ago
taskTyp = baseDictionary.dicValue,
2 years ago
ctnrTyp = "2"
};
string message = JsonConvert.SerializeObject(agvTask);
2 years ago
string result = HttpHelper.SendPostMessage(baseEquip.serverIp, baseEquip.serverPort.Value, "rcms/services/rest/hikRpcService/genAgvSchedulingTask", message);
2 years ago
var reponseMessage = JsonConvert.DeserializeObject<ReponseMessage>(result);
if (reponseMessage != null && reponseMessage.message == "成功")
{
2 years ago
_logger.Info("五楼Agv下发任务成功" + message);
2 years ago
Console.WriteLine(DateTime.Now + ":五楼Agv下发任务成功" + item.currPointNo + "," + currentEquip.agvPositionCode);
2 years ago
item.taskCode = reponseMessage.data;
2 years ago
item.taskStatus = 1;
dbContext.Update(item);
2 years ago
dbContext.WcsTaskLog.Where(t => t.objid == item.objid).Update(t => new WcsTaskLog { taskStatus = 1 });
2 years ago
dbContext.SaveChanges();
}
2 years ago
else
{
2 years ago
_logger.Info("五楼Agv下发任务失败" + item.taskType + result);
2 years ago
}
}
2 years ago
else if (item.taskType == StaticTaskType.FiveRawSplitReturn)//拆分区返库
2 years ago
{
BaseEquip currentEquip = StaticData.BaseEquip.First(t => t.objid == 29);
RequestAGVTaskDto agvTask = new()
{
2 years ago
reqCode = StaticData.SnowId.NextId().ToString(),
2 years ago
positionCodePath = new List<Position>
{
new()
{
2 years ago
positionCode = currentEquip.agvPositionCode,
2 years ago
type = "00"
},
new()
{
2 years ago
positionCode = item.endPointNo,
2 years ago
type = "00"
}
2 years ago
},
2 years ago
taskTyp = baseDictionary.dicValue,
ctnrTyp = "2"
2 years ago
2 years ago
};
string message = JsonConvert.SerializeObject(agvTask);
string result = HttpHelper.SendPostMessage(baseEquip.serverIp, baseEquip.serverPort.Value, "rcms/services/rest/hikRpcService/genAgvSchedulingTask", message);
var reponseMessage = JsonConvert.DeserializeObject<ReponseMessage>(result);
if (reponseMessage != null && reponseMessage.message == "成功")
{
2 years ago
_logger.Info("五楼Agv下发任务成功" + message);
2 years ago
Console.WriteLine(DateTime.Now + ":五楼Agv下发任务成功" + currentEquip.agvPositionCode + "," + item.endPointNo);
2 years ago
item.taskCode = reponseMessage.data;
2 years ago
item.taskStatus = 1;
dbContext.Update(item);
dbContext.WcsTaskLog.Where(t => t.objid == item.objid).Update(t => new WcsTaskLog { taskStatus = 1 });
dbContext.SaveChanges();
}
else
{
2 years ago
_logger.Info("五楼Agv下发任务失败" + item.taskType + result);
2 years ago
}
}
2 years ago
else if (item.taskType == StaticTaskType.FiveRawIn)//原材料入库
2 years ago
{
BaseEquip startEquip = StaticData.BaseEquip.First(t => t.objid == 5);
var agvTask = new RequestAGVTaskDto
{
2 years ago
reqCode = StaticData.SnowId.NextId().ToString(),
2 years ago
positionCodePath = new List<Position>
{
new ()
{
2 years ago
positionCode= startEquip.agvPositionCode,
2 years ago
type="00"
},
new ()
{
2 years ago
positionCode=item.endPointNo,
2 years ago
type="00"
}
},
2 years ago
taskTyp = baseDictionary.dicValue,
2 years ago
ctnrTyp = "2",
};
string message = JsonConvert.SerializeObject(agvTask);
string result = HttpHelper.SendPostMessage(baseEquip.serverIp, baseEquip.serverPort.Value, "rcms/services/rest/hikRpcService/genAgvSchedulingTask", message);
var reponseMessage = JsonConvert.DeserializeObject<ReponseMessage>(result);
if (reponseMessage != null && reponseMessage.message == "成功")
{
2 years ago
_logger.Info("五楼Agv下发任务成功" + message);
2 years ago
Console.WriteLine(DateTime.Now + ":五楼Agv下发任务成功" + startEquip.agvPositionCode + "," + item.endPointNo);
2 years ago
item.taskCode = reponseMessage.data;
2 years ago
item.taskStatus = 1;
dbContext.Update(item);
dbContext.WcsTaskLog.Where(t => t.objid == item.objid).Update(t => new WcsTaskLog() { taskStatus = 1 });
dbContext.SaveChanges();
}
else
{
2 years ago
_logger.Info("五楼Agv下发任务失败" + item.taskType + result);
2 years ago
}
}
2 years ago
else if (item.taskType == StaticTaskType.FiveRemove)//移库
2 years ago
{
var agvTask = new RequestAGVTaskDto
{
2 years ago
reqCode = StaticData.SnowId.NextId().ToString(),
2 years ago
positionCodePath = new List<Position>
{
new ()
{
2 years ago
positionCode=item.currPointNo,
2 years ago
type="00"
},
new ()
{
2 years ago
positionCode=item.endPointNo,
2 years ago
type="00"
}
},
taskTyp = baseDictionary.dicValue,
2 years ago
ctnrTyp = "2",
};
string message = JsonConvert.SerializeObject(agvTask);
string result = HttpHelper.SendPostMessage(baseEquip.serverIp, baseEquip.serverPort.Value, "rcms/services/rest/hikRpcService/genAgvSchedulingTask", message);
var reponseMessage = JsonConvert.DeserializeObject<ReponseMessage>(result);
if (reponseMessage != null && reponseMessage.message == "成功")
{
2 years ago
_logger.Info("五楼Agv下发任务成功" + message);
2 years ago
Console.WriteLine(DateTime.Now + ":五楼Agv下发任务成功" + item.currPointNo + "," + item.endPointNo);
2 years ago
item.taskCode = reponseMessage.data;
2 years ago
item.taskStatus = 1;
dbContext.Update(item);
dbContext.WcsTaskLog.Where(t => t.objid == item.objid).Update(t => new WcsTaskLog() { taskStatus = 1 });
dbContext.SaveChanges();
}
else
{
2 years ago
_logger.Info("五楼Agv下发任务失败" + item.taskType + result);
2 years ago
}
2 years ago
}
}
else
{
2 years ago
if (item.taskStatus == 3)
2 years ago
{
2 years ago
if (item.currPointId == 5)
2 years ago
{
2 years ago
var lineSignalValue = StaticData.PlcDic[0].Read(LineSignal.plcpointAddress);
if (lineSignalValue == null || Convert.ToInt32(lineSignalValue) == 0)
2 years ago
{
2 years ago
Console.WriteLine(DateTime.Now + ":五楼Agv接驳位为空无法取货");
_logger.Info("五楼Agv接驳位为空无法取货");
continue;
2 years ago
}
2 years ago
}
else if (item.endPointId == 5)
{
var lineSignalValue = StaticData.PlcDic[0].Read(LineSignal.plcpointAddress);
1 year ago
var wcsrun = StaticData.PlcDic[0].Read(StaticData.BasePlcpointList.First(t => t.plcpointNo == "wcsrun03").plcpointAddress);
if (lineSignalValue == null || Convert.ToInt32(lineSignalValue) == 1 || wcsrun == null || wcsrun.ToString() != "0")
2 years ago
{
2 years ago
Console.WriteLine(DateTime.Now + ":五楼Agv接驳位有货无法送货");
_logger.Info("五楼Agv接驳位有货无法送货");
continue;
2 years ago
}
}
2 years ago
var agvTask = new RequestAGVTaskDto
2 years ago
{
2 years ago
reqCode = StaticData.SnowId.NextId().ToString(),
taskCode = item.taskCode
};
string message = JsonConvert.SerializeObject(agvTask);
string result = HttpHelper.SendPostMessage(baseEquip.serverIp, baseEquip.serverPort.Value, "rcms/services/rest/hikRpcService/continueTask", message);
ReponseMessage? reponseMessage = JsonConvert.DeserializeObject<ReponseMessage>(result);
if (reponseMessage != null && reponseMessage.message == "成功")
{
_logger.Info("五楼Agv下发继续任务成功" + message);
Console.WriteLine(DateTime.Now + ":五楼Agv继续任务" + item.currPointNo + "," + item.endPointNo);
item.taskStatus = 4;
dbContext.Update(item);
dbContext.WcsTaskLog.Where(t => t.objid == item.objid).Update(t => new WcsTaskLog() { taskStatus = 4 });
dbContext.SaveChanges();
}
}
else if (item.taskStatus == 5)
{
if (item.taskType == StaticTaskType.FiveRemove)//移库
{
Console.WriteLine(DateTime.Now + ":五楼AGV线程完成任务" + item.currPointNo + "," + item.endPointNo);
_logger.Info("五楼Agv完成任务成功" + item.ToJsonString());
1 year ago
WmsProductStock? wmsProductStock = null;
1 year ago
var wmsRawStock = dbContext.WmsRawStock.Where(t => t.locationCode == item.currPointNo).FirstOrDefault();
if (wmsRawStock != null)
2 years ago
{
1 year ago
wmsRawStock.locationCode = item.endPointNo;
dbContext.Update(wmsRawStock);
}
else if (wmsRawStock == null)
{
wmsProductStock = dbContext.WmsProductStock.FirstOrDefault(t => t.locationCode == item.currPointNo);
if (wmsProductStock != null)
2 years ago
{
1 year ago
wmsProductStock.locationCode = item.endPointNo;
dbContext.Update(wmsProductStock);
2 years ago
}
2 years ago
else
2 years ago
{
2 years ago
continue;
2 years ago
}
1 year ago
}
else
{
continue;
}
WmsBaseLocation wmsBaseLocation = dbContext.WmsBaseLocation.Where(t => t.locationId == item.currPointId).First();
WmsBaseLocation toLocation = dbContext.WmsBaseLocation.Where(t => t.locationId == item.endPointId).First();
SystemData.UnLockOutLocation(wmsBaseLocation, dbContext);
SystemData.UnLockOutLocation(toLocation, dbContext);
dbContext.WmsBaseLocation.Where(t => t.locationId == wmsBaseLocation.locationId)
.Update(t => new WmsBaseLocation() { containerCode = null, updateTime = DateTime.Now, locationStatus = "1", returnFlag = "0" });
dbContext.WmsBaseLocation.Where(t => t.locationId == toLocation.locationId)
.Update(t => new WmsBaseLocation { containerCode = item.containerNo, updateTime = DateTime.Now, locationStatus = "1", returnFlag = wmsBaseLocation.returnFlag });
1 year ago
1 year ago
//dbContext.WmsBaseLocation.Where(t => t.locationId == item.currPointId).Update(t => new WmsBaseLocation
//{
// returnFlag = "0",
// locationStatus = "1",
// containerCode = null,
// updateTime = DateTime.Now
//});
//dbContext.WmsBaseLocation.Where(t => t.locationId == item.endPointId).Update(t => new WmsBaseLocation
//{
// locationStatus = "1",
// returnFlag = wmsBaseLocation.returnFlag,
// containerCode = item.containerNo,
// updateTime = DateTime.Now
//});
1 year ago
1 year ago
dbContext.Remove(item);
dbContext.WcsTaskLog.Where(t => t.objid == item.objid).Update(t => new WcsTaskLog() { taskStatus = 6 });
#region 插入移库记录
var wmsMove = dbContext.WmsMove.Where(t => t.MoveId == item.orderId).FirstOrDefault();
if (wmsMove == null)
{
wmsMove = new WmsMove();
wmsMove.MoveId = StaticData.SnowId.NextId();
wmsMove.TaskCode = StaticData.SnowId.NextId().ToString();
wmsMove.WarehouseId = wmsBaseLocation.warehouseId;
wmsMove.OriLocationCode = wmsBaseLocation.locationCode;
wmsMove.TargetLocationCode = toLocation.locationCode;
wmsMove.InstockBatch = wmsRawStock == null ? wmsProductStock.productBatch : wmsRawStock.instockBatch;
wmsMove.MaterialId = wmsRawStock == null ? wmsProductStock.productId : wmsRawStock.materialId;
wmsMove.PlanAmount = 1;
wmsMove.RealOutstockAmount = 1;
wmsMove.RealInstockAmount = 1;
wmsMove.OperationType = "3";
wmsMove.MoveWay = "2";
wmsMove.MoveType = "1";
wmsMove.AuditStatus = "1";
wmsMove.ExecuteStatus = "2";
wmsMove.UpdateBy = "WCS";
wmsMove.UpdateDate = DateTime.Now;
wmsMove.BeginTime = DateTime.Now;
wmsMove.EndTime = DateTime.Now;
dbContext.WmsMove.Add(wmsMove);
2 years ago
}
1 year ago
else
2 years ago
{
1 year ago
wmsMove.RealOutstockAmount += 1;
wmsMove.EndTime = DateTime.Now;
wmsMove.UpdateDate = DateTime.Now;
wmsMove.UpdateBy = "WCS";
wmsMove.ExecuteStatus = "2";
dbContext.Update(wmsMove);
2 years ago
}
1 year ago
WmsMoveDetail wmsMoveDetail = new WmsMoveDetail();
wmsMoveDetail.MoveId = wmsMove.MoveId;
wmsMoveDetail.MaterialBarcode = wmsMove.InstockBatch;
wmsMoveDetail.InstockBatch = wmsMove.InstockBatch;
wmsMoveDetail.MaterialId = wmsRawStock == null ? (long)wmsProductStock.productId : (long)wmsRawStock.materialId;
wmsMoveDetail.LocationCode = toLocation.locationCode;
wmsMoveDetail.PlanAmount = 1;
wmsMoveDetail.RealInstockAmount = 1;
wmsMoveDetail.RealAmount = 1;
wmsMoveDetail.ExecuteStatus = "2";
wmsMoveDetail.ExecuteTime = DateTime.Now;
wmsMoveDetail.ExecuteEndTime = DateTime.Now;
wmsMoveDetail.ExecutePerson = "WCS";
wmsMoveDetail.UpdateBy = "WCS";
wmsMoveDetail.UpdateDate = DateTime.Now;
dbContext.WmsMoveDetail.Add(wmsMoveDetail);
#endregion
dbContext.SaveChanges();
SystemData.SendPlcLocation(wmsBaseLocation);
SystemData.SendPlcLocation(toLocation);
2 years ago
}
else if (item.taskType == StaticTaskType.FiveProductOut)//出库
{
Console.WriteLine(DateTime.Now + ":五楼AGV线程完成任务" + item.currPointNo + "," + item.endPointNo);
_logger.Info("五楼Agv完成任务成功" + item.ToJsonString());
1 year ago
2 years ago
var wmsProductOutstock = dbContext.WmsProductOutstock.FirstOrDefault(t => t.productOutstockId == item.orderId);
1 year ago
if (wmsProductOutstock != null)
2 years ago
{
var wmsBaseLocation = dbContext.WmsBaseLocation.Where(t => t.locationId == item.currPointId).First();
WmsProductStock wmsProductStock = dbContext.WmsProductStock.First(t => t.locationCode == wmsBaseLocation.locationCode);
2 years ago
wmsProductOutstock.outstockQty += 1;
if (wmsProductOutstock.applyQty <= wmsProductOutstock.outstockQty)
2 years ago
{
2 years ago
wmsProductOutstock.endTime = DateTime.Now;
wmsProductOutstock.executeStatus = "2";
}
WmsProductOutstockDetail? wmsProductOutstockDetail = dbContext.WmsProductOutstockDetail.FirstOrDefault(x => x.productOutstockId == wmsProductOutstock.productOutstockId && x.locationCode == item.currPointId.ToString());
if (wmsProductOutstockDetail != null)
{ //人工出库mes会自动插入wcs只需要更新即可
wmsProductOutstockDetail.outstockAmount = 1;
wmsProductOutstockDetail.executeStatus = "2";
wmsProductOutstockDetail.updateDate = DateTime.Now;
wmsProductOutstockDetail.endTime = DateTime.Now;
dbContext.Update(wmsProductOutstockDetail);
}
else
{
wmsProductOutstockDetail = new WmsProductOutstockDetail();
wmsProductOutstockDetail.productOutstockId = wmsProductOutstock.productOutstockId;
wmsProductOutstockDetail.warehouseId = wmsProductOutstock.warehouseId;
wmsProductOutstockDetail.locationCode = wmsBaseLocation.locationCode;
wmsProductOutstockDetail.productBarcode = wmsProductStock.productBatch;
wmsProductOutstockDetail.productId = wmsProductStock.productId;
wmsProductOutstockDetail.planAmount = wmsProductOutstock.applyQty;
wmsProductOutstockDetail.outstockAmount = wmsProductOutstock.outstockQty;
wmsProductOutstockDetail.executeStatus = "2";
wmsProductOutstockDetail.updateBy = "WCS";
wmsProductOutstockDetail.updateDate = DateTime.Now;
wmsProductOutstockDetail.beginTime = DateTime.Now;
wmsProductOutstockDetail.endTime = DateTime.Now;
dbContext.Add(wmsProductOutstockDetail);
}
2 years ago
wmsBaseLocation.locationStatus = "1";
wmsBaseLocation.containerCode = null;
wmsBaseLocation.updateTime = DateTime.Now;
wmsBaseLocation.updateBy = "WCS";
2 years ago
SystemData.UnLockOutLocation(wmsBaseLocation, dbContext);
1 year ago
dbContext.Update(wmsBaseLocation);
2 years ago
dbContext.WmsProductStock.Where(t => t.locationCode == wmsBaseLocation.locationCode).Delete();
BaseEquip floorLineEquip = StaticData.BaseEquip.First(t => t.equipType == 1 && t.floorNo == 5);
WcsTask newTask = CoreMapper.Map<WcsTask>(item);
newTask.createTime = DateTime.Now;
newTask.nextPointId = floorLineEquip.objid;
newTask.nextPointNo = floorLineEquip.equipNo;
newTask.fromFloorNo = 5;
newTask.floorNo = 1;
newTask.taskStatus = 6;
newTask.objid = StaticData.SnowId.NextId();
2 years ago
dbContext.Remove(item);
dbContext.Add(newTask);
WcsTaskLog wcsTaskLog = CoreMapper.Map<WcsTaskLog>(newTask);
dbContext.Add(wcsTaskLog);
dbContext.SaveChanges();
dbContext.WcsTaskLog.Where(t => t.objid == item.objid).Update(t => new WcsTaskLog { taskStatus = 6 });
1 year ago
SystemData.SendPlcLocation(wmsBaseLocation);
2 years ago
}
}
else if (item.taskType == StaticTaskType.FiveRawToBack)//原材料到背板安装
{
Console.WriteLine(DateTime.Now + ":五楼AGV线程完成任务" + item.currPointNo + "," + item.endPointNo);
_logger.Info("五楼Agv完成任务成功" + item.ToJsonString());
WmsRawOutstock? wmsRawOutstock = dbContext.WmsRawOutstock.Where(t => t.rawOutstockId == item.orderId).FirstOrDefault();
2 years ago
if (wmsRawOutstock != null)
{
1 year ago
wmsRawOutstock.realOutstockAmount += 1;
wmsRawOutstock.executeStatus = "2";
wmsRawOutstock.endTime = DateTime.Now;
WmsBaseLocation wmsBaseLocation = dbContext.WmsBaseLocation.First(t => t.locationId == item.currPointId);
wmsBaseLocation.returnFlag = "0";
wmsBaseLocation.locationStatus = "1";
wmsBaseLocation.containerCode = null;
wmsBaseLocation.updateTime = DateTime.Now;
wmsBaseLocation.updateBy = "WCS";
WmsRawStock wmsRawStock = dbContext.WmsRawStock.FirstOrDefault(t => t.locationCode == wmsBaseLocation.locationCode);
WmsRawOutstockDetail newWmsRawOutstockDetail = new WmsRawOutstockDetail();
newWmsRawOutstockDetail.rawOutstockId = wmsRawOutstock.rawOutstockId;
newWmsRawOutstockDetail.taskCode = wmsRawOutstock.taskCode;
newWmsRawOutstockDetail.warehouseId = wmsRawOutstock.warehouseId;
newWmsRawOutstockDetail.locationCode = wmsRawOutstock.locationCode;
newWmsRawOutstockDetail.materialBarcode = wmsRawOutstock.materialBatch;
newWmsRawOutstockDetail.materialId = wmsRawOutstock.materialId;
if (wmsRawStock != null)
{
MesBaseBarcodeInfo? mesBaseBarcodeInfo = dbContext.MesBaseBarcodeInfo.Where(t => t.barcodeInfo == wmsRawStock.instockBatch).FirstOrDefault();
if (mesBaseBarcodeInfo != null)
{
newWmsRawOutstockDetail.instockBatch = mesBaseBarcodeInfo.batchCode;
newWmsRawOutstockDetail.materialProductionDate = mesBaseBarcodeInfo.productionDate;
}
}
newWmsRawOutstockDetail.planAmount = wmsRawOutstock.outstockAmount;
newWmsRawOutstockDetail.outstockAmount = wmsRawOutstock.realOutstockAmount;
newWmsRawOutstockDetail.executeStatus = "2";
newWmsRawOutstockDetail.outstockPerson = wmsRawOutstock.applyBy;
newWmsRawOutstockDetail.outstockTime = DateTime.Now;
newWmsRawOutstockDetail.outstockWay = "2";
newWmsRawOutstockDetail.createBy = "WCS";
newWmsRawOutstockDetail.createDate = DateTime.Now;
newWmsRawOutstockDetail.stackAmount = 1;
1 year ago
SystemData.UnLockOutLocation(wmsBaseLocation, dbContext);
dbContext.Add(newWmsRawOutstockDetail);
1 year ago
dbContext.Update(wmsRawOutstock);
dbContext.Update(wmsBaseLocation);
dbContext.WmsRawStock.Where(t => t.locationCode == wmsBaseLocation.locationCode).Delete();
1 year ago
dbContext.Remove(item);
if (wmsRawStock != null)
{
dbContext.Remove(wmsRawStock);
}
1 year ago
dbContext.SaveChanges();
dbContext.WcsTaskLog.Where(t => t.objid == item.objid).Update(t => new WcsTaskLog { taskStatus = 6 });
SystemData.SendPlcLocation(wmsBaseLocation);
2 years ago
}
2 years ago
}
else if (item.taskType == StaticTaskType.FiveHalfIn)//半成品入库
{
Console.WriteLine(DateTime.Now + ":五楼AGV线程完成任务" + item.currPointNo + "," + item.endPointNo);
_logger.Info("五楼Agv完成任务成功" + item.ToJsonString());
WmsBaseLocation wmsBaseLocation = dbContext.WmsBaseLocation.First(t => t.locationId == item.endPointId);
wmsBaseLocation.locationStatus = "1";
wmsBaseLocation.containerCode = item.containerNo;
wmsBaseLocation.updateTime = DateTime.Now;
wmsBaseLocation.updateBy = "WCS";
var mesBasePalletInfo = dbContext.MesBasePalletInfo.Where(t => t.palletInfoCode == item.containerNo).FirstOrDefault();
var wmsProductInstock = dbContext.WmsProductInstock
1 year ago
.Where(t => t.executeStatus == "1" && t.productType == "2" && t.warehouseId == 521).OrderByDescending(x=>x.applyDate)
2 years ago
.FirstOrDefault();
if (mesBasePalletInfo != null && wmsProductInstock != null)
2 years ago
{
2 years ago
//WmsProductInstockDetail? wmsProductInstockDetail = dbContext.WmsProductInstockDetail.Where(t => t.productInstockId == wmsProductInstock.productInstockId).FirstOrDefault();
//if (wmsProductInstockDetail != null)
//{
wmsProductInstock.executeStatus = "2";
wmsProductInstock.endTime = DateTime.Now;
dbContext.Update(wmsProductInstock);
WmsProductStock wmsProductStock = new WmsProductStock()
2 years ago
{
2 years ago
productId = wmsProductInstock.productId,
activeFlag = "1",
updateBy = "WCS",
updateDate = DateTime.Now,
saleorderCode = wmsProductInstock.saleorderCode,
saleOrderId = wmsProductInstock.SaleOrderId == null ? 0 : wmsProductInstock.SaleOrderId,
stockType = "2",
productStockId = wmsProductInstock.productInstockId,
qualityStatus = "0",
createBy = "WCS",
createDate = DateTime.Now,
locationCode = wmsBaseLocation.locationCode,
warehouseFloor = 5,
totalAmount = 1,
instockDate = DateTime.Now,
productBatch = mesBasePalletInfo.materialBarcode,
palletInfoCode = mesBasePalletInfo.palletInfoCode,
frozenAmount = 0,
occupyAmount = 0,
planCode = wmsProductInstock.planCode,
planDetailCode = wmsProductInstock.planDetailCode,
warehouseId = 521
2 years ago
};
BaseEquip startEquip = StaticData.BaseEquip.First(t => t.objid == item.currPointId);
//wmsProductInstockDetail.executeStatus = "2";
//wmsProductInstockDetail.instockDate = DateTime.Now;
startEquip.emptyCount = 0;
//dbContext.Update(wmsProductInstockDetail);
dbContext.Update(startEquip);
dbContext.Add(wmsProductStock);
dbContext.Update(wmsBaseLocation);
1 year ago
dbContext.Remove(item);
2 years ago
dbContext.WcsTaskLog.Where(t => t.objid == item.objid).Update(t => new WcsTaskLog { taskStatus = 6 });
dbContext.SaveChanges();
//}
1 year ago
SystemData.SendPlcLocation(wmsBaseLocation);
2 years ago
}
2 years ago
}
else if (item.taskType == StaticTaskType.FiveRawToSplit)//原材料到柜体拆分
{
Console.WriteLine(DateTime.Now + ":五楼AGV线程完成任务" + item.currPointNo + "," + item.endPointNo);
_logger.Info("五楼Agv完成任务成功" + item.ToJsonString());
var wmsRawOutStock = dbContext.WmsRawOutstock.Where(t => t.rawOutstockId == item.orderId).FirstOrDefault();
WmsBaseLocation wmsBaseLocation = dbContext.WmsBaseLocation.First(t => t.locationId == item.currPointId);
WmsRawStock? wmsRawStock = dbContext.WmsRawStock.Where(t => t.locationCode == wmsBaseLocation.locationCode).FirstOrDefault();
if (wmsRawOutStock != null && wmsRawStock != null)
2 years ago
{
2 years ago
wmsRawOutStock.realOutstockAmount += 1;
wmsRawOutStock.executeStatus = "2";
wmsRawOutStock.endTime = DateTime.Now;
WmsRawOutstockDetail newWmsRawOutstockDetail = new WmsRawOutstockDetail();
newWmsRawOutstockDetail.rawOutstockId = wmsRawOutStock.rawOutstockId;
newWmsRawOutstockDetail.taskCode = wmsRawOutStock.taskCode;
newWmsRawOutstockDetail.warehouseId = wmsRawOutStock.warehouseId;
newWmsRawOutstockDetail.locationCode = wmsRawStock.locationCode;
newWmsRawOutstockDetail.materialBarcode = wmsRawStock.instockBatch;
newWmsRawOutstockDetail.materialId = wmsRawStock.materialId;
MesBaseBarcodeInfo? mesBaseBarcodeInfo = dbContext.MesBaseBarcodeInfo.Where(t => t.barcodeInfo == wmsRawStock.instockBatch).FirstOrDefault();
if (mesBaseBarcodeInfo != null)
{
newWmsRawOutstockDetail.instockBatch = mesBaseBarcodeInfo.batchCode;
newWmsRawOutstockDetail.materialProductionDate = mesBaseBarcodeInfo.productionDate;
}
newWmsRawOutstockDetail.planAmount = wmsRawOutStock.outstockAmount;
newWmsRawOutstockDetail.outstockAmount = wmsRawOutStock.realOutstockAmount;
newWmsRawOutstockDetail.executeStatus = "2";
newWmsRawOutstockDetail.outstockPerson = wmsRawOutStock.applyBy;
newWmsRawOutstockDetail.outstockTime = DateTime.Now;
newWmsRawOutstockDetail.outstockWay = "2";
newWmsRawOutstockDetail.createBy = "WCS";
newWmsRawOutstockDetail.createDate = DateTime.Now;
newWmsRawOutstockDetail.stackAmount = 1;
1 year ago
2 years ago
wmsBaseLocation.locationStatus = "1";
2 years ago
wmsBaseLocation.containerCode = null;
2 years ago
wmsBaseLocation.updateTime = DateTime.Now;
wmsBaseLocation.updateBy = "WCS";
2 years ago
SystemData.UnLockOutLocation(wmsBaseLocation, dbContext);
1 year ago
dbContext.Update(wmsBaseLocation);
dbContext.Update(wmsRawOutStock);
dbContext.Add(newWmsRawOutstockDetail);
dbContext.Remove(wmsRawStock);
dbContext.Remove(item);
dbContext.SaveChanges();
dbContext.WcsTaskLog.Where(t => t.objid == item.objid).Update(t => new WcsTaskLog { taskStatus = 6 });
1 year ago
SystemData.SendPlcLocation(wmsBaseLocation);
2 years ago
}
}
else if (item.taskType == StaticTaskType.FiveRawSplitReturn)//柜体拆分到原材料
{
Console.WriteLine(DateTime.Now + ":五楼AGV线程完成任务" + item.currPointNo + "," + item.endPointNo);
_logger.Info("五楼Agv完成任务成功" + item.ToJsonString());
WmsBaseLocation wmsBaseLocation = dbContext.WmsBaseLocation.First(t => t.locationId == item.endPointId);
wmsBaseLocation.locationStatus = "1";
wmsBaseLocation.returnFlag = "1";
wmsBaseLocation.containerCode = item.containerNo;
wmsBaseLocation.updateTime = DateTime.Now;
wmsBaseLocation.updateBy = "WCS";
MesBasePalletInfo? mesBasePalletInfo = dbContext.MesBasePalletInfo.FirstOrDefault(t => t.palletInfoCode == item.containerNo);
if (mesBasePalletInfo != null)
{
MesBaseBarcodeInfo? mesBaseBarcodeInfo = dbContext.MesBaseBarcodeInfo.FirstOrDefault(t => t.barcodeInfo == mesBasePalletInfo.materialBarcode);
if (mesBaseBarcodeInfo != null)
2 years ago
{
2 years ago
WmsRawStock wmsRawStock = new()
{
2 years ago
palletInfoCode = mesBasePalletInfo.palletInfoCode,
activeFlag = "1",
createBy = "WCS",
createDate = DateTime.Now,
2 years ago
frozenAmount = 0,
instockDate = DateTime.Now,
locationCode = wmsBaseLocation.locationCode,
2 years ago
occupyAmount = 0,
warehouseFloor = 5,
2 years ago
stockType = "1",
totalAmount = 1,
2 years ago
saleOrderId = mesBaseBarcodeInfo.saleOrderId == null ? 0 : mesBaseBarcodeInfo.saleOrderId,
safeFlag = mesBaseBarcodeInfo.safeFlag,
supplierId = mesBaseBarcodeInfo.manufacturerId,
materialId = mesBasePalletInfo.materialId,
qualityStatus = "0",
rawStockId = StaticData.SnowId.NextId(),
completeFlag = "0",
instockBatch = mesBaseBarcodeInfo.barcodeInfo,
updateBy = "WCS",
updateDate = DateTime.Now,
warehouseId = 511,
};
1 year ago
var WmsRawInstock = dbContext.WmsRawInstock.FirstOrDefault(t => t.materialBarCode == mesBasePalletInfo.materialBarcode && (t.instockType == "2" || t.instockType == "4"));
1 year ago
if (WmsRawInstock != null)
{
WmsRawInstock.returnFlag = null;
WmsRawInstock.executeStatus = "2";
WmsRawInstock.updateDate = DateTime.Now;
SystemData.UnLockOutLocation(wmsBaseLocation, dbContext);
1 year ago
dbContext.Update(wmsBaseLocation);
1 year ago
dbContext.Update(WmsRawInstock);
dbContext.Add(wmsRawStock);
BaseEquip startEquip = StaticData.BaseEquip.First(t => t.objid == item.currPointId);
startEquip.emptyCount = 0;
dbContext.Update(startEquip);
dbContext.Remove(item);
dbContext.SaveChanges();
dbContext.WcsTaskLog.Where(t => t.objid == item.objid).Update(t => new WcsTaskLog { taskStatus = 6 });
SystemData.SendPlcLocation(wmsBaseLocation);
}
2 years ago
}
2 years ago
}
2 years ago
2 years ago
}
else if (item.taskType == StaticTaskType.FiveRawIn)//原材料入库
{
Console.WriteLine(DateTime.Now + ":五楼AGV线程完成任务" + item.currPointNo + "," + item.endPointNo);
_logger.Info("五楼Agv完成任务成功" + item.ToJsonString());
WmsBaseLocation wmsBaseLocation = dbContext.WmsBaseLocation.First(t => t.locationId == item.endPointId);
wmsBaseLocation.locationStatus = "1";
wmsBaseLocation.containerCode = item.containerNo;
var mesBasePalletInfo = dbContext.MesBasePalletInfo.FirstOrDefault(t => t.palletInfoCode == item.containerNo);
if (mesBasePalletInfo != null)
2 years ago
{
2 years ago
var mesBaseBarcodeInfo = dbContext.MesBaseBarcodeInfo.FirstOrDefault(t => t.barcodeInfo == mesBasePalletInfo.materialBarcode);
if (mesBaseBarcodeInfo != null)
2 years ago
{
1 year ago
//if (mesBaseBarcodeInfo.PurchaseOrderId == -1)
//{ // 虚拟托盘号,合并的物料分别插入WmsRawInstock
// List<MesSaleOrderRelate> mesSaleOrderRelates = dbContext.MesSaleOrderRelate.Where(x => x.SaleOrderId == mesBaseBarcodeInfo.saleOrderId).ToList();
// List<WmsRawInstock>? wmsRawInstocks = new List<WmsRawInstock>();
// foreach (var mesSaleOrderRelate in mesSaleOrderRelates)
// {
// WmsRawInstock wmsRawInstock = new WmsRawInstock()
// {
// taskCode = StaticData.SnowId.NextId().ToString(),
// materialBarCode = null,
// materialBatchCode = null,
// applyBy = "wcs",
// applyDate = System.DateTime.Now,
// purchaseOrderId = mesSaleOrderRelate.PurchaseOrderId,
// beginTime = DateTime.Now,
// endTime = DateTime.Now,
// locationCode = wmsBaseLocation.locationCode,
// executeStatus = "2",
// instockAmount = mesSaleOrderRelate.RelateSaleOrderAmount,
// instockType = "1",
// materialId = mesSaleOrderRelate.MaterialId,
// operationType = "3",
// palletInfoCode = mesBaseBarcodeInfo.palletInfoCode,
// poNo = mesBaseBarcodeInfo.poNo,
// warehouseId = 511
// };
// wmsRawInstocks.Add(wmsRawInstock);
// }
// if (wmsRawInstocks.Count > 0)
// {
1 year ago
// dbContext.AddRange(wmsRawInstocks);
1 year ago
// }
//}
//else
1 year ago
{
WmsRawInstock wmsRawInstock = new WmsRawInstock()
{
taskCode = StaticData.SnowId.NextId().ToString(),
1 year ago
materialBarCode = mesBaseBarcodeInfo.barcodeInfo,
materialBatchCode = mesBaseBarcodeInfo.batchCode,
applyBy = "wcs",
applyDate = System.DateTime.Now,
purchaseOrderId = mesBaseBarcodeInfo.PurchaseOrderId,
beginTime = DateTime.Now,
endTime = DateTime.Now,
locationCode = wmsBaseLocation.locationCode,
executeStatus = "2",
instockAmount = 1,
1 year ago
instockType = "4",
1 year ago
materialId = mesBaseBarcodeInfo.materialId,
operationType = "3",
palletInfoCode = mesBaseBarcodeInfo.palletInfoCode,
poNo = mesBaseBarcodeInfo.poNo,
warehouseId = 511
};
dbContext.Add(wmsRawInstock);
}
2 years ago
WmsRawStock wmsRawStock = new()
2 years ago
{
2 years ago
palletInfoCode = mesBasePalletInfo.palletInfoCode,
activeFlag = "1",
createBy = "WCS",
createDate = DateTime.Now,
frozenAmount = 0,
instockDate = DateTime.Now,
locationCode = wmsBaseLocation.locationCode,
occupyAmount = 0,
warehouseFloor = 5,
stockType = "1",
totalAmount = 1,
saleOrderId = mesBaseBarcodeInfo.saleOrderId == null ? 0 : mesBaseBarcodeInfo.saleOrderId,
safeFlag = mesBaseBarcodeInfo.safeFlag,
supplierId = mesBaseBarcodeInfo.manufacturerId,
materialId = mesBasePalletInfo.materialId,
qualityStatus = "0",
rawStockId = StaticData.SnowId.NextId(),
completeFlag = mesBaseBarcodeInfo.completeFlag,
instockBatch = mesBaseBarcodeInfo.barcodeInfo,
updateBy = "WCS",
updateDate = DateTime.Now,
warehouseId = 511,
};
1 year ago
2 years ago
wmsBaseLocation.returnFlag = "0";
1 year ago
SystemData.UnLockOutLocation(wmsBaseLocation, dbContext);
dbContext.Update(wmsBaseLocation);
2 years ago
BaseEquip lineEquip = dbContext.BaseEquip.First(t => t.objid == 5);
lineEquip.equipStatus = 0;
dbContext.Update(lineEquip);
dbContext.Add(wmsRawStock);
dbContext.Remove(item);
dbContext.SaveChanges();
dbContext.WcsTaskLog.Where(t => t.objid == item.objid).Update(t => new WcsTaskLog { taskStatus = 6 });
1 year ago
SystemData.SendPlcLocation(wmsBaseLocation);
2 years ago
}
2 years ago
}
}
1 year ago
else if (item.taskType == StaticTaskType.FiveStockReturnTask)
{
BaseEquip floorLineEquip = StaticData.BaseEquip.First(t => t.objid == 5);
var wmsRawOutstock = dbContext.WmsRawOutstock.Where(t => t.rawOutstockId == item.orderId).FirstOrDefault();
var wmsRawStock = dbContext.WmsRawStock.Where(t => t.locationCode == item.currPointNo).FirstOrDefault();
var wmsBaseLocation = dbContext.WmsBaseLocation.Where(t => t.locationCode == item.currPointNo).FirstOrDefault();
if (wmsRawOutstock != null && wmsRawStock != null && wmsBaseLocation != null)
{
wmsRawOutstock.realOutstockAmount += 1;
wmsRawOutstock.executeStatus = "2";
wmsRawOutstock.endTime = DateTime.Now;
dbContext.Remove(wmsRawStock);
wmsBaseLocation.locationStatus = "1";
wmsBaseLocation.containerCode = null;
wmsBaseLocation.updateTime = DateTime.Now;
wmsBaseLocation.updateBy = "WCS";
WmsRawOutstockDetail newWmsRawOutstockDetail = new WmsRawOutstockDetail();
newWmsRawOutstockDetail.rawOutstockId = wmsRawOutstock.rawOutstockId;
newWmsRawOutstockDetail.taskCode = wmsRawOutstock.taskCode;
newWmsRawOutstockDetail.warehouseId = wmsRawOutstock.warehouseId;
newWmsRawOutstockDetail.locationCode = wmsRawOutstock.locationCode;
newWmsRawOutstockDetail.materialBarcode = wmsRawOutstock.materialBatch;
newWmsRawOutstockDetail.materialId = wmsRawOutstock.materialId;
MesBaseBarcodeInfo? mesBaseBarcodeInfo = dbContext.MesBaseBarcodeInfo.Where(t => t.barcodeInfo == wmsRawStock.instockBatch).FirstOrDefault();
if (mesBaseBarcodeInfo != null)
{
newWmsRawOutstockDetail.instockBatch = mesBaseBarcodeInfo.batchCode;
newWmsRawOutstockDetail.materialProductionDate = mesBaseBarcodeInfo.productionDate;
}
newWmsRawOutstockDetail.planAmount = wmsRawOutstock.outstockAmount;
newWmsRawOutstockDetail.outstockAmount = wmsRawOutstock.realOutstockAmount;
newWmsRawOutstockDetail.executeStatus = "2";
newWmsRawOutstockDetail.outstockPerson = wmsRawOutstock.applyBy;
newWmsRawOutstockDetail.outstockTime = DateTime.Now;
newWmsRawOutstockDetail.outstockWay = "2";
newWmsRawOutstockDetail.createBy = "WCS";
newWmsRawOutstockDetail.createDate = DateTime.Now;
newWmsRawOutstockDetail.stackAmount = 1;
1 year ago
SystemData.UnLockOutLocation(wmsBaseLocation, dbContext);
dbContext.Add(newWmsRawOutstockDetail);
1 year ago
dbContext.Update(wmsBaseLocation);
dbContext.Update(wmsRawOutstock);
item.createTime = DateTime.Now;
item.nextPointId = floorLineEquip.objid;
item.nextPointNo = floorLineEquip.equipNo;
item.fromFloorNo = 5;
item.floorNo = 1;
item.taskStatus = 6;
dbContext.Update(item);
dbContext.WcsTaskLog.Where(t => t.objid == item.objid).Update(t => new WcsTaskLog { taskStatus = 6, updateTime = DateTime.Now });
dbContext.SaveChanges();
}
}
2 years ago
}
}
2 years ago
break;
}
}
catch (Exception ex)
{
2 years ago
if (ex is PlcException)
{
2 years ago
2 years ago
}
else
{
_logger.Error(ex.Message + "\n" + ex.StackTrace);
2 years ago
}
}
finally
{
Thread.Sleep(1000);
}
}
}
}
}