日期时间选择器痛苦在 Bu.如果前面的条件不相等,我想禁用它
本文关键字:不相等 条件 痛苦 选择器 时间 Bu 前面 如果 日期 | 更新日期: 2023-09-27 18:30:58
我有一个包含历史数据的旧时间表应用程序,HR 希望偶尔查看旧数据,因此我的任务是构建一个可以执行此操作的 C# 应用程序。 首先,用户选择一个支付组下拉列表,选择一个支付组,根据支付组选择员工下拉列表填充, 然后我有两个文本框,一个包含最小日期,另一个包含您猜对了最大日期,然后我有两个日期时间选择器从日期到日期。日期时间选取器从"最小日期"框和"最大日期"文本框中获取其值,选择所有项目后,用户单击"运行报告"并生成报告。
如需视觉效果,请单击此 ->图片
我的问题是,如果没有可用的日期,我想将日期时间选择器的可见性设置为 false,如下所示 -> 图片中,因为您可以看到日期不会更改,因为日期时间选择器无法将自己设置为等于空字符串,因此解决方法是我只想让用户甚至看不到日期时间选择器
我尝试过的代码:
private void mindateset() // fill the listbox of values of mindate and maxdate
{
if (Employee.SelectedValue != null)
{
if (Employee.SelectedValue.ToString().Trim().Length > 0)
{
try
{
using (MSSQL.SqlConnection connection = new MSSQL.SqlConnection(constr))
{
timepunchnew = new EtimeHistoryDataSet();
connection.Open();
using (MSSQL.SqlCommand command = new MSSQL.SqlCommand("SELECT MIN(TransDate) AS mindate, MAX(TransDate) AS maxdate FROM dbo.EtimePunchDetail WHERE (EmpID = @empid)", connection))
{
MSSQL.SqlParameter myminparam = new MSSQL.SqlParameter();
myminparam.Direction = ParameterDirection.Input;
myminparam.ParameterName = "@empid";
myminparam.Value = Employee.SelectedValue;
command.Parameters.Add(myminparam);
MSSQL.SqlDataAdapter myadapter = new System.Data.SqlClient.SqlDataAdapter();
myadapter.SelectCommand = command;
myadapter.Fill(timepunchnew, "Mindate");
AvailableMin.DataSource = timepunchnew.Mindate;
AvailableMin.DisplayMember = "mindate";
AvailableMax.DataSource = timepunchnew.Mindate;
AvailableMax.DisplayMember = "maxdate";
FromDate.MinDate = DateTime.Parse(AvailableMin.Text);
FromDate.Value = FromDate.MinDate;
if (FromDate.Value != FromDate.MinDate)
{
if (DialogResult.OK == MessageBox.Show("The Selected User Does Not Have Any FromDate"))
{
FromDate.Visible = false;
}
else
{
FromDate.Value = FromDate.MinDate;
FromDate.Visible = true;
}
}
ToDate.MaxDate = DateTime.Parse(AvailableMax.Text);
ToDate.Value = ToDate.MaxDate;
if (ToDate.Value != ToDate.MaxDate)
if (DialogResult.OK == MessageBox.Show("The Selected User Does Not Have Any FromDate"))
{
ToDate.Visible = false;
}
else
{
ToDate.Value = ToDate.MinDate;
ToDate.Visible = true;
}
}
}
任何这方面的帮助将不胜感激,这是我项目的最后一步
我创建了两个文本框并将其放在日期时间选择器值上,如果列表框中没有可用的日期,则使其可见:)
private void AvailableMin_SelectedIndexChanged(object sender, EventArgs e)
{
if (AvailableMin.Text == "")
{
textBox2.Visible = true;
textBox2.Text = "There are no to dates available for this particular user";
}
else
{
textBox2.Visible = false;
}
}
private void AvailableMax_SelectedIndexChanged(object sender, EventArgs e)
{
if (AvailableMax.Text == "")
{
textBox1.Visible = true;
textBox1.Text = "There are no to dates available for this particular user";
}
else
{
textBox1.Visible = false;
}
}