예제 #1
0
        /// <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);
            }
        }
예제 #2
0
        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);
            }
        }
예제 #3
0
        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);
        }
예제 #4
0
        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);
        }
예제 #5
0
        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).");
                }
            }
        }
예제 #6
0
        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;
                }
            }
        }
예제 #7
0
 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;
         }
     }
 }
예제 #8
0
        /// <summary>
        /// 检测默认部门按钮是否可用
        /// </summary>
        private void checkCheckBox()
        {
            var dft = DepartmentInstance.Find(f => f.IsDefault == true && f.Delete == false);

            cbIsDefault.Enabled = null == dft;
        }
예제 #9
0
        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);
            }
        }