Setup - I want user to enter details for their plastic cards. They can click on AddNewCard button to add multiple cards.
Code
[Serializable]
public class Card
{
public string Number { get; set; }
public string Code { get; set; }
}
public class CardControl : CompositeControl
{
private LinkButton _lnkAddNewCard = new LinkButton { Text = "Add Card" };
private PlaceHolder _plcListCards=new PlaceHolder();
private IList<Card> _lstCards
{
get { return (IList<Card>) ViewState["ListCards"]; }
set { ViewState["ListCards"] = value; }
}
protected override void OnInit(EventArgs e)
{
_lnkAddNewCard.Click+=_lnkAddNewCard_Click;
}
void _lnkAddNewCard_Click(object sender, EventArgs e)
{
var lstCards = _lstCards ?? new List<Card>();
lstCards.Add(new Card());
_lstCards = lstCards;
RenderCard(_lstCards[lstCards.Count - 1]);
}
protected override void CreateChildControls()
{
Controls.Clear();
Controls.Add(_lnkAddNewCard);
Controls.Add(_plcListCards);
RenderCards();
}
protected void RenderCards()
{
_plcListCards.Controls.Clear();
if(_lstCards == null) _lstCards = new List<Card> { new Card() };
foreach (var card in _lstCards)
RenderCard(card);
}
protected void RenderCard(Card card)
{
_plcListCards.Controls.Add(new TextBox() { Text = card.Number});
_plcListCards.Controls.Add(new TextBox() { Text = card.Code});
}
}
Issue
- On first Page Load, Textboxes for first Card entry are shown.
- If user clicks on Add New card, postback happens and button click event fires.
- As it's a postback, CreateChildControls has executed already, so, button click event handler calls RenderCard() so as to append textboxes for second card entry.
- If user clicks Add New card again, button click doesn't fire this time. A BIG WHY?