using System; using System.Text.RegularExpressions; using System.Data; using BP.DA; using BP.En; using BP.Sys; namespace BP.Cloud { /// /// 操作员 属性 /// public class EmpAttr : BP.En.EntityNoNameAttr { #region 基本属性 /// /// 用户ID /// public const string UserID = "UserID"; /// /// 部门 /// public const string FK_Dept = "FK_Dept"; /// /// 密码 /// public const string Pass = "Pass"; /// /// 电话 /// public const string Tel = "Tel"; /// /// 邮箱 /// public const string Email = "Email"; /// /// 序号 /// public const string Idx = "Idx"; /// /// 拼音 /// public const string PinYin = "PinYin"; public const string Leader = "Leader"; #endregion /// /// QQAppID /// public const string QQAppID = "QQAppID"; /// /// QQ号 /// public const string QQ = "QQ"; /// /// 组织结构编码 /// public const string OrgNo = "OrgNo"; public const string OrgName = "OrgName"; public const string OpenID = "OpenID"; public const string OpenID2 = "OpenID2"; /// /// 连接的ID /// public const string unionid = "unionid"; public const string EmpSta = "EmpSta"; } /// /// 操作员 的摘要说明。 /// public class Emp : EntityNoName { #region 扩展属性 /// /// 该人员是否被禁用. /// public bool IsEnable { get { if (this.No == "admin") return true; string sql = "SELECT COUNT(FK_Emp) FROM Port_DeptEmpStation WHERE FK_Emp='" + this.No + "'"; if (DBAccess.RunSQLReturnValInt(sql, 0) == 0) return false; sql = "SELECT COUNT(FK_Emp) FROM Port_DeptEmp WHERE FK_Emp='" + this.No + "'"; if (DBAccess.RunSQLReturnValInt(sql, 0) == 0) return false; return true; } } /// /// 用户ID. /// public string UserID { get { return this.GetValStrByKey(EmpAttr.UserID); } set { this.SetValByKey(EmpAttr.UserID, value); } } public string OpenID { get { return this.GetValStrByKey(EmpAttr.OpenID); } set { this.SetValByKey(EmpAttr.OpenID, value); } } public string OpenID2 { get { return this.GetValStrByKey(EmpAttr.OpenID2); } set { this.SetValByKey(EmpAttr.OpenID2, value); } } public string unionid { get { return this.GetValStrByKey(EmpAttr.unionid); } set { this.SetValByKey(EmpAttr.unionid, value); } } /// /// 拼音 /// public string PinYin { get { return this.GetValStrByKey(EmpAttr.PinYin); } set { this.SetValByKey(EmpAttr.PinYin, value); } } /// /// 主要的部门。 /// public Dept HisDept { get { try { return new Dept(this.FK_Dept); } catch (Exception ex) { throw new Exception("@获取操作员" + this.No + "部门[" + this.FK_Dept + "]出现错误,可能是系统管理员没有给他维护部门.@" + ex.Message); } } } /// /// 部门 /// public string FK_Dept { get { return this.GetValStrByKey(EmpAttr.FK_Dept); } set { this.SetValByKey(EmpAttr.FK_Dept, value); } } public string FK_DeptText { get { return this.GetValRefTextByKey(EmpAttr.FK_Dept); } } public string Tel { get { return this.GetValStrByKey(EmpAttr.Tel); } set { this.SetValByKey(EmpAttr.Tel, value); } } public string Email { get { return this.GetValStrByKey(EmpAttr.Email); } set { this.SetValByKey(EmpAttr.Email, value); } } /// /// 直属领导 /// public string Leader { get { return this.GetValStrByKey(EmpAttr.Leader); } set { this.SetValByKey(EmpAttr.Leader, value); } } /// /// 密码 /// public string Pass { get { return this.GetValStrByKey(EmpAttr.Pass); } set { this.SetValByKey(EmpAttr.Pass, value); } } public string QQ { get { return this.GetValStrByKey(EmpAttr.QQ); } set { this.SetValByKey(EmpAttr.QQ, value); } } public string QQAppID { get { return this.GetValStringByKey(EmpAttr.QQAppID); } set { this.SetValByKey(EmpAttr.QQAppID, value); } } /// /// 顺序号 /// public int Idx { get { return this.GetValIntByKey(EmpAttr.Idx); } set { this.SetValByKey(EmpAttr.Idx, value); } } /// /// 组织结构编码 /// public string OrgNo { get { return this.GetValStrByKey(EmpAttr.OrgNo); } set { this.SetValByKey(EmpAttr.OrgNo, value); } } public string OrgName { get { return this.GetValStrByKey(EmpAttr.OrgName); } set { this.SetValByKey(EmpAttr.OrgName, value); } } #endregion #region 公共方法 /// /// 检查密码(可以重写此方法) /// /// 密码 /// 是否匹配成功 public bool CheckPass(string pass) { //启用加密 if (BP.Difference.SystemConfig.IsEnablePasswordEncryption == true) pass = BP.Tools.Cryptography.EncryptString(pass); /*使用数据库校验.*/ if (this.Pass.Equals(pass) == true) return true; return false; } #endregion 公共方法 #region 构造函数 /// /// 操作员 /// public Emp() { } /// /// 初始化人员 /// /// /// public Emp(string orgNo, string userID) { int i= this.Retrieve(EmpAttr.OrgNo, orgNo, EmpAttr.UserID, userID); if (i == 0) throw new Exception("@组织编号:" + orgNo + " 或者UserID:" + UserID + "错误."); } /// /// 操作员 /// /// 编号 public Emp(string no) { try { //如果小于11位估计不是一个手机号. /* if (BP.DA.DataType.IsMobile(no) == false) this.No = BP.Web.WebUser.OrgNo + "_" + no; else this.No = no;*/ this.No = no; this.Retrieve(); // this.No = no; } catch (Exception ex) { int i = this.RetrieveFromDBSources(); if (i == 0) throw new Exception("err@用户账号[" + this.No + "]错误:" + ex.Message); } } public override UAC HisUAC { get { UAC uac = new UAC(); if (BP.Web.WebUser.IsAdmin == true) uac.OpenAll(); else uac.Readonly(); return uac; } } /// /// 重写基类方法 /// public override Map EnMap { get { if (this._enMap != null) return this._enMap; Map map = new Map("Port_Emp", "用户"); map.setEnType(EnType.App); map.IndexField = EmpAttr.FK_Dept; #region 字段 /*关于字段属性的增加 */ map.AddTBStringPK(EmpAttr.No, null, "手机号/ID", false, false, 1, 500, 90); map.AddTBString(EmpAttr.UserID, null, "用户ID", true, true, 0, 100, 10); map.AddTBString(EmpAttr.Name, null, "姓名", true, false, 0, 500, 130); map.AddDDLEntities(EmpAttr.FK_Dept, null, "当前登录的部门", new BP.Port.Depts(), false); //状态. 0=启用,1=禁用. map.AddTBInt(EmpAttr.EmpSta, 0, "EmpSta", false, false); map.AddTBString(EmpAttr.Leader, null, "部门领导", false, false, 0, 100, 10); map.AddTBString(EmpAttr.Tel, null, "电话", true, false, 0, 20, 130); map.AddTBString(EmpAttr.Email, null, "邮箱", true, false, 0, 100, 132, true); map.AddTBString(EmpAttr.PinYin, null, "拼音", false, false, 0, 1000, 132, true); map.AddTBString(EmpAttr.OrgNo, null, "OrgNo", true, true, 0, 500, 132, true); //map.AddDDLEntities(EmpAttr.OrgNo, null, "组织", new BP.Cloud.Orgs(), false); //map.AddTBString(EmpAttr.OrgNo, null, "OrgNo", false, false, 0, 36, 36); //map.AddTBString(EmpAttr.OrgName, null, "OrgName", false, false, 0, 36, 36); map.AddTBInt(EmpAttr.Idx, 0, "序号", true, false); #endregion 字段 #region 相关方法. RefMethod rm = new RefMethod(); rm.Title = "设置图片签名"; rm.ClassMethodName = this.ToString() + ".DoSinger"; rm.RefMethodType = RefMethodType.RightFrameOpen; map.AddRefMethod(rm); rm = new RefMethod(); rm.Title = "部门角色"; rm.ClassMethodName = this.ToString() + ".DoEmpDepts"; rm.RefMethodType = RefMethodType.RightFrameOpen; map.AddRefMethod(rm); //节点绑定部门. 节点绑定部门. map.AttrsOfOneVSM.AddBranches(new DeptEmps(), new BP.Port.Depts(), BP.Port.DeptEmpAttr.FK_Emp, BP.Port.DeptEmpAttr.FK_Dept, "部门维护", EmpAttr.Name, EmpAttr.No, "@WebUser.FK_Dept"); rm = new RefMethod(); rm.Title = "修改密码"; rm.ClassMethodName = this.ToString() + ".DoResetpassword"; rm.HisAttrs.AddTBString("pass1", null, "输入密码", true, false, 0, 100, 100); rm.HisAttrs.AddTBString("pass2", null, "再次输入", true, false, 0, 100, 100); map.AddRefMethod(rm); rm = new RefMethod(); rm.Title = "修改主部门"; rm.ClassMethodName = this.ToString() + ".DoEditMainDept"; rm.RefAttrKey = EmpAttr.FK_Dept; rm.RefMethodType = RefMethodType.LinkModel; map.AddRefMethod(rm); rm = new RefMethod(); rm.Title = "设置部门直属领导"; rm.ClassMethodName = this.ToString() + ".DoEditLeader"; rm.RefAttrKey = "LeaderName"; rm.RefMethodType = RefMethodType.LinkModel; map.AddRefMethod(rm); #endregion 相关方法. this._enMap = map; return this._enMap; } } #region 方法执行. public string DoEditMainDept() { return "../../../GPM/EmpDeptMainDept.htm?FK_Emp=" + this.No + "&FK_Dept=" + this.FK_Dept; } public string DoEditLeader() { return "../../../GPM/EmpLeader.htm?FK_Emp=" + this.No + "&FK_Dept=" + this.FK_Dept; } public string DoEmpDepts() { return "/GPM/EmpDepts.htm?FK_Emp=" + this.No; } public string DoSinger() { //路径 return "../../../GPM/Siganture.htm?EmpNo=" + this.No; } #endregion 方法执行. protected override bool beforeInsert() { if (BP.Difference.SystemConfig.IsEnablePasswordEncryption == true) { if (DataType.IsNullOrEmpty(this.Pass)) this.Pass = "123"; if (this.Pass.Length < 28) this.Pass = BP.Tools.Cryptography.EncryptString(this.Pass); } ////当前人员所在的部门. // this.OrgNo = BP.Web.WebUser.OrgNo; ////处理主部门的问题. //DeptEmp de = new DeptEmp(); //de.FK_Dept = this.FK_Dept; //de.FK_Emp = this.No; //de.IsMainDept = true; //de.OrgNo = this.OrgNo; //de.Save(); return base.beforeInsert(); } protected override bool beforeUpdateInsertAction() { //增加拼音,以方便查找. if (DataType.IsNullOrEmpty(this.Name) == true) throw new Exception("err@名称不能为空."); string pinyinQP = BP.DA.DataType.ParseStringToPinyin(this.Name).ToLower(); string pinyinJX = BP.DA.DataType.ParseStringToPinyinJianXie(this.Name).ToLower(); this.PinYin = "," + pinyinQP + "," + pinyinJX + ","; return base.beforeUpdateInsertAction(); } /// /// 保存后修改WF_Emp中的邮箱 /// protected override void afterInsertUpdateAction() { string sql = "Select Count(*) From WF_Emp Where No='" + this.No + "'"; int count = DBAccess.RunSQLReturnValInt(sql); if (count == 0) sql = "INSERT INTO WF_Emp (No,Name) VALUES('" + this.No + "','" + this.Name + "')"; DBAccess.RunSQL(sql); //修改Port_Emp中的缓存 BP.Port.Emp emp = new BP.Port.Emp(); emp.No = this.No; if (emp.RetrieveFromDBSources() != 0) { emp.FK_Dept = this.FK_Dept; emp.Update(); } base.afterInsertUpdateAction(); } protected override bool beforeDelete() { if (this.OrgNo.Equals(BP.Web.WebUser.OrgNo)==false) throw new Exception("err@您不能删除别人的数据."); DeptEmps ens = new DeptEmps(); ens.Delete(DeptEmpAttr.FK_Emp, this.No); DeptEmpStations ensD = new DeptEmpStations(); ensD.Delete(DeptEmpAttr.FK_Emp, this.No); return base.beforeDelete(); } /// /// 删除之后要做的事情 /// protected override void afterDelete() { base.afterDelete(); } public static string GenerPinYin(string name) { //增加拼音,以方便查找. string pinyinQP = BP.DA.DataType.ParseStringToPinyin(name).ToLower(); string pinyinJX = BP.DA.DataType.ParseStringToPinyinJianXie(name).ToLower(); string py = "," + pinyinQP + "," + pinyinJX + ","; return py; } /// /// 向上移动 /// public string DoUp() { this.DoOrderUp(EmpAttr.FK_Dept, this.FK_Dept, EmpAttr.Idx); return "执行成功."; } /// /// 向下移动 /// public string DoDown() { this.DoOrderDown(EmpAttr.FK_Dept, this.FK_Dept, EmpAttr.Idx); return "执行成功."; } public string DoResetpassword(string pass1, string pass2) { if (pass1.Equals(pass2) == false) return "两次密码不一致"; if (BP.Difference.SystemConfig.IsEnablePasswordEncryption == true) pass1 = BP.Tools.Cryptography.EncryptString(pass1); this.Pass = pass1; this.Update(); return "密码设置成功"; } /// /// 获取集合 /// public override Entities GetNewEntities { get { return new Emps(); } } #endregion 构造函数 } /// /// 操作员s // public class Emps : EntitiesNoName { #region 构造方法 /// /// 得到它的 Entity /// public override Entity GetNewEntity { get { return new Emp(); } } /// /// 操作员s /// public Emps() { } #endregion 构造方法 #region 为了适应自动翻译成java的需要,把实体转换成List. /// /// 转化成 java list,C#不能调用. /// /// List public System.Collections.Generic.IList ToJavaList() { return (System.Collections.Generic.IList)this; } /// /// 转化成list /// /// List public System.Collections.Generic.List Tolist() { System.Collections.Generic.List list = new System.Collections.Generic.List(); for (int i = 0; i < this.Count; i++) { list.Add((Emp)this[i]); } return list; } #endregion 为了适应自动翻译成java的需要,把实体转换成List. } }