王 垚
2022-09-05 89e9e87324656eb6ff2bc70c731ee676eeac9111
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
using System;
using System.ComponentModel;
using System.Data;
using Kingdee.BOS.Core.Bill.PlugIn;
using Kingdee.BOS.Core.DynamicForm.PlugIn.Args;
using Kingdee.BOS.Orm.DataEntity;
using Kingdee.BOS.ServiceHelper;
using ZD.Cloud.WebApi;
using System.Linq;
using Kingdee.BOS.Core.Bill.PlugIn.Args;
using Kingdee.K3.SCM.Core;
 
namespace Demo.BillView.PRD
{
    /// <summary>
    /// 日计划用料清单变更单 表单插件
    /// </summary>
    [Description("日计划用料清单变更单表单插件")]
    [Kingdee.BOS.Util.HotUpdate]
    public class Pro_DayPlanBG : AbstractBillPlugIn
    {
        CloudClient cloudClient = new CloudClient("http://localhost//k3cloud/");
 
        public override void DataChanged(DataChangedEventArgs e)
        {
            base.DataChanged(e);
            var model = this.View.Model;
            decimal FHQty = Convert.ToDecimal(model.GetValue("FHQty"));
            if (e.Field.Key.Contains("FUseRateNew"))
            {
                if (e.OldValue == e.NewValue || e.NewValue == null)
                    return;
                decimal FNumerator = Convert.ToDecimal(model.GetValue("FNumerator", e.Row));//分子
                decimal FDenominator = Convert.ToDecimal(model.GetValue("FDenominator", e.Row));//分母
                decimal FUseRateNew = Convert.ToDecimal(model.GetValue("FUseRateNew", e.Row));//使用比例
                decimal Hqty;
                if (FNumerator == 0 || FDenominator == 0)
                {
                    Hqty = Math.Ceiling(FHQty * (FUseRateNew / 100));
                }
                Hqty = Math.Ceiling((FNumerator / FDenominator) * FHQty * (FUseRateNew / 100));
                this.View.Model.SetValue("FHQtyMustNew", Hqty, e.Row);//新计划数量
                var m = e.Row;
                //项次
                var pro = model.GetValue("FReplaceGroup", m).ToString();
                var entrys = model.DataObject.GetValue<DynamicObjectCollection>("FEntity");
                //LogService.WriteAsync(entrys);
                //查找到的同批项次
                var finds = entrys.Where(entry => entry.GetValue<string>("FReplaceGroup") == pro && entry.GetValue<int>("Seq") != (m + 1));
                if (finds.Count() == 0) return;
                var seq = finds.First().GetValue<int>("Seq");
                model.SetValue("FUseRateNew", 100 - Convert.ToDecimal(e.NewValue), seq - 1);
            }
            if (e.Field.Key.Contains("FHQtyMustNew"))
            {
                if (e.OldValue == e.NewValue || e.NewValue == null)
                    return;
                var m = e.Row;
                decimal FNumerator = Convert.ToDecimal(model.GetValue("FNumerator", e.Row));//分子
                decimal FDenominator = Convert.ToDecimal(model.GetValue("FDenominator", e.Row));//分母
                decimal FHQtyMustNew = Convert.ToDecimal(model.GetValue("FHQtyMustNew", e.Row));//新计划数量
                decimal Hqty;
                decimal zero = 0;
                if (FNumerator == 0 || FDenominator == 0)
                {
                    Hqty = Math.Ceiling(FHQtyMustNew / FHQty * 100);
                }
                Hqty = Math.Ceiling(FHQtyMustNew / ((FNumerator / FDenominator) * FHQty) * 100);
                this.View.Model.SetValue("FUseRateNew", Hqty, e.Row);//新用料比例
            }
        }
 
        public override void BeforeSave(BeforeSaveEventArgs e)
        {
            base.BeforeSave(e);
            var entrys = this.View.Model.DataObject.GetValue<DynamicObjectCollection>("FEntity");
            string resultMes = "";
            foreach (var entry in entrys)
            {
                var fReplaceGroup = entry["FReplaceGroup"].ToString();
                //LogService.WriteAsync(entrys);
                //查找到的同批项次
                var finds = entrys.Where(trys => trys.GetValue<string>("FReplaceGroup") == fReplaceGroup);
                if (finds.Count() > 1) return;
 
                string sql = string.Format(@"/*dialect*/
select count(*) from Sc_DayPlanPPBomBillSub a 
join Sc_DayPlanPPBomBillMain b on a.FID = b.FID
where FREPLACEGROUP = '{0}' and FHMaterSubID<> '{1}' and(FPickedQty + FTranslateQty) > FHQty * ((100 - {2}) / 100.0) * FDwyl and a.FID = {3}", entry["FReplaceGroup"].ToString(), entry["FHMaterSubID_Id"].ToString(), entry["FUseRateNew"].ToString(), entry["FDayPlanId"].ToString());
                int result = DBServiceHelper.ExecuteScalar<int>(Context, sql, 0);
                if (result > 0)
                    resultMes += $"行号:" + entry["Seq"].ToString() + ",存在替代料关系,使用比例变更后超出了领用数量";
            }
            if (resultMes != "")
            {
                e.Cancel = true;
                this.View.ShowErrMessage(resultMes);
            }
 
        }
    }
}