From 5b189017d143be6366f56ffcdd3c3699a381e034 Mon Sep 17 00:00:00 2001 From: schangxiang@126.com <schangxiang@126.com> Date: 周二, 20 5月 2025 12:43:55 +0800 Subject: [PATCH] 22 --- PipeLineLems/server/src/CMS.Plugin.PipeLineLems.Application/Implements/SharedService.cs | 90 ++++++++++++++++++++++++++++++++++++++++++--- 1 files changed, 84 insertions(+), 6 deletions(-) diff --git a/PipeLineLems/server/src/CMS.Plugin.PipeLineLems.Application/Implements/SharedService.cs b/PipeLineLems/server/src/CMS.Plugin.PipeLineLems.Application/Implements/SharedService.cs index 7f09104..f681023 100644 --- a/PipeLineLems/server/src/CMS.Plugin.PipeLineLems.Application/Implements/SharedService.cs +++ b/PipeLineLems/server/src/CMS.Plugin.PipeLineLems.Application/Implements/SharedService.cs @@ -8,6 +8,7 @@ using CMS.Plugin.OrderManagement.Abstractions.Models; using CMS.Plugin.PipeLineLems.Application.Contracts.Dtos.CallMaterialOrder; using CMS.Plugin.PipeLineLems.Application.Contracts.Dtos.WorkPlan; +using CMS.Plugin.PipeLineLems.Application.Contracts.Dtos.WorkTask; using CMS.Plugin.PipeLineLems.Application.Contracts.Services; using CMS.Plugin.PipeLineLems.Domain.CallMaterialOrder; using CMS.Plugin.PipeLineLems.Domain.CallMaterialOrderRecord; @@ -23,6 +24,7 @@ using Microsoft.Extensions.DependencyInjection; using Newtonsoft.Json; using Volo.Abp; +using Volo.Abp.ObjectMapping; using Volo.Abp.Uow; namespace CMS.Plugin.PipeLineLems.Application.Implements; @@ -42,6 +44,10 @@ /// <returns></returns> public async Task<MesOrderResponse> CommonPick(IServiceProvider _serviceProvider, PickInput input, MyCurrentUser myCurrentUser) { + if (string.IsNullOrEmpty(input.TaskCode)) + { + throw new UserFriendlyException("璇疯緭鍏ヤ换鍔$紪鍙�"); + }; if (string.IsNullOrEmpty(input.PipeSpecCode)) { throw new UserFriendlyException("璇疯緭鍏ョ娈电紪鐮�"); @@ -103,13 +109,19 @@ }); } //鐗╂枡鍙傛暟鍒楄〃 - var firstWorkPlans = await workPlanAppService.GetListByFilterAsync(x => x.PipeSpecCode == input.PipeSpecCode); - - var firstWorkPlan = await workPlanAppService.GetSingleByFilterAsync(x => x.PipeSpecCode == input.PipeSpecCode); + var firstWorkPlan = await workPlanAppService.GetSingleByFilterAsync(x => x.TaskCode == input.TaskCode); var callMaterialOrder = await callMaterialOrderAppService.GetSingleByFilterAsync(x => x.DataIdentifier == firstWorkPlan.DataIdentifier); //TODO:杩欓噷璋冪敤wms鐨勫彨鏂欐帴鍙� try { + //棣栧厛鍒ゆ柇搴撳瓨鏄惁瀛樺湪 + var dto = await IsExistInWms(input.PipeSpecCode); + if (dto != null) + { + throw new UserFriendlyException($"宸茬粡鍒嗘嫞杩囷紝搴撳瓨鍦ㄥ簱浣峽dto.PlaceNo},鎵樼洏鍙穥dto.ContainerNo}"); + } + + WmsMaterialStockCreateDto param = new WmsMaterialStockCreateDto() { ContainerNo = input.ContinerNo, @@ -256,6 +268,7 @@ }; return response; } + /// <summary> /// 鍒涘缓浣滀笟璁″垝 /// </summary> @@ -264,7 +277,6 @@ /// <param name="workPlanAppService"></param> /// <returns></returns> /// <exception cref="UserFriendlyException"></exception> - public async Task<MesOrderResponse> CommonCreatebyApsAsync(List<WorkPlanInput> input, IServiceProvider _serviceProvider, WorkPlanAppService workPlanAppService, string userId, string userAccount @@ -304,6 +316,8 @@ var orderManager = _serviceProvider.GetRequiredService<IOrderManager>(); var productProvider = _serviceProvider.GetRequiredService<IProductProvider>(); var formulaProvider = _serviceProvider.GetRequiredService<IFormulaProvider>(); + + var workTaskAppService = _serviceProvider.GetRequiredService<IWorkTaskAppService>(); List<OrderModel> orderModels = new List<OrderModel>(); @@ -441,16 +455,36 @@ insertObj.CreatorName = userAccount; insertObj.Remark = "绯荤粺瀵煎叆"; await workPlanAppService.CreateAsync(insertObj); + + //澧炲姞鏂板璁″垝浠诲姟琛ㄦ暟鎹� 銆怑ditby shaocx,2025-05-20銆� + var org_insertTaskObj = ObjectMapper.Map<WorkPlanCreateDto, WorkTaskCreateDto>(insertObj); + org_insertTaskObj.Son_TaskCode = insertObj.TaskCode; + await workTaskAppService.CreateAsync(org_insertTaskObj); + if (insertObj.ProcessName == "鍒囧壊宸ュ簭") + {//鏂板缓 鍒嗘嫞宸ュ簭 + var insertTaskObj = ObjectMapper.Map<WorkPlanCreateDto, WorkTaskCreateDto>(insertObj); + insertTaskObj.Son_TaskCode = insertObj.TaskCode + "_1"; + insertTaskObj.ProcessName = "鍒嗘嫞宸ュ簭"; + await workTaskAppService.CreateAsync(insertTaskObj); + } + else if (insertObj.ProcessName == "瑁呴厤宸ュ簭") + {//鏂板缓 娉曞叞鍐茬爜宸ュ簭(澶氫釜) + //鐩墠鏆傛椂鎼炴垚涓�涓硶鍏� + var insertTaskObj = ObjectMapper.Map<WorkPlanCreateDto, WorkTaskCreateDto>(insertObj); + insertTaskObj.Son_TaskCode = insertObj.TaskCode + "_1"; + insertTaskObj.ProcessName = "娉曞叞鍐茬爜宸ュ簭"; + await workTaskAppService.CreateAsync(insertTaskObj); + } } #endregion await uow.CompleteAsync(); } - catch (Exception) + catch (Exception ex) { await uow.RollbackAsync(); - throw; + throw ex; } finally { @@ -1148,6 +1182,50 @@ } /// <summary> + /// 绠℃缂栫爜鏄惁瀛樺湪搴撳瓨涓� + /// </summary> + /// <param name="pipeSpecCode"></param> + /// <returns></returns> + /// <exception cref="UserFriendlyException"></exception> + public async Task<WmsMaterialStockDto> IsExistInWms(string pipeSpecCode) + { + //TODO:杩欓噷璋冪敤wms鐨勫簱瀛樻煡璇㈡帴鍙� + try + { + GetWmsMaterialStockInput param = new GetWmsMaterialStockInput() + { + RedundantField2 = pipeSpecCode, + RedundantField2_FilterMode = SearchFilterModeEnum.绮惧噯鏌ヨ + }; + + string baseUrl = @"http://127.0.0.1:18000/api/v1/HIAWms/"; + string url = baseUrl + "LMesOperate/FindListByFilter"; + string json = JsonConvert.SerializeObject(param); + var result = HttpApiRequest.HttpPost(url, json); + var res = JsonConvert.DeserializeObject<CmsApiResponse<List<WmsMaterialStockDto>>>(result); + if (res.Code == 200) + { + var retData = res.Data as List<WmsMaterialStockDto>; + if (retData?.Count > 0) + { + return retData.First(); + } + return null; + + } + else + { + throw new UserFriendlyException(res.Message); + }; + } + catch (Exception) + { + + throw; + } + } + + /// <summary> /// 鐢熸垚闅忔満鐨刉msTaskNo /// </summary> /// <returns>闅忔満鐢熸垚鐨勪换鍔$紪鍙�</returns> -- Gitblit v1.9.3