From 247d5855038f8d485c1d3a4b4a7bf148c66cbfd4 Mon Sep 17 00:00:00 2001
From: 王 垚 <1402714037@qq.com>
Date: 星期一, 11 一月 2021 15:19:53 +0800
Subject: [PATCH] 领料单改为缺料单

---
 src/BLL/Demo.BillView/PRD/Pro_WorkBillPlatform.cs |  458 ++++++++++++++++++++++++++++++++++++++++----------------
 1 files changed, 327 insertions(+), 131 deletions(-)

diff --git a/src/BLL/Demo.BillView/PRD/Pro_WorkBillPlatform.cs b/src/BLL/Demo.BillView/PRD/Pro_WorkBillPlatform.cs
index 9767d5a..26391a6 100644
--- a/src/BLL/Demo.BillView/PRD/Pro_WorkBillPlatform.cs
+++ b/src/BLL/Demo.BillView/PRD/Pro_WorkBillPlatform.cs
@@ -17,6 +17,8 @@
 using Kingdee.BOS.ServiceHelper;
 using Kingdee.BOS.ServiceHelper.FileServer;
 using Kingdee.BOS.Util;
+using Kingdee.K3.Core.SCM.STK;
+using Kingdee.K3.SCM.ServiceHelper;
 using Newtonsoft.Json.Linq;
 using NPOI.HSSF.UserModel;
 using NPOI.SS.Formula.Functions;
@@ -57,29 +59,18 @@
                 if (e.BarItemKey.ToUpper() == "BTEXPORT")
                 {
                     ExportExcel();
-                    //this.View.ShowMessage("娴嬭瘯鍟�");
-
-
                     string path = PathUtils.GetServerPath(KeyConst.TEMPFILEPATH, PathName);
-
                     DynamicFormShowParameter dynamicForm = new DynamicFormShowParameter();
                     dynamicForm.FormId = "BOS_FileDownLoad";
                     dynamicForm.OpenStyle.ShowType = ShowType.Modal;
                     dynamicForm.CustomParams.Add("IsExportData", "true");
                     dynamicForm.CustomParams.Add("url", path);
-
                     this.View.ShowForm(dynamicForm);
-
-
-                    //ShowDownload();
-
                 }
-
                 if (e.BarItemKey.ToUpper() == "TBSEARCH")
                 {
                     SearchList();
                 }
-
                 if (e.BarItemKey.ToUpper() == "TBLOCK")
                 {
                     Lock();
@@ -103,9 +94,34 @@
                 //鎻愭枡璁″垝
                 if (e.BarItemKey.ToUpper() == "TBEXTRACTION")
                 {
-                    Extraction();
-                }
+                    try
+                    {
+                        COMPLETE();
+                        DayPlanPPBomBill();
+                        Extraction();
+                    }
+                    catch (Exception ex)
+                    {
+                        this.View.ShowErrMessage(ex.Message.ToString());
+                    }
+                    finally
+                    {
+                        this.View.ShowMessage("鎿嶄綔鎴愬姛锛�");
 
+                    }
+
+                }
+                //棰勭暀
+                if (e.BarItemKey.ToUpper() == "TBRESERVE")
+                {
+                    Reserve();
+                }
+                //閲婃斁
+                if (e.BarItemKey.ToUpper() == "TBRELEASE")
+                {
+
+                    Release();
+                }
             }
             catch (Exception ex)
             {
@@ -115,7 +131,6 @@
         public override void EntryBarItemClick(BarItemClickEventArgs e)
         {
             base.EntryBarItemClick(e);
-
             if (e.BarItemKey.ToUpper() == "TBEDIT")
             {
                 SearchListEdit();
@@ -127,23 +142,25 @@
         /// <param name="e"></param>    
         public override void EntityRowDoubleClick(Kingdee.BOS.Core.DynamicForm.PlugIn.Args.EntityRowClickEventArgs e)
         {
-            var m = e.Row;
-            var n = e.Key;
             base.EntityRowClick(e);
+
             DynamicFormShowParameter formPa = new DynamicFormShowParameter();
-            formPa.FormId = "paez_CompleteAnalysisDetail";
 
-            /* jsonModel.Add("FHMainICMOInterID", FMainInterID);//涓荤敓浜ц鍗曚富鍐呯爜
-             jsonModel.Add("FHMainICMOEntryID", FMainEntryID);//涓荤敓浜ц鍗曞瓙鍐呯爜
-             jsonModel.Add("FHICMOInterID", FDayPlanWorkID);//鏃ヨ鍒掕鍗曚富鍐呯爜
-            current["FMatrailId_Id"].ToString(), current["FHMainSourceInterID"].ToString(), current["FHMainSourceEntryID"].ToString(), current["FDayPlanWorkID"].ToString())
-
-            */
-
-            formPa.CustomParams.Add("FHMainICMOInterID", Convert.ToString(this.View.Model.GetValue("FHMainSourceInterID", e.Row).ToString()));
-            formPa.CustomParams.Add("FHMainICMOEntryID", Convert.ToString(this.View.Model.GetValue("FHMainSourceEntryID", e.Row).ToString()));
-            formPa.CustomParams.Add("FHICMOInterID", Convert.ToString(this.View.Model.GetValue("FDayPlanWorkID", e.Row).ToString()));
-            formPa.CustomParams.Add("FMatrailId_Id", Convert.ToString((this.View.Model.GetValue("FMatrailId", e.Row) as DynamicObject)["Id"].ToString()));
+            if (e.ColKey == "FDELAYLNUM")
+            {
+                //鐢熶骇璁″垝骞冲彴鎷栨湡鏄庣粏璺宠浆
+                formPa.FormId = "paez_TardinessDetails";
+                formPa.CustomParams.Add("FID", Convert.ToString(this.View.Model.GetValue("FDayPlanWorkID", e.Row).ToString()));
+            }
+            else
+            {
+                //榻愬鍒嗘瀽鏄庣粏鍒楄〃璺宠浆
+                formPa.FormId = "paez_CompleteAnalysisDetail";
+                formPa.CustomParams.Add("FHMainICMOInterID", Convert.ToString(this.View.Model.GetValue("FHMainSourceInterID", e.Row).ToString()));
+                formPa.CustomParams.Add("FHMainICMOEntryID", Convert.ToString(this.View.Model.GetValue("FHMainSourceEntryID", e.Row).ToString()));
+                formPa.CustomParams.Add("FHICMOInterID", Convert.ToString(this.View.Model.GetValue("FDayPlanWorkID", e.Row).ToString()));
+                formPa.CustomParams.Add("FMatrailId_Id", Convert.ToString((this.View.Model.GetValue("FMatrailId", e.Row) as DynamicObject)["Id"].ToString()));
+            }
             this.View.ShowForm(formPa);
         }
         /// <summary>
@@ -711,7 +728,6 @@
         /// </summary>
         public void CompleteSetAnalysis()
         {
-
             try
             {
                 Stopwatch sw = new Stopwatch();
@@ -760,7 +776,7 @@
                 string sql = @"
 /*dialect*/
 select a.FPRDMOMAINID,a.FPRDMOENTYID,a.FID,b.FEntryID,a.FHPRDORGID FStockOrgId,t5.FNUMBER as OrgFnumber,a.FHOrderLev,b.FHQTY,b.FHMASTERDATE,T1.FBillNo,T1.FMOBillNO,T1.FMOEntrySeq,T1.FMoId,T1.FMaterialID,T1.FQty,
-T2.FMATERIALID FMATERIALID2, T4.FNumber,T2.FNeedQty,FNeedQty/FQty dwyl,FHQTY*(FNeedQty/FQty) PlanCount  from SC_WORKBILLSORTBILLMAIN a
+T2.FMATERIALID FMATERIALID2, T4.FNumber,T2.FNeedQty,FNeedQty/FQty dwyl,(FHQTY-ISNULL(FProductNum,0))*(FNeedQty/FQty) PlanCount  from SC_WORKBILLSORTBILLMAIN a
 join SC_WORKBILLSORTBILLSub b on a.FID = b.FID
 join T_PRD_PPBOM T1 on a.FPRDMOMAINID = t1.FMoId and a.FPRDMOENTYID = t1.FMOENTRYID
 LEFT JOIN(select FID, MAX(FENTRYID) FENTRYID, SUM(FNeedQty) FNeedQty, FMATERIALID from T_PRD_PPBOMENTRY
@@ -768,10 +784,10 @@
  --LEFT JOIN T_STK_Inventory T3 on t2.FMATERIALID = t3.FMATERIALID
 JOIN T_BD_MATERIAL T4 on T2.FMATERIALID = T4.FMATERIALID
 JOIN T_ORG_Organizations t5 on a.FHPRDORGID = t5.FORGID
---where FPRDMOMAINID = 100010
---where  t4.FMATERIALID in (105773
---)
-ORDER BY b.FHMASTERDATE,a.FHOrderLev  ";
+--鏉′欢涓轰粖澶╁線鍚庣殑鏃ヨ鍒� + 浠婂ぉ涔嬪墠鏈叧闂殑鏃ヨ鍒�
+where (FHEntryCloseDate is null and DATEDIFF(D,GETDATE(),FHMASTERDATE)<0)or DATEDIFF(D,GETDATE(),FHMASTERDATE)>=0
+ORDER BY b.FHMASTERDATE,a.FHOrderLev 
+";
                 ds = DBServiceHelper.ExecuteDataSet(Context, sql);
                 List<PRD_PPBOM> BomList = ds.ToModelList<PRD_PPBOM>();
                 //鏃ヨ鍒�+鐢熶骇璁㈠崟瀛愯〃缂栫爜ID
@@ -779,18 +795,17 @@
                 //CompleteAnalysisTempModel 鐢ㄤ簬瀛樺偍涓存椂闇�瑕佹彃鍏ユ暟鎹�
                 List<CompleteAnalysisTempModel> completeAnalysisTempModel = new List<CompleteAnalysisTempModel>();
                 int i = 1;
+                //鍒涘缓瀛楀吀 鐢ㄤ簬鍌ㄥ瓨鐗╂枡 + 鍗犵敤鏁伴噺
+                Dictionary<string, decimal> occupyDic = new Dictionary<string, decimal>();
                 foreach (var item in DatePlanList)
                 {
                     this.View.Session["ProcessRateValue"] = Convert.ToInt32(this.View.Session["ProcessRateValue"]) + Convert.ToInt32((decimal)(1.0 / DatePlanList.Count));
-
                     //绛涢�夊嚭褰撴棩璁″垝鏁版嵁
                     var _BomList = BomList.Where(x => x.FHMASTERDATE == item.FHMASTERDATE && x.FPRDMOENTYID == item.FPRDMOENTYID).ToList();
                     foreach (var _item in _BomList)
                     {
                         //璇ユ棩璁″垝鐗╂枡闇�瑕佹暟
                         decimal need = _item.PlanCount;
-                        //瀹為檯鎬诲簱瀛� 
-                        decimal sjkc = 0;
                         var sjkcList = ListInventoryByStockOrgId.Where(x => x.FMATERIALID == _item.FMATERIALID2 && x.FStockOrgId == _item.FStockOrgId).FirstOrDefault();
                         //鐪熸闇�瑕佸彇璁$畻鐨勬暟閲忥紙鎷嗗垎璐т富锛�
                         //璐т富鍖归厤
@@ -800,10 +815,20 @@
                             decimal _fLackCount = _item.PlanCount > sjkcList.FBASEQTY ? (_item.PlanCount - sjkcList.FBASEQTY) : 0;//缂烘枡鏁伴噺
                             foreach (var Inventory in _ListInventory)
                             {
+
                                 if (need == 0)
                                     break;
                                 decimal fCompleteCount = need >= Inventory.FBASEQTY ? Inventory.FBASEQTY : need;//榻愬鏁伴噺
-                                //鎬昏鍒掓暟閲� 鍜� 鎬诲簱瀛樻暟閲忔瘮瀵� 
+                                decimal occupyMaterial = 0;
+                                if (!occupyDic.ContainsKey(_item.FMATERIALID2))
+                                {
+                                    occupyDic.Add(_item.FMATERIALID2, fCompleteCount);
+                                }
+                                else
+                                {
+                                    occupyMaterial = occupyDic[_item.FMATERIALID2];
+                                    occupyDic[_item.FMATERIALID2] = occupyMaterial + fCompleteCount;
+                                }
                                 completeAnalysisTempModel.Add(new Demo.Model.Model.CompleteAnalysisTempModel
                                 {
                                     FHMainICMOInterIDr = _item.FPRDMOMAINID,
@@ -822,6 +847,7 @@
                                     FLackCount = _fLackCount,//缂烘枡鏁伴噺
                                     FHStockQty = sjkcList.FBASEQTY,//鍗虫椂搴撳瓨
                                     FHLeftQty = Inventory.FBASEQTY,//鍙敤鏁伴噺
+                                    FOccupyCount = occupyMaterial,//鍗犵敤鏁伴噺
                                     FComPlete = sjkcList.FBASEQTY >= _item.PlanCount ? "榻愬" : "鏈綈濂�",
                                     FPlanDate = item.FHMASTERDATE // 鏃ヨ鍒掓棩鏈�
                                 });
@@ -835,6 +861,9 @@
                         }
                         else
                         {
+                            decimal occupyMaterial = 0;
+                            if (occupyDic.ContainsKey(_item.FMATERIALID2))
+                                occupyMaterial = occupyDic[_item.FMATERIALID2];
                             completeAnalysisTempModel.Add(new Demo.Model.Model.CompleteAnalysisTempModel
                             {
                                 FHMainICMOInterIDr = _item.FPRDMOMAINID,
@@ -852,12 +881,13 @@
                                 FLackCount = _item.PlanCount,//缂烘枡鏁伴噺
                                 FHStockQty = 0,//鍗虫椂搴撳瓨
                                 FHLeftQty = 0,//鍙敤鏁伴噺
+                                FOccupyCount = occupyMaterial,//鍗犵敤鏁伴噺
                                 FComPlete = "鏈綈濂�",
                                 FPlanDate = item.FHMASTERDATE // 鏃ヨ鍒掓棩鏈�
                             });
                         }
                     }
-                    Thread.Sleep(100);
+                    //Thread.Sleep(100);
                     this.View.Session["ProcessRateValue"] = Convert.ToInt32((Convert.ToDecimal(40) / DatePlanList.Count) * i);
                     i++;
 
@@ -891,6 +921,7 @@
                     jsonModel.Add("FOwnerTypeId", item.FOwnerTypeId);
                     jsonModel.Add("FComPlete", item.FComPlete);
                     jsonModel.Add("FLackCount", item.FLackCount);
+                    jsonModel.Add("FOccupyCount", item.FOccupyCount);
                     jsonModel.Add("FPlanDate", item.FPlanDate);
                     if (item.FOwnerId != null)
                         jsonModel.Add("FOwnerId", new JObject() { ["FNUMBER"] = item.FOwnerId });
@@ -954,8 +985,8 @@
                 sqlwhere += $" and FPreparatDate='{FPreparatDate}'";
             try
             {
-                string sql = @"/*dialect*/select t1.* from  Sc_WorkBillSortBillMain t1
-   left join T_BD_MATERIAL t3 on t1.FHMaterID=t3.FMATERIALID
+                string sql = @"/*dialect*/ select t1.*,isnull((select SUM(isnull(FNotProductNum,0)) from SC_WORKBILLSORTBILLSub t2 where t2.FID = t1.FID and DATEDIFF(D,FHMASTERDATE,GETDATE())>0),0)FNotProductNum from  Sc_WorkBillSortBillMain t1
+ left join T_BD_MATERIAL t3 on t1.FHMaterID=t3.FMATERIALID
 " + sqlwhere;
                 DataTable dt = DBServiceHelper.ExecuteDataSet(Context, sql).Tables[0];
                 DateTime DateNow = DateTime.Now;//鑾峰彇褰撳墠鏃ユ湡
@@ -987,15 +1018,11 @@
                     this.Model.SetValue("FOrderQuantity", dt.Rows[i]["FOrderQuantity"].ToString(), i);//鐢熶骇璁㈠崟鏁伴噺
                     this.Model.SetValue("FDayPlanQuantity", dt.Rows[i]["FDayPlanQuantity"].ToString(), i);//鏃ヨ鍒掓暟閲�
                     this.Model.SetValue("FNoScheduled", dt.Rows[i]["FNoScheduled"].ToString(), i);//鏈帓鏁伴噺
+                    this.Model.SetValue("FDelaylnUM", dt.Rows[i]["FNotProductNum"].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];
                     foreach (DataRow dr in _dt.Rows)
                     {
-                        /*
-                        this.Model.SetValue(dr["FColumn"].ToString(), dr["FHQTY"].ToString(), i);//鏃ヨ鍒掑伐鍗旻ID
-                        if (dr["FHLockedSub"].ToString() == "1")
-                            this.View.GetFieldEditor(dr["FColumn"].ToString(), i).Enabled = false; //鍗曟嵁浣撹閿佸畾瀛楁
-                        */
                         DateTime start = Convert.ToDateTime(DateNow.ToShortDateString());
                         DateTime end = Convert.ToDateTime(Convert.ToDateTime(dr["FHMASTERDATE"]).ToShortDateString());
                         TimeSpan getDay = end.Subtract(start);
@@ -1087,8 +1114,8 @@
                 sqlwhere += $" and FPreparatDate='{FPreparatDate}'";
             try
             {
-                string sql = @"/*dialect*/select t1.* from  Sc_WorkBillSortBillMain t1
-   left join T_BD_MATERIAL t3 on t1.FHMaterID=t3.FMATERIALID
+                string sql = @"/*dialect*/ select t1.*,isnull((select SUM(isnull(FNotProductNum,0)) from SC_WORKBILLSORTBILLSub t2 where t2.FID = t1.FID and DATEDIFF(D,FHMASTERDATE,GETDATE())>0),0)FNotProductNum from  Sc_WorkBillSortBillMain t1
+ left join T_BD_MATERIAL t3 on t1.FHMaterID=t3.FMATERIALID
 " + sqlwhere;
                 DataTable dt = DBServiceHelper.ExecuteDataSet(Context, sql).Tables[0];
                 DateTime DateNow = DateTime.Now;//鑾峰彇褰撳墠鏃ユ湡
@@ -1120,6 +1147,7 @@
                     this.Model.SetValue("FOrderQuantity", dt.Rows[i]["FOrderQuantity"].ToString(), i);//鐢熶骇璁㈠崟鏁伴噺
                     this.Model.SetValue("FDayPlanQuantity", dt.Rows[i]["FDayPlanQuantity"].ToString(), i);//鏃ヨ鍒掓暟閲�
                     this.Model.SetValue("FNoScheduled", dt.Rows[i]["FNoScheduled"].ToString(), i);//鏈帓鏁伴噺
+                    this.Model.SetValue("FDelaylnUM", dt.Rows[i]["FNotProductNum"].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];
                     foreach (DataRow dr in _dt.Rows)
@@ -1174,15 +1202,12 @@
             {
                 FDayPlanWorkID += Convert.ToString(dr["FID"]) + ",";
             }
-
             FDayPlanWorkID = FDayPlanWorkID.Substring(0, FDayPlanWorkID.Length - 1);
-
             //鎻愭枡璁″垝棰勫鐞� 娓呯悊鎻愭枡璁″垝鍗曟暟鎹� 鏇存柊閲囪喘璁㈠崟鎻愭枡璁″垝鏁伴噺
             sql = string.Format(@"
  
  exec [鎻愭枡璁″垝棰勫鐞哴 '{0}'
  ", FDayPlanWorkID.Replace(",", "-"));
-
             DBServiceHelper.Execute(Context, sql);
             //閲囪喘璁㈠崟鏁版嵁
             sql = @"
@@ -1197,10 +1222,9 @@
 ";
             List<PurchaseInventory> PurchaseInventory = DBServiceHelper.ExecuteDataSet(Context, sql).ToModelList<PurchaseInventory>();
             LogHelper.Info("閲囪喘璁㈠崟鏁版嵁" + sql);
-
             sql = string.Format(@"
  /*dialect*/
- SELECT T1.FID,FHMATERID,FHMASTERDATE,FHQTY,FCOMPLETECOUNT,FPRDMOMAINID,T2.FENTRYID,T1.FBILLNO, FNeedQty,t5.FFIXLEADTIME,t5.FMAXPOQTY,t5.FMINPOQTY,t3.FMATERIALID,t6.FNumber,FHQTY*FNeedQty NeedQty,FHPRDORGID FStockOrgId FROM  SC_WORKBILLSORTBILLMAIN T1 
+ SELECT T1.FID,FHMATERID,FHMASTERDATE,FHQTY,FCOMPLETECOUNT,FPRDMOMAINID,T2.FENTRYID,T1.FBILLNO, FNeedQty,(FLeadtime+FLeadTtime2)FFIXLEADTIME,t5.FMAXPOQTY,FJITBatch FMINPOQTY,FJITMATERIALGROUP,FJITMaterielDemand,FJITSafeStock,t3.FMATERIALID,t6.FNumber,FHQTY*FNeedQty NeedQty,FHPRDORGID FStockOrgId FROM  SC_WORKBILLSORTBILLMAIN T1 
 JOIN SC_WORKBILLSORTBILLSUB T2 ON T1.FID=T2.FID
 LEFT JOIN(SELECT T1.FID,max(t2.FMATERIALID)FMATERIALIDMAIN, max(t2.FMoId)FMoId,MAX(FENTRYID) FENTRYID, SUM(convert(decimal(18, 2), FBASENUMERATOR / FBASEDENOMINATOR))FNeedQty, T1.FMATERIALID from T_PRD_PPBOMENTRY  T1
 JOIN T_PRD_PPBOM   T2 on t1.FID = t2.FID
@@ -1211,14 +1235,13 @@
 WHERE  DATEDIFF(D,GETDATE(),FHMASTERDATE) >=0
 AND FDayPlanQuantity>FCOMPLETECOUNT
 AND FERPCLSID=1 
-AND T2.FENTRYID not in (select distinct FHSOURCEENTRYID from CG_PODEMANDPLANBILLSUB where FHSOURCEINTERID IN ({0}))
+ AND T2.FENTRYID not in (select distinct FHSOURCEENTRYID from CG_PODEMANDPLANBILLSUB where FHSOURCEINTERID IN ({0}))
 AND T1.FID in ({0})
 order by FHMASTERDATE
 ", FDayPlanWorkID);
             LogHelper.Info("鎻愭枡鏁版嵁" + sql);
             DataSet ds = DBServiceHelper.ExecuteDataSet(Context, sql);
             List<DayPlanPpbom> DayPlanPpbom = ds.ToModelList<DayPlanPpbom>();
-
             //鎵�鏈夌墿鏂欑殑搴撳瓨
             ds = DBServiceHelper.ExecuteDataSet(Context, @" /*dialect*/ select   sum(FBASEQTY)FBASEQTY,FMATERIALID,FStockOrgId from T_STK_Inventory group by FMATERIALID, FStockOrgId ");
             ListInventoryByStockOrgId = ds.ToModelList<PRD_Inventory>();
@@ -1647,6 +1670,7 @@
         /// </summary>
         public void DayPlanPPBomBill()
         {
+            //閿佸畾鐨勬棩璁″垝涓嶇敓鎴�
             try
             {
                 string sql = string.Format(@"
@@ -1721,6 +1745,7 @@
                             ModelEnty.Add("FHSourceID", new JObject() { ["Fnumber"] = _item.FHSourceID });//鐢熶骇璧勬簮FHSourceID
                             ModelEnty.Add("FNumerator", _item.FNumerator);//鍒嗘瘝
                             ModelEnty.Add("FDenominator", _item.FDenominator);//鍒嗗瓙
+                            ModelEnty.Add("FDwyl", Convert.ToDecimal(_item.FNumerator) / Convert.ToDecimal(_item.FDenominator));//鍗曚綅鐢ㄦ枡
                             ModelEnty.Add("FFIXSCRAPQTY", _item.FFIXSCRAPQTY);//鍥哄畾鎹熻��
                             ModelEnty.Add("FHQtyScrap", _item.FHQtyScrap);//鍙樺姩鎹熻�楃巼%
                             Entry.Add(ModelEnty);
@@ -1765,15 +1790,12 @@
             {
                 FDayPlanWorkID += Convert.ToString(dr["FID"]) + ",";
             }
-
             FDayPlanWorkID = FDayPlanWorkID.Substring(0, FDayPlanWorkID.Length - 1);
-
             //鎻愭枡璁″垝棰勫鐞� 娓呯悊鎻愭枡璁″垝鍗曟暟鎹� 鏇存柊閲囪喘璁㈠崟鎻愭枡璁″垝鏁伴噺
             sql = string.Format(@"
- 
+  /*dialect*/
  exec [鎻愭枡璁″垝棰勫鐞哴 '{0}'
  ", FDayPlanWorkID.Replace(",", "-"));
-
             DBServiceHelper.Execute(Context, sql);
             //閲囪喘璁㈠崟鏁版嵁
             sql = @"
@@ -1788,29 +1810,30 @@
 ";
             List<PurchaseInventory> PurchaseInventory = DBServiceHelper.ExecuteDataSet(Context, sql).ToModelList<PurchaseInventory>();
             LogHelper.Info("閲囪喘璁㈠崟鏁版嵁" + sql);
-
             sql = string.Format(@"
  /*dialect*/
- select T1.*,t5.FFIXLEADTIME,t5.FMAXPOQTY,t5.FMINPOQTY,t6.FNumber from (
-select FHICMOINTERID FID,FHICMOENTRYID FEntryID,FPlanDate FHMASTERDATE,FLackCount NeedQty,FHMATERID FMATERIALID,FHStockOrgID FStockOrgId,FPRDBILLNO FBillNo from JIT_MOMaterReadysBill 
-)T1
-join t_BD_MaterialBase t4 on T1.FMATERIALID = t4.FMATERIALID
-join t_BD_MaterialPlan t5 on T1.FMATERIALID = t5.FMATERIALID
-JOIN T_BD_MATERIAL T6 ON T1.FMATERIALID = T6.FMATERIALID
-WHERE T1.NeedQty >0 AND FERPCLSID=1
-AND T1.FENTRYID not in (select distinct FHSOURCEENTRYID from CG_PODEMANDPLANBILLSUB where FHSOURCEINTERID IN ({0}))
-AND T1.FID in ({0})
+ SELECT T1.FID,FHMATERID,FHMASTERDATE,FHQTY,FCOMPLETECOUNT,FPRDMOMAINID,T2.FENTRYID,T1.FBILLNO, FNeedQty,(FLeadtime+FLeadTtime2)FFIXLEADTIME,t5.FMAXPOQTY,FJITBatch FMINPOQTY,FJITMATERIALGROUP,FJITMaterielDemand,FJITSafeStock,t3.FMATERIALID,t6.FNumber,FHQTY*FNeedQty NeedQty,FHPRDORGID FStockOrgId FROM  SC_WORKBILLSORTBILLMAIN T1 
+JOIN SC_WORKBILLSORTBILLSUB T2 ON T1.FID=T2.FID
+LEFT JOIN(SELECT T1.FID,max(t2.FMATERIALID)FMATERIALIDMAIN, max(t2.FMoId)FMoId,MAX(FENTRYID) FENTRYID, SUM(convert(decimal(18, 2), FBASENUMERATOR / FBASEDENOMINATOR))FNeedQty, T1.FMATERIALID from T_PRD_PPBOMENTRY  T1
+JOIN T_PRD_PPBOM   T2 on t1.FID = t2.FID
+group by T1.FMATERIALID, T1.FID) T3 on T1.FPRDMOMAINID = t3.FMoId  and T1.FHMATERID = t3.FMATERIALIDMAIN
+JOIN T_BD_MATERIAL T6 ON T3.FMATERIALID = T6.FMATERIALID
+join t_BD_MaterialBase t4 on t3.FMATERIALID = t4.FMATERIALID
+join t_BD_MaterialPlan t5 on t3.FMATERIALID = t5.FMATERIALID
+WHERE  DATEDIFF(D,GETDATE(),FHMASTERDATE) >=0
+AND FDayPlanQuantity>FCOMPLETECOUNT
+AND FERPCLSID=1 
+ AND T2.FENTRYID not in (select distinct FHSOURCEENTRYID from CG_PODEMANDPLANBILLSUB where FHSOURCEINTERID IN ({0}))
+AND T1.FID in ({0}) 
 order by FHMASTERDATE
 ", FDayPlanWorkID);
             LogHelper.Info("鎻愭枡鏁版嵁" + sql);
             DataSet ds = DBServiceHelper.ExecuteDataSet(Context, sql);
             List<DayPlanPpbom> DayPlanPpbom = ds.ToModelList<DayPlanPpbom>();
-
+            //鐗╂枡+搴撳瓨缁勭粐鍒嗙被
             var MaterialIDList = DayPlanPpbom.GroupBy(p => new { p.FMATERIALID, p.FStockOrgId }).Select(x => new PODemandPlanTemp { FMATERIALID = x.Key.FMATERIALID, FStockOrgId = x.Key.FStockOrgId }).ToList();
             var _MaterialIDList = MaterialIDList.Where(p => p.FMATERIALID == "105773").ToList();
-
             LogHelper.Info("鐗╂枡琛屾暟" + MaterialIDList.Count);
-
             //鎻愭枡璁″垝鏁版嵁闆嗕复鏃跺瓨鍌ㄩ泦鍚�
             List<PODemandPlanTemp> PODemandPlanTemp = new List<PODemandPlanTemp>();
             //sql闆嗗悎 鏇存柊閲囪喘璁㈠崟鍗犵敤鐨勬彁鏂欒鍒掓暟閲�
@@ -1818,45 +1841,52 @@
             //MaterialIDList = new List<string> { "105773" };
             foreach (var item in MaterialIDList)
             {
-                LogHelper.Info(item.FMATERIALID.ToString());
+                //褰撳墠鐗╂枡娌℃湁閲囪喘璁㈠崟鏃� 鐩存帴璺冲嚭
+                List<PurchaseInventory> _PurchaseInventory = PurchaseInventory.Where(x => x.FMATERIALID == item.FMATERIALID && x.FStockOrgId == item.FStockOrgId && x.FQTY > 0).ToList();
+                if (_PurchaseInventory.Count == 0)
+                {
+                    LogHelper.Info("褰撳墠鐗╂枡鏃犻噰璐俊鎭細" + item.FMATERIALID + " 搴撳瓨缁勭粐锛�" + item.FStockOrgId);
+                    continue;
+                }
+                //LogHelper.Info(item.FMATERIALID.ToString());
+                //褰撳墠鐗╂枡鍜屽簱瀛樼粍缁囧搴旂殑闇�杩涜鎻愭枡璁″垝鐨勬暟鎹�
                 List<DayPlanPpbom> _DayPlanPpbom = DayPlanPpbom.Where(x => x.FMATERIALID == item.FMATERIALID && x.FStockOrgId == item.FStockOrgId).ToList();
-
                 decimal FMINPOQTY = _DayPlanPpbom.FirstOrDefault().FMINPOQTY;//鏈�灏忚捣璁㈤噺
                 double FFIXLEADTIME = _DayPlanPpbom.FirstOrDefault().FFIXLEADTIME;//鎻愬墠鏈�
+                string FJITmaterialGroup = _DayPlanPpbom.FirstOrDefault().FJITmaterialGroup;//jit鐗╂枡鍒嗙被
+                string FJITMaterielDemand = _DayPlanPpbom.FirstOrDefault().FJITMaterielDemand; //JIT鐗╂枡闇�姹備緵璐у懆鏈�
+                string FJITSafeStock = _DayPlanPpbom.FirstOrDefault().FJITSafeStock; //JIT瀹夊叏搴撳瓨
                 decimal NeedQty = 0;
-                DateTime DATE = _DayPlanPpbom.FirstOrDefault().FHMASTERDATE;
+                DateTime DATE = _DayPlanPpbom.FirstOrDefault().FHMASTERDATE;//绗竴涓璐ц捣濮嬫棩鏈�
                 int i = 1;
                 //璁板綍鍦ㄦ渶灏忛噰璐噺闇�姹備笅鐨勬棩璁″垝鏄庣粏FentyrID
                 List<int> FEntryIdList = new List<int>();
                 foreach (var _item in _DayPlanPpbom)
                 {
-
                     if (NeedQty == 0)
                         DATE = Convert.ToDateTime(_item.FHMASTERDATE).AddDays(-FFIXLEADTIME);
-
                     FEntryIdList.Add(_item.FENTRYID);
-
                     NeedQty += _item.NeedQty;
+                    if ((FJITmaterialGroup == "鎬婚噺鎺у埗瑙勬牸绫�" || FJITmaterialGroup == "璁㈠崟涓撶敤涓�х被") && FEntryIdList.Count < Convert.ToInt32(FJITMaterielDemand)) //璁㈠崟涓撶敤涓�х被
+                        continue;
                     if (NeedQty >= FMINPOQTY)
                     {
+                        /*淇敼鍓� 鍒ゆ柇鏂瑰紡
                         List<PurchaseInventory> _PurchaseInventory = PurchaseInventory.Where(x => x.FMATERIALID == item.FMATERIALID && x.FStockOrgId == item.FStockOrgId && x.FQTY > 0).ToList();
                         if (_PurchaseInventory.Count == 0)
                         {
                             NeedQty = 0;
                             break;
                         }
-
+                        */
                         foreach (var Purchase in _PurchaseInventory)
                         {
-                            LogHelper.Info("Purchase");
-                            LogHelper.Info("鐗╂枡锛�" + Purchase.FMATERIALID + ",鏁伴噺锛�" + Purchase.FQTY);
-
+                            //LogHelper.Info("Purchase");
+                            //LogHelper.Info("鐗╂枡锛�" + Purchase.FMATERIALID + ",鏁伴噺锛�" + Purchase.FQTY);
                             if (Purchase.FQTY >= NeedQty)
                             {
-                                List<int> mmm = new List<int>();
                                 foreach (int id in FEntryIdList)
                                 {
-                                    mmm.Add(id);
                                     var DayPlanPpbomls = DayPlanPpbom.Where(c => c.FENTRYID == id && c.FMATERIALID == _item.FMATERIALID).FirstOrDefault();
                                     PODemandPlanTemp.Add(new Demo.Model.Model.PODemandPlan.PODemandPlanTemp
                                     {
@@ -1878,7 +1908,6 @@
                                         PurchseFqty = Purchase.FQTY,
                                         FStockOrgId = Purchase.FStockOrgId, //閲囪喘缁勭粐
                                         FORGNumber = Purchase.FORGNumber
-
                                     });
                                     //鎵i櫎鏃ヨ鍒掓槑缁嗗凡琚垎閰嶇殑鏁伴噺
                                     DayPlanPpbomls.NeedQty = 0;
@@ -1893,16 +1922,16 @@
                             }
                             else
                             {
+                                //鏇存柊鎬婚渶姹傛暟閲�
                                 NeedQty = NeedQty - Purchase.FQTY;
                                 decimal _NeedQty = Purchase.FQTY;//閲囪喘璁㈠崟鏁伴噺
                                 List<int> mmm = new List<int>();
                                 foreach (int id in FEntryIdList)
                                 {
-
                                     var DayPlanPpbomls = DayPlanPpbom.Where(c => c.FENTRYID == id && c.FMATERIALID == _item.FMATERIALID).FirstOrDefault();
-                                    decimal Qty = DayPlanPpbomls.NeedQty;
+                                    decimal Qty = DayPlanPpbomls.NeedQty;//璁㈠崟鏁伴噺
                                     if (Qty > _NeedQty)
-                                        Qty = _NeedQty;
+                                        Qty = _NeedQty; //璁㈠崟鏁伴噺>閲囪喘璁㈠崟鏁伴噺 鍙栭噰璐鍗�
                                     _NeedQty = _NeedQty - DayPlanPpbomls.NeedQty;
                                     PODemandPlanTemp.Add(new Demo.Model.Model.PODemandPlan.PODemandPlanTemp
                                     {
@@ -1916,7 +1945,6 @@
                                         OLDDATE = DayPlanPpbomls.FHMASTERDATE,
                                         FFIXLEADTIME = FFIXLEADTIME,
 
-
                                         PurchseFID = Purchase.FID,
                                         PurchseFentryID = Purchase.FENTRYID,
                                         FSUPPLIERID = Purchase.FSUPPLIERID,
@@ -1925,18 +1953,14 @@
                                         PurchseFqty = Purchase.FQTY,
                                         FStockOrgId = Purchase.FStockOrgId, //閲囪喘缁勭粐
                                         FORGNumber = Purchase.FORGNumber
-
-
                                     });
+                                    //鏇存柊璁″垝鏁伴噺锛堝墿浣欓渶瑕佹帓鐨勶級 缁х画鍘昏绠椾笅涓�涓噰璐鍗�
                                     DayPlanPpbomls.NeedQty -= Qty;
-
                                     //鏇存柊閲囪喘璁㈠崟
                                     sqlList.Add($"/*dialect*/ update t_PUR_POOrderEntry set FPODemandPlanCount = isnull(FPODemandPlanCount,0)+ '{Qty}' where FENTRYID = {Purchase.FENTRYID}");
-
                                     //鏇存柊Model
                                     var ls = PurchaseInventory.Where(c => c.FENTRYID == Purchase.FENTRYID).FirstOrDefault();
                                     ls.FQTY -= Qty;
-
                                     if (_NeedQty < 0)
                                     {
                                         foreach (var mm in mmm)
@@ -1945,19 +1969,16 @@
                                         }
                                         break;
                                     }
-
                                     mmm.Add(id);
                                 }
                                 foreach (var mm in mmm)
                                 {
                                     FEntryIdList.Remove(mm);
                                 }
-
                             }
                         }
                         NeedQty = 0;
                     }
-
                     #region 鍓╀笅涓嶈冻鏃舵寜鏈�灏忛噰璐壒娆$敓鎴�
                     //鍓╀笅涓嶈冻鏃舵寜鏈�灏忛噰璐壒娆$敓鎴�
                     //else if (i == _DayPlanPpbom.Count && NeedQty > 0)
@@ -1969,12 +1990,10 @@
                     //        NeedQty = 0;
                     //        break;
                     //    }
-
                     //    foreach (var Purchase in _PurchaseInventory)
                     //    {
                     //        if (Purchase.FQTY >= NeedQty)
                     //        {
-
                     //            List<int> mmm = new List<int>();
                     //            foreach (int id in FEntryIdList)
                     //            {
@@ -1991,14 +2010,12 @@
                     //                    FNumber = DayPlanPpbomls.FNumber,
                     //                    OLDDATE = DayPlanPpbomls.FHMASTERDATE,
                     //                    FFIXLEADTIME = FFIXLEADTIME,
-
                     //                    PurchseFID = Purchase.FID,
                     //                    PurchseFentryID = Purchase.FENTRYID,
                     //                    FSUPPLIERID = Purchase.FSUPPLIERID,
                     //                    PurchseFNUMBER = Purchase.FNUMBER,
                     //                    PurchseFBillNo = Purchase.FBillNo,
                     //                    PurchseFqty = Purchase.FQTY
-
                     //                });
                     //                //鎵i櫎鏃ヨ鍒掓槑缁嗗凡琚垎閰嶇殑鏁伴噺
                     //                DayPlanPpbomls.NeedQty = 0;
@@ -2018,7 +2035,6 @@
                     //            List<int> mmm = new List<int>();
                     //            foreach (int id in FEntryIdList)
                     //            {
-
                     //                var DayPlanPpbomls = DayPlanPpbom.Where(c => c.FENTRYID == id && c.FMATERIALID == _item.FMATERIALID).FirstOrDefault();
                     //                decimal Qty = DayPlanPpbomls.NeedQty;
                     //                if (Qty > _NeedQty)
@@ -2035,25 +2051,19 @@
                     //                    FNumber = DayPlanPpbomls.FNumber,
                     //                    OLDDATE = DayPlanPpbomls.FHMASTERDATE,
                     //                    FFIXLEADTIME = FFIXLEADTIME,
-
-
                     //                    PurchseFID = Purchase.FID,
                     //                    PurchseFentryID = Purchase.FENTRYID,
                     //                    FSUPPLIERID = Purchase.FSUPPLIERID,
                     //                    PurchseFNUMBER = Purchase.FNUMBER,
                     //                    PurchseFBillNo = Purchase.FBillNo,
                     //                    PurchseFqty = Purchase.FQTY
-
-
                     //                });
                     //                DayPlanPpbomls.NeedQty -= Qty;
                     //                //鏇存柊閲囪喘璁㈠崟
                     //                sqlList.Add($"/*dialect*/ update t_PUR_POOrderEntry set FPODemandPlanCount = isnull(FPODemandPlanCount,0)+ '{Qty}' where FENTRYID = {Purchase.FENTRYID}");
-
                     //                //鏇存柊Model
                     //                var ls = PurchaseInventory.Where(c => c.FENTRYID == Purchase.FENTRYID).FirstOrDefault();
                     //                ls.FQTY -= Qty;
-
                     //                if (_NeedQty < 0)
                     //                {
                     //                    foreach (var mm in mmm)
@@ -2062,14 +2072,12 @@
                     //                    }
                     //                    break;
                     //                }
-
                     //                mmm.Add(id);
                     //            }
                     //            foreach (var mm in mmm)
                     //            {
                     //                FEntryIdList.Remove(mm);
                     //            }
-
                     //        }
                     //    }
                     //    NeedQty = 0;
@@ -2078,30 +2086,22 @@
                     i++;
                 }
             }
-
             var PODemandPlanList222 = PODemandPlanTemp.GroupBy(p => new PODemandPlanTemp { PurchseFNUMBER = p.PurchseFNUMBER, FHMASTERDATE = p.FHMASTERDATE }).Select(x => new PODemandPlanTemp { PurchseFNUMBER = x.Key.PurchseFNUMBER, FHMASTERDATE = x.Key.FHMASTERDATE }).ToList();
-
             var PODemandPlanList = PODemandPlanTemp.GroupBy(p => new { p.PurchseFNUMBER, p.FHMASTERDATE }).Select(x => new PODemandPlanTemp { PurchseFNUMBER = x.Key.PurchseFNUMBER, FHMASTERDATE = x.Key.FHMASTERDATE }).ToList();
-
-
             foreach (var item in PODemandPlanList)
             {
                 DateTime date = item.FHMASTERDATE;
                 string PurchseFNUMBER = item.PurchseFNUMBER;
-
                 JObject model = new JObject();
                 model.Add("FHDate", date);
                 model.Add("FHRemark", "鐢熶骇璁㈠崟鍙凤細" + "娴嬭瘯鍛㈠憿");
                 model.Add("FSupplierID", new JObject() { ["Fnumber"] = PurchseFNUMBER });
                 JArray Fentity = new JArray();
-
                 List<PODemandPlanTemp> _PODemandPlanList = PODemandPlanTemp.Where(x => x.FHMASTERDATE == date && x.PurchseFNUMBER == PurchseFNUMBER).ToList();
                 foreach (var _item in _PODemandPlanList)
                 {
                     JObject FentityModel = new JObject();
-
                     FentityModel.Add("FHPURCHASEORGID", new JObject() { ["Fnumber"] = _item.FORGNumber });//閲囪喘缁勭粐
-
                     FentityModel.Add("FHMaterID", new JObject() { ["Fnumber"] = _item.FNumber });//鐗╂枡
                     FentityModel.Add("FHQty", _item.FQty);//鏁伴噺
                     FentityModel.Add("FHSourceInterID", _item.FID);//鏃ヨ鍒掑伐鍗旻ID
@@ -2111,8 +2111,6 @@
                     FentityModel.Add("FDayPlanDate", _item.OLDDATE);//鏃ヨ鍒掑伐鍗曠被鍨�
                     FentityModel.Add("FHRelationQty", _item.PurchseFqty);//鍏宠仈鏁伴噺
                     FentityModel.Add("FFIXLEADTIME", _item.FFIXLEADTIME);//鎻愬墠鏈�
-
-
                     FentityModel.Add("FPURCHASEORGID", new JObject() { ["Fnumber"] = _item.FORGNumber });//閲囪喘缁勭粐
                     FentityModel.Add("FHPOOrderInterID", _item.PurchseFID);// 閲囪喘璁㈠崟鍐呯爜锛欶HPOOrderInterID
                     FentityModel.Add("FHPOOrderEntryID", _item.PurchseFentryID); //閲囪喘璁㈠崟瀛愬唴鐮侊細FHPOOrderEntryID
@@ -2130,29 +2128,227 @@
                     ["IsVerifyBaseDataField"] = "false",
                     ["Model"] = model
                 };
-
                 CloudClient cloudClient = new CloudClient("http://localhost/K3Cloud/");
                 var result = cloudClient.Save("paez_PODemandPlan", jsonRoot.ToString());
                 JObject saveObj = JObject.Parse(result);
                 string saveIsSuc = saveObj["Result"]["ResponseStatus"]["IsSuccess"].ToString().ToUpper();
-
                 LogHelper.Info("鏈�鍚�");
                 LogHelper.Info(jsonRoot.ToString());
-                if (saveIsSuc == "TRUE")
-                {
-                }
-                else
-                {
+                if (saveIsSuc != "TRUE")
                     LogHelper.Error(saveIsSuc);
-
-                }
-
             }
             DBServiceHelper.ExecuteBatch(Context, sqlList);
-            this.View.ShowMessage("鎿嶄綔鎴愬姛");
             // var PODemandPlanList22 = PODemandPlanTemp.GroupBy(p => new   {p.FSUPPLIERID,     p.FHMASTERDATE }).ToList();
+        }
+        /// <summary>
+        /// 1.閿佸簱锛屽叿浣撳瓧娈垫牴鎹笟鍔″崟鎹喅瀹氾紝鈥業nv鈥欒〃绀哄嵆鏃跺簱瀛橈紝鈥楩InvDetailID鈥欎负鍗虫椂搴撳瓨ID
+        /// </summary>
+        public void Reserve()
+        {
+            try
+            {
+                decimal ReserveCount = Convert.ToDecimal((this.Model.GetValue("FReservedCount")));
+                if (ReserveCount == 0)
+                {
+                    this.View.ShowMessage("璇疯緭鍏ラ鐣欐暟閲�");
+                    return;
+                }
+                //鑾峰彇鍗曟嵁浣撲俊鎭�
+                Entity entity = this.View.BillBusinessInfo.GetEntity("FEntity");
+                //鍗曟嵁浣撲俊鎭浆鎹负鍒楄〃闆嗗悎
+                DynamicObjectCollection entityDataObjoct = this.View.Model.GetEntityDataObject(entity);
+                DynamicObjectCollection filterResult = entityDataObjoct.Clone();
+                filterResult.Clear();
+                entityDataObjoct.Where(x => Convert.ToBoolean(x["FFOCUS"])).ToList().ForEach(x => filterResult.Add(x));
+                if (filterResult.Count == 0)
+                {
+                    this.View.ShowMessage("璇烽�夋嫨闇�瑕侀鐣欑殑鍗曟嵁锛�");
+                    return;
+                }
+                //鎬诲簱瀛� 鐗╂枡+搴撳瓨缁勭粐+搴撳瓨鏁伴噺
+                DataSet ds = DBServiceHelper.ExecuteDataSet(Context, @" 
+/*dialect*/ 
+ select  sum(isnull(a.FBASEQTY,0)-ISNULL(b.FHUseQty,0))FBASEQTY,T1.FStockOrgId,T1.FMATERIALID from 
+(
+select a.FHPRDORGID FStockOrgId,T2.FMATERIALID from SC_WORKBILLSORTBILLMAIN a
+join SC_WORKBILLSORTBILLSub b on a.FID = b.FID
+join T_PRD_PPBOM T1 on a.FPRDMOMAINID = t1.FMoId and a.FPRDMOENTYID = t1.FMOENTRYID
+LEFT JOIN(select FID,FMATERIALID from T_PRD_PPBOMENTRY
+group by FMATERIALID,FID) T2 on T1.FID = t2.FID
+group by a.FHPRDORGID,T2.FMATERIALID
+) T1 
+LEFT JOIN T_STK_Inventory a on T1.FStockOrgId = a.FStockOrgId and T1.FMATERIALID =a.FMATERIALID 
+LEFT JOIN JIT_MOMaterReadysBill B ON T1.FStockOrgId = b.FHSTOCKORGID and T1.FMATERIALID =b.FHMATERID
+--where T1.FMATERIALID in (105773)
+group by T1.FStockOrgId,T1.FMATERIALID
+");
+                ListInventoryByStockOrgId = ds.ToModelList<PRD_Inventory>();
+                foreach (DynamicObject current in entityDataObjoct)
+                {
+                    if (Convert.ToString(current["FFOCUS"]) == "False")
+                        continue;
+                    string sql = string.Format(@"
+/*dialect*/
+--鐢熶骇鐢ㄦ枡娓呭崟鍒楄〃
+SELECT T1.FID,T1.FBillNo,T1.FMOBillNO,T1.FMOEntrySeq,T1.FMoId,T1.FMaterialID,T1.FQty,FPRDORGID FStockOrgId,
+T2.FMATERIALID FMATERIALID2,T4.FNumber,T2.FNeedQty,convert(decimal(18,2),FNeedQty/FQty ) as dwyl
+--,isnull(t3.FBASEQTY,0)FBASEQTY
+ FROM T_PRD_PPBOM T1
+LEFT JOIN (select FID,MAX(FENTRYID)FENTRYID,SUM(FNeedQty)FNeedQty,FMATERIALID  from T_PRD_PPBOMENTRY where FMoId='{0}'
+group by FMATERIALID,FID ) T2 on T1.FID=t2.FID
+--LEFT JOIN T_STK_Inventory T3 on t2.FMATERIALID = t3.FMATERIALID
+LEFT JOIN T_BD_MATERIAL T4 on T2.FMATERIALID=T4.FMATERIALID
+where t1.FMoId='{0}'    and T1.FMaterialID='{1}'
+", current["FHMainSourceInterID"].ToString(), current["FMatrailId_Id"].ToString());
+                    ds = DBServiceHelper.ExecuteDataSet(Context, sql);
+                    var PpbomList = ds.ToModelList<PRD_PPBOM>();
+                    //褰撳墠鏈�澶ч綈濂楁暟 涓嬪眰闇�姹傛暟閲�/鐖剁骇闇�姹傛暟閲�=鍗曚綅鐢ㄦ枡
+                    //var SumGetComplete = Math.Floor(PpbomList.Min(t => t.FBASEQTY / (t.FNeedQty / t.FQty)));
+                    //鏈�澶ч綈濂楁暟
+                    var result = (from a in PpbomList
+                                  join b in ListInventoryByStockOrgId
+                                  on new { materialId = a.FMATERIALID2, stockOrgId = a.FStockOrgId }
+                                  equals new { materialId = b.FMATERIALID, stockOrgId = b.FStockOrgId }
+                                  into g
+                                  from b in g.DefaultIfEmpty()
+                                  select new
+                                  {
+                                      value = (b?.FBASEQTY / a.dwyl) ?? 0
+                                  }).ToList().Min(x => x.value);
+                    if (result < ReserveCount)
+                    {
+                        this.View.ShowErrMessage("褰撳墠搴撳瓨瓒呭嚭鍙鐣欐渶澶ф暟锛�" + result + "");
+                        return;
+                    };
+                    //灏嗛鐣欐暟閲忓垎閰嶅埌鏃ヨ鍒掑伐鍗�
+                    sql = string.Format(@"/*dialect*/select FEntryID,FHQTY from Sc_WorkBillSortBillSub
+where FID='{0}' and isnull(FCOMPLETE,'鏈綈濂�')='鏈綈濂�'", current["FDayPlanWorkID"].ToString());
+                    DataTable dayPlanDt = DBServiceHelper.ExecuteDataSet(Context, sql).Tables[0];
+                    var count = ReserveCount;
+                    List<string> sqlList = new List<string>();
+                    if (dayPlanDt.Rows.Count > 0)
+                    {
+                        foreach (DataRow dr in dayPlanDt.Rows)
+                        {
+                            if (count > 0)
+                            {
+                                sql = string.Format("/*dialect*/ update Sc_WorkBillSortBillSub set FReservedCount = {0} where FEntryID = {1}", count >= Convert.ToDecimal(dr["FHQTY"]) ? Convert.ToDecimal(dr["FHQTY"]) : count, dr["FEntryID"].ToString());
+                                sqlList.Add(sql);
+                                count = count - Convert.ToDecimal(dr["FHQTY"]);
+                            }
+                            else
+                                break;
+                        }
+                        DBServiceHelper.ExecuteBatch(Context, sqlList);
+                    }
+                    sql = string.Format(@"/*dialect*/
+--鐢熶骇鐢ㄦ枡娓呭崟鍒楄〃
+SELECT T1.FID,T1.FBillNo,T2.FENTRYID,T1.FMOBillNO,T1.FMOEntrySeq,T1.FMoId,T1.FMaterialID,T1.FQty,FPRDORGID FStockOrgId,
+T2.FMATERIALID FMATERIALID2,T4.FNumber,T2.FNeedQty,convert(decimal(18,2),FNeedQty/T1.FQty ) as dwyl,
+t5.FBASEUNITID,t6.FSTOREUNITID,t7.FID FSTKID,t7.FOwnerID,t7.FOwnerTypeID,t7.FSTOCKID,t7.FBASEQTY
+--,isnull(t3.FBASEQTY,0)FBASEQTY
+ FROM T_PRD_PPBOM T1
+LEFT JOIN (select FID,MAX(FENTRYID)FENTRYID,SUM(FNeedQty)FNeedQty,FMATERIALID  from T_PRD_PPBOMENTRY   where FMoId='{0}'
+group by FMATERIALID,FID ) T2 on T1.FID=t2.FID
+--LEFT JOIN T_STK_Inventory T3 on t2.FMATERIALID = t3.FMATERIALID
+LEFT JOIN T_BD_MATERIAL T4 on T2.FMATERIALID=T4.FMATERIALID
+join t_BD_MaterialBase t5 on t4.FMATERIALID = t5.FMATERIALID
+join t_BD_MaterialStock t6 on t4.FMATERIALID = t6.FMATERIALID
+join T_STK_INVENTORY t7 on t4.FMATERIALID = t7.FMATERIALID and t1.FPRDORGID=t7.FSTOCKORGID
+where t1.FMoId='{0}'    and T1.FMaterialID='{1}'
+", current["FHMainSourceInterID"].ToString(), current["FMatrailId_Id"].ToString());
+                    DataTable skDt = DBServiceHelper.ExecuteDataSet(Context, sql).Tables[0];
+                    //閿佸簱
+                    List<LockStockArgs> list = new List<LockStockArgs>();
+                    foreach (DataRow dr in skDt.Rows)
+                    {
+                        LockStockArgs lockStockArgs = new LockStockArgs();
+                        lockStockArgs.ObjectId = "PRD_PPBOM"; //瀛楁 FDEMANDFORMID = 'PRD_PPBOM'
+                        lockStockArgs.BillId = dr["FID"].ToString(); //鐢熶骇鐢ㄦ枡娓呭崟涓昏〃ID
+                        lockStockArgs.BillDetailID = dr["FENTRYID"].ToString();//鐢熶骇鐢ㄦ枡娓呭崟鏄庣粏琛↖D
+                        lockStockArgs.BillNo = dr["FBillNo"].ToString();//鐢熶骇鐢ㄦ枡娓呭崟鍗曟嵁鍙�
+                        lockStockArgs.FEntryID = Convert.ToInt32(current["FHMainSourceEntryID"]); ;
+                        lockStockArgs.FID = Convert.ToInt32(current["FHMainSourceInterID"]); //鐢熶骇璁㈠崟琛孖D
+                        lockStockArgs.BaseQty = decimal.Parse(dr["FBASEQTY"].ToString());//鍩烘湰鍗曚綅鏁伴噺
+                        lockStockArgs.BaseUnitID = int.Parse(dr["FBASEUNITID"].ToString());//鍩烘湰鍗曚綅
+                        //lockStockArgs.Lot = Convert.ToString(current["FBatch"]); ;//鎵规 FBatch
+                        lockStockArgs.MaterialID = long.Parse(dr["FMATERIALID2"].ToString());
+                        lockStockArgs.OwnerID = long.Parse(dr["FOwnerID"].ToString());
+                        lockStockArgs.OwnerTypeID = dr["FOwnerTypeID"].ToString();
+                        lockStockArgs.Qty = Convert.ToDecimal(dr["dwyl"].ToString()) * ReserveCount;//鏁伴噺
+                        lockStockArgs.STOCKID = long.Parse(dr["FSTOCKID"].ToString());//浠撳簱
+                        lockStockArgs.StockOrgID = long.Parse(dr["FStockOrgId"].ToString());//搴撳瓨缁勭粐
+                        lockStockArgs.UnitID = long.Parse(dr["FSTOREUNITID"].ToString());//鍗曚綅
+                        lockStockArgs.LockBaseQty = Convert.ToDecimal(dr["dwyl"].ToString()) * ReserveCount;
+                        lockStockArgs.LockQty = Convert.ToDecimal(dr["dwyl"].ToString()) * ReserveCount;//鍩烘湰鍗曚綅鏁伴噺
+                        lockStockArgs.FInvDetailID = Convert.ToString(dr["FSTKID"].ToString());
+                        list.Add(lockStockArgs);
+                    }
+                    var sa = StockServiceHelper.SaveLockInfo(Context, list, "Inv", false);
+                    sql = @"/*dialect*/
+                             update a set 
+                             FPARENTFORMID	='PRD_MO',
+                             FPARENTINTERID	=b.FMOID,
+                             FPARENTENTRYID	=b.FMOENTRYID,
+                             FPARENTBILLNO = b.FMOBILLNO,
+                             FSRCFORMID = 'PRD_MO',
+                             FSRCINTERID = b.FMOID,
+                             FSRCENTRYID = b.FMOENTRYID,
+                             FSRCBILLNO = b.FMOBILLNO
+                             from T_PLN_RESERVELINK a 
+                             join T_PRD_PPBOM b on a.FDEMANDINTERID = b.FID
+                             where a.FPARENTINTERID = '' and a.FPARENTENTRYID =''";
+                    DBServiceHelper.Execute(Context, sql);
+                    this.View.ShowMessage("鎿嶄綔鎴愬姛锛�");
+                }
+            }
+            catch (Exception ex)
+            {
+                LogHelper.Error(ex.Message.ToString());
+                this.View.ShowErrMessage(ex.Message.ToString());
+            }
+        }
+        /// <summary>
+        /// 閲婃斁
+        /// </summary>  
+        public void Release()
+        {
+            try
+            {
+                //鑾峰彇鍗曟嵁浣撲俊鎭�
+                Entity entity = this.View.BillBusinessInfo.GetEntity("FEntity");
+                //鍗曟嵁浣撲俊鎭浆鎹负鍒楄〃闆嗗悎
+                DynamicObjectCollection entityDataObjoct = this.View.Model.GetEntityDataObject(entity);
+                DynamicObjectCollection filterResult = entityDataObjoct.Clone();
+                filterResult.Clear();
+                entityDataObjoct.Where(x => Convert.ToBoolean(x["FFOCUS"])).ToList().ForEach(x => filterResult.Add(x));
+                if (filterResult.Count == 0)
+                {
+                    this.View.ShowMessage("璇烽�夋嫨闇�瑕侀鐣欑殑鍗曟嵁锛�");
+                    return;
+                }
+                foreach (DynamicObject current in filterResult)
+                {
+                    if (Convert.ToString(current["FFOCUS"]) == "False")
+                        continue;
+                    string sql = string.Format(@"/*dialect*/ update Sc_WorkBillSortBillSub set FReservedCount = 0 where FID='{0}'", current["FDayPlanWorkID"].ToString());
+                    DBServiceHelper.Execute(Context, sql);
+
+                    //鍒犻櫎閿佸簱琛�(涓嶇敤鏇存柊搴撳瓨 搴撳瓨琛ㄦ病鏈夋洿)
+                    sql = string.Format(@"/*dialect*/
+delete T_PLN_RESERVELINKENTRY where FID IN (SELECT FID FROM T_PLN_RESERVELINK WHERE FPARENTINTERID='{0}' AND FPARENTENTRYID='{1}')
+delete T_PLN_RESERVELINK WHERE  FPARENTINTERID='{0}' AND FPARENTENTRYID='{1}'", Convert.ToString(current["FHMainSourceInterID"]), Convert.ToString(current["FHMainSourceEntryID"]));
+                }
+                this.View.ShowMessage("鎿嶄綔鎴愬姛锛�");
+            }
+            catch (Exception ex)
+            {
+                LogHelper.Error(ex.Message.ToString());
+                this.View.ShowErrMessage(ex.Message.ToString());
+            }
         }
     }
 }
 
 
+//tbReleaseReserve
\ No newline at end of file

--
Gitblit v1.9.1