У меня есть кнопка, которая создает 6 элементов управления для столбцов TableLayoutPanel, 6 столбцов: номер заказа, название продукта ( поле со списком ), текущее количество ( метка ), Количество купленных, новое количество и строка удаления.
Поле со списком заполняется с помощью SQLite.Для таблицы вариантов у меня есть 7 столбцов: [Название продукта], Имя, [Серийный номер], [Склад в наличии], [Продать до].
Как сделать так, чтобы надписи под«Текущее количество» изменяется в зависимости от [На складе в наличии] выбранного элемента в поле со списком?
В моем текущем коде ошибка «Индекс находился за пределами массива» отображается каждый раз, когда я выбираюв поле со списком.
Код для создания динамического поля со списком:
ComboBox cboItemName = new ComboBox
{
Name = "cboItemName" + rowIndex,
Dock = DockStyle.Fill,
DropDownStyle = ComboBoxStyle.DropDownList
};
cboItemName.SelectedIndexChanged += new EventHandler(cboItemName_SelectedIndexChanged);
tblOrders.Controls.Add(FillComboBox(cboItemName));
Код для обработчика события поля со списком:
void cboItemName_SelectedIndexChanged(object sender, EventArgs e)
{
var cbo = (ComboBox)sender;
string name = cbo.Name;
string splittedString = new String(name.Where(Char.IsDigit).ToArray());;
string labelName = "lblCurrentQuantity" + splittedString;
string selectedIndex = cbo.SelectedIndex.ToString();
string selectedItem = cbo.SelectedItem.ToString();
Label tbx = tblOrders.Controls.Find(labelName, true).FirstOrDefault() as Label;
EditLabelCurrentQuantity(tbx, selectedItem);
}
И, наконец,код для изменения текста этикетки:
private void EditLabelCurrentQuantity(Label label, string itemSelected)
{
auth = new Authentication();
auth.getConnection();
try
{
using (SQLiteConnection con = new SQLiteConnection(auth.connectionString))
{
con.Open();
SQLiteCommand cmd = new SQLiteCommand();
cmd.CommandText = @"SELECT [Stock On Hand] FROM Variants WHERE Name='" + itemSelected + "'";
cmd.Connection = con;
SQLiteDataReader reader = cmd.ExecuteReader();
while (reader.Read())
{
string name = Convert.ToString(reader["[Stock On Hand]"]);
}
con.Close();
}
}
catch (Exception ex)
{
MessageBox.Show(ex.Message, "Error", MessageBoxButtons.OK, MessageBoxIcon.Error);
}
}