/// <summary> /// 显示编辑选项 /// </summary> private void showEdit() { var dept = DepartmentInstance.Find(f => f.id == ParseInt(Utility.Decrypt(hidID.Value))); if (null != dept) { txtAbbreviation.Value = dept.Code; txtAddress.Value = dept.Address; var parent = DepartmentInstance.Find(f => f.id == dept.Parent && f.Delete == false); txtDepartment.Value = null == parent ? "" : parent.Name; hidDepartment.Value = null == parent ? "" : parent.id.ToString(); txtFax.Value = dept.Fax; txtName.Value = dept.Name; txtPhone.Value = dept.Phone; txtRoom.Value = dept.Room; cbIsDefault.Checked = dept.IsDefault.Value; if (dept.IsDefault == true) { cbIsDefault.Enabled = true; } } else { ShowNotification("./department_list.aspx", "Error: paramenter error, cannot edit dept. information.", false); } }
private void ShowDepartments() { List <int> depts; if ("" == hidDepartment.Value) { depts = DepartmentInstance.GetAllDepartments(); } else { depts = DepartmentInstance.GetSubdepartments(ParseInt(hidDepartment.Value)); } var totalRecords = 0; var pageIndex = "" == hidPageIndex.Value ? 1 : int.Parse(hidPageIndex.Value); var list = DepartmentInstance.FindPageList <TB_Department>(pageIndex, PageSize, out totalRecords, f => f.Delete == false && (f.Name.IndexOf(txtName.Value.Trim()) >= 0) && depts.Contains(f.id), "Parent,Name"); var totalPages = totalRecords / PageSize + (totalRecords % PageSize > 0 ? 1 : 0); string html = ""; if (totalRecords < 1) { html = "<tr><td colspan=\"10\">No records, You can change the condition and try again or " + " <a href=\"./department_add.aspx\">ADD</a> new one.</td></tr>"; } else { var cnt = (pageIndex - 1) * PageSize; foreach (var obj in list) { cnt++; var users = AccountInstance.FindList(f => f.Department == obj.id).Count(); var upper = 0 == obj.Parent ? null : DepartmentInstance.Find(f => f.id == obj.Parent); var id = Utility.UrlEncode(Utility.Encrypt(obj.id.ToString())); html += "<tr>" + "<td style=\"width: 40px; text-align: center;\"><input type=\"checkbox\" id=\"cb_" + id + "\" /></td>" + "<td style=\"width: 40px; text-align: center;\">" + cnt + "</td>" + "<td><a href=\"./department_add.aspx?key=" + id + "\" >" + obj.Name + "</a></td>" + "<td>" + obj.Phone + "</td>" + "<td>" + obj.Fax + "</td>" + "<td>" + (obj.IsDefault == true ? "Yes" : "-") + "</td>" + "<td><a href=\"#d" + (null == upper ? "" : upper.id.ToString()) + "\" >" + (null == upper ? "" : upper.Name) + "</a></td>" + "<td>" + (0 == users ? "0" : ("<a href=\"./account_list.aspx?key=" + Utility.UrlEncode(Utility.Encrypt("d," + obj.id.ToString())) + "\" >" + users + "</a>")) + "</td>" + "<td>" + obj.Room + "</td>" + "<td>" + obj.Address + "</td>" + "</tr>"; } } tbodyBody.InnerHtml = html; divPagging.InnerHtml = ""; if (totalRecords > 0) { ShowPaggings(pageIndex, totalPages, totalRecords, "./department_list.aspx", divPagging); } }
private void NewDepartment() { var dept = DepartmentInstance.GetObject(); BuildInfo(dept); DepartmentInstance.Add(dept); // 保存操作历史 SaveHistory(new TB_AccountHistory { ActionId = ActionInstance.Find(f => f.Name.Equals("AddDept")).id, ObjectA = "[id=" + dept.id + "] " + dept.Name }); ShowNotification("./department_list.aspx", "Success: You added a new department.", true); }
private void EditDept() { var id = int.Parse(Utility.Decrypt(hidID.Value)); var dept = DepartmentInstance.Find(f => f.id == id && f.Delete == false); BuildInfo(dept); Update(dept); SaveHistory(new TB_AccountHistory { ActionId = ActionInstance.Find(f => f.Name.Equals("EditDept")).id, ObjectA = "[id=" + dept.id + "] " + dept.Name }); ShowNotification("./department_list.aspx", "Success: You changed the dept. info.", true); }
protected void bt_Delete_Click(object sender, EventArgs e) { if (!HasSessionLose) { if ("" != hidID.Value) { var subIds = new List <int>(); var ids = GetIdList(hidID.Value.Split(new char[] { ',' })); subIds.AddRange(ids); var list = DepartmentInstance.FindList(f => ids.Contains(f.id)); foreach (var dept in list) { // 先删除所有下属部门 var subs = DepartmentInstance.GetSubdepartments(dept.id); subIds.AddRange(subs); var subList = DepartmentInstance.FindList(f => subs.Contains(f.id) && f.Delete == false); foreach (var sub in subList) { //subIds.Add(sub.id); sub.Delete = true; Update(sub); } // 更新删除状态 dept.Delete = true; Update(dept); // 保存删除历史记录 SaveHistory(new TB_AccountHistory { ActionId = ActionInstance.Find(f => f.Name.Equals("DeleteDept")).id, ObjectA = "[id=" + dept.id + "] " + dept.Name }); } // 删除动作完成之后才处理用户的默认部门信息 TB_Department dftDept = DepartmentInstance.GetDefaultDepartment(); // 清理所有下级部门的用户列表 foreach (var id in subIds) { AccountInstance.ClearDeptInfo(id, null == dftDept ? 0 : dftDept.id); } ShowNotification("./department_list.aspx", "Success: You have delete " + ids.Count() + " department(s)."); } } }
private void initQueryCondition() { if (!string.IsNullOrEmpty(_key)) { var k = Utility.Decrypt(_key).Split(new char[] { ',' }); switch (k[0]) { case "d": // 部门查询 hidDepartment.Value = k[1]; var dept = DepartmentInstance.Find(f => f.id == ParseInt(k[1])); txtDepartment.Value = dept.Name; break; case "r": hidRole.Value = k[1]; var role = RoleInstance.Find(f => f.id == ParseInt(k[1])); txtRole.Value = role.Name; break; } } }
private void BuildAccountInfo(TB_Account obj) { obj.Answer = txtAnswer.Value.Trim(); obj.Code = txtCode.Value.Trim(); obj.Department = ParseInt(hidDepartment.Value); if (obj.Department < 0) { obj.Department = null; // 获取默认部门 var dept = DepartmentInstance.Find(f => f.IsDefault == true && f.Delete == false); if (null != dept) { obj.Department = dept.id; } } obj.Email = txtEmail.Value.Trim(); obj.LandlineNumber = txtLindline.Value.Trim(); obj.Name = txtName.Value.Trim(); //新建用户时 if (obj.id == 0) { obj.Password = Utility.MD5("123456"); } obj.Phone = txtPhone.Value.Trim(); obj.Question = txtQuestion.Value.Trim(); obj.Role = ParseInt(hidRole.Value); // 默认角色 if (obj.Role < 0) { obj.Role = (int?)null; var role = RoleInstance.Find(f => f.IsDefault == true && f.Delete == false); if (null != role) { obj.Role = role.id; } } }
/// <summary> /// 检测默认部门按钮是否可用 /// </summary> private void checkCheckBox() { var dft = DepartmentInstance.Find(f => f.IsDefault == true && f.Delete == false); cbIsDefault.Enabled = null == dft; }
private void ShowAccountList() { // 部门id列表 var depts = "" != hidDepartment.Value ? (DepartmentInstance.GetSubdepartments(ParseInt(hidDepartment.Value))) : (DepartmentInstance.GetAllDepartments()); // 角色列表 List <int> roles; if ("" != hidRole.Value) { roles = new List <int>(); roles.Add(ParseInt(hidRole.Value)); } else { roles = RoleInstance.GetAllRole(); } var totalRecords = 0; var pageIndex = "" == hidPageIndex.Value ? 1 : int.Parse(hidPageIndex.Value); var list = AccountInstance.FindPageList <TB_Account>(pageIndex, PageSize, out totalRecords, f => (f.Name.IndexOf(txtName.Value.Trim()) >= 0) && (roles.Contains(f.Role.Value) || f.Role == (int?)null) && (depts.Contains(f.Department.Value) || f.Department == (int?)null) && f.Delete == false, "Name"); var totalPages = totalRecords / PageSize + (totalRecords % PageSize > 0 ? 1 : 0); string html = ""; if (totalRecords < 1) { html = "<tr><td colspan=\"12\">No records, You can change the condition and try again or " + " <a href=\"./account_add.aspx\">ADD</a> new one.</td></tr>"; } else { var cnt = (pageIndex - 1) * PageSize; foreach (var obj in list) { cnt++; var id = Utility.UrlEncode(Utility.Encrypt(obj.id.ToString())); html += "<tr " + (obj.Locked == true ? "style=\"color: red;\"" : "") + ">" + "<td style=\"width: 40px; text-align: center;\"><input type=\"checkbox\" id=\"cb_" + id + "\" /></td>" + "<td style=\"width: 40px; text-align: center;\">" + cnt + "</td>" + "<td style=\"width: 60px;\"><a href=\"./account_add.aspx?key=" + id + "\" >" + obj.Name + "</a></td>" + "<td style=\"width: 60px;\">" + obj.Code + "</td>" + "<td style=\"width: 80px;\">" + obj.RegisterTime.Value.ToString("yyyy-MM-dd") + "</td>" + "<td style=\"width: 50px;\">" + (obj.Locked == true ? "Locked" : "Normal") + "</td>" + "<td>" + ("<a href=\"#d" + (null == obj.Department ? "" : obj.Department.ToString()) + "\" >" + (null == obj.Department ? "-" : obj.TB_Department.Name) + "</a>") + "</td>" + "<td>" + ("<a href=\"#r" + (null == obj.Role ? "" : obj.Role.ToString()) + "\" >" + (null == obj.Role ? "-" : obj.TB_Role.Name) + "</a>") + "</td>" + "<td>" + obj.LoginTimes.ToString() + "</td>" + "<td>" + (null == obj.LastLoginTime ? "never" : obj.LastLoginTime.Value.ToString("yyyy-MM-dd HH:mm:ss")) + "</td>" + "<td>" + obj.LastLoginIp + "</td>" + "<td></td>" + "</tr>"; } } tbodyBody.InnerHtml = html; divPagging.InnerHtml = ""; if (totalRecords > 0) { ShowPaggings(pageIndex, totalPages, totalRecords, "./account_list.aspx", divPagging); } }