Personalizzare il contenuto delle celle del Calendar

di Daniele Bochicchio, in ASP.NET, Web Server Controls, C#,

In passato mi sono già occupato del control Calendar. La verità è che si tratta di un oggetto molto flessibile e comodo per le più svariate esigenze.
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] = "https://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>

Il risultato è visibile ad esempio all'interno dei Blogs di ASPItalia.com:
http://blogs.aspitalia.com/

Commenti

Visualizza/aggiungi commenti

| Condividi su: Twitter, Facebook, LinkedIn

Per inserire un commento, devi avere un account.

Fai il login e torna a questa pagina, oppure registrati alla nostra community.

Approfondimenti

I più letti di oggi