narsil/Tanshu.Accounts.PointOfSale/User Management/UserListForm.cs

88 lines
2.4 KiB
C#
Raw Normal View History

using System;
2018-08-24 10:41:33 +00:00
using System.Collections.Generic;
using System.Linq;
using System.Windows.Forms;
using Tanshu.Accounts.Entities;
using Tanshu.Accounts.Repository;
namespace Tanshu.Accounts.PointOfSale
{
public partial class UserListForm : Form
{
private IList<User> _list;
public UserListForm()
{
InitializeComponent();
}
private void btnAdd_Click(object sender, EventArgs e)
{
using (var frm = new UserForm(null))
frm.ShowDialog();
2018-08-24 10:41:33 +00:00
_list = UserBI.List();
bsList.DataSource = _list;
}
private void UserListForm_Load(object sender, EventArgs e)
{
ShowGrid();
}
private void ShowGrid()
{
2018-08-24 10:41:33 +00:00
_list = UserBI.List();
bsList.DataSource = _list;
}
private void btnEdit_Click(object sender, EventArgs e)
{
var id = ((User)bsList.Current).UserID;
using (var frm = new UserForm(id))
frm.ShowDialog();
2018-08-24 10:41:33 +00:00
_list = UserBI.List();
bsList.DataSource = _list;
}
private void btnExit_Click(object sender, EventArgs e)
{
this.Close();
}
private void dgvUsers_CellFormatting(object sender, DataGridViewCellFormattingEventArgs e)
{
var data = dgvUsers.Rows[e.RowIndex].DataBoundItem as User;
if (data == null)
return;
if (e.ColumnIndex == dgvUsers.Columns["Password"].Index)
{
e.Value = "******";
}
if (e.ColumnIndex == dgvUsers.Columns["MsrString"].Index)
{
e.Value = !string.IsNullOrEmpty(data.MsrString);
}
if (e.ColumnIndex == dgvUsers.Columns["UserGroups"].Index)
{
2018-08-24 10:41:33 +00:00
e.Value = string.Join(", ", data.Roles.Select(x => x.Name).ToArray());
}
var tax = e.Value as Tax;
if (tax != null)
{
e.Value = string.Format("{1:P} - {0}", tax.Name, tax.Rate); ;
return;
}
var productGroup = e.Value as ProductGroup;
if (productGroup != null)
{
e.Value = productGroup.Name;
}
}
private void chkIsActive_CheckStateChanged(object sender, EventArgs e)
{
ShowGrid();
}
}
}