液晶标签剩余协议对接 编码

This commit is contained in:
hehaibing-1996
2024-12-10 19:09:43 +08:00
parent c94af9e987
commit 85a35ac34f
17 changed files with 393 additions and 149 deletions

View File

@ -4,7 +4,9 @@ using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using WCS.BLL.DbModels.Task;
using WCS.BLL.HardWare;
using TaskModeEnum = WCS.BLL.DbModels.Task.TaskModeEnum;
namespace WCS.DAL.DbModels
{
@ -89,7 +91,7 @@ namespace WCS.DAL.DbModels
public bool IsEnable { get; set; } = true;
[SugarColumn(ColumnName = "current_mode", IsNullable = true, ColumnDescription = "串联后大货架编码;大货架编码:未串联时是与货架编码是一对一的关系;串联后与货架编码是一对多的关系")]
public Mode CurrentMode { get; set; } = Mode.;
public TaskModeEnum CurrentMode { get; set; } = TaskModeEnum.;
/// <summary>
/// 序号

View File

@ -40,7 +40,7 @@ namespace WCS.DAL.DbModels
/// 货架当前状态
/// </summary>
[SugarColumn(ColumnName = "current_mode", IsNullable = false, ColumnDescription = "货架当前状态")]
public Mode CurrentMode { get; set; }
public WCS.BLL.DbModels.Task.TaskModeEnum CurrentMode { get; set; }
/// <summary>
/// 货架设置当前模式的时间

View File

@ -21,7 +21,7 @@ namespace WCS.BLL.HardWare
/// <summary>
/// 当前模式
/// </summary>
Mode CurrentMode { get; set; }
WCS.BLL.DbModels.Task.TaskModeEnum CurrentMode { get; set; }
/// <summary>
/// 设置当前模式

View File

@ -4,6 +4,7 @@ using System.Linq;
using System.Text;
using System.Threading.Tasks;
using WCS.BLL.DbModels;
using WCS.BLL.DbModels.Task;
using WCS.Model;
using static WCS.BLL.HardWare.WarningLight;
@ -52,7 +53,7 @@ namespace WCS.BLL.HardWare
/// <summary>
/// 货架当前模式
/// </summary>
public Mode CurrentMode { get; set; }
public WCS.BLL.DbModels.Task.TaskModeEnum CurrentMode { get; set; }
/// <summary>
/// 设置到当前模式的时间
/// </summary>
@ -82,7 +83,7 @@ namespace WCS.BLL.HardWare
/// <summary>
/// 设置货架模式
/// </summary>
public void SetCurrentMode(Mode mode);
public void SetCurrentMode(TaskModeEnum mode);
/// <summary>
/// 货架进入入库模式
@ -135,12 +136,4 @@ namespace WCS.BLL.HardWare
/// </summary>
public void ShelfCheck();
}
public enum Mode
{
= 0,
= 1,
= 2,
= 3
}
}

View File

@ -4,6 +4,7 @@ using System.Text.RegularExpressions;
using System.Threading.Tasks;
using WCS.BLL.Config;
using WCS.BLL.DbModels;
using WCS.BLL.DbModels.Task;
using WCS.BLL.Manager;
using WCS.DAL.Db;
using WCS.DAL.DbModels;
@ -27,7 +28,7 @@ namespace WCS.BLL.HardWare
ShelfCode = shelfInfo.ShelfCode;
RowCounts = shelfInfo.Rowcounts;
ColumnCounts = shelfInfo.Columncounts;
SetCurrentMode(Mode.);
SetCurrentMode(TaskModeEnum.);
ClientIp = shelfInfo.ClientIp;
LightId = shelfInfo.LightId;
WarningLight = new WarningLight() { LightId = shelfInfo.LightId };
@ -59,6 +60,9 @@ namespace WCS.BLL.HardWare
Task.WaitAll(task);
while (true)
{
Logs.Write($"[test]{ShelfCode}");
try
{
//未完成首次连接时 暂不发送
if (TcpCleint.IsFirstConnected == false)
@ -66,10 +70,6 @@ namespace WCS.BLL.HardWare
await Task.Delay(2000);
continue;
}
Logs.Write($"[test]");
try
{
//查询是否有需要刷新的
var needRefreshModules = MXL4Modules.Where(t => t.IsNeedRefresh)
.ToList();
@ -78,16 +78,121 @@ namespace WCS.BLL.HardWare
//查询当前是否有任务
var currentTasks = DbHelp.db.Queryable<CurrentTask>()
.Where(t => t.ModuleId == module.ModuleId)
.Where(t => t.IsSended == false)
.OrderBy(t => t.CreateTime)
.ToList();
//存在入库、出库、盘点等任务
//入库、出库、盘点等任务
if (currentTasks != null && currentTasks.Count > 0)
{
var firstTask = currentTasks.First();
var taskMode = currentTasks.First().TaskMode;
#region Continue
if (module.CurrentMode == TaskModeEnum.)
{
//进入对应模式
switch (taskMode)
{
case (TaskModeEnum.):
module.GoInInstoreMode(TcpCleint);
break;
case (TaskModeEnum.):
module.GoInOutstoreMode(TcpCleint);
break;
case (TaskModeEnum.):
module.GoInStocktakingMode(TcpCleint);
break;
default:
break;
}
//等待10ms这边将状态成功更新了来
await Task.Delay(10);
}
//不存在入库、出库、盘点等任务
else
{
module.SetCurrentMode(Mode.);
taskMode = module.CurrentMode;
}
#endregion
//只显示当前模式的任务
currentTasks = currentTasks.Where(t => t.TaskMode == taskMode).ToList();
//这个分支应该很少跑到 有刷新必然有新任务
if (currentTasks == null || currentTasks.Count == 0)
{
Logs.Write($"【后台发送线程】{module.ModuleCode}当前模式{module.CurrentMode},需要刷新!但是没有对应的新任务!");
var tasks = DbHelp.db.Queryable<CurrentTask>()
.Where(t => t.ModuleId == module.ModuleId)
.Where(t => t.IsSended == true)
.Where(t => t.TaskMode == taskMode)
.OrderBy(t => t.CreateTime)
.ToList();
if (tasks != null && tasks.Count > 0)
{
Logs.Write($"【后台发送线程】{module.ModuleCode}当前模式{module.CurrentMode},需要刷新!但是没有对应的新任务!有已发送的任务未完成故不处理!");
module.IsNeedRefresh = false;
continue;
}
//退出对应模式到待机模式! 后续持续刷新数据!
else
{
Logs.Write($"【后台发送线程】{module.ModuleCode}当前模式{module.CurrentMode},需要刷新!但是没有对应的新任务!没有已发送未完成的任务!退出当前模式!");
// 退出对应模式
switch (taskMode)
{
case (TaskModeEnum.):
module.GoOutInstoreMode(TcpCleint);
break;
case (TaskModeEnum.):
module.GoOutOutstoreMode(TcpCleint);
break;
case (TaskModeEnum.):
module.GoOutStocktakingMode(TcpCleint);
break;
default:
break;
}
continue;
}
}
//按照任务顺序给其发送数据
foreach (var currentTask in currentTasks)
{
module.SendTaskId(currentTask.TaskID, TcpCleint);
module.SendMatCode(currentTask.MatCode, TcpCleint);
module.SendMatName(currentTask.MatName, TcpCleint);
module.SendMatSpec(currentTask.MatSpec, TcpCleint);
module.SendMatBatch(currentTask.MatBatch, TcpCleint);
module.SendMatQty(currentTask.Qty, TcpCleint);
currentTask.IsSended = true;
DbHelp.db.Updateable(currentTask).ExecuteCommand();
}
//发送完毕后就不刷新了
module.IsNeedRefresh = false;
continue;
}
//不存在入库、出库、盘点等任务 应该变成待机
else
{
//退出对应模式到待机模式! 后续持续刷新数据!
if (module.CurrentMode != TaskModeEnum.)
{
// 退出对应模式
switch (module.CurrentMode)
{
case (TaskModeEnum.):
module.GoOutInstoreMode(TcpCleint);
break;
case (TaskModeEnum.):
module.GoOutOutstoreMode(TcpCleint);
break;
case (TaskModeEnum.):
module.GoOutStocktakingMode(TcpCleint);
break;
default:
break;
}
continue;
}
//向上层系统获取数据
@ -96,7 +201,6 @@ namespace WCS.BLL.HardWare
//获取成功 无数据
module.StandbyNoInfoDisplay(TcpCleint);
module.IsNeedRefresh = false;//未获取到库存数据 回没有库位显示信息给硬件
//获取失败 跳过此次循环后继续获取
}
}
@ -115,7 +219,7 @@ namespace WCS.BLL.HardWare
public string ShelfCode { get; set; }
public int RowCounts { get; set; }
public int ColumnCounts { get; set; }
public Mode CurrentMode { get; set; }
public TaskModeEnum CurrentMode { get; set; }
public DateTime SetCurrentModeTime { get; set; }
public string ModulesStr { get; set; }//当前货架所有模组的Str
public string GroupName { get; set; }
@ -128,15 +232,15 @@ namespace WCS.BLL.HardWare
public WarningLight WarningLight { get; set; }
public void ClearWarning()
{
if (this.CurrentMode == Mode.)
if (this.CurrentMode == TaskModeEnum.)
{
WarningLight.BlueLight(TcpCleint);
}
else if (this.CurrentMode == Mode.)
else if (this.CurrentMode == TaskModeEnum.)
{
WarningLight.GreenLight(TcpCleint);
}
else if (this.CurrentMode == Mode.)
else if (this.CurrentMode == TaskModeEnum.)
{
WarningLight.GreenLight(TcpCleint);
}
@ -215,7 +319,7 @@ namespace WCS.BLL.HardWare
}
#endregion
public void SetCurrentMode(Mode mode)
public void SetCurrentMode(TaskModeEnum mode)
{
this.CurrentMode = mode;
this.SetCurrentModeTime = DateTime.Now;
@ -275,17 +379,38 @@ namespace WCS.BLL.HardWare
if (data[TcpCleint.PreFixLength + 3] == 0x02)
GoBackStandbyModeReturnProcess(data, boardId);
break;
case 0xA1://标签返回入库成功信号
case 0xA1:
//标签返回入库成功信号
if (data[TcpCleint.PreFixLength + 3] == 0x05)
InStoreSuccessProcess(data, boardId);
//进入入库模式成功
else if (data[TcpCleint.PreFixLength + 3] == 0x01)
GoInInStoreReturnProcess(data, boardId);
//退出入库模式
else if (data[TcpCleint.PreFixLength + 3] == 0x03)
GoBackStandbyModeReturnProcess(data, boardId);
break;
case 0xA2://标签返回出库成功信号
case 0xA2:
//标签返回出库成功信号
if (data[TcpCleint.PreFixLength + 3] == 0x04)
OutStoreSuccessProcess(data, boardId);
//进入出库模式成功
else if (data[TcpCleint.PreFixLength + 3] == 0x01)
GoInOutStoreReturnProcess(data, boardId);
//退出出库模式
else if (data[TcpCleint.PreFixLength + 3] == 0x03)
GoBackStandbyModeReturnProcess(data, boardId);
break;
case 0xA3://标签返回盘点成功信号
case 0xA3:
//标签返回盘点成功信号
if (data[TcpCleint.PreFixLength + 3] == 0x03)
StocktakingSuccessProcess(data, boardId);
//进入盘点模式
else if (data[TcpCleint.PreFixLength + 3] == 0x01)
GoInStocktakingReturnProcess(data, boardId);
//退出盘点模式
else if (data[TcpCleint.PreFixLength + 3] == 0x02)
GoBackStandbyModeReturnProcess(data, boardId);
break;
default:
;
@ -311,8 +436,64 @@ namespace WCS.BLL.HardWare
Logs.Write($"【回到待机模式】货架【{ShelfCode}】通过板子ID【{boardId}】未找到对应模组!");
}
SetCurrentMode(Mode.);
SetCurrentMode(TaskModeEnum.);
}
/// <summary>
/// 标签返回进入入库模式信号
/// </summary>
/// <param name="data"></param>
public void GoInInStoreReturnProcess(byte[] data, int boardId)
{
//获取对应的模组
var module = MXL4Modules.Where(t => t.BoardId == boardId)
.FirstOrDefault();
if (module != null)
{
module.SetCurrentMode(TaskModeEnum.);
}
else
{
Logs.Write($"【进入入库模式成功】货架【{ShelfCode}】通过板子ID【{boardId}】未找到对应模组!");
}
}
/// <summary>
/// 标签返回进入出库模式信号
/// </summary>
/// <param name="data"></param>
public void GoInOutStoreReturnProcess(byte[] data, int boardId)
{
//获取对应的模组
var module = MXL4Modules.Where(t => t.BoardId == boardId)
.FirstOrDefault();
if (module != null)
{
module.SetCurrentMode(TaskModeEnum.);
}
else
{
Logs.Write($"【进入出库模式成功】货架【{ShelfCode}】通过板子ID【{boardId}】未找到对应模组!");
}
}
/// <summary>
/// 标签返回进入盘点模式信号
/// </summary>
/// <param name="data"></param>
public void GoInStocktakingReturnProcess(byte[] data, int boardId)
{
//获取对应的模组
var module = MXL4Modules.Where(t => t.BoardId == boardId)
.FirstOrDefault();
if (module != null)
{
module.SetCurrentMode(TaskModeEnum.);
}
else
{
Logs.Write($"【进入盘点模式成功】货架【{ShelfCode}】通过板子ID【{boardId}】未找到对应模组!");
}
}
/// <summary>
/// 标签返回入库成功信号

View File

@ -6,6 +6,7 @@ using System.Text;
using System.Threading.Tasks;
using TouchSocket.Core;
using WCS.BLL.Config;
using WCS.BLL.DbModels.Task;
using WCS.DAL.Db;
using WCS.DAL.DbModels;
@ -50,38 +51,47 @@ namespace WCS.BLL.HardWare
/// </summary>
public byte[] SendMatQtyData = { 0xA9, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 };
/// <summary>
/// 进入入库模式
/// </summary>
public byte[] GoInInstoreModeData = { 0xA1, 0x01, 0x02, 0x01, 0x00, 0x00, 0x00, 0x00 };
/// <summary>
/// 退出入库模式
/// </summary>
public byte[] GoOutInstoreModeData = { 0xA1, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 };
/// <summary>
/// 进入出库模式
/// </summary>
public byte[] GoInOutstoreModeData = { 0xA2, 0x01, 0x02, 0x01, 0x00, 0x00, 0x00, 0x00 };
/// <summary>
/// 退出出库模式
/// </summary>
public byte[] GoOutOutstoreModeData = { 0xA2, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 };
/// <summary>
/// 进入盘点模式
/// </summary>
public byte[] GoInStocktakingModeData = { 0xA3, 0x01, 0x02, 0x01, 0x00, 0x00, 0x00, 0x00 };
/// <summary>
/// 进入盘点模式
/// </summary>
public byte[] GoOutStocktakingModeData = { 0xA3, 0x02, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 };
/// <summary>
/// 待机模式 无库存显示信息
/// </summary>
public byte[] StandbyNoInfoDisplayData = { 0xA4, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 };
#endregion
public int ModuleId { get; set; }
public string ModuleCode { get; set; }
public int BoardId { get; set; }
public bool IsEnable { get; set; }
public Mode CurrentMode { get; set; }
public TaskModeEnum CurrentMode { get; set; }
public bool IsNeedRefresh { get; set; } = true;
/// <summary>
/// 是否已发送自检命令
/// </summary>
public bool IsSelfCheck { get; set; } = false;
public List<string> CurrentOutSns { get; set; }
public List<string> CurrentStockTakingSns { get; set; }
public void SetCurrentMode(Mode currentMode)
public void SetCurrentMode(TaskModeEnum currentMode)
{
CurrentMode = currentMode;
}
@ -102,6 +112,25 @@ namespace WCS.BLL.HardWare
tcpClient.SendThenReturn(tcpClient.GenerateMessage(BoardId, StandbyNoInfoDisplayData));
}
/// <summary>
/// 进入入库模式
/// </summary>
/// <param name="tcpClient"></param>
public void GoInInstoreMode(TCPClient tcpClient)
{
tcpClient.SendThenReturn(tcpClient.GenerateMessage(BoardId, GoInInstoreModeData));
//SetCurrentMode(TaskModeEnum.入库模式);
}
/// <summary>
/// 退出入库模式
/// </summary>
/// <param name="tcpClient"></param>
public void GoOutInstoreMode(TCPClient tcpClient)
{
tcpClient.SendThenReturn(tcpClient.GenerateMessage(BoardId, GoOutInstoreModeData));
//SetCurrentMode(TaskModeEnum.入库模式);
}
/// <summary>
/// 进入出库模式
/// </summary>
@ -109,6 +138,35 @@ namespace WCS.BLL.HardWare
public void GoInOutstoreMode(TCPClient tcpClient)
{
tcpClient.SendThenReturn(tcpClient.GenerateMessage(BoardId, GoInOutstoreModeData));
//SetCurrentMode(TaskModeEnum.出库模式);
}
/// <summary>
/// 退出出库模式
/// </summary>
/// <param name="tcpClient"></param>
public void GoOutOutstoreMode(TCPClient tcpClient)
{
tcpClient.SendThenReturn(tcpClient.GenerateMessage(BoardId, GoOutInstoreModeData));
//SetCurrentMode(TaskModeEnum.出库模式);
}
/// <summary>
/// 进入盘点模式
/// </summary>
/// <param name="tcpClient"></param>
public void GoInStocktakingMode(TCPClient tcpClient)
{
tcpClient.SendThenReturn(tcpClient.GenerateMessage(BoardId, GoInStocktakingModeData));
//SetCurrentMode(TaskModeEnum.盘点模式);
}
/// <summary>
/// 退出盘点模式
/// </summary>
/// <param name="tcpClient"></param>
public void GoOutStocktakingMode(TCPClient tcpClient)
{
tcpClient.SendThenReturn(tcpClient.GenerateMessage(BoardId, GoOutStocktakingModeData));
//SetCurrentMode(TaskModeEnum.盘点模式);
}
//发送任务ID
@ -116,7 +174,6 @@ namespace WCS.BLL.HardWare
{
var taskIDData = Convert.ToByte(taskID);
SendTaskIdData[1] = taskIDData;
tcpClient.SendThenReturn(tcpClient.GenerateMessage(BoardId, SendTaskIdData));
}
//发送料号

View File

@ -4,6 +4,7 @@ using System.Linq;
using System.Text;
using System.Threading.Tasks;
using WCS.BLL.DbModels;
using WCS.BLL.DbModels.Task;
using WCS.BLL.Manager;
using WCS.DAL.Db;
using WCS.DAL.DbModels;
@ -20,7 +21,7 @@ namespace WCS.BLL.HardWare
ShelfCode = shelfInfo.ShelfCode;
RowCounts = shelfInfo.Rowcounts;
ColumnCounts = shelfInfo.Columncounts;
SetCurrentMode(Mode.);
SetCurrentMode(TaskModeEnum.);
ClientIp = shelfInfo.ClientIp;
LightId = shelfInfo.LightId;
@ -31,7 +32,7 @@ namespace WCS.BLL.HardWare
public string ShelfCode { get; set; }
public int RowCounts { get; set; }
public int ColumnCounts { get; set; }
public Mode CurrentMode { get; set; }
public TaskModeEnum CurrentMode { get; set; }
public string ModulesStr { get; set; }
public string GroupName { get; set; }
public MatInfoResponse InStoreData { get; set; }
@ -100,7 +101,7 @@ namespace WCS.BLL.HardWare
return;
}
public void SetCurrentMode(Mode mode)
public void SetCurrentMode(TaskModeEnum mode)
{
}

View File

@ -1,6 +1,7 @@
using System;
using WCS.BLL.Config;
using WCS.BLL.DbModels;
using WCS.BLL.DbModels.Task;
using WCS.BLL.Manager;
using WCS.DAL.Db;
using WCS.DAL.DbModels;
@ -23,7 +24,7 @@ namespace WCS.BLL.HardWare
ShelfCode = shelfInfo.ShelfCode;
RowCounts = shelfInfo.Rowcounts;
ColumnCounts = shelfInfo.Columncounts;
SetCurrentMode(Mode.);
SetCurrentMode(TaskModeEnum.);
ClientIp = shelfInfo.ClientIp;
LightId = shelfInfo.LightId;
WarningLight = new WarningLight() { LightId = shelfInfo.LightId };
@ -55,7 +56,7 @@ namespace WCS.BLL.HardWare
public string ShelfCode { get; set; }
public int RowCounts { get; set; }
public int ColumnCounts { get; set; }
public Mode CurrentMode { get; set; }
public TaskModeEnum CurrentMode { get; set; }
public DateTime SetCurrentModeTime { get; set; }
public string ModulesStr { get; set; }//当前货架所有模组的Str
@ -70,15 +71,15 @@ namespace WCS.BLL.HardWare
public WarningLight WarningLight { get; set; }
public void ClearWarning()
{
if (this.CurrentMode == Mode.)
if (this.CurrentMode == TaskModeEnum.)
{
WarningLight.BlueLight(TcpCleint);
}
else if (this.CurrentMode == Mode.)
else if (this.CurrentMode == TaskModeEnum.)
{
WarningLight.GreenLight(TcpCleint);
}
else if (this.CurrentMode == Mode.)
else if (this.CurrentMode == TaskModeEnum.)
{
WarningLight.GreenLight(TcpCleint);
}
@ -123,20 +124,20 @@ namespace WCS.BLL.HardWare
try
{
Logs.Write($"[GoInInstore IPAddress]{IPAddress}", LogsType.Instore);
if (this.CurrentMode == Mode.)
if (this.CurrentMode == TaskModeEnum.)
{
CurrentCom = IPAddress;
return;
}
//判断当前模式是否为待机模式
else if (this.CurrentMode != Mode.)
else if (this.CurrentMode != TaskModeEnum.)
{
return;
}
else
{
//this.CurrentMode = Mode.入库模式;
SetCurrentMode(Mode.);
//this.CurrentMode = TaskModeEnum.入库模式;
SetCurrentMode(TaskModeEnum.);
}
//清空错误
ExceptionMessages.Clear();
@ -161,7 +162,7 @@ namespace WCS.BLL.HardWare
timeSpan = DateTime.Now - beginTime;
//所有板子成功进入入库模式 表示进入入库模式成功,跳出循环
var isExistsNotInstore = Modules.Where(t => t.CurrentMode != Mode.)
var isExistsNotInstore = Modules.Where(t => t.CurrentMode != TaskModeEnum.)
.Where(t => t.IsEnable)
.Any();
if (!isExistsNotInstore)
@ -184,7 +185,7 @@ namespace WCS.BLL.HardWare
}
//循环结束后判断当前板子状态
var notInstoreList = Modules.Where(t => t.CurrentMode != Mode.)
var notInstoreList = Modules.Where(t => t.CurrentMode != TaskModeEnum.)
.Where(t => t.IsEnable).ToList();
if (notInstoreList.Count > 0)
@ -235,14 +236,14 @@ namespace WCS.BLL.HardWare
public void GoOutInstore()
{
//当前货架是否为入库模式
if (CurrentMode != Mode.)
if (CurrentMode != TaskModeEnum.)
{
return;
}
else
{
//this.CurrentMode = Mode.待机模式;
SetCurrentMode(Mode.);
//this.CurrentMode = TaskModeEnum.待机模式;
SetCurrentMode(TaskModeEnum.);
}
//清空错误
@ -251,7 +252,7 @@ namespace WCS.BLL.HardWare
foreach (var module in Modules.Where(t => t.IsEnable)
.ToList())
{
if (module.CurrentMode == Mode.)
if (module.CurrentMode == TaskModeEnum.)
module.GoOutInstoreMode(TcpCleint);
}
@ -262,7 +263,7 @@ namespace WCS.BLL.HardWare
{
timeSpan = DateTime.Now - beginTime;
//所有板子是否成功退出入库模式
var isExistsInstore = Modules.Where(t => t.CurrentMode != Mode.)
var isExistsInstore = Modules.Where(t => t.CurrentMode != TaskModeEnum.)
.Where(t => t.IsEnable)
.Any();
if (!isExistsInstore)
@ -274,13 +275,13 @@ namespace WCS.BLL.HardWare
}
//循环结束后判断当前板子状态
var list = Modules.Where(t => t.CurrentMode != Mode.)
var list = Modules.Where(t => t.CurrentMode != TaskModeEnum.)
.Where(t => t.IsEnable)
.ToList();
if (list.Count > 0)
{
//CurrentMode = Mode.待机模式;
SetCurrentMode(Mode.);
//CurrentMode = TaskModeEnum.待机模式;
SetCurrentMode(TaskModeEnum.);
foreach (var item in list)
{
ExceptionMessages.Add($"模组{item.ModuleCode}未成功退出入库模式!");
@ -372,7 +373,7 @@ namespace WCS.BLL.HardWare
//查一下是否是当前发料单最后一个货架(在出库模式 同一个发料单下)
var isLastShelf = ShelfManager.Shelves
.Where(t => t.OrderNumber == OrderNumber)
.Where(t => t.CurrentMode == Mode.)
.Where(t => t.CurrentMode == TaskModeEnum.)
.Any();
if (!isLastShelf)
{
@ -421,7 +422,7 @@ namespace WCS.BLL.HardWare
.ToList();
var shelfs = ShelfManager.Shelves.Where(t => shelfIds.Contains(t.ShelfId)).ToList();
var otherModeShelfs = shelfs.Where(t => t.CurrentMode != HardWare.Mode.).ToList();
var otherModeShelfs = shelfs.Where(t => t.CurrentMode != TaskModeEnum.).ToList();
if (otherModeShelfs != null && otherModeShelfs.Count > 0)
{
otherModeShelfs.ForEach(t =>
@ -454,7 +455,7 @@ namespace WCS.BLL.HardWare
Task.Run(() =>
{
//判断是否是当前订单最后一个出库货架
var isOuting = ShelfManager.Shelves.Where(t => t.CurrentMode == Mode. && t.OrderNumber == OrderNumber)
var isOuting = ShelfManager.Shelves.Where(t => t.CurrentMode == TaskModeEnum. && t.OrderNumber == OrderNumber)
.Any();
//WebSocket通知前台以更新左侧出库单列表的状态
if (!isOuting)
@ -483,7 +484,7 @@ namespace WCS.BLL.HardWare
Logs.Write($"发料单{OrderNumber},非最后一个出库货架!", LogsType.Outstore);
var otherShelfs = ShelfManager.Shelves
.Where(t => t.OrderNumber == OrderNumber)
.Where(t => t.CurrentMode == Mode.)
.Where(t => t.CurrentMode == TaskModeEnum.)
.ToList();
otherShelfs.ForEach(shelf =>
@ -516,7 +517,7 @@ namespace WCS.BLL.HardWare
Task.Run(() =>
{
//判断是否是当前订单最后一个出库货架
var isOuting = ShelfManager.Shelves.Where(t => t.CurrentMode == Mode. && t.OrderNumber == OrderNumber)
var isOuting = ShelfManager.Shelves.Where(t => t.CurrentMode == TaskModeEnum. && t.OrderNumber == OrderNumber)
.Any();
//WebSocket通知前台以更新左侧出库单列表的状态
if (!isOuting)
@ -560,14 +561,14 @@ namespace WCS.BLL.HardWare
try
{
//第一步:设置货架当前模式
if (CurrentMode != Mode.)
if (CurrentMode != TaskModeEnum.)
{
Modules.ForEach(t => { t.Reset(TcpCleint); });
//复位需要点时间间隔才能响应指令
Thread.Sleep(1500);
}
//CurrentMode = Mode.出库模式;
SetCurrentMode(Mode.);
//CurrentMode = TaskModeEnum.出库模式;
SetCurrentMode(TaskModeEnum.);
//设置当前操作人
OutOperateUser = OperateUser;
@ -609,7 +610,7 @@ namespace WCS.BLL.HardWare
timeSpan = DateTime.Now - beginTime;
//所有板子成功进入出库模式 表示进入出库模式成功,跳出循环
var isExistsNotInstore = outModules.Where(t => t.CurrentMode != Mode.)
var isExistsNotInstore = outModules.Where(t => t.CurrentMode != TaskModeEnum.)
.Where(t => t.IsEnable)
.Any();
if (!isExistsNotInstore)
@ -619,7 +620,7 @@ namespace WCS.BLL.HardWare
//循环延时处理
Thread.Sleep(50);
}
var list = outModules.Where(t => t.IsEnable && t.CurrentMode != Mode.).ToList();
var list = outModules.Where(t => t.IsEnable && t.CurrentMode != TaskModeEnum.).ToList();
if (list != null && list.Count > 0)
{
var messages = list.Select(t => $"模组{t.ModuleCode}未进入出库模式!").ToList();
@ -653,7 +654,7 @@ namespace WCS.BLL.HardWare
{
Logs.Write($"货架【{ShelfCode}】,开始退出出库", LogsType.Outstore);
//找到在出库中的模组
var outingModules = Modules.Where(t => t.CurrentMode == Mode.)
var outingModules = Modules.Where(t => t.CurrentMode == TaskModeEnum.)
.ToList();
foreach (var module in outingModules)
{
@ -668,7 +669,7 @@ namespace WCS.BLL.HardWare
timeSpan = DateTime.Now - beginTime;
//所有板子成功退出出库模式 表示退出出库模式成功,跳出循环
var isExistsOutstore = outingModules.Where(t => t.CurrentMode == Mode.)
var isExistsOutstore = outingModules.Where(t => t.CurrentMode == TaskModeEnum.)
.Where(t => t.IsEnable)
.Any();
if (!isExistsOutstore)
@ -678,7 +679,7 @@ namespace WCS.BLL.HardWare
//循环延时处理
Thread.Sleep(50);
}
var list = outingModules.Where(t => t.IsEnable && t.CurrentMode == Mode.).ToList();
var list = outingModules.Where(t => t.IsEnable && t.CurrentMode == TaskModeEnum.).ToList();
if (list != null && list.Count > 0)
{
var messages = list.Select(t => $"模组{t.ModuleCode}未退出出库模式!").ToList();
@ -700,13 +701,13 @@ namespace WCS.BLL.HardWare
CurrentOutStoreMatSNs.Clear();
WarningLight.CloseLight(TcpCleint);
SetCurrentMode(Mode.);
SetCurrentMode(TaskModeEnum.);
Logs.Write($"货架【{ShelfCode}】,结束退出出库", LogsType.Outstore);
//Task.Run(() =>
//{
// //判断是否是当前订单最后一个出库货架
// var isOuting = ShelfManager.Shelves.Where(t => t.CurrentMode == Mode.出库模式 && t.OrderNumber == OrderNumber)
// var isOuting = ShelfManager.Shelves.Where(t => t.CurrentMode == TaskModeEnum.出库模式 && t.OrderNumber == OrderNumber)
// .Any();
// //WebSocket通知前台以更新左侧出库单列表的状态
// if (!isOuting)
@ -734,19 +735,19 @@ namespace WCS.BLL.HardWare
try
{
//第一步:设置货架当前模式
if (CurrentMode != Mode.)
if (CurrentMode != TaskModeEnum.)
{
Modules.ForEach(t =>
{
if (CurrentMode != Mode.)
if (CurrentMode != TaskModeEnum.)
t.Reset(TcpCleint);
});
//复位需要点时间间隔才能响应指令
Thread.Sleep(1500);
}
//CurrentMode = Mode.盘点模式;
SetCurrentMode(Mode.);
//CurrentMode = TaskModeEnum.盘点模式;
SetCurrentMode(TaskModeEnum.);
//第二步:货架添加 盘点单号 记录当前盘点的发料单
CurrentStockTakingOrder = stockTakingOrder;
@ -787,7 +788,7 @@ namespace WCS.BLL.HardWare
timeSpan = DateTime.Now - beginTime;
//所有板子成功进入盘点模式 表示进入盘点模式成功,跳出循环
var isExistsNotInstore = outModules.Where(t => t.CurrentMode != Mode.)
var isExistsNotInstore = outModules.Where(t => t.CurrentMode != TaskModeEnum.)
.Where(t => t.IsEnable)
.Any();
if (!isExistsNotInstore)
@ -797,7 +798,7 @@ namespace WCS.BLL.HardWare
//循环延时处理
Thread.Sleep(50);
}
var list = outModules.Where(t => t.IsEnable && t.CurrentMode != Mode.).ToList();
var list = outModules.Where(t => t.IsEnable && t.CurrentMode != TaskModeEnum.).ToList();
if (list != null && list.Count > 0)
{
var messages = list.Select(t => $"模组{t.ModuleCode}未进入盘点模式!").ToList();
@ -847,7 +848,7 @@ namespace WCS.BLL.HardWare
public void GoOutStocktaking()
{
//找到在盘点中的模组
var stockTakingModules = Modules.Where(t => t.CurrentMode == Mode.)
var stockTakingModules = Modules.Where(t => t.CurrentMode == TaskModeEnum.)
.ToList();
foreach (var module in stockTakingModules)
{
@ -864,7 +865,7 @@ namespace WCS.BLL.HardWare
timeSpan = DateTime.Now - beginTime;
//所有板子成功退出盘点模式 表示退出盘点模式成功,跳出循环
var isExistsNotInstore = stockTakingModules.Where(t => t.CurrentMode == Mode.)
var isExistsNotInstore = stockTakingModules.Where(t => t.CurrentMode == TaskModeEnum.)
.Where(t => t.IsEnable)
.Any();
if (!isExistsNotInstore)
@ -874,7 +875,7 @@ namespace WCS.BLL.HardWare
//循环延时处理
Thread.Sleep(50);
}
var list = stockTakingModules.Where(t => t.IsEnable && t.CurrentMode == Mode.).ToList();
var list = stockTakingModules.Where(t => t.IsEnable && t.CurrentMode == TaskModeEnum.).ToList();
if (list != null && list.Count > 0)
{
var messages = list.Select(t => $"模组{t.ModuleCode}未退出盘点模式!").ToList();
@ -896,8 +897,8 @@ namespace WCS.BLL.HardWare
});
CurrentOutStoreMatSNs.Clear();
WarningLight.CloseLight(TcpCleint);
//this.CurrentMode = Mode.待机模式;
SetCurrentMode(Mode.);
//this.CurrentMode = TaskModeEnum.待机模式;
SetCurrentMode(TaskModeEnum.);
}
public void Reset()
@ -911,8 +912,8 @@ namespace WCS.BLL.HardWare
});
}
WarningLight.CloseLight(TcpCleint);
//this.CurrentMode = Mode.待机模式;
SetCurrentMode(Mode.);
//this.CurrentMode = TaskModeEnum.待机模式;
SetCurrentMode(TaskModeEnum.);
}
public void QueryVoltage(int moduleId)
@ -933,7 +934,7 @@ namespace WCS.BLL.HardWare
}
}
public void SetCurrentMode(Mode mode)
public void SetCurrentMode(TaskModeEnum mode)
{
this.CurrentMode = mode;
this.SetCurrentModeTime = DateTime.Now;
@ -958,7 +959,7 @@ namespace WCS.BLL.HardWare
{
try
{
if (CurrentMode == Mode.)
if (CurrentMode == TaskModeEnum.)
OrderNumber = "自检中...";
foreach (var module in Modules.Where(t => t.IsEnable).ToList())
{
@ -1021,7 +1022,7 @@ namespace WCS.BLL.HardWare
}
finally
{
if (CurrentMode == Mode.)
if (CurrentMode == TaskModeEnum.)
OrderNumber = string.Empty;
}
}
@ -1134,7 +1135,7 @@ namespace WCS.BLL.HardWare
}
else
{
module.CurrentMode = Mode.;
module.CurrentMode = TaskModeEnum.;
}
}
//库存物料与实际情况不匹配
@ -1147,7 +1148,7 @@ namespace WCS.BLL.HardWare
}
else
{
module.CurrentMode = Mode.;
module.CurrentMode = TaskModeEnum.;
}
//获取当前板所有库位
var storeInfos = DbHelp.db.Queryable<StoreInfo>()
@ -1262,14 +1263,14 @@ namespace WCS.BLL.HardWare
/// <param name="data"></param>
public void GoOutInstoreProcess(byte[] data, int boardId, int lightNumber)
{
var module = this.Modules.Where(t => t.BoardId == boardId && t.CurrentMode == Mode.).FirstOrDefault();
var module = this.Modules.Where(t => t.BoardId == boardId && t.CurrentMode == TaskModeEnum.).FirstOrDefault();
if (module == null)
{
return;
}
else
{
module.CurrentMode = Mode.;
module.CurrentMode = TaskModeEnum.;
}
}
@ -1555,7 +1556,7 @@ namespace WCS.BLL.HardWare
}
else
{
module.CurrentMode = Mode.;
module.CurrentMode = TaskModeEnum.;
}
}
//库存物料与实际情况不匹配
@ -1569,7 +1570,7 @@ namespace WCS.BLL.HardWare
}
else
{
module.CurrentMode = Mode.;
module.CurrentMode = TaskModeEnum.;
}
//获取当前板所有库位
var storeInfos = DbHelp.db.Queryable<StoreInfo>()
@ -1675,7 +1676,7 @@ namespace WCS.BLL.HardWare
public void OutstoreReturnProcess(byte[] data, int boardId, int lightNumber)
{
if (CurrentMode != Mode.)
if (CurrentMode != TaskModeEnum.)
{
Logs.Write($"出库错误:{ShelfCode}该货架模式不是出库模式或盘点模式!", LogsType.Outstore);
return;
@ -1807,7 +1808,7 @@ namespace WCS.BLL.HardWare
//更新时间 避免超时被自动退出
Task.Run(() =>
{
var shelves = ShelfManager.Shelves.Where(t => t.CurrentMode == Mode. && t.OrderNumber == OrderNumber).ToList();
var shelves = ShelfManager.Shelves.Where(t => t.CurrentMode == TaskModeEnum. && t.OrderNumber == OrderNumber).ToList();
foreach (var shelf in shelves)
{
shelf.SetCurrentModeTime = DateTime.Now;
@ -1862,7 +1863,7 @@ namespace WCS.BLL.HardWare
//查一下是否是当前发料单最后一个货架(在出库模式 同一个发料单下)
var isLastShelf = ShelfManager.Shelves
.Where(t => t.OrderNumber == OrderNumber)
.Where(t => t.CurrentMode == Mode.)
.Where(t => t.CurrentMode == TaskModeEnum.)
.Any();
if (!isLastShelf)
{
@ -1911,7 +1912,7 @@ namespace WCS.BLL.HardWare
.ToList();
var shelfs = ShelfManager.Shelves.Where(t => shelfIds.Contains(t.ShelfId)).ToList();
var otherModeShelfs = shelfs.Where(t => t.CurrentMode != HardWare.Mode.).ToList();
var otherModeShelfs = shelfs.Where(t => t.CurrentMode != TaskModeEnum.).ToList();
if (otherModeShelfs != null && otherModeShelfs.Count > 0)
{
otherModeShelfs.ForEach(t =>
@ -1943,7 +1944,7 @@ namespace WCS.BLL.HardWare
Task.Run(() =>
{
//判断是否是当前订单最后一个出库货架
var isOuting = ShelfManager.Shelves.Where(t => t.CurrentMode == Mode. && t.OrderNumber == OrderNumber)
var isOuting = ShelfManager.Shelves.Where(t => t.CurrentMode == TaskModeEnum. && t.OrderNumber == OrderNumber)
.Any();
//WebSocket通知前台以更新左侧出库单列表的状态
if (!isOuting)
@ -1971,7 +1972,7 @@ namespace WCS.BLL.HardWare
Logs.Write($"发料单{OrderNumber},非最后一个出库货架!", LogsType.Outstore);
var otherShelfs = ShelfManager.Shelves
.Where(t => t.OrderNumber == OrderNumber)
.Where(t => t.CurrentMode == Mode.)
.Where(t => t.CurrentMode == TaskModeEnum.)
.ToList();
otherShelfs.ForEach(shelf =>
@ -2002,7 +2003,7 @@ namespace WCS.BLL.HardWare
Task.Run(() =>
{
//判断是否是当前订单最后一个出库货架
var isOuting = ShelfManager.Shelves.Where(t => t.CurrentMode == Mode. && t.OrderNumber == OrderNumber)
var isOuting = ShelfManager.Shelves.Where(t => t.CurrentMode == TaskModeEnum. && t.OrderNumber == OrderNumber)
.Any();
//WebSocket通知前台以更新左侧出库单列表的状态
if (!isOuting)
@ -2087,14 +2088,14 @@ namespace WCS.BLL.HardWare
/// <param name="data"></param>
public void GoOutOutstoreProcess(byte[] data, int boardId, int lightNumber)
{
var module = this.Modules.Where(t => t.BoardId == boardId && t.CurrentMode == Mode.).FirstOrDefault();
var module = this.Modules.Where(t => t.BoardId == boardId && t.CurrentMode == TaskModeEnum.).FirstOrDefault();
if (module == null)
{
return;
}
else
{
module.CurrentMode = Mode.;
module.CurrentMode = TaskModeEnum.;
}
}
@ -2215,20 +2216,20 @@ namespace WCS.BLL.HardWare
}
else
{
module.CurrentMode = Mode.;
module.CurrentMode = TaskModeEnum.;
}
}
public void GoOutStockTakingReturnProcess(byte[] data, int boardId, int lightNumber)
{
var module = this.Modules.Where(t => t.BoardId == boardId && t.CurrentMode == Mode.).FirstOrDefault();
var module = this.Modules.Where(t => t.BoardId == boardId && t.CurrentMode == TaskModeEnum.).FirstOrDefault();
if (module == null)
{
return;
}
else
{
module.CurrentMode = Mode.;
module.CurrentMode = TaskModeEnum.;
}
}
@ -2243,7 +2244,7 @@ namespace WCS.BLL.HardWare
}
else
{
module.CurrentMode = Mode.;
module.CurrentMode = TaskModeEnum.;
}
}

View File

@ -6,6 +6,7 @@ using System.Text;
using System.Threading.Tasks;
using TouchSocket.Core;
using WCS.BLL.Config;
using WCS.BLL.DbModels.Task;
using WCS.DAL.Db;
using WCS.DAL.DbModels;
@ -97,7 +98,7 @@ namespace WCS.BLL.HardWare
public string ModuleCode { get; set; }
public int BoardId { get; set; }
public bool IsEnable { get; set; }
public Mode CurrentMode { get; set; }
public TaskModeEnum CurrentMode { get; set; }
/// <summary>
/// 是否已发送自检命令
/// </summary>
@ -112,7 +113,7 @@ namespace WCS.BLL.HardWare
public void GoInInstoreMode(TCPClient tcpClient)
{
if (CurrentMode != Mode.)
if (CurrentMode != TaskModeEnum.)
{
//TO DO 退出对应的模式 然后再发送进入入库模式
}
@ -168,7 +169,7 @@ namespace WCS.BLL.HardWare
public void GoOutInstoreMode(TCPClient tcpClient)
{
if (CurrentMode == Mode.)
if (CurrentMode == TaskModeEnum.)
{
tcpClient.Send(tcpClient.GenerateMessage(BoardId, GoOutInstoreData));
}
@ -194,7 +195,7 @@ namespace WCS.BLL.HardWare
/// <param name="tcpClient"></param>
public void ShelfCheck(TCPClient tcpClient)
{
if (CurrentMode != Mode.)
if (CurrentMode != TaskModeEnum.)
{
return;
}

View File

@ -1,6 +1,7 @@
using SqlSugar;
using WCS.BLL.Config;
using WCS.BLL.DbModels;
using WCS.BLL.DbModels.Task;
using WCS.BLL.HardWare;
using WCS.BLL.Tool;
using WCS.DAL;
@ -128,7 +129,7 @@ namespace WCS.BLL.Manager
try
{
#region
var inStoreShelf = ShelfManager.Shelves.Where(t => t.CurrentMode == Mode.)
var inStoreShelf = ShelfManager.Shelves.Where(t => t.CurrentMode == TaskModeEnum.)
.Where(t => DateTime.Now - t.SetCurrentModeTime >= TimeSpan.FromMinutes(3))
.ToList();
foreach (var shelf in inStoreShelf)
@ -140,7 +141,7 @@ namespace WCS.BLL.Manager
#region
//出库超过n分钟自动进入待机模式
var outStoreShelf = ShelfManager.Shelves.Where(t => t.CurrentMode == Mode.)
var outStoreShelf = ShelfManager.Shelves.Where(t => t.CurrentMode == TaskModeEnum.)
.Where(t => DateTime.Now - t.SetCurrentModeTime >= TimeSpan.FromMinutes(5))
.ToList();
foreach (var shelf in outStoreShelf)
@ -151,7 +152,7 @@ namespace WCS.BLL.Manager
#endregion
#region
var stockTakingShelf = ShelfManager.Shelves.Where(t => t.CurrentMode == Mode.)
var stockTakingShelf = ShelfManager.Shelves.Where(t => t.CurrentMode == TaskModeEnum.)
.Where(t => DateTime.Now - t.SetCurrentModeTime >= TimeSpan.FromMinutes(5))
.ToList();
foreach (var shelf in stockTakingShelf)
@ -272,7 +273,7 @@ namespace WCS.BLL.Manager
try
{
//待机模式未关灯
var shelves = ShelfManager.Shelves.Where(t => t.CurrentMode == Mode. && t.LightColor != WarningLight.LightColorEnum.)
var shelves = ShelfManager.Shelves.Where(t => t.CurrentMode == TaskModeEnum. && t.LightColor != WarningLight.LightColorEnum.)
.Where(t => t.SetCurrentModeTime < DateTime.Now.AddSeconds(-5))
.ToList();
foreach (var shelf in shelves)
@ -296,7 +297,7 @@ namespace WCS.BLL.Manager
}
//出库模式未亮灯
var outShelves = ShelfManager.Shelves.Where(t => t.CurrentMode == Mode. && t.LightColor == WarningLight.LightColorEnum.)
var outShelves = ShelfManager.Shelves.Where(t => t.CurrentMode == TaskModeEnum. && t.LightColor == WarningLight.LightColorEnum.)
.Where(t => t.SetCurrentModeTime < DateTime.Now.AddSeconds(-5))
.ToList();
foreach (var shelf in outShelves)

View File

@ -7,6 +7,7 @@ using System.Text;
using System.Threading.Tasks;
using WCS.BLL.Config;
using WCS.BLL.DbModels;
using WCS.BLL.DbModels.Task;
using WCS.BLL.HardWare;
using WCS.DAL.Db;
using WCS.DAL.DbModels;
@ -363,15 +364,15 @@ namespace WCS.BLL.Manager
{
switch (smartShelf.CurrentMode)
{
case Mode.:
case TaskModeEnum.:
module.GoInInstoreMode(smartShelf.TcpCleint);
smartShelf.WarningLight.BlueLight(smartShelf.TcpCleint);
break;
case Mode.:
case TaskModeEnum.:
Logs.Write("smartShelf.GoInOutstoreByWebSocket", LogsType.WebSocket);
smartShelf.GoInOutstoreByWebSocket(module.ModuleId);
break;
case Mode.:
case TaskModeEnum.:
module.Reset(smartShelf.TcpCleint);
smartShelf.WarningLight.CloseLight(smartShelf.TcpCleint);
break;

View File

@ -5,6 +5,7 @@ using System.Runtime.InteropServices;
using System.Text.RegularExpressions;
using WCS.BLL.Config;
using WCS.BLL.DbModels;
using WCS.BLL.DbModels.Task;
using WCS.BLL.HardWare;
using WCS.BLL.Manager;
using WCS.BLL.Services.IService;
@ -16,6 +17,7 @@ using WCS.Model;
using WCS.Model.ApiModel.InOutRecord;
using WCS.Model.ApiModel.InStore;
using WCS.Model.ApiModel.MXBackgroundThread;
using static Dm.net.buffer.ByteArrayBuffer;
namespace WCS.BLL.Services.Service
{
@ -68,7 +70,7 @@ namespace WCS.BLL.Services.Service
//已找到模组对应货架
shelf.GoInInstore(request.IpAdress);
if (shelf.CurrentMode == Mode.)
if (shelf.CurrentMode == TaskModeEnum.)
//成功进入入库模式
return new ShelfGoInInstoreResponse()
{
@ -157,7 +159,7 @@ namespace WCS.BLL.Services.Service
};
}
//判断当前是否是入库模式
if (shelf.CurrentMode != Mode.)
if (shelf.CurrentMode != TaskModeEnum.)
{
return new ResponseCommon<MatInfo>()
{
@ -381,7 +383,7 @@ namespace WCS.BLL.Services.Service
}
//判断当前是否是入库模式
if (shelf.CurrentMode != Mode.)
if (shelf.CurrentMode != TaskModeEnum.)
{
return new ResponseCommon()
{

View File

@ -2,6 +2,7 @@
using SqlSugar;
using WCS.BLL.Config;
using WCS.BLL.DbModels;
using WCS.BLL.DbModels.Task;
using WCS.BLL.Manager;
using WCS.BLL.Services.IService;
using WCS.BLL.Tool;
@ -487,7 +488,7 @@ namespace WCS.BLL.Services.Service
//获取后台当前正在进行出库的订单 将出库状态反馈给前端
var outingOrderNumbers = ShelfManager.Shelves
.Where(t => t.CurrentMode == HardWare.Mode.)
.Where(t => t.CurrentMode == TaskModeEnum.)
.Select(t => t.OrderNumber)
.ToList();
foreach (var record in records)
@ -753,7 +754,7 @@ namespace WCS.BLL.Services.Service
.ToList();
var shelfs = ShelfManager.Shelves.Where(t => shelfIds.Contains(t.ShelfId)).ToList(); ;
var outherModeShelfs = shelfs.Where(t => t.CurrentMode != HardWare.Mode.).Select(t => t.ShelfCode).ToList();
var outherModeShelfs = shelfs.Where(t => t.CurrentMode != TaskModeEnum.).Select(t => t.ShelfCode).ToList();
if (outherModeShelfs != null && outherModeShelfs.Count > 0)
{
return new ResponseCommon()
@ -1200,7 +1201,7 @@ namespace WCS.BLL.Services.Service
//找到正在出对应出库单的货架
var shelves = ShelfManager.Shelves.Where(t => t.OrderNumber == request.OrderNumber)
.Where(t => t.CurrentMode == HardWare.Mode.)
.Where(t => t.CurrentMode == TaskModeEnum.)
.ToList();
if (shelves == null || shelves.Count == 0)

View File

@ -3,6 +3,7 @@ using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using WCS.BLL.DbModels.Task;
using WCS.BLL.Manager;
using WCS.BLL.Services.IService;
using WCS.DAL.Db;
@ -66,7 +67,7 @@ namespace WCS.BLL.Services.Service
foreach (var ip in cleintIps)
{
var currentIdShelfs = shelfs.Where(t => t.ClientIp == ip)
.Where(t => t.CurrentMode == HardWare.Mode.)
.Where(t => t.CurrentMode == TaskModeEnum.)
.ToList();
Task.Run(() =>
{

View File

@ -6,6 +6,7 @@ using System.Text;
using System.Threading.Tasks;
using WCS.BLL.Config;
using WCS.BLL.DbModels;
using WCS.BLL.DbModels.Task;
using WCS.BLL.Manager;
using WCS.BLL.Services.IService;
using WCS.DAL.Db;
@ -566,7 +567,7 @@ namespace WCS.BLL.Services.Service
.ToList();
var shelfs = ShelfManager.Shelves.Where(t => shelfIds.Contains(t.ShelfId)).ToList(); ;
var outherModeShelfs = shelfs.Where(t => t.CurrentMode != HardWare.Mode.).Select(t => t.ShelfCode).ToList();
var outherModeShelfs = shelfs.Where(t => t.CurrentMode != TaskModeEnum.).Select(t => t.ShelfCode).ToList();
if (outherModeShelfs != null && outherModeShelfs.Count > 0)
{
return new ResponseCommon()
@ -651,7 +652,7 @@ namespace WCS.BLL.Services.Service
#endregion
#region
var shelfs = ShelfManager.Shelves.Where(t => t.CurrentMode == HardWare.Mode. && t.OrderNumber == order.StocktakingOrderNumber).ToList();
var shelfs = ShelfManager.Shelves.Where(t => t.CurrentMode == TaskModeEnum. && t.OrderNumber == order.StocktakingOrderNumber).ToList();
shelfs.ForEach(t =>
{
t.GoOutStocktaking();
@ -704,7 +705,7 @@ namespace WCS.BLL.Services.Service
Message = $"货架{inventoryDetail.ShelfCode}不存在!",
};
}
else if (shelf.CurrentMode != HardWare.Mode.)
else if (shelf.CurrentMode != TaskModeEnum.)
{
return new ResponseCommon()
{
@ -787,7 +788,7 @@ namespace WCS.BLL.Services.Service
Message = $"货架{stockTakingMatDetail.StoreInfo.ShelfCode}不存在!",
};
}
else if (shelf.CurrentMode != HardWare.Mode.)
else if (shelf.CurrentMode != TaskModeEnum.)
{
DbHelp.db.RollbackTran();
return new ResponseCommon()
@ -826,7 +827,7 @@ namespace WCS.BLL.Services.Service
//更新时间 避免被自动退出
Task.Run(() =>
{
var shelves = ShelfManager.Shelves.Where(t => t.CurrentMode == HardWare.Mode. && t.OrderNumber == request.StocktakingOrderNumber)
var shelves = ShelfManager.Shelves.Where(t => t.CurrentMode == TaskModeEnum. && t.OrderNumber == request.StocktakingOrderNumber)
.ToList();
foreach (var shelf in shelves)
{

View File

@ -24,6 +24,7 @@ namespace WCS.BLL.DbModels.Task
{
= 0,
= 1,
= 2
= 2,
= 3
}
}

View File

@ -2,6 +2,7 @@
using NPOI.SS.Formula.Functions;
using SqlSugar;
using WCS.BLL.DbModels;
using WCS.BLL.DbModels.Task;
using WCS.BLL.HardWare;
using WCS.BLL.Manager;
using WCS.BLL.Services.IService;
@ -9,7 +10,6 @@ using WCS.BLL.Services.Service;
using WCS.DAL.Db;
using WCS.Model;
using WCS.Model.ApiModel.Home;
using Mode = WCS.BLL.HardWare.Mode;
namespace WCS.WebApi.Controllers
{
@ -212,12 +212,12 @@ namespace WCS.WebApi.Controllers
if (request.IsResetAll == false)
shelfs = ShelfManager.Shelves
.Where(t => request.SelfIds.Contains(t.ShelfId))
.Where(t => t.CurrentMode != Mode.)
.Where(t => t.CurrentMode != TaskModeEnum.)
.ToList();
else
shelfs = ShelfManager.Shelves
.Where(t => request.GroupNames.Contains(t.GroupName))
.Where(t => t.CurrentMode != Mode.)
.Where(t => t.CurrentMode != TaskModeEnum.)
.ToList();
foreach (var shelf in shelfs)
{