新增提单纸页数计算

optimize
jianghaiqing 2 years ago
parent 9736272e8b
commit d281f42091

@ -1105,6 +1105,7 @@ namespace Myshipping.Application
/// </summary> /// </summary>
/// <param name="PKIds">任务主键数组</param> /// <param name="PKIds">任务主键数组</param>
/// <returns>返回结果</returns> /// <returns>返回结果</returns>
[HttpPost("/TaskManage/LaraPaperCalc")]
public async Task<List<LaraPaperCalcInfo>> LaraPaperCalc(string[] PKIds) public async Task<List<LaraPaperCalcInfo>> LaraPaperCalc(string[] PKIds)
{ {
List<LaraPaperCalcInfo> list = new List<LaraPaperCalcInfo>(); List<LaraPaperCalcInfo> list = new List<LaraPaperCalcInfo>();
@ -1122,18 +1123,40 @@ namespace Myshipping.Application
if (mblnoList.Count > 0) if (mblnoList.Count > 0)
{ {
//根据主单号获取任务类型是DRAFT的任务取时间最新的 //根据主单号获取任务类型是DRAFT的任务取时间最新的
var taskList = _taskBaseInfoRepository.AsQueryable() var fileList = _taskBaseInfoRepository.EntityContext.Queryable<TaskBaseInfo>()
.LeftJoin(_taskFileInfoRepository.AsQueryable(), (tsk, file) => tsk.PK_ID == file.TASK_PKID) .InnerJoin<TaskFileInfo>((tsk, file) => tsk.PK_ID == file.TASK_PKID)
.Where((tsk, file) => PKIds.Contains(tsk.PK_ID) && tsk.TASK_TYPE == TaskBusiTypeEnum.DRAFT.ToString() && file != null) .Where((tsk, file) =>
.OrderByDescending(tsk => tsk.CreatedTime) tsk.TASK_TYPE == TaskBusiTypeEnum.DRAFT.ToString() && mblnoList.Contains(tsk.MBL_NO))
.Select((tsk, file) => new { tsk = tsk, file = file }).ToList(); .Select((tsk, file) => new { tsk = tsk, file = file }).ToList();
var calcList = fileList.GroupBy(t => t.tsk.PK_ID)
.Select(a =>
{
var currList = a.ToList();
return new
{
tsk = currList.FirstOrDefault().tsk,
clist = a.Select(x => x.file).ToList()
};
}).OrderByDescending(t => t.tsk.CreatedTime).ToList();
list = mblnoList.Select((mbl,idx) => { list = mblnoList.Select((mbl, idx) =>
{
var calcInfo = new LaraPaperCalcInfo(); var calcInfo = new LaraPaperCalcInfo();
calcInfo.MBLNo = mbl;
calcInfo.Indx = idx + 1; calcInfo.Indx = idx + 1;
var files = calcList.FirstOrDefault(t => t.tsk.MBL_NO.Equals(mbl, StringComparison.OrdinalIgnoreCase));
if (files != null)
{
calcInfo.DraftNum = files.clist.Select(t => t.FILE_NAME.GetPageNum()).Sum();
}
calcInfo.PaperNum = calcInfo.DraftNum * 3;
return calcInfo; return calcInfo;
}).ToList(); }).ToList();
@ -1149,4 +1172,24 @@ namespace Myshipping.Application
} }
} }
public static class DraftPaperExtension
{
public static int GetPageNum(this string Name)
{
try
{
if (string.IsNullOrWhiteSpace(Name))
return 0;
string s = Regex.Replace(Name.Substring(Name.LastIndexOf('-') + 1), "\\.[a-zA-Z]+", "");
return int.Parse(s);
}
catch(Exception ex)
{
throw Oops.Bah($"文件名{0} 取页数异常,{1}", Name, ex.Message);
}
}
}
} }

Loading…
Cancel
Save