using System; using System.Data; using System.Windows.Forms; namespace FileWatcher { public partial class MaCodeSearchTextBox : UserControl { #region 构造函数 public MaCodeSearchTextBox() { InitializeComponent(); } #endregion #region 变量 /// /// 是否通过Leave事件找到数据 /// public bool LeaveFindData; /// /// DBFind窗体弹出的标题 /// private string DBTitle1; /// /// 输入框是否可编辑 /// private bool TextBoxEnable1; /// /// 业务逻辑的标识符 /// private string caller; /// /// 发起DbFind的窗体 /// private string formName; /// /// 需要赋值的字段 /// private string[] setValueField; /// /// 初始的筛选条件 /// private string condition; /// /// 权限标识 /// private string Power1; /// /// 查询的表名 /// private string tableName; /// /// 查询的字段 /// private string selectField; /// /// 设置绑定的CheckBox /// LockCheckBox LockCheckBox; public delegate void DBSourceChange(object sender, EventArgs e); public event DBSourceChange DbChange; DataTable dt = new DataTable(); DbFind db; DataTable ReturnData1; public override string Text { get { return TextBox.Text.ToUpper(); } set { TextBox.Text = value; } } string AllPower1; public string AllPower { get { return AllPower1; } set { AllPower1 = value; } } public string Caller { get { return caller; } set { caller = value; } } public string FormName { get { return formName; } set { formName = value; } } public string[] SetValueField { get { return setValueField; } set { setValueField = value; } } public string Condition { get { return condition; } set { condition = value; } } public string TableName { get { return tableName; } set { tableName = value; } } public string SelectField { get { return selectField; } set { selectField = value; } } public string Power { get { return Power1; } set { Power1 = value; } } public string DBTitle { get { return DBTitle1; } set { DBTitle1 = value; } } public bool TextBoxEnable { get { return TextBoxEnable1; } set { TextBoxEnable1 = value; } } public DataTable ReturnData { get { return ReturnData1; } set { ReturnData1 = value; } } #endregion #region 自定义事件 public delegate void OnTextChange(object sender, EventArgs e); //定义事件 public event OnTextChange UserControlTextChanged; //定义委托 public delegate void Icon_Click(object sender, EventArgs e); /// /// 图标点击事件 /// public event Icon_Click SearchIconClick; #endregion //定义委托 private void TextBox_TextChanged(object sender, EventArgs e) { UserControlTextChanged?.Invoke(sender, new EventArgs()); } //Key先发起失去焦点事件,在执行用户自定义的事件 private void TextBox_KeyDown(object sender, KeyEventArgs e) { if (e.KeyCode == Keys.Enter) GetData(true); } public void SetLockCheckBox(LockCheckBox ctl) { LockCheckBox = ctl; } public void GetData(bool LeaveOrEnter) { DataHelper dh = SystemInf.dh; string sql = ""; //将查询到的结果返回界面 if (TextBox.Text != "") { sql = "select " + BaseUtil.AddField(setValueField) + " from " + tableName + " where " + Name + "='" + TextBox.Text.ToUpper() + "'"; } else if (db != null) { sql = "select " + BaseUtil.AddField(setValueField) + " from " + tableName + " where " + Name + "='" + db.TextBoxValue1 + "'"; } if (condition != null) { sql += " and " + condition; } try { dt = (DataTable)dh.ExecuteSql(sql, "select"); if (dt.Rows.Count > 0) ReturnDataToFrom(); } catch (Exception e) { } if (LeaveOrEnter || TextBox.Text != "") LockCheckBox.Checked = true; } private void fillControl(int i, Control ct) { for (int j = 0; j < setValueField.Length; j++) { if (ct.Controls.Count > 0 && ct.Name.ToString() != setValueField[j]) { Control.ControlCollection controls = ct.Controls; for (int k = 0; k < ct.Controls.Count; k++) { fillControl(i, controls[k]); } } else { if ((setValueField[j] == dt.Columns[i].Caption.ToLower() || setValueField[j] == dt.Columns[i].ColumnName.ToLower() || setValueField[j].Contains(dt.Columns[i].Caption.ToLower()) || (ct != null && ct.Tag != null && ct.Tag.ToString() == dt.Columns[i].Caption.ToLower())) && ct.Name.ToString() == setValueField[j]) ct.Text = dt.Rows[0][dt.Columns[i].ColumnName].ToString(); } } } private void Search_Icon_Click(object sender, EventArgs e) { SearchIconClick?.Invoke(sender, new EventArgs()); db = new DbFind(Name, tableName, selectField, setValueField, caller, formName, condition); db.Text = DBTitle1; if (db.IsAbleDbFind1) { db.ShowDialog(); GetData(true); } else { MessageBox.Show("该字段未配置DbFind", "提示", MessageBoxButtons.OK, MessageBoxIcon.Asterisk); } } private void ReturnDataToFrom() { ReturnData1 = dt; DbChange?.Invoke(new object(), new EventArgs()); } public void TextBox_Leave(object sender, EventArgs e) { //GetData(false); } private void SearchTextBox_Load(object sender, EventArgs e) { if (!TextBoxEnable1) TextBox.BackColor = System.Drawing.Color.White; TextBox.Enabled = TextBoxEnable1; } private void SearchTextBox_SizeChanged(object sender, EventArgs e) { TextBox.Width = this.Width - Search_Icon.Width - 3; } private void MaCodeSearchTextBox_Leave(object sender, EventArgs e) { if (TextBox.Text != "") GetData(false); } } }