using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Windows; using System.Windows.Controls; using System.Windows.Data; using System.Windows.Documents; using System.Windows.Input; using System.Windows.Media; using System.Windows.Media.Imaging; using System.Windows.Shapes; using System.Dynamic; using Aitex.Core.Account; namespace Aitex.Triton160.UI.Views { /// /// Interaction logic for RoleEditView.xaml /// public partial class RoleEditView : Window { public RoleEditView() { InitializeComponent(); Loaded += new RoutedEventHandler(RoleEditView_Loaded); dataGrid1.CanUserAddRows = false; dataGrid1.RowHeight = 25; } public class PermissionClass { public static Dictionary ViewPermissionCheck = new Dictionary(); static IEnumerable permissions = Enum.GetValues(typeof(Permission_CN)).Cast(); static PermissionClass() { foreach (Permission_CN p in permissions) { if (p == Permission_CN.ProcessHidden) { //只针对ReactorProcess相关界面 ViewPermissionCheck.Add(p, "RecipeMonitor"); //"ProcessView" } else { ViewPermissionCheck.Add(p, ""); } } } public static List GetPermissions(string viewName) { List permissionInfos = new List(); foreach (Permission_CN p in ViewPermissionCheck.Keys) { if (ViewPermissionCheck[p] == "") permissionInfos.Add(p); else if(viewName.IndexOf(ViewPermissionCheck[p])>=0) permissionInfos.Add(p); } return permissionInfos; } } public enum Permission_CN { Hidden, ReadOnly, Partial, Full, ProcessHidden } public List DataSource = new List(); void RoleEditView_Loaded(object sender, RoutedEventArgs e) { var viewList = Triton160UiSystem.Instance.WCF.Account.GetAllViewList(); var viewPermission = Triton160UiSystem.Instance.WCF.Account.GetAllRolesPermission(); //Dynamically do data binding function here foreach (var role in viewPermission.Keys) { dynamic singleViewPermission = new ExpandoObject(); ((IDictionary)singleViewPermission).Add(new KeyValuePair("RoleName", role)); foreach (var view in viewPermission[role].Keys) { switch(viewPermission[role][view]) { case ViewPermission.Invisiable: ((IDictionary)singleViewPermission).Add(new KeyValuePair(view, Permission_CN.Hidden)); break; case ViewPermission.Readonly: ((IDictionary)singleViewPermission).Add(new KeyValuePair(view, Permission_CN.ReadOnly)); break; case ViewPermission.PartlyControl: ((IDictionary)singleViewPermission).Add(new KeyValuePair(view, Permission_CN.Partial)); break; case ViewPermission.FullyControl: ((IDictionary)singleViewPermission).Add(new KeyValuePair(view, Permission_CN.Full)); break; case ViewPermission.ProcessOPControl: ((IDictionary)singleViewPermission).Add(new KeyValuePair(view, Permission_CN.ProcessHidden)); break; } } DataSource.Add(singleViewPermission); } dataGrid1.DataContext = DataSource; //dynamically creating data grid column foreach (var view in viewList) { var datagGridColumn = new DataGridComboBoxColumn() { Header = view.Value, Width = 100 }; dataGrid1.Columns.Add(datagGridColumn); datagGridColumn.SelectedItemBinding = new Binding() { Path = new PropertyPath(view.Key) }; datagGridColumn.ItemsSource = PermissionClass.GetPermissions(view.Key); } } private void btnClose_Click(object sender, RoutedEventArgs e) { Close(); } private void btnAddNew_Click(object sender, RoutedEventArgs e) { dynamic singleViewPermission = new ExpandoObject(); ((IDictionary)singleViewPermission).Add(new KeyValuePair("RoleName", "New Role")); //var viewList = AccountServiceClient.GetAllViewList(); var viewList = Triton160UiSystem.Instance.WCF.Account.GetAllViewList(); // chaosong@mod 20160325 to add account management foreach (var view in viewList.Keys) { ((IDictionary)singleViewPermission).Add(new KeyValuePair(view, Permission_CN.Hidden)); } DataSource.Add(singleViewPermission); dataGrid1.DataContext = null; dataGrid1.DataContext = DataSource; } /// /// Save role to xml file /// /// /// private void btnSave_Click(object sender, RoutedEventArgs e) { for (int i = 0; i < DataSource.Count - 1; i++) { for (int j = i + 1; j < DataSource.Count; j++) { dynamic obj1 = DataSource[i]; dynamic obj2 = DataSource[j]; if (String.Compare(obj1.RoleName, obj2.RoleName) == 0) { MessageBox.Show(string.Format("\"{0}\" Existed,modify to save!", obj1.RoleName), "Role Editor Error", MessageBoxButton.OK, MessageBoxImage.Warning); return; } } } var permissionDic = new Dictionary>(); foreach (dynamic role in DataSource) { permissionDic.Add(role.RoleName, new Dictionary()); foreach (var item in ((IDictionary)role).Keys) { if (item == "RoleName") continue; var perm = (Permission_CN)((IDictionary)role)[item]; switch (perm) { case Permission_CN.Full: permissionDic[role.RoleName].Add(item, ViewPermission.FullyControl); break; case Permission_CN.Partial: permissionDic[role.RoleName].Add(item, ViewPermission.PartlyControl); break; case Permission_CN.ReadOnly: permissionDic[role.RoleName].Add(item, ViewPermission.Readonly); break; case Permission_CN.Hidden: permissionDic[role.RoleName].Add(item, ViewPermission.Invisiable); break; case Permission_CN.ProcessHidden: permissionDic[role.RoleName].Add(item, ViewPermission.ProcessOPControl); break; } } } if (Triton160UiSystem.Instance.WCF.Account.SaveAllRolesPermission(permissionDic)) { MessageBox.Show(Application.Current.Resources["GlobalLableAccountViewSaveRoleOk"].ToString()); } else { MessageBox.Show(Application.Current.Resources["GlobalLableAccountViewSaveRoleFailed"].ToString()); } } /// /// Delete current selecte role /// /// /// private void btnRoleDelete_Click(object sender, RoutedEventArgs e) { dynamic obj = dataGrid1.SelectedItem; if (obj != null) { if (MessageBox.Show(string.Format(Application.Current.Resources["GlobalLableAccountViewDeleteRoleInfo"].ToString(), obj.RoleName), Application.Current.Resources["GlobalLableAccountViewMsgTitle"].ToString(), MessageBoxButton.YesNo, MessageBoxImage.Question) == MessageBoxResult.Yes) { foreach (dynamic role in DataSource) { if (role.RoleName == obj.RoleName) { DataSource.Remove(role); break; } } dataGrid1.DataContext = null; dataGrid1.DataContext = DataSource; } } } } }