Can anyone solve this problem? I want to get the items details by its category by clicking the category first then click the item button. When I click Categories, it shows the items. But then when I click the foreach created item button its just refreshing and not firing the BtnItem_Click Event. I am beginner with c# I don't know why is that happen. Thank you so much in advance.
Here is my code:
protected void Page_Init(object sender, EventArgs e)
{
getcategories();
}
private void getcategories()
{
try
{
CategoryModel model = new CategoryModel();
List<TblCategory> categories = model.GetAllCategory();
if (categories != null)
{
foreach (TblCategory category in categories)
{
Button btnCategory = new Button();
btnCategory.Text = category.CategoryName;
btnCategory.ID = category.Id.ToString();
btnCategory.CssClass = category.BtnColor;
btnCategory.Click += BtnCategory_Click;
pnlcategories.Controls.Add(btnCategory);
}
}
else
{
pnlcategories.Controls.Add(new Literal { Text = "No Categories found!" });
}
}
catch (Exception ex)
{
alerterror.Visible = true;
lblerror.Visible = true;
lblerror.Text = "Error: " + ex;
}
}
private void BtnCategory_Click(object sender, EventArgs e)
{
try
{
List<Control> listControls = pnlitem.Controls.Cast<Control>().ToList();
foreach (Control control in listControls)
{
pnlitem.Controls.Remove(control);
control.Dispose();
}
Button btn = sender as Button;
string cssclass = btn.CssClass;
string Id = btn.ID.ToString();
var selectcategory = (from p in db.TblItems
where p.CategoryId == Id
select p).ToList();
if (selectcategory != null)
{
foreach (TblItem item in selectcategory)
{
Button btnItem = new Button();
btnItem.Text = item.ItemName;
btnItem.ToolTip = "P" + item.ItemPrice.ToString("0.00");
btnItem.CssClass = cssclass;
btnItem.ID = item.Id;
btnItem.Click += BtnItem_Click;
pnlitem.Controls.Add(btnItem);
}
}
}
catch (Exception ex)
{
alerterror.Visible = true;
lblerror.Visible = true;
lblerror.Text = "Error: " + ex;
}
}
private void BtnItem_Click(object sender, EventArgs e) // <== this is not triggering
{
alertsuccess.Visible = true;
lblsuccess.Visible = true;
lblsuccess.Text = "Trigger success!";
}
and here is my html form:
×<div id="alerterror" runat="server" class="alert alert-danger alert-lg fade in w3-card-4" visible="false">
<span class="close" data-dismiss="alert">×</span>
<asp:Label ID="lblerror" runat="server" Visible="false"></asp:Label>
</div>
<asp:UpdatePanel ID="UpdatePanel1" runat="server">
<ContentTemplate>
<asp:Panel CssClass="pnlcat" ID="pnlcategories" runat="server" Wrap="true">
</asp:Panel>
<asp:Panel ID="pnlitem" runat="server" CssClass="pnlprod" Wrap="true" BorderStyle="Solid" BorderWidth="1px">
</asp:Panel>
</ContentTemplate>
</asp:UpdatePanel>