Employee_Power.cs 9.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Data;
  4. using System.Threading;
  5. using System.Windows.Forms;
  6. using UAS_MES_NEW.CustomControl.DataGrid_View;
  7. using UAS_MES_NEW.DataOperate;
  8. using UAS_MES_NEW.Entity;
  9. using UAS_MES_NEW.PublicForm;
  10. using UAS_MES_NEW.PublicMethod;
  11. namespace UAS_MES_NEW.Employee
  12. {
  13. public partial class Employee_Power : Form
  14. {
  15. DataHelper dh;
  16. DataTable dt;
  17. AutoSizeFormClass asc = new AutoSizeFormClass();
  18. LogStringBuilder sql = new LogStringBuilder();
  19. Thread thread;
  20. SetLoadingWindow stw;
  21. DataTable Dbfind;
  22. ItemObject item;
  23. string[] title = new string[] { "读权限", "写权限", "删除权限", "特殊权限", "全部权限" };
  24. string[] DataPreperty = new string[] { "ugp_ifread", "ugp_ifwrite", "ugp_ifdelete", "ugp_ifspecial", "ugp_ifall" };
  25. public Employee_Power()
  26. {
  27. InitializeComponent();
  28. }
  29. public Employee_Power(string GroupCode, string GroupName)
  30. {
  31. InitializeComponent();
  32. ug_code.Text = GroupCode;
  33. sn_module.Text = GroupName;
  34. }
  35. private void 权限控制_Load(object sender, EventArgs e)
  36. {
  37. //不检测进程
  38. asc.controllInitializeSize(this);
  39. CheckForIllegalCrossThreadCalls = false;
  40. //界面加载时设置保存按钮不可见
  41. if (ug_code.Text == "")
  42. SavePower.Visible = false;
  43. dh = SystemInf.dh;
  44. ///手动插入四列含有列头勾选框的列
  45. for (int i = 0; i < title.Length; i++)
  46. {
  47. DataGridViewCheckBoxColumn dgvc = new DataGridViewCheckBoxColumn();
  48. dgvc.AutoSizeMode = DataGridViewAutoSizeColumnMode.None;
  49. dgvc.Width = 190;
  50. dgvc.Name = title[i];
  51. dgvc.DataPropertyName = DataPreperty[i];
  52. DataGridViewCheckBoxHeaderCell ch1 = new DataGridViewCheckBoxHeaderCell(GroupPowerDGV, dgvc);
  53. dgvc.HeaderCell = ch1;
  54. this.GroupPowerDGV.Columns.Insert(i + 3, dgvc);
  55. }
  56. //分组放大镜
  57. ug_code.FormName = Name;
  58. ug_code.TableName = "CS$USERGROUP";
  59. ug_code.SelectField = "ug_code # 分组编号,ug_name # 分组名称,ug_inman # 录入人,ug_indate #录入日期";
  60. ug_code.SetValueField = new string[] { "ug_code" };
  61. ug_code.DbChange += Ug_code_Dbchage;
  62. //由于需要额外添加一个全部值,需要手动添加Item
  63. dt = (DataTable)dh.ExecuteSql("select DISTINCT sn_module from CS$SYSNAVATION where sn_using=1", "select");
  64. item = new ItemObject("全部", "");
  65. sn_module.Items.Add(item);
  66. for (int i = 0; i < dt.Rows.Count; i++)
  67. {
  68. string sn_moudle = dt.Rows[i]["sn_module"].ToString();
  69. item = new ItemObject(sn_moudle, sn_moudle);
  70. sn_module.Items.Add(item);
  71. }
  72. //如果页面加载的时候通过传参的构造函数
  73. if (ug_code.Text != "")
  74. Screen.PerformClick();
  75. }
  76. private void Ug_code_Dbchage(object sender, EventArgs e)
  77. {
  78. Dbfind = ug_code.ReturnData;
  79. BaseUtil.SetFormValue(this.Controls, Dbfind);
  80. }
  81. private void Screen_Click(object sender, EventArgs e)
  82. {
  83. //拼接条件,获取按照用户输入条件的数据集
  84. sql.Clear();
  85. sql.Append("select sn_id,sn_module,sn_displayname,sn_caller,ugp_id,ugp_ifread,ugp_ifwrite,ugp_ifdelete,ugp_ifspecial,ugp_ifall ");
  86. sql.Append("from cs$sysnavation left join cs$usergrouppower on ugp_groupcode='" + ug_code.Text + "' ");
  87. sql.Append("and ugp_caller=sn_caller where sn_using=1 and sn_module like '%" + (sn_module.Text == "全部" ? "" : sn_module.Text) + "%' order by sn_modulecode,sn_detno");
  88. dt = (DataTable)dh.ExecuteSql(sql.GetString(), "select");
  89. BaseUtil.FillDgvWithDataTable(GroupPowerDGV, dt);
  90. }
  91. private void SavePower_Click(object sender, EventArgs e)
  92. {
  93. //保存表格中变更的记录
  94. dt = (DataTable)GroupPowerDGV.DataSource;
  95. //删除之前的分组权限
  96. if (sn_module.Text == "" || sn_module.Text == "全部")
  97. {
  98. dh.ExecuteSql("delete from cs$usergrouppower where ugp_groupcode='" + ug_code.Text + "'", "delete");
  99. }
  100. else
  101. {
  102. dh.ExecuteSql("delete from cs$usergrouppower where ugp_groupcode='" + ug_code.Text + "' and ugp_module='" + sn_module.Text + "'", "delete");
  103. }
  104. string insertsql = "Insert into cs$usergrouppower (ugp_id,ugp_module,ugp_groupcode,ugp_caller,ugp_ifread,ugp_ifwrite,ugp_ifdelete,ugp_ifspecial,ugp_ifall) values(cs$usergrouppower_seq.nextval,'" + sn_module.Text + "','" + ug_code.Text + "',:ugp_caller,:ugp_ifread,:ugp_ifwrite,:ugp_ifdelete,:ugp_ifspecial,:ugp_ifall)";
  105. //获取变化了得DataSource
  106. DataTable ChangedDT = dt.GetChanges();
  107. if (ChangedDT != null)
  108. {
  109. int ChangedRowCount = ChangedDT.Rows.Count;
  110. string[] caller = new string[ChangedRowCount];
  111. string[] ifread = new string[ChangedRowCount];
  112. string[] ifwrite = new string[ChangedRowCount];
  113. string[] ifdelete = new string[ChangedRowCount];
  114. string[] ifspecial = new string[ChangedRowCount];
  115. string[] ifall = new string[ChangedRowCount];
  116. for (int i = 0; i < ChangedRowCount; i++)
  117. {
  118. caller[i] = ChangedDT.Rows[i]["sn_caller"].ToString();
  119. ifread[i] = ChangedDT.Rows[i]["ugp_ifread"].ToString();
  120. ifwrite[i] = ChangedDT.Rows[i]["ugp_ifwrite"].ToString();
  121. ifdelete[i] = ChangedDT.Rows[i]["ugp_ifdelete"].ToString();
  122. ifspecial[i] = ChangedDT.Rows[i]["ugp_ifspecial"].ToString();
  123. ifall[i] = ChangedDT.Rows[i]["ugp_ifall"].ToString();
  124. }
  125. dh.BatchInsert(insertsql, new string[] { "ugp_caller", "ugp_ifread", "ugp_ifwrite", "ugp_ifdelete", "ugp_ifspecial", "ugp_ifall" }, caller, ifread, ifwrite, ifdelete, ifspecial, ifall);
  126. //保存后重新加载权限
  127. //保存后重置本地权限
  128. if (User.UserAccountType == "admin")
  129. {
  130. sql.Clear();
  131. sql.Append("select distinct sn_module,sn_caller ugp_caller,1 ugp_ifdelete,1 ugp_ifread,1 ugp_ifspecial,1 ugp_ifall,");
  132. sql.Append("1 ugp_ifwrite from CS$SYSNAVATION left join CS$USERGROUPPOWER on sn_caller=ugp_caller order by sn_module");
  133. }
  134. else
  135. {
  136. sql.Clear();
  137. sql.Append("select distinct sn_module,ugp_caller,ugp_ifdelete,ugp_ifread,ugp_ifspecial,ugp_ifwrite,ugp_ifall ");
  138. sql.Append("from CS$USERGROUPPOWER left join CS$SYSNAVATION on ");
  139. sql.Append("sn_caller=ugp_caller where ugp_groupcode in ( select eg_groupcode from cs$empgroup left join ");
  140. sql.Append("cs$userresource on ur_groupcode = eg_groupcode where eg_emcode = '" + User.UserCode + "') order by sn_module");
  141. }
  142. dt = (DataTable)dh.ExecuteSql(sql.GetString(), "select");
  143. for (int i = 0; i < dt.Rows.Count; i++)
  144. {
  145. Dictionary<string, bool> dic = new Dictionary<string, bool>();
  146. dic.Add("IFDELETE", dt.Rows[i]["UGP_IFDELETE"].ToString() != "1" ? false : true);
  147. dic.Add("IFREAD", dt.Rows[i]["UGP_IFREAD"].ToString() != "1" ? false : true);
  148. dic.Add("IFWRITE", dt.Rows[i]["UGP_IFWRITE"].ToString() != "1" ? false : true);
  149. dic.Add("IFSPECIAL", dt.Rows[i]["UGP_IFSPECIAL"].ToString() != "1" ? false : true);
  150. dic.Add("IFALL", dt.Rows[i]["UGP_IFALL"].ToString() != "1" ? false : true);
  151. //之后通过Call来获取页面操作的权限
  152. if (!SystemInf.Caller.ContainsKey(dt.Rows[i]["ugp_caller"].ToString()))
  153. SystemInf.Caller.Add(dt.Rows[i]["ugp_caller"].ToString(), dic);
  154. }
  155. MessageBox.Show("保存成功!");
  156. }
  157. }
  158. //加载页面的数据
  159. private void LoadData()
  160. {
  161. sql.Clear();
  162. sql.Append("select sn_id,sn_module,sn_displayname,sn_caller,ugp_id,ugp_ifread,ugp_ifwrite,ugp_ifdelete,ugp_ifspecial,ugp_ifall ");
  163. sql.Append("from cs$sysnavation left join cs$usergrouppower on ugp_groupcode='" + ug_code.Text + "' and ugp_caller=sn_caller ");
  164. sql.Append("where sn_using=1 and ugp_groupcode='" + ug_code.Text + "' order by sn_modulecode,sn_detno");
  165. dt = (DataTable)dh.ExecuteSql(sql.GetString(), "select");
  166. BaseUtil.FillDgvWithDataTable(GroupPowerDGV, dt);
  167. }
  168. private void GroupPower_DataError(object sender, DataGridViewDataErrorEventArgs e) { }
  169. private void 权限控制_SizeChanged(object sender, EventArgs e)
  170. {
  171. asc.controlAutoSize(this);
  172. }
  173. private void ug_code_UserControlTextChanged(object sender, EventArgs e)
  174. {
  175. if (ug_code.Text == "")
  176. SavePower.Visible = false;
  177. else
  178. {
  179. SavePower.Visible = true;
  180. Screen.PerformClick();
  181. }
  182. }
  183. private void sn_module_SelectedIndexChanged(object sender, EventArgs e)
  184. {
  185. Screen.PerformClick();
  186. }
  187. }
  188. }