using JNPF.Common.Core.Manager; using JNPF.Common.Dtos.VisualDev; using JNPF.Systems.Interfaces.System; using JNPF.VisualDev; using JNPF.VisualDev.Interfaces; using Microsoft.Extensions.Logging; using Newtonsoft.Json; using Newtonsoft.Json.Linq; using SqlSugar; using Tnb.WarehouseMgr.Entities; using Tnb.WarehouseMgr.Entities.Dto.Inputs; using Tnb.WarehouseMgr.Interfaces; namespace Tnb.WarehouseMgr { /// /// 异常取消 /// [OverideVisualDev(ModuleConsts.MODULE_WMSEXCPTIONCOMPLETEPDA_ID)] public class WmsPDAExceptionCompleteService : BaseWareHouseService, IPdaStroage { private readonly ISqlSugarClient _db; private readonly IRunService _runService; private readonly IVisualDevService _visualDevService; private readonly IWareHouseService _wareHouseService; private readonly IBillRullService _billRullService; private readonly IUserManager _userManager; public WmsPDAExceptionCompleteService( ISqlSugarRepository repository, IRunService runService, IVisualDevService visualDevService, IWareHouseService wareHouseService, IUserManager userManager, IBillRullService billRullService) { _db = repository.AsSugarClient(); _runService = runService; _visualDevService = visualDevService; _wareHouseService = wareHouseService; _userManager = userManager; _billRullService = billRullService; OverideFuncs.CreateAsync = ExceptionComplete; } private async Task ExceptionComplete(VisualDevModelDataCrInput input) { try { Logger.LogWarning($"【ExceptionComplete】 {JsonConvert.SerializeObject(input)}"); await _db.Ado.BeginTranAsync(); TaskCompleUpInput taskCompleUpInput = new(); List list = new(); if (input.data.ContainsKey(nameof(WmsDistaskH.id))) { list.Add(input.data[nameof(WmsDistaskH.id)].ToString()!); taskCompleUpInput.disTaskIds = list; await _wareHouseService.TaskComplate(taskCompleUpInput); } await _db.Ado.CommitTranAsync(); } catch (Exception) { await _db.Ado.RollbackTranAsync(); throw; } return Task.FromResult(true); } } }