lixiaojun
2025-01-21 ad1a5544539174ad4ec0beeddef96fa17e4f32fc
WinFrmUI/Yw.WinFrmUI.Hydro.Core/06-visual/02-tank/HydroTankListCtrl.cs
@@ -7,9 +7,12 @@
        public HydroTankListCtrl()
        {
            InitializeComponent();
            this.layoutControl1.SetupLayoutControl();
            this.gridView1.SetNormalView(30);
            this.gridView1.RegistCustomDrawRowIndicator(40);
            this.layoutControl1.SetupLayoutControl();
            this.generalSearchAndSetCtrl1.SearchEvent += Search;
            this.generalSearchAndSetCtrl1.ClearEvent += Reset;
            this.generalSearchAndSetCtrl1.SetEvent += Set;
        }
        /// <summary>
@@ -30,18 +33,6 @@
        public event Action<List<HydroVisualViewModel>> HydroChangedViewEvent;
        /// <summary>
        /// 显示查询面板
        /// </summary>
        [Browsable(true)]
        [Description("显示查询面板")]
        [DefaultValue(true)]
        public bool ShowFindPanel
        {
            get { return this.gridView1.OptionsFind.AlwaysVisible; }
            set { this.gridView1.OptionsFind.AlwaysVisible = value; }
        }
        /// <summary>
        /// 是否拥有水力列表
        /// </summary>
        public bool HasHydroList
@@ -49,32 +40,50 @@
            get { return _allList != null && _allList.Count > 0; }
        }
        //所有列表
        private List<HydroTankViewModel> _allList = null;
        //所有绑定列表
        private List<HydroTankViewModel> _allBindingList = null;
        private List<HydroTankViewModel> _allList = null;//所有列表
        private List<HydroTankViewModel> _allBindingList = null; //所有绑定列表
        private HydroChangeHelper _changeHelper = null;//改变辅助类
        private HydroPropStatusHelper _propStatusHelper = null;//属性状态辅助类
        /// <summary>
        /// 绑定数据
        /// </summary>
        public void SetBindingData(Yw.Model.HydroModelInfo hydroInfo)
        public void SetBindingData
            (
                Yw.Model.HydroModelInfo hydroInfo,
                HydroChangeHelper changeHelper = null,
                HydroPropStatusHelper propStatusHelper = null
            )
        {
            _allList = new List<HydroTankViewModel>();
            if (hydroInfo != null && hydroInfo.Tanks != null && hydroInfo.Tanks.Count > 0)
            {
                foreach (var visual in hydroInfo.Tanks)
                {
                    var vm = new HydroTankViewModel(visual, hydroInfo);
                    _allList.Add(vm);
                }
            }
            Search();
            SetBindingData(hydroInfo, allCalcuResultVisualDict: null, changeHelper, propStatusHelper);
        }
        /// <summary>
        /// 绑定数据
        /// </summary>
        public void SetBindingData(Yw.Model.HydroModelInfo hydroInfo, List<HydroCalcuResult> allCalcuResultList)
        public void SetBindingData
            (
                Yw.Model.HydroModelInfo hydroInfo,
                List<HydroCalcuVisualResult> allCalcuResultList,
                HydroChangeHelper changeHelper = null,
                HydroPropStatusHelper propStatusHelper = null
            )
        {
            var allCalcuResultVisualDict = allCalcuResultList?.ToDictionary(x => x.Code);
            SetBindingData(hydroInfo, allCalcuResultVisualDict, changeHelper, propStatusHelper);
        }
        /// <summary>
        /// 绑定数据
        /// </summary>
        public void SetBindingData
            (
                HydroModelInfo hydroInfo,
                Dictionary<string, HydroCalcuVisualResult> allCalcuResultVisualDict,
                HydroChangeHelper changeHelper = null,
                HydroPropStatusHelper propStatusHelper = null
            )
        {
            _allList = new List<HydroTankViewModel>();
            if (hydroInfo != null && hydroInfo.Tanks != null && hydroInfo.Tanks.Count > 0)
@@ -82,7 +91,7 @@
                foreach (var visual in hydroInfo.Tanks)
                {
                    var vm = new HydroTankViewModel(visual, hydroInfo);
                    var calcuResult = allCalcuResultList?.Find(x => x.Code == visual.Code);
                    var calcuResult = allCalcuResultVisualDict?.GetValue(visual.Code);
                    if (calcuResult != null)
                    {
                        vm.UpdateCalcuProperty(calcuResult);
@@ -90,22 +99,31 @@
                    _allList.Add(vm);
                }
            }
            _changeHelper = changeHelper;
            _propStatusHelper = propStatusHelper;
            Search();
        }
        /// <summary>
        /// 绑定数据
        /// </summary>
        public void SetBindingData(List<HydroVisualViewModel> allVisualViewModelList)
        public void SetBindingData
            (
                List<HydroVisualViewModel> allVisualViewModelList,
                HydroChangeHelper changeHelper = null,
                HydroPropStatusHelper propStatusHelper = null
            )
        {
            _allList = new List<HydroTankViewModel>();
            allVisualViewModelList?.ForEach(x =>
            {
                if (x.Catalog == HydroParterCatalogHelper.GetName(Yw.Hydro.ParterCatalog.Tank))
                if (x.Vmo.Catalog == Yw.Hydro.ParterCatalog.Tank)
                {
                    _allList.Add(x as HydroTankViewModel);
                }
            });
            _changeHelper = changeHelper;
            _propStatusHelper = propStatusHelper;
            Search();
        }
@@ -179,15 +197,24 @@
        /// <summary>
        /// 更新计算属性
        /// </summary>
        public void UpdateCalcuProperty(List<HydroCalcuResult> allCalcuResultList)
        public void UpdateCalcuProperty(List<HydroCalcuVisualResult> allCalcuResultList)
        {
            if (allCalcuResultList != null && allCalcuResultList.Count > 0)
            var allCalcuResultVisualDict = allCalcuResultList?.ToDictionary(x => x.Code);
            UpdateCalcuProperty(allCalcuResultVisualDict);
        }
        /// <summary>
        /// 更新计算属性
        /// </summary>
        public void UpdateCalcuProperty(Dictionary<string, HydroCalcuVisualResult> allCalcuResultVisualDict)
        {
            if (allCalcuResultVisualDict != null && allCalcuResultVisualDict.Count > 0)
            {
                if (_allList != null && _allList.Count > 0)
                {
                    foreach (var visual in _allList)
                    {
                        var calcuResult = allCalcuResultList.Find(x => x.Code == visual.Code);
                        var calcuResult = allCalcuResultVisualDict.GetValue(visual.Code);
                        if (calcuResult != null)
                        {
                            visual.UpdateCalcuProperty(calcuResult);
@@ -244,9 +271,13 @@
                return;
            }
            var dlg = new SetHydroTankDlg();
            dlg.SetBindingData(_allBindingList.Select(x => x.Vmo).ToList());
            dlg.SetBindingData(_allBindingList.Select(x => x.Vmo).ToList(), _changeHelper, _propStatusHelper);
            dlg.ReloadDataEvent += (list) =>
            {
                if (list == null || list.Count < 1)
                {
                    return;
                }
                _allBindingList.ForEach(x => x.UpdateProperty());
                this.hydroTankViewModelBindingSource.ResetBindings(false);
                var allVisualViewModelList = _allBindingList.Select(x => x as HydroVisualViewModel).ToList();
@@ -257,23 +288,6 @@
            dlg.ShowDialog();
        }
        //查询
        private void btnSearch_Click(object sender, EventArgs e)
        {
            Search();
        }
        //重置
        private void btnReset_Click(object sender, EventArgs e)
        {
            Reset();
        }
        //设置
        private void btnSet_Click(object sender, EventArgs e)
        {
            Set();
        }
        private void gridView1_RowCellClick(object sender, DevExpress.XtraGrid.Views.Grid.RowCellClickEventArgs e)
        {
@@ -286,9 +300,13 @@
            if (e.Column == this.colSet)
            {
                var dlg = new SetHydroTankDlg();
                dlg.SetBindingData(row.Vmo);
                dlg.SetBindingData(row.Vmo, _changeHelper, _propStatusHelper);
                dlg.ReloadDataEvent += (list) =>
                {
                    if (list == null || list.Count < 1)
                    {
                        return;
                    }
                    row.UpdateProperty();
                    this.gridView1.RefreshRow(e.RowHandle);
                    this.HydroChangedViewEvent?.Invoke(new List<HydroVisualViewModel>() { row });
@@ -319,7 +337,6 @@
            this.colMaxLevel.Visible = false;
            this.colDN.Visible = false;
            this.colMinVol.Visible = false;
            this.colCurve.Visible = false;
            this.colOverFlow.Visible = false;
            this.colCalcuPress.Visible = false;
            this.colCalcuHead.Visible = false;
@@ -346,7 +363,6 @@
            this.colMaxLevel.Visible = true;
            this.colDN.Visible = true;
            this.colMinVol.Visible = true;
            this.colCurve.Visible = true;
            this.colOverFlow.Visible = true;
            this.colCalcuPress.Visible = false;
            this.colCalcuHead.Visible = false;
@@ -373,7 +389,6 @@
            this.colMaxLevel.Visible = true;
            this.colDN.Visible = true;
            this.colMinVol.Visible = true;
            this.colCurve.Visible = true;
            this.colOverFlow.Visible = true;
            this.colCalcuPress.Visible = true;
            this.colCalcuHead.Visible = true;
@@ -385,9 +400,9 @@
        }
        /// <summary>
        /// 设置批量设置模式
        /// 设置批量模式
        /// </summary>
        public void SetBulkSetView()
        public void SetBulkView()
        {
            this.groupForHead.Visibility = DevExpress.XtraLayout.Utils.LayoutVisibility.Always;
            this.colDbLocked.Visible = true;
@@ -400,7 +415,6 @@
            this.colMaxLevel.Visible = true;
            this.colDN.Visible = true;
            this.colMinVol.Visible = true;
            this.colCurve.Visible = true;
            this.colOverFlow.Visible = true;
            this.colCalcuPress.Visible = false;
            this.colCalcuHead.Visible = false;
@@ -411,8 +425,30 @@
            this.colSet.Visible = true;
        }
        /// <summary>
        /// 设置结果模式
        /// </summary>
        public void SetResultView()
        {
            this.groupForHead.Visibility = DevExpress.XtraLayout.Utils.LayoutVisibility.Never;
            this.colDbLocked.Visible = true;
            this.colName.Visible = true;
            this.colCode.Visible = true;
            this.colModelType.Visible = true;
            this.colPoolElev.Visible = true;
            this.colInitLevel.Visible = true;
            this.colMinLevel.Visible = true;
            this.colMaxLevel.Visible = true;
            this.colDN.Visible = true;
            this.colMinVol.Visible = true;
            this.colOverFlow.Visible = true;
            this.colCalcuPress.Visible = true;
            this.colCalcuHead.Visible = true;
            this.colCalcuDemand.Visible = true;
            this.colHasDb.Visible = true;
            this.colFlags.Visible = true;
            this.colDescription.Visible = true;
            this.colSet.Visible = false;
        }
    }
}