This commit is contained in:
tongfei
2023-12-01 14:20:40 +08:00
13 changed files with 189 additions and 58 deletions

View File

@@ -4441,6 +4441,21 @@
子仓库 子仓库
</summary> </summary>
</member> </member>
<member name="P:WMS.Web.Core.Dto.TakeStock.TakeStockQueryInfoResponse.MaterialName">
<summary>
物料名称
</summary>
</member>
<member name="P:WMS.Web.Core.Dto.TakeStock.TakeStockQueryInfoResponse.MaterialNumber">
<summary>
物料编码
</summary>
</member>
<member name="P:WMS.Web.Core.Dto.TakeStock.TakeStockQueryInfoResponse.Specifications">
<summary>
物料规格型号
</summary>
</member>
<member name="P:WMS.Web.Core.Dto.TakeStock.TakeStockQueryInfoResponse.BeforeQty"> <member name="P:WMS.Web.Core.Dto.TakeStock.TakeStockQueryInfoResponse.BeforeQty">
<summary> <summary>
系统库存 系统库存

View File

@@ -1101,7 +1101,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>
@@ -1571,7 +1571,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">
@@ -1641,7 +1641,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>
@@ -2590,6 +2590,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>
获取组织名称 获取组织名称
@@ -3909,6 +3917,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>
获取组织名称 获取组织名称
@@ -5588,6 +5604,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>
盘点单类型 盘点单类型

View File

@@ -55,6 +55,21 @@ namespace WMS.Web.Core.Dto.TakeStock
[Column("子仓库")] [Column("子仓库")]
public string Erp_SubStock { get; set; } public string Erp_SubStock { get; set; }
/// <summary> /// <summary>
/// 物料名称
/// </summary>
[Column("物料名称")]
public string MaterialName { get; set; }
/// <summary>
/// 物料编码
/// </summary>
[Column("物料编码")]
public string MaterialNumber { get; set; }
/// <summary>
/// 物料规格型号
/// </summary>
[Column("规格型号")]
public string Specifications { get; set; }
/// <summary>
/// 系统库存 /// 系统库存
/// </summary> /// </summary>
[Column("系统库存")] [Column("系统库存")]

View File

@@ -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;

View File

@@ -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;
} }
} }

View File

@@ -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>
/// 生成单据号 /// 生成单据号

View File

@@ -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>

View File

@@ -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;
//最好一条一条执行,否则执行失败 但是金蝶那边又同步成功 就会造成数据比价乱 //最好一条一条执行,否则执行失败 但是金蝶那边又同步成功 就会造成数据比价乱

View File

@@ -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>

View File

@@ -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);
} }
} }
} }

View 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
}
}

View File

@@ -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(),

View File

@@ -197,9 +197,12 @@ namespace WMS.Web.Repositories
Id = s.Id, Id = s.Id,
BillNo = s.BillNo, BillNo = s.BillNo,
Unit = _erpBasicDataExtendService.GetMaterialUnitName(materials, s.MaterialId), Unit = _erpBasicDataExtendService.GetMaterialUnitName(materials, s.MaterialId),
Stock = _singleDataService.GetSingleData(SingleAction.Stocks, _loginRepositories.CompanyId, s.StockCode), Stock = _singleDataService.GetSingleData(SingleAction.StocksJoinOrgCode, _loginRepositories.CompanyId, s.StockCode + s.OrgCode),
SubStock = _singleDataService.GetSingleData(SingleAction.SubStocks, _loginRepositories.CompanyId, s.SubStockId), SubStock = _singleDataService.GetSingleData(SingleAction.SubStocks, _loginRepositories.CompanyId, s.SubStockId),
Erp_SubStock= _erpBasicDataExtendService.GetStockName(subStocks, s.Erp_SubStockId), Erp_SubStock= _erpBasicDataExtendService.GetStockName(subStocks, s.Erp_SubStockId),
MaterialName = _erpBasicDataExtendService.GetMaterialName(materials, s.MaterialId),
MaterialNumber = _erpBasicDataExtendService.GetMaterialNumber(materials, s.MaterialId),
Specifications = _erpBasicDataExtendService.GetMaterialSpecifications(materials, s.MaterialId),
BeforeQty = s.BeforeQty, BeforeQty = s.BeforeQty,
AfterQty = s.AfterQty, AfterQty = s.AfterQty,
FinalQty = s.FinalQty, FinalQty = s.FinalQty,
@@ -207,7 +210,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();