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;
}
}
}
}
}