using System.Collections.Generic;
using System.Linq;
using System.Text.Json;
using System.Threading.Tasks;
using Volo.Abp.Uow;
using Win_in.Sfs.Wms.DataExchange.Domain;
using Win_in.Sfs.Wms.DataExchange.Domain.Fawtyg.Tyrp;
using Win_in.Sfs.Wms.DataExchange.Domain.Shared;
namespace Win_in.Sfs.Wms.DataExchange.Fawtyg.TyrpAgent.Outgoing;
public class ScontrolWriter : IWriter
{
private readonly IScontrolManager _dataInterfaceManager;
private readonly IOutgoingToExternalManager _outgoingToExternalManager;
public ScontrolWriter(IScontrolManager dataInterfaceManager, IOutgoingToExternalManager outgoingToExternalManager)
{
_dataInterfaceManager = dataInterfaceManager;
_outgoingToExternalManager = outgoingToExternalManager;
}
///
/// 写入数据
///
///
///
public virtual async Task WriteAsync(List outgoingDataList)
{
var groups = outgoingDataList.GroupBy(r => r.SourceDataGroupCode);
foreach (var group in groups)
{
var dataInterfaceList = new List();
var dataInterfaceDetailList = new List();
var entitys = group.ToList();
foreach (var entity in entitys)
{
if (entity.TableType == EnumExchangeTableType.MainTable)//主表(MainTable)
{
var receipt = JsonSerializer.Deserialize(entity.DestinationDataContent);
dataInterfaceList.Add(receipt);
}
else if (entity.TableType == EnumExchangeTableType.DetailTable) // 子表(DetailTable)
{
var receiptDetail = JsonSerializer.Deserialize(entity.DestinationDataContent);
dataInterfaceDetailList.Add(receiptDetail);
}
}
try
{
//dataInterface分主子表分别写入ERP
await _dataInterfaceManager.PostListAsync(dataInterfaceList, dataInterfaceDetailList).ConfigureAwait(false);
}
catch (System.Exception ex)
{
foreach (var item in entitys)
{
item.SetError(EnumExchangeDataErrorCode.Exception, ex.Message, ex.ToString());
}
}
}
//将数据归档
await _outgoingToExternalManager.ArchiveManyAsync(outgoingDataList).ConfigureAwait(false);
}
}