lixiaojun
2024-11-09 c9585ab171fb973d16792d7a290994bf8279da63
WinFrmUI/Yw.WinFrmUI.Hydro.Core/06-visual/13-pressmeter/HydroPressmeterListCtrl.cs
ÎļþÃû´Ó WinFrmUI/Yw.WinFrmUI.Hydro.Core/06-parter/13-pressmeter/HydroPressmeterListCtrl.cs ÐÞ¸Ä
@@ -3,7 +3,7 @@
namespace Yw.WinFrmUI
{
    public partial class HydroPressmeterListCtrl : DevExpress.XtraEditors.XtraUserControl, IHydroParterList
    public partial class HydroPressmeterListCtrl : DevExpress.XtraEditors.XtraUserControl, IHydroVisualList
    {
        public HydroPressmeterListCtrl()
        {
@@ -16,11 +16,19 @@
        /// <summary>
        /// æ°´åŠ›ç‚¹å‡»äº‹ä»¶
        /// </summary>
        public event Action<Yw.Model.HydroParterInfo> HydroClickEvent;
        public event Action<Yw.Model.HydroVisualInfo> HydroClickInfoEvent;
        /// <summary>
        /// æ°´åŠ›ç‚¹å‡»è§†å›¾äº‹ä»¶
        /// </summary>
        public event Action<HydroVisualViewModel> HydroClickViewEvent;
        /// <summary>
        /// æ°´åŠ›æ”¹å˜äº‹ä»¶
        /// </summary>
        public event Action<List<HydroParterInfo>> HydroChangedEvent;
        public event Action<List<Yw.Model.HydroVisualInfo>> HydroChangedInfoEvent;
        /// <summary>
        /// æ°´åŠ›æ”¹å˜è§†å›¾äº‹ä»¶
        /// </summary>
        public event Action<List<HydroVisualViewModel>> HydroChangedViewEvent;
        /// <summary>
        /// æ˜¾ç¤ºæŸ¥è¯¢é¢æ¿
@@ -35,7 +43,7 @@
        }
        /// <summary>
        /// æ˜¯å¦æ‹¥æœ‰æ°´åˆ©åˆ—表
        /// æ˜¯å¦æ‹¥æœ‰æ°´åŠ›åˆ—è¡¨
        /// </summary>
        public bool HasHydroList
        {
@@ -50,14 +58,14 @@
        /// <summary>
        /// ç»‘定数据
        /// </summary>
        public void SetBindingData(HydroModelInfo hydroInfo)
        public void SetBindingData(Yw.Model.HydroModelInfo hydroInfo)
        {
            _allList = new List<HydroPressmeterViewModel>();
            if (hydroInfo != null && hydroInfo.Pressmeters != null && hydroInfo.Pressmeters.Count > 0)
            {
                foreach (var pressmeter in hydroInfo.Pressmeters)
                foreach (var visual in hydroInfo.Pressmeters)
                {
                    var vm = new HydroPressmeterViewModel(pressmeter, hydroInfo);
                    var vm = new HydroPressmeterViewModel(visual, hydroInfo);
                    _allList.Add(vm);
                }
            }
@@ -72,10 +80,10 @@
            _allList = new List<HydroPressmeterViewModel>();
            if (hydroInfo != null && hydroInfo.Pressmeters != null && hydroInfo.Pressmeters.Count > 0)
            {
                foreach (var pressmeter in hydroInfo.Pressmeters)
                foreach (var visual in hydroInfo.Pressmeters)
                {
                    var vm = new HydroPressmeterViewModel(pressmeter, hydroInfo);
                    var calcuResult = allCalcuResultList?.Find(x => x.Code == pressmeter.Code);
                    var vm = new HydroPressmeterViewModel(visual, hydroInfo);
                    var calcuResult = allCalcuResultList?.Find(x => x.Code == visual.Code);
                    if (calcuResult != null)
                    {
                        vm.UpdateCalcuProperty(calcuResult);
@@ -84,6 +92,30 @@
                }
            }
            Search();
        }
        /// <summary>
        /// ç»‘定数据
        /// </summary>
        public void SetBindingData(List<HydroVisualViewModel> allVisualViewModelList)
        {
            _allList = new List<HydroPressmeterViewModel>();
            allVisualViewModelList?.ForEach(x =>
            {
                if (x.Catalog == HydroParterCatalogHelper.GetName(Yw.Hydro.ParterCatalog.Pressmeter))
                {
                    _allList.Add(x as HydroPressmeterViewModel);
                }
            });
            Search();
        }
        /// <summary>
        /// æ›´æ–°ç»‘定
        /// </summary>
        public void UpdateBindingData()
        {
            this.hydroPressmeterViewModelBindingSource.ResetBindings(false);
        }
        /// <summary>
@@ -102,17 +134,17 @@
        /// <summary>
        /// æ›´æ–°å±žæ€§
        /// </summary>
        public void UpdateProperty(Yw.Model.HydroParterInfo parter)
        public void UpdateProperty(Yw.Model.HydroVisualInfo visual)
        {
            if (_allList == null || _allList.Count < 1)
            {
                return;
            }
            if (parter == null)
            if (visual == null)
            {
                return;
            }
            var vm = _allList.Find(x => x.Code == parter.Code);
            var vm = _allList.Find(x => x.Code == visual.Code);
            if (vm == null)
            {
                return;
@@ -124,17 +156,17 @@
        /// <summary>
        /// æ›´æ–°å±žæ€§
        /// </summary>
        public void UpdateProperty(List<Yw.Model.HydroParterInfo> parterList)
        public void UpdateProperty(List<Yw.Model.HydroVisualInfo> visualList)
        {
            if (_allList == null || _allList.Count < 1)
            {
                return;
            }
            if (parterList == null || parterList.Count < 1)
            if (visualList == null || visualList.Count < 1)
            {
                return;
            }
            parterList.ForEach(x =>
            visualList.ForEach(x =>
            {
                var vm = _allList.Find(t => x.Code == x.Code);
                if (vm != null)
@@ -154,12 +186,12 @@
            {
                if (_allList != null && _allList.Count > 0)
                {
                    foreach (var parter in _allList)
                    foreach (var visual in _allList)
                    {
                        var calcuResult = allCalcuResultList.Find(x => x.Code == parter.Code);
                        var calcuResult = allCalcuResultList.Find(x => x.Code == visual.Code);
                        if (calcuResult != null)
                        {
                            parter.UpdateCalcuProperty(calcuResult);
                            visual.UpdateCalcuProperty(calcuResult);
                        }
                    }
                    this.hydroPressmeterViewModelBindingSource.ResetBindings(false);
@@ -209,22 +241,67 @@
            Search();
            if (_allBindingList == null || _allBindingList.Count < 1)
            {
                XtraMessageBox.Show("无可设置流量计数据");
                TipFormHelper.ShowWarn("无数据!");
                return;
            }
            var dlg = new SetHydroPressmeterDlg();
            dlg.SetBindingData(_allBindingList.Select(x => x.Vmo).ToList());
            dlg.ReloadDataEvent += (list) =>
            {
                _allBindingList.ForEach(x =>
                {
                    x.UpdateProperty();
                });
                _allBindingList.ForEach(x => x.UpdateProperty());
                this.hydroPressmeterViewModelBindingSource.ResetBindings(false);
                var allParterList = _allBindingList.Select(x => x.Vmo as HydroParterInfo).ToList();
                this.HydroChangedEvent?.Invoke(allParterList);
                var allVisualViewModelList = _allBindingList.Select(x => x as HydroVisualViewModel).ToList();
                this.HydroChangedViewEvent?.Invoke(allVisualViewModelList);
                var allVisualInfoList = allVisualViewModelList.Select(x => x.Vmo).ToList();
                this.HydroChangedInfoEvent?.Invoke(allVisualInfoList);
            };
            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)
        {
            var row = this.gridView1.GetRow(e.RowHandle) as HydroPressmeterViewModel;
            if (row == null)
            {
                return;
            }
            if (e.Column == this.colSet)
            {
                var dlg = new SetHydroPressmeterDlg();
                dlg.SetBindingData(row.Vmo);
                dlg.ReloadDataEvent += (list) =>
                {
                    row.UpdateProperty();
                    this.gridView1.RefreshRow(e.RowHandle);
                    this.HydroChangedViewEvent?.Invoke(new List<HydroVisualViewModel>() { row });
                    this.HydroChangedInfoEvent?.Invoke(new List<HydroVisualInfo>() { row.Vmo });
                };
                dlg.ShowDialog();
            }
            else
            {
                this.HydroClickViewEvent?.Invoke(row);
                this.HydroClickInfoEvent?.Invoke(row.Vmo);
            }
        }
        /// <summary>
@@ -233,14 +310,14 @@
        public void SetSimpleView()
        {
            this.groupForHead.Visibility = DevExpress.XtraLayout.Utils.LayoutVisibility.Never;
            this.colDbLocked.Visible = true;
            this.colDbLocked.Visible = false;
            this.colName.Visible = true;
            this.colCode.Visible = true;
            this.colModelType.Visible = true;
            this.colElev.Visible = false;
            this.colMinorLoss.Visible = false;
            this.colCalcuPr.Visible = false;
            this.colHasDb.Visible = true;
            this.colHasDb.Visible = false;
            this.colFlags.Visible = true;
            this.colDescription.Visible = true;
            this.colSet.Visible = false;
@@ -301,32 +378,6 @@
            this.colFlags.Visible = true;
            this.colDescription.Visible = true;
            this.colSet.Visible = true;
        }
        private void gridView1_RowCellClick(object sender, DevExpress.XtraGrid.Views.Grid.RowCellClickEventArgs e)
        {
            var row = this.gridView1.GetRow(e.RowHandle) as HydroPressmeterViewModel;
            if (row == null)
            {
                return;
            }
            if (e.Column == this.colSet)
            {
                var dlg = new SetHydroPressmeterDlg();
                dlg.SetBindingData(row.Vmo);
                dlg.ReloadDataEvent += (list) =>
                {
                    row.UpdateProperty();
                    this.gridView1.RefreshRow(e.RowHandle);
                    this.HydroChangedEvent?.Invoke(new List<Model.HydroParterInfo>() { row.Vmo });
                };
                dlg.ShowDialog();
            }
            else
            {
                this.HydroClickEvent?.Invoke(row.Vmo);
            }
        }