From 65927056612a7ffef20708aefda33d09be51ef6b Mon Sep 17 00:00:00 2001
From: lg <999544862qq.com>
Date: 星期日, 08 九月 2024 22:16:00 +0800
Subject: [PATCH] 权限整理

---
 DevApp/Gs.DevApp/DevFrm/User/Role.cs |  101 +++++++++++++++++++++++++++-----------------------
 1 files changed, 55 insertions(+), 46 deletions(-)

diff --git a/DevApp/Gs.DevApp/DevFrm/User/Role.cs b/DevApp/Gs.DevApp/DevFrm/User/Role.cs
index 1d4fe54..6c143a2 100644
--- a/DevApp/Gs.DevApp/DevFrm/User/Role.cs
+++ b/DevApp/Gs.DevApp/DevFrm/User/Role.cs
@@ -1,5 +1,6 @@
 锘縰sing DevExpress.XtraGrid.Views.Base;
-using DevExpress.XtraTreeList.Nodes;
+using DevExpress.XtraGrid.Views.Grid;
+using DevExpress.XtraGrid.Views.Grid.ViewInfo;
 using Gs.DevApp.Models;
 using Gs.DevApp.ToolBox;
 using Newtonsoft.Json;
@@ -9,10 +10,11 @@
 
 namespace Gs.DevApp.DevFrm.User
 {
+    //https://www.cnblogs.com/mkmkbj/p/16771297.html
     //https://blog.csdn.net/m0_54035969/article/details/140716675
     public partial class Role : DevExpress.XtraEditors.XtraForm
     {
-        System.Text.StringBuilder sbRolist = new System.Text.StringBuilder();
+        System.Text.StringBuilder actionLst = new System.Text.StringBuilder();
         public Role()
         {
             InitializeComponent();
@@ -25,19 +27,21 @@
             this.toolBarMenu1.btnRoleClick += ToolBarMenu1_btnRoleClick;
             gcMain.MouseDoubleClick += GcMain_MouseDoubleClick;
             gridView1.FocusedRowChanged += GridView1_FocusedRowChanged;
-            PageBar1.PagerEvent += PageBar1_PagerEvent;
-            GetPageList(1, UtilityHelper.GetPageSize());
+            pageBar1.PagerEvent += PageBar1_PagerEvent;
+            getPageList(1, UtilityHelper.GetPageSize());
             trv.AfterCheck += Trv_AfterCheck;
         }
-
-
-
+        /// <summary>
+        /// 鎹㈠垏鎹簨浠�
+        /// </summary>
+        /// <param name="sender"></param>
+        /// <param name="e"></param>
         private void GridView1_FocusedRowChanged(object sender, FocusedRowChangedEventArgs e)
         {
             string rowGuid = "";
             DataRow myDataRow = gridView1.GetDataRow(e.FocusedRowHandle);
             rowGuid = myDataRow["guid"].ToString();
-            GetTree(rowGuid);
+            getTree(rowGuid);
             groupBox1.Text = "璇峰嬀閫夈��" + myDataRow["roleName"].ToString() + "銆戠殑鏉冮檺";
         }
         /// <summary>
@@ -47,12 +51,20 @@
         /// <param name="e"></param>
         private void GcMain_MouseDoubleClick(object sender, MouseEventArgs e)
         {
-            string rowGuid = "";
-            ColumnView cv = (ColumnView)gcMain.FocusedView;
-            object rowIdObj = gridView1.GetRowCellValue(cv.FocusedRowHandle, "guid");
-            DataRow myDataRow = gridView1.GetDataRow(gridView1.FocusedRowHandle);
-            rowGuid = myDataRow["guid"].ToString();
-            GetModel(rowGuid, false, 999);
+            GridHitInfo info = gridView1.CalcHitInfo(e.Location);
+            if (info.InRow)
+            {
+                GridView view = info.View as GridView;
+                if (view != null)
+                {
+                    DataRow row = view.GetDataRow(info.RowHandle);
+                    if (row != null)
+                    {
+                        string rowGuid = (row["guid"].ToString());
+                        getModel(rowGuid, false, 999);
+                    }
+                }
+            }
         }
         /// <summary>
         /// 鍒嗛〉浜嬩欢
@@ -61,7 +73,7 @@
         /// <param name="pageSize"></param>
         private void PageBar1_PagerEvent(int curPage, int pageSize)
         {
-            GetPageList(curPage, pageSize);
+            getPageList(curPage, pageSize);
         }
         /// <summary>
         /// 鍙栨秷浜嬩欢
@@ -85,11 +97,11 @@
                 ToolBox.MsgHelper.Warning("璇峰厛閫夋嫨浣犺鎿嶄綔鐨勮锛�");
                 return;
             }
-            if (!MsgHelper.AskQuestion("浣犻�夋嫨浜嗐��" + dr["roleName"].ToString() + "銆戯紝纭畾鍒犻櫎鍚楋紵"))
+            if (!MsgHelper.AskQuestion("浣犻�夋嫨浜嗐��" + dr["roleName"].ToString() + "銆戯紝纭畾鍒犻櫎鍚楋紵\n璇ユ搷浣滃皢浼氭竻绌虹浉搴旂殑鐢ㄦ埛鏉冮檺"))
                 return;
             var _obj = new
             {
-                guidList = dr["guid"].ToString(),//涓诲缓
+                guid = dr["guid"].ToString(),//涓诲缓
             };
             string strJson = "";
             try
@@ -99,7 +111,7 @@
                 if (_rtn.rtnCode > 0)
                 {
                     UtilityHelper.ChangeTab(xtraTabControl1, 0);
-                    GetPageList(1, UtilityHelper.GetPageSize());
+                    getPageList(1, UtilityHelper.GetPageSize());
                 }
                 ToolBox.MsgHelper.Warning("鎻愮ず锛�" + _rtn.rtnMsg);
             }
@@ -116,7 +128,7 @@
         private void ToolBarMenu1_btnLoadClick(object sender, EventArgs e)
         {
             UtilityHelper.ChangeTab(xtraTabControl1, 0);
-            GetPageList(1, UtilityHelper.GetPageSize());
+            getPageList(1, UtilityHelper.GetPageSize());
         }
         /// <summary>
         /// 淇敼浜嬩欢
@@ -131,7 +143,7 @@
                 ToolBox.MsgHelper.Warning("璇峰厛閫夋嫨浣犺鎿嶄綔鐨勮锛�");
                 return;
             }
-            GetModel(dr["guid"].ToString(), true, 1);
+            getModel(dr["guid"].ToString(), true, 1);
 
         }
         /// <summary>
@@ -165,10 +177,10 @@
                 txt_rolRemark.Focus();
                 return;
             }
-            if (string.IsNullOrEmpty(txt_status.Text.Trim()))
+            if (txt_status.SelectedIndex <= 0)
             {
                 Gs.DevApp.ToolBox.MsgHelper.Warning("瑙掕壊鐘舵�佷笉鑳戒负绌猴紒");
-                txt_rolRemark.Focus();
+                txt_status.Focus();
                 return;
             }
             var _obj = new
@@ -178,10 +190,9 @@
                 rolRemark = txt_rolRemark.Text.Trim(),
                 status = txt_status.SelectedIndex,//鐘舵��
             };
-            string strJson = "";
             try
             {
-                strJson = UtilityHelper.HttpPost("", "Role/EditModel", JsonConvert.SerializeObject(_obj));
+                string strJson = UtilityHelper.HttpPost("", "Role/EditModel", JsonConvert.SerializeObject(_obj));
                 ReturnModel<dynamic> _rtn = ToolBox.UtilityHelper.GetDataByJson(strJson);
                 ToolBox.MsgHelper.Warning("鎻愮ず锛�" + _rtn.rtnMsg);
                 if (_rtn.rtnCode > 0)
@@ -212,23 +223,18 @@
             }
             if (!MsgHelper.AskQuestion("浣犻�夋嫨浜嗐��" + dr["roleName"].ToString() + "銆戯紝纭畾璁剧疆鏉冮檺鍚楋紵"))
                 return;
-            sbRolist = new System.Text.StringBuilder();
+            actionLst = new System.Text.StringBuilder();
             TraverseTreeViewNodes(trv.Nodes);
             var _obj = new
             {
                 roleGuid = dr["guid"].ToString(),
-                roleLst = sbRolist.ToString(),
+                actionLst = actionLst.ToString(),
             };
-            string strJson = "";
             try
             {
-                strJson = UtilityHelper.HttpPost("", "MenuAction/SetRoleByRolueGuid", JsonConvert.SerializeObject(_obj));
+                string strJson = UtilityHelper.HttpPost("", "MenuAction/SetMenuActionByRole", JsonConvert.SerializeObject(_obj));
                 ReturnModel<dynamic> _rtn = ToolBox.UtilityHelper.GetDataByJson(strJson);
-                if (_rtn.rtnCode > 0)
-                {
-
-                }
-                ToolBox.MsgHelper.Warning("鎻愮ず锛�" + _rtn.rtnMsg);
+                ToolBox.MsgHelper.Warning("鎻愮ず锛�" + _rtn.rtnData.outMsg);
             }
             catch (Exception ex)
             {
@@ -241,32 +247,31 @@
         /// </summary>
         /// <param name="curPage">绗嚑椤�</param>
         /// <param name="pageSize">姣忛〉鍑犳潯</param>
-        private void GetPageList(int curPage, int pageSize)
+        private void getPageList(int curPage, int pageSize)
         {
             Models.PageQueryModel pgq = new Models.PageQueryModel(curPage, pageSize, "createDate", "asc", "", "");
             string json = JsonConvert.SerializeObject(pgq);
-            string strReturn = "";
             try
             {
-                strReturn = UtilityHelper.HttpPost("", "Role/GetListPage", json);
+                string strReturn = UtilityHelper.HttpPost("", "Role/GetListPage", json);
                 ReturnModel<PageListModel> dd = UtilityHelper.GetTableByJson(strReturn);
                 DataTable dt = dd.rtnData.list;
                 gcMain.BindingContext = new BindingContext();
                 gcMain.DataSource = dt;
                 gcMain.ForceInitialize();
                 int dddd = dd.rtnData.pages;//鎬婚〉
-                PageBar1.TotalPages = dddd;
-                PageBar1.RecordCount = dd.rtnData.total;//璁板綍鎬绘暟
-                PageBar1.CurrentPage = curPage;//褰撳墠椤�
-                PageBar1.RowsCount = pageSize;//姣忛〉鏄剧ず
-                PageBar1.setTxt();
+                pageBar1.TotalPages = dddd;
+                pageBar1.RecordCount = dd.rtnData.total;//璁板綍鎬绘暟
+                pageBar1.CurrentPage = curPage;//褰撳墠椤�
+                pageBar1.RowsCount = pageSize;//姣忛〉鏄剧ず
+                pageBar1.setTxt();
             }
             catch (Exception ex)
             {
                 ToolBox.MsgHelper.Warning("鎻愮ず锛�" + ex.Message);
             }
         }
-        private void GetModel(string strGuid, bool isEdit, int tabIdx)
+        private void getModel(string strGuid, bool isEdit, int tabIdx)
         {
             if (string.IsNullOrEmpty(strGuid))
             {
@@ -297,7 +302,7 @@
                 ToolBox.MsgHelper.Warning("鎻愮ず锛�" + ex.Message);
             }
         }
-        private void GetTree(string rolueGuid)
+        private void getTree(string roleGuid)
         {
             trv.Nodes.Clear();
             ImageList imageList = new ImageList();
@@ -308,12 +313,12 @@
             trv.ImageList = imageList;
             var _obj = new
             {
-                rolueGuid = rolueGuid,//涓诲缓
+                roleGuid = roleGuid,//涓诲缓
             };
             string strReturn = "";
             try
             {
-                strReturn = UtilityHelper.HttpPost("", "MenuAction/GetListPageByOrg", JsonConvert.SerializeObject(_obj));
+                strReturn = UtilityHelper.HttpPost("", "MenuAction/GetListByRole", JsonConvert.SerializeObject(_obj));
                 ReturnModel<PageListModel> dd = UtilityHelper.GetTableByJson(strReturn);
                 DataTable dt = dd.rtnData.list;
                 DataRow[] drGrp = dt.Select("upGuid='' or upGuid is null");
@@ -324,6 +329,7 @@
                     node.Text = _dy["name"].ToString();//涓虹粨鐐硅祴鍊�
                     node.Name = _dy["guid"].ToString();
                     node.ImageIndex = 0;
+                    node.Checked = (_dy["isCk"].ToString() == "1" ? true : false);
                     DataRow[] drItem = dt.Select("upGuid='" + _dy["guid"].ToString() + "' and orgGuid='" + _dy["guid"].ToString() + "'");
                     foreach (DataRow _dy2 in drItem)
                     {
@@ -331,6 +337,7 @@
                         node22.Text = _dy2["name"].ToString();//涓虹粨鐐硅祴鍊�
                         node22.Name = _orgGuid + _dy2["guid"].ToString();
                         node22.ImageIndex = 1;
+                        node22.Checked = (_dy2["isCk"].ToString() == "1" ? true : false);
                         DataRow[] drItem33 = dt.Select("upGuid='" + _dy2["guid"].ToString() + "' and orgGuid='" + _dy["guid"].ToString() + "'");
                         foreach (DataRow _dy3 in drItem33)
                         {
@@ -338,6 +345,7 @@
                             node33.Text = _dy3["name"].ToString();//涓虹粨鐐硅祴鍊�
                             node33.Name = _orgGuid + _dy3["guid"].ToString();
                             node33.ImageIndex = 2;
+                            node33.Checked = (_dy3["isCk"].ToString() == "1" ? true : false);
                             DataRow[] drItem44 = dt.Select("upGuid='" + _dy3["guid"].ToString() + "' and orgGuid='" + _dy["guid"].ToString() + "'");
                             foreach (DataRow _dy4 in drItem44)
                             {
@@ -345,6 +353,7 @@
                                 node44.Text = _dy4["name"].ToString();//涓虹粨鐐硅祴鍊�
                                 node44.Name = _orgGuid + _dy4["guid"].ToString();
                                 node44.ImageIndex = 3;
+                                node44.Checked = (_dy4["isCk"].ToString() == "1" ? true : false);
                                 node33.Nodes.Add(node44);
                             }
                             node22.Nodes.Add(node33);
@@ -378,7 +387,7 @@
             foreach (TreeNode node in nodes)
             {
                 if (node.Checked)
-                    sbRolist.Append(node.Name + "~");
+                    actionLst.Append(node.Name + "~");
                 // 閫掑綊閬嶅巻瀛愯妭鐐�
                 if (node.Nodes.Count > 0)
                 {

--
Gitblit v1.9.3