E' utile per selezionare date, ma anche per mostrare eventualmente dati estratti da un database.
L'esempio di oggi rientra nell'ultima tipologia ed anche se alla fine mostra solo dei link in base al valore contenuto in un Array (precedentemente popolato ad esempio a partire da un database), può semplicemente essere riciclato per fini differenti, ad esempio per mostrare le presenze di un dipendente in un mese.
Il codice si basa dunque su un Array bidimensionale, composta dalla prima colonna che indica il mese e dalla seconda che indica il giorno.
Alla fine è sufficiente intercettare l'evento DayRender del
Calendar (che si verifica ogni volta che un giorno è creato) e scrivere all'interno della cella quello che ci pare.
<SCRIPT runat="SERVER" language="C#">
private string[,] myContent = new string[13, 32];
private void Page_Load(object sender, System.EventArgs e)
{
// estrazione dati da db
// creiamo alcuni inserimenti a caso
myContent[DateTime.Today.Month, DateTime.Today.Day] = "http://www.aspitalia.com/";
myContent[12, 12] = "http://whideyday.aspitalia.com/";
myContent[DateTime.Today.Month, 28] = "http://forum.aspitalia.com/";
}
protected void cal_DayRender(object sender,DayRenderEventArgs e)
{
// disattivo la selezione di tutti i giorni
e.Day.IsSelectable = false;
// verifico che nell'Array ci sia qualcosa
string Cont = null;
DateTime dt = DateTime.Parse(e.Day.Date.ToString());
Cont = myContent[Convert.ToInt32(dt.Month.ToString()), Convert.ToInt32(dt.Day.ToString())];
if (Cont!= null)
{
// rimuovo tutti i controls esistenti
for (int j = 0; j<=e.Cell.Controls.Count; j++)
{
e.Cell.Controls.RemoveAt(j);
}
// cambio colore di sfondo
e.Cell.BackColor = System.Drawing.Color.Red;
// creo una nuova label e l'aggiungo alla cella
Label lblContent = new Label();
lblContent.Text = "<a href=\"" + Cont + "\">" + e.Day.DayNumberText + "</a>";
e.Cell.Controls.Add (lblContent);
}
}
</SCRIPT>
<form runat="server">
<asp:calendar id="cal" runat="server" onDayRender="cal_DayRender" enableviestate="false"/>
</form>