YUI Library Home

YUI Library Examples: Calendar Control: Handling Calendar Events

Calendar Control: Handling Calendar Events

The Calendar control exposes a number of CustomEvents, so that applications can listen for and react to interesting moments in the Calendar's operation. This example demonstrates how to listen for the select and deselect events, which are fired whenever a date in the Calendar is selected or deselected.

Su Mo Tu We Th Fr Sa
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5
Select/Deselect Events

Setting up the Calendar

Calendar provides several events to which an application can subscribe in order to react easily to changes in the state of the Calendar. The events provided are:

  • beforeRenderEvent - Fired prior to the rendering of the Calendar
  • renderEvent - Fired after the Calendar is rendered
  • beforeSelectEvent - Fired before a selection is made
  • selectEvent - Fired after a date selection is made. This event receives one argument -- an array of dates fields in the format: [[yyyy,mm,dd],[yyyy,mm,dd]]
  • beforeDeselectEvent - Fired before a deselection is made
  • deselectEvent - Fired after dates are deselected. This event receives one argument -- an array of dates fields in the format: [[yyyy,mm,dd],[yyyy,mm,dd]]
  • changePageEvent - Fired when the active Calendar page is changed
  • clearEvent - Fired when the Calendar is cleared. Calling clear on a Calendar removes all of its selections and sets the page to the current month and year.
  • resetEvent - Fired when the Calendar is reset. Calling a Calendar's reset method resets the Calendar to its original view and selection state.

The events are each defined by YAHOO.util.CustomEvent, and are subscribed to using the subscribe method of CustomEvent. In this example, we will display a message each time a date is selected or deselected. The selectEvent and deselectEvent events will fire when selections and deselections are made via user interaction (eg, when a user clicks to select a date) or programatically (eg., if a script on the page executes the select method to select a date).

The dateToLocaleString function used to generate the messages demonstrates how you can use the locale configuration properties for Calendar when creating string representations of dates

1function dateToLocaleString(dt, cal) { 
2        var wStr = cal.cfg.getProperty("WEEKDAYS_LONG")[dt.getDay()]; 
3        var dStr = dt.getDate(); 
4        var mStr = cal.cfg.getProperty("MONTHS_LONG")[dt.getMonth()]; 
5        var yStr = dt.getFullYear(); 
6        return (wStr + ", " + dStr + " " + mStr + " " + yStr); 
7
8 
9function mySelectHandler(type,args,obj) { 
10        var selected = args[0]; 
11        var selDate = this.toDate(selected[0]); 
12 
13        logEvent("SELECTED: " + dateToLocaleString(selDate, this)); 
14}; 
15 
16function myDeselectHandler(type, args, obj) { 
17        var deselected = args[0]; 
18        var deselDate = this.toDate(deselected[0]); 
19 
20        logEvent("DESELECTED: " + dateToLocaleString(deselDate, this)); 
21}; 
22 
23YAHOO.example.calendar.cal1 = new YAHOO.widget.Calendar("cal1","cal1Container"); 
24 
25YAHOO.example.calendar.cal1.selectEvent.subscribe(mySelectHandler, YAHOO.example.calendar.cal1, true); 
26YAHOO.example.calendar.cal1.deselectEvent.subscribe(myDeselectHandler, YAHOO.example.calendar.cal1, true); 
27 
28YAHOO.example.calendar.cal1.render(); 
view plain | print | ?

Configuration for This Example

You can load the necessary JavaScript and CSS for this example from Yahoo's servers. Click here to load the YUI Dependency Configurator with all of this example's dependencies preconfigured.

YUI Logger Output:

Logger Console

INFO 1063ms (+0) 7:54:58 PM:

Config

Firing Config event: iframe=false

INFO 1063ms (+0) 7:54:58 PM:

Config

Firing Config event: close=false

INFO 1063ms (+1) 7:54:58 PM:

Config

Firing Config event: title=

CELL 1062ms (+0) 7:54:58 PM:

Calendar cal1

renderer[0] for (2025-4-5)

CELL 1062ms (+0) 7:54:58 PM:

Calendar cal1

Rendering cell cal1_cell41 (2025-4-5)

CELL 1062ms (+0) 7:54:58 PM:

Calendar cal1

renderer[0] for (2025-4-4)

CELL 1062ms (+0) 7:54:58 PM:

Calendar cal1

Rendering cell cal1_cell40 (2025-4-4)

CELL 1062ms (+0) 7:54:58 PM:

Calendar cal1

renderer[0] for (2025-4-3)

CELL 1062ms (+0) 7:54:58 PM:

Calendar cal1

Rendering cell cal1_cell39 (2025-4-3)

CELL 1062ms (+0) 7:54:58 PM:

Calendar cal1

renderer[0] for (2025-4-2)

CELL 1062ms (+0) 7:54:58 PM:

Calendar cal1

Rendering cell cal1_cell38 (2025-4-2)

CELL 1062ms (+0) 7:54:58 PM:

Calendar cal1

renderer[0] for (2025-4-1)

CELL 1062ms (+0) 7:54:58 PM:

Calendar cal1

Rendering cell cal1_cell37 (2025-4-1)

CELL 1062ms (+0) 7:54:58 PM:

Calendar cal1

renderer[1] for (2025-3-31)

CELL 1062ms (+0) 7:54:58 PM:

Calendar cal1

renderer[0] for (2025-3-31)

CELL 1062ms (+0) 7:54:58 PM:

Calendar cal1

Rendering cell cal1_cell36 (2025-3-31)

CELL 1062ms (+0) 7:54:58 PM:

Calendar cal1

renderer[1] for (2025-3-30)

CELL 1062ms (+0) 7:54:58 PM:

Calendar cal1

renderer[0] for (2025-3-30)

CELL 1062ms (+0) 7:54:58 PM:

Calendar cal1

Rendering cell cal1_cell35 (2025-3-30)

CELL 1062ms (+0) 7:54:58 PM:

Calendar cal1

renderer[1] for (2025-3-29)

CELL 1062ms (+0) 7:54:58 PM:

Calendar cal1

renderer[0] for (2025-3-29)

CELL 1062ms (+0) 7:54:58 PM:

Calendar cal1

Rendering cell cal1_cell34 (2025-3-29)

CELL 1062ms (+0) 7:54:58 PM:

Calendar cal1

renderer[1] for (2025-3-28)

CELL 1062ms (+0) 7:54:58 PM:

Calendar cal1

renderer[0] for (2025-3-28)

CELL 1062ms (+0) 7:54:58 PM:

Calendar cal1

Rendering cell cal1_cell33 (2025-3-28)

CELL 1062ms (+0) 7:54:58 PM:

Calendar cal1

renderer[1] for (2025-3-27)

CELL 1062ms (+0) 7:54:58 PM:

Calendar cal1

renderer[0] for (2025-3-27)

CELL 1062ms (+0) 7:54:58 PM:

Calendar cal1

Rendering cell cal1_cell32 (2025-3-27)

CELL 1062ms (+0) 7:54:58 PM:

Calendar cal1

renderer[1] for (2025-3-26)

CELL 1062ms (+0) 7:54:58 PM:

Calendar cal1

renderer[0] for (2025-3-26)

CELL 1062ms (+0) 7:54:58 PM:

Calendar cal1

Rendering cell cal1_cell31 (2025-3-26)

CELL 1062ms (+0) 7:54:58 PM:

Calendar cal1

renderer[1] for (2025-3-25)

CELL 1062ms (+1) 7:54:58 PM:

Calendar cal1

renderer[0] for (2025-3-25)

CELL 1061ms (+0) 7:54:58 PM:

Calendar cal1

Rendering cell cal1_cell30 (2025-3-25)

CELL 1061ms (+0) 7:54:58 PM:

Calendar cal1

renderer[1] for (2025-3-24)

CELL 1061ms (+0) 7:54:58 PM:

Calendar cal1

renderer[0] for (2025-3-24)

CELL 1061ms (+0) 7:54:58 PM:

Calendar cal1

Rendering cell cal1_cell29 (2025-3-24)

CELL 1061ms (+0) 7:54:58 PM:

Calendar cal1

renderer[1] for (2025-3-23)

CELL 1061ms (+0) 7:54:58 PM:

Calendar cal1

renderer[0] for (2025-3-23)

CELL 1061ms (+0) 7:54:58 PM:

Calendar cal1

Rendering cell cal1_cell28 (2025-3-23)

CELL 1061ms (+0) 7:54:58 PM:

Calendar cal1

renderer[1] for (2025-3-22)

CELL 1061ms (+0) 7:54:58 PM:

Calendar cal1

renderer[0] for (2025-3-22)

CELL 1061ms (+0) 7:54:58 PM:

Calendar cal1

Rendering cell cal1_cell27 (2025-3-22)

CELL 1061ms (+0) 7:54:58 PM:

Calendar cal1

renderer[1] for (2025-3-21)

CELL 1061ms (+0) 7:54:58 PM:

Calendar cal1

renderer[0] for (2025-3-21)

CELL 1061ms (+0) 7:54:58 PM:

Calendar cal1

Rendering cell cal1_cell26 (2025-3-21)

CELL 1061ms (+0) 7:54:58 PM:

Calendar cal1

renderer[1] for (2025-3-20)

CELL 1061ms (+0) 7:54:58 PM:

Calendar cal1

renderer[0] for (2025-3-20)

CELL 1061ms (+0) 7:54:58 PM:

Calendar cal1

Rendering cell cal1_cell25 (2025-3-20)

CELL 1061ms (+0) 7:54:58 PM:

Calendar cal1

renderer[1] for (2025-3-19)

CELL 1061ms (+0) 7:54:58 PM:

Calendar cal1

renderer[0] for (2025-3-19)

CELL 1061ms (+0) 7:54:58 PM:

Calendar cal1

Rendering cell cal1_cell24 (2025-3-19)

CELL 1061ms (+0) 7:54:58 PM:

Calendar cal1

renderer[1] for (2025-3-18)

CELL 1061ms (+0) 7:54:58 PM:

Calendar cal1

renderer[0] for (2025-3-18)

CELL 1061ms (+0) 7:54:58 PM:

Calendar cal1

Rendering cell cal1_cell23 (2025-3-18)

CELL 1061ms (+0) 7:54:58 PM:

Calendar cal1

renderer[1] for (2025-3-17)

CELL 1061ms (+0) 7:54:58 PM:

Calendar cal1

renderer[0] for (2025-3-17)

CELL 1061ms (+0) 7:54:58 PM:

Calendar cal1

Rendering cell cal1_cell22 (2025-3-17)

CELL 1061ms (+0) 7:54:58 PM:

Calendar cal1

renderer[2] for (2025-3-16)

CELL 1061ms (+0) 7:54:58 PM:

Calendar cal1

renderer[1] for (2025-3-16)

CELL 1061ms (+0) 7:54:58 PM:

Calendar cal1

renderer[0] for (2025-3-16)

CELL 1061ms (+0) 7:54:58 PM:

Calendar cal1

Rendering cell cal1_cell21 (2025-3-16)

CELL 1061ms (+0) 7:54:58 PM:

Calendar cal1

renderer[1] for (2025-3-15)

CELL 1061ms (+0) 7:54:58 PM:

Calendar cal1

renderer[0] for (2025-3-15)

CELL 1061ms (+0) 7:54:58 PM:

Calendar cal1

Rendering cell cal1_cell20 (2025-3-15)

CELL 1061ms (+0) 7:54:58 PM:

Calendar cal1

renderer[1] for (2025-3-14)

CELL 1061ms (+1) 7:54:58 PM:

Calendar cal1

renderer[0] for (2025-3-14)

CELL 1060ms (+0) 7:54:58 PM:

Calendar cal1

Rendering cell cal1_cell19 (2025-3-14)

CELL 1060ms (+0) 7:54:58 PM:

Calendar cal1

renderer[1] for (2025-3-13)

CELL 1060ms (+0) 7:54:58 PM:

Calendar cal1

renderer[0] for (2025-3-13)

CELL 1060ms (+0) 7:54:58 PM:

Calendar cal1

Rendering cell cal1_cell18 (2025-3-13)

CELL 1060ms (+0) 7:54:58 PM:

Calendar cal1

renderer[1] for (2025-3-12)

CELL 1060ms (+0) 7:54:58 PM:

Calendar cal1

renderer[0] for (2025-3-12)

CELL 1060ms (+0) 7:54:58 PM:

Calendar cal1

Rendering cell cal1_cell17 (2025-3-12)

CELL 1060ms (+0) 7:54:58 PM:

Calendar cal1

renderer[1] for (2025-3-11)

CELL 1060ms (+0) 7:54:58 PM:

Calendar cal1

renderer[0] for (2025-3-11)

CELL 1060ms (+0) 7:54:58 PM:

Calendar cal1

Rendering cell cal1_cell16 (2025-3-11)

CELL 1060ms (+0) 7:54:58 PM:

Calendar cal1

renderer[1] for (2025-3-10)

CELL 1060ms (+0) 7:54:58 PM:

Calendar cal1

renderer[0] for (2025-3-10)

CELL 1060ms (+0) 7:54:58 PM:

Calendar cal1

Rendering cell cal1_cell15 (2025-3-10)

CELL 1060ms (+0) 7:54:58 PM:

Calendar cal1

renderer[1] for (2025-3-9)

CELL 1060ms (+0) 7:54:58 PM:

Calendar cal1

renderer[0] for (2025-3-9)

CELL 1060ms (+0) 7:54:58 PM:

Calendar cal1

Rendering cell cal1_cell14 (2025-3-9)

CELL 1060ms (+0) 7:54:58 PM:

Calendar cal1

renderer[1] for (2025-3-8)

CELL 1060ms (+0) 7:54:58 PM:

Calendar cal1

renderer[0] for (2025-3-8)

CELL 1060ms (+0) 7:54:58 PM:

Calendar cal1

Rendering cell cal1_cell13 (2025-3-8)

CELL 1060ms (+0) 7:54:58 PM:

Calendar cal1

renderer[1] for (2025-3-7)

CELL 1060ms (+0) 7:54:58 PM:

Calendar cal1

renderer[0] for (2025-3-7)

CELL 1060ms (+0) 7:54:58 PM:

Calendar cal1

Rendering cell cal1_cell12 (2025-3-7)

CELL 1060ms (+0) 7:54:58 PM:

Calendar cal1

renderer[1] for (2025-3-6)

CELL 1060ms (+0) 7:54:58 PM:

Calendar cal1

renderer[0] for (2025-3-6)

CELL 1060ms (+0) 7:54:58 PM:

Calendar cal1

Rendering cell cal1_cell11 (2025-3-6)

CELL 1060ms (+0) 7:54:58 PM:

Calendar cal1

renderer[1] for (2025-3-5)

CELL 1060ms (+1) 7:54:58 PM:

Calendar cal1

renderer[0] for (2025-3-5)

CELL 1059ms (+0) 7:54:58 PM:

Calendar cal1

Rendering cell cal1_cell10 (2025-3-5)

CELL 1059ms (+0) 7:54:58 PM:

Calendar cal1

renderer[1] for (2025-3-4)

CELL 1059ms (+0) 7:54:58 PM:

Calendar cal1

renderer[0] for (2025-3-4)

CELL 1059ms (+0) 7:54:58 PM:

Calendar cal1

Rendering cell cal1_cell9 (2025-3-4)

CELL 1059ms (+0) 7:54:58 PM:

Calendar cal1

renderer[1] for (2025-3-3)

CELL 1059ms (+1059) 7:54:58 PM:

Calendar cal1

renderer[0] for (2025-3-3)

INFO 0ms (+0) 7:54:56 PM:

global

Logger initialized

Note: You are viewing this example in debug mode with logging enabled. This can significantly slow performance.

Reload with logging
and debugging disabled.

More Calendar Control Resources:

Copyright © 2009 Yahoo! Inc. All rights reserved.

Privacy Policy - Terms of Service - Copyright Policy - Job Openings