Tiger.Api/Language.dbBinary files differ
Tiger.Business.WMS/Transaction/In_Default.cs
@@ -12,6 +12,9 @@ using Tiger.Model.Sharetronic.Shelf; using Tiger.Business.WMS.Sharetronic.Shelf; using Microsoft.IdentityModel.Tokens; using Apache.NMS.ActiveMQ.Commands; using Tiger.Model.MES.Yada; using Tiger.Model.Entitys.MES.Position; namespace Tiger.Business.WMS.Transaction { @@ -36,15 +39,16 @@ public string OrgCode { get; set; } public Inventory CurInvItem { get; set; } public ScanShelfInfo CurScanShelf { get; set; } public string Command { get; set; } = "Normal"; #endregion #region Functions /// <summary> /// æ«æç©æå¹¶å¤æ ¸ï¼å¦æç©æå·²ç»å®æç§»åºåè´§æ¶ä¸äº®ç¯æéå¨ä½ /// æ«æå ¥å£ /// </summary> public async Task<ApiAction> ScanItem(BaseInput input) public async Task<ApiAction<ScanOutput>> Scan(BaseInput input) { var action = new ApiAction(); var action = new ApiAction<ScanOutput>(); try { if (input.SN.IsNullOrEmpty()) @@ -52,18 +56,38 @@ action.IsSuccessed = false; //action.LocaleMsg = Biz.L("æ¡ç ä¸è½ä¸ºç©º"); action.LocaleMsg = Biz.L("WMS.Default.ScanItem.SnEmptyFailure"); return action; return SetOutPutMqttMsg(action, input.Locale); } //è´§æ¶ä¸ºç©ºåæ«æç认为æ¯è´§æ¶ if (string.IsNullOrEmpty(CurScanShelf?.RackCode)) if (string.IsNullOrEmpty(CurScanShelf?.ShelfCode)) { var _action = await ScanShelf(input.SN); action.LocaleMsg = _action.LocaleMsg; action.IsSuccessed = _action.IsSuccessed; action.Data = _action.Data; return action; action = await ScanShelf(input.SN); } //æ«æç©æå¹¶å¤æ ¸ { action = await ScanItem(input); } } catch (Exception ex) { //åæ¶å½åæä½ ResetInfo(); //action.CatchExceptionWithLog(ex, $"æ«æ[{input.SN}]å¼å¸¸"); action.CatchExceptionWithLog(ex, Biz.L("WMS.Default.Scan.ScanException", input.SN)); } return SetOutPutMqttMsg(action, input.Locale); } /// <summary> /// æ«æç©æå¹¶å¤æ ¸ï¼å¦æç©æå·²ç»å®æç§»åºåè´§æ¶ä¸äº®ç¯æéå¨ä½ /// </summary> public async Task<ApiAction<ScanOutput>> ScanItem(BaseInput input) { var action = new ApiAction<ScanOutput>(new ScanOutput() { Command = Command }); try { if (CurInvItem.IsNullOrEmpty()) { Result<IInventory> result = WMS_ITEM_Biz.WmsItem.Get(input.SN, input.AuthOption, true); if (!result.IsSuccessed) { @@ -71,28 +95,67 @@ action.LocaleMsg = result.LocaleMsg; return action; } var inv = result.Data as Inventory; CurInvItem = result.Data as Inventory; //éªè¯æ¡ç æ¯å¦æ£ç¡®!inv.isNormalStatus || inv.Status.GetValue() != WMS_ITEM.STATUSs.NotExists.GetValue() && if (inv.Status.GetValue() == WMS_ITEM.STATUSs.InStore.GetValue()) //éªè¯æ¡ç æ¯å¦æ£ç¡® if (new[] { WMS_ITEM.STATUSs.InStore, WMS_ITEM.STATUSs.Loaded, WMS_ITEM.STATUSs.UseUp }.Contains(CurInvItem.Status)) { action.IsSuccessed = false; //action.LocaleMsg = Biz.L("ç¶æ[{0}]å¼å¸¸ï¼è¯·éæ°æ«æ"); action.LocaleMsg = Biz.L("WMS.Default.ScanItem.StatusException", string.Join(',', inv.StatusList.Select(q => q.GetDesc()))); action.LocaleMsg = Biz.L("WMS.Default.ScanItem.StatusException", string.Join(',', CurInvItem.StatusList.Select(q => q.GetDesc()))); return action; } //ç©æéªè¯ if (inv.ItemInfo.IsNullOrEmpty() || inv.ItemInfo.IS_ACTIVE == "N") if (CurInvItem.ItemInfo.IsNullOrEmpty() || CurInvItem.ItemInfo.IS_ACTIVE == "N") { action.IsSuccessed = false; //action.LocaleMsg = Biz.L("ç©æç¼ç [{0}]ä¸å卿è è¯¥ç©ææªå¯ç¨"); action.LocaleMsg = Biz.L("WMS.Default.ScanItem.ItemCodeNotExistsOrNotActive", inv.ItemInfo.ITEM_CODE.IsNullOrEmpty(inv.Barcode.ItemCode)); action.LocaleMsg = Biz.L("WMS.Default.ScanItem.ItemCodeNotExistsOrNotActive", CurInvItem.ItemInfo.ITEM_CODE.IsNullOrEmpty(CurInvItem.Barcode.ItemCode)); return action; } if (!inv.IsNullOrEmpty()) //æ£æ¥ç©ææ°éï¼å¦ææ²¡æåæ¥è¯¢é è¾¾æ¡ç ä¸»æ¡£ï¼ææ°éè¿åå端确认 if (CurInvItem.Items.Any(q => q.QTY <= 0)) { if (inv.Items.Count == 0) var qtyList = Biz.DataSource["YadaU9C"].Client.Queryable<mes_MaterialBarCode>().Where(q => CurInvItem.Items.Select(q => q.SN).Contains(q.Code)).ToList(); foreach (var qty in qtyList) { var item = CurInvItem.Items.First(q => q.SN == qty.Code); item.QTY = qty.WhQty; } action.Data.Data = CurInvItem.Items.ToDictionary(k => k.SN, v => v.QTY); action.Data.Command = Command = "ComfirmQty"; //action.LocaleMsg = Biz.L("请确认æ¡ç [{0}]çæ°éæ¯å¦æ£ç¡®"); action.LocaleMsg = Biz.L("WMS.Default.ScanItem.ComfirmQty", input.SN); return action; } } //æ´æ°å·²ç¡®è®¤ç©ææ°é if (Command == "ComfirmQty") { var qtyList = (input.Data ?? "").JsonToObject<Dictionary<string, decimal>>() ?? new Dictionary<string, decimal>(); if (qtyList.Any(q => q.Value <= 0)) { action.IsSuccessed = false; action.Data.Data = CurInvItem.Items.ToDictionary(k => k.SN, v => v.QTY); action.Data.Command = Command = "ComfirmQty"; //action.LocaleMsg = Biz.L("æ°éä¸è½å°äºçäºé¶ï¼è¯·éæ°ç¡®è®¤æ¡ç [{0}]çæ°é"); action.LocaleMsg = Biz.L("WMS.Default.ScanItem.ReComfirmQty", input.SN); return action; } else { foreach (var qty in qtyList) { var item = CurInvItem.Items.First(q => q.SN == qty.Key); item.QTY = qty.Value; } Command = "Normal"; } } if (CurInvItem.Items.Count == 0) { List<WMS_ITEM_HIS> ItemHistorys = new List<WMS_ITEM_HIS>(); WMS_ITEM Item; @@ -100,67 +163,66 @@ Item = new() { SN = inv.Barcode.SN, ITEM_CODE = inv.Barcode.ItemCode, SN = CurInvItem.Barcode.SN, ITEM_CODE = CurInvItem.Barcode.ItemCode, AUTH_ORG = input.AuthOption.CurOrg, STATUS = WMS_ITEM.STATUSs.WaitIn.GetValue(), QTY = inv.Barcode.Qty.ToDecimal(), PROD_DATE = inv.Barcode.DateCode.ToDateTime(), QTY = CurInvItem.Barcode.Qty.ToDecimal(), PROD_DATE = CurInvItem.Barcode.DateCode.ToDateTime(), ERP_WH = CurScanShelf.WarehouseCode, UNIT = inv.Barcode.Unit, UNIT = CurInvItem.Barcode.Unit, }; WMS_ITEM_HIS his = new(Item, $"æ å䏿¶å ¥åº"); ItemHistorys.Add(his); ItemPkgs = new() { SN = inv.Barcode.SN, SN = CurInvItem.Barcode.SN, AUTH_ORG = input.AuthOption.CurOrg, ITEM_CODE = inv.Barcode.ItemCode, QTY = inv.Barcode.Qty.ToDecimal(), ITEM_CODE = CurInvItem.Barcode.ItemCode, QTY = CurInvItem.Barcode.Qty.ToDecimal(), ERP_WH = CurScanShelf.WarehouseCode, UNIT = inv.Barcode.Unit, UNIT = CurInvItem.Barcode.Unit, }; var noExt = inv.Items.Where(q => !inv.ItemsExt.Any(s => s.SN == q.SN)).ToList(); var noExt = CurInvItem.Items.Where(q => !CurInvItem.ItemsExt.Any(s => s.SN == q.SN)).ToList(); //æ©å±è¡¨ä¸å卿¶æ°å»º foreach (var item in noExt) { inv.ItemsExt.Add(new() CurInvItem.ItemsExt.Add(new() { SN = item.SN, META_SN = inv.Barcode.MetaSn, QR_CODE = inv.Barcode.MetaSn META_SN = CurInvItem.Barcode.MetaSn, QR_CODE = CurInvItem.Barcode.MetaSn }); } inv.Items.Add(Item); inv.History.Add(his); inv.Packages.Add(ItemPkgs); CurInvItem.Items.Add(Item); CurInvItem.History.Add(his); CurInvItem.Packages.Add(ItemPkgs); } else if (inv.Items.Count == 1) else if (CurInvItem.Items.Count == 1) { inv.Items.First().QTY = inv.Barcode.Qty.ToDecimal(); inv.Items.First().ERP_WH = CurScanShelf.WarehouseCode; inv.Items.First().AUTH_ORG = input.AuthOption.CurOrg; CurInvItem.Items.First().QTY = CurInvItem.Barcode.Qty.ToDecimal(); CurInvItem.Items.First().ERP_WH = CurScanShelf.WarehouseCode; CurInvItem.Items.First().AUTH_ORG = input.AuthOption.CurOrg; inv.Packages.First().QTY = inv.Barcode.Qty.ToDecimal(); inv.Packages.First().ERP_WH = CurScanShelf.WarehouseCode; inv.Packages.First().AUTH_ORG = input.AuthOption.CurOrg; CurInvItem.Packages.First().QTY = CurInvItem.Barcode.Qty.ToDecimal(); CurInvItem.Packages.First().ERP_WH = CurScanShelf.WarehouseCode; CurInvItem.Packages.First().AUTH_ORG = input.AuthOption.CurOrg; } //å¦ææ«æå¤ç®±çä¸è½æ´æ°æ°é else { foreach (var item in inv.Items) foreach (var item in CurInvItem.Items) { item.ERP_WH = CurScanShelf.WarehouseCode; item.AUTH_ORG = input.AuthOption.CurOrg; } foreach (var item in inv.Packages) foreach (var item in CurInvItem.Packages) { item.ERP_WH = CurScanShelf.WarehouseCode; item.AUTH_ORG = input.AuthOption.CurOrg; } } } @@ -168,7 +230,7 @@ // 夿æ¯å¦æºè½è´§æ¶ if (CurScanShelf.Shelf.IsLightShelf) { ShelfApiResult shelfApiResult = await Share.Shelf.PutOn(TransID, CurScanShelf.Shelf, inv.Items[0]); ShelfApiResult shelfApiResult = await Share.Shelf.PutOn(TransID, CurScanShelf.Shelf, CurInvItem.Items[0]); if (!shelfApiResult.IsSuccess) { action.IsSuccessed = false; @@ -209,7 +271,7 @@ } //夿å¨ä½æ¯å¦åæ¾ if (nLocation.IS_SINGLE == "Y" && inv.Items.Count > 1) if (nLocation.IS_SINGLE == "Y" && CurInvItem.Items.Count > 1) { action.IsSuccessed = false; //action.LocaleMsg = Biz.L("å¨ä½[{0}]åªè½åæ¾ä¸ä¸ªç©æ"); @@ -218,12 +280,12 @@ } //æ§è¡ä¸æ¶ foreach (var item in inv.Items) foreach (var item in CurInvItem.Items) { item.TRANS_CODE = "In_Default"; item.TRANS_NO = $"In_Default_{DateTime.Now:yyyyMMdd}"; } Result<PutOnInfo> putonResult = WMS_ITEM_Biz.WmsItem.PutOn(inv, input.AuthOption, nLocation.LOCATION_CODE); Result<PutOnInfo> putonResult = WMS_ITEM_Biz.WmsItem.PutOn(CurInvItem, input.AuthOption, nLocation.LOCATION_CODE); if (!putonResult.IsSuccessed) { action.IsSuccessed = false; @@ -250,21 +312,21 @@ throw dbTran.ErrorException; } // è¿åå ¶ä»å ¥åºå¯¹è±¡ action.Data = new DefaultInStoreOutput action.Data.Data = new DefaultInStoreOutput { Barcode = inv.SN, MaterialCode = inv.ItemInfo.ITEM_CODE, MaterialName = inv.ItemInfo.ITEM_NAME, CurrentQty = inv.Items[0].QTY, Unit = inv.Items[0].UNIT, DateCode = inv.Items[0].PROD_DATE, Barcode = CurInvItem.SN, MaterialCode = CurInvItem.ItemInfo.ITEM_CODE, MaterialName = CurInvItem.ItemInfo.ITEM_NAME, CurrentQty = CurInvItem.Items[0].QTY, Unit = CurInvItem.Items[0].UNIT, DateCode = CurInvItem.Items[0].PROD_DATE, WarehouseCode = putOnInfo.Warehouse.WH_CODE, RegionCode = putOnInfo.Region.REGION_CODE, ShelfCode = putOnInfo.Shelf.SHELF_CODE, LocationCode = putOnInfo.Location.LOCATION_CODE, }; //action.LocaleMsg = Biz.L($"æ«ææ¡ç [{0}]䏿¶å°å¨ä½[{1}]æå"); action.LocaleMsg = Biz.L("WMS.Default.ScanItem.PutOnSucceeded", inv.SN, putOnInfo.Location.LOCATION_CODE); action.LocaleMsg = Biz.L("WMS.Default.ScanItem.PutOnSucceeded", CurInvItem.SN, putOnInfo.Location.LOCATION_CODE); } catch (Exception ex) { @@ -279,9 +341,9 @@ /// <summary> /// æ«æè´§æ¶æè å¨ä½ /// </summary> public async Task<ApiAction<ScanShelfInfo>> ScanShelf(string Code) public async Task<ApiAction<ScanOutput>> ScanShelf(string Code) { var action = new ApiAction<ScanShelfInfo>(); var action = new ApiAction<ScanOutput>(); try { if (Code.IsNullOrEmpty()) @@ -348,7 +410,7 @@ CurScanShelf.IsScanShelf = true; //action.LocaleMsg = Biz.L("æ«æè´§æ¶/å¨ä½[{0}]æå"); action.LocaleMsg = Biz.L("WMS.Default.ScanShelf.ScanSucceeded", Code); action.Data = CurScanShelf; action.Data.Data = CurScanShelf; } catch (Exception ex) { @@ -368,6 +430,7 @@ public override void ResetInfo() { base.ResetInfo(); Command = null; CurInvItem = null; CurScanShelf = null; } Tiger.Business.WMS/Transaction/Out_Default.cs
@@ -35,15 +35,16 @@ public string OrgCode { get; set; } public Inventory CurInvItem { get; set; } public ScanShelfInfo CurScanShelf { get; set; } public string Command { get; set; } = "Normal"; #endregion #region Functions /// <summary> /// æ«æç©æå¹¶å¤æ ¸ï¼å¦ææ¯æºè½è´§æ¶åäº®ç¯æéå¨ä½ /// æ«æå ¥å£ /// </summary> public async Task<ApiAction<DefaultScanItemOutput>> ScanItem(BaseInput input) public async Task<ApiAction<ScanOutput>> Scan(BaseInput input) { var action = new ApiAction<DefaultScanItemOutput>(); var action = new ApiAction<ScanOutput>(); try { if (input.SN.IsNullOrEmpty()) @@ -51,9 +52,31 @@ action.IsSuccessed = false; //action.LocaleMsg = Biz.L("æ¡ç ä¸è½ä¸ºç©º"); action.LocaleMsg = Biz.L("WMS.Default.ScanItem.SnEmptyFailure"); return action; return SetOutPutMqttMsg(action, input.Locale); } //æ«æç©æå¹¶å¤æ ¸ { action = await ScanItem(input); } } catch (Exception ex) { //åæ¶å½åæä½ ResetInfo(); //action.CatchExceptionWithLog(ex, $"æ«æ[{input.SN}]å¼å¸¸"); action.CatchExceptionWithLog(ex, Biz.L("WMS.Default.Scan.ScanException", input.SN)); } return SetOutPutMqttMsg(action, input.Locale); } /// <summary> /// æ«æç©æå¹¶å¤æ ¸ï¼å¦ææ¯æºè½è´§æ¶åäº®ç¯æéå¨ä½ /// </summary> public async Task<ApiAction<ScanOutput>> ScanItem(BaseInput input) { var action = new ApiAction<ScanOutput>(new ScanOutput() { Command = Command }); try { //è§£ææ¡ç Result<IInventory> result = WMS_ITEM_Biz.WmsItem.Get(input.SN, input.AuthOption, true); if (!result.IsSuccessed) @@ -125,7 +148,7 @@ throw dbTran.ErrorException; } action.Data = new DefaultScanItemOutput() action.Data.Data = new DefaultScanItemOutput() { SN = CurInvItem.SN, ItemCode = CurInvItem.ItemInfo.ITEM_CODE, @@ -138,13 +161,13 @@ ScanAfCut = CurInvItem.Warehouse.SCAN_AF_CUT }; //action.LocaleMsg = Biz.L($"æ«ææ¡ç [{0}]ä»å¨ä½[{1}]䏿¶æå"); action.LocaleMsg = Biz.L("WMS.Default.ScanItem.TakeDownSucceeded", action.Data.SN, action.Data.locationCode); action.LocaleMsg = Biz.L("WMS.Default.ScanItem.TakeDownSucceeded", CurInvItem.SN, CurInvItem.Location?.LOCATION_CODE); } catch (Exception ex) { ResetInfo(); //action.CatchExceptionWithLog(ex, $"æ«ææ¡ç [{input.SN}]夿 ¸å¼å¸¸"); action.CatchExceptionWithLog(ex, Biz.L("WMS.Default.ScanItem.ScanException", action.Data.SN)); action.CatchExceptionWithLog(ex, Biz.L("WMS.Default.ScanItem.ScanException", input.SN)); } return action; } @@ -152,9 +175,9 @@ /// <summary> /// æ«æè´§æ¶æè å¨ä½(ä¾äº®ç¯è´§æ¶ä½¿ç¨) /// </summary> public async Task<ApiAction<ScanShelfInfo>> ScanShelf(string Code) public async Task<ApiAction<ScanOutput>> ScanShelf(string Code) { var action = new ApiAction<ScanShelfInfo>(); var action = new ApiAction<ScanOutput>(); try { if (Code.IsNullOrEmpty()) @@ -177,14 +200,13 @@ CurScanShelf.WarehouseCode = whUnit.WH_CODE; CurScanShelf.RegionCode = whUnit.REGION_CODE; CurScanShelf.ShelfCode = whUnit.SHELF_CODE; CurScanShelf.LocationCode = whUnit.LOCATION_CODE; CurScanShelf.ShelfType = whUnit.SHELF_TYPE; CurScanShelf.IsSmartRack = true; } // æ«æå¨ä½ä»£ç // æ«æåºä½ä»£ç else { var nLocation = await Biz.Db.Queryable<V_WH_UNIT>().Where(t => t.LOCATION_CODE.ToUpper() == Code.ToUpper() && t.AUTH_ORG == OrgCode).FirstAsync(); var nLocation = await Biz.Db.Queryable<V_WH_UNIT>().Where(t => t.LOCATION_CODE.ToUpper() == Code.ToUpper() && t.AUTH_ORG == OrgCode).IncludesAllFirstLayer().FirstAsync(); if (nLocation == null) { action.IsSuccessed = false; @@ -210,7 +232,7 @@ // return action; // } //} CurScanShelf.Shelf = nLocation.Shelf; CurScanShelf.Location = nLocation.Location; CurScanShelf.WarehouseCode = nLocation.WH_CODE; CurScanShelf.RegionCode = nLocation.REGION_CODE; @@ -222,7 +244,7 @@ CurScanShelf.IsScanShelf = true; //action.LocaleMsg = Biz.L("æ«æè´§æ¶/å¨ä½[{0}]æå"); action.LocaleMsg = Biz.L("WMS.Default.ScanShelf.ScanSucceeded", Code); action.Data = CurScanShelf; action.Data.Data = CurScanShelf; } catch (Exception ex) { @@ -242,6 +264,7 @@ public override void ResetInfo() { base.ResetInfo(); Command = null; CurInvItem = null; CurScanShelf = null; } Tiger.Business.WMS/Transaction/WMSTransactionBase.cs
@@ -13,6 +13,7 @@ using Newtonsoft.Json; using Tiger.Business.WMS.Seastone; using Tiger.IBusiness; using Tiger.Model.Entitys.MES.Position; namespace Tiger.Business.WMS.Transaction { @@ -87,8 +88,64 @@ #endregion #region MQTT /// <summary> /// 设置å½åæ¡ç çå·¥åºä¿¡æ¯ /// </summary> public ApiAction<ScanOutput> SetOutPutMqttMsg(ApiAction<ScanOutput> action, string locale = null) { MQTT.Message msg = new() { IsSuccessed = action.IsSuccessed, Content = Biz.T(action.LocaleMsg, locale), }; switch (action.Status) { case ApiAction.StatusCodes.Success: msg.Voice = MQTT.Voice.Success; msg.Color = "#FF1E90FF"; break; case ApiAction.StatusCodes.Warning: msg.Voice = MQTT.Voice.Warning; msg.Color = "#FFB8860B"; break; case ApiAction.StatusCodes.Error: case ApiAction.StatusCodes.Failed: msg.Voice = MQTT.Voice.Fail; msg.Color = "#FFFF0000"; break; case ApiAction.StatusCodes.Exception: msg.Voice = MQTT.Voice.Fail; msg.Color = "#FF8B0000"; break; case ApiAction.StatusCodes.Normal: case ApiAction.StatusCodes.NeedConfrim: case ApiAction.StatusCodes.Confrimed: default: msg.Voice = MQTT.Voice.Silent; msg.Color = "#FF000000"; break; } if (action.IsSuccessed) { msg.Voice = MQTT.Voice.Success; msg.Color = "#FF228B22"; } else if (!action.IsSuccessed) { msg.Voice = MQTT.Voice.Fail; msg.Color = "#FFFF0000"; } else { msg.Voice = MQTT.Voice.Silent; msg.Color = "#FF000000"; } action.Data.MqttMsg = msg; return action; } private Thread MQTTThread; private void MQTT() private void Mqtt() { try { Tiger.Controllers.WMS/Controllers/WMSController.In_Default.cs
@@ -112,11 +112,11 @@ { if (action.IsAsync) { response = action.GetResponse(await trans.ScanItem(action.Data)); response = action.GetResponse(await trans.Scan(action.Data)); } else { lock (trans.TransLock) { response = action.GetResponse(trans.ScanItem(action.Data).Result); } lock (trans.TransLock) { response = action.GetResponse(trans.Scan(action.Data).Result); } } } else @@ -141,45 +141,45 @@ /// </summary> /// <param name="action"></param> /// <returns></returns> [HttpPost] [Route("api/[controller]/In_Default/ScanShelf")] public async Task<IActionResult> In_Default_ScanShelfAsync([FromBody] ApiAction action) { ApiAction response; IIn_Default trans = null; try { if (iBiz.WMS.Context.GetTransDic().ContainsKey(action.ID)) { trans = iBiz.WMS.Context.GetTransDic()[action.ID] as IIn_Default; if (!trans.IsFinished) { if (action.IsAsync) { response = action.GetResponse(await trans.ScanShelf(action.Data?.ToString())); } else { lock (trans.TransLock) { response = action.GetResponse(trans.ScanShelf(action.Data?.ToString()).Result); } } } else { response = action.GetResponse($"Transaction Error: æ å䏿¶äºå¡[ID:{action.ID}]å·²ç»å ³éï¼è¯·éæ°æå¼ä¸æ¶åè½", false); } } else { response = action.GetResponse($"Transaction Error: æ å䏿¶äºå¡[ID:{action.ID}]æ°æ®ä¸¢å¤±ï¼è¯·éæ°æå¼ä¸æ¶åè½", false); } } catch (System.Exception ex) { response = action.GetResponse().CatchExceptionWithLog(ex); } trans?.AddHistory(Request, action); return Ok(response); } //[HttpPost] //[Route("api/[controller]/In_Default/ScanShelf")] //public async Task<IActionResult> In_Default_ScanShelfAsync([FromBody] ApiAction action) //{ // ApiAction response; // IIn_Default trans = null; // try // { // if (iBiz.WMS.Context.GetTransDic().ContainsKey(action.ID)) // { // trans = iBiz.WMS.Context.GetTransDic()[action.ID] as IIn_Default; // if (!trans.IsFinished) // { // if (action.IsAsync) // { // response = action.GetResponse(await trans.ScanShelf(action.Data?.ToString())); // } // else // { // lock (trans.TransLock) { response = action.GetResponse(trans.ScanShelf(action.Data?.ToString()).Result); } // } // } // else // { // response = action.GetResponse($"Transaction Error: æ å䏿¶äºå¡[ID:{action.ID}]å·²ç»å ³éï¼è¯·éæ°æå¼ä¸æ¶åè½", false); // } // } // else // { // response = action.GetResponse($"Transaction Error: æ å䏿¶äºå¡[ID:{action.ID}]æ°æ®ä¸¢å¤±ï¼è¯·éæ°æå¼ä¸æ¶åè½", false); // } // } // catch (System.Exception ex) // { // response = action.GetResponse().CatchExceptionWithLog(ex); // } // trans?.AddHistory(Request, action); // return Ok(response); //} } } Tiger.Controllers.WMS/Controllers/WMSController.Out_Default.cs
@@ -112,11 +112,11 @@ { if (action.IsAsync) { response = action.GetResponse(await trans.ScanItem(action.Data)); response = action.GetResponse(await trans.Scan(action.Data)); } else { lock (trans.TransLock) { response = action.GetResponse(trans.ScanItem(action.Data).Result); } lock (trans.TransLock) { response = action.GetResponse(trans.Scan(action.Data).Result); } } } else @@ -142,45 +142,45 @@ /// </summary> /// <param name="action"></param> /// <returns></returns> [HttpPost] [Route("api/[controller]/Out_Default/ScanShelf")] public async Task<IActionResult> Out_Default_ScanShelfAsync([FromBody] ApiAction action) { ApiAction response; IOut_Default trans = null; try { if (iBiz.WMS.Context.GetTransDic().ContainsKey(action.ID)) { trans = iBiz.WMS.Context.GetTransDic()[action.ID] as IOut_Default; if (!trans.IsFinished) { if (action.IsAsync) { response = action.GetResponse(await trans.ScanShelf(action.Data?.ToString())); } else { lock (trans.TransLock) { response = action.GetResponse(trans.ScanShelf(action.Data?.ToString()).Result); } } } else { response = action.GetResponse($"Transaction Error: æ å䏿¶äºå¡[ID:{action.ID}]å·²ç»å ³éï¼è¯·éæ°æå¼æ å䏿¶åè½", false); } } else { response = action.GetResponse($"Transaction Error: æ å䏿¶äºå¡[ID:{action.ID}]æ°æ®ä¸¢å¤±ï¼è¯·éæ°æå¼æ å䏿¶åè½", false); } } catch (System.Exception ex) { response = action.GetResponse().CatchExceptionWithLog(ex); } trans?.AddHistory(Request, action); return Ok(response); } //[HttpPost] //[Route("api/[controller]/Out_Default/ScanShelf")] //public async Task<IActionResult> Out_Default_ScanShelfAsync([FromBody] ApiAction action) //{ // ApiAction response; // IOut_Default trans = null; // try // { // if (iBiz.WMS.Context.GetTransDic().ContainsKey(action.ID)) // { // trans = iBiz.WMS.Context.GetTransDic()[action.ID] as IOut_Default; // if (!trans.IsFinished) // { // if (action.IsAsync) // { // response = action.GetResponse(await trans.ScanShelf(action.Data?.ToString())); // } // else // { // lock (trans.TransLock) { response = action.GetResponse(trans.ScanShelf(action.Data?.ToString()).Result); } // } // } // else // { // response = action.GetResponse($"Transaction Error: æ å䏿¶äºå¡[ID:{action.ID}]å·²ç»å ³éï¼è¯·éæ°æå¼æ å䏿¶åè½", false); // } // } // else // { // response = action.GetResponse($"Transaction Error: æ å䏿¶äºå¡[ID:{action.ID}]æ°æ®ä¸¢å¤±ï¼è¯·éæ°æå¼æ å䏿¶åè½", false); // } // } // catch (System.Exception ex) // { // response = action.GetResponse().CatchExceptionWithLog(ex); // } // trans?.AddHistory(Request, action); // return Ok(response); //} } } Tiger.IBusiness.WMS/Transaction/IIn_Default.cs
@@ -13,14 +13,9 @@ public IIn_Default Init(string id, string userCode, string apiHost, string orgCode); /// <summary> /// æ«æç©æå¹¶å¤æ ¸ï¼å¦æç©æå·²ç»å®æç§»åºåè´§æ¶ä¸äº®ç¯æéå¨ä½ /// æ«æå ¥å£ /// </summary> public Task<ApiAction> ScanItem(BaseInput input); /// <summary> /// æ«æè´§æ¶æè å¨ä½ /// </summary> public Task<ApiAction<ScanShelfInfo>> ScanShelf(string Code); public Task<ApiAction<ScanOutput>> Scan(BaseInput input); public bool Close(bool needSaveHistoryLog = false); } Tiger.IBusiness.WMS/Transaction/IOut_Default.cs
@@ -11,15 +11,11 @@ public interface IOut_Default : IWMSTransaction { public IOut_Default Init(string id, string userCode, string apiHost, string orgCode); /// <summary> /// æ«æç©æå¹¶å¤æ ¸ï¼å¦æç©æå·²ç»å®æç§»åºåè´§æ¶ä¸äº®ç¯æéå¨ä½ /// </summary> public Task<ApiAction<DefaultScanItemOutput>> ScanItem(BaseInput input); /// <summary> /// æ«æè´§æ¶æè å¨ä½ /// æ«æå ¥å£ /// </summary> public Task<ApiAction<ScanShelfInfo>> ScanShelf(string Code); public Task<ApiAction<ScanOutput>> Scan(BaseInput input); public bool Close(bool needSaveHistoryLog = false); } Tiger.IBusiness/Core/ApiConfig.cs
@@ -180,7 +180,7 @@ { public static IConfiguration Configuration => RheaConfig.Configuration; public static string DB_ModelAssembly => RheaConfig.DB_ModelAssembly; public static string DefaultLanguage => Configuration?["DefaultLanguage"] ?? "en-us"; public static string DefaultLanguage => Configuration?["DefaultLanguage"] ?? "zh-cn"; public static void InitConfig(IConfiguration _configuration, Dictionary<string, Dictionary<string, string>> language) { //Init Rhea Tiger.Model.Net/Entitys/MES/MES_ROUTE_ACT_VAR.cs
¶Ô±ÈÐÂÎļþ @@ -0,0 +1,156 @@ using System; using SqlSugar; using System.Linq; using System.ComponentModel; using System.Collections.Generic; namespace Tiger.Model { /// <summary> /// å®ä½ï¼å·¥åºè¡ä¸ºåé /// </summary> [Description("Primary:ID")] [DisplayName("å·¥åºè¡ä¸ºåé")] [Serializable] [SugarTable("MES_ROUTE_ACT_VAR")] public class MES_ROUTE_ACT_VAR : DbEntityWithAuth { #region æé 彿° /// <summary> /// å®ä½ï¼å·¥åºè¡ä¸ºåé /// </summary> public MES_ROUTE_ACT_VAR() {} #endregion #region å ¬å ±å±æ§ /// <summary> /// å·¥èºè·¯çº¿ID /// </summary> [DisplayName("å·¥èºè·¯çº¿ID")] public string ROT_ID { get; set; } /// <summary> /// å·¥èºå·¥åºè¡ä¸ºID /// </summary> [DisplayName("å·¥èºå·¥åºè¡ä¸ºID")] public string ACT_ID { get; set; } /// <summary> /// è¡ä¸ºåéç¼ç /// </summary> [DisplayName("è¡ä¸ºåéç¼ç ")] public string VAR_CODE { get; set; } /// <summary> /// è¡ä¸ºåéåç§° /// </summary> [DisplayName("è¡ä¸ºåéåç§°")] public string VAR_NAME { get; set; } /// <summary> /// åéçæ§ä»¶ /// </summary> [DisplayName("åéçæ§ä»¶")] public string VAR_CONTROL { get; set; } /// <summary> /// åéå¼ç±»å(0Stringå符串|1Integeræ´å½¢|2Floatæµ®ç¹å|3DateTimeæ¥ææ¶é´) /// </summary> [DisplayName("åéå¼ç±»å(0Stringå符串|1Integeræ´å½¢|2Floatæµ®ç¹å|3DateTimeæ¥ææ¶é´)")] public int VALUE_TYPE { get; set; } /// <summary> /// æ¯å¦åªè¯»(Y/N) /// </summary> [DisplayName("æ¯å¦åªè¯»(Y/N)")] public string READONLY { get; set; } /// <summary> /// æ¯å¦æ¾ç¤º(Y/N) /// </summary> [DisplayName("æ¯å¦æ¾ç¤º(Y/N)")] public string VISIABLE { get; set; } /// <summary> /// é»è®¤å¼ /// </summary> [DisplayName("é»è®¤å¼")] public string DEFAULT { get; set; } /// <summary> /// 设置å¼1 /// </summary> [DisplayName("设置å¼1")] public string OPTION_1 { get; set; } /// <summary> /// 设置å¼2 /// </summary> [DisplayName("设置å¼2")] public string OPTION_2 { get; set; } /// <summary> /// 设置å¼3 /// </summary> [DisplayName("设置å¼3")] public string OPTION_3 { get; set; } /// <summary> /// 设置å¼4 /// </summary> [DisplayName("设置å¼4")] public string OPTION_4 { get; set; } /// <summary> /// 设置å¼5 /// </summary> [DisplayName("设置å¼5")] public string OPTION_5 { get; set; } /// <summary> /// 夿³¨ /// </summary> [DisplayName("夿³¨")] public string REMARK { get; set; } #endregion #region èæå±æ§ /*ä¾å [SugarColumn(IsIgnore = true)] public string FieldName { get; set; } */ #endregion #region å¤é®å±æ§ /*ä¾å //ä¸å¯¹ä¸å¤é®å¯¼èª [Navigate(NavigateType.OneToOne, nameof(ClassAId))]//ä¸å¯¹ä¸ ClassAIdæ¯MES_ROUTE_ACT_VARç±»éé¢çå¤é®IDåæ®µ public ClassA ClassA { get; set; } //注æç¦æ¢æå¨èµå¼ï¼åªè½æ¯null //ä¸å¯¹å¤å¤é®å¯¼èª [Navigate(NavigateType.OneToMany, nameof(ClassA.MES_ROUTE_ACT_VARId))]//ClassA表ä¸çMES_ROUTE_ACT_VARId public List<ClassA> ClassAList { get; set; }//注æç¦æ¢æå¨èµå¼ï¼åªè½æ¯null //å¤å¯¹å¤å¤é®å¯¼èª [Navigate(typeof(MappingClass), nameof(MappingClass.MES_ROUTE_ACT_VARId), nameof(MappingClass.ClassAId))]//注æé¡ºåº public List<ClassA> ClassAList { get; set; } //注æç¦æ¢æå¨èµå¼ï¼åªè½æ¯null */ #endregion #region æä¸¾åé /*ä¾å public enum FieldNames { [Description("æä¸¾æè¿°0")] Enum0, [Description("æä¸¾æè¿°1")] Enum1, } */ /// <summary> /// æä¸¾ï¼åéå¼ç±»å(0Stringå符串|1Integeræ´å½¢|2Floatæµ®ç¹å|3DateTimeæ¥ææ¶é´) /// </summary> public enum VALUE_TYPEs { [Description("å符串")] String = 0, [Description("æ´å½¢")] Integer = 1, [Description("æµ®ç¹å")] Float = 2, [Description("æ¥ææ¶é´")] DateTime = 3, } #endregion #region å ¬å ±æ¹æ³ #endregion }//endClass } Tiger.Model.Net/Entitys/MES/MES_WIP_ACT.cs
@@ -194,6 +194,11 @@ [DisplayName("è¡ä¸ºæä½å¼5")] public string ACT_VALUE_5 { get; set; } /// <summary> /// è¡ä¸ºåéåå ¸ /// </summary> [DisplayName("è¡ä¸ºåéåå ¸")] public string ACT_VAR_DIC { get; set; } /// <summary> /// è¡ä¸ºæ¯å¦æå(Y/N) /// </summary> [DisplayName("è¡ä¸ºæ¯å¦æå(Y/N)")] Tiger.Model.Net/Entitys/MES/MES_WIP_ACT_VAR.cs
¶Ô±ÈÐÂÎļþ @@ -0,0 +1,276 @@ using System; using SqlSugar; using System.Linq; using System.ComponentModel; using System.Collections.Generic; namespace Tiger.Model { /// <summary> /// å®ä½ï¼ç产è¡ä¸ºåé /// </summary> [Description("Primary:ID")] [DisplayName("ç产è¡ä¸ºåé")] [Serializable] [SugarTable("MES_WIP_ACT_VAR")] public class MES_WIP_ACT_VAR : DbEntityWithAuth { #region æé 彿° /// <summary> /// å®ä½ï¼ç产è¡ä¸ºåé /// </summary> public MES_WIP_ACT_VAR() {} #endregion #region å ¬å ±å±æ§ /// <summary> /// å¨å¶åID /// </summary> [DisplayName("å¨å¶åID")] public string WIP_ID { get; set; } /// <summary> /// ç产è¿ç¨è®°å½ID /// </summary> [DisplayName("ç产è¿ç¨è®°å½ID")] public string HIS_ID { get; set; } /// <summary> /// è¿ç«æ¡ç /// </summary> [DisplayName("è¿ç«æ¡ç ")] public string SN { get; set; } /// <summary> /// ç©æç¼ç /// </summary> [DisplayName("ç©æç¼ç ")] public string ITEM_CODE { get; set; } /// <summary> /// å·¥åå· /// </summary> [DisplayName("å·¥åå·")] public string WORK_ORDER { get; set; } /// <summary> /// å·¥åæ¹æ¬¡å· /// </summary> [DisplayName("å·¥åæ¹æ¬¡å·")] public string BATCH_NO { get; set; } /// <summary> /// 客æ·ç¼ç /// </summary> [DisplayName("客æ·ç¼ç ")] public string CUST_CODE { get; set; } /// <summary> /// å·¥èºè·¯çº¿ç¼ç /// </summary> [DisplayName("å·¥èºè·¯çº¿ç¼ç ")] public string ROT_CODE { get; set; } /// <summary> /// å·¥èºè·¯çº¿èç¹ID /// </summary> [DisplayName("å·¥èºè·¯çº¿èç¹ID")] public string NODE_ID { get; set; } /// <summary> /// å·¥èºè·¯çº¿èç¹åç§° /// </summary> [DisplayName("å·¥èºè·¯çº¿èç¹åç§°")] public string NODE_NAME { get; set; } /// <summary> /// å·¥åè¡ä¸ºèç¹ID /// </summary> [DisplayName("å·¥åè¡ä¸ºèç¹ID")] public string ACT_ID { get; set; } /// <summary> /// è¡ä¸ºåç§° /// </summary> [DisplayName("è¡ä¸ºåç§°")] public string ACT_NAME { get; set; } /// <summary> /// å·¥åç¼ç /// </summary> [DisplayName("å·¥åç¼ç ")] public string FTY_CODE { get; set; } /// <summary> /// 车é´ç¼ç /// </summary> [DisplayName("车é´ç¼ç ")] public string WS_CODE { get; set; } /// <summary> /// 产线ç¼ç /// </summary> [DisplayName("产线ç¼ç ")] public string LINE_CODE { get; set; } /// <summary> /// å²ä½ç¼ç /// </summary> [DisplayName("å²ä½ç¼ç ")] public string POST_CODE { get; set; } /// <summary> /// å·¥åºç¼ç /// </summary> [DisplayName("å·¥åºç¼ç ")] public string OPER_CODE { get; set; } /// <summary> /// å 工段 /// </summary> [DisplayName("å 工段")] public string SEGMENT { get; set; } /// <summary> /// åå æµè½¬æ¡ç /// </summary> [DisplayName("åå æµè½¬æ¡ç ")] public string FLOW_SN { get; set; } /// <summary> /// æç/è½½å ·æ¡ç /// </summary> [DisplayName("æç/è½½å ·æ¡ç ")] public string TRAY_SN { get; set; } /// <summary> /// å å è£ æ¡ç /// </summary> [DisplayName("å å è£ æ¡ç ")] public string INNER_SN { get; set; } /// <summary> /// å¤ç®±æ¡ç /// </summary> [DisplayName("å¤ç®±æ¡ç ")] public string CARTON_SN { get; set; } /// <summary> /// æ æ¿æ¡ç /// </summary> [DisplayName("æ æ¿æ¡ç ")] public string PALLET_SN { get; set; } /// <summary> /// å½åæä½æ¶é´ /// </summary> [DisplayName("å½åæä½æ¶é´")] public DateTime OPERATION_TIME { get; set; } = DateTime.MinValue; /// <summary> /// çå¶ç¼ç /// </summary> [DisplayName("çå¶ç¼ç ")] public string SFTS_CODE { get; set; } /// <summary> /// çæ¬¡ç¼ç /// </summary> [DisplayName("çæ¬¡ç¼ç ")] public string SFT_CODE { get; set; } /// <summary> /// æ¶æ®µç¼ç /// </summary> [DisplayName("æ¶æ®µç¼ç ")] public string PRD_CODE { get; set; } /// <summary> /// è¡ä¸ºåéç¼ç /// </summary> [DisplayName("è¡ä¸ºåéç¼ç ")] public string VAR_CODE { get; set; } /// <summary> /// è¡ä¸ºåéåç§° /// </summary> [DisplayName("è¡ä¸ºåéåç§°")] public string VAR_NAME { get; set; } /// <summary> /// åéçæ§ä»¶ /// </summary> [DisplayName("åéçæ§ä»¶")] public string VAR_CONTROL { get; set; } /// <summary> /// åéå¼ç±»å(0Stringå符串|1Integeræ´å½¢|2Floatæµ®ç¹å|3DateTimeæ¥ææ¶é´) /// </summary> [DisplayName("åéå¼ç±»å(0Stringå符串|1Integeræ´å½¢|2Floatæµ®ç¹å|3DateTimeæ¥ææ¶é´)")] public int VALUE_TYPE { get; set; } /// <summary> /// è¾å ¥å¼ /// </summary> [DisplayName("è¾å ¥å¼")] public string INPUT_VALUE { get; set; } /// <summary> /// æä½å¼1 /// </summary> [DisplayName("æä½å¼1")] public string VALUE_1 { get; set; } /// <summary> /// æä½å¼2 /// </summary> [DisplayName("æä½å¼2")] public string VALUE_2 { get; set; } /// <summary> /// æä½å¼3 /// </summary> [DisplayName("æä½å¼3")] public string VALUE_3 { get; set; } /// <summary> /// æä½å¼4 /// </summary> [DisplayName("æä½å¼4")] public string VALUE_4 { get; set; } /// <summary> /// æä½å¼5 /// </summary> [DisplayName("æä½å¼5")] public string VALUE_5 { get; set; } /// <summary> /// 夿³¨ /// </summary> [DisplayName("夿³¨")] public string REMARK { get; set; } /// <summary> /// è¿½æº¯ä¿¡æ¯ /// </summary> [DisplayName("追溯信æ¯")] public string TRACE_INFO { get; set; } #endregion #region èæå±æ§ /*ä¾å [SugarColumn(IsIgnore = true)] public string FieldName { get; set; } */ #endregion #region å¤é®å±æ§ /*ä¾å //ä¸å¯¹ä¸å¤é®å¯¼èª [Navigate(NavigateType.OneToOne, nameof(ClassAId))]//ä¸å¯¹ä¸ ClassAIdæ¯MES_WIP_ACT_VARç±»éé¢çå¤é®IDåæ®µ public ClassA ClassA { get; set; } //注æç¦æ¢æå¨èµå¼ï¼åªè½æ¯null //ä¸å¯¹å¤å¤é®å¯¼èª [Navigate(NavigateType.OneToMany, nameof(ClassA.MES_WIP_ACT_VARId))]//ClassA表ä¸çMES_WIP_ACT_VARId public List<ClassA> ClassAList { get; set; }//注æç¦æ¢æå¨èµå¼ï¼åªè½æ¯null //å¤å¯¹å¤å¤é®å¯¼èª [Navigate(typeof(MappingClass), nameof(MappingClass.MES_WIP_ACT_VARId), nameof(MappingClass.ClassAId))]//注æé¡ºåº public List<ClassA> ClassAList { get; set; } //注æç¦æ¢æå¨èµå¼ï¼åªè½æ¯null */ #endregion #region æä¸¾åé /*ä¾å public enum FieldNames { [Description("æä¸¾æè¿°0")] Enum0, [Description("æä¸¾æè¿°1")] Enum1, } */ /// <summary> /// æä¸¾ï¼åéå¼ç±»å(0Stringå符串|1Integeræ´å½¢|2Floatæµ®ç¹å|3DateTimeæ¥ææ¶é´) /// </summary> public enum VALUE_TYPEs { [Description("å符串")] String = 0, [Description("æ´å½¢")] Integer = 1, [Description("æµ®ç¹å")] Float = 2, [Description("æ¥ææ¶é´")] DateTime = 3, } #endregion #region å ¬å ±æ¹æ³ #endregion }//endClass } Tiger.Model.Net/Entitys/MES/MES_WO_ACT_VAR.cs
¶Ô±ÈÐÂÎļþ @@ -0,0 +1,166 @@ using System; using SqlSugar; using System.Linq; using System.ComponentModel; using System.Collections.Generic; namespace Tiger.Model { /// <summary> /// å®ä½ï¼å·¥åè¡ä¸ºåé /// </summary> [Description("Primary:ID")] [DisplayName("å·¥åè¡ä¸ºåé")] [Serializable] [SugarTable("MES_WO_ACT_VAR")] public class MES_WO_ACT_VAR : DbEntityWithAuth { #region æé 彿° /// <summary> /// å®ä½ï¼å·¥åè¡ä¸ºåé /// </summary> public MES_WO_ACT_VAR() {} #endregion #region å ¬å ±å±æ§ /// <summary> /// å ³èå·¥åå· /// </summary> [DisplayName("å ³èå·¥åå·")] public string WORK_ORDER { get; set; } /// <summary> /// 产åç¼ç /// </summary> [DisplayName("产åç¼ç ")] public string PROD_CODE { get; set; } /// <summary> /// 客æ·ç¼ç /// </summary> [DisplayName("客æ·ç¼ç ")] public string CUST_CODE { get; set; } /// <summary> /// å·¥åè¡ä¸ºèç¹ID /// </summary> [DisplayName("å·¥åè¡ä¸ºèç¹ID")] public string ACT_ID { get; set; } /// <summary> /// è¡ä¸ºåéç¼ç /// </summary> [DisplayName("è¡ä¸ºåéç¼ç ")] public string VAR_CODE { get; set; } /// <summary> /// è¡ä¸ºåéåç§° /// </summary> [DisplayName("è¡ä¸ºåéåç§°")] public string VAR_NAME { get; set; } /// <summary> /// åéçæ§ä»¶ /// </summary> [DisplayName("åéçæ§ä»¶")] public string VAR_CONTROL { get; set; } /// <summary> /// åéå¼ç±»å(0Stringå符串|1Integeræ´å½¢|2Floatæµ®ç¹å|3DateTimeæ¥ææ¶é´) /// </summary> [DisplayName("åéå¼ç±»å(0Stringå符串|1Integeræ´å½¢|2Floatæµ®ç¹å|3DateTimeæ¥ææ¶é´)")] public int VALUE_TYPE { get; set; } /// <summary> /// æ¯å¦åªè¯»(Y/N) /// </summary> [DisplayName("æ¯å¦åªè¯»(Y/N)")] public string READONLY { get; set; } /// <summary> /// æ¯å¦æ¾ç¤º(Y/N) /// </summary> [DisplayName("æ¯å¦æ¾ç¤º(Y/N)")] public string VISIABLE { get; set; } /// <summary> /// é»è®¤å¼ /// </summary> [DisplayName("é»è®¤å¼")] public string DEFAULT { get; set; } /// <summary> /// 设置å¼1 /// </summary> [DisplayName("设置å¼1")] public string OPTION_1 { get; set; } /// <summary> /// 设置å¼2 /// </summary> [DisplayName("设置å¼2")] public string OPTION_2 { get; set; } /// <summary> /// 设置å¼3 /// </summary> [DisplayName("设置å¼3")] public string OPTION_3 { get; set; } /// <summary> /// 设置å¼4 /// </summary> [DisplayName("设置å¼4")] public string OPTION_4 { get; set; } /// <summary> /// 设置å¼5 /// </summary> [DisplayName("设置å¼5")] public string OPTION_5 { get; set; } /// <summary> /// 夿³¨ /// </summary> [DisplayName("夿³¨")] public string REMARK { get; set; } #endregion #region èæå±æ§ /*ä¾å [SugarColumn(IsIgnore = true)] public string FieldName { get; set; } */ #endregion #region å¤é®å±æ§ /*ä¾å //ä¸å¯¹ä¸å¤é®å¯¼èª [Navigate(NavigateType.OneToOne, nameof(ClassAId))]//ä¸å¯¹ä¸ ClassAIdæ¯MES_WO_ACT_VARç±»éé¢çå¤é®IDåæ®µ public ClassA ClassA { get; set; } //注æç¦æ¢æå¨èµå¼ï¼åªè½æ¯null //ä¸å¯¹å¤å¤é®å¯¼èª [Navigate(NavigateType.OneToMany, nameof(ClassA.MES_WO_ACT_VARId))]//ClassA表ä¸çMES_WO_ACT_VARId public List<ClassA> ClassAList { get; set; }//注æç¦æ¢æå¨èµå¼ï¼åªè½æ¯null //å¤å¯¹å¤å¤é®å¯¼èª [Navigate(typeof(MappingClass), nameof(MappingClass.MES_WO_ACT_VARId), nameof(MappingClass.ClassAId))]//注æé¡ºåº public List<ClassA> ClassAList { get; set; } //注æç¦æ¢æå¨èµå¼ï¼åªè½æ¯null */ #endregion #region æä¸¾åé /*ä¾å public enum FieldNames { [Description("æä¸¾æè¿°0")] Enum0, [Description("æä¸¾æè¿°1")] Enum1, } */ /// <summary> /// æä¸¾ï¼åéå¼ç±»å(0Stringå符串|1Integeræ´å½¢|2Floatæµ®ç¹å|3DateTimeæ¥ææ¶é´) /// </summary> public enum VALUE_TYPEs { [Description("å符串")] String = 0, [Description("æ´å½¢")] Integer = 1, [Description("æµ®ç¹å")] Float = 2, [Description("æ¥ææ¶é´")] DateTime = 3, } #endregion #region å ¬å ±æ¹æ³ #endregion }//endClass } Tiger.Model.Net/Entitys/WMS/Api/BaseInput.cs
@@ -2,53 +2,6 @@ namespace Tiger.Model { public class BaseInput { /// <summary> /// /// </summary> public AuthOption AuthOption { get; set; } /// <summary> /// æ¡ç /// </summary> public string SN { get; set; } /// <summary> /// æµ·å ³åå· /// </summary> public string CustomsNo { get; set; } } public class BasePageInput { public AuthOption AuthOption { get; set; } public int pageIndex { get; set; } public int pageSize { get; set; } public int total { get; set; } public string Code { get; set; } } public class BasePageOutput<T> { public List<T> data { get; set; } public int total { get; set; } } public class BaseCodeInput { public AuthOption AuthOption { get; set; } public string Code { get; set; } } public class OutOthDtlInput : BasePageInput { public bool IsItemCodeList { get; set; } } public class OutWoDtlInput : BasePageInput { public bool IsItemCodeList { get; set; } } } Tiger.Model.Net/Entitys/WMS/Api/Input_Entitys.cs
@@ -8,20 +8,62 @@ namespace Tiger.Model { public class ScanShelfInfo public class BaseInput { public string WarehouseCode { get; set; } public string RegionCode { get; set; } public string ShelfCode { get; set; } public string LocationCode { get; set; } public string RackCode => ShelfCode; public bool IsSmartRack { get; set; } public decimal Capacity { get; set; } public int LotCount { get; set; } public decimal MaxSize { get; set; } public int ShelfType { get; set; } public bool IsScanShelf { get; set; } public WMS_SHELF Shelf { get; set; } public WMS_LOCATION Location { get; set; } /// <summary> /// æ°æ®åºæææ¥è¯¢é项 /// </summary> public AuthOption AuthOption { get; set; } /// <summary> /// 客æ·ç«¯æ¾ç¤ºçè¯è¨ /// </summary> public string Locale { get; set; } /// <summary> /// æä½æä»¤ /// </summary> public string Command { get; set; } /// <summary> /// æ¡ç /// </summary> public string SN { get; set; } /// <summary> /// å½åæä½éè¦æäº¤çé项 /// </summary> public Dictionary<string, string> Options { get; set; } = new Dictionary<string, string>(); /// <summary> /// å½åæä½éè¦æäº¤çæ°æ® /// </summary> public string Data { get; set; } } public class BasePageInput { public AuthOption AuthOption { get; set; } public int pageIndex { get; set; } public int pageSize { get; set; } public int total { get; set; } public string Code { get; set; } } public class BasePageOutput<T> { public List<T> data { get; set; } public int total { get; set; } } public class BaseCodeInput { public AuthOption AuthOption { get; set; } public string Code { get; set; } } public class OutOthDtlInput : BasePageInput { public bool IsItemCodeList { get; set; } } public class OutWoDtlInput : BasePageInput { public bool IsItemCodeList { get; set; } } } Tiger.Model.Net/Entitys/WMS/Api/Output_Entitys.cs
@@ -4,10 +4,49 @@ using System.Linq; using System.Text; using System.Threading.Tasks; using Tiger.Model.Entitys.MES.Position; using Tiger.Model.Minsun; namespace Tiger.Model { public class ScanOutput<T> { /// <summary> /// æä½æä»¤ /// </summary> public string Command { get; set; } /// <summary> /// Mqttæ¶æ¯ /// </summary> public MQTT.Message MqttMsg { get; set; } /// <summary> /// å½åæä½è¿åçæ°æ® /// </summary> public T Data { get; set; } } public class ScanOutput : ScanOutput<object> { } public class ScanShelfInfo { public string WarehouseCode { get; set; } public string RegionCode { get; set; } public string ShelfCode { get; set; } public string LocationCode { get; set; } public string RackCode => ShelfCode; public bool IsSmartRack { get; set; } public decimal Capacity { get; set; } public int LotCount { get; set; } public decimal MaxSize { get; set; } public int ShelfType { get; set; } public bool IsScanShelf { get; set; } public WMS_SHELF Shelf { get; set; } public WMS_LOCATION Location { get; set; } } public class DefaultScanItemOutput { public int ReqType { get; set; } @@ -24,7 +63,6 @@ public string ScanAfCut { get; set; } public string Unit { get; set; } public DateTime DateCode { get; set; } public string Message { get; set; } } public class DefaultInStoreOutput Tiger.Model.Net/Tiger.Model.Net.csproj
@@ -80,6 +80,9 @@ <Compile Include="DTO\MESDTO.cs" /> <Compile Include="Entitys\MES\ParameterEntity\BizPrintInstoreDocParameter.cs" /> <Compile Include="Entitys\BAS\BAS_ITEM_DOC.cs" /> <Compile Include="Entitys\MES\YadaU9\mes_Bin.cs" /> <Compile Include="Entitys\MES\YadaU9\mes_MaterialBarCode.cs" /> <Compile Include="Entitys\MES\YadaU9\mes_Wh.cs" /> <Compile Include="Entitys\MQTTEntity.cs" /> <Compile Include="Entitys\Api\Base.cs" /> <Compile Include="Entitys\Automate\SNInfo.cs" />