调整同步状态
This commit is contained in:
@@ -1091,7 +1091,7 @@
|
|||||||
</summary>
|
</summary>
|
||||||
<param name="operateId"></param>
|
<param name="operateId"></param>
|
||||||
</member>
|
</member>
|
||||||
<member name="M:WMS.Web.Domain.Entitys.OutStock.SyncFail(System.String,System.Int32)">
|
<member name="M:WMS.Web.Domain.Entitys.OutStock.SyncFail(System.String,System.Int32,WMS.Web.Domain.Values.SyncStatus)">
|
||||||
<summary>
|
<summary>
|
||||||
同步金蝶(失败)
|
同步金蝶(失败)
|
||||||
</summary>
|
</summary>
|
||||||
@@ -1561,7 +1561,7 @@
|
|||||||
</member>
|
</member>
|
||||||
<member name="P:WMS.Web.Domain.Entitys.TakeStock.SuccessSync">
|
<member name="P:WMS.Web.Domain.Entitys.TakeStock.SuccessSync">
|
||||||
<summary>
|
<summary>
|
||||||
同步成功或者失败 null 就是未同步
|
同步状态
|
||||||
</summary>
|
</summary>
|
||||||
</member>
|
</member>
|
||||||
<member name="P:WMS.Web.Domain.Entitys.TakeStock.BoxId">
|
<member name="P:WMS.Web.Domain.Entitys.TakeStock.BoxId">
|
||||||
@@ -1631,7 +1631,7 @@
|
|||||||
</summary>
|
</summary>
|
||||||
<param name="creatorId"></param>
|
<param name="creatorId"></param>
|
||||||
</member>
|
</member>
|
||||||
<member name="M:WMS.Web.Domain.Entitys.TakeStock.Sync(System.Boolean,System.String)">
|
<member name="M:WMS.Web.Domain.Entitys.TakeStock.Sync(System.Boolean,System.String,WMS.Web.Domain.Values.SyncStatus)">
|
||||||
<summary>
|
<summary>
|
||||||
同步金蝶结果
|
同步金蝶结果
|
||||||
</summary>
|
</summary>
|
||||||
@@ -2580,6 +2580,14 @@
|
|||||||
<param name="materialId"></param>
|
<param name="materialId"></param>
|
||||||
<returns></returns>
|
<returns></returns>
|
||||||
</member>
|
</member>
|
||||||
|
<member name="M:WMS.Web.Domain.IService.Public.IErpBasicDataExtendService.GetMaterialUnitId(System.Collections.Generic.List{WMS.Web.Core.Dto.Erp.ErpMaterialDto},System.Int32)">
|
||||||
|
<summary>
|
||||||
|
获取物料基本单位id
|
||||||
|
</summary>
|
||||||
|
<param name="erpMaterials"></param>
|
||||||
|
<param name="materialId"></param>
|
||||||
|
<returns></returns>
|
||||||
|
</member>
|
||||||
<member name="M:WMS.Web.Domain.IService.Public.IErpBasicDataExtendService.GetOrgName(System.Collections.Generic.List{WMS.Web.Core.Dto.Erp.Org.ErpOrgDto},System.Int32)">
|
<member name="M:WMS.Web.Domain.IService.Public.IErpBasicDataExtendService.GetOrgName(System.Collections.Generic.List{WMS.Web.Core.Dto.Erp.Org.ErpOrgDto},System.Int32)">
|
||||||
<summary>
|
<summary>
|
||||||
获取组织名称
|
获取组织名称
|
||||||
@@ -3899,6 +3907,14 @@
|
|||||||
<param name="materialId"></param>
|
<param name="materialId"></param>
|
||||||
<returns></returns>
|
<returns></returns>
|
||||||
</member>
|
</member>
|
||||||
|
<member name="M:WMS.Web.Domain.Services.Public.ErpBasicDataExtendService.GetMaterialUnitId(System.Collections.Generic.List{WMS.Web.Core.Dto.Erp.ErpMaterialDto},System.Int32)">
|
||||||
|
<summary>
|
||||||
|
获取物料基本单位Id
|
||||||
|
</summary>
|
||||||
|
<param name="erpMaterials"></param>
|
||||||
|
<param name="materialId"></param>
|
||||||
|
<returns></returns>
|
||||||
|
</member>
|
||||||
<member name="M:WMS.Web.Domain.Services.Public.ErpBasicDataExtendService.GetOrgName(System.Collections.Generic.List{WMS.Web.Core.Dto.Erp.Org.ErpOrgDto},System.Int32)">
|
<member name="M:WMS.Web.Domain.Services.Public.ErpBasicDataExtendService.GetOrgName(System.Collections.Generic.List{WMS.Web.Core.Dto.Erp.Org.ErpOrgDto},System.Int32)">
|
||||||
<summary>
|
<summary>
|
||||||
获取组织名称
|
获取组织名称
|
||||||
@@ -5578,6 +5594,26 @@
|
|||||||
获取仓位详情:根据仓位ID集合和公司ID
|
获取仓位详情:根据仓位ID集合和公司ID
|
||||||
</summary>
|
</summary>
|
||||||
</member>
|
</member>
|
||||||
|
<member name="T:WMS.Web.Domain.Values.SyncStatus">
|
||||||
|
<summary>
|
||||||
|
同步金蝶状态
|
||||||
|
</summary>
|
||||||
|
</member>
|
||||||
|
<member name="F:WMS.Web.Domain.Values.SyncStatus.Fail">
|
||||||
|
<summary>
|
||||||
|
失败
|
||||||
|
</summary>
|
||||||
|
</member>
|
||||||
|
<member name="F:WMS.Web.Domain.Values.SyncStatus.Success">
|
||||||
|
<summary>
|
||||||
|
成功
|
||||||
|
</summary>
|
||||||
|
</member>
|
||||||
|
<member name="F:WMS.Web.Domain.Values.SyncStatus.PortionSuccess">
|
||||||
|
<summary>
|
||||||
|
部分成功(数据保存成功,提交或者审核失败)
|
||||||
|
</summary>
|
||||||
|
</member>
|
||||||
<member name="T:WMS.Web.Domain.Values.TakeStockType">
|
<member name="T:WMS.Web.Domain.Values.TakeStockType">
|
||||||
<summary>
|
<summary>
|
||||||
盘点单类型
|
盘点单类型
|
||||||
|
|||||||
@@ -80,7 +80,7 @@ namespace WMS.Web.Domain.Entitys
|
|||||||
/// 同步成功或者失败 默认是失败状态
|
/// 同步成功或者失败 默认是失败状态
|
||||||
/// </summary>
|
/// </summary>
|
||||||
[Column("SuccessSync")]
|
[Column("SuccessSync")]
|
||||||
public bool SuccessSync { get; set; } = false;
|
public SyncStatus SuccessSync { get; set; } = SyncStatus.Fail;
|
||||||
///// <summary>
|
///// <summary>
|
||||||
///// 同步失败的源订单号(默认就包含所有来源单号)
|
///// 同步失败的源订单号(默认就包含所有来源单号)
|
||||||
///// </summary>
|
///// </summary>
|
||||||
@@ -118,15 +118,15 @@ namespace WMS.Web.Domain.Entitys
|
|||||||
if (task.Type == OutStockType.Sal)
|
if (task.Type == OutStockType.Sal)
|
||||||
{
|
{
|
||||||
//只有销售出库才需要同步金蝶
|
//只有销售出库才需要同步金蝶
|
||||||
this.SuccessSync = false;
|
this.SuccessSync = SyncStatus.Fail;
|
||||||
var erpd = this.Details.SelectMany(s => s.ErpDetails).ToList();
|
var erpd = this.Details.SelectMany(s => s.ErpDetails).ToList();
|
||||||
erpd.ForEach(f => f.SuccessSync = false);
|
erpd.ForEach(f => f.SuccessSync = SyncStatus.Fail);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
this.SuccessSync = true;
|
this.SuccessSync = SyncStatus.Success;
|
||||||
var erpd = this.Details.SelectMany(s => s.ErpDetails).ToList();
|
var erpd = this.Details.SelectMany(s => s.ErpDetails).ToList();
|
||||||
erpd.ForEach(f => f.SuccessSync = true);
|
erpd.ForEach(f => f.SuccessSync = SyncStatus.Success);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@@ -138,11 +138,11 @@ namespace WMS.Web.Domain.Entitys
|
|||||||
//foreach (var e in erpDetailIds)
|
//foreach (var e in erpDetailIds)
|
||||||
// this.SuccessSyncFail.Remove(e);
|
// this.SuccessSyncFail.Remove(e);
|
||||||
var erpd = this.Details.SelectMany(s => s.ErpDetails).Where(w => w.SourceBillNo.Equals(sourcBillNo)).ToList();
|
var erpd = this.Details.SelectMany(s => s.ErpDetails).Where(w => w.SourceBillNo.Equals(sourcBillNo)).ToList();
|
||||||
erpd.ForEach(f => f.SuccessSync = true);
|
erpd.ForEach(f => f.SuccessSync = SyncStatus.Success);
|
||||||
//所有erp明细同步成功才是整个单据成功
|
//所有erp明细同步成功才是整个单据成功
|
||||||
if (this.Details.SelectMany(s => s.ErpDetails).Where(w => w.SuccessSync != false).Any())
|
if (this.Details.SelectMany(s => s.ErpDetails).Where(w => w.SuccessSync == SyncStatus.Success).Any())
|
||||||
{
|
{
|
||||||
this.SuccessSync = true;
|
this.SuccessSync = SyncStatus.Success;
|
||||||
this.Remark = "";
|
this.Remark = "";
|
||||||
}
|
}
|
||||||
this.OperateId = operateId;
|
this.OperateId = operateId;
|
||||||
@@ -152,9 +152,9 @@ namespace WMS.Web.Domain.Entitys
|
|||||||
/// 同步金蝶(失败)
|
/// 同步金蝶(失败)
|
||||||
/// </summary>
|
/// </summary>
|
||||||
/// <param name="operateId"></param>
|
/// <param name="operateId"></param>
|
||||||
public void SyncFail(string remark, int operateId)
|
public void SyncFail(string remark, int operateId, SyncStatus syncStatus)
|
||||||
{
|
{
|
||||||
this.SuccessSync = false;
|
this.SuccessSync = syncStatus;
|
||||||
this.Remark = remark;
|
this.Remark = remark;
|
||||||
this.OperateId = operateId;
|
this.OperateId = operateId;
|
||||||
this.SyncTime = DateTime.Now;
|
this.SyncTime = DateTime.Now;
|
||||||
|
|||||||
@@ -3,6 +3,7 @@ using System.Collections.Generic;
|
|||||||
using System.ComponentModel.DataAnnotations.Schema;
|
using System.ComponentModel.DataAnnotations.Schema;
|
||||||
using System.Text;
|
using System.Text;
|
||||||
using WMS.Web.Core;
|
using WMS.Web.Core;
|
||||||
|
using WMS.Web.Domain.Values;
|
||||||
|
|
||||||
namespace WMS.Web.Domain.Entitys
|
namespace WMS.Web.Domain.Entitys
|
||||||
{
|
{
|
||||||
@@ -48,6 +49,6 @@ namespace WMS.Web.Domain.Entitys
|
|||||||
/// 同步成功或者失败 默认是失败状态
|
/// 同步成功或者失败 默认是失败状态
|
||||||
/// </summary>
|
/// </summary>
|
||||||
[Column("SuccessSync")]
|
[Column("SuccessSync")]
|
||||||
public bool SuccessSync { get; set; } = false;
|
public SyncStatus SuccessSync { get; set; } = SyncStatus.Fail;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -36,10 +36,10 @@ namespace WMS.Web.Domain.Entitys
|
|||||||
[Column("CreatorId")]
|
[Column("CreatorId")]
|
||||||
public int CreatorId { get; set; }
|
public int CreatorId { get; set; }
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// 同步成功或者失败 null 就是未同步
|
/// 同步状态
|
||||||
/// </summary>
|
/// </summary>
|
||||||
[Column("SuccessSync")]
|
[Column("SuccessSync")]
|
||||||
public bool? SuccessSync { get; set; }
|
public SyncStatus SuccessSync { get; set; } = SyncStatus.Fail;
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// 箱Id
|
/// 箱Id
|
||||||
/// </summary>
|
/// </summary>
|
||||||
@@ -115,18 +115,10 @@ namespace WMS.Web.Domain.Entitys
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
/// <param name="isSuccess"></param>
|
/// <param name="isSuccess"></param>
|
||||||
/// <param name="remark"></param>
|
/// <param name="remark"></param>
|
||||||
public void Sync(bool isSuccess,string remark)
|
public void Sync(bool isSuccess, string remark, SyncStatus syncStatus)
|
||||||
{
|
{
|
||||||
if (isSuccess)
|
this.SuccessSync = syncStatus;
|
||||||
{
|
this.Remark = "";
|
||||||
this.SuccessSync = true;
|
|
||||||
this.Remark = "";
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
this.SuccessSync = false;
|
|
||||||
this.Remark = remark;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// 生成单据号
|
/// 生成单据号
|
||||||
|
|||||||
@@ -43,7 +43,13 @@ namespace WMS.Web.Domain.IService.Public
|
|||||||
/// <param name="materialId"></param>
|
/// <param name="materialId"></param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
string GetMaterialUnitName(List<ErpMaterialDto> erpMaterials, int materialId);
|
string GetMaterialUnitName(List<ErpMaterialDto> erpMaterials, int materialId);
|
||||||
|
/// <summary>
|
||||||
|
/// 获取物料基本单位id
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="erpMaterials"></param>
|
||||||
|
/// <param name="materialId"></param>
|
||||||
|
/// <returns></returns>
|
||||||
|
int GetMaterialUnitId(List<ErpMaterialDto> erpMaterials, int materialId);
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// 获取组织名称
|
/// 获取组织名称
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
|||||||
@@ -178,9 +178,9 @@ namespace WMS.Web.Domain.Services
|
|||||||
var list = await _outStockRepositories.GetEntityList(dto.Ids);
|
var list = await _outStockRepositories.GetEntityList(dto.Ids);
|
||||||
foreach (var entity in list)
|
foreach (var entity in list)
|
||||||
{
|
{
|
||||||
if (entity.SuccessSync) continue;
|
if (entity.SuccessSync!=SyncStatus.Fail) continue;
|
||||||
List<string> failList =entity.Details.SelectMany(s=>s.ErpDetails)
|
List<string> failList =entity.Details.SelectMany(s=>s.ErpDetails)
|
||||||
.Where(w=> w.SuccessSync==false).GroupBy(g=>g.SourceBillNo)
|
.Where(w=> w.SuccessSync== SyncStatus.Fail).GroupBy(g=>g.SourceBillNo)
|
||||||
.Select(s=>s.Key).ToList();//同步失败的来源单号
|
.Select(s=>s.Key).ToList();//同步失败的来源单号
|
||||||
//找到单据里需要同步的单据
|
//找到单据里需要同步的单据
|
||||||
var sourcNos = entity.Details.SelectMany(s => s.ErpDetails).GroupBy(s => s.SourceBillNo).Select(s => s.Key);
|
var sourcNos = entity.Details.SelectMany(s => s.ErpDetails).GroupBy(s => s.SourceBillNo).Select(s => s.Key);
|
||||||
@@ -199,7 +199,7 @@ namespace WMS.Web.Domain.Services
|
|||||||
if (res.IsSuccess)
|
if (res.IsSuccess)
|
||||||
entity.SyncSuccess(s, loginInfo.UserInfo.StaffId);
|
entity.SyncSuccess(s, loginInfo.UserInfo.StaffId);
|
||||||
else
|
else
|
||||||
entity.SyncFail(res.Message, loginInfo.UserInfo.StaffId);
|
entity.SyncFail(res.Message, loginInfo.UserInfo.StaffId, SyncStatus.Fail);
|
||||||
}
|
}
|
||||||
//entity.SuccessSync = entity.SuccessSyncFail.Count() > 0 ? false : true;
|
//entity.SuccessSync = entity.SuccessSyncFail.Count() > 0 ? false : true;
|
||||||
//最好一条一条执行,否则执行失败 但是金蝶那边又同步成功 就会造成数据比价乱
|
//最好一条一条执行,否则执行失败 但是金蝶那边又同步成功 就会造成数据比价乱
|
||||||
|
|||||||
@@ -98,7 +98,32 @@ namespace WMS.Web.Domain.Services.Public
|
|||||||
public string GetMaterialUnitName(List<ErpMaterialDto> erpMaterials, int materialId)
|
public string GetMaterialUnitName(List<ErpMaterialDto> erpMaterials, int materialId)
|
||||||
{
|
{
|
||||||
var mat = erpMaterials.Where(x => x.MaterialId == materialId).FirstOrDefault();
|
var mat = erpMaterials.Where(x => x.MaterialId == materialId).FirstOrDefault();
|
||||||
return mat == null ? "" : mat.BaseUnitName;
|
if (mat == null)
|
||||||
|
{
|
||||||
|
var result = _erpService.BillQueryForMaterial(materialId).Result;
|
||||||
|
if (!result.IsSuccess)
|
||||||
|
return "";
|
||||||
|
return result.Data == null ? "" : result.Data.BaseUnitName;
|
||||||
|
}
|
||||||
|
return mat.BaseUnitName;
|
||||||
|
}
|
||||||
|
/// <summary>
|
||||||
|
/// 获取物料基本单位Id
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="erpMaterials"></param>
|
||||||
|
/// <param name="materialId"></param>
|
||||||
|
/// <returns></returns>
|
||||||
|
public int GetMaterialUnitId(List<ErpMaterialDto> erpMaterials, int materialId)
|
||||||
|
{
|
||||||
|
var mat = erpMaterials.Where(x => x.MaterialId == materialId).FirstOrDefault();
|
||||||
|
if (mat == null)
|
||||||
|
{
|
||||||
|
var result = _erpService.BillQueryForMaterial(materialId).Result;
|
||||||
|
if (!result.IsSuccess)
|
||||||
|
return 0;
|
||||||
|
return result.Data == null ? 0 : result.Data.BaseUnitId;
|
||||||
|
}
|
||||||
|
return mat.BaseUnitId;
|
||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
|
|||||||
@@ -38,11 +38,12 @@ namespace WMS.Web.Domain.Services
|
|||||||
private readonly IErpService _erpService;
|
private readonly IErpService _erpService;
|
||||||
private readonly ILogger<TakeStockService> _logger;
|
private readonly ILogger<TakeStockService> _logger;
|
||||||
private readonly IBoxInventoryService _boxInventoryService;
|
private readonly IBoxInventoryService _boxInventoryService;
|
||||||
|
private readonly IErpBasicDataExtendService _erpBasicDataExtendService;
|
||||||
public TakeStockService(IMapper mapper, ILoginService loginService,
|
public TakeStockService(IMapper mapper, ILoginService loginService,
|
||||||
IBasicsRepositories transactionRepositories,
|
IBasicsRepositories transactionRepositories,
|
||||||
ITakeStockRepositories takeStockRepositories, ILoginRepositories loginRepositories,
|
ITakeStockRepositories takeStockRepositories, ILoginRepositories loginRepositories,
|
||||||
ISingleDataService singleDataService, IErpService erpService, ILogger<TakeStockService> logger,
|
ISingleDataService singleDataService, IErpService erpService, ILogger<TakeStockService> logger,
|
||||||
IBoxInventoryService boxInventoryService)
|
IBoxInventoryService boxInventoryService, IErpBasicDataExtendService erpBasicDataExtendService)
|
||||||
{
|
{
|
||||||
_mapper = mapper;
|
_mapper = mapper;
|
||||||
_loginService = loginService;
|
_loginService = loginService;
|
||||||
@@ -53,6 +54,7 @@ namespace WMS.Web.Domain.Services
|
|||||||
_erpService = erpService;
|
_erpService = erpService;
|
||||||
_logger = logger;
|
_logger = logger;
|
||||||
_boxInventoryService = boxInventoryService;
|
_boxInventoryService = boxInventoryService;
|
||||||
|
_erpBasicDataExtendService = erpBasicDataExtendService;
|
||||||
}
|
}
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// 保存
|
/// 保存
|
||||||
@@ -107,7 +109,7 @@ namespace WMS.Web.Domain.Services
|
|||||||
public async Task<Result> Sync(OperateRequest dto)
|
public async Task<Result> Sync(OperateRequest dto)
|
||||||
{
|
{
|
||||||
var list = await _takeStockRepositories.GetEntityList(dto.Ids);
|
var list = await _takeStockRepositories.GetEntityList(dto.Ids);
|
||||||
list = list.Where(w => w.SuccessSync == false).ToList();
|
list = list.Where(w => w.SuccessSync == SyncStatus.Fail).ToList();
|
||||||
foreach (var entity in list)
|
foreach (var entity in list)
|
||||||
await Loss_Profit(entity);
|
await Loss_Profit(entity);
|
||||||
|
|
||||||
@@ -123,7 +125,9 @@ namespace WMS.Web.Domain.Services
|
|||||||
//获取金蝶仓库仓位编码
|
//获取金蝶仓库仓位编码
|
||||||
//var stockCode = _singleDataService.GetSingleDataCode(SingleAction.Stocks, _loginRepositories.CompanyId, entity.StockId);
|
//var stockCode = _singleDataService.GetSingleDataCode(SingleAction.Stocks, _loginRepositories.CompanyId, entity.StockId);
|
||||||
var subStockCode = _singleDataService.GetSingleDataCode(SingleAction.Stocks, _loginRepositories.CompanyId, entity.SubStockId);
|
var subStockCode = _singleDataService.GetSingleDataCode(SingleAction.Stocks, _loginRepositories.CompanyId, entity.SubStockId);
|
||||||
|
var materials_result = await _erpService.BillQueryForMaterial();
|
||||||
|
var materials = materials_result.Data.ToList();
|
||||||
|
var unitId = _erpBasicDataExtendService.GetMaterialUnitId(materials,entity.MaterialId);
|
||||||
var res = await _erpService.BillQueryForStock();
|
var res = await _erpService.BillQueryForStock();
|
||||||
var stock = res.Data.FirstOrDefault(f => f.Code == entity.StockCode);//需要根据单点code搜索
|
var stock = res.Data.FirstOrDefault(f => f.Code == entity.StockCode);//需要根据单点code搜索
|
||||||
var subStock = res.Data.FirstOrDefault(f => f.Code == subStockCode);//需要根据单点code搜索
|
var subStock = res.Data.FirstOrDefault(f => f.Code == subStockCode);//需要根据单点code搜索
|
||||||
@@ -136,7 +140,7 @@ namespace WMS.Web.Domain.Services
|
|||||||
FOwnerid = stock.OrgId.ToString(),
|
FOwnerid = stock.OrgId.ToString(),
|
||||||
FKeeperId = stock.OrgId.ToString(),
|
FKeeperId = stock.OrgId.ToString(),
|
||||||
MaterialId = entity.MaterialId.ToString(),
|
MaterialId = entity.MaterialId.ToString(),
|
||||||
UnitId = "", //物料带出来
|
UnitId = unitId.ToString(), //物料带出来
|
||||||
StockId = stock.Id.ToString(),
|
StockId = stock.Id.ToString(),
|
||||||
SubStockId = subStock.Id.ToString(),
|
SubStockId = subStock.Id.ToString(),
|
||||||
BeforeQty = entity.BeforeQty,
|
BeforeQty = entity.BeforeQty,
|
||||||
@@ -157,7 +161,7 @@ namespace WMS.Web.Domain.Services
|
|||||||
FormIdParam type = entity.ResultType == TakeStockType.Loss ? FormIdParam.STK_StockCountLoss : FormIdParam.STK_StockCountGain;
|
FormIdParam type = entity.ResultType == TakeStockType.Loss ? FormIdParam.STK_StockCountLoss : FormIdParam.STK_StockCountGain;
|
||||||
//操作金蝶
|
//操作金蝶
|
||||||
var resSync = await ErpOperate(dto, type);
|
var resSync = await ErpOperate(dto, type);
|
||||||
entity.Sync(resSync.IsSuccess, resSync.Message);
|
entity.Sync(resSync.result.IsSuccess, resSync.result.Message,resSync.syncStatus);
|
||||||
await _takeStockRepositories.Edit(entity, true);
|
await _takeStockRepositories.Edit(entity, true);
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
@@ -167,13 +171,13 @@ namespace WMS.Web.Domain.Services
|
|||||||
/// <param name="dto"></param>
|
/// <param name="dto"></param>
|
||||||
/// <param name="type"></param>
|
/// <param name="type"></param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
private async Task<Result> ErpOperate(ErpTakeStockSaveDto dto, FormIdParam type)
|
private async Task<(Result result,SyncStatus syncStatus)> ErpOperate(ErpTakeStockSaveDto dto, FormIdParam type)
|
||||||
{
|
{
|
||||||
string formId = type.ToString();
|
string formId = type.ToString();
|
||||||
_logger.LogInformation($"开始同步金蝶 单号:{dto.BillNo} 数据: {JsonConvert.SerializeObject(dto)}");
|
_logger.LogInformation($"开始同步金蝶 单号:{dto.BillNo} 数据: {JsonConvert.SerializeObject(dto)}");
|
||||||
var res_s = await _erpService.Save<ErpTakeStockSaveDto>(dto, formId);
|
var res_s = await _erpService.Save<ErpTakeStockSaveDto>(dto, formId);
|
||||||
if (!res_s.IsSuccess)
|
if (!res_s.IsSuccess)
|
||||||
return Result.ReFailure(res_s.Message, res_s.Status);
|
return (Result.ReFailure(res_s.Message, res_s.Status), SyncStatus.Fail);
|
||||||
//提交
|
//提交
|
||||||
ErpOperateDto o_dto = new ErpOperateDto(formId, res_s.Data);
|
ErpOperateDto o_dto = new ErpOperateDto(formId, res_s.Data);
|
||||||
var res = await _erpService.Submit(o_dto, formId);
|
var res = await _erpService.Submit(o_dto, formId);
|
||||||
@@ -181,10 +185,10 @@ namespace WMS.Web.Domain.Services
|
|||||||
{
|
{
|
||||||
//如果提交失败
|
//如果提交失败
|
||||||
//1.则调删单接口
|
//1.则调删单接口
|
||||||
var del_res = await _erpService.Delete(o_dto, formId);
|
//var del_res = await _erpService.Delete(o_dto, formId);
|
||||||
if (!del_res.IsSuccess)
|
//if (!del_res.IsSuccess)
|
||||||
_logger.LogError($"盘盈盘亏同步金蝶 单号:{dto.BillNo} 提交失败原因: {res.Message} 删单失败原因:{del_res.Message}");
|
// _logger.LogError($"盘盈盘亏同步金蝶 单号:{dto.BillNo} 提交失败原因: {res.Message} 删单失败原因:{del_res.Message}");
|
||||||
return res;
|
return (res, SyncStatus.PortionSuccess);
|
||||||
}
|
}
|
||||||
//审核
|
//审核
|
||||||
res = await _erpService.Audit(o_dto, formId);
|
res = await _erpService.Audit(o_dto, formId);
|
||||||
@@ -193,20 +197,20 @@ namespace WMS.Web.Domain.Services
|
|||||||
//如果审核失败
|
//如果审核失败
|
||||||
//1.调反审核接口
|
//1.调反审核接口
|
||||||
//2.调删除接口
|
//2.调删除接口
|
||||||
var noAudit_res = await _erpService.NoAudit(o_dto, formId);
|
//var noAudit_res = await _erpService.NoAudit(o_dto, formId);
|
||||||
if (!noAudit_res.IsSuccess)
|
//if (!noAudit_res.IsSuccess)
|
||||||
{
|
//{
|
||||||
_logger.LogError($"盘盈盘亏同步金蝶 单号:{dto.BillNo} 审核失败原因: {res.Message} 反审核失败原因:{noAudit_res.Message}");
|
// _logger.LogError($"盘盈盘亏同步金蝶 单号:{dto.BillNo} 审核失败原因: {res.Message} 反审核失败原因:{noAudit_res.Message}");
|
||||||
return res;
|
// return res;
|
||||||
}
|
//}
|
||||||
|
|
||||||
var del_res = await _erpService.Delete(o_dto, formId);
|
//var del_res = await _erpService.Delete(o_dto, formId);
|
||||||
if (!del_res.IsSuccess)
|
//if (!del_res.IsSuccess)
|
||||||
_logger.LogError($"盘盈盘亏同步金蝶 单号:{dto.BillNo} 审核失败原因: {res.Message} 删单失败原因:{del_res.Message}");
|
// _logger.LogError($"盘盈盘亏同步金蝶 单号:{dto.BillNo} 审核失败原因: {res.Message} 删单失败原因:{del_res.Message}");
|
||||||
return res;
|
return (res, SyncStatus.PortionSuccess);
|
||||||
}
|
}
|
||||||
_logger.LogInformation($"同步金蝶成功");
|
_logger.LogInformation($"同步金蝶成功");
|
||||||
return Result.ReSuccess();
|
return (Result.ReSuccess(),SyncStatus.Success);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
29
src/WMS.Web.Domain/Values/SyncStatus.cs
Normal file
29
src/WMS.Web.Domain/Values/SyncStatus.cs
Normal file
@@ -0,0 +1,29 @@
|
|||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Text;
|
||||||
|
using WMS.Web.Core;
|
||||||
|
|
||||||
|
namespace WMS.Web.Domain.Values
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// 同步金蝶状态
|
||||||
|
/// </summary>
|
||||||
|
public enum SyncStatus
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// 失败
|
||||||
|
/// </summary>
|
||||||
|
[EnumRemark("失败")]
|
||||||
|
Fail =0,
|
||||||
|
/// <summary>
|
||||||
|
/// 成功
|
||||||
|
/// </summary>
|
||||||
|
[EnumRemark("成功")]
|
||||||
|
Success =1,
|
||||||
|
/// <summary>
|
||||||
|
/// 部分成功(数据保存成功,提交或者审核失败)
|
||||||
|
/// </summary>
|
||||||
|
[EnumRemark("部分成功")]
|
||||||
|
PortionSuccess =2
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -141,7 +141,12 @@ namespace WMS.Web.Repositories
|
|||||||
if (dto.Type != null)
|
if (dto.Type != null)
|
||||||
query = query.Where(w => w.order.Type == (OutStockType)dto.Type);
|
query = query.Where(w => w.order.Type == (OutStockType)dto.Type);
|
||||||
if (dto.SuccessSync != null)
|
if (dto.SuccessSync != null)
|
||||||
query = query.Where(w => w.order.SuccessSync == dto.SuccessSync);
|
{
|
||||||
|
if (dto.SuccessSync == true)
|
||||||
|
query = query.Where(w => w.order.SuccessSync == SyncStatus.Success);
|
||||||
|
else
|
||||||
|
query = query.Where(w => w.order.SuccessSync != SyncStatus.Success);
|
||||||
|
}
|
||||||
if (dto.DeliveryOrgId != null)
|
if (dto.DeliveryOrgId != null)
|
||||||
query = query.Where(w => w.order.DeliveryOrgId == dto.DeliveryOrgId);
|
query = query.Where(w => w.order.DeliveryOrgId == dto.DeliveryOrgId);
|
||||||
if (!string.IsNullOrEmpty(dto.StockCode))
|
if (!string.IsNullOrEmpty(dto.StockCode))
|
||||||
@@ -160,7 +165,7 @@ namespace WMS.Web.Repositories
|
|||||||
Type = s.order.Type.GetRemark(),
|
Type = s.order.Type.GetRemark(),
|
||||||
Creator = _singleDataService.GetSingleData(SingleAction.Staffs, _loginRepositories.CompanyId, s.order.CreatorId),
|
Creator = _singleDataService.GetSingleData(SingleAction.Staffs, _loginRepositories.CompanyId, s.order.CreatorId),
|
||||||
CreateTime = s.order.CreateTime.DateToStringSeconds(),
|
CreateTime = s.order.CreateTime.DateToStringSeconds(),
|
||||||
SuccessSync = s.order.SuccessSync == true ? "成功" : "失败",
|
SuccessSync = s.order.SuccessSync == SyncStatus.Success ? "成功" : "失败",
|
||||||
Stock = _singleDataService.GetSingleData(SingleAction.StocksJoinOrgCode, _loginRepositories.CompanyId, s.order.StockCode + s.order.OrgCode),
|
Stock = _singleDataService.GetSingleData(SingleAction.StocksJoinOrgCode, _loginRepositories.CompanyId, s.order.StockCode + s.order.OrgCode),
|
||||||
SourceBillNoList = s.detail.ErpDetails.Select(s => s.SourceBillNo).ToList(),
|
SourceBillNoList = s.detail.ErpDetails.Select(s => s.SourceBillNo).ToList(),
|
||||||
SaleBillNoList = s.detail.ErpDetails.Select(s => s.SaleBillNo).ToList(),
|
SaleBillNoList = s.detail.ErpDetails.Select(s => s.SaleBillNo).ToList(),
|
||||||
|
|||||||
@@ -207,7 +207,7 @@ namespace WMS.Web.Repositories
|
|||||||
Remark = s.Remark,
|
Remark = s.Remark,
|
||||||
Creator = _singleDataService.GetSingleData(SingleAction.Staffs, _loginRepositories.CompanyId, s.CreatorId),
|
Creator = _singleDataService.GetSingleData(SingleAction.Staffs, _loginRepositories.CompanyId, s.CreatorId),
|
||||||
Date = s.Date.DateToStringSeconds(),
|
Date = s.Date.DateToStringSeconds(),
|
||||||
SuccessSync = s.SuccessSync==true?"成功":"失败",
|
SuccessSync = s.SuccessSync== SyncStatus.Success ? "成功":"失败",
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
}).Skip((dto.PageNo - 1) * dto.PageSize).Take(dto.PageSize).ToListAsync();
|
}).Skip((dto.PageNo - 1) * dto.PageSize).Take(dto.PageSize).ToListAsync();
|
||||||
|
|||||||
Reference in New Issue
Block a user