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.

176 lines
6.3 KiB

2 years ago
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text.Json;
using System.Threading.Tasks;
using Microsoft.Extensions.Logging;
2 years ago
using Volo.Abp.Guids;
using Win_in.Sfs.Basedata.Application.Contracts;
2 years ago
using Win_in.Sfs.Shared.Domain.Shared;
using Win_in.Sfs.Wms.DataExchange.Domain;
using Win_in.Sfs.Wms.DataExchange.Domain.Fawtyg.EOS;
using Win_in.Sfs.Wms.DataExchange.Domain.Shared;
using Win_in.Sfs.Wms.DataExchange.WMS.PurchaseOrder;
namespace Win_in.Sfs.Wms.DataExchange.Fawtyg.EosAgent;
public class PlanReader : IReader
{
private readonly IPlanManager _planManager;
private readonly IIncomingFromExternalManager _incomingFromExternalManager;
private readonly ILogger<PlanReader> _logger;
2 years ago
private readonly IGuidGenerator _guidGenerator;
private readonly IPurchasePriceSheetAppService _purchasePriceSheetAppService;
2 years ago
public PlanReader(
IPlanManager planManager
, IIncomingFromExternalManager incomingFromExternalManager
, ILogger<PlanReader> logger
, IGuidGenerator guidGenerator,
IPurchasePriceSheetAppService purchasePriceSheetAppService
2 years ago
)
{
_planManager = planManager;
_incomingFromExternalManager = incomingFromExternalManager;
_logger = logger;
2 years ago
_guidGenerator = guidGenerator;
_purchasePriceSheetAppService = purchasePriceSheetAppService;
2 years ago
2 years ago
}
public virtual async Task<List<IncomingFromExternal>> ReadAsync()
{
//从EOS读取待处理Plan
2 years ago
var toBeProcessedPlans = await _planManager.GetToBeProcessedListAsync().ConfigureAwait(false);
2 years ago
if (!toBeProcessedPlans.Any())
{
_logger.LogInformation("no plans");
return new List<IncomingFromExternal>();
}
var pobillno = await GetPriceItems(toBeProcessedPlans).ConfigureAwait(false);
if (pobillno.Count > 0)
{
toBeProcessedPlans = toBeProcessedPlans.Where(r => !pobillno.Contains(r.PlanBillNo)).ToList();
}
2 years ago
//Plan逐一转换为PurchaseOrder
var incomingDataList = BuildIncomingFromExternalFromPlanAsync(toBeProcessedPlans);
2 years ago
await _incomingFromExternalManager.CreateBulkAsync(incomingDataList).ConfigureAwait(false);
2 years ago
//更新EOS数据状态
await _planManager.UpdateProcessedListAsync(toBeProcessedPlans).ConfigureAwait(false);
return incomingDataList;
}
private async Task<List<string>> GetPriceItems(List<Plan> toBeProcessedPlans)
{
List<string> pobillno = new List<string>();
2 years ago
foreach (var plan in toBeProcessedPlans)
{
if (pobillno.Contains(plan.PlanBillNo)) continue;
var price = await _purchasePriceSheetAppService.GetByItemCodeAsync(plan.ERP,plan.SupplierCode).ConfigureAwait(false);
if (price == null)
{
pobillno.Add(plan.PlanBillNo);
}
}
return pobillno;
}
2 years ago
private List<IncomingFromExternal> BuildIncomingFromExternalFromPlanAsync(List<Plan> toBeProcessedPlans)
{
var incomingDataList = new List<IncomingFromExternal>();
foreach (var plan in toBeProcessedPlans)
{
var incomingData = BuildIncomingFromExternal(plan);
incomingData.SetEffectiveDate(plan.EosDate);
2 years ago
incomingData.SetId(_guidGenerator.Create());
2 years ago
try
{
var po = BuildPurchaseOrderExchangeDto(plan);
incomingData.DestinationDataContent = JsonSerializer.Serialize(po);
}
catch (Exception ex)
{
incomingData.SetError(EnumExchangeDataErrorCode.Exception, ex.Message, ex.ToString());
}
incomingDataList.Add(incomingData);
}
return incomingDataList;
}
private IncomingFromExternal BuildIncomingFromExternal(Plan plan)
{
var incomingData = new IncomingFromExternal()
{
DataType = EnumIncomingDataType.PurchaseOrder.ToString(),
DataAction = plan.PlanBillState switch
{
0 => EnumExchangeDataAction.Add,
1 => EnumExchangeDataAction.Delete,
10 months ago
2=> EnumExchangeDataAction.Modify,
2 years ago
_ => throw new ArgumentOutOfRangeException()
},
SourceSystem = EnumSystemType.SCP.ToString(),
SourceDataId = plan.Id.ToString(),
SourceDataGroupCode = plan.PlanBillNo,
SourceDataDetailCode = plan.ERP,
SourceDataContent = JsonSerializer.Serialize(plan),
WriteTime = DateTime.Now,
Writer = nameof(EosIncomingBackgroundWorker),
DestinationSystem = EnumSystemType.WMS.ToString(),
};
return incomingData;
}
private static PurchaseOrderExchangeDto BuildPurchaseOrderExchangeDto(Plan plan)
{
var po = new PurchaseOrderExchangeDto()
{
Number = plan.PlanBillNo,
SupplierCode = plan.SupplierCode,
OrderDate = plan.ReleaseDate,
DueDate = plan.PlanArriveDate,
ContactName = plan.PlanUserCode,
//OrderStatus = plan.PlanBillState == 0
// ? EnumOrderStatus.Open
// : EnumOrderStatus.Close,
OrderStatus= EnumOrderStatus.Open,
2 years ago
ActiveDate = plan.EosDate,
Worker = plan.PlanUserCode,
// PoType = "2",
// IsConsignment = false,
// Version = "",
// TaxRate = 0,
// WarehouseCode = "",
// Remark = plan.PlanMemo,
};
var poDetail = new PurchaseOrderDetailExchangeDto()
{
LocationErpCode = plan.Loc,
Uom = plan.Unit,
Qty = plan.Qty,
ItemCode = plan.ERP,
ProjectCode = plan.XmCode,
LineStatus = plan.PlanBillState == 0
? EnumOrderStatus.Open
: EnumOrderStatus.Close,
Remark = plan.PlanMemo,
Lot="",
2 years ago
// PoLine = "",
// SupplierPackUom = plan.Unit,
// SupplierPackQty = plan.Qty,
// StdPackUom = plan.Unit,
// StdPackQty = plan.Qty,
// ConvertRate = 1,
// IsConsignment = false,
};
po.Detail = poDetail;
return po;
}
}