22
schangxiang@126.com
2024-12-20 3bb1d845a5d110a6b8757195109db6fd207e83d3
CC/iWareCC_ASRS/ThreadService/00_269¹¤Î»/DataProcess_269.cs
@@ -1,9 +1,11 @@
using Admin.NET.Application;
using iWareCC.Common.Helper;
using iWareCC.Forms;
using iWareCC.StationService;
using iWareCommon.Common.Globle;
using iWareCommon.Utils;
using iWareModel;
using iWareSql.DataAccess;
using iWareSql.DBModel;
using iWareSql.WmsDBModel;
using System;
@@ -12,6 +14,7 @@
using System.Text;
using System.Threading;
using System.Threading.Tasks;
using System.Windows.Forms;
using XiGang.Core.Model;
namespace iWareCC.ThreadService
@@ -32,11 +35,30 @@
            {
                Thread.Sleep(1000);//休眠2秒,将休眠写到前面,是为了下面的continue方法执行后不显示错误信息的提示!!!【EditBy shaocx,2022-05-24】
                SystemWarningMsg._lbl_alert_DataProcess_269 = string.Empty;
                try
                {
                    //if (SystemValue.isAllowRuning_DataProcess_269 && SystemValue.isStartedModel)
                    if (SystemValue.isStartedModel)
                    {
                        //增加验证密码 ã€Editby shaocx,2024-12-19】
                        using (WmsDBModel edm = new WmsDBModel())
                        {
                            var isTrigger = WmsConfigEncryptionHandler.IsTrigger(edm);
                            if (isTrigger)
                            {
                                //要求必须输入管理员密码才可以!!!
                                FormManagerPassword fr = new FormManagerPassword();
                                fr.StartPosition = FormStartPosition.CenterScreen;
                                fr.ShowDialog();
                                if (!fr.isValidateOk)
                                {
                                    return;
                                }
                            }
                        }
                        var rgvLocation = StationLocationEnum.首次扫码工位.ToString();
                        /*
                         * 1、从数据库中判断是否齐套
@@ -62,6 +84,24 @@
                                var upiObj = wmsDB.mes_batchOrderUPI_new.Where(x => x.UPI == upiCode).FirstOrDefault();
                                if (upiObj == null)
                                {
                                    //推送plc äººå·¥æ”¾è¡Œ
                                    using (StationServiceClient client = new StationServiceClient())
                                    {
                                        var res = await client.WriteStation_PersonAllowAsync((int)EDevice.Station, false, rgvLocation);
                                        if (!res.result)
                                        {
                                            SystemWarningMsg._lbl_alert_DataProcess_269 = $"{rgvLocation.ToString()}- æŽ¨é€plc äººå·¥æ”¾è¡Œ å¤±è´¥,WriteStation_PersonAllowAsync è¿”回:{res.resMsg}";
                                            continue;
                                        }
                                        else
                                        {
                                            Log4NetHelper.WriteInfoLog(logType, $"{rgvLocation.ToString()}-推送plc äººå·¥æ”¾è¡Œ æˆåŠŸ,WriteStation_PersonAllowAsync,参数: ç«™ç‚¹{rgvLocation}");
                                        }
                                    }
                                    //写入报警信息
                                    await MyExtendHelper.WriteBoolPlcDataForWarning(PlcWarningAddressGloble.Num_269_1);
                                    SystemWarningMsg._lbl_alert_DataProcess_269 = $"{rgvLocation.ToString()},根据UPI:{upiCode}没有找到对象 ";
                                    continue;
                                    //*/
@@ -73,7 +113,7 @@
                                    var res = await client.WriteQiTaoInfoAsync((int)EDevice.Station, rgvLocation, true);
                                    if (!res.result)
                                    {
                                        SystemWarningMsg._lbl_alert_DataProcess_BZ01 = $"{rgvLocation.ToString()}- æŽ¨é€plc解析完成 å¤±è´¥,WriteQiTaoInfoAsync返回:{res.resMsg}";
                                        SystemWarningMsg._lbl_alert_DataProcess_269 = $"{rgvLocation.ToString()}- æŽ¨é€plc解析完成 å¤±è´¥,WriteQiTaoInfoAsync返回:{res.resMsg}";
                                        continue;
                                    }
                                    else
@@ -84,12 +124,43 @@
                                upiObj.AreaCode = (int)AreaCodeEnum.待缓存分拣区;
                                //记录板件队列表
                                var queueData = wmsDB.mes_upi_linequeue.Where(x => x.Upi == upiObj.UPI).FirstOrDefault();
                                if (queueData != null)
                                {
                                    wmsDB.mes_upi_linequeue.Remove(queueData);
                                }
                                mes_upi_linequeue addUpiLineQueue = ClassHelper.RotationMapping<mes_upi_linequeue, mes_batchOrderUPI_new>(upiObj);
                                addUpiLineQueue.Id = Yitter.IdGenerator.YitIdHelper.NextId();
                                addUpiLineQueue.Location = "269";
                                addUpiLineQueue.AreaCode = (int)AreaCodeEnum.待缓存分拣区;
                                addUpiLineQueue.Upi = upiObj.UPI;
                                addUpiLineQueue.UpiFlag = (int)UpiFlagEnum.正常;
                                addUpiLineQueue.UpiStatus = (int)UpiStatusEnum.初始;
                                addUpiLineQueue.CreateTime = DateTime.Now;
                                addUpiLineQueue.CreateUserName = SysGloble.WCSSystem;
                                wmsDB.mes_upi_linequeue.Add(addUpiLineQueue);
                                WmsRecordUpiProcessHandler.SaveWmsRecordUpiProcess(wmsDB, upiObj, "269", "首次扫码");
                                ////更新配置 269_LastPackageUpi
                                //var bz30Config = wmsDB.SysConfig.Where(x => x.Code == "269_LastPackageUpi").FirstOrDefault();
                                //if (bz30Config == null)
                                //{
                                //    SystemWarningMsg._lbl_Alert_DataProcess_ValidateQiTao = $"没有配置 269_LastPackageUpi å€¼";
                                //    continue;
                                //}
                                //bz30Config.Value = upiObj.PackageCode + "|" + upiObj.UPI;
                                FormCC.Globle_269_LastPackageUpi = upiObj.PackageCode + "|" + upiObj.UPI + "|" + DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");
                                wmsDB.SaveChanges();
                                //*/
                            }
                        }
                        else
                        {
                            SystemWarningMsg._lbl_alert_DataProcess_269 = $"{rgvLocation.ToString()}-没有要处理的数据";
                        }
                    }
                }
                catch (Exception ex)