Calendar provides configuration properties that can be used to change the Calendar's various data labels, when the Calendar is used in different locales. This example shows how to provide locale specific labels for month and weekday names, as well as how to configure the expected format of any date strings passed in to the Calendar. It uses Germany as an example locale
There are several properties that are used to change localization settings:
In addition, the Calendar provides special configuration properties for determining how incoming dates and date ranges should be formatted. By default, the date format for input to the Calendar is mm/dd/yyyy. Ranges are separated by a dash ("-") and lists of dates are delimited using a comma (","). Using these properties, the initial formatting of date can be easily modified:
In our tutorial, we will create a German Calendar that is set up both to accept dates in the standard German format (dd.mm.yyyy) and present the labels in German. Note that all of our date label values will contain special characters in Unicode notation. Also, we will present the weekday labels in the "short" format, which will amount to 2 characters in this example.
1 | YAHOO.example.calendar.cal1 = new YAHOO.widget.Calendar("cal1","cal1Container", |
2 | { LOCALE_WEEKDAYS:"short", |
3 | START_WEEKDAY: 1, |
4 | MULTI_SELECT: true |
5 | } ); |
6 | |
7 | // Correct formats for Germany: dd.mm.yyyy, dd.mm, mm.yyyy |
8 | |
9 | YAHOO.example.calendar.cal1.cfg.setProperty("DATE_FIELD_DELIMITER", "."); |
10 | |
11 | YAHOO.example.calendar.cal1.cfg.setProperty("MDY_DAY_POSITION", 1); |
12 | YAHOO.example.calendar.cal1.cfg.setProperty("MDY_MONTH_POSITION", 2); |
13 | YAHOO.example.calendar.cal1.cfg.setProperty("MDY_YEAR_POSITION", 3); |
14 | |
15 | YAHOO.example.calendar.cal1.cfg.setProperty("MD_DAY_POSITION", 1); |
16 | YAHOO.example.calendar.cal1.cfg.setProperty("MD_MONTH_POSITION", 2); |
17 | |
18 | // Date labels for German locale |
19 | |
20 | YAHOO.example.calendar.cal1.cfg.setProperty("MONTHS_SHORT", ["Jan", "Feb", "M\u00E4r", "Apr", "Mai", "Jun", "Jul", "Aug", "Sep", "Okt", "Nov", "Dez"]); |
21 | YAHOO.example.calendar.cal1.cfg.setProperty("MONTHS_LONG", ["Januar", "Februar", "M\u00E4rz", "April", "Mai", "Juni", "Juli", "August", "September", "Oktober", "November", "Dezember"]); |
22 | YAHOO.example.calendar.cal1.cfg.setProperty("WEEKDAYS_1CHAR", ["S", "M", "D", "M", "D", "F", "S"]); |
23 | YAHOO.example.calendar.cal1.cfg.setProperty("WEEKDAYS_SHORT", ["So", "Mo", "Di", "Mi", "Do", "Fr", "Sa"]); |
24 | YAHOO.example.calendar.cal1.cfg.setProperty("WEEKDAYS_MEDIUM",["Son", "Mon", "Die", "Mit", "Don", "Fre", "Sam"]); |
25 | YAHOO.example.calendar.cal1.cfg.setProperty("WEEKDAYS_LONG", ["Sonntag", "Montag", "Dienstag", "Mittwoch", "Donnerstag", "Freitag", "Samstag"]); |
view plain | print | ? |
Next, we can set some selected dates and the current pagedate using our newly configured date format, and render the Calendar:
1 | YAHOO.example.calendar.cal1.select("1.10.2006-8.10.2006"); |
2 | YAHOO.example.calendar.cal1.cfg.setProperty("PAGEDATE", "10.2006"); |
3 | YAHOO.example.calendar.cal1.render(); |
view plain | print | ? |
Copyright © 2008 Yahoo! Inc. All rights reserved.
Privacy Policy - Terms of Service - Copyright Policy - Job Openings