using Rhea.Common;
|
using SqlSugar;
|
using System;
|
using System.Collections.Generic;
|
using System.Linq;
|
using System.Text;
|
using System.Threading.Tasks;
|
using Tiger.IBusiness;
|
using Tiger.IBusiness.MES.WorkAction;
|
using Tiger.Model;
|
using Tiger.Model.Entitys.MES.Position;
|
|
namespace Tiger.Business.MES.WorkAction
|
{
|
public class PackingAction : IPackingAction
|
{
|
#region Propertys & Variables
|
#region 固定写法,工序中的必要信息
|
public bool IsFinished { get; set; } = false;
|
public IWorkStep CurStep { get; set; }
|
public IPosition CurPosition { get; set; }
|
public MES_WO_NODE_ACT NodeAct { get; set; }
|
public MES_WO_ACTION Setting { get; set; }
|
#endregion
|
public BAS_PKG_RULE PkgRule { get; set; }
|
public WipPkg CurPkg { get; set; }
|
public WipPkgItem CurPkgItem { get; set; }
|
public PackingActionOutput CurCmd { get; set; }
|
public int PrintTimes = 0;
|
public Dictionary<int, BAS_LABEL_TEMP> LabelDic { get; set; } = new();
|
public List<BAS_LABEL_PV> LabelPV { get; set; } = new();
|
public int FinishLevel = 0;
|
#endregion Propertys & Variables
|
|
#region Functions
|
/// <summary>
|
/// 初始化工序行为
|
/// </summary>
|
/// <returns></returns>
|
public void Init(IWorkStep curStep, IPosition position, MES_WO_NODE_ACT nodeAct, MES_WO_ACTION setting)
|
{
|
#region 固定写法,给默认变量赋值
|
CurStep = curStep;
|
CurPosition = position;
|
NodeAct = nodeAct;
|
Setting = setting;
|
#endregion
|
//手动结束包装专用,临时执行行为
|
if (setting.IsNullOrEmpty())
|
{
|
PkgRule = Biz.Db.Queryable<BAS_PKG_RULE>().Where(q => q.RULE_CODE == setting.PKG_CODE).IncludesAllFirstLayer().IncludesAllSecondLayer(q => q.Details).First();
|
}
|
//正常条码过站执行包装行为
|
else
|
{
|
PkgRule = Biz.Db.Queryable<BAS_PKG_RULE>().Where(q => q.RULE_CODE == setting.PKG_CODE).IncludesAllFirstLayer().IncludesAllSecondLayer(q => q.Details).First();
|
}
|
//根据行为设置获取多层包装的标签打印模板字典
|
var codes = (Setting.OPTION_1?? "").JsonToObject<List<WipPkgItem>>();
|
foreach (var code in codes)
|
{
|
var label = code.LABEL_CODE.IsNullOrEmpty() ? null : Biz.Db.Queryable<BAS_LABEL_TEMP>().Where(q => q.LABEL_CODE == code.LABEL_CODE).IncludesAllFirstLayer().First();
|
LabelDic.Add(code.PKG_LEVEL, label);
|
}
|
//如果工序上下文中没有包装记录则新建一个,有则获取当前的包装记录
|
if (CurPosition.Context.ContainsKey("CurPackage") && !CurPosition.Context["CurPackage"].IsNullOrEmpty())
|
{
|
CurPkg = (CurPosition.Context["CurPackage"] as WipPkg).Clone();
|
}
|
else
|
{
|
var max = PkgRule.Details.OrderByDescending(q => q.PKG_LEVEL).First();
|
CurPkg = new WipPkg()
|
{
|
RULE_CODE = PkgRule.RULE_CODE,
|
RULE_NAME = PkgRule.RULE_NAME,
|
Item = new WipPkgItem()
|
{
|
PKG_CODE = max.PKG_CODE,
|
PKG_NAME = max.PkgType.PKG_NAME,
|
IS_MIN_PKG = max.PkgType.IS_MIN_PKG,
|
PKG_LEVEL = max.PKG_LEVEL,
|
PKG_QTY = max.PKG_QTY,
|
LABEL_CODE = LabelDic[max.PKG_LEVEL]?.LABEL_CODE,
|
}
|
};
|
WipPkgItem child = null;
|
foreach (var dtl in PkgRule.Details.OrderBy(q => q.PKG_LEVEL))
|
{
|
if (1 < dtl.PKG_LEVEL && dtl.PKG_LEVEL < max.PKG_LEVEL)
|
{
|
var item = new WipPkgItem()
|
{
|
PKG_CODE = dtl.PKG_CODE,
|
PKG_NAME = dtl.PkgType.PKG_NAME,
|
IS_MIN_PKG = dtl.PkgType.IS_MIN_PKG,
|
PKG_LEVEL = dtl.PKG_LEVEL,
|
PKG_QTY = dtl.PKG_QTY,
|
LABEL_CODE = LabelDic[dtl.PKG_LEVEL]?.LABEL_CODE,
|
};
|
if (!child.IsNullOrEmpty())
|
{
|
item.Items.Add(child);
|
}
|
child = item;
|
}
|
}
|
if (!child.IsNullOrEmpty())
|
{
|
CurPkg.Item.Items.Add(child);
|
}
|
|
}
|
}
|
|
/// <summary>
|
/// 获取行为开始的提示信息
|
/// </summary>
|
/// <returns></returns>
|
public Locale GetBeginMsg()
|
{
|
var min = PkgRule.Details.OrderBy(q => q.PKG_LEVEL).First();
|
//行为设定的OPTION_1是第一层包装的标签模板代码,如果为空则不需要打印
|
if (LabelDic[min.PKG_LEVEL].IsNullOrEmpty())
|
{
|
var msg = new Locale("MES.WorkAction.PackingAction.BeginMsg", min.PKG_LEVEL, min.PkgType.PKG_NAME, CurPosition.CurSN);
|
//var msg = new Locale($"已扫描第{dtl.PKG_LEVEL}层包装[{dtl.PkgType.PKG_NAME}]的标签条码[{CurPosition.CurWipSN.SN}]");
|
return msg;
|
}
|
else
|
{
|
var msg = new Locale("MES.WorkAction.PackingAction.BeginPrint", min.PKG_LEVEL, min.PkgType.PKG_NAME, LabelDic[min.PKG_LEVEL]?.LABEL_CODE, LabelDic[min.PKG_LEVEL].LABEL_NAME);
|
//var msg = new Locale($"开始打印第{min.PKG_LEVEL}层包装[{min.PkgType.PKG_NAME}]的标签[{LabelDic[min.PKG_LEVEL]?.LABEL_CODE}: {LabelDic[min.PKG_LEVEL].LABEL_NAME}]");
|
return msg;
|
}
|
}
|
|
/// <summary>
|
/// 尝试开始执行工序行为
|
/// </summary>
|
/// <returns></returns>
|
public ApiAction<SubmitOutput> TryBegin(SubmitInput input)
|
{
|
var action = new ApiAction<SubmitOutput>(new SubmitOutput());
|
action.LocaleMsg = GetBeginMsg();
|
|
var min = PkgRule.Details.OrderBy(q => q.PKG_LEVEL).First();
|
//根据包装不同层级的标签模板代码,如果为空则不需要打印
|
if (LabelDic[min.PKG_LEVEL].IsNullOrEmpty())
|
{
|
input.Data = new PackingActionInput()
|
{
|
ExecCode = "Scan",
|
IsFinish = true,
|
PkgLevel = min.PKG_LEVEL,
|
PkgSN = CurPosition.CurSN,
|
}.ToJson();
|
action = Submit(input);
|
}
|
else
|
{
|
//设置打印变量值
|
LabelDic[min.PKG_LEVEL] = CurPosition.SetLabelVariables(LabelPV, LabelDic[min.PKG_LEVEL]);
|
|
var data = new PackingActionOutput() { PkgInfo = CurPkg };
|
data.ExecCode = "Print";
|
data.PkgLevel = min.PKG_LEVEL;
|
data.PrintLable = LabelDic[min.PKG_LEVEL];
|
CurCmd = data;
|
PrintTimes++;
|
action.Data.Data = data;
|
//action.LocaleMsg = new Locale($"开始第{PrintTimes}次打印第{min.PKG_LEVEL}层包装[{min.PkgType.PKG_NAME}]的标签[{LabelDic[min.PKG_LEVEL]?.LABEL_CODE}: {LabelDic[min.PKG_LEVEL].LABEL_NAME}]");
|
action.LocaleMsg = new Locale("MES.WorkAction.PackingAction.BeginPrint", PrintTimes, min.PKG_LEVEL, min.PkgType.PKG_NAME, LabelDic[min.PKG_LEVEL]?.LABEL_CODE, LabelDic[min.PKG_LEVEL].LABEL_NAME);
|
}
|
|
//如果返回成功则认为当前行为可以开始执行,否则返回失败
|
action.IsSuccessed = true;
|
return action;
|
}
|
|
/// <summary>
|
/// 工序行为提交数据
|
/// </summary>
|
/// <returns></returns>
|
public ApiAction<SubmitOutput> Submit(SubmitInput input)
|
{
|
var action = new ApiAction<SubmitOutput>(new SubmitOutput());
|
|
var pInput = input?.Data?.JsonToObject<PackingActionInput>();
|
switch (pInput?.ExecCode)
|
{
|
//Scan:扫码,扫描当前包装层级的条码
|
case "Scan":
|
if (CurCmd.IsNullOrEmpty() || CurCmd.ExecCode == "Scan" || (CurCmd.ExecCode == "Print" && CurCmd.PkgLevel == pInput.PkgLevel))
|
{
|
//客户端扫描成功
|
if (pInput.IsFinish)
|
{
|
CurCmd = null;
|
PrintTimes = 0;
|
action = SavePkgData(input, action);
|
}
|
//客户端扫描失败
|
else
|
{
|
var dtl = PkgRule.Details.First(q => q.PKG_LEVEL == pInput.PkgLevel);
|
action.IsSuccessed = false;
|
//action.LocaleMsg = new($"条码扫描失败,请重新扫描第{dtl.PKG_LEVEL}层包装[{dtl.PkgType.PKG_NAME}]的标签条码");
|
action.LocaleMsg = new("MES.WorkAction.PackingAction.ScanFail", dtl.PKG_LEVEL, dtl.PkgType.PKG_NAME);
|
return action;
|
}
|
}
|
break;
|
//Print:打印,打印当前包装层级的标签
|
case "Print":
|
if (CurCmd.ExecCode == "Print")
|
{
|
var dtl = PkgRule.Details.First(q => q.PKG_LEVEL == pInput.PkgLevel);
|
//客户端完成打印
|
if (pInput.IsFinish)
|
{
|
CurCmd = null;
|
PrintTimes = 0;
|
var data = new PackingActionOutput() { PkgInfo = CurPkg };
|
data.ExecCode = "Scan";
|
data.PkgLevel = dtl.PKG_LEVEL;
|
CurCmd = data;
|
action.Data.Data = data;
|
//action.LocaleMsg = new($"请扫描第{dtl.PKG_LEVEL}层包装[{dtl.PkgType.PKG_NAME}]的标签条码");
|
action.LocaleMsg = new("MES.WorkAction.PackingAction.PleaseScanLabel", dtl.PKG_LEVEL, dtl.PkgType.PKG_NAME);
|
}
|
//客户端打印失败
|
else
|
{
|
//如果打印失败则尝试三次重新打印,如果都失败则重置工序
|
if (PrintTimes < 3 && !CurCmd.IsNullOrEmpty())
|
{
|
PrintTimes++;
|
action.Data.Data = CurCmd;
|
//action.LocaleMsg = new Locale($"开始{PrintTimes}次打印第{dtl.PKG_LEVEL}层包装[{dtl.PkgType.PKG_NAME}]的标签[{LabelDic[dtl.PKG_LEVEL]?.LABEL_CODE}: {LabelDic[dtl.PKG_LEVEL].LABEL_NAME}]");
|
action.LocaleMsg = new Locale("MES.WorkAction.PackingAction.BeginPrint", PrintTimes, dtl.PKG_LEVEL, dtl.PkgType.PKG_NAME, LabelDic[dtl.PKG_LEVEL]?.LABEL_CODE, LabelDic[dtl.PKG_LEVEL].LABEL_NAME);
|
}
|
else
|
{
|
CurCmd = null;
|
PrintTimes = 0;
|
action.IsSuccessed = false;
|
//action.LocaleMsg = new($"尝试第{PrintTimes}次打印第{dtl.PKG_LEVEL}层包装[{dtl.PkgType.PKG_NAME}]的标签[{LabelDic[dtl.PKG_LEVEL]?.LABEL_CODE}: {LabelDic[dtl.PKG_LEVEL].LABEL_NAME}]失败,工序已重置,请重新扫描进站产品条码");
|
action.LocaleMsg = new("MES.WorkAction.PackingAction.PrintFail3Times", PrintTimes, dtl.PKG_LEVEL, dtl.PkgType.PKG_NAME, LabelDic[dtl.PKG_LEVEL]?.LABEL_CODE, LabelDic[dtl.PKG_LEVEL].LABEL_NAME);
|
CurPosition.ResetNode();
|
}
|
}
|
}
|
break;
|
// Complete:完成,完成全部包装后结束行为
|
case "Complete":
|
if (CurCmd.ExecCode == "Complete")
|
{
|
CurCmd = null;
|
PrintTimes = 0;
|
action = End();
|
}
|
break;
|
// 手动结束包装,保存暂存的包装数据
|
case null:
|
{
|
CurCmd = null;
|
PrintTimes = 0;
|
FinishLevel = 1;
|
WipPkgItem curItem = CurPkg.Item;
|
while (curItem.PKG_LEVEL > 2)
|
{
|
var next = curItem.Items.FirstOrDefault(q => !q.IsFinished);
|
curItem = next;
|
}
|
CurPkgItem = curItem;
|
|
//手动结束包装默认从第二层包装开始验证
|
var dtl = PkgRule.Details.First(q => q.PKG_LEVEL == 2);
|
//行为设定的OPTION_1-9是包装不同层级的标签模板代码,如果为空则不需要打印
|
if (LabelDic[dtl.PKG_LEVEL].IsNullOrEmpty())
|
{
|
var data = new PackingActionOutput() { PkgInfo = CurPkg };
|
data.ExecCode = "Scan";
|
data.PkgLevel = dtl.PKG_LEVEL;
|
CurCmd = data;
|
action.Data.Data = data;
|
//action.LocaleMsg = new($"请扫描第{dtl.PKG_LEVEL}层包装[{dtl.PkgType.PKG_NAME}]的标签条码");
|
action.LocaleMsg = new("MES.WorkAction.PackingAction.PleaseScanLabel", dtl.PKG_LEVEL, dtl.PkgType.PKG_NAME);
|
}
|
else
|
{
|
//设置打印变量值
|
LabelDic[dtl.PKG_LEVEL] = CurPosition.SetLabelVariables(LabelPV, LabelDic[dtl.PKG_LEVEL]);
|
|
var data = new PackingActionOutput() { PkgInfo = CurPkg };
|
data.ExecCode = "Print";
|
data.PkgLevel = dtl.PKG_LEVEL;
|
data.PrintLable = LabelDic[dtl.PKG_LEVEL];
|
CurCmd = data;
|
PrintTimes++;
|
action.Data.Data = data;
|
//action.LocaleMsg = new Locale($"开始第{PrintTimes}次打印第{min.PKG_LEVEL}层包装[{min.PkgType.PKG_NAME}]的标签[{LabelDic[min.PKG_LEVEL]?.LABEL_CODE}: {LabelDic[min.PKG_LEVEL].LABEL_NAME}]");
|
action.LocaleMsg = new Locale("MES.WorkAction.PackingAction.BeginPrint", PrintTimes, dtl.PKG_LEVEL, dtl.PkgType.PKG_NAME, LabelDic[dtl.PKG_LEVEL]?.LABEL_CODE, LabelDic[dtl.PKG_LEVEL].LABEL_NAME);
|
}
|
}
|
break;
|
default:
|
break;
|
}
|
|
//如果行为设置为出错需要重置工序操作
|
if (!action.IsSuccessed && NodeAct.NEED_RESET == "Y")
|
{
|
CurPosition.ResetNode();
|
}
|
return action;
|
}
|
|
//保存包装信息
|
public ApiAction<SubmitOutput> SavePkgData(SubmitInput input, ApiAction<SubmitOutput> action)
|
{
|
var pInput = input.Data?.JsonToObject<PackingActionInput>();
|
try
|
{
|
//正在处理的包装层级明细
|
var dtl = PkgRule.Details.First(q => q.PKG_LEVEL == FinishLevel + 1);
|
|
//没有保存过任何包装层级的数据,则先处理最小包装数据
|
if (FinishLevel == 0)
|
{
|
CurPkgItem = new WipPkgItem()
|
{
|
PKG_CODE = dtl.PKG_CODE,
|
PKG_NAME = dtl.PkgType.PKG_NAME,
|
IS_MIN_PKG = dtl.PkgType.IS_MIN_PKG,
|
PKG_LEVEL = dtl.PKG_LEVEL,
|
PKG_QTY = dtl.PKG_QTY,
|
LABEL_CODE = LabelDic[dtl.PKG_LEVEL]?.LABEL_CODE,
|
IsFinished = true,
|
Package = new()
|
{
|
AUTH_ORG = CurPosition.WorkBatch.WO.AUTH_ORG,
|
AUTH_PROD = CurPosition.CurLine.LINE_CODE,
|
SN = pInput.PkgSN,
|
PKG_TYPE = dtl.PkgType.PKG_NAME,
|
ITEM_CODE = CurPosition.CurWipSNs.First().ITEM_CODE,
|
QTY = CurPosition.CurWipSNs.First().QTY,
|
UNIT = dtl.PkgType.PKG_NAME,
|
WORK_ORDER = CurPosition.CurWipSNs.First().WORK_ORDER,
|
BATCH_NO = CurPosition.CurWipSNs.First().BATCH_NO,
|
ROT_CODE = CurPosition.CurWipSNs.First().ROT_CODE,
|
NODE_ID = CurPosition.CurWipSNs.First().NODE_ID,
|
NODE_NAME = CurPosition.CurWipSNs.First().NODE_NAME,
|
FTY_CODE = CurPosition.CurWipSNs.First().FTY_CODE,
|
WS_CODE = CurPosition.CurWipSNs.First().WS_CODE,
|
LINE_CODE = CurPosition.CurWipSNs.First().LINE_CODE,
|
POST_CODE = CurPosition.CurWipSNs.First().POST_CODE,
|
OPER_CODE = CurPosition.CurWipSNs.First().OPER_CODE,
|
SEGMENT = CurPosition.CurWipSNs.First().SEGMENT,
|
}
|
};
|
FinishLevel++;
|
action = SavePkgData(input, action);
|
}
|
//处理其他包装层级数据
|
else
|
{
|
//客户端提交的包装层级等于当前处理的包装层级
|
if (pInput.PkgLevel == dtl.PKG_LEVEL)
|
{
|
CurPkgItem.IsFinished = true;
|
CurPkgItem.Package = new()
|
{
|
AUTH_ORG = CurPosition.WorkBatch.WO.AUTH_ORG,
|
AUTH_PROD = CurPosition.CurLine.LINE_CODE,
|
SN = pInput.PkgSN,
|
PKG_TYPE = dtl.PkgType.PKG_NAME,
|
ITEM_CODE = CurPosition.CurWipSNs.First().ITEM_CODE,
|
QTY = CurPkgItem.Items.Sum(q => q.Package.QTY),
|
UNIT = dtl.PkgType.PKG_NAME,
|
WORK_ORDER = CurPosition.CurWipSNs.First().WORK_ORDER,
|
BATCH_NO = CurPosition.CurWipSNs.First().BATCH_NO,
|
ROT_CODE = CurPosition.CurWipSNs.First().ROT_CODE,
|
NODE_ID = CurPosition.CurWipSNs.First().NODE_ID,
|
NODE_NAME = CurPosition.CurWipSNs.First().NODE_NAME,
|
FTY_CODE = CurPosition.CurWipSNs.First().FTY_CODE,
|
WS_CODE = CurPosition.CurWipSNs.First().WS_CODE,
|
LINE_CODE = CurPosition.CurWipSNs.First().LINE_CODE,
|
POST_CODE = CurPosition.CurWipSNs.First().POST_CODE,
|
OPER_CODE = CurPosition.CurWipSNs.First().OPER_CODE,
|
SEGMENT = CurPosition.CurWipSNs.First().SEGMENT,
|
};
|
FinishLevel++;
|
//完成包装的层级小于最外层包装层级
|
if (FinishLevel < PkgRule.Details.Max(q => q.PKG_LEVEL))
|
{
|
//当前处理的包装层级已经处理完,继续往上保存
|
action = SavePkgData(input, action);
|
}
|
//最外层包装已经完成包装,保存包装数据到数据库
|
else
|
{
|
action = SaveToDB();
|
}
|
}
|
//当前处理的包装层级已经处理完,继续往上保存
|
else if (pInput.PkgLevel == FinishLevel)
|
{
|
//获取当前的包装明细的上一层包装对象
|
WipPkgItem curItem = CurPkg.Item;
|
while (curItem.PKG_LEVEL > dtl.PKG_LEVEL)
|
{
|
var next = curItem.Items.FirstOrDefault(q => !q.IsFinished);
|
if (next.IsNullOrEmpty())
|
{
|
var nextDtl = PkgRule.Details.First(q => q.PKG_LEVEL == curItem.PKG_LEVEL - 1);
|
next = new WipPkgItem()
|
{
|
PKG_CODE = nextDtl.PKG_CODE,
|
PKG_NAME = nextDtl.PkgType.PKG_NAME,
|
IS_MIN_PKG = nextDtl.PkgType.IS_MIN_PKG,
|
PKG_LEVEL = nextDtl.PKG_LEVEL,
|
PKG_QTY = nextDtl.PKG_QTY,
|
LABEL_CODE = LabelDic[nextDtl.PKG_LEVEL]?.LABEL_CODE,
|
};
|
curItem.Items.Add(next);
|
}
|
curItem = next;
|
}
|
//添加当前的包装明细到上一层包装的明细列表
|
if (!curItem.Items.Contains(CurPkgItem))
|
{
|
curItem.Items.Add(CurPkgItem);
|
}
|
CurPkgItem = curItem;
|
|
//添加明细后判断当前包装层级的明细数量是否等于包装数量,若相等则标记当前包装层级为完成并尝试打印标签
|
if (CurPkgItem.Items.Count(q => q.IsFinished) == CurPkgItem.PKG_QTY || CurStep.IsNullOrEmpty())
|
{
|
//行为设定的OPTION_1-9是包装不同层级的标签模板代码,如果为空则不需要打印
|
if (LabelDic[dtl.PKG_LEVEL].IsNullOrEmpty())
|
{
|
var data = new PackingActionOutput() { PkgInfo = CurPkg };
|
data.ExecCode = "Scan";
|
data.PkgLevel = dtl.PKG_LEVEL;
|
CurCmd = data;
|
action.Data.Data = data;
|
//action.LocaleMsg = new($"请扫描第{dtl.PKG_LEVEL}层包装[{dtl.PkgType.PKG_NAME}]的标签条码");
|
action.LocaleMsg = new("MES.WorkAction.PackingAction.PleaseScanLabel", dtl.PKG_LEVEL, dtl.PkgType.PKG_NAME);
|
}
|
else
|
{
|
//设置打印变量值
|
LabelDic[dtl.PKG_LEVEL] = CurPosition.SetLabelVariables(LabelPV, LabelDic[dtl.PKG_LEVEL]);
|
|
var data = new PackingActionOutput() { PkgInfo = CurPkg };
|
data.ExecCode = "Print";
|
data.PkgLevel = dtl.PKG_LEVEL;
|
data.PrintLable = LabelDic[dtl.PKG_LEVEL];
|
CurCmd = data;
|
PrintTimes++;
|
action.Data.Data = data;
|
//action.LocaleMsg = new Locale($"开始第{PrintTimes}次打印第{dtl.PKG_LEVEL}层包装[{dtl.PkgType.PKG_NAME}]的标签[{LabelDic[dtl.PKG_LEVEL]?.LABEL_CODE}: {LabelDic[dtl.PKG_LEVEL].LABEL_NAME}]");
|
action.LocaleMsg = new Locale("MES.WorkAction.PackingAction.BeginPrint", PrintTimes, dtl.PKG_LEVEL, dtl.PkgType.PKG_NAME, LabelDic[dtl.PKG_LEVEL]?.LABEL_CODE, LabelDic[dtl.PKG_LEVEL].LABEL_NAME);
|
}
|
}
|
//当前包装层级的明细数量未达到包装数量,则完成本次扫描,等待下个产品进站
|
else
|
{
|
action = End();
|
}
|
}
|
//数据异常
|
else
|
{
|
var pdtl = PkgRule.Details.First(q => q.PKG_LEVEL == pInput.PkgLevel);
|
action.IsSuccessed = false;
|
//action.LocaleMsg = new($"客户端提交的包装层级[{pdtl.PKG_LEVEL}]({pdtl.PkgType.PKG_NAME})数据不是正在处理的包装层级[{dtl.PKG_LEVEL}]({dtl.PkgType.PKG_NAME}),工序已重置,请重新扫描进站产品条码");
|
action.LocaleMsg = new("MES.WorkAction.PackingAction.SaveLevelNotMatchException", pdtl.PKG_LEVEL, pdtl.PkgType.PKG_NAME, dtl.PKG_LEVEL, dtl.PkgType.PKG_NAME);
|
CurPosition.ResetNode();
|
}
|
}
|
}
|
catch (System.Exception ex)
|
{
|
var dtl = PkgRule.Details.First(q => q.PKG_LEVEL == pInput.PkgLevel);
|
action.CatchExceptionWithLog(ex, $"包装行为:扫描第{dtl.PKG_LEVEL}层包装[{dtl.PkgType.PKG_NAME}]的标签条码[{input.SN}]后保存数据失败");
|
action.IsSuccessed = false;
|
//action.LocaleMsg = new($"扫描第{dtl.PKG_LEVEL}层包装[{dtl.PkgType.PKG_NAME}]的标签条码[{input.SN}]后保存数据失败,工序已重置,请重新扫描进站产品条码");
|
action.LocaleMsg = new("MES.WorkAction.PackingAction.SavePkgDataException", dtl.PKG_LEVEL, dtl.PkgType.PKG_NAME, input.SN);
|
CurPosition.ResetNode();
|
}
|
return action;
|
}
|
|
private List<MES_WIP_PKG> GetPackageList(WipPkgItem parent)
|
{
|
List<MES_WIP_PKG> list = new() { parent.Package };
|
foreach (var item in parent.Items)
|
{
|
item.Package.PARENT_SN = parent.Package.SN;
|
list.AddRange(GetPackageList(item));
|
}
|
return list;
|
}
|
|
public ApiAction<SubmitOutput> SaveToDB()
|
{
|
var action = new ApiAction<SubmitOutput>(new SubmitOutput());
|
|
var pkgList = GetPackageList(CurPkg.Item);
|
|
//保存数据库
|
var db = Biz.Db;
|
var dbTran = db.UseTran(() =>
|
{
|
db.Insertable(pkgList, CurPosition.UserCode).ExecuteCommand();
|
});
|
if (!dbTran.IsSuccess)
|
{
|
throw dbTran.ErrorException;
|
}
|
|
var data = new PackingActionOutput() { PkgInfo = CurPkg };
|
data.ExecCode = "Complete";
|
data.PkgLevel = CurPkg.Item.PKG_LEVEL;
|
CurCmd = data;
|
action.Data.Data = data;
|
//action.LocaleMsg = new($"第{CurPkg.Item.PKG_LEVEL}层包装[{CurPkg.Item.PKG_NAME}]已经全部完成,保存包装数据");
|
action.LocaleMsg = new("MES.WorkAction.PackingAction.PackageComplete", CurPkg.Item.PKG_LEVEL, CurPkg.Item.PKG_NAME);
|
|
//手动结束包装则标记行为完成
|
if (CurStep.IsNullOrEmpty())
|
{
|
IsFinished = true;
|
}
|
|
return action;
|
}
|
|
/// <summary>
|
/// 结束执行工序行为
|
/// </summary>
|
/// <returns></returns>
|
public ApiAction<SubmitOutput> End()
|
{
|
var action = new ApiAction<SubmitOutput>(new SubmitOutput());
|
|
//记录行为操作记录
|
var wipActs = new List<MES_WIP_ACT>();
|
foreach (var wipSn in CurPosition.CurWipSNs)
|
{
|
var wipAct = new MES_WIP_ACT()
|
{
|
AUTH_ORG = CurPosition.WorkBatch.WO.AUTH_ORG,
|
AUTH_PROD = CurPosition.CurLine.LINE_CODE,
|
HIS_ID = CurPosition.CurWipSNHiss.First(q => q.SN == wipSn.SN).ID,
|
SN = wipSn.SN,
|
STATUS = wipSn.STATUS,
|
ITEM_CODE = wipSn.ITEM_CODE,
|
WORK_ORDER = wipSn.WORK_ORDER,
|
BATCH_NO = wipSn.BATCH_NO,
|
ROT_CODE = wipSn.ROT_CODE,
|
NODE_ID = wipSn.NODE_ID,
|
NODE_NAME = wipSn.NODE_NAME,
|
ACT_ID = NodeAct.ID,
|
ACT_NAME = NodeAct.ACT_NAME,
|
FTY_CODE = wipSn.FTY_CODE,
|
WS_CODE = wipSn.WS_CODE,
|
LINE_CODE = wipSn.LINE_CODE,
|
POST_CODE = wipSn.POST_CODE,
|
OPER_CODE = wipSn.OPER_CODE,
|
SEGMENT = wipSn.SEGMENT,
|
TRAY_SN = wipSn.TRAY_SN,
|
OPERATION_TIME = DateTime.Now,
|
SFTS_CODE = wipSn.SFTS_CODE,
|
SFT_CODE = wipSn.SFT_CODE,
|
PRD_CODE = wipSn.PRD_CODE,
|
ACT_TYPE = NodeAct.ACT_TYPE,
|
ACT_SN = wipSn.SN,
|
ACT_RESULT = "Y",
|
TRACE_INFO = $"产品条码[{string.Join(",", CurPosition.CurSN)}]包装完成",
|
};
|
wipActs.Add(wipAct);
|
}
|
|
//保存数据
|
CurStep.DBSubmitAction = () =>
|
{
|
var db = CurPosition.GetCommitDB();
|
db.Storageable(wipActs, CurPosition.UserCode).ExecuteCommand();
|
};
|
|
if (CurPkg.IsFinished)
|
{
|
//最外层包装已经完成包装,则把工序中暂存标记设为false,统一提交包装内产品的过站记录
|
CurPosition.NeedTemporaryStoreDBCommitAction = false;
|
//删除工序上下文中的包装记录
|
CurPosition.Context.Remove("CurPackage");
|
}
|
else
|
{
|
//最外层包装未完成包装,则把工序中暂存标记设为true,待全部包装完成再统一提交包装内产品的过站记录
|
CurPosition.NeedTemporaryStoreDBCommitAction = true;
|
//如果工序上下文中没有包装记录则新建一个
|
if (CurPosition.Context.ContainsKey("CurPackage"))
|
{
|
CurPosition.Context["CurPackage"] = CurPkg;
|
}
|
else
|
{
|
CurPosition.Context.Add("CurPackage", CurPkg);
|
}
|
}
|
|
IsFinished = true;
|
action.LocaleMsg = new($"产品条码[{CurPosition.CurSN}]包装完成");
|
action.LocaleMsg = new("MES.WorkAction.PackingAction.PackingSuccess", CurPosition.CurSN);
|
return action;
|
}
|
|
|
#endregion Functions
|
}
|
}
|