From 5c465adb6748bfac0bccab66f1587b4ff2b6695a Mon Sep 17 00:00:00 2001
From: yanjinhui <3306209981@qq.com>
Date: 星期二, 18 三月 2025 15:11:24 +0800
Subject: [PATCH] 扭矩

---
 项目代码/WIDESEAWCS_Server 正式/SerialPortService/ProcessServer.cs |  267 +++++++++++++++++++++++++++++++++++++++++++++++++----
 1 files changed, 245 insertions(+), 22 deletions(-)

diff --git "a/\351\241\271\347\233\256\344\273\243\347\240\201/WIDESEAWCS_Server \346\255\243\345\274\217/SerialPortService/ProcessServer.cs" "b/\351\241\271\347\233\256\344\273\243\347\240\201/WIDESEAWCS_Server \346\255\243\345\274\217/SerialPortService/ProcessServer.cs"
index d0789f3..4a723d7 100644
--- "a/\351\241\271\347\233\256\344\273\243\347\240\201/WIDESEAWCS_Server \346\255\243\345\274\217/SerialPortService/ProcessServer.cs"
+++ "b/\351\241\271\347\233\256\344\273\243\347\240\201/WIDESEAWCS_Server \346\255\243\345\274\217/SerialPortService/ProcessServer.cs"
@@ -2,51 +2,274 @@
 using System.Collections.Generic;
 using System.Linq;
 using System.Text;
+using System.Text.RegularExpressions;
 using System.Threading.Tasks;
+using AutoMapper.Configuration.Conventions;
+using SqlSugar;
 using WIDESEA_ISerialPortRepository;
+using WIDESEA_SerialPortRepository;
 using WIDESEAWCS_Core;
 using WIDESEAWCS_Core.BaseRepository;
 using WIDESEAWCS_Core.BaseServices;
+using WIDESEAWCS_DTO.SerialPort;
 using WIDESEAWCS_ITaskInfoService;
 using WIDESEAWCS_Model.Models;
 
 namespace WIDESEAWCS_TaskInfoService
 {
     public class ProcessServer : ServiceBase<Dt_Process, IProcessRepository>, IProcessServer
-    { 
-        private readonly UnitOfWorkManage _unitOfWorkManage;
-        public ProcessServer(IProcessRepository BaseDal, UnitOfWorkManage unitOfWorkManage) : base(BaseDal)
+    {
+        private IPutakeRepository _putakeRepository;
+        private IUnitOfWorkManage _unitOfWorkManage;
+        private ITorqueOpRepository _torqueOpRepository;
+        public ProcessServer(IProcessRepository BaseDal, IUnitOfWorkManage unitOfWorkManage, IPutakeRepository putakeRepository, ITorqueOpRepository torqueOpRepository) : base(BaseDal)
         {
-            _unitOfWorkManage=unitOfWorkManage;
+            _putakeRepository = putakeRepository;
+            _unitOfWorkManage = unitOfWorkManage;
+            _torqueOpRepository = torqueOpRepository;
         }
-        public WebResponseContent GetProcess(string gruop)
+
+        public override PageGridData<Dt_Process> GetPageData(PageDataOptions options)
+        {
+            OrderByParameters = new Dictionary<string, OrderByType>
+            {
+                { nameof(Dt_Process.SetpNum), OrderByType.Asc },//鎸変粈涔堝瓧娈垫帓搴�
+                 { nameof(Dt_Process.CraftType), OrderByType.Asc }
+            };
+            return base.GetPageData(options);
+        }
+
+    
+
+        //鑾峰彇濂楃瓛鏁伴噺
+        public WebResponseContent GetSleeveandStep(string gruops)
         {
             try
             {
-                _unitOfWorkManage.BeginTran();
-                var proce = BaseDal.QueryData(i => i.CraftType == gruop);
-
-
-                _unitOfWorkManage.CommitTran();
-                if (proce != null)
-                {
-                    return new WebResponseContent { Status = true, Data = gruop };
-                }
-                else
-                {
-                    return new WebResponseContent
+                var result = BaseDal.QueryData(x => x.CraftType == gruops) // 鍏堢瓫閫� CraftType
+                    .GroupBy(x => x.CraftType) // 鎸� CraftType 鍒嗙粍
+                    .Select(g => new
                     {
-                        Status = false,
-                        Message = "鏁版嵁涓虹┖"
+                        maxNodal = g.Max(a => a.Nodal),
+                        sumTorqueSum = g.Sum(a => a.TorqueSum)
+                    }).ToList();
+                
+                return new WebResponseContent { Status = true, Data = result };
+            }
+            catch (Exception ex)
+            {
+                return new WebResponseContent { Status = false, Message = "鏌ヨ澶辫触锛�" + ex.Message };
+            }
+        }
+
+
+
+        public WebResponseContent AddOrUpdateProcess(AddProcessDTO addProcessDTO)
+        {
+            try
+            {
+                var allProcesses = BaseDal.QueryData(); // 浠呮煡璇竴娆℃墍鏈夋暟鎹�
+
+                if (addProcessDTO.id == 0) // 娣诲姞
+                {
+                    // 妫�鏌ユ槸鍚﹀凡缁忓瓨鍦ㄧ浉鍚岀殑 setnum
+                    if (allProcesses.Any(x => x.SetpNum == addProcessDTO.setnum && x.CraftType == addProcessDTO.craftstype))
+                    {
+                        return new WebResponseContent { Status = false, Message = $"姝ラ {addProcessDTO.setnum} 宸插瓨鍦紝涓嶈兘閲嶅娣诲姞锛�" };
+                    }
+
+                    // 鍒涘缓鏂板伐鑹烘楠�
+                    var proces = new Dt_Process
+                    {
+                        SetpNum = addProcessDTO.setnum,
+                        CraftType = addProcessDTO.craftstype,
+                        CraftsStep = addProcessDTO.craftsstep,
+                        CraftContent = addProcessDTO.craftcontent,
+                        Tools = addProcessDTO.tools,
+                        Material = addProcessDTO.material,
+                        ArticleOneid = addProcessDTO.aritcleoneid,
+                        ArticleOne = addProcessDTO.articleone,
+                        ArticleTowid = addProcessDTO.aritcletowid,
+                        ArticleTwo = addProcessDTO.articletwo,
+                        CreateDate = DateTime.Now
                     };
+
+                    BaseDal.AddData(proces);
+                    return new WebResponseContent { Status = true, Data = proces };
                 }
+                else // 鏇存柊
+                {
+                    var existingProcess = allProcesses.FirstOrDefault(x => x.CraftID == addProcessDTO.id);
+                    if (existingProcess == null)
+                    {
+                        return new WebResponseContent { Status = false, Message = "鏈壘鍒拌宸ヨ壓姝ラ锛屾棤娉曟洿鏂帮紒" };
+                    }
+
+                    // 鍙湁褰� setnum 鍙戠敓鍙樺寲鏃讹紝鎵嶈繘琛岄噸澶嶆�ф鏌�
+                    if (existingProcess.SetpNum != addProcessDTO.setnum &&
+                        allProcesses.Any(x => x.SetpNum == addProcessDTO.setnum && x.CraftType == addProcessDTO.craftstype && x.CraftID != addProcessDTO.id))
+                    {
+                        return new WebResponseContent { Status = false, Message = $"姝ラ {addProcessDTO.setnum} 宸插瓨鍦紝涓嶈兘閲嶅锛�" };
+                    }
+
+                    // 鏇存柊鏁版嵁
+                    existingProcess.Nodal = addProcessDTO.Nodal;
+                    existingProcess.SetpNum = addProcessDTO.setnum;
+                    existingProcess.CraftType = addProcessDTO.craftstype;
+                    existingProcess.CraftsStep = addProcessDTO.craftsstep;
+                    existingProcess.CraftContent = addProcessDTO.craftcontent;
+                    existingProcess.Tools = addProcessDTO.tools;
+                    existingProcess.Material = addProcessDTO.material;
+                    existingProcess.ArticleOneid = addProcessDTO.aritcleoneid;
+                    existingProcess.ArticleOne = addProcessDTO.articleone;
+                    existingProcess.ArticleTowid = addProcessDTO.aritcletowid;
+                    existingProcess.ArticleTwo = addProcessDTO.articletwo;
+                    existingProcess.CreateDate = DateTime.Now;
+
+                    BaseDal.UpdateData(existingProcess);
+                    return new WebResponseContent { Status = true, Data = existingProcess };
+                }
+            }
+            catch (Exception ex)
+            {
+                return new WebResponseContent { Status = false, Message = "鎿嶄綔澶辫触锛�" + ex.Message };
+            }
+        }
+
+
+
+
+        //鑾峰彇褰撳墠浠诲姟宸ヤ綔姝ラ
+        public WebResponseContent Getcircuit(string group, string takeid)
+        {
+            try
+            {
+                //鏍规嵁缁勫拰浠诲姟鍙疯幏寰梩op琛ㄥ叏閮ㄦ暟鎹�
+                var torp = _torqueOpRepository.QueryData(x => x.GroupOp == group && x.TakeId == takeid);
+
+
+                //鑾峰彇Modifier  ="true"  琛ㄧず鏄己鍒舵墽琛�
+                var Mod = torp.Select(x => x.Modifier).FirstOrDefault();
+
+                //鏌ュ嚭宸ヨ壓琛�
+                var process = BaseDal.QueryData(x => x.CraftType == group);
+
+                //杩斿洖褰撳墠宸ヨ壓鐨勬渶澶ф楠�
+                var maxproce = process.Max(x => x.SetpNum);
+                
+
+                //鎷垮埌宸ヨ壓琛ㄤ腑姝ラ涓�1鐨�
+                var proNoe = process.Where(x => x.SetpNum == 1);//鑾峰緱宸ヨ壓琛ㄤ腑鐨勭涓�姝�
+                if (torp.Count == 0)
+                {
+                    return new WebResponseContent { Status = true, Message = "杩斿洖宸ヨ壓琛ㄤ腑鐨勭涓�鏉�", Data =new { proNoe, maxproce } };
+                }
+
+                var nowNum = torp.Max(x => x.ProcessSte);//鑾峰緱褰撳墠鏈�澶ф楠�
+
+                //op.Modifier="true"  琛ㄧず鏄己鍒舵墽琛岋紝灏变笉闇�瑕佸垽鏂簲鎵殑娆℃暟锛岀洿鎺ヨ繑鍥� op.ProcessSte+1
+                if (Mod == "true")
+                {
+                   var  now= maxproce + 1;
+                    return new WebResponseContent { Status = true, Data = new { proNoe, maxproce, now } };
+                }
+
+                //濡傛灉瀛樺�艰〃涓湁鏁版嵁灏辫繑鍥炵粰浠栧綋鍓嶅伐鑹烘楠�
+                var maxpro = process.Where(x => x.SetpNum == nowNum);
+
+
+                //鍒ゆ柇褰撳墠姝ラ鐨勬壄鍔涙鏁版槸鍚﹀畬鎴愶紝娌″畬鎴愯繑鍥炲綋鍓嶆楠わ紝瀹屾垚杩斿洖op.ProcessSte+1锛岀姸鎬佸�肩粰false   
+
+                return new WebResponseContent { Status = true, Message = "杩斿洖褰撳墠浠诲姟鍋氬埌鐨勫ぇ姝ラ", Data =new { maxpro, maxproce } };
 
             }
             catch (Exception ex)
             {
-                _unitOfWorkManage.RollbackTran();
-                return new WebResponseContent { Status = false, Message = "澶辫触" + ex.Message };
+                return new WebResponseContent { Status = false, Message = "鏌ヨ澶辫触锛�" + ex.Message };
+            }
+        }
+
+        public WebResponseContent Nextprocess(SetpDTO setpDTO,bool flag)//寮哄埗鎵ц缁欐垜true
+        {
+            try
+            {
+                Dt_TorqueOp op = new Dt_TorqueOp();
+                //鏌ュ嚭宸ヨ壓琛�
+                var process = BaseDal.QueryData(x => x.CraftType == setpDTO.group);
+
+                // 鏌ヨ褰撳墠姝ラ鐨� TorqueOp 璁板綍锛屽尮閰� ProcessSte鍜岀粍锛屼换鍔″彿锛屾鏌ユ槸鍚﹁揪鍒拌姹傦紙瀹為檯鏁伴噺锛�
+                int practiceCount = _torqueOpRepository.QueryData(x => x.ProcessSte == setpDTO.setnum && x.GroupOp == setpDTO.group && x.TakeId == setpDTO.takeid).Count();
+
+                //鏌ュ埌鏈夎鏉℃暟鎹簡(鏇村叿鍒嗙粍鍜屾楠ゆ壘鍒拌鏉℃暟鎹�)
+                var nowdate = process.Where(x => x.CraftType == setpDTO.group && x.SetpNum == setpDTO.setnum);
+
+                //杩斿洖褰撳墠宸ヨ壓鐨勬渶澶ф楠�
+                var maxproce = process.Max(x => x.SetpNum);
+                var TorqueOneQuantity = nowdate.Select(x => x.TorqueOneQuantity).FirstOrDefault();
+                var TorqueTwoQuantity= nowdate.Select(x => x.TorqueTwoQuantity).FirstOrDefault();
+
+                //鍒ゆ柇瀛樺�艰〃鐨勬暟鎹槸鍚︽弧瓒宠姝ラ闇�瑕佸嚑鏉℃暟鎹殑鏉℃暟
+                int TargetCount = TorqueOneQuantity + TorqueTwoQuantity;//涓�鍏辫鏈夊灏戞潯鏁版嵁锛堢洰鏍囨暟閲忥級
+
+                if (practiceCount < TargetCount && !flag)
+                {
+                    return new WebResponseContent { Status = true, Message = "娌℃湁瀹屾垚褰撳墠姝ラ", Data =new { nowdate, maxproce } };
+                }
+                else if(practiceCount == TargetCount || (practiceCount != TargetCount && flag))//寮哄埗鎵ц 鍓嶇缁欐垜涓�涓猣lag=ture鏃�
+                {
+                    //寮哄埗璺宠浆涓嬩竴姝ワ紝鎻掑叆op琛ㄥ綋鍓嶆楠�
+                    op.TakeId = setpDTO.takeid;
+                    op.GroupOp = setpDTO.group;
+                    op.ProcessSte = setpDTO.setnum;
+                    op.CreateDate = DateTime.Now;
+                    op.Creater = "admin";
+                    op.Modifier = "true";
+                }
+
+                if (maxproce == setpDTO.setnum)
+                {
+                    return new WebResponseContent { Status = false, Message = "浣犲畬鎴愪簡褰撳墠浣滀笟" };
+                }
+                int num = setpDTO.setnum + 1;
+
+                //杩斿洖涓嬩竴姝ユ楠�
+                var nex = process.Where(x => x.CraftType == setpDTO.group && x.SetpNum == num).FirstOrDefault();
+
+
+                _torqueOpRepository.AddData(op);
+                return new WebResponseContent { Status = true,Message= $"浣犲凡瀹屾垚褰撳墠绗瑊setpDTO.setnum}锛屽噯澶囩{num}姝ヤ换鍔�", Data = new { nex, maxproce } };
+            }
+            catch (Exception ex)
+            {
+                return new WebResponseContent { Status = false, Message = "鏌ヨ澶辫触锛�" + ex.Message };
+            }
+        }
+
+        public WebResponseContent PreviousProcess(SetpDTO setpDTO)
+        {
+            try
+            {
+                //鏌ュ嚭宸ヨ壓琛�
+                var process = BaseDal.QueryData(x => x.CraftType == setpDTO.group);
+
+                // 鏌ヨ褰撳墠姝ラ鐨� TorqueOp 璁板綍锛屽尮閰� ProcessSte鍜岀粍锛屼换鍔″彿锛屾鏌ユ槸鍚﹁揪鍒拌姹傦紙瀹為檯鏁伴噺锛�
+                int practiceCount = _torqueOpRepository.QueryData(x => x.ProcessSte == setpDTO.setnum && x.GroupOp == setpDTO.group && x.TakeId == setpDTO.takeid).Count();
+                //鏌ュ埌鏈夎鏉℃暟鎹簡(鏇村叿鍒嗙粍鍜屾楠ゆ壘鍒拌鏉℃暟鎹�)
+                var nowdate = process.Where(x => x.CraftType == setpDTO.group && x.SetpNum == setpDTO.setnum);
+
+                //杩斿洖褰撳墠宸ヨ壓鐨勬渶澶ф楠�
+                var maxproce = process.Max(x => x.SetpNum);
+                int num = setpDTO.setnum - 1;
+                var nex = process.Where(x => x.CraftType == setpDTO.group && x.SetpNum == num).FirstOrDefault();
+                return new WebResponseContent { Status = true, Message = $"涓婁竴姝setpDTO.setnum}", Data = new { nex, maxproce } };
+            }
+            catch (Exception ex)
+            {
+                return new WebResponseContent { Status = false, Message = "鏌ヨ澶辫触锛�" + ex.Message };
             }
         }
     }
-}
+       
+
+    }
+

--
Gitblit v1.9.3