I have a Horizontal DataList of several LinkButtons. button represents a stage that can be whether "COMPLETED" (green image) or "NOT STARTED" (grey image). In addition, each such button must contain some text and it's stage number, for example: "STAGE 1", "STAGE 2" etc...
I found several solutions but none of them answered both of my demands - the image and the text.
Does anybody have a good and elegant solution on that matter?
Here's the html code:
<asp:DataList ID="dlStatuses" runat="server" RepeatDirection="Horizontal"
onitemdatabound="dlStatuses_ItemDataBound"
onitemcommand="dlStatuses_ItemCommand">
<HeaderTemplate>
<table border="0" cellpadding="0" cellspacing="0">
</HeaderTemplate>
<ItemTemplate>
<asp:LinkButton ID="linkBtnStatuses" runat="server">
<asp:Image ID="linkButtonImage" runat="server" ImageAlign="Middle" BorderStyle="None"/>
</asp:LinkButton>
</ItemTemplate>
</asp:DataList>
and the code behind:
protected void dlStatuses_ItemDataBound(object sender, DataListItemEventArgs e)
{
if (e.Item.ItemType == ListItemType.Item || e.Item.ItemType == ListItemType.AlternatingItem)
{
DataRow row = (e.Item.DataItem as DataRowView).Row;
#region Place Icons
int StatusLevel = int.Parse(row["LevelID"].ToString());
LinkButton lnkButton = (e.Item.FindControl("linkBtnStatuses")) as LinkButton;
Image img = (e.Item.FindControl("linkButtonImage")) as Image;
//lnkButton.Text = " Stage No. " + StatusLevel.ToString();
switch (StatusLevel)
{
case 1:
img.ImageUrl = "~/style/images/Green.png";
break;
case 2:
img.ImageUrl = "~/style/images/Grey.png";
break;
}
}
Thanks in advance