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