You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

132 lines
5.4 KiB

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<SalePriceReader> _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<SalePriceReader> 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<List<IncomingFromExternal>> ReadAsync()
{
//从Tyrp读取待处理SalePrice
var toBeProcessedSalePrices = await _iSalePriceManager.GetToBeProcessedListAsync().ConfigureAwait(false);
if (!toBeProcessedSalePrices.Any())
{
_logger.LogInformation("no SalePrices");
return new List<IncomingFromExternal>();
}
//获取wms销售单价数据
SfsBaseDataRequestInputBase input = new SfsBaseDataRequestInputBase();
var wmsSalePrices = await _SalePriceAppService.GetAllListByFilterAsync(input).ConfigureAwait(false);
var wmsToSalePriceExchangeDtos = _objectMapper.Map<List<SalePriceSheetDTO>, List<SalePriceExchangeDto>>(wmsSalePrices);
List<SalePriceExchangeDto> eosToBomExchangeDtos = new List<SalePriceExchangeDto>();
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<IncomingFromExternal>();
}
//SalePrice逐一转换为SalePrice
var incomingDataList = BuildIncomingFromExternalFromBomAsync(updateDatas, toBeProcessedSalePrices);
await _incomingFromExternalManager.CreateBulkAsync(incomingDataList).ConfigureAwait(false);
return incomingDataList;
}
private List<IncomingFromExternal> BuildIncomingFromExternalFromBomAsync(List<SalePriceExchangeDto> updateDatas, List<spriceout> toBeProcessedSalePrices)
{
var incomingDataList = new List<IncomingFromExternal>();
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;
}
}