From a0e7ad65f78935d8b4818f063f6974db567d199d Mon Sep 17 00:00:00 2001
From: 王 垚 <1402714037@qq.com>
Date: 星期四, 26 十一月 2020 16:40:11 +0800
Subject: [PATCH] 测试问题项更改

---
 src/BLL/Demo.BillView/PRD/Pro_WorkBillPlatform.cs |   77 ++++++++++++++++++++++++++++++++++++--
 1 files changed, 72 insertions(+), 5 deletions(-)

diff --git a/src/BLL/Demo.BillView/PRD/Pro_WorkBillPlatform.cs b/src/BLL/Demo.BillView/PRD/Pro_WorkBillPlatform.cs
index d4ac0a7..85e5725 100644
--- a/src/BLL/Demo.BillView/PRD/Pro_WorkBillPlatform.cs
+++ b/src/BLL/Demo.BillView/PRD/Pro_WorkBillPlatform.cs
@@ -262,9 +262,21 @@
             else
                 sqlwhere += $" and FHSeOrderBillNo='{FSalOrder}'";
 
-            string sql = $"/*dialect*/update t1 set t1.FHLockedSub=1 from Sc_WorkBillSortBillSub t1  join Sc_WorkBillSortBillMain t2 on  t1.FID = t2.FID  where  FHMASTERDATE between  DATEADD(day,-1,getdate()) and DATEADD(day,{day - 1},getdate())   " + sqlwhere;
+            //鑾峰彇鍗曟嵁浣撲俊鎭�
+            Entity entity = this.View.BillBusinessInfo.GetEntity("FEntity");
+            //鍗曟嵁浣撲俊鎭浆鎹负鍒楄〃闆嗗悎
+            DynamicObjectCollection entityDataObjoct = this.View.Model.GetEntityDataObject(entity);
+            List<string> sqlList = new List<string>();
+            string sql;
+            foreach (var item in entityDataObjoct)
+            {
 
-            int result = DBUtils.Execute(Context, sql);
+                sql = $"/*dialect*/update Sc_WorkBillSortBillSub set FHLockedSub=1    where FEntryID in  (select TOP({day}) FEntryID from Sc_WorkBillSortBillSub where FHLOCKEDSUB = 0 AND FID = { Convert.ToString(item["FDayPlanWorkID"])} AND DATEDIFF(DAY, GETDATE(), FHMASTERDATE) >= 0 ORDER BY FEntryID)  ";
+                sqlList.Add(sql);
+
+            }
+
+            int result = DBServiceHelper.ExecuteBatch(Context, sqlList);
             if (result > 0)
             {
                 SearchList222();
@@ -272,7 +284,6 @@
             }
             else
                 this.View.ShowMessage("鎿嶄綔澶辫触锛岃仈绯荤鐞嗗憳锛�");
-
         }
         /// <summary>
         /// 淇濆瓨鍔熻兘
@@ -287,11 +298,17 @@
             //鍗曟嵁浣撲俊鎭浆鎹负鍒楄〃闆嗗悎
             DynamicObjectCollection entityDataObjoct = this.View.Model.GetEntityDataObject(entity);
             DateTime date = DateTime.Now;
-
             foreach (DynamicObject current in entityDataObjoct)
             {
+                DateTime FBzDate = Convert.ToDateTime(Convert.ToDateTime(current["FBzDate"]));
+                DateTime end = Convert.ToDateTime(Convert.ToDateTime(current["FBzDate"]).AddDays(60).ToShortDateString());//鏈�澶ф棩鏈�
                 for (int i = 0; i <= 60; i++)
                 {
+                    DateTime start = Convert.ToDateTime(date.AddDays(i).ToShortDateString());
+                    TimeSpan getDay = end.Subtract(start);
+                    //缂栧埗鏃ユ湡+61澶�>date.AddDays(i).ToShortDateString() continue
+                    if (getDay.Days < 0)
+                        break;
                     sql = $"/*dialect*/update t1 set FHQTY='{Convert.ToString(current["FT" + "" + i + ""])}' from Sc_WorkBillSortBillSub t1 join " +
                         $" Sc_WorkBillSortBillMain t2 on  t1.FID = t2.FID where FHMASTERDATE='{date.AddDays(i).ToShortDateString()}' and t2.FID='{Convert.ToString(current["FDayPlanWorkID"])}'";
                     sqlList.Add(sql);
@@ -571,6 +588,16 @@
             else
                 sqlwhere += $" and FHSeOrderBillNo='{FSalOrder}'";
 
+
+            //鐢熶骇璁㈠崟鍙�
+            string FScOrderMainNo = Convert.ToString((this.Model.GetValue("FScOrderMainNo")));
+            if (string.IsNullOrEmpty(FScOrderMainNo))
+            {
+
+            }
+            else
+                sqlwhere += $" and FSCORDERNO='{FScOrderMainNo}'";
+
             //鐗╂枡
             if ((this.Model.GetValue("FMatralId") as DynamicObject) != null)
             {
@@ -612,6 +639,10 @@
                     this.Model.SetValue("FHMainSourceInterID", dt.Rows[i]["FPRDMOMAINID"].ToString(), i);//婧愬崟涓诲唴鐮丗HMainSourceInterID
                     this.Model.SetValue("FHMainSourceEntryID", dt.Rows[i]["FPRDMOENTYID"].ToString(), i);//婧愬崟瀛愬唴鐮丗HMainSourceEntryID
                     this.Model.SetValue("FDayPlanWorkID", dt.Rows[i]["FID"].ToString(), i);//鏃ヨ鍒掑伐鍗旻ID
+
+                    this.Model.SetValue("FProductWorkShopId", dt.Rows[i]["FHSourceID"].ToString(), i);//鐢熶骇杞﹂棿
+                    this.Model.SetValue("FResourcesId", dt.Rows[i]["FHWorkShopID"].ToString(), i);//鐢熶骇璧勬簮
+
 
                     sql = @"/*dialect*/SELECT * FROM Sc_WorkBillSortBillSub WHERE DATEDIFF(D,GETDATE(),FHMASTERDATE)>=0 and FID=" + dt.Rows[i]["FID"].ToString();
                     DataTable _dt = DBServiceHelper.ExecuteDataSet(Context, sql).Tables[0];
@@ -870,6 +901,41 @@
 
             DataSet ds = DBServiceHelper.ExecuteDataSet(Context, sql);
             List<DayPlanPpbom> DayPlanPpbom = ds.ToModelList<DayPlanPpbom>();
+
+            sql = @"select T1.FID,FPLANCOUNT,FCOMPLETECOUNT,t2.FHQTY from    SC_WORKBILLSORTBILLMAIN T1 
+JOIN SC_WORKBILLSORTBILLSUB T2 ON T1.FID=T2.FID WHERE  DATEDIFF(D,GETDATE(),FHMASTERDATE) >=0 AND FPLANCOUNT>FCOMPLETECOUNT AND T1.FID in (" + FDayPlanWorkID + ")";
+            DataSet Complete = DBServiceHelper.ExecuteDataSet(Context, sql);
+            List<DayPlanPpbom> CompleteList = ds.ToModelList<DayPlanPpbom>();
+            //FID闆嗗悎
+            var FIDList = CompleteList.Select(x => x.FID).Distinct().ToList();
+            foreach (var item in FIDList)
+            {
+                var _CompleteList = CompleteList.Where(p => p.FID == item).ToList();
+                decimal FComplete = _CompleteList.FirstOrDefault().FCOMPLETECOUNT;
+                if (FComplete == 0)
+                    continue;
+                foreach (var _item in _CompleteList)
+                {
+                    FComplete = FComplete - _item.FHQTY;
+                    if (FComplete >= 0)
+                    {
+                        DayPlanPpbom.RemoveAll(p => p.FENTRYID == _item.FENTRYID);
+
+                    }
+                    else
+                    {
+                        DayPlanPpbom.FindAll(p => p.FENTRYID == _item.FENTRYID).ForEach(x =>
+                        {
+                            x.NeedQty = -(x.FNeedQty * FComplete);
+                        });
+                        break;
+                    }
+
+
+                }
+
+            }
+
             //鐗╂枡闆嗗悎 鐢辩墿鏂欏幓鍒嗙粍
             List<string> MaterialIDList = DayPlanPpbom.Select(x => x.FMATERIALID).Distinct().ToList();
             //鎻愭枡璁″垝鏁版嵁闆嗕复鏃跺瓨鍌ㄩ泦鍚�
@@ -1023,6 +1089,7 @@
                         {
                             if (Purchase.FQTY >= NeedQty)
                             {
+
                                 List<int> mmm = new List<int>();
                                 foreach (int id in FEntryIdList)
                                 {
@@ -1117,7 +1184,7 @@
                                 {
                                     FEntryIdList.Remove(mm);
                                 }
-                                
+
                             }
                         }
                         NeedQty = 0;

--
Gitblit v1.9.1