using HslCommunication;
using Microsoft.EntityFrameworkCore;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading;
using System.Threading.Tasks;
using WIDESEA_Common;
using WIDESEA_Common.LoctionEnum;
using WIDESEA_Common.Tools;
using WIDESEA_Core.EFDbContext;
using WIDESEA_Entity.DomainModels;
using WIDESEA_Services.IRepositories;
using WIDESEA_Services.Repositories;
using WIDESEA_WCS.WCSClient;
namespace WIDESEA_WCS
{
public partial class StackerExecutor
{
public static object requestZJGFUP = new object();//requestZJJK
private static int _readGFBUPSignalsoZ = 0;//_readZTBUPSignalso
///
/// 正极辊分上料工作逻辑
///
///
public static void Z_GFSB_UpTask()
{
if (Interlocked.Exchange(ref _readGFBUPSignalsoZ, 1) == 0)
{
Task.Run(() =>
{
try
{
VOLContext Context = new VOLContext();
Ibase_ware_locationRepository locRepository = new base_ware_locationRepository(Context);
Ibase_routing_tableRepository routingRepository = new base_routing_tableRepository(Context);
Idt_agvtaskRepository agvRepository = new dt_agvtaskRepository(Context);
List TBSBS = new List { "辊分机正极1", "辊分机正极2", "辊分机正极3", "辊分机正极4" };
foreach (var TBSB in TBSBS)
{
//string SBID = TBSB.Replace("辊分机正极", "");//设备号
PLCClient plc = WCSService.Clients.Find(v => v.PLCName == TBSB);
if (plc == null)
{
//WriteLog.GetLog("GFZ上料呼叫").Write($"设备:{TBSB} 内容:未连接PLC 时间记录:{DateTime.Now}", "GFZ上料呼叫");
continue;
}
//当前设备有没有上料请求
//bool GYR_RFX = Convert.ToBoolean(plc.ReadValue("R_Feedingrequest".ToString(), plc.EquipType));
//if (GYR_RFX)
OperateResult GYR_RFX = plc.MelsecPLCClient.MelsecMcNetClient.ReadBool("D5493.0");
Int16 tf = Convert.ToInt16(GYR_RFX.Content);
if (GYR_RFX.Content)
{
//查看当前辊分机设备是否有AGV任务
var SBtask = agvRepository.FindFirst(f => f.agv_toaddress == plc.EquipType);
//有结束本次循环
if (SBtask != null) { continue; }
#region 记录上料请求信号
WriteLog.GetLog().Write($"{plc.PLCName}上料请求:{GYR_RFX.Content}---{DateTime.Now}", $"正极棍分上料请求");
#endregion
List Routing_Table = routingRepository.Find(d => d.route_end == plc.EquipType);
List loctionList = new List();
foreach (var item in Routing_Table)
{
base_ware_location ware_Locations = locRepository.FindFirst(d => d.upper_code == item.route_began && d.status == 1 && d.location_state == LoctionStateEnum.LocationState_Stored.ToString() && d.logic_col == 1 && d.task == 2);
if (ware_Locations == null)
{
continue;
}
loctionList.Add(ware_Locations);
}
if (loctionList.Count != 0)
{
base_ware_location Location = loctionList.OrderBy(d => d.update_time).FirstOrDefault();
//生成辊分机上料任务
dt_agvtask agvtask = new dt_agvtask()
{
agv_id = Guid.NewGuid(),
agv_tasknum = "KH-" + IdenxManager.GetTaskNo(),
agv_fromaddress = Location.upper_code,
agv_toaddress = plc.EquipType,
agv_code = "正极AGV调度",
agv_remark = "辊分上料任务",
agv_taskstate = AGVTaskStateEnum.Create.ToString(),
agv_tasktype = AGVTaskTypeEnum.TaskType_Outbound.ToString(),
agv_worktype = 1,//工作类型
agv_materielid = "",
agv_qty = 1,
agv_createtime = DateTime.Now,
agv_grade = 0,//任务优先级
agv_userid = "WCS",
agv_barcode = "",
};
//Location.update_time = DateTime.Now;
Location.task = 1;
Location.logic_col = 1;
var entry = locRepository.DbContext.ChangeTracker.Entries().FirstOrDefault();
if (entry != null)
{
entry.State = EntityState.Detached;
}
int a = locRepository.Update(Location, d => new { d.task, d.logic_col }, true);
if (a == 1)
{
agvRepository.Add(agvtask, true);
//WriteDBLog.Info($"【{TBSB}】上料任务生成").Write($"生成任务:{agvtask.agv_tasknum},起点货位状态:托盘光电检测:{Location.tpgd},状态:{Location.location_state},更新时间:{Location.wireless_time}", $"【{TBSB}】上料任务生成");
//WriteDBLog.Info($"【{TBSB}】上料任务生成").Write($"----------------任务生成成功 {DateTime.Now} -------------- {Environment.NewLine}", $"【{TBSB}】上料任务生成");
}
}
}
}
}
catch (Exception ex)
{
WriteLog.GetLog().Write($"正极棍分上料:{DateTime.Now} --------------{ex}", $"正极棍分上料");
}
finally
{
Interlocked.Exchange(ref _readGFBUPSignalsoZ, 0);
}
});
}
}
}
}