using Microsoft.OpenApi.Extensions;
using ServiceCenter.Extensions;
using ServiceCenter.Logs;
using ServiceCenter.SqlSugars;
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using WCS.Core;
using WCS.Entity;
using WCS.Entity.Protocol.Station;
using WCS.WorkEngineering.Extensions;
using WCS.WorkEngineering.WebApi.Controllers;
using WCS.WorkEngineering.WebApi.Models.WMS.Response;
using WCS.WorkEngineering.Worlds;
using TaskStatus = WCS.Entity.TaskStatus;
namespace WCS.WorkEngineering.Systems.重绕区
{
///
/// 组盘缓存生成AGV任务
///
[BelongTo(typeof(RewindWorld))]
[Description("组盘缓存生成AGV任务")]
public class 组盘缓存生成AGV任务 : DeviceSystem>
{
protected override bool ParallelDo => true;
public override void Do(Device obj)
{
if (!obj.Data3.Status.HasFlag(StationStatus.Auto))
{
World.Log($"设备处于{obj.Data3.Status.GetDisplayName()}状态");
return;
}
if (!obj.Data3.Status.HasFlag(StationStatus.PH_Status))
{
World.Log($"设备无光电");
return;
}
SqlSugarHelper.Do(_db =>
{
var db = _db.Default;
var task = db.Queryable().ReadPastUpdLock().Single(x => x.Status == TaskStatus.ConveyorExecution && x.ID == obj.Data2.TaskNumber);
if (task == null)
{
World.Log($"未找到对应任务[{obj.Data2.TaskNumber}],请检查该任务状态与更新状态是否均为输送机执行中", LogLevelEnum.High);
return;
}
var agvId = DateTime.Now.GetFormat(GetFormatterEnum.only) + task.ID;
//开始创建AGV任务
var agvTask = db.Queryable().RowLock().SplitTable(x => x.Take(2)).Single(x => x.TaskId == task.ID && x.TaskType == AGVTaskType.EnterDepot);
if (agvTask == null)
{
db.InsertableRowLock(new WCS_AgvTaskInfo()
{
ID = _db.GetAgvTaskId(),
TaskType = AGVTaskType.EnterDepot,
Status = AGVTaskStatus.NewBuild,
TaskId = task.ID,
Position = obj.Entity.Code,
Station = task.SrmStation,
WorkShop = 111,
AddWho = "WCS",
AddTime = DateTime.Now,
AgvID = agvId
}).SplitTable().ExecuteCommand();
World.Log($"{task.ID}未找到对应的AGV任务");
return;
}
if (agvTask.Status != AGVTaskStatus.NewBuild)
{
World.Log($"AGV任务{agvTask.ID}状态不是新建", LogLevelEnum.High);
return;
}
//分配缓存货位 暂时先根据光电判断
List cacheWells = new List { "9201", "9202", "9203", "9204", "9205", "9206", "9207", "9208", "9209","9210","9211","9212",
"9213","9214","9215",/*"9216","9217","9218","9219","9220","9221","9222","9223","9224"*/};
var devs = Device.All.Where(x => cacheWells.Contains(x.Code)).Select(x =>
new Device(x, World));
if (!devs.Any()) return;
string sta = "";
if (!devs.Any(v => !v.Data3.Status.HasFlag(StationStatus.PH_Status))) return;
foreach (var dev in devs)
{
if (!dev.Data3.Status.HasFlag(StationStatus.PH_Status) && !db.Queryable().RowLock().SplitTable(x => x.Take(2)).Any(x => x.Station == dev.Entity.Code && x.TaskType == AGVTaskType.EnterDepot
&& x.Status < AGVTaskStatus.MissionCompleted))
{
var res = WmsApi.GetFlatLocalIn(obj.Data2.TaskNumber,"T1",dev.Entity.Code,1);
if (res.ResCode == ResponseStatusCodeEnum.Sucess && res.ResData.CellNo == dev.Entity.Code)
{
sta = dev.Entity.Code;
}
else if (res.ResCode == ResponseStatusCodeEnum.Sucess)
{
sta = res.ResData.CellNo;
World.Log($"{dev.Entity.Code}分配货位{res.ResData.CellNo}");
}
else
{
continue;
}
break;
//sta = dev.Entity.Code;
//break;
}
}
agvId = agvTask.AgvID;
if (sta == "") return;
agvTask.Status = AGVTaskStatus.Confirm;
agvTask.AgvStatus = AGVTaskStatus.Confirm;
agvTask.Station = sta;
db.UpdateableRowLock(agvTask).UpdateColumns(x => new { x.AgvID, x.Status, x.AgvStatus, x.Station }).SplitTable(x => x.Take(2)).ExecuteCommand();
task.Status = TaskStatus.AGVExecution;
task.AgvTaskID = agvTask.ID;
task.EditTime = DateTime.Now;
task.EditWho = "WCS";
task.AddrFrom = obj.Entity.Code;
task.AddrTo = agvTask.Station;
db.Updateable(task).UpdateColumns(x => new { x.Status, x.AgvTaskID, x.EditTime, x.EditWho,x.AddrFrom, x.AddrTo }).ExecuteCommand();
task.AddWCS_TASK_DTL(db, obj.Entity.Code, "AGV", $"任务下发至AGV{agvId},目标缓存货位{agvTask.Station}");
AgvApi.组盘入库(obj.Entity.Code, agvTask.Station, agvId);
});
}
public override bool Select(Device dev)
{
return dev.Code is "9126";
}
}
}