using System; using System.Collections.Generic; using System.Linq; using System.Security.Cryptography.Xml; using System.Text; using System.Threading.Tasks; using WIDESEA_Comm; using WIDESEA_Comm.TaskNo; using WIDESEA_Core.EFDbContext; using WIDESEA_Core.FreeDB; using WIDESEA_Entity.DomainModels; using WIDESEA_WCS.IRepositories; using WIDESEA_WCS.Repositories; using static FreeSql.Internal.GlobalFilter; using static System.Collections.Specialized.BitVector32; namespace WIDESEA_WCS.JobsPart.Common { public class OutboundTask { static FreeDB freeDB = new FreeDB(); /// /// 创建出库任务 /// public static void CreateOutboundTask() { try { VOLContext context = new VOLContext(); Idt_stationinfoRepository stationinfoRepository = new dt_stationinfoRepository(context); var mes_heads = freeDB.Select().Where(x => x.processCode == "28").OrderBy(x => x.expectedStartTime).ToList(); foreach (var mes_head in mes_heads) { #region 根据库存入库时间最晚查询 var inventory = freeDB.Select().Where(x => x.FigureNumber == mes_head.drawingNo).OrderByDescending(x => x.OnlineTime).First(); if (inventory != null) { var Station = stationinfoRepository.Find(x => x.stationCode == inventory.stationCode).FirstOrDefault(); if (Station != null) { var stationinfo = stationinfoRepository.Find(x => x.line == Station.line && x.area == Station.area && x.enable).OrderByDescending(x => x.column).FirstOrDefault(); if (stationinfo != null) { if (stationinfo.bindSN == null) throw new Exception(stationinfo.stationCode + "车轮SN号信息异常!"); List lists = new List(); var SNS = stationinfo.bindSN.Split(","); foreach (var SN in SNS) { if (!string.IsNullOrEmpty(SN)) lists.Add(SN); } foreach (var item in lists) { if (freeDB.Select().Where(x => x.jobID == mes_head.jobID && x.SN == item).Any()) { dt_agvtask agvtask = new dt_agvtask() { agv_fromaddress = stationinfo.stationCode, agv_id = Guid.NewGuid(), agv_tasknum = IdenxManager.GetTaskNo("KH-", "WMS"), agv_grade = 1, agv_createtime = DateTime.Now, agv_taskstate = "Queue", agv_materielid = stationinfo.stationType, agv_qty = stationinfo.quantity, agv_tasktype = "TaskType_Outbound", agv_toaddress = "", agv_userid = "系统", bindSN = stationinfo.bindSN, agv_worktype = Convert.ToInt32(mes_head.processCode), agv_materbarcode = mes_head.materialCode, agv_Traytype = stationinfo.tray_type, agv_TrayStatus = stationinfo.tray_status }; dt_stationinfo TargetLocation = GetEmptyLocation(stationinfoRepository); if (TargetLocation != null) { agvtask.agv_taskstate = "Create"; agvtask.agv_toaddress = TargetLocation.stationCode; TargetLocation.location_state = LocationStateEnum.Busy.ToString(); freeDB.Update(TargetLocation); } freeDB.Add(agvtask); return; } } } stationinfo = stationinfoRepository.Find(x => x.stationType == mes_head.drawingNo && x.line != Station.line).OrderBy(x => x.line).ThenByDescending(x => x.column).FirstOrDefault(); if (stationinfo != null && stationinfo.enable) { if (stationinfo.bindSN == null) throw new Exception(stationinfo.stationCode + "车轮SN号信息异常!"); List lists = new List(); var SNS = stationinfo.bindSN.Split(","); foreach (var SN in SNS) { if (!string.IsNullOrEmpty(SN)) lists.Add(SN); } foreach (var item in lists) { if (freeDB.Select().Where(x => x.jobID == mes_head.jobID && x.SN == item).Any()) { dt_agvtask agvtask = new dt_agvtask() { agv_fromaddress = stationinfo.stationCode, agv_id = Guid.NewGuid(), agv_tasknum = IdenxManager.GetTaskNo("KH-", "WMS"), agv_grade = 1, agv_createtime = DateTime.Now, agv_taskstate = "Queue", agv_materielid = stationinfo.stationType, agv_qty = stationinfo.quantity, agv_tasktype = "TaskType_Outbound", agv_toaddress = "", agv_userid = "系统", bindSN = stationinfo.bindSN, agv_worktype = Convert.ToInt32(mes_head.processCode), agv_materbarcode = mes_head.materialCode, agv_Traytype = stationinfo.tray_type, agv_TrayStatus = stationinfo.tray_status }; dt_stationinfo TargetLocation = GetEmptyLocation(stationinfoRepository); if (TargetLocation != null) { agvtask.agv_taskstate = "Create"; agvtask.agv_toaddress = TargetLocation.stationCode; TargetLocation.location_state = LocationStateEnum.Busy.ToString(); freeDB.Update(TargetLocation); } freeDB.Add(agvtask); return; } } } } } #endregion #region MyRegion //var station = stationinfoRepository.Find(x => x.stationType == mes_head.drawingNo && x.line != x.line).OrderBy(x => x.line).ThenByDescending(x => x.column).FirstOrDefault(); //bool ok = false; //List list = new List(); //if (station != null && station.location_state == LocationStateEnum.Stroge.ToString() && station.enable) //{ // var SNS = station.bindSN.Split(","); // foreach (var SN in SNS) // { // if (!string.IsNullOrEmpty(SN)) // list.Add(SN); // } //} //foreach (var SN in list) //{ // if (ok = freeDB.Select().Where(x => x.jobID == mes_head.jobID && x.SN == SN).Any()) continue; //} //if (ok) //{ // dt_agvtask agvtask = new dt_agvtask() // { // agv_fromaddress = station.stationCode, // agv_id = Guid.NewGuid(), // agv_tasknum = IdenxManager.GetTaskNo("KH-", "WMS"), // agv_grade = 1, // agv_createtime = DateTime.Now, // agv_taskstate = "Queue", // agv_materielid = station.stationType, // agv_qty = station.quantity, // agv_tasktype = "TaskType_Outbound", // agv_toaddress = "", // agv_userid = "系统", // bindSN = station.bindSN, // agv_worktype = Convert.ToInt32(mes_head.processCode), // agv_materbarcode = mes_head.materialCode, // agv_barcode = station.tray_type // }; // dt_stationinfo TargetLocation = GetEmptyLocation(stationinfoRepository); // if (TargetLocation != null) // { // agvtask.agv_taskstate = "Create"; // agvtask.agv_toaddress = TargetLocation.stationCode; // TargetLocation.location_state = LocationStateEnum.Busy.ToString(); // freeDB.Update(TargetLocation); // } // freeDB.Add(agvtask); //} #endregion } } catch (Exception) { throw; } } private static dt_stationinfo GetEmptyLocation(Idt_stationinfoRepository stationinfoRepository) { dt_stationinfo TargetLocation = null; var stations = stationinfoRepository.Find(x => x.stationCode.Contains("S01001")); foreach (var station in stations) { TargetLocation = stationinfoRepository.FindFirst(x => x.stationCode == station.stationCode && x.location_state == LocationStateEnum.Empty.ToString() && x.enable); if (TargetLocation != null) continue; } if (TargetLocation == null) { throw new Exception("检测线上料位已满"); } return TargetLocation; } } }