using System; using System.Collections.Generic; using System.Linq; using System.Text.Json; using System.Threading.Tasks; using Microsoft.Extensions.Configuration; using Microsoft.Extensions.Logging; using Volo.Abp.Guids; using Volo.Abp.ObjectMapping; using Win_in.Sfs.Basedata.Application.Contracts; using Win_in.Sfs.Wms.DataExchange.Domain; using Win_in.Sfs.Wms.DataExchange.Domain.Fawtyg.Tyrp; using Win_in.Sfs.Wms.DataExchange.Domain.Shared; using Win_in.Sfs.Wms.DataExchange.WMS.SalePrice; namespace Win_in.Sfs.Wms.DataExchange.Fawtyg.TyrpAgent.Incoming; public class SalePriceReader : IReader { private readonly ISalePriceManager _iSalePriceManager; private readonly IIncomingFromExternalManager _incomingFromExternalManager; private readonly ILogger _logger; private readonly IGuidGenerator _guidGenerator; private readonly IConfiguration _configuration; private readonly ISalePriceSheetAppService _SalePriceAppService; private readonly IObjectMapper _objectMapper; public SalePriceReader( ISalePriceManager iSalePriceManager , IIncomingFromExternalManager incomingFromExternalManager , IGuidGenerator guidGenerator , ILogger logger , IConfiguration configuration, ISalePriceSheetAppService SalePriceSheetAppService, IObjectMapper objectMapper ) { _guidGenerator = guidGenerator; _configuration = configuration; _iSalePriceManager = iSalePriceManager; _incomingFromExternalManager = incomingFromExternalManager; _logger = logger; _SalePriceAppService = SalePriceSheetAppService; _objectMapper = objectMapper; } public virtual async Task> ReadAsync() { //从Tyrp读取待处理SalePrice var toBeProcessedSalePrices = await _iSalePriceManager.GetToBeProcessedListAsync().ConfigureAwait(false); if (!toBeProcessedSalePrices.Any()) { _logger.LogInformation("no SalePrices"); return new List(); } //获取wms销售单价数据 SfsBaseDataRequestInputBase input = new SfsBaseDataRequestInputBase(); var wmsSalePrices = await _SalePriceAppService.GetAllListByFilterAsync(input).ConfigureAwait(false); var wmsToSalePriceExchangeDtos = _objectMapper.Map, List>(wmsSalePrices); List eosToBomExchangeDtos = new List(); foreach (var toBeProcessedSalePrice in toBeProcessedSalePrices) { var SalePrice = BuildScrapNoteOrderExchangeMes(toBeProcessedSalePrice); eosToBomExchangeDtos.Add(SalePrice); } //和wms和eos数据进行比较,获取需要处理得数据 var updateDatas = eosToBomExchangeDtos.Except(wmsToSalePriceExchangeDtos).ToList(); if (!updateDatas.Any()) { _logger.LogInformation("no SalePrices"); return new List(); } //SalePrice逐一转换为SalePrice var incomingDataList = BuildIncomingFromExternalFromBomAsync(updateDatas, toBeProcessedSalePrices); await _incomingFromExternalManager.CreateBulkAsync(incomingDataList).ConfigureAwait(false); return incomingDataList; } private List BuildIncomingFromExternalFromBomAsync(List updateDatas, List toBeProcessedSalePrices) { var incomingDataList = new List(); foreach (var data in updateDatas) { var item = toBeProcessedSalePrices.FirstOrDefault(r => r.spriceout_part == data.ItemCode && r.spriceout_cust == data.CustomerCode); var incomingData = BuildIncomingFromExternal(item); incomingData.SetEffectiveDate(DateTime.Now); try { incomingData.DestinationDataContent = JsonSerializer.Serialize(data); incomingData.SetId(_guidGenerator.Create()); } catch (Exception ex) { incomingData.SetError(EnumExchangeDataErrorCode.Exception, ex.Message, ex.ToString()); } incomingDataList.Add(incomingData); } return incomingDataList; } private IncomingFromExternal BuildIncomingFromExternal(spriceout SalePrice) { var incomingData = new IncomingFromExternal() { DataType = EnumIncomingDataType.SalePrice.ToString(), DataAction = EnumExchangeDataAction.Add, SourceSystem = EnumSystemType.ERP.ToString(), SourceDataId = SalePrice.spriceout_part, SourceDataGroupCode = SalePrice.spriceout_part, SourceDataDetailCode = SalePrice.spriceout_cust, SourceDataContent = JsonSerializer.Serialize(SalePrice), WriteTime = DateTime.Now, Writer = nameof(TyrpIncomingBackgroundWorker), DestinationSystem = EnumSystemType.ERP.ToString(), }; return incomingData; } private static SalePriceExchangeDto BuildScrapNoteOrderExchangeMes(spriceout SalePrice) { var price = new SalePriceExchangeDto() { ItemCode = SalePrice.spriceout_part, CustomerCode = SalePrice.spriceout_cust, SalePrice = SalePrice.spriceout_price, Description = "接口同步", }; return price; } }