调整盘盈盘亏同步
This commit is contained in:
@@ -1,11 +1,13 @@
|
||||
using AutoMapper;
|
||||
using Microsoft.EntityFrameworkCore.Storage;
|
||||
using Microsoft.Extensions.Logging;
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using System.Text;
|
||||
using System.Threading.Tasks;
|
||||
using WMS.Web.Core.Dto;
|
||||
using WMS.Web.Core.Dto.Erp;
|
||||
using WMS.Web.Core.Dto.Erp.TakeStock;
|
||||
using WMS.Web.Core.Dto.Login;
|
||||
using WMS.Web.Core.Dto.TakeStock;
|
||||
@@ -32,10 +34,11 @@ namespace WMS.Web.Domain.Services
|
||||
private readonly ILoginRepositories _loginRepositories;
|
||||
private readonly ISingleDataService _singleDataService;
|
||||
private readonly IErpService _erpService;
|
||||
private readonly ILogger<TakeStockService> _logger;
|
||||
public TakeStockService(IMapper mapper, ILoginService loginService,
|
||||
IBasicsRepositories transactionRepositories,
|
||||
ITakeStockRepositories takeStockRepositories, ILoginRepositories loginRepositories,
|
||||
ISingleDataService singleDataService, IErpService erpService)
|
||||
ISingleDataService singleDataService, IErpService erpService, ILogger<TakeStockService> logger)
|
||||
{
|
||||
_mapper = mapper;
|
||||
_loginService = loginService;
|
||||
@@ -44,6 +47,7 @@ namespace WMS.Web.Domain.Services
|
||||
_loginRepositories = loginRepositories;
|
||||
_singleDataService = singleDataService;
|
||||
_erpService = erpService;
|
||||
_logger = logger;
|
||||
}
|
||||
/// <summary>
|
||||
/// 保存
|
||||
@@ -93,52 +97,6 @@ namespace WMS.Web.Domain.Services
|
||||
return Result.ReSuccess();
|
||||
}
|
||||
/// <summary>
|
||||
/// 作废
|
||||
/// </summary>
|
||||
/// <param name="entity"></param>
|
||||
/// <returns></returns>
|
||||
public async Task<Result> Profit(TakeStock entity)
|
||||
{
|
||||
//获取金蝶仓库仓位编码
|
||||
//var stockCode = _singleDataService.GetSingleDataCode(SingleAction.Stocks, _loginRepositories.CompanyId, entity.StockCode);
|
||||
var subStockCode = _singleDataService.GetSingleDataCode(SingleAction.Stocks, _loginRepositories.CompanyId, entity.SubStockId);
|
||||
|
||||
var res = await _erpService.BillQueryForStock();
|
||||
var stock = res.Data.FirstOrDefault(f => f.Code == entity.StockCode);//需要根据单点code搜索
|
||||
var subStock = res.Data.FirstOrDefault(f => f.Code == subStockCode);//需要根据单点code搜索
|
||||
if (stock == null || subStock == null) return Result.ReFailure(ResultCodes.ErpStockNoData);
|
||||
//组装dto
|
||||
#region 组装dto
|
||||
List<ErpTakeStockDetailsSaveDto> detils = new List<ErpTakeStockDetailsSaveDto>();
|
||||
detils.Add(new ErpTakeStockDetailsSaveDto()
|
||||
{
|
||||
FOwnerid = stock.OrgId.ToString(),
|
||||
FKeeperId = stock.OrgId.ToString(),
|
||||
MaterialId = entity.MaterialId.ToString(),
|
||||
UnitId = "",//物料带出来
|
||||
StockId = stock.Id.ToString(),
|
||||
SubStockId = subStock.Id.ToString(),
|
||||
BeforeQty = entity.BeforeQty,
|
||||
AfterQty = entity.AfterQty,
|
||||
FinalQty = entity.FinalQty,
|
||||
Fnote = ""
|
||||
});
|
||||
ErpTakeStockSaveDto dto = new ErpTakeStockSaveDto()
|
||||
{
|
||||
BillNo = entity.BillNo,
|
||||
StockOrgId = stock.OrgId.ToString(),
|
||||
Type = "PY01_SYS",
|
||||
Date = entity.Date,
|
||||
Details = detils
|
||||
};
|
||||
#endregion
|
||||
|
||||
var resSync = await _erpService.Save<ErpTakeStockSaveDto>(dto, FormIdParam.STK_StockCountGain.ToString());
|
||||
entity.Sync(resSync.IsSuccess, resSync.Message);
|
||||
await _takeStockRepositories.Edit(entity, true);
|
||||
return res;
|
||||
}
|
||||
/// <summary>
|
||||
/// 盘盈盘亏同步金蝶
|
||||
/// </summary>
|
||||
/// <param name="entity"></param>
|
||||
@@ -180,10 +138,56 @@ namespace WMS.Web.Domain.Services
|
||||
#endregion
|
||||
//判断盘盈盘亏
|
||||
string formId = entity.ResultType == TakeStockType.Loss ? FormIdParam.STK_StockCountLoss.ToString() : FormIdParam.STK_StockCountGain.ToString();
|
||||
var resSync = await _erpService.Save<ErpTakeStockSaveDto>(dto, formId);
|
||||
//操作金蝶
|
||||
var resSync = await ErpOperate(dto, formId);
|
||||
entity.Sync(resSync.IsSuccess, resSync.Message);
|
||||
await _takeStockRepositories.Edit(entity, true);
|
||||
return res;
|
||||
}
|
||||
/// <summary>
|
||||
/// 同步金蝶操作
|
||||
/// </summary>
|
||||
/// <param name="dto"></param>
|
||||
/// <param name="formId"></param>
|
||||
/// <returns></returns>
|
||||
private async Task<Result> ErpOperate(ErpTakeStockSaveDto dto, string formId)
|
||||
{
|
||||
var res = await _erpService.Save<ErpTakeStockSaveDto>(dto, formId);
|
||||
if (!res.IsSuccess)
|
||||
return res;
|
||||
//提交
|
||||
ErpOperateDto o_dto = new ErpOperateDto(formId, "");
|
||||
res = await _erpService.Submit(o_dto, formId);
|
||||
if (!res.IsSuccess)
|
||||
{
|
||||
//如果提交失败
|
||||
//1.则调删单接口
|
||||
var del_res = await _erpService.Delete(o_dto, formId);
|
||||
if (!del_res.IsSuccess)
|
||||
_logger.LogError($"盘盈盘亏同步金蝶 单号:{dto.BillNo} 提交失败原因: {res.Message} 删单失败原因:{del_res.Message}");
|
||||
return res;
|
||||
}
|
||||
//审核
|
||||
res = await _erpService.Audit(o_dto, formId);
|
||||
if (!res.IsSuccess)
|
||||
{
|
||||
//如果审核失败
|
||||
//1.调反审核接口
|
||||
//2.调删除接口
|
||||
var noAudit_res = await _erpService.NoAudit(o_dto, formId);
|
||||
if (!noAudit_res.IsSuccess)
|
||||
{
|
||||
_logger.LogError($"盘盈盘亏同步金蝶 单号:{dto.BillNo} 审核失败原因: {res.Message} 反审核失败原因:{noAudit_res.Message}");
|
||||
return res;
|
||||
}
|
||||
|
||||
var del_res = await _erpService.Delete(o_dto, formId);
|
||||
if (!del_res.IsSuccess)
|
||||
_logger.LogError($"盘盈盘亏同步金蝶 单号:{dto.BillNo} 审核失败原因: {res.Message} 删单失败原因:{del_res.Message}");
|
||||
return res;
|
||||
}
|
||||
|
||||
return Result.ReSuccess();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user