using System; using System.Data; using System.Windows.Forms; namespace FileWatcher { public partial class SearchTextBox : UserControl { #region 构造函数 public SearchTextBox() { 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; DataTable dt = new DataTable(); DbFind db; private DataTable returnData; public override string Text { get { return TextBox.Text; } 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 returnData; } set { returnData = 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; public delegate void DBSourceChange(object sender, EventArgs e); public event DBSourceChange DbChange; public delegate void OnTextKeyDown(object sender, KeyEventArgs e); public event OnTextKeyDown TextKeyDown; #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) { TextBox_Leave(sender, e); TextKeyDown?.Invoke(sender, new KeyEventArgs(e.KeyCode)); } } 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(); } else { MessageBox.Show("该字段未配置DbFind", "提示", MessageBoxButtons.OK, MessageBoxIcon.Asterisk); } } /// /// 触发给界面的 /// /// /// public void ReturnDataToForm() { returnData = dt; DbChange?.Invoke(new object(), new EventArgs()); } private void TextBox_Enter(object sender, EventArgs e) { TextBox.BackColor = System.Drawing.Color.GreenYellow; } /// /// 重新刷新数据 /// /// /// public void RefreshDB(object sender, EventArgs e) { TextBox_Leave(sender, e); GetData(); } public void TextBox_Leave(object sender, EventArgs e) { TextBox.BackColor = System.Drawing.Color.White; GetData(); } private void SearchTextBox_Load(object sender, EventArgs e) { if (!TextBoxEnable1) TextBox.BackColor = System.Drawing.Color.White; TextBox.Enabled = TextBoxEnable1; Search_Icon.Power = this.Power; } private void SearchTextBox_SizeChanged(object sender, EventArgs e) { TextBox.Width = this.Width - Search_Icon.Width - 3; } public void GetData() { DataHelper dh = SystemInf.dh; string sql = ""; //将查询到的结果返回界面 if (TextBox.Text != "") { sql = "select " + BaseUtil.AddField(setValueField) + " from " + tableName + " where " + Name + "='" + TextBox.Text + "'"; } 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) ReturnDataToForm(); } catch (Exception e) { } } } }