From 727ed59c834554dfea2afc77a883f1545c9165a5 Mon Sep 17 00:00:00 2001
From: schangxiang@126.com <schangxiang@126.com>
Date: 周一, 12 5月 2025 14:56:10 +0800
Subject: [PATCH] 222

---
 PipeLineLems/server/src/CMS.Plugin.PipeLineLems.Application/Implements/MesAppService.cs |  425 ++++++++++++++++++-----------------------------------
 1 files changed, 145 insertions(+), 280 deletions(-)

diff --git a/PipeLineLems/server/src/CMS.Plugin.PipeLineLems.Application/Implements/MesAppService.cs b/PipeLineLems/server/src/CMS.Plugin.PipeLineLems.Application/Implements/MesAppService.cs
index 427de9f..c2beaf6 100644
--- a/PipeLineLems/server/src/CMS.Plugin.PipeLineLems.Application/Implements/MesAppService.cs
+++ b/PipeLineLems/server/src/CMS.Plugin.PipeLineLems.Application/Implements/MesAppService.cs
@@ -1,308 +1,173 @@
-using CMS.Plugin.PipeLineLems.Application.Contracts.Dtos.MyTestEntityNames;
+using CMS.Plugin.FormulaManagement.Abstractions;
+using CMS.Plugin.OrderManagement.Abstractions;
+using CMS.Plugin.OrderManagement.Abstractions.Enums;
+using CMS.Plugin.OrderManagement.Abstractions.Models;
+using CMS.Plugin.PipeLineLems.Application.Contracts.Dtos.WorkPlan;
 using CMS.Plugin.PipeLineLems.Application.Contracts.Services;
-using CMS.Plugin.PipeLineLems.Domain.MyTestEntityNames;
-using CMS.Plugin.PipeLineLems.Domain.Shared;
-using CMS.Plugin.PipeLineLems.Domain.Shared.MyTestEntityNames;
+using CMS.Plugin.PipeLineLems.Domain.WorkPlan;
+using CMS.Plugin.ProductManagement.Abstractions;
+using Microsoft.Extensions.DependencyInjection;
 using Volo.Abp;
-using Volo.Abp.Application.Dtos;
-using Volo.Abp.Data;
-using Volo.Abp.ObjectExtending;
+using Volo.Abp.Users;
 
 namespace CMS.Plugin.PipeLineLems.Application.Implements;
 
-/// <inheritdoc />
-public class MesAppService : CMSPluginAppService, IMesAppService
+public class MesAppService : CMSPluginAppService,IMesAppService
 {
-    private readonly IMyTestEntityNameRepository _mytestentitynameRepository;
+    private readonly IServiceProvider _serviceProvider;
+    private readonly WorkPlanAppService _workPlanAppService;
+    private readonly SharedService _sharedService;
+    //private readonly IEventBus _eventBus;
 
-    /// <summary>
-    /// Initializes a new instance of the <see cref="MyTestEntityNameAppService"/> class.
-    /// </summary>
-    /// <param name="mytestentitynameRepository">The task job repository.</param>
-    public MesAppService(IMyTestEntityNameRepository mytestentitynameRepository)
+    public MesAppService(IServiceProvider serviceProvider
+        , WorkPlanAppService workPlanAppService
+        //, IEventBus eventBus
+        , SharedService sharedService
+        )
     {
-        _mytestentitynameRepository = mytestentitynameRepository;
+        _serviceProvider = serviceProvider;
+        // _eventBus = eventBus;
+        _workPlanAppService = workPlanAppService;
+        _sharedService = sharedService;
     }
 
-    /// <inheritdoc />
-    public virtual async Task<MyTestEntityNameDto> GetAsync(Guid id)
+    public async Task<MesOrderResponse> CreateAsync(List<WorkPlanInput> input, string userId, string userAccount)
     {
-        return ObjectMapper.Map<MyTestEntityName, MyTestEntityNameDto>(await _mytestentitynameRepository.GetAsync(id));
+        var response = await _sharedService.CommonCreatebyApsAsync(input, _serviceProvider, _workPlanAppService, userId, userAccount);
+
+        return response;
     }
+    //public async Task<MesOrderResponse> CreateAsync(List<WorkPlanInput> input)
+    //{
+    //    if (input == null)
+    //    {
+    //        throw new UserFriendlyException("杈撳叆鍙傛暟涓嶈兘涓虹┖");
+    //    }
 
-    /// <inheritdoc />
-    public virtual async Task<PagedResultDto<MyTestEntityNameDto>> GetListAsync(GetMyTestEntityNamesInput input)
-    {
-        Check.NotNull(input, nameof(input));
+    //    if (input.Count == 0)
+    //    {
+    //        throw new UserFriendlyException("杈撳叆鍙傛暟Data涓嶈兘涓虹┖");
+    //    }
 
-        if (input.Sorting.IsNullOrWhiteSpace())
-        {
-            input.Sorting = nameof(MyTestEntityName.Sort);
-        }
+    //    var orderManager = _serviceProvider.GetRequiredService<IOrderManager>();
+    //    var productProvider = _serviceProvider.GetRequiredService<IProductProvider>();
+    //    var formulaProvider = _serviceProvider.GetRequiredService<IFormulaProvider>();
+    //    List<OrderModel> orderModels = new List<OrderModel>();
+    //    //鎸夌収浠诲姟缂栧彿鍒嗙粍
+    //    var groupTask = input.GroupBy(x => x.TaskCode);
+    //    foreach (var gTask in groupTask)
+    //    {
+    //        var taskCode = gTask.Key;
+    //        var order = await orderManager.GetByCodeAsync(taskCode);
+    //        if (order != null)
+    //        {
+    //            throw new UserFriendlyException($"浠诲姟缂栧彿[{taskCode}]宸插瓨鍦�");
+    //        }
 
-        var specification = new MyTestEntityNameSpecification(input.Name);
-        var count = await _mytestentitynameRepository.GetCountAsync(input.Filter, specification);
-        var list = await _mytestentitynameRepository.GetListAsync(input.Sorting, input.MaxResultCount,  input.SkipCount, input.Filter, specification);
 
-        return new PagedResultDto<MyTestEntityNameDto>(count, ObjectMapper.Map<List<MyTestEntityName>, List<MyTestEntityNameDto>>(list));
-    }
+    //        //var product = await productProvider.FindByNameAsync(orderItem.PipeSectionName);
+    //        //if (product == null)
+    //        //{
+    //        //    throw new UserFriendlyException($"浜у搧鍚嶇О[{orderItem.PipeSectionName}]涓嶅瓨鍦�");
+    //        //}
 
-    /// <inheritdoc />
-    public virtual async Task<MyTestEntityNameDto> CreateAsync(MyTestEntityNameCreateDto input)
-    {
-        await CheckCreateOrUpdateDtoAsync(input);
+    //        //var formula = await formulaProvider.GetFormulaAsync(product.Id);
+    //        //if (formula == null)
+    //        //{
+    //        //    throw new UserFriendlyException($"浜у搧鍨嬪彿[{orderItem.MaterialCode}]鏃犲叧鑱旈厤鏂�");
+    //        //}
+    //        //棣栧厛瑕佸垱寤� 鎵撶爜鍒囧壊鐨勫伐鍗� 
+    //        var productForCut = await productProvider.FindByNameAsync("鍒囧壊鍘熸枡绠�");
+    //        if (productForCut == null)
+    //        {
+    //            throw new UserFriendlyException($"浜у搧鍚嶇О[鍒囧壊鍘熸枡绠涓嶅瓨鍦�");
+    //        }
+    //        var formulaForCut = await formulaProvider.GetFormulaAsync(productForCut.Id);
+    //        if (formulaForCut == null)
+    //        {
+    //            throw new UserFriendlyException($"浜у搧鍚嶇О[鍒囧壊鍘熸枡绠鏃犲叧鑱旈厤鏂�");
+    //        }
+    //        //鍒嗙粍鏁版嵁
+    //        var group = gTask.ToList().GroupBy(x => x.DataIdentifier);
+    //        foreach (var item in group)
+    //        {
+    //            OrderModel orderModelForCut = new OrderModel()
+    //            {
+    //                Id = Guid.NewGuid(),
+    //                Code = "Cut_" + taskCode,
+    //                Source = "APS鎺ㄩ��",
+    //                PlanStartTime = gTask.ToList().First().PlannedStartTime,
+    //                PlanFinishTime = gTask.ToList().First().PlannedEndTime,
+    //                PlanQty = (ulong)item.ToList().Count,
+    //                Status = OrderStatus.NotActive,
+    //                Product = new AssociationProductModel() { Id = productForCut.Id, Name = productForCut.Name, Model = productForCut.Model, ShortNumber = productForCut.ShortNumber },
+    //                Formula = new AssociationFormulaModel() { Id = formulaForCut.Id, Code = formulaForCut.Code, Name = formulaForCut.Name }
+    //            };
+    //            orderModelForCut.ExtraProperties["OuterDiameter"] = gTask.ToList().First().OuterDiameter;//澶栧緞
+    //            orderModelForCut.ExtraProperties["Material"] = gTask.ToList().First().Material;//鏉愯川
+    //            orderModelForCut.ExtraProperties["Length"] = gTask.ToList().First().Length;//闀垮害
 
-        var exist = await _mytestentitynameRepository.NameExistAsync(input.Name);
-        if (exist)
-        {
-            throw new UserFriendlyException(L[CMSPluginDomainErrorCodes.NameAlreadyExists, input.Name]);
-        }
+    //            var orderForCut = await orderManager.GetByCodeAsync(orderModelForCut.Code);
+    //            if (orderForCut != null)
+    //            {
+    //                //throw new UserFriendlyException($"宸ュ崟[{orderModelForCut.Code}]宸插瓨鍦�");
+    //                //涓嶅啀鎶涘紓甯革紝鐩存帴璺宠繃
+    //                break;
+    //            }
 
-        var maxSort = await _mytestentitynameRepository.GetMaxSortAsync();
-        var sort = input.Sort ?? maxSort;
-        var mytestentityname = new MyTestEntityName(GuidGenerator.Create(), input.Code, input.Name, sort, input.Remark);
-        input.MapExtraPropertiesTo(mytestentityname, MappingPropertyDefinitionChecks.None);
+    //            var orderModelResultForCut = await orderManager.CreateAsync(orderModelForCut);
+    //            if (orderModelResultForCut == null)
+    //            {
+    //                throw new UserFriendlyException($"宸ュ崟[{orderModelForCut.Code}]鍒涘缓澶辫触");
+    //            }
+    //            orderModels.Add(orderModelResultForCut);
 
-        await _mytestentitynameRepository.InsertAsync(mytestentityname);
 
-        if (input.Sort.HasValue && mytestentityname.Sort != maxSort)
-        {
-            await AdjustSortAsync(mytestentityname.Id, mytestentityname.Sort);
-        }
+    //            //OrderModel orderModel = new OrderModel();
+    //            //orderModel.Id = Guid.NewGuid();
+    //            //orderModel.Code = orderItem.TaskCode;
+    //            //orderModel.Source = "APS鎺ㄩ��";
+    //            //orderModel.Product = new AssociationProductModel() { Id = product.Id, Name = product.Name, Model = product.Model, ShortNumber = product.ShortNumber };
+    //            ////orderModel.Formula = new AssociationFormulaModel() { Id = formula.Id, Code = formula.Code, Name = formula.Name };
+    //            //orderModel.PlanStartTime = orderItem.PlannedStartTime;
+    //            //orderModel.PlanFinishTime = orderItem.PlannedEndTime;
+    //            //orderModel.PlanQty = (ulong?)orderItem.OrderQty;
+    //            //orderModel.Status = OrderStatus.NotActive;
+    //            //orderModel.ExtraProperties["Source"] = "ddd";
+    //            //var source = orderModel.ExtraProperties["Source"];
+    //            //var orderModelResult = await orderManager.CreateAsync(orderModel);
+    //            //if (orderModelResult == null)
+    //            //{
+    //            //    throw new UserFriendlyException($"宸ュ崟[{orderItem.TaskCode}]鍒涘缓澶辫触");
+    //            //}
+    //            //orderModels.Add(orderModelResult);
+    //        }
 
-        return ObjectMapper.Map<MyTestEntityName, MyTestEntityNameDto>(mytestentityname);
-    }
+    //    }
 
-    /// <inheritdoc />
-    public virtual async Task<MyTestEntityNameDto> UpdateAsync(Guid id, MyTestEntityNameUpdateDto input)
-    {
-        await CheckCreateOrUpdateDtoAsync(input);
 
-        var mytestentityname = await _mytestentitynameRepository.GetAsync(id);
-        var exist = await _mytestentitynameRepository.NameExistAsync(input.Name, mytestentityname.Id);
-        if (exist)
-        {
-            throw new UserFriendlyException(L[CMSPluginDomainErrorCodes.NameAlreadyExists, input.Name]);
-        }
+    //    //淇濆瓨鍒拌〃涓�
+    //    foreach (var item in input)
+    //    {
+    //        var insertObj = ObjectMapper.Map<WorkPlanInput, WorkPlanCreateDto>(item);
+    //        //insertObj.OrgMaterialCode = "1111";
+    //        insertObj.Sort = 1;
+    //        await _workPlanAppService.CreateAsync(insertObj);
+    //    }
 
-        mytestentityname.SetConcurrencyStampIfNotNull(input.ConcurrencyStamp);
-        input.MapExtraPropertiesTo(mytestentityname, MappingPropertyDefinitionChecks.None);
 
-        mytestentityname.Update(input.Code, input.Name, input.Remark);
+    //    // 鍙戝竷浜嬩欢
+    //    //await _eventBus.PublishAsync(new EntityChangedEto("MESCREATE", input, null, EntityChangeType.Add, true));
 
-        await _mytestentitynameRepository.UpdateAsync(mytestentityname);
-
-        return ObjectMapper.Map<MyTestEntityName, MyTestEntityNameDto>(mytestentityname);
-    }
-
-    /// <inheritdoc />
-    public async Task<List<MyTestEntityNameDto>> CloneAsync(IEnumerable<Guid> ids)
-    {
-        var mytestentitynames = new List<MyTestEntityName>();
-        if (ids != null)
-        {
-            var sort = await _mytestentitynameRepository.GetMaxSortAsync();
-            foreach (var id in ids)
-            {
-                var mytestentityname = await _mytestentitynameRepository.FindAsync(id);
-                if (mytestentityname != null)
-                {
-                    var name = mytestentityname.Name + MyTestEntityNameConsts.CloneTag;
-                    var notExist = false;
-                    while (!notExist)
-                    {
-                        var exist = await _mytestentitynameRepository.NameExistAsync(name);
-                        if (exist || mytestentitynames.Any(x => x.Name == name))
-                        {
-                            name += MyTestEntityNameConsts.CloneTag;
-                            continue;
-                        }
-
-                        notExist = true;
-                    }
-
-                    mytestentityname = await _mytestentitynameRepository.InsertAsync(mytestentityname.Clone(GuidGenerator.Create(), name, sort++));
-                    mytestentitynames.Add(mytestentityname);
-                }
-            }
-        }
-
-        return ObjectMapper.Map<List<MyTestEntityName>, List<MyTestEntityNameDto>>(mytestentitynames);
-    }
-
-    /// <inheritdoc />
-    public virtual Task DeleteAsync(Guid id)
-    {
-        return _mytestentitynameRepository.DeleteAsync(id);
-    }
-
-    /// <inheritdoc />
-    public async Task DeleteManyAsync(IEnumerable<Guid> ids)
-    {
-        foreach (var id in ids)
-        {
-            await DeleteAsync(id);
-        }
-    }
-
-    /// <inheritdoc />
-    public virtual async Task AdjustSortAsync(Guid id, int sort)
-    {
-        var list = await _mytestentitynameRepository.GetListAsync(nameof(MyTestEntityName.Sort));
-        if (list != null && list.Any())
-        {
-            var initSort = 1;
-            list.ForEach(x => x.AdjustSort(initSort++));
-            var entity = list.FirstOrDefault(x => x.Id == id);
-            if (entity != null)
-            {
-                if (sort == 1)
-                {
-                    list.Where(x => x.Id != id).ToList()?.ForEach(x => x.AdjustSort(x.Sort + 1));
-                }
-                else if (entity.Sort > sort)
-                {
-                    list.Where(x => x.Id != id && x.Sort >= sort).ToList()?.ForEach(x => x.AdjustSort(x.Sort + 1));
-                    list.Where(x => x.Id != id && x.Sort < sort).ToList()?.ForEach(x => x.AdjustSort(x.Sort - 1));
-                }
-                else if (entity.Sort < sort)
-                {
-                    list.Where(x => x.Id != id && x.Sort > sort).ToList()?.ForEach(x => x.AdjustSort(x.Sort + 1));
-                    list.Where(x => x.Id != id && x.Sort <= sort).ToList()?.ForEach(x => x.AdjustSort(x.Sort - 1));
-                }
-
-                entity.AdjustSort(sort);
-            }
-        }
-
-        await _mytestentitynameRepository.UpdateManyAsync(list);
-    }
-
-    /// <inheritdoc />
-    public async Task ImportAsync(MyTestEntityNamesImportModel input)
-    {
-        Check.NotNull(input, nameof(input));
-
-        var mytestentitynameCreateDtos = new List<(int RowIndex, MyTestEntityNameCreateDto Item)>();
-        var mytestentitynameUpdateDtos = new List<(int RowIndex, Guid Id, MyTestEntityNameUpdateDto Item)>();
-        var mytestentitynames = input.MyTestEntityNames;
-
-        if (mytestentitynames != null && mytestentitynames.Any())
-        {
-            #region 瀵煎叆鏍¢獙
-
-            // 鍒ゆ柇鍚嶇О鏄惁閲嶅锛屽苟杈撳嚭绗嚑琛岄噸澶�
-            var duplicateMyTestEntityNames = mytestentitynames.GroupBy(x => x.Name).Where(x => x.Count() > 1).ToList();
-            if (duplicateMyTestEntityNames?.Any() == true)
-            {
-                var duplicateMyTestEntityNameMsgs = duplicateMyTestEntityNames.Select(x => $"绗� {string.Join(",", x.Select(x => x.RowIndex))} 琛岋細{x.Key}  鍚嶇О閲嶅");
-                var errorMsg = $"瀵煎叆澶辫触锛侀厤缃紝 {string.Join(",", duplicateMyTestEntityNameMsgs)}锛岀粓姝㈠鍏�";
-                throw new UserFriendlyException(errorMsg);
-            }
-
-            #endregion
-
-            foreach (var mytestentityname in mytestentitynames)
-            {
-                if (mytestentityname.Code.IsNullOrWhiteSpace() && mytestentityname.Name.IsNullOrWhiteSpace())
-                {
-                    continue;
-                }
-
-                if (mytestentityname.Name.IsNullOrWhiteSpace())
-                {
-                    var errorMsg = $"瀵煎叆澶辫触锛侀厤缃紝绗瑊mytestentityname.RowIndex}琛岋細MyTestEntityName鍚嶇О涓嶈兘涓虹┖";
-                    throw new UserFriendlyException(errorMsg);
-                }
-
-                var oldMyTestEntityName = await _mytestentitynameRepository.FindByNameAsync(mytestentityname.Name);
-                if (oldMyTestEntityName != null)
-                {
-                    var mytestentitynameUpdateDto = new MyTestEntityNameUpdateDto
-                    {
-                        Code = mytestentityname.Code,
-                        Name = mytestentityname.Name,
-                        Remark = mytestentityname.Remark,
-                    };
-
-                    mytestentitynameUpdateDtos.Add((mytestentityname.RowIndex, oldMyTestEntityName.Id, mytestentitynameUpdateDto));
-                }
-                else
-                {
-                    var mytestentitynameCreateDto = new MyTestEntityNameCreateDto
-                    {
-                        Code = mytestentityname.Code,
-                        Name = mytestentityname.Name,
-                        Remark = mytestentityname.Remark,
-                    };
-
-                    mytestentitynameCreateDtos.Add((mytestentityname.RowIndex, mytestentitynameCreateDto));
-                }
-            }
-        }
-
-        // 鏂板
-        foreach (var mytestentitynameDto in mytestentitynameCreateDtos)
-        {
-            try
-            {
-                await CreateAsync(mytestentitynameDto.Item);
-            }
-            catch (Exception e)
-            {
-                var errorMsg = $"瀵煎叆澶辫触锛侀厤缃紝绗瑊mytestentitynameDto.RowIndex}琛岋細{e.Message}锛岀粓姝㈠鍏�";
-                throw new UserFriendlyException(errorMsg);
-            }
-        }
-
-        // 鏇存柊
-        foreach (var mytestentitynameDto in mytestentitynameUpdateDtos)
-        {
-            try
-            {
-                await UpdateAsync(mytestentitynameDto.Id, mytestentitynameDto.Item);
-            }
-            catch (Exception e)
-            {
-                var errorMsg = $"瀵煎叆澶辫触锛侀厤缃紝绗瑊mytestentitynameDto.RowIndex}琛岋細{e.Message}锛岀粓姝㈠鍏�";
-                throw new UserFriendlyException(errorMsg);
-            }
-        }
-    }
-
-    /// <inheritdoc />
-    public async Task<(Dictionary<string, object> Sheets, string FileName)> ExportAsync(GetMyTestEntityNamesInput input)
-    {
-        Check.NotNull(input, nameof(input));
-
-        if (input.Sorting.IsNullOrWhiteSpace())
-        {
-            input.Sorting = nameof(MyTestEntityName.Sort);
-        }
-
-        var specification = new MyTestEntityNameSpecification(input.Name);
-        var list = await _mytestentitynameRepository.GetListAsync(input.Sorting, input.MaxResultCount, input.SkipCount, input.Filter, specification, includeDetails: true);
-        var result = ObjectMapper.Map<List<MyTestEntityName>, List<MyTestEntityNameDto>>(list);
-
-        var sheets = new Dictionary<string, object>
-        {
-            ["閰嶇疆"] = result.Select(x => x.GetExportData()).ToList(),
-        };
-
-        var fileName = result.Count > 1 ? "MyTestEntityName鍒楄〃" : result.Count == 1 ? result.First()?.Name : "MyTestEntityName妯$増";
-        return (sheets, fileName);
-    }
-
-    /// <summary>
-    /// Checks the create or update dto asynchronous.
-    /// </summary>
-    /// <param name="input">The input.</param>
-    protected Task CheckCreateOrUpdateDtoAsync(MyTestEntityNameCreateOrUpdateDtoBase input)
-    {
-        Check.NotNull(input, nameof(input));
-        Check.NotNullOrWhiteSpace(input.Code, "缂栧彿", MyTestEntityNameConsts.MaxCodeLength);
-        Check.NotNullOrWhiteSpace(input.Name, "鍚嶇О", MyTestEntityNameConsts.MaxNameLength);
-        Check.Length(input.Remark, "澶囨敞", MyTestEntityNameConsts.MaxRemarkLength);
-        return Task.CompletedTask;
-    }
+    //    var response = new MesOrderResponse
+    //    {
+    //        Code = "000000",
+    //        Data = orderModels,
+    //        Fail = false,
+    //        Mesg = "澶勭悊鎴愬姛",
+    //        Success = true,
+    //        Time = DateTime.UtcNow
+    //    };
+    //    return response;
+    //}
 }

--
Gitblit v1.9.3