YUI Library Home

YUI Library Examples: Calendar Control: Calendar and Select Fields

Calendar Control: Calendar and Select Fields

This example builds upon the Events example, by demonstrating how you can use the select event to set the state of some dropdowns. It also demonstates how the current page and selected date can be set on the Calendar after it is first rendered.

Su Mo Tu We Th Fr Sa
29 30 31 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 6 7 8

Setting up the Calendar

In this example, we will build a Calendar that can accept selections on any date from 1/1/2006 to 12/31/2010, and we will set up a series of select boxes that can be used to change the selected date. First, we will construct the Calendar with the minimum and maximum dates specified:

1YAHOO.example.calendar.cal1 = new YAHOO.widget.Calendar("cal1","cal1Container"
2                                                            { mindate:"1/1/2006"
3                                                              maxdate:"12/31/2010" }); 
view plain | print | ?

Next, we will place our markup, which includes a standard container for the Calendar, and the select elements needed to change the date:

1<div id="cal1Container"></div> 
2 
3<form name="dates"
4    <select id="selMonth" name="selMonth"
5        ... 
6    </select> 
7 
8    <select name="selDay" id="selDay"
9        ... 
10    </select> 
11 
12    <select name="selYear" id="selYear"
13        ... 
14    </select> 
15</form> 
view plain | print | ?

Next, we must define a handler that will fire when the user changes the selected date on the Calendar. This function will be named handleSelect, and will be subscribed to the Calendar's selectEvent:

1function handleSelect(type,args,obj) { 
2    var dates = args[0]; 
3    var date = dates[0]; 
4    var year = date[0], month = date[1], day = date[2]; 
5 
6    var selMonth = document.getElementById("selMonth"); 
7    var selDay = document.getElementById("selDay"); 
8    var selYear = document.getElementById("selYear"); 
9 
10    selMonth.selectedIndex = month; 
11    selDay.selectedIndex = day; 
12 
13    for (var y=0;y<selYear.options.length;y++) { 
14        if (selYear.options[y].text == year) { 
15            selYear.selectedIndex = y; 
16            break
17        } 
18    } 
19
20 
21... 
22 
23YAHOO.example.calendar.cal1.selectEvent.subscribe(handleSelect, YAHOO.example.calendar.cal1, true); 
view plain | print | ?

The handleSelect function receives an array of selected dates as an argument. Since this Calendar is only single-select, we will only need to retrieve the first (and only) item in the array. The date argument is passed as an easily sorted Integer array in the format: [yyyy, mm, dd]. The handleSelect function uses this array to properly select the corresponding values in each select field. Note that it's also necessary to subscribe the function to the selectEvent on the Calendar so that it will be fired when a selection is made.

Next, we will define a function called updateCal, which will be used to update the Calendar with the field values that are selected in each select field:

1function updateCal() { 
2    var selMonth = document.getElementById("selMonth"); 
3    var selDay = document.getElementById("selDay"); 
4    var selYear = document.getElementById("selYear"); 
5 
6    var month = parseInt(selMonth.options[selMonth.selectedIndex].text); 
7    var day = parseInt(selDay.options[selDay.selectedIndex].value); 
8    var year = parseInt(selYear.options[selYear.selectedIndex].value); 
9 
10    if (! isNaN(month) && ! isNaN(day) && ! isNaN(year)) { 
11        var date = month + "/" + day + "/" + year; 
12 
13        YAHOO.example.calendar.cal1.select(date); 
14        YAHOO.example.calendar.cal1.cfg.setProperty("pagedate", month + "/" + year); 
15        YAHOO.example.calendar.cal1.render(); 
16    } 
17
view plain | print | ?

The updateCal function does two key things. First, it grabs the selected values from the select fields and uses them to make a new selection on the Calendar. Next, it changes the visible page of the Calendar to the Calendar's earliest selected date, so that the selection will be clear to the user. We can wire up the select fields to call updateCal when selections are made using the Event utility. In our example, we will do this after initializing the Calendar:

1YAHOO.util.Event.addListener(["selMonth","selDay","selYear"], "change", updateCal); 
view plain | print | ?

It's worth noting that this example doesn't cover advanced features like date validation or randomly changing the selectable days based on the day of the month, so you are able to select invalid dates like February 31. Calendar automatically attempts to compensate for the extra invalid dates by moving the selection forward into the next month.

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.

Copyright © 2009 Yahoo! Inc. All rights reserved.

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