安虹睿 7 months ago
parent
commit
c649b81d42
  1. 47
      src/Modules/新版JIT或JIS系统服务端/src/WY.NewJit.Application/EdiReceive/ImportRecordAppService.cs
  2. 67
      src/Modules/新版JIT或JIS系统服务端/src/WY.NewJit.Application/MsgBaseData/AssemblyCfgs/AssemblyCfgErpAppService.cs
  3. 4
      src/Modules/新版JIT或JIS系统服务端/src/WY.NewJit.Application/MsgBaseData/Dics/DicAppService.cs
  4. 4
      src/Modules/新版JIT或JIS系统服务端/src/WY.NewJit.Application/MsgBaseData/PrintTemplateConfiguration/PrintTemplateConfigurationService.cs
  5. 2
      src/Modules/新版JIT或JIS系统服务端/src/WY.NewJit.Application/MsgCheck/BillM100s/MenBanPackingRecService.cs
  6. 2
      src/Modules/新版JIT或JIS系统服务端/src/WY.NewJit.Application/MsgCheck/BillM100s/ZhuHuBanPackingRecService.cs
  7. 6
      src/Modules/新版JIT或JIS系统服务端/src/WY.NewJit.Application/PrintTable/WaitPrintAppService.cs
  8. 14
      src/Modules/新版JIT或JIS系统服务端/src/WY.NewJit.Application/WY.NewJit.Application.xml
  9. 11
      src/Modules/新版JIT或JIS系统服务端/src/WY.NewJit.Domain/EdiReceive/Services/EdiParseDomainService.cs
  10. 12
      src/Modules/新版JIT或JIS系统服务端/src/WY.NewJit.Domain/EdiReceive/Services/HQ_M100DomainService.cs

47
src/Modules/新版JIT或JIS系统服务端/src/WY.NewJit.Application/EdiReceive/ImportRecordAppService.cs

@ -78,6 +78,9 @@ namespace WY.NewJit.EdiReceive
} }
} }
private readonly IUnitOfWorkManager _unitOfWorkManager;
#endregion #endregion
@ -91,7 +94,8 @@ namespace WY.NewJit.EdiReceive
IBlobContainer<OurFileContainer> blobContainer, IBlobContainer<OurFileContainer> blobContainer,
DicDomainService dicDomainService, DicDomainService dicDomainService,
EdiParseDomainService ediParseDomainService, EdiParseDomainService ediParseDomainService,
Microsoft.Extensions.Configuration.IConfiguration configuration) Microsoft.Extensions.Configuration.IConfiguration configuration,
IUnitOfWorkManager unitOfWorkManager)
{ {
_importRecordRepository = importRecordRepository; _importRecordRepository = importRecordRepository;
_logger = logger; _logger = logger;
@ -100,6 +104,7 @@ namespace WY.NewJit.EdiReceive
_dicDomainService = dicDomainService; _dicDomainService = dicDomainService;
_ediParseDomainService = ediParseDomainService; _ediParseDomainService = ediParseDomainService;
_configuration = configuration; _configuration = configuration;
_unitOfWorkManager = unitOfWorkManager;
} }
#region 私有方法 #region 私有方法
@ -423,7 +428,7 @@ namespace WY.NewJit.EdiReceive
/// <param name="files">导入文件</param> /// <param name="files">导入文件</param>
/// <param name="forceExecute">校验出错时,是否强制执行</param> /// <param name="forceExecute">校验出错时,是否强制执行</param>
/// <returns>执行成功返回真</returns> /// <returns>执行成功返回真</returns>
[UnitOfWork] [UnitOfWork(IsDisabled =true)]
[HttpPost] [HttpPost]
[Route("import")] [Route("import")]
[DisableRequestSizeLimit] [DisableRequestSizeLimit]
@ -465,25 +470,29 @@ namespace WY.NewJit.EdiReceive
return ret; return ret;
} }
var srcLst = impResult.Data.AsEnumerable().ToList(); using (var uow = _unitOfWorkManager.Begin())
var tarLst = ObjectMapper.Map<List<ImportRecordDto>, List<ImportRecord>>(srcLst);
foreach (var tar in tarLst)
{
//tar.CreatePerson = "导入";
tar.CreateTime = ServerHelper.CurrentDateTime;
}
//报文解析
ObjectResultDto ret2 = await _ediParseDomainService.ParseEdi(tarLst, forceExecute);
if (ret2.Status == false)
{
return ret2;
}
if (ret2.Status == true && ret2.Message.HasValue())
{ {
return ret2; var srcLst = impResult.Data.AsEnumerable().ToList();
var tarLst = ObjectMapper.Map<List<ImportRecordDto>, List<ImportRecord>>(srcLst);
foreach (var tar in tarLst)
{
//tar.CreatePerson = "导入";
tar.CreateTime = ServerHelper.CurrentDateTime;
}
//报文解析
ObjectResultDto ret2 = await _ediParseDomainService.ParseEdi(tarLst, forceExecute);
if (ret2.Status == false)
{
return ret2;
}
if (ret2.Status == true && ret2.Message.HasValue())
{
return ret2;
}
await uow.CompleteAsync();
ret.Status = true;
return ret;
} }
ret.Status = true;
return ret;
} }
catch (Exception ex) catch (Exception ex)
{ {

67
src/Modules/新版JIT或JIS系统服务端/src/WY.NewJit.Application/MsgBaseData/AssemblyCfgs/AssemblyCfgErpAppService.cs

@ -741,6 +741,14 @@ SELECT top 1 v.Id
ret.Status = false; ret.Status = false;
return ret; return ret;
} }
var err2 = CheckMaterialRepeatByAssembly(srcLst, material3Lst);
if (!string.IsNullOrEmpty(err2))
{
ret.Message = err2;
ret.Status = false;
return ret;
}
#endregion #endregion
#region 插入数据 #region 插入数据
List<AssemblyCfgGroup> assemblyCfgGroups = new List<AssemblyCfgGroup>(); List<AssemblyCfgGroup> assemblyCfgGroups = new List<AssemblyCfgGroup>();
@ -835,6 +843,65 @@ SELECT top 1 v.Id
return error; return error;
} }
/// <summary>
/// 导入总成时,校验规格说明包含的4个物料号分别是1001,1002,1003,1004
/// </summary>
/// <param name="srcLst">导入总成list</param>
/// <param name="material3Lst">总成物料list</param>
/// <returns></returns>
private string CheckMaterialRepeatByAssembly(List<ImportErpAssemblyGroupDto> srcLst, List<MaterialExt> material3Lst)
{
StringBuilder strBuild = new StringBuilder();
string[] arr = new string[4] { "1001", "1002", "1003", "1004" };
string arrStr = string.Join(',', arr);
var qry = from item in srcLst
group item by item.SpecExplain into g
select new
{
SpecExplain = g.Key,
ColorExplain = g.ElementAt(0).ColorExplain,
Details = g.Select(itm => itm.MaterialNum).ToList()
};
foreach (var item in qry)
{
if (item.Details.Count != 4)
{
strBuild.AppendLine($"规格说明{item.SpecExplain}包含的物料号不是4个");
}
//遍历物料号
List<string> strLst = new List<string>();
foreach (string materialNum in item.Details)
{
var materialObj = material3Lst.FirstOrDefault(itm => itm.RelationKey == materialNum);
if (materialObj == null)
{
strBuild.AppendLine($"规格说明{item.SpecExplain}:物料号{materialNum}在物料表不存在!");
}
else
{
if (arr.Contains(materialObj.MaterialType2) == true)
{
strLst.Add(materialObj.MaterialType2);
}
else
{
strBuild.AppendLine($"规格说明{item.SpecExplain}:物料号{materialNum}的MaterialType2不是【{arrStr}】其中之一!");
}
}
}
if (string.IsNullOrEmpty(strBuild.ToString()))
{
if (strLst.Count != strLst.Distinct().Count())
{
string repeatLst = string.Join(',', strLst);
strBuild.AppendLine($"规格说明{item.SpecExplain}包含的配置号重复{repeatLst}");
}
}
}
return strBuild.ToString();
}
//[UnitOfWork] //[UnitOfWork]
//[HttpPost] //[HttpPost]

4
src/Modules/新版JIT或JIS系统服务端/src/WY.NewJit.Application/MsgBaseData/Dics/DicAppService.cs

@ -34,7 +34,7 @@ namespace WY.NewJit.MsgBaseData
/// <summary> /// <summary>
/// 日志 /// 日志
/// </summary> /// </summary>
private ILogger<PartCfgAppService> _logger; private ILogger<DicAppService> _logger;
/// <summary> /// <summary>
/// 错误信息前缀 /// 错误信息前缀
@ -52,7 +52,7 @@ namespace WY.NewJit.MsgBaseData
/// </summary> /// </summary>
public DicAppService( public DicAppService(
DicDomainService dicDomainService, DicDomainService dicDomainService,
ILogger<PartCfgAppService> logger ILogger<DicAppService> logger
) )
{ {
_dicDomainService = dicDomainService; _dicDomainService = dicDomainService;

4
src/Modules/新版JIT或JIS系统服务端/src/WY.NewJit.Application/MsgBaseData/PrintTemplateConfiguration/PrintTemplateConfigurationService.cs

@ -37,7 +37,7 @@ namespace WY.NewJit.MsgBaseData
/// <summary> /// <summary>
/// 日志 /// 日志
/// </summary> /// </summary>
private ILogger<PartCfgAppService> _logger; private ILogger<PrintTemplateConfigurationService> _logger;
/// <summary> /// <summary>
/// Dapper仓储 /// Dapper仓储
@ -70,7 +70,7 @@ namespace WY.NewJit.MsgBaseData
/// </summary> /// </summary>
public PrintTemplateConfigurationService( public PrintTemplateConfigurationService(
IRepository<PrintTemplateConfiguration, Guid> repository, IRepository<PrintTemplateConfiguration, Guid> repository,
ILogger<PartCfgAppService> logger, ILogger<PrintTemplateConfigurationService> logger,
NewJitDapperRepository newJitDapperRepository, NewJitDapperRepository newJitDapperRepository,
IBlobContainer<OurFileContainer> blobContainer, IBlobContainer<OurFileContainer> blobContainer,
DicDomainService dicDomainService DicDomainService dicDomainService

2
src/Modules/新版JIT或JIS系统服务端/src/WY.NewJit.Application/MsgCheck/BillM100s/MenBanPackingRecService.cs

@ -360,7 +360,7 @@ namespace Win.Sfs.SettleAccount.FISes
{ {
if (alreadyPrintItem.BillStatus == BillStatusEnum.BreakNum && waitPrintLst[0].BillStatus == BillStatusEnum.BreakNum) if (alreadyPrintItem.BillStatus == BillStatusEnum.BreakNum && waitPrintLst[0].BillStatus == BillStatusEnum.BreakNum)
{ {
throw new BusinessException("1001", "未打印列表和已打印列表出现都是断号的情况号码未【" + alreadyPrintItem.HostSN2 + "】,不能报废!"); throw new BusinessException("1001", "未打印列表和已打印列表出现都是断号状态【" + alreadyPrintItem.HostSN2 + "】,不能报废!");
} }
//未打印有一条补打的记录,忽略已打印的对应记录,将未打印记录的补打状态改成顺序打印状态 //未打印有一条补打的记录,忽略已打印的对应记录,将未打印记录的补打状态改成顺序打印状态
if (waitPrintLst[0].PrintType == WY.NewJit.PrintTable.PrintTypeEnum.ReplenishPrint) if (waitPrintLst[0].PrintType == WY.NewJit.PrintTable.PrintTypeEnum.ReplenishPrint)

2
src/Modules/新版JIT或JIS系统服务端/src/WY.NewJit.Application/MsgCheck/BillM100s/ZhuHuBanPackingRecService.cs

@ -396,7 +396,7 @@ namespace Win.Sfs.SettleAccount.FISes
{ {
if (alreadyPrintItem.BillStatus == BillStatusEnum.BreakNum && waitPrintLst[0].BillStatus == BillStatusEnum.BreakNum) if (alreadyPrintItem.BillStatus == BillStatusEnum.BreakNum && waitPrintLst[0].BillStatus == BillStatusEnum.BreakNum)
{ {
throw new BusinessException("1001", "未打印列表和已打印列表出现都是断号的情况号码未【" + alreadyPrintItem.HostSN2 + "】,不能报废!"); throw new BusinessException("1001", "未打印列表和已打印列表出现都是柱护板断号状态【" + alreadyPrintItem.HostSN2 + "】,不能报废!");
} }
//未打印有一条补打的记录,忽略已打印的对应记录,将未打印记录的补打状态改成顺序打印状态 //未打印有一条补打的记录,忽略已打印的对应记录,将未打印记录的补打状态改成顺序打印状态
if (waitPrintLst[0].PrintType == WY.NewJit.PrintTable.PrintTypeEnum.ReplenishPrint) if (waitPrintLst[0].PrintType == WY.NewJit.PrintTable.PrintTypeEnum.ReplenishPrint)

6
src/Modules/新版JIT或JIS系统服务端/src/WY.NewJit.Application/PrintTable/WaitPrintAppService.cs

@ -830,7 +830,7 @@ namespace WY.NewJit.PrintTable
&& itm.PrintType == PrintTypeEnum.OrderPrint //顺序打印 && itm.PrintType == PrintTypeEnum.OrderPrint //顺序打印
).MinAsync(itm => itm.HostSN2); ).MinAsync(itm => itm.HostSN2);
int minHostSN = minHostSN2 % 100000; int minHostSN = minHostSN2 % 100000;
if (input.BeginHostSN != minHostSN) if (input.BeginHostSN != minHostSN2)
{ {
retLst.Add($"输入的大众起始大众顺序号{input.BeginHostSN}和未打印表中的最小大众顺序号{minHostSN2}不相等!"); retLst.Add($"输入的大众起始大众顺序号{input.BeginHostSN}和未打印表中的最小大众顺序号{minHostSN2}不相等!");
return new ListResultDto<string>(retLst); return new ListResultDto<string>(retLst);
@ -853,7 +853,7 @@ namespace WY.NewJit.PrintTable
string breakNumStr = string.Join(" ", breakNumLst); string breakNumStr = string.Join(" ", breakNumLst);
// string breakNumStr = string.Concat(breakNumLst); // string breakNumStr = string.Concat(breakNumLst);
retLst.Add($"存在断号:{breakNumStr}"); retLst.Add($"存在断号:{breakNumStr}");
return new ListResultDto<string>(retLst); //return new ListResultDto<string>(retLst);
} }
//判断未知总成 //判断未知总成
bool containNotMatch = billLst.Any(itm => itm.BillStatus == BillStatusEnum.NotMatch); bool containNotMatch = billLst.Any(itm => itm.BillStatus == BillStatusEnum.NotMatch);
@ -863,7 +863,7 @@ namespace WY.NewJit.PrintTable
string str = string.Join(" ", lst); string str = string.Join(" ", lst);
//string str = string.Concat(lst); //string str = string.Concat(lst);
retLst.Add($"存在未知总成:{str}"); retLst.Add($"存在未知总成:{str}");
return new ListResultDto<string>(retLst); //return new ListResultDto<string>(retLst);
} }
return new ListResultDto<string>(retLst); return new ListResultDto<string>(retLst);

14
src/Modules/新版JIT或JIS系统服务端/src/WY.NewJit.Application/WY.NewJit.Application.xml

@ -49,7 +49,7 @@
错误信息前缀 错误信息前缀
</summary> </summary>
</member> </member>
<member name="M:WY.NewJit.EdiReceive.ImportRecordAppService.#ctor(Volo.Abp.Domain.Repositories.IRepository{WY.NewJit.EdiReceive.Entitys.ImportRecord,System.Guid},Microsoft.Extensions.Logging.ILogger{WY.NewJit.EdiReceive.ImportRecordAppService},WY.NewJit.EntityFrameworkCore.NewJitDapperRepository,Volo.Abp.BlobStoring.IBlobContainer{WY.NewJit.Common.OurFileContainer},WY.NewJit.MsgBaseData.DicDomainService,WY.NewJit.EdiReceive.Services.EdiParseDomainService,Microsoft.Extensions.Configuration.IConfiguration)"> <member name="M:WY.NewJit.EdiReceive.ImportRecordAppService.#ctor(Volo.Abp.Domain.Repositories.IRepository{WY.NewJit.EdiReceive.Entitys.ImportRecord,System.Guid},Microsoft.Extensions.Logging.ILogger{WY.NewJit.EdiReceive.ImportRecordAppService},WY.NewJit.EntityFrameworkCore.NewJitDapperRepository,Volo.Abp.BlobStoring.IBlobContainer{WY.NewJit.Common.OurFileContainer},WY.NewJit.MsgBaseData.DicDomainService,WY.NewJit.EdiReceive.Services.EdiParseDomainService,Microsoft.Extensions.Configuration.IConfiguration,Volo.Abp.Uow.IUnitOfWorkManager)">
<summary> <summary>
构造函数 构造函数
</summary> </summary>
@ -414,6 +414,14 @@
<param name="files"></param> <param name="files"></param>
<returns></returns> <returns></returns>
</member> </member>
<member name="M:WY.NewJit.MsgBaseData.AssemblyCfgErpAppService.CheckMaterialRepeatByAssembly(System.Collections.Generic.List{WY.NewJit.MsgBaseData.ImportErpAssemblyGroupDto},System.Collections.Generic.List{WY.NewJit.Extends.PaiGe.MaterialExt})">
<summary>
导入总成时,校验规格说明包含的4个物料号分别是1001,1002,1003,1004
</summary>
<param name="srcLst">导入总成list</param>
<param name="material3Lst">总成物料list</param>
<returns></returns>
</member>
<member name="M:WY.NewJit.MsgBaseData.AssemblyCfgErpAppService.RemoveRepeatErpAssembly(System.Int32)"> <member name="M:WY.NewJit.MsgBaseData.AssemblyCfgErpAppService.RemoveRepeatErpAssembly(System.Int32)">
<summary> <summary>
系统初始化时使用,去掉重复的ERP总成 系统初始化时使用,去掉重复的ERP总成
@ -629,7 +637,7 @@
错误信息前缀 错误信息前缀
</summary> </summary>
</member> </member>
<member name="M:WY.NewJit.MsgBaseData.DicAppService.#ctor(WY.NewJit.MsgBaseData.DicDomainService,Microsoft.Extensions.Logging.ILogger{WY.NewJit.MsgBaseData.PartCfgAppService})"> <member name="M:WY.NewJit.MsgBaseData.DicAppService.#ctor(WY.NewJit.MsgBaseData.DicDomainService,Microsoft.Extensions.Logging.ILogger{WY.NewJit.MsgBaseData.DicAppService})">
<summary> <summary>
构造函数 构造函数
</summary> </summary>
@ -1106,7 +1114,7 @@
错误信息前缀 错误信息前缀
</summary> </summary>
</member> </member>
<member name="M:WY.NewJit.MsgBaseData.PrintTemplateConfigurationService.#ctor(Volo.Abp.Domain.Repositories.IRepository{WY.NewJit.MsgBaseData.PrintTemplateConfiguration,System.Guid},Microsoft.Extensions.Logging.ILogger{WY.NewJit.MsgBaseData.PartCfgAppService},WY.NewJit.EntityFrameworkCore.NewJitDapperRepository,Volo.Abp.BlobStoring.IBlobContainer{WY.NewJit.Common.OurFileContainer},WY.NewJit.MsgBaseData.DicDomainService)"> <member name="M:WY.NewJit.MsgBaseData.PrintTemplateConfigurationService.#ctor(Volo.Abp.Domain.Repositories.IRepository{WY.NewJit.MsgBaseData.PrintTemplateConfiguration,System.Guid},Microsoft.Extensions.Logging.ILogger{WY.NewJit.MsgBaseData.PrintTemplateConfigurationService},WY.NewJit.EntityFrameworkCore.NewJitDapperRepository,Volo.Abp.BlobStoring.IBlobContainer{WY.NewJit.Common.OurFileContainer},WY.NewJit.MsgBaseData.DicDomainService)">
<summary> <summary>
构造函数 构造函数
</summary> </summary>

11
src/Modules/新版JIT或JIS系统服务端/src/WY.NewJit.Domain/EdiReceive/Services/EdiParseDomainService.cs

@ -311,8 +311,11 @@ namespace WY.NewJit.EdiReceive.Services
{ {
throw new Exception($"{_errorMessagePrefix}更新M100失败:{m100Obj.HostSN2}"); throw new Exception($"{_errorMessagePrefix}更新M100失败:{m100Obj.HostSN2}");
} }
bool hasBeforeNotPrint = await _hqM100DomainServie.BeforeNotPrint((int)(m100Obj.HostSN2));
bool isReplenishPrint = hasBeforeNotPrint ? false : true; //未打印表包含重新解析之前的记录,设置成正常打印,否则设置成补打
//判断未打印表是否有数据,有则更新,没有则插入 //判断未打印表是否有数据,有则更新,没有则插入
ObjectResultDto wpRet = await _hqM100DomainServie.InsertOrUpdateWaitPrintByM100(m100Ret, false, true); ObjectResultDto wpRet = await _hqM100DomainServie.InsertOrUpdateWaitPrintByM100(m100Ret, false, isReplenishPrint);
if (wpRet.Status == false) if (wpRet.Status == false)
{ {
throw new Exception(wpRet.Message); throw new Exception(wpRet.Message);
@ -400,10 +403,14 @@ namespace WY.NewJit.EdiReceive.Services
int curVal = notRepeatOrder[curIdx].HostSN; int curVal = notRepeatOrder[curIdx].HostSN;
int priorIdx = curIdx - 1; int priorIdx = curIdx - 1;
int priorVal = notRepeatOrder[priorIdx].HostSN; int priorVal = notRepeatOrder[priorIdx].HostSN;
if (curVal - priorVal != 1) if (curVal - priorVal > 1)
{ {
sb.AppendLine($"流水号{priorVal}和{curVal}之间存在断号"); sb.AppendLine($"流水号{priorVal}和{curVal}之间存在断号");
} }
else if (curVal - priorVal == 0)
{
sb.AppendLine($"流水号{priorVal}和{curVal}之间存在重复");
}
} }
return sb.ToString(); return sb.ToString();
} }

12
src/Modules/新版JIT或JIS系统服务端/src/WY.NewJit.Domain/EdiReceive/Services/HQ_M100DomainService.cs

@ -195,5 +195,17 @@ namespace WY.NewJit.MsgCheck
} }
return ret; return ret;
} }
/// <summary>
/// 根据传入参数hostSN2,判断存在小于hostSN2的未打印记录
/// </summary>
/// <param name="hostSN2"></param>
/// <returns></returns>
public async Task<bool> BeforeNotPrint(int hostSN2)
{
var qry = await _waitPrintRepository.GetQueryableAsync();
bool hasBeforeNotPrint = qry.Any(itm => itm.HostSN2 < hostSN2 && itm.PrintType == PrintTypeEnum.OrderPrint && itm.BillStatus == BillStatusEnum.Match);
return hasBeforeNotPrint;
}
} }
} }

Loading…
Cancel
Save