UNPKG

@angular/common

Version:

Angular - commonly needed directives and services

634 lines 59.9 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ /** * @license * Copyright Google Inc. All Rights Reserved. * * Use of this source code is governed by an MIT-style license that can be * found in the LICENSE file at https://angular.io/license */ import { ɵLocaleDataIndex as LocaleDataIndex, ɵfindLocaleData as findLocaleData, ɵgetLocalePluralCase } from '@angular/core'; import { CURRENCIES_EN } from './currencies'; /** @enum {number} */ const NumberFormatStyle = { Decimal: 0, Percent: 1, Currency: 2, Scientific: 3, }; export { NumberFormatStyle }; NumberFormatStyle[NumberFormatStyle.Decimal] = 'Decimal'; NumberFormatStyle[NumberFormatStyle.Percent] = 'Percent'; NumberFormatStyle[NumberFormatStyle.Currency] = 'Currency'; NumberFormatStyle[NumberFormatStyle.Scientific] = 'Scientific'; /** @enum {number} */ const Plural = { Zero: 0, One: 1, Two: 2, Few: 3, Many: 4, Other: 5, }; export { Plural }; Plural[Plural.Zero] = 'Zero'; Plural[Plural.One] = 'One'; Plural[Plural.Two] = 'Two'; Plural[Plural.Few] = 'Few'; Plural[Plural.Many] = 'Many'; Plural[Plural.Other] = 'Other'; /** @enum {number} */ const FormStyle = { Format: 0, Standalone: 1, }; export { FormStyle }; FormStyle[FormStyle.Format] = 'Format'; FormStyle[FormStyle.Standalone] = 'Standalone'; /** @enum {number} */ const TranslationWidth = { /** 1 character for `en-US`. For example: 'S' */ Narrow: 0, /** 3 characters for `en-US`. For example: 'Sun' */ Abbreviated: 1, /** Full length for `en-US`. For example: "Sunday" */ Wide: 2, /** 2 characters for `en-US`, For example: "Su" */ Short: 3, }; export { TranslationWidth }; TranslationWidth[TranslationWidth.Narrow] = 'Narrow'; TranslationWidth[TranslationWidth.Abbreviated] = 'Abbreviated'; TranslationWidth[TranslationWidth.Wide] = 'Wide'; TranslationWidth[TranslationWidth.Short] = 'Short'; /** @enum {number} */ const FormatWidth = { /** * For `en-US`, 'M/d/yy, h:mm a'` * (Example: `6/15/15, 9:03 AM`) */ Short: 0, /** * For `en-US`, `'MMM d, y, h:mm:ss a'` * (Example: `Jun 15, 2015, 9:03:01 AM`) */ Medium: 1, /** * For `en-US`, `'MMMM d, y, h:mm:ss a z'` * (Example: `June 15, 2015 at 9:03:01 AM GMT+1`) */ Long: 2, /** * For `en-US`, `'EEEE, MMMM d, y, h:mm:ss a zzzz'` * (Example: `Monday, June 15, 2015 at 9:03:01 AM GMT+01:00`) */ Full: 3, }; export { FormatWidth }; FormatWidth[FormatWidth.Short] = 'Short'; FormatWidth[FormatWidth.Medium] = 'Medium'; FormatWidth[FormatWidth.Long] = 'Long'; FormatWidth[FormatWidth.Full] = 'Full'; /** @enum {number} */ const NumberSymbol = { /** * Decimal separator. * For `en-US`, the dot character. * Example : 2,345`.`67 */ Decimal: 0, /** * Grouping separator, typically for thousands. * For `en-US`, the comma character. * Example: 2`,`345.67 */ Group: 1, /** * List-item separator. * Example: "one, two, and three" */ List: 2, /** * Sign for percentage (out of 100). * Example: 23.4% */ PercentSign: 3, /** * Sign for positive numbers. * Example: +23 */ PlusSign: 4, /** * Sign for negative numbers. * Example: -23 */ MinusSign: 5, /** * Computer notation for exponential value (n times a power of 10). * Example: 1.2E3 */ Exponential: 6, /** * Human-readable format of exponential. * Example: 1.2x103 */ SuperscriptingExponent: 7, /** * Sign for permille (out of 1000). * Example: 23.4‰ */ PerMille: 8, /** * Infinity, can be used with plus and minus. * Example: ∞, +∞, -∞ */ Infinity: 9, /** * Not a number. * Example: NaN */ NaN: 10, /** * Symbol used between time units. * Example: 10:52 */ TimeSeparator: 11, /** * Decimal separator for currency values (fallback to `Decimal`). * Example: $2,345.67 */ CurrencyDecimal: 12, /** * Group separator for currency values (fallback to `Group`). * Example: $2,345.67 */ CurrencyGroup: 13, }; export { NumberSymbol }; NumberSymbol[NumberSymbol.Decimal] = 'Decimal'; NumberSymbol[NumberSymbol.Group] = 'Group'; NumberSymbol[NumberSymbol.List] = 'List'; NumberSymbol[NumberSymbol.PercentSign] = 'PercentSign'; NumberSymbol[NumberSymbol.PlusSign] = 'PlusSign'; NumberSymbol[NumberSymbol.MinusSign] = 'MinusSign'; NumberSymbol[NumberSymbol.Exponential] = 'Exponential'; NumberSymbol[NumberSymbol.SuperscriptingExponent] = 'SuperscriptingExponent'; NumberSymbol[NumberSymbol.PerMille] = 'PerMille'; NumberSymbol[NumberSymbol.Infinity] = 'Infinity'; NumberSymbol[NumberSymbol.NaN] = 'NaN'; NumberSymbol[NumberSymbol.TimeSeparator] = 'TimeSeparator'; NumberSymbol[NumberSymbol.CurrencyDecimal] = 'CurrencyDecimal'; NumberSymbol[NumberSymbol.CurrencyGroup] = 'CurrencyGroup'; /** @enum {number} */ const WeekDay = { Sunday: 0, Monday: 1, Tuesday: 2, Wednesday: 3, Thursday: 4, Friday: 5, Saturday: 6, }; export { WeekDay }; WeekDay[WeekDay.Sunday] = 'Sunday'; WeekDay[WeekDay.Monday] = 'Monday'; WeekDay[WeekDay.Tuesday] = 'Tuesday'; WeekDay[WeekDay.Wednesday] = 'Wednesday'; WeekDay[WeekDay.Thursday] = 'Thursday'; WeekDay[WeekDay.Friday] = 'Friday'; WeekDay[WeekDay.Saturday] = 'Saturday'; /** * Retrieves the locale ID from the currently loaded locale. * The loaded locale could be, for example, a global one rather than a regional one. * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n) * * \@publicApi * @param {?} locale A locale code, such as `fr-FR`. * @return {?} The locale code. For example, `fr`. */ export function getLocaleId(locale) { return findLocaleData(locale)[LocaleDataIndex.LocaleId]; } /** * Retrieves day period strings for the given locale. * * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n) * * \@publicApi * @param {?} locale A locale code for the locale format rules to use. * @param {?} formStyle The required grammatical form. * @param {?} width The required character width. * @return {?} An array of localized period strings. For example, `[AM, PM]` for `en-US`. */ export function getLocaleDayPeriods(locale, formStyle, width) { /** @type {?} */ const data = findLocaleData(locale); /** @type {?} */ const amPmData = (/** @type {?} */ ([data[LocaleDataIndex.DayPeriodsFormat], data[LocaleDataIndex.DayPeriodsStandalone]])); /** @type {?} */ const amPm = getLastDefinedValue(amPmData, formStyle); return getLastDefinedValue(amPm, width); } /** * Retrieves days of the week for the given locale, using the Gregorian calendar. * * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n) * * \@publicApi * @param {?} locale A locale code for the locale format rules to use. * @param {?} formStyle The required grammatical form. * @param {?} width The required character width. * @return {?} An array of localized name strings. * For example,`[Sunday, Monday, ... Saturday]` for `en-US`. */ export function getLocaleDayNames(locale, formStyle, width) { /** @type {?} */ const data = findLocaleData(locale); /** @type {?} */ const daysData = (/** @type {?} */ ([data[LocaleDataIndex.DaysFormat], data[LocaleDataIndex.DaysStandalone]])); /** @type {?} */ const days = getLastDefinedValue(daysData, formStyle); return getLastDefinedValue(days, width); } /** * Retrieves months of the year for the given locale, using the Gregorian calendar. * * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n) * * \@publicApi * @param {?} locale A locale code for the locale format rules to use. * @param {?} formStyle The required grammatical form. * @param {?} width The required character width. * @return {?} An array of localized name strings. * For example, `[January, February, ...]` for `en-US`. */ export function getLocaleMonthNames(locale, formStyle, width) { /** @type {?} */ const data = findLocaleData(locale); /** @type {?} */ const monthsData = (/** @type {?} */ ([data[LocaleDataIndex.MonthsFormat], data[LocaleDataIndex.MonthsStandalone]])); /** @type {?} */ const months = getLastDefinedValue(monthsData, formStyle); return getLastDefinedValue(months, width); } /** * Retrieves Gregorian-calendar eras for the given locale. * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n) * * \@publicApi * @param {?} locale A locale code for the locale format rules to use. * @param {?} width The required character width. * @return {?} An array of localized era strings. * For example, `[AD, BC]` for `en-US`. */ export function getLocaleEraNames(locale, width) { /** @type {?} */ const data = findLocaleData(locale); /** @type {?} */ const erasData = (/** @type {?} */ (data[LocaleDataIndex.Eras])); return getLastDefinedValue(erasData, width); } /** * Retrieves the first day of the week for the given locale. * * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n) * * \@publicApi * @param {?} locale A locale code for the locale format rules to use. * @return {?} A day index number, using the 0-based week-day index for `en-US` * (Sunday = 0, Monday = 1, ...). * For example, for `fr-FR`, returns 1 to indicate that the first day is Monday. */ export function getLocaleFirstDayOfWeek(locale) { /** @type {?} */ const data = findLocaleData(locale); return data[LocaleDataIndex.FirstDayOfWeek]; } /** * Range of week days that are considered the week-end for the given locale. * * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n) * * \@publicApi * @param {?} locale A locale code for the locale format rules to use. * @return {?} The range of day values, `[startDay, endDay]`. */ export function getLocaleWeekEndRange(locale) { /** @type {?} */ const data = findLocaleData(locale); return data[LocaleDataIndex.WeekendRange]; } /** * Retrieves a localized date-value formating string. * * @see `FormatWidth` / [Internationalization (i18n) Guide](https://angular.io/guide/i18n) * * \@publicApi * @param {?} locale A locale code for the locale format rules to use. * @param {?} width The format type. * @return {?} The localized formating string. */ export function getLocaleDateFormat(locale, width) { /** @type {?} */ const data = findLocaleData(locale); return getLastDefinedValue(data[LocaleDataIndex.DateFormat], width); } /** * Retrieves a localized time-value formatting string. * * @see `FormatWidth` / [Internationalization (i18n) Guide](https://angular.io/guide/i18n) * \@publicApi * @param {?} locale A locale code for the locale format rules to use. * @param {?} width The format type. * @return {?} The localized formatting string. */ export function getLocaleTimeFormat(locale, width) { /** @type {?} */ const data = findLocaleData(locale); return getLastDefinedValue(data[LocaleDataIndex.TimeFormat], width); } /** * Retrieves a localized date-time formatting string. * * @see `FormatWidth` / [Internationalization (i18n) Guide](https://angular.io/guide/i18n) * * \@publicApi * @param {?} locale A locale code for the locale format rules to use. * @param {?} width The format type. * @return {?} The localized formatting string. */ export function getLocaleDateTimeFormat(locale, width) { /** @type {?} */ const data = findLocaleData(locale); /** @type {?} */ const dateTimeFormatData = (/** @type {?} */ (data[LocaleDataIndex.DateTimeFormat])); return getLastDefinedValue(dateTimeFormatData, width); } /** * Retrieves a localized number symbol that can be used to replace placeholders in number formats. * @see `NumberSymbol` / [Internationalization (i18n) Guide](https://angular.io/guide/i18n) * * \@publicApi * @param {?} locale The locale code. * @param {?} symbol The symbol to localize. * @return {?} The character for the localized symbol. */ export function getLocaleNumberSymbol(locale, symbol) { /** @type {?} */ const data = findLocaleData(locale); /** @type {?} */ const res = data[LocaleDataIndex.NumberSymbols][symbol]; if (typeof res === 'undefined') { if (symbol === NumberSymbol.CurrencyDecimal) { return data[LocaleDataIndex.NumberSymbols][NumberSymbol.Decimal]; } else if (symbol === NumberSymbol.CurrencyGroup) { return data[LocaleDataIndex.NumberSymbols][NumberSymbol.Group]; } } return res; } /** * Retrieves a number format for a given locale. * * Numbers are formatted using patterns, like `#,###.00`. For example, the pattern `#,###.00` * when used to format the number 12345.678 could result in "12'345,678". That would happen if the * grouping separator for your language is an apostrophe, and the decimal separator is a comma. * * <b>Important:</b> The characters `.` `,` `0` `#` (and others below) are special placeholders * that stand for the decimal separator, and so on, and are NOT real characters. * You must NOT "translate" the placeholders. For example, don't change `.` to `,` even though in * your language the decimal point is written with a comma. The symbols should be replaced by the * local equivalents, using the appropriate `NumberSymbol` for your language. * * Here are the special characters used in number patterns: * * | Symbol | Meaning | * |--------|---------| * | . | Replaced automatically by the character used for the decimal point. | * | , | Replaced by the "grouping" (thousands) separator. | * | 0 | Replaced by a digit (or zero if there aren't enough digits). | * | # | Replaced by a digit (or nothing if there aren't enough). | * | ¤ | Replaced by a currency symbol, such as $ or USD. | * | % | Marks a percent format. The % symbol may change position, but must be retained. | * | E | Marks a scientific format. The E symbol may change position, but must be retained. | * | ' | Special characters used as literal characters are quoted with ASCII single quotes. | * * @see `NumberFormatStyle` / [CLDR website](http://cldr.unicode.org/translation/number-patterns) / [Internationalization (i18n) Guide](https://angular.io/guide/i18n) * * \@publicApi * @param {?} locale A locale code for the locale format rules to use. * @param {?} type The type of numeric value to be formatted (such as `Decimal` or `Currency`.) * @return {?} The localized format string. */ export function getLocaleNumberFormat(locale, type) { /** @type {?} */ const data = findLocaleData(locale); return data[LocaleDataIndex.NumberFormats][type]; } /** * Retrieves the symbol used to represent the currency for the main country * corresponding to a given locale. For example, '$' for `en-US`. * * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n) * * \@publicApi * @param {?} locale A locale code for the locale format rules to use. * @return {?} The localized symbol character, * or `null` if the main country cannot be determined. */ export function getLocaleCurrencySymbol(locale) { /** @type {?} */ const data = findLocaleData(locale); return data[LocaleDataIndex.CurrencySymbol] || null; } /** * Retrieves the name of the currency for the main country corresponding * to a given locale. For example, 'US Dollar' for `en-US`. * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n) * * \@publicApi * @param {?} locale A locale code for the locale format rules to use. * @return {?} The currency name, * or `null` if the main country cannot be determined. */ export function getLocaleCurrencyName(locale) { /** @type {?} */ const data = findLocaleData(locale); return data[LocaleDataIndex.CurrencyName] || null; } /** * Retrieves the currency values for a given locale. * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n) * @param {?} locale A locale code for the locale format rules to use. * @return {?} The currency values. */ function getLocaleCurrencies(locale) { /** @type {?} */ const data = findLocaleData(locale); return data[LocaleDataIndex.Currencies]; } /** * \@alias core/ɵgetLocalePluralCase * \@publicApi * @type {?} */ export const getLocalePluralCase = ɵgetLocalePluralCase; /** * @param {?} data * @return {?} */ function checkFullData(data) { if (!data[LocaleDataIndex.ExtraData]) { throw new Error(`Missing extra locale data for the locale "${data[LocaleDataIndex.LocaleId]}". Use "registerLocaleData" to load new data. See the "I18n guide" on angular.io to know more.`); } } /** * Retrieves locale-specific rules used to determine which day period to use * when more than one period is defined for a locale. * * There is a rule for each defined day period. The * first rule is applied to the first day period and so on. * Fall back to AM/PM when no rules are available. * * A rule can specify a period as time range, or as a single time value. * * This functionality is only available when you have loaded the full locale data. * See the ["I18n guide"](guide/i18n#i18n-pipes). * * @see `getLocaleExtraDayPeriods()` / [Internationalization (i18n) Guide](https://angular.io/guide/i18n) * * \@publicApi * @param {?} locale A locale code for the locale format rules to use. * @return {?} The rules for the locale, a single time value or array of *from-time, to-time*, * or null if no periods are available. * */ export function getLocaleExtraDayPeriodRules(locale) { /** @type {?} */ const data = findLocaleData(locale); checkFullData(data); /** @type {?} */ const rules = data[LocaleDataIndex.ExtraData][2 /* ExtraDayPeriodsRules */] || []; return rules.map((/** * @param {?} rule * @return {?} */ (rule) => { if (typeof rule === 'string') { return extractTime(rule); } return [extractTime(rule[0]), extractTime(rule[1])]; })); } /** * Retrieves locale-specific day periods, which indicate roughly how a day is broken up * in different languages. * For example, for `en-US`, periods are morning, noon, afternoon, evening, and midnight. * * This functionality is only available when you have loaded the full locale data. * See the ["I18n guide"](guide/i18n#i18n-pipes). * * @see `getLocaleExtraDayPeriodRules()` / [Internationalization (i18n) Guide](https://angular.io/guide/i18n) * * \@publicApi * @param {?} locale A locale code for the locale format rules to use. * @param {?} formStyle The required grammatical form. * @param {?} width The required character width. * @return {?} The translated day-period strings. */ export function getLocaleExtraDayPeriods(locale, formStyle, width) { /** @type {?} */ const data = findLocaleData(locale); checkFullData(data); /** @type {?} */ const dayPeriodsData = (/** @type {?} */ ([ data[LocaleDataIndex.ExtraData][0 /* ExtraDayPeriodFormats */], data[LocaleDataIndex.ExtraData][1 /* ExtraDayPeriodStandalone */] ])); /** @type {?} */ const dayPeriods = getLastDefinedValue(dayPeriodsData, formStyle) || []; return getLastDefinedValue(dayPeriods, width) || []; } /** * Retrieves the first value that is defined in an array, going backwards from an index position. * * To avoid repeating the same data (as when the "format" and "standalone" forms are the same) * add the first value to the locale data arrays, and add other values only if they are different. * * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n) * * \@publicApi * @template T * @param {?} data The data array to retrieve from. * @param {?} index A 0-based index into the array to start from. * @return {?} The value immediately before the given index position. */ function getLastDefinedValue(data, index) { for (let i = index; i > -1; i--) { if (typeof data[i] !== 'undefined') { return data[i]; } } throw new Error('Locale data API: locale data undefined'); } /** * Extracts the hours and minutes from a string like "15:45" * @param {?} time * @return {?} */ function extractTime(time) { const [h, m] = time.split(':'); return { hours: +h, minutes: +m }; } /** * Retrieves the currency symbol for a given currency code. * * For example, for the default `en-US` locale, the code `USD` can * be represented by the narrow symbol `$` or the wide symbol `US$`. * * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n) * * \@publicApi * @param {?} code The currency code. * @param {?} format The format, `wide` or `narrow`. * @param {?=} locale A locale code for the locale format rules to use. * * @return {?} The symbol, or the currency code if no symbol is available.0 */ export function getCurrencySymbol(code, format, locale = 'en') { /** @type {?} */ const currency = getLocaleCurrencies(locale)[code] || CURRENCIES_EN[code] || []; /** @type {?} */ const symbolNarrow = currency[1 /* SymbolNarrow */]; if (format === 'narrow' && typeof symbolNarrow === 'string') { return symbolNarrow; } return currency[0 /* Symbol */] || code; } // Most currencies have cents, that's why the default is 2 /** @type {?} */ const DEFAULT_NB_OF_CURRENCY_DIGITS = 2; /** * Reports the number of decimal digits for a given currency. * The value depends upon the presence of cents in that particular currency. * * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n) * * \@publicApi * @param {?} code The currency code. * @return {?} The number of decimal digits, typically 0 or 2. */ export function getNumberOfCurrencyDigits(code) { /** @type {?} */ let digits; /** @type {?} */ const currency = CURRENCIES_EN[code]; if (currency) { digits = currency[2 /* NbOfDigits */]; } return typeof digits === 'number' ? digits : DEFAULT_NB_OF_CURRENCY_DIGITS; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"locale_data_api.js","sourceRoot":"","sources":["../../../../../../../packages/common/src/i18n/locale_data_api.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {ɵLocaleDataIndex as LocaleDataIndex, ɵfindLocaleData as findLocaleData, ɵgetLocalePluralCase} from '@angular/core';\nimport {CURRENCIES_EN, CurrenciesSymbols} from './currencies';\nimport {CurrencyIndex, ExtraLocaleDataIndex} from './locale_data';\n\n/**\n * Format styles that can be used to represent numbers.\n * @see `getLocaleNumberFormat()`.\n * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n)\n *\n * @publicApi\n */\nexport enum NumberFormatStyle {\n  Decimal,\n  Percent,\n  Currency,\n  Scientific\n}\n\n/**\n * Plurality cases used for translating plurals to different languages.\n *\n * @see `NgPlural`\n * @see `NgPluralCase`\n * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n)\n *\n * @publicApi\n */\nexport enum Plural {\n  Zero = 0,\n  One = 1,\n  Two = 2,\n  Few = 3,\n  Many = 4,\n  Other = 5,\n}\n\n/**\n * Context-dependant translation forms for strings.\n * Typically the standalone version is for the nominative form of the word,\n * and the format version is used for the genitive case.\n * @see [CLDR website](http://cldr.unicode.org/translation/date-time#TOC-Stand-Alone-vs.-Format-Styles)\n * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n)\n *\n * @publicApi\n */\nexport enum FormStyle {\n  Format,\n  Standalone\n}\n\n/**\n * String widths available for translations.\n * The specific character widths are locale-specific.\n * Examples are given for the word \"Sunday\" in English.\n *\n * @publicApi\n */\nexport enum TranslationWidth {\n  /** 1 character for `en-US`. For example: 'S' */\n  Narrow,\n  /** 3 characters for `en-US`. For example: 'Sun' */\n  Abbreviated,\n  /** Full length for `en-US`. For example: \"Sunday\" */\n  Wide,\n  /** 2 characters for `en-US`, For example: \"Su\" */\n  Short\n}\n\n/**\n * String widths available for date-time formats.\n * The specific character widths are locale-specific.\n * Examples are given for `en-US`.\n *\n * @see `getLocaleDateFormat()`\n * @see `getLocaleTimeFormat()``\n * @see `getLocaleDateTimeFormat()`\n * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n)\n * @publicApi\n */\nexport enum FormatWidth {\n  /**\n   * For `en-US`, 'M/d/yy, h:mm a'`\n   * (Example: `6/15/15, 9:03 AM`)\n   */\n  Short,\n  /**\n   * For `en-US`, `'MMM d, y, h:mm:ss a'`\n   * (Example: `Jun 15, 2015, 9:03:01 AM`)\n   */\n  Medium,\n  /**\n   * For `en-US`, `'MMMM d, y, h:mm:ss a z'`\n   * (Example: `June 15, 2015 at 9:03:01 AM GMT+1`)\n   */\n  Long,\n  /**\n   * For `en-US`, `'EEEE, MMMM d, y, h:mm:ss a zzzz'`\n   * (Example: `Monday, June 15, 2015 at 9:03:01 AM GMT+01:00`)\n   */\n  Full\n}\n\n/**\n * Symbols that can be used to replace placeholders in number patterns.\n * Examples are based on `en-US` values.\n *\n * @see `getLocaleNumberSymbol()`\n * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n)\n *\n * @publicApi\n */\nexport enum NumberSymbol {\n  /**\n   * Decimal separator.\n   * For `en-US`, the dot character.\n   * Example : 2,345`.`67\n   */\n  Decimal,\n  /**\n   * Grouping separator, typically for thousands.\n   * For `en-US`, the comma character.\n   * Example: 2`,`345.67\n   */\n  Group,\n  /**\n   * List-item separator.\n   * Example: \"one, two, and three\"\n   */\n  List,\n  /**\n   * Sign for percentage (out of 100).\n   * Example: 23.4%\n   */\n  PercentSign,\n  /**\n   * Sign for positive numbers.\n   * Example: +23\n   */\n  PlusSign,\n  /**\n   * Sign for negative numbers.\n   * Example: -23\n   */\n  MinusSign,\n  /**\n   * Computer notation for exponential value (n times a power of 10).\n   * Example: 1.2E3\n   */\n  Exponential,\n  /**\n   * Human-readable format of exponential.\n   * Example: 1.2x103\n   */\n  SuperscriptingExponent,\n  /**\n   * Sign for permille (out of 1000).\n   * Example: 23.4‰\n   */\n  PerMille,\n  /**\n   * Infinity, can be used with plus and minus.\n   * Example: ∞, +∞, -∞\n   */\n  Infinity,\n  /**\n   * Not a number.\n   * Example: NaN\n   */\n  NaN,\n  /**\n   * Symbol used between time units.\n   * Example: 10:52\n   */\n  TimeSeparator,\n  /**\n   * Decimal separator for currency values (fallback to `Decimal`).\n   * Example: $2,345.67\n   */\n  CurrencyDecimal,\n  /**\n   * Group separator for currency values (fallback to `Group`).\n   * Example: $2,345.67\n   */\n  CurrencyGroup\n}\n\n/**\n * The value for each day of the week, based on the `en-US` locale\n *\n * @publicApi\n */\nexport enum WeekDay {\n  Sunday = 0,\n  Monday,\n  Tuesday,\n  Wednesday,\n  Thursday,\n  Friday,\n  Saturday\n}\n\n/**\n * Retrieves the locale ID from the currently loaded locale.\n * The loaded locale could be, for example, a global one rather than a regional one.\n * @param locale A locale code, such as `fr-FR`.\n * @returns The locale code. For example, `fr`.\n * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n)\n *\n * @publicApi\n */\nexport function getLocaleId(locale: string): string {\n  return findLocaleData(locale)[LocaleDataIndex.LocaleId];\n}\n\n/**\n * Retrieves day period strings for the given locale.\n *\n * @param locale A locale code for the locale format rules to use.\n * @param formStyle The required grammatical form.\n * @param width The required character width.\n * @returns An array of localized period strings. For example, `[AM, PM]` for `en-US`.\n * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n)\n *\n * @publicApi\n */\nexport function getLocaleDayPeriods(\n    locale: string, formStyle: FormStyle, width: TranslationWidth): [string, string] {\n  const data = findLocaleData(locale);\n  const amPmData = <[\n    string, string\n  ][][]>[data[LocaleDataIndex.DayPeriodsFormat], data[LocaleDataIndex.DayPeriodsStandalone]];\n  const amPm = getLastDefinedValue(amPmData, formStyle);\n  return getLastDefinedValue(amPm, width);\n}\n\n/**\n * Retrieves days of the week for the given locale, using the Gregorian calendar.\n *\n * @param locale A locale code for the locale format rules to use.\n * @param formStyle The required grammatical form.\n * @param width The required character width.\n * @returns An array of localized name strings.\n * For example,`[Sunday, Monday, ... Saturday]` for `en-US`.\n * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n)\n *\n * @publicApi\n */\nexport function getLocaleDayNames(\n    locale: string, formStyle: FormStyle, width: TranslationWidth): string[] {\n  const data = findLocaleData(locale);\n  const daysData =\n      <string[][][]>[data[LocaleDataIndex.DaysFormat], data[LocaleDataIndex.DaysStandalone]];\n  const days = getLastDefinedValue(daysData, formStyle);\n  return getLastDefinedValue(days, width);\n}\n\n/**\n * Retrieves months of the year for the given locale, using the Gregorian calendar.\n *\n * @param locale A locale code for the locale format rules to use.\n * @param formStyle The required grammatical form.\n * @param width The required character width.\n * @returns An array of localized name strings.\n * For example,  `[January, February, ...]` for `en-US`.\n * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n)\n *\n * @publicApi\n */\nexport function getLocaleMonthNames(\n    locale: string, formStyle: FormStyle, width: TranslationWidth): string[] {\n  const data = findLocaleData(locale);\n  const monthsData =\n      <string[][][]>[data[LocaleDataIndex.MonthsFormat], data[LocaleDataIndex.MonthsStandalone]];\n  const months = getLastDefinedValue(monthsData, formStyle);\n  return getLastDefinedValue(months, width);\n}\n\n/**\n * Retrieves Gregorian-calendar eras for the given locale.\n * @param locale A locale code for the locale format rules to use.\n * @param formStyle The required grammatical form.\n * @param width The required character width.\n\n * @returns An array of localized era strings.\n * For example, `[AD, BC]` for `en-US`.\n * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n)\n *\n * @publicApi\n */\nexport function getLocaleEraNames(locale: string, width: TranslationWidth): [string, string] {\n  const data = findLocaleData(locale);\n  const erasData = <[string, string][]>data[LocaleDataIndex.Eras];\n  return getLastDefinedValue(erasData, width);\n}\n\n/**\n * Retrieves the first day of the week for the given locale.\n *\n * @param locale A locale code for the locale format rules to use.\n * @returns A day index number, using the 0-based week-day index for `en-US`\n * (Sunday = 0, Monday = 1, ...).\n * For example, for `fr-FR`, returns 1 to indicate that the first day is Monday.\n * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n)\n *\n * @publicApi\n */\nexport function getLocaleFirstDayOfWeek(locale: string): WeekDay {\n  const data = findLocaleData(locale);\n  return data[LocaleDataIndex.FirstDayOfWeek];\n}\n\n/**\n * Range of week days that are considered the week-end for the given locale.\n *\n * @param locale A locale code for the locale format rules to use.\n * @returns The range of day values, `[startDay, endDay]`.\n * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n)\n *\n * @publicApi\n */\nexport function getLocaleWeekEndRange(locale: string): [WeekDay, WeekDay] {\n  const data = findLocaleData(locale);\n  return data[LocaleDataIndex.WeekendRange];\n}\n\n/**\n * Retrieves a localized date-value formating string.\n *\n * @param locale A locale code for the locale format rules to use.\n * @param width The format type.\n * @returns The localized formating string.\n * @see `FormatWidth`\n * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n)\n *\n * @publicApi\n */\nexport function getLocaleDateFormat(locale: string, width: FormatWidth): string {\n  const data = findLocaleData(locale);\n  return getLastDefinedValue(data[LocaleDataIndex.DateFormat], width);\n}\n\n/**\n * Retrieves a localized time-value formatting string.\n *\n * @param locale A locale code for the locale format rules to use.\n * @param width The format type.\n * @returns The localized formatting string.\n * @see `FormatWidth`\n * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n)\n\n * @publicApi\n */\nexport function getLocaleTimeFormat(locale: string, width: FormatWidth): string {\n  const data = findLocaleData(locale);\n  return getLastDefinedValue(data[LocaleDataIndex.TimeFormat], width);\n}\n\n/**\n * Retrieves a localized date-time formatting string.\n *\n * @param locale A locale code for the locale format rules to use.\n * @param width The format type.\n * @returns The localized formatting string.\n * @see `FormatWidth`\n * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n)\n *\n * @publicApi\n */\nexport function getLocaleDateTimeFormat(locale: string, width: FormatWidth): string {\n  const data = findLocaleData(locale);\n  const dateTimeFormatData = <string[]>data[LocaleDataIndex.DateTimeFormat];\n  return getLastDefinedValue(dateTimeFormatData, width);\n}\n\n/**\n * Retrieves a localized number symbol that can be used to replace placeholders in number formats.\n * @param locale The locale code.\n * @param symbol The symbol to localize.\n * @returns The character for the localized symbol.\n * @see `NumberSymbol`\n * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n)\n *\n * @publicApi\n */\nexport function getLocaleNumberSymbol(locale: string, symbol: NumberSymbol): string {\n  const data = findLocaleData(locale);\n  const res = data[LocaleDataIndex.NumberSymbols][symbol];\n  if (typeof res === 'undefined') {\n    if (symbol === NumberSymbol.CurrencyDecimal) {\n      return data[LocaleDataIndex.NumberSymbols][NumberSymbol.Decimal];\n    } else if (symbol === NumberSymbol.CurrencyGroup) {\n      return data[LocaleDataIndex.NumberSymbols][NumberSymbol.Group];\n    }\n  }\n  return res;\n}\n\n/**\n * Retrieves a number format for a given locale.\n *\n * Numbers are formatted using patterns, like `#,###.00`. For example, the pattern `#,###.00`\n * when used to format the number 12345.678 could result in \"12'345,678\". That would happen if the\n * grouping separator for your language is an apostrophe, and the decimal separator is a comma.\n *\n * <b>Important:</b> The characters `.` `,` `0` `#` (and others below) are special placeholders\n * that stand for the decimal separator, and so on, and are NOT real characters.\n * You must NOT \"translate\" the placeholders. For example, don't change `.` to `,` even though in\n * your language the decimal point is written with a comma. The symbols should be replaced by the\n * local equivalents, using the appropriate `NumberSymbol` for your language.\n *\n * Here are the special characters used in number patterns:\n *\n * | Symbol | Meaning |\n * |--------|---------|\n * | . | Replaced automatically by the character used for the decimal point. |\n * | , | Replaced by the \"grouping\" (thousands) separator. |\n * | 0 | Replaced by a digit (or zero if there aren't enough digits). |\n * | # | Replaced by a digit (or nothing if there aren't enough). |\n * | ¤ | Replaced by a currency symbol, such as $ or USD. |\n * | % | Marks a percent format. The % symbol may change position, but must be retained. |\n * | E | Marks a scientific format. The E symbol may change position, but must be retained. |\n * | ' | Special characters used as literal characters are quoted with ASCII single quotes. |\n *\n * @param locale A locale code for the locale format rules to use.\n * @param type The type of numeric value to be formatted (such as `Decimal` or `Currency`.)\n * @returns The localized format string.\n * @see `NumberFormatStyle`\n * @see [CLDR website](http://cldr.unicode.org/translation/number-patterns)\n * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n)\n *\n * @publicApi\n */\nexport function getLocaleNumberFormat(locale: string, type: NumberFormatStyle): string {\n  const data = findLocaleData(locale);\n  return data[LocaleDataIndex.NumberFormats][type];\n}\n\n/**\n * Retrieves the symbol used to represent the currency for the main country\n * corresponding to a given local