/
Core-Gadget - i18n
Core-Gadget - i18n
The "JavaScript i18n" feature provides a JavaScript API for localized parsing and formatting of dates, times, numbers and currency according to the rules for the gadget's locale as set by the container. The feature is specified by including either an "Optional" or "Required" element within the "ModulePrefs" of the Gadget specification. The feature identifier is "opensocial-i18n". A container MUST emit the OpenSocial JavaScript i18n libraries and data files required by the libraries if an application requires the feature <Require feature="opensocial-i18n"/>. The container SHOULD emit the OpenSocial JavaScript i18n libraries and data files required by the libraries if an application optionallly requests the feature <Optional feature="opensocial-i18n"/>. Once available, gadget developer's can use the feature via the "gadgets.i18n" JavaScript class. The locale used by a gadget is established by the container when the gadget is rendered. The i18n feature will use the country and language specified in the locale to load the appropriate formatter and parser for any given date, time, number or currency. The i18n feature provides four distinct methods, defined <xref target="i18n.methods">here</xref>. These are formatDateTime, formatNumber, parseDateTime and parseNumber. At a minimum, each method takes as input a format pattern that defines the structure of the data being parsed or formatted and the value to which the pattern is to be applied. For instance, to format an integer using a localized grouping separator (e.g. the number 1234567 formatted as "1,234,567" when the locale is "en-US"), the following can be used:</t> var str = gadgets.i18n.formatNumber("#,###", 1234567); The i18n feature includes a number of common, predefined format patterns that can be used. The specific definition of these formats are specific to the locale established by the container. For instance, using the predefined "gadgets.i18n.MEDIUM_DATE_FORMAT" pattern to format the date for August, 4th 2006 using the "de" (German) locale using the formatDateTime method would output "04.08.2006". Using the same predefined pattern using the "en-US" (United States) locale, however, would output "08-04-2006". var date = new Date(2006,7,4); var str = gadgets.i18n.formatDateTime(gadgets.i18n.MEDIUM_DATE_FORMAT, date); When parsing and formatting currencies using the predefined patterns, There are several considerations that need to be taken into account. For example, when the default locale is set to "fr-FR" (France), and the gadgets.i18n.CURRENCY_PATTERN is used to parse a string, the parser will assume that the input string is formatted according to the localized rules for the "fr-FR" locale: var num = gadgets.i18n.parseNumber(gadgets.i18n.CURRENCY_PATTERN, "20 000 \u20AC"); Here, "num" will equal 20000. </t> If a foreign currency is used, U.S. Dollars for instance, the input string MUST still be formatted in accordance to the rules specified for the established locale and an optional currency code can be specified: var num = gadgets.i18n.parseNumber(gadgets.i18n.CURRENCY_PATTERN, "20 000 $", 0, "USD"); If, however, the input string is not formatted in accordance to the localized rules for the established locale, the predefined pattern will not work and a custom pattern needs to be used: var num = gadgets.i18n.parseNumber("#,###", "$20,000", 0, "USD"); #.#. Specifying Format and Parsing Patterns #.#.#. Date/Time Pattern Specification When formatting and parsing dates and times, the i18n feature utilizes the patten specification defined in Appendix F of the <eref target="http://www.unicode.org/reports/tr35/#Date_Format_Patterns"> Unicode Locale Data Markup Language</eref> with the exception that support for the following symbols is not required: - w: Week of year - W: Week of Month - D: Day of year - F: Day of Week in Month - g: Modified Julian day #.#.#. Number Pattern Specification Patterns for formatting and parsing numbers are expressed using the same grammar used by the Java Standard Edition's as described <eref target="http://docs.oracle.com/javase/7/docs/api/java/text/NumberFormat.html">NumberFormat</eref> class.</t> For example, assuming a locale of "en-US", using the pattern "#,##0.00" to format the number 1234567.1234 using the formatNumber method would output "1,234,567.12". #.#. JavaScript Definitions #.#.#. Predefined Format Constants The Predefined Format Constants that MUST be supported are listed in the table below. The specific pattern associated with each constant will vary by locale. <texttable> <ttcol align="left" width="15%">Property</ttcol> <ttcol align="left">Description</ttcol> <c><spanx style="verb">gadgets.i18n.CURRENCY_PATTERN</spanx></c> <c>The default currency format, e.g. for the locale "en-US", the number 1234.235 would format as "$1,234.34".</c> <c><spanx style="verb">gadgets.i18n.DECIMAL_PATTERN</spanx></c> <c>The default decimal number format, e.g. for the locale "de-DE", the number 1234 with a fractional decimal of 13 would format as "1.234,13".</c> <c><spanx style="verb">gadgets.i18n.PERCENT_PATTERN</spanx></c> <c>The default percentage number format, e.g. for the locale "en-US", the number 123 would format as "12,300%"</c> <c><spanx style="verb">gadgets.i18n.SCIENTIFIC_PATTERN</spanx></c> <c>The default scientific-notation format, e.g. the number 12345.0 would format as "1E4"</c> <c><spanx style="verb">gadgets.i18n.FULL_DATE_FORMAT</spanx></c> <c></c> <c><spanx style="verb">gadgets.i18n.FULL_DATETIME_FORMAT</spanx></c> <c></c> <c><spanx style="verb">gadgets.i18n.FULL_TIME_FORMAT</spanx></c> <c></c> <c><spanx style="verb">gadgets.i18n.LONG_DATE_FORMAT</spanx></c> <c></c> <c><spanx style="verb">gadgets.i18n.LONG_DATETIME_FORMAT</spanx></c> <c></c> <c><spanx style="verb">gadgets.i18n.LONG_TIME_FORMAT</spanx></c> <c></c> <c><spanx style="verb">gadgets.i18n.MEDIUM_DATE_FORMAT</spanx></c> <c></c> <c><spanx style="verb">gadgets.i18n.MEDIUM_DATETIME_FORMAT</spanx></c> <c></c> <c><spanx style="verb">gadgets.i18n.MEDIUM_TIME_FORMAT</spanx></c> <c></c> <c><spanx style="verb">gadgets.i18n.SHORT_DATE_FORMAT</spanx></c> <c></c> <c><spanx style="verb">gadgets.i18n.SHORT_DATETIME_FORMAT</spanx></c> <c></c> <c><spanx style="verb">gadgets.i18n.SHORT_TIME_FORMAT</spanx></c> <c></c> </texttable> </section> (after here is the current javascript reference.. largely unmodified)