using ServiceCenter.Logs;
using ServiceCenter.SqlSugars;
using System.ComponentModel;
using WCS.Core;
using WCS.Entity;
using WCS.Entity.Protocol.BCR;
using WCS.Entity.Protocol.Station;
using WCS.WorkEngineering.Extensions;
using WCS.WorkEngineering.WebApi.Controllers;
using WCS.WorkEngineering.Worlds;
using DeviceFlags = WCS.WorkEngineering.Extensions.DeviceFlags;
using TaskStatus = WCS.Entity.TaskStatus;
namespace WCS.WorkEngineering.Systems
{
///
/// 二楼入库工位处理系统
///
[BelongTo(typeof(MainWorld))]
[Description("二楼入库工位处理系统")]
public class 二楼入库工位处理系统 : DeviceSystem
{
protected override bool ParallelDo => false;
protected override bool SaveLogsToFile => true;
private List BCRS = new List();
public 二楼入库工位处理系统()
{
BCRS = Device.All.Where(v => v.HasProtocol()).Select(v => new BCR(v, World)).ToList();
}
public override void Do(Station obj)
{
obj.StorageStationIsForbid();
//判断凭证号是否一致
if (obj.Data.VoucherNo != obj.Data2.VoucherNo) throw new KnownException($"凭证号不一致,DB520:{obj.Data.VoucherNo}-DB521{obj.Data2.VoucherNo}", LogLevelEnum.High);
//设备是否停止运行
if (obj.Data3.Status.HasFlag(StatusEunm.Run)) throw new KnownException("设备运行中", LogLevelEnum.Low);
if (!obj.Data3.Status.HasFlag(StatusEunm.PH_Status)) throw new KnownException("没有光电", LogLevelEnum.Low);
if (obj.Data2.TaskNumber != 0) throw new KnownException("有任务", LogLevelEnum.Low);
if (obj.Data2.Request != 1) throw new KnownException("没有请求", LogLevelEnum.Low);
WCS_TaskInfo task = null;
SqlSugarHelper.Do(db =>
{
if (obj.Entity.Code == "1025" || obj.Entity.Code == "1023")
{
var taskInfos = db.Default.Queryable().Where(v => v.Type == TaskType.EmptyInit && v.Status == TaskStatus.WaitingToExecute);
var taskInfo = taskInfos.First(v => v.SrmStation == obj.Entity.Code) ?? throw new KnownException($"未找到对应的任务", LogLevelEnum.Mid);
if (taskInfo != null)
{
task = taskInfo;
if (task.Type != TaskType.EmptyInit && task.Status != Entity.TaskStatus.WaitingToExecute) throw new KnownException($"任务:{task.ID}不是待执行状态,请检查异常原因", LogLevelEnum.High);
}
}
if (task == null) return;
if (task.Status == Entity.TaskStatus.ConveyorExecution) return;
if (obj.Entity.Code == "1025")
{
//获取称重
var dev91 = Device.All.Where(v => v.Code == obj.Entity.Code).Select(v => new Device(v, this.World)).FirstOrDefault();
task.Weight = dev91.Data.Weight;
WmsApi.WcsUploadInfo(task.ID, (decimal)task.Weight, task.BarCode);
}
task.Status = Entity.TaskStatus.ConveyorExecution;
db.Default.Updateable(task).ExecuteCommand();
task.AddWCS_TASK_DTL(db, obj.Entity.Code, "SRM", $"状态更新为{Entity.TaskStatus.ConveyorExecution},等待分配货位后堆垛机进行取货");
});
if (task == null) throw new KnownException("数据更新错误", LogLevelEnum.High);
obj.Data.TaskNumber = task.ID;
}
public override bool Select(Device dev)
{
//return dev.Code == "1025";
return dev.HasFlag(DeviceFlags.二楼入库口);
}
}
}