[6a3a178] | 1 | /**
|
---|
| 2 | * @license
|
---|
| 3 | * Copyright Google LLC All Rights Reserved.
|
---|
| 4 | *
|
---|
| 5 | * Use of this source code is governed by an MIT-style license that can be
|
---|
| 6 | * found in the LICENSE file at https://angular.io/license
|
---|
| 7 | */
|
---|
| 8 | import { ɵfindLocaleData, ɵgetLocaleCurrencyCode, ɵgetLocalePluralCase, ɵLocaleDataIndex } from '@angular/core';
|
---|
| 9 | import { CURRENCIES_EN } from './currencies';
|
---|
| 10 | /**
|
---|
| 11 | * Format styles that can be used to represent numbers.
|
---|
| 12 | * @see `getLocaleNumberFormat()`.
|
---|
| 13 | * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n-overview)
|
---|
| 14 | *
|
---|
| 15 | * @publicApi
|
---|
| 16 | */
|
---|
| 17 | export var NumberFormatStyle;
|
---|
| 18 | (function (NumberFormatStyle) {
|
---|
| 19 | NumberFormatStyle[NumberFormatStyle["Decimal"] = 0] = "Decimal";
|
---|
| 20 | NumberFormatStyle[NumberFormatStyle["Percent"] = 1] = "Percent";
|
---|
| 21 | NumberFormatStyle[NumberFormatStyle["Currency"] = 2] = "Currency";
|
---|
| 22 | NumberFormatStyle[NumberFormatStyle["Scientific"] = 3] = "Scientific";
|
---|
| 23 | })(NumberFormatStyle || (NumberFormatStyle = {}));
|
---|
| 24 | /**
|
---|
| 25 | * Plurality cases used for translating plurals to different languages.
|
---|
| 26 | *
|
---|
| 27 | * @see `NgPlural`
|
---|
| 28 | * @see `NgPluralCase`
|
---|
| 29 | * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n-overview)
|
---|
| 30 | *
|
---|
| 31 | * @publicApi
|
---|
| 32 | */
|
---|
| 33 | export var Plural;
|
---|
| 34 | (function (Plural) {
|
---|
| 35 | Plural[Plural["Zero"] = 0] = "Zero";
|
---|
| 36 | Plural[Plural["One"] = 1] = "One";
|
---|
| 37 | Plural[Plural["Two"] = 2] = "Two";
|
---|
| 38 | Plural[Plural["Few"] = 3] = "Few";
|
---|
| 39 | Plural[Plural["Many"] = 4] = "Many";
|
---|
| 40 | Plural[Plural["Other"] = 5] = "Other";
|
---|
| 41 | })(Plural || (Plural = {}));
|
---|
| 42 | /**
|
---|
| 43 | * Context-dependant translation forms for strings.
|
---|
| 44 | * Typically the standalone version is for the nominative form of the word,
|
---|
| 45 | * and the format version is used for the genitive case.
|
---|
| 46 | * @see [CLDR website](http://cldr.unicode.org/translation/date-time-1/date-time#TOC-Standalone-vs.-Format-Styles)
|
---|
| 47 | * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n-overview)
|
---|
| 48 | *
|
---|
| 49 | * @publicApi
|
---|
| 50 | */
|
---|
| 51 | export var FormStyle;
|
---|
| 52 | (function (FormStyle) {
|
---|
| 53 | FormStyle[FormStyle["Format"] = 0] = "Format";
|
---|
| 54 | FormStyle[FormStyle["Standalone"] = 1] = "Standalone";
|
---|
| 55 | })(FormStyle || (FormStyle = {}));
|
---|
| 56 | /**
|
---|
| 57 | * String widths available for translations.
|
---|
| 58 | * The specific character widths are locale-specific.
|
---|
| 59 | * Examples are given for the word "Sunday" in English.
|
---|
| 60 | *
|
---|
| 61 | * @publicApi
|
---|
| 62 | */
|
---|
| 63 | export var TranslationWidth;
|
---|
| 64 | (function (TranslationWidth) {
|
---|
| 65 | /** 1 character for `en-US`. For example: 'S' */
|
---|
| 66 | TranslationWidth[TranslationWidth["Narrow"] = 0] = "Narrow";
|
---|
| 67 | /** 3 characters for `en-US`. For example: 'Sun' */
|
---|
| 68 | TranslationWidth[TranslationWidth["Abbreviated"] = 1] = "Abbreviated";
|
---|
| 69 | /** Full length for `en-US`. For example: "Sunday" */
|
---|
| 70 | TranslationWidth[TranslationWidth["Wide"] = 2] = "Wide";
|
---|
| 71 | /** 2 characters for `en-US`, For example: "Su" */
|
---|
| 72 | TranslationWidth[TranslationWidth["Short"] = 3] = "Short";
|
---|
| 73 | })(TranslationWidth || (TranslationWidth = {}));
|
---|
| 74 | /**
|
---|
| 75 | * String widths available for date-time formats.
|
---|
| 76 | * The specific character widths are locale-specific.
|
---|
| 77 | * Examples are given for `en-US`.
|
---|
| 78 | *
|
---|
| 79 | * @see `getLocaleDateFormat()`
|
---|
| 80 | * @see `getLocaleTimeFormat()`
|
---|
| 81 | * @see `getLocaleDateTimeFormat()`
|
---|
| 82 | * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n-overview)
|
---|
| 83 | * @publicApi
|
---|
| 84 | */
|
---|
| 85 | export var FormatWidth;
|
---|
| 86 | (function (FormatWidth) {
|
---|
| 87 | /**
|
---|
| 88 | * For `en-US`, 'M/d/yy, h:mm a'`
|
---|
| 89 | * (Example: `6/15/15, 9:03 AM`)
|
---|
| 90 | */
|
---|
| 91 | FormatWidth[FormatWidth["Short"] = 0] = "Short";
|
---|
| 92 | /**
|
---|
| 93 | * For `en-US`, `'MMM d, y, h:mm:ss a'`
|
---|
| 94 | * (Example: `Jun 15, 2015, 9:03:01 AM`)
|
---|
| 95 | */
|
---|
| 96 | FormatWidth[FormatWidth["Medium"] = 1] = "Medium";
|
---|
| 97 | /**
|
---|
| 98 | * For `en-US`, `'MMMM d, y, h:mm:ss a z'`
|
---|
| 99 | * (Example: `June 15, 2015 at 9:03:01 AM GMT+1`)
|
---|
| 100 | */
|
---|
| 101 | FormatWidth[FormatWidth["Long"] = 2] = "Long";
|
---|
| 102 | /**
|
---|
| 103 | * For `en-US`, `'EEEE, MMMM d, y, h:mm:ss a zzzz'`
|
---|
| 104 | * (Example: `Monday, June 15, 2015 at 9:03:01 AM GMT+01:00`)
|
---|
| 105 | */
|
---|
| 106 | FormatWidth[FormatWidth["Full"] = 3] = "Full";
|
---|
| 107 | })(FormatWidth || (FormatWidth = {}));
|
---|
| 108 | /**
|
---|
| 109 | * Symbols that can be used to replace placeholders in number patterns.
|
---|
| 110 | * Examples are based on `en-US` values.
|
---|
| 111 | *
|
---|
| 112 | * @see `getLocaleNumberSymbol()`
|
---|
| 113 | * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n-overview)
|
---|
| 114 | *
|
---|
| 115 | * @publicApi
|
---|
| 116 | */
|
---|
| 117 | export var NumberSymbol;
|
---|
| 118 | (function (NumberSymbol) {
|
---|
| 119 | /**
|
---|
| 120 | * Decimal separator.
|
---|
| 121 | * For `en-US`, the dot character.
|
---|
| 122 | * Example: 2,345`.`67
|
---|
| 123 | */
|
---|
| 124 | NumberSymbol[NumberSymbol["Decimal"] = 0] = "Decimal";
|
---|
| 125 | /**
|
---|
| 126 | * Grouping separator, typically for thousands.
|
---|
| 127 | * For `en-US`, the comma character.
|
---|
| 128 | * Example: 2`,`345.67
|
---|
| 129 | */
|
---|
| 130 | NumberSymbol[NumberSymbol["Group"] = 1] = "Group";
|
---|
| 131 | /**
|
---|
| 132 | * List-item separator.
|
---|
| 133 | * Example: "one, two, and three"
|
---|
| 134 | */
|
---|
| 135 | NumberSymbol[NumberSymbol["List"] = 2] = "List";
|
---|
| 136 | /**
|
---|
| 137 | * Sign for percentage (out of 100).
|
---|
| 138 | * Example: 23.4%
|
---|
| 139 | */
|
---|
| 140 | NumberSymbol[NumberSymbol["PercentSign"] = 3] = "PercentSign";
|
---|
| 141 | /**
|
---|
| 142 | * Sign for positive numbers.
|
---|
| 143 | * Example: +23
|
---|
| 144 | */
|
---|
| 145 | NumberSymbol[NumberSymbol["PlusSign"] = 4] = "PlusSign";
|
---|
| 146 | /**
|
---|
| 147 | * Sign for negative numbers.
|
---|
| 148 | * Example: -23
|
---|
| 149 | */
|
---|
| 150 | NumberSymbol[NumberSymbol["MinusSign"] = 5] = "MinusSign";
|
---|
| 151 | /**
|
---|
| 152 | * Computer notation for exponential value (n times a power of 10).
|
---|
| 153 | * Example: 1.2E3
|
---|
| 154 | */
|
---|
| 155 | NumberSymbol[NumberSymbol["Exponential"] = 6] = "Exponential";
|
---|
| 156 | /**
|
---|
| 157 | * Human-readable format of exponential.
|
---|
| 158 | * Example: 1.2x103
|
---|
| 159 | */
|
---|
| 160 | NumberSymbol[NumberSymbol["SuperscriptingExponent"] = 7] = "SuperscriptingExponent";
|
---|
| 161 | /**
|
---|
| 162 | * Sign for permille (out of 1000).
|
---|
| 163 | * Example: 23.4‰
|
---|
| 164 | */
|
---|
| 165 | NumberSymbol[NumberSymbol["PerMille"] = 8] = "PerMille";
|
---|
| 166 | /**
|
---|
| 167 | * Infinity, can be used with plus and minus.
|
---|
| 168 | * Example: ∞, +∞, -∞
|
---|
| 169 | */
|
---|
| 170 | NumberSymbol[NumberSymbol["Infinity"] = 9] = "Infinity";
|
---|
| 171 | /**
|
---|
| 172 | * Not a number.
|
---|
| 173 | * Example: NaN
|
---|
| 174 | */
|
---|
| 175 | NumberSymbol[NumberSymbol["NaN"] = 10] = "NaN";
|
---|
| 176 | /**
|
---|
| 177 | * Symbol used between time units.
|
---|
| 178 | * Example: 10:52
|
---|
| 179 | */
|
---|
| 180 | NumberSymbol[NumberSymbol["TimeSeparator"] = 11] = "TimeSeparator";
|
---|
| 181 | /**
|
---|
| 182 | * Decimal separator for currency values (fallback to `Decimal`).
|
---|
| 183 | * Example: $2,345.67
|
---|
| 184 | */
|
---|
| 185 | NumberSymbol[NumberSymbol["CurrencyDecimal"] = 12] = "CurrencyDecimal";
|
---|
| 186 | /**
|
---|
| 187 | * Group separator for currency values (fallback to `Group`).
|
---|
| 188 | * Example: $2,345.67
|
---|
| 189 | */
|
---|
| 190 | NumberSymbol[NumberSymbol["CurrencyGroup"] = 13] = "CurrencyGroup";
|
---|
| 191 | })(NumberSymbol || (NumberSymbol = {}));
|
---|
| 192 | /**
|
---|
| 193 | * The value for each day of the week, based on the `en-US` locale
|
---|
| 194 | *
|
---|
| 195 | * @publicApi
|
---|
| 196 | */
|
---|
| 197 | export var WeekDay;
|
---|
| 198 | (function (WeekDay) {
|
---|
| 199 | WeekDay[WeekDay["Sunday"] = 0] = "Sunday";
|
---|
| 200 | WeekDay[WeekDay["Monday"] = 1] = "Monday";
|
---|
| 201 | WeekDay[WeekDay["Tuesday"] = 2] = "Tuesday";
|
---|
| 202 | WeekDay[WeekDay["Wednesday"] = 3] = "Wednesday";
|
---|
| 203 | WeekDay[WeekDay["Thursday"] = 4] = "Thursday";
|
---|
| 204 | WeekDay[WeekDay["Friday"] = 5] = "Friday";
|
---|
| 205 | WeekDay[WeekDay["Saturday"] = 6] = "Saturday";
|
---|
| 206 | })(WeekDay || (WeekDay = {}));
|
---|
| 207 | /**
|
---|
| 208 | * Retrieves the locale ID from the currently loaded locale.
|
---|
| 209 | * The loaded locale could be, for example, a global one rather than a regional one.
|
---|
| 210 | * @param locale A locale code, such as `fr-FR`.
|
---|
| 211 | * @returns The locale code. For example, `fr`.
|
---|
| 212 | * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n-overview)
|
---|
| 213 | *
|
---|
| 214 | * @publicApi
|
---|
| 215 | */
|
---|
| 216 | export function getLocaleId(locale) {
|
---|
| 217 | return ɵfindLocaleData(locale)[ɵLocaleDataIndex.LocaleId];
|
---|
| 218 | }
|
---|
| 219 | /**
|
---|
| 220 | * Retrieves day period strings for the given locale.
|
---|
| 221 | *
|
---|
| 222 | * @param locale A locale code for the locale format rules to use.
|
---|
| 223 | * @param formStyle The required grammatical form.
|
---|
| 224 | * @param width The required character width.
|
---|
| 225 | * @returns An array of localized period strings. For example, `[AM, PM]` for `en-US`.
|
---|
| 226 | * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n-overview)
|
---|
| 227 | *
|
---|
| 228 | * @publicApi
|
---|
| 229 | */
|
---|
| 230 | export function getLocaleDayPeriods(locale, formStyle, width) {
|
---|
| 231 | const data = ɵfindLocaleData(locale);
|
---|
| 232 | const amPmData = [
|
---|
| 233 | data[ɵLocaleDataIndex.DayPeriodsFormat], data[ɵLocaleDataIndex.DayPeriodsStandalone]
|
---|
| 234 | ];
|
---|
| 235 | const amPm = getLastDefinedValue(amPmData, formStyle);
|
---|
| 236 | return getLastDefinedValue(amPm, width);
|
---|
| 237 | }
|
---|
| 238 | /**
|
---|
| 239 | * Retrieves days of the week for the given locale, using the Gregorian calendar.
|
---|
| 240 | *
|
---|
| 241 | * @param locale A locale code for the locale format rules to use.
|
---|
| 242 | * @param formStyle The required grammatical form.
|
---|
| 243 | * @param width The required character width.
|
---|
| 244 | * @returns An array of localized name strings.
|
---|
| 245 | * For example,`[Sunday, Monday, ... Saturday]` for `en-US`.
|
---|
| 246 | * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n-overview)
|
---|
| 247 | *
|
---|
| 248 | * @publicApi
|
---|
| 249 | */
|
---|
| 250 | export function getLocaleDayNames(locale, formStyle, width) {
|
---|
| 251 | const data = ɵfindLocaleData(locale);
|
---|
| 252 | const daysData = [data[ɵLocaleDataIndex.DaysFormat], data[ɵLocaleDataIndex.DaysStandalone]];
|
---|
| 253 | const days = getLastDefinedValue(daysData, formStyle);
|
---|
| 254 | return getLastDefinedValue(days, width);
|
---|
| 255 | }
|
---|
| 256 | /**
|
---|
| 257 | * Retrieves months of the year for the given locale, using the Gregorian calendar.
|
---|
| 258 | *
|
---|
| 259 | * @param locale A locale code for the locale format rules to use.
|
---|
| 260 | * @param formStyle The required grammatical form.
|
---|
| 261 | * @param width The required character width.
|
---|
| 262 | * @returns An array of localized name strings.
|
---|
| 263 | * For example, `[January, February, ...]` for `en-US`.
|
---|
| 264 | * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n-overview)
|
---|
| 265 | *
|
---|
| 266 | * @publicApi
|
---|
| 267 | */
|
---|
| 268 | export function getLocaleMonthNames(locale, formStyle, width) {
|
---|
| 269 | const data = ɵfindLocaleData(locale);
|
---|
| 270 | const monthsData = [data[ɵLocaleDataIndex.MonthsFormat], data[ɵLocaleDataIndex.MonthsStandalone]];
|
---|
| 271 | const months = getLastDefinedValue(monthsData, formStyle);
|
---|
| 272 | return getLastDefinedValue(months, width);
|
---|
| 273 | }
|
---|
| 274 | /**
|
---|
| 275 | * Retrieves Gregorian-calendar eras for the given locale.
|
---|
| 276 | * @param locale A locale code for the locale format rules to use.
|
---|
| 277 | * @param width The required character width.
|
---|
| 278 |
|
---|
| 279 | * @returns An array of localized era strings.
|
---|
| 280 | * For example, `[AD, BC]` for `en-US`.
|
---|
| 281 | * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n-overview)
|
---|
| 282 | *
|
---|
| 283 | * @publicApi
|
---|
| 284 | */
|
---|
| 285 | export function getLocaleEraNames(locale, width) {
|
---|
| 286 | const data = ɵfindLocaleData(locale);
|
---|
| 287 | const erasData = data[ɵLocaleDataIndex.Eras];
|
---|
| 288 | return getLastDefinedValue(erasData, width);
|
---|
| 289 | }
|
---|
| 290 | /**
|
---|
| 291 | * Retrieves the first day of the week for the given locale.
|
---|
| 292 | *
|
---|
| 293 | * @param locale A locale code for the locale format rules to use.
|
---|
| 294 | * @returns A day index number, using the 0-based week-day index for `en-US`
|
---|
| 295 | * (Sunday = 0, Monday = 1, ...).
|
---|
| 296 | * For example, for `fr-FR`, returns 1 to indicate that the first day is Monday.
|
---|
| 297 | * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n-overview)
|
---|
| 298 | *
|
---|
| 299 | * @publicApi
|
---|
| 300 | */
|
---|
| 301 | export function getLocaleFirstDayOfWeek(locale) {
|
---|
| 302 | const data = ɵfindLocaleData(locale);
|
---|
| 303 | return data[ɵLocaleDataIndex.FirstDayOfWeek];
|
---|
| 304 | }
|
---|
| 305 | /**
|
---|
| 306 | * Range of week days that are considered the week-end for the given locale.
|
---|
| 307 | *
|
---|
| 308 | * @param locale A locale code for the locale format rules to use.
|
---|
| 309 | * @returns The range of day values, `[startDay, endDay]`.
|
---|
| 310 | * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n-overview)
|
---|
| 311 | *
|
---|
| 312 | * @publicApi
|
---|
| 313 | */
|
---|
| 314 | export function getLocaleWeekEndRange(locale) {
|
---|
| 315 | const data = ɵfindLocaleData(locale);
|
---|
| 316 | return data[ɵLocaleDataIndex.WeekendRange];
|
---|
| 317 | }
|
---|
| 318 | /**
|
---|
| 319 | * Retrieves a localized date-value formating string.
|
---|
| 320 | *
|
---|
| 321 | * @param locale A locale code for the locale format rules to use.
|
---|
| 322 | * @param width The format type.
|
---|
| 323 | * @returns The localized formating string.
|
---|
| 324 | * @see `FormatWidth`
|
---|
| 325 | * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n-overview)
|
---|
| 326 | *
|
---|
| 327 | * @publicApi
|
---|
| 328 | */
|
---|
| 329 | export function getLocaleDateFormat(locale, width) {
|
---|
| 330 | const data = ɵfindLocaleData(locale);
|
---|
| 331 | return getLastDefinedValue(data[ɵLocaleDataIndex.DateFormat], width);
|
---|
| 332 | }
|
---|
| 333 | /**
|
---|
| 334 | * Retrieves a localized time-value formatting string.
|
---|
| 335 | *
|
---|
| 336 | * @param locale A locale code for the locale format rules to use.
|
---|
| 337 | * @param width The format type.
|
---|
| 338 | * @returns The localized formatting string.
|
---|
| 339 | * @see `FormatWidth`
|
---|
| 340 | * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n-overview)
|
---|
| 341 |
|
---|
| 342 | * @publicApi
|
---|
| 343 | */
|
---|
| 344 | export function getLocaleTimeFormat(locale, width) {
|
---|
| 345 | const data = ɵfindLocaleData(locale);
|
---|
| 346 | return getLastDefinedValue(data[ɵLocaleDataIndex.TimeFormat], width);
|
---|
| 347 | }
|
---|
| 348 | /**
|
---|
| 349 | * Retrieves a localized date-time formatting string.
|
---|
| 350 | *
|
---|
| 351 | * @param locale A locale code for the locale format rules to use.
|
---|
| 352 | * @param width The format type.
|
---|
| 353 | * @returns The localized formatting string.
|
---|
| 354 | * @see `FormatWidth`
|
---|
| 355 | * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n-overview)
|
---|
| 356 | *
|
---|
| 357 | * @publicApi
|
---|
| 358 | */
|
---|
| 359 | export function getLocaleDateTimeFormat(locale, width) {
|
---|
| 360 | const data = ɵfindLocaleData(locale);
|
---|
| 361 | const dateTimeFormatData = data[ɵLocaleDataIndex.DateTimeFormat];
|
---|
| 362 | return getLastDefinedValue(dateTimeFormatData, width);
|
---|
| 363 | }
|
---|
| 364 | /**
|
---|
| 365 | * Retrieves a localized number symbol that can be used to replace placeholders in number formats.
|
---|
| 366 | * @param locale The locale code.
|
---|
| 367 | * @param symbol The symbol to localize.
|
---|
| 368 | * @returns The character for the localized symbol.
|
---|
| 369 | * @see `NumberSymbol`
|
---|
| 370 | * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n-overview)
|
---|
| 371 | *
|
---|
| 372 | * @publicApi
|
---|
| 373 | */
|
---|
| 374 | export function getLocaleNumberSymbol(locale, symbol) {
|
---|
| 375 | const data = ɵfindLocaleData(locale);
|
---|
| 376 | const res = data[ɵLocaleDataIndex.NumberSymbols][symbol];
|
---|
| 377 | if (typeof res === 'undefined') {
|
---|
| 378 | if (symbol === NumberSymbol.CurrencyDecimal) {
|
---|
| 379 | return data[ɵLocaleDataIndex.NumberSymbols][NumberSymbol.Decimal];
|
---|
| 380 | }
|
---|
| 381 | else if (symbol === NumberSymbol.CurrencyGroup) {
|
---|
| 382 | return data[ɵLocaleDataIndex.NumberSymbols][NumberSymbol.Group];
|
---|
| 383 | }
|
---|
| 384 | }
|
---|
| 385 | return res;
|
---|
| 386 | }
|
---|
| 387 | /**
|
---|
| 388 | * Retrieves a number format for a given locale.
|
---|
| 389 | *
|
---|
| 390 | * Numbers are formatted using patterns, like `#,###.00`. For example, the pattern `#,###.00`
|
---|
| 391 | * when used to format the number 12345.678 could result in "12'345,678". That would happen if the
|
---|
| 392 | * grouping separator for your language is an apostrophe, and the decimal separator is a comma.
|
---|
| 393 | *
|
---|
| 394 | * <b>Important:</b> The characters `.` `,` `0` `#` (and others below) are special placeholders
|
---|
| 395 | * that stand for the decimal separator, and so on, and are NOT real characters.
|
---|
| 396 | * You must NOT "translate" the placeholders. For example, don't change `.` to `,` even though in
|
---|
| 397 | * your language the decimal point is written with a comma. The symbols should be replaced by the
|
---|
| 398 | * local equivalents, using the appropriate `NumberSymbol` for your language.
|
---|
| 399 | *
|
---|
| 400 | * Here are the special characters used in number patterns:
|
---|
| 401 | *
|
---|
| 402 | * | Symbol | Meaning |
|
---|
| 403 | * |--------|---------|
|
---|
| 404 | * | . | Replaced automatically by the character used for the decimal point. |
|
---|
| 405 | * | , | Replaced by the "grouping" (thousands) separator. |
|
---|
| 406 | * | 0 | Replaced by a digit (or zero if there aren't enough digits). |
|
---|
| 407 | * | # | Replaced by a digit (or nothing if there aren't enough). |
|
---|
| 408 | * | ¤ | Replaced by a currency symbol, such as $ or USD. |
|
---|
| 409 | * | % | Marks a percent format. The % symbol may change position, but must be retained. |
|
---|
| 410 | * | E | Marks a scientific format. The E symbol may change position, but must be retained. |
|
---|
| 411 | * | ' | Special characters used as literal characters are quoted with ASCII single quotes. |
|
---|
| 412 | *
|
---|
| 413 | * @param locale A locale code for the locale format rules to use.
|
---|
| 414 | * @param type The type of numeric value to be formatted (such as `Decimal` or `Currency`.)
|
---|
| 415 | * @returns The localized format string.
|
---|
| 416 | * @see `NumberFormatStyle`
|
---|
| 417 | * @see [CLDR website](http://cldr.unicode.org/translation/number-patterns)
|
---|
| 418 | * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n-overview)
|
---|
| 419 | *
|
---|
| 420 | * @publicApi
|
---|
| 421 | */
|
---|
| 422 | export function getLocaleNumberFormat(locale, type) {
|
---|
| 423 | const data = ɵfindLocaleData(locale);
|
---|
| 424 | return data[ɵLocaleDataIndex.NumberFormats][type];
|
---|
| 425 | }
|
---|
| 426 | /**
|
---|
| 427 | * Retrieves the symbol used to represent the currency for the main country
|
---|
| 428 | * corresponding to a given locale. For example, '$' for `en-US`.
|
---|
| 429 | *
|
---|
| 430 | * @param locale A locale code for the locale format rules to use.
|
---|
| 431 | * @returns The localized symbol character,
|
---|
| 432 | * or `null` if the main country cannot be determined.
|
---|
| 433 | * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n-overview)
|
---|
| 434 | *
|
---|
| 435 | * @publicApi
|
---|
| 436 | */
|
---|
| 437 | export function getLocaleCurrencySymbol(locale) {
|
---|
| 438 | const data = ɵfindLocaleData(locale);
|
---|
| 439 | return data[ɵLocaleDataIndex.CurrencySymbol] || null;
|
---|
| 440 | }
|
---|
| 441 | /**
|
---|
| 442 | * Retrieves the name of the currency for the main country corresponding
|
---|
| 443 | * to a given locale. For example, 'US Dollar' for `en-US`.
|
---|
| 444 | * @param locale A locale code for the locale format rules to use.
|
---|
| 445 | * @returns The currency name,
|
---|
| 446 | * or `null` if the main country cannot be determined.
|
---|
| 447 | * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n-overview)
|
---|
| 448 | *
|
---|
| 449 | * @publicApi
|
---|
| 450 | */
|
---|
| 451 | export function getLocaleCurrencyName(locale) {
|
---|
| 452 | const data = ɵfindLocaleData(locale);
|
---|
| 453 | return data[ɵLocaleDataIndex.CurrencyName] || null;
|
---|
| 454 | }
|
---|
| 455 | /**
|
---|
| 456 | * Retrieves the default currency code for the given locale.
|
---|
| 457 | *
|
---|
| 458 | * The default is defined as the first currency which is still in use.
|
---|
| 459 | *
|
---|
| 460 | * @param locale The code of the locale whose currency code we want.
|
---|
| 461 | * @returns The code of the default currency for the given locale.
|
---|
| 462 | *
|
---|
| 463 | * @publicApi
|
---|
| 464 | */
|
---|
| 465 | export function getLocaleCurrencyCode(locale) {
|
---|
| 466 | return ɵgetLocaleCurrencyCode(locale);
|
---|
| 467 | }
|
---|
| 468 | /**
|
---|
| 469 | * Retrieves the currency values for a given locale.
|
---|
| 470 | * @param locale A locale code for the locale format rules to use.
|
---|
| 471 | * @returns The currency values.
|
---|
| 472 | * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n-overview)
|
---|
| 473 | */
|
---|
| 474 | function getLocaleCurrencies(locale) {
|
---|
| 475 | const data = ɵfindLocaleData(locale);
|
---|
| 476 | return data[ɵLocaleDataIndex.Currencies];
|
---|
| 477 | }
|
---|
| 478 | /**
|
---|
| 479 | * @alias core/ɵgetLocalePluralCase
|
---|
| 480 | * @publicApi
|
---|
| 481 | */
|
---|
| 482 | export const getLocalePluralCase = ɵgetLocalePluralCase;
|
---|
| 483 | function checkFullData(data) {
|
---|
| 484 | if (!data[ɵLocaleDataIndex.ExtraData]) {
|
---|
| 485 | throw new Error(`Missing extra locale data for the locale "${data[ɵLocaleDataIndex
|
---|
| 486 | .LocaleId]}". Use "registerLocaleData" to load new data. See the "I18n guide" on angular.io to know more.`);
|
---|
| 487 | }
|
---|
| 488 | }
|
---|
| 489 | /**
|
---|
| 490 | * Retrieves locale-specific rules used to determine which day period to use
|
---|
| 491 | * when more than one period is defined for a locale.
|
---|
| 492 | *
|
---|
| 493 | * There is a rule for each defined day period. The
|
---|
| 494 | * first rule is applied to the first day period and so on.
|
---|
| 495 | * Fall back to AM/PM when no rules are available.
|
---|
| 496 | *
|
---|
| 497 | * A rule can specify a period as time range, or as a single time value.
|
---|
| 498 | *
|
---|
| 499 | * This functionality is only available when you have loaded the full locale data.
|
---|
| 500 | * See the ["I18n guide"](guide/i18n-common-format-data-locale).
|
---|
| 501 | *
|
---|
| 502 | * @param locale A locale code for the locale format rules to use.
|
---|
| 503 | * @returns The rules for the locale, a single time value or array of *from-time, to-time*,
|
---|
| 504 | * or null if no periods are available.
|
---|
| 505 | *
|
---|
| 506 | * @see `getLocaleExtraDayPeriods()`
|
---|
| 507 | * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n-overview)
|
---|
| 508 | *
|
---|
| 509 | * @publicApi
|
---|
| 510 | */
|
---|
| 511 | export function getLocaleExtraDayPeriodRules(locale) {
|
---|
| 512 | const data = ɵfindLocaleData(locale);
|
---|
| 513 | checkFullData(data);
|
---|
| 514 | const rules = data[ɵLocaleDataIndex.ExtraData][2 /* ExtraDayPeriodsRules */] || [];
|
---|
| 515 | return rules.map((rule) => {
|
---|
| 516 | if (typeof rule === 'string') {
|
---|
| 517 | return extractTime(rule);
|
---|
| 518 | }
|
---|
| 519 | return [extractTime(rule[0]), extractTime(rule[1])];
|
---|
| 520 | });
|
---|
| 521 | }
|
---|
| 522 | /**
|
---|
| 523 | * Retrieves locale-specific day periods, which indicate roughly how a day is broken up
|
---|
| 524 | * in different languages.
|
---|
| 525 | * For example, for `en-US`, periods are morning, noon, afternoon, evening, and midnight.
|
---|
| 526 | *
|
---|
| 527 | * This functionality is only available when you have loaded the full locale data.
|
---|
| 528 | * See the ["I18n guide"](guide/i18n-common-format-data-locale).
|
---|
| 529 | *
|
---|
| 530 | * @param locale A locale code for the locale format rules to use.
|
---|
| 531 | * @param formStyle The required grammatical form.
|
---|
| 532 | * @param width The required character width.
|
---|
| 533 | * @returns The translated day-period strings.
|
---|
| 534 | * @see `getLocaleExtraDayPeriodRules()`
|
---|
| 535 | * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n-overview)
|
---|
| 536 | *
|
---|
| 537 | * @publicApi
|
---|
| 538 | */
|
---|
| 539 | export function getLocaleExtraDayPeriods(locale, formStyle, width) {
|
---|
| 540 | const data = ɵfindLocaleData(locale);
|
---|
| 541 | checkFullData(data);
|
---|
| 542 | const dayPeriodsData = [
|
---|
| 543 | data[ɵLocaleDataIndex.ExtraData][0 /* ExtraDayPeriodFormats */],
|
---|
| 544 | data[ɵLocaleDataIndex.ExtraData][1 /* ExtraDayPeriodStandalone */]
|
---|
| 545 | ];
|
---|
| 546 | const dayPeriods = getLastDefinedValue(dayPeriodsData, formStyle) || [];
|
---|
| 547 | return getLastDefinedValue(dayPeriods, width) || [];
|
---|
| 548 | }
|
---|
| 549 | /**
|
---|
| 550 | * Retrieves the writing direction of a specified locale
|
---|
| 551 | * @param locale A locale code for the locale format rules to use.
|
---|
| 552 | * @publicApi
|
---|
| 553 | * @returns 'rtl' or 'ltr'
|
---|
| 554 | * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n-overview)
|
---|
| 555 | */
|
---|
| 556 | export function getLocaleDirection(locale) {
|
---|
| 557 | const data = ɵfindLocaleData(locale);
|
---|
| 558 | return data[ɵLocaleDataIndex.Directionality];
|
---|
| 559 | }
|
---|
| 560 | /**
|
---|
| 561 | * Retrieves the first value that is defined in an array, going backwards from an index position.
|
---|
| 562 | *
|
---|
| 563 | * To avoid repeating the same data (as when the "format" and "standalone" forms are the same)
|
---|
| 564 | * add the first value to the locale data arrays, and add other values only if they are different.
|
---|
| 565 | *
|
---|
| 566 | * @param data The data array to retrieve from.
|
---|
| 567 | * @param index A 0-based index into the array to start from.
|
---|
| 568 | * @returns The value immediately before the given index position.
|
---|
| 569 | * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n-overview)
|
---|
| 570 | *
|
---|
| 571 | * @publicApi
|
---|
| 572 | */
|
---|
| 573 | function getLastDefinedValue(data, index) {
|
---|
| 574 | for (let i = index; i > -1; i--) {
|
---|
| 575 | if (typeof data[i] !== 'undefined') {
|
---|
| 576 | return data[i];
|
---|
| 577 | }
|
---|
| 578 | }
|
---|
| 579 | throw new Error('Locale data API: locale data undefined');
|
---|
| 580 | }
|
---|
| 581 | /**
|
---|
| 582 | * Extracts the hours and minutes from a string like "15:45"
|
---|
| 583 | */
|
---|
| 584 | function extractTime(time) {
|
---|
| 585 | const [h, m] = time.split(':');
|
---|
| 586 | return { hours: +h, minutes: +m };
|
---|
| 587 | }
|
---|
| 588 | /**
|
---|
| 589 | * Retrieves the currency symbol for a given currency code.
|
---|
| 590 | *
|
---|
| 591 | * For example, for the default `en-US` locale, the code `USD` can
|
---|
| 592 | * be represented by the narrow symbol `$` or the wide symbol `US$`.
|
---|
| 593 | *
|
---|
| 594 | * @param code The currency code.
|
---|
| 595 | * @param format The format, `wide` or `narrow`.
|
---|
| 596 | * @param locale A locale code for the locale format rules to use.
|
---|
| 597 | *
|
---|
| 598 | * @returns The symbol, or the currency code if no symbol is available.
|
---|
| 599 | * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n-overview)
|
---|
| 600 | *
|
---|
| 601 | * @publicApi
|
---|
| 602 | */
|
---|
| 603 | export function getCurrencySymbol(code, format, locale = 'en') {
|
---|
| 604 | const currency = getLocaleCurrencies(locale)[code] || CURRENCIES_EN[code] || [];
|
---|
| 605 | const symbolNarrow = currency[1 /* SymbolNarrow */];
|
---|
| 606 | if (format === 'narrow' && typeof symbolNarrow === 'string') {
|
---|
| 607 | return symbolNarrow;
|
---|
| 608 | }
|
---|
| 609 | return currency[0 /* Symbol */] || code;
|
---|
| 610 | }
|
---|
| 611 | // Most currencies have cents, that's why the default is 2
|
---|
| 612 | const DEFAULT_NB_OF_CURRENCY_DIGITS = 2;
|
---|
| 613 | /**
|
---|
| 614 | * Reports the number of decimal digits for a given currency.
|
---|
| 615 | * The value depends upon the presence of cents in that particular currency.
|
---|
| 616 | *
|
---|
| 617 | * @param code The currency code.
|
---|
| 618 | * @returns The number of decimal digits, typically 0 or 2.
|
---|
| 619 | * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n-overview)
|
---|
| 620 | *
|
---|
| 621 | * @publicApi
|
---|
| 622 | */
|
---|
| 623 | export function getNumberOfCurrencyDigits(code) {
|
---|
| 624 | let digits;
|
---|
| 625 | const currency = CURRENCIES_EN[code];
|
---|
| 626 | if (currency) {
|
---|
| 627 | digits = currency[2 /* NbOfDigits */];
|
---|
| 628 | }
|
---|
| 629 | return typeof digits === 'number' ? digits : DEFAULT_NB_OF_CURRENCY_DIGITS;
|
---|
| 630 | }
|
---|
| 631 | //# 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 LLC 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 {ɵCurrencyIndex, ɵExtraLocaleDataIndex, ɵfindLocaleData, ɵgetLocaleCurrencyCode, ɵgetLocalePluralCase, ɵLocaleDataIndex} from '@angular/core';\n\nimport {CURRENCIES_EN, CurrenciesSymbols} from './currencies';\n\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-overview)\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-overview)\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-1/date-time#TOC-Standalone-vs.-Format-Styles)\n * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n-overview)\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-overview)\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-overview)\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-overview)\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-overview)\n *\n * @publicApi\n */\nexport function getLocaleDayPeriods(\n    locale: string, formStyle: FormStyle, width: TranslationWidth): Readonly<[string, string]> {\n  const data = ɵfindLocaleData(locale);\n  const amPmData = <[string, string][][]>[\n    data[ɵLocaleDataIndex.DayPeriodsFormat], data[ɵLocaleDataIndex.DayPeriodsStandalone]\n  ];\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-overview)\n *\n * @publicApi\n */\nexport function getLocaleDayNames(\n    locale: string, formStyle: FormStyle, width: TranslationWidth): ReadonlyArray<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-overview)\n *\n * @publicApi\n */\nexport function getLocaleMonthNames(\n    locale: string, formStyle: FormStyle, width: TranslationWidth): ReadonlyArray<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 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-overview)\n *\n * @publicApi\n */\nexport function getLocaleEraNames(\n    locale: string, width: TranslationWidth): Readonly<[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-overview)\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-overview)\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-overview)\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-overview)\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-overview)\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-overview)\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-overview)\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 locale. For example, '$' for `en-US`.\n *\n * @param locale A locale code for the locale format rules to use.\n * @returns The localized symbol character,\n * or `null` if the main country cannot be determined.\n * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n-overview)\n *\n * @publicApi\n */\nexport function getLocaleCurrencySymbol(locale: string): string|null {\n  const data = ɵfindLocaleData(locale);\n  return data[ɵLocaleDataIndex.CurrencySymbol] || null;\n}\n\n/**\n * Retrieves the name of the currency for the main country corresponding\n * to a given locale. For example, 'US Dollar' for `en-US`.\n * @param locale A locale code for the locale format rules to use.\n * @returns The currency name,\n * or `null` if the main country cannot be determined.\n * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n-overview)\n *\n * @publicApi\n */\nexport function getLocaleCurrencyName(locale: string): string|null {\n  const data = ɵfindLocaleData(locale);\n  return data[ɵLocaleDataIndex.CurrencyName] || null;\n}\n\n/**\n * Retrieves the default currency code for the given locale.\n *\n * The default is defined as the first currency which is still in use.\n *\n * @param locale The code of the locale whose currency code we want.\n * @returns The code of the default currency for the given locale.\n *\n * @publicApi\n */\nexport function getLocaleCurrencyCode(locale: string): string|null {\n  return ɵgetLocaleCurrencyCode(locale);\n}\n\n/**\n * Retrieves the currency values for a given locale.\n * @param locale A locale code for the locale format rules to use.\n * @returns The currency values.\n * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n-overview)\n */\nfunction getLocaleCurrencies(locale: string): {[code: string]: CurrenciesSymbols} {\n  const data = ɵfindLocaleData(locale);\n  return data[ɵLocaleDataIndex.Currencies];\n}\n\n/**\n * @alias core/ɵgetLocalePluralCase\n * @publicApi\n */\nexport const getLocalePluralCase: (locale: string) => ((value: number) => Plural) =\n    ɵgetLocalePluralCase;\n\nfunction checkFullData(data: any) {\n  if (!data[ɵLocaleDataIndex.ExtraData]) {\n    throw new Error(`Missing extra locale data for the locale \"${\n        data[ɵLocaleDataIndex\n                 .LocaleId]}\". Use \"registerLocaleData\" to load new data. See the \"I18n guide\" on angular.io to know more.`);\n  }\n}\n\n/**\n * Retrieves locale-specific rules used to determine which day period to use\n * when more than one period is defined for a locale.\n *\n * There is a rule for each defined day period. The\n * first rule is applied to the first day period and so on.\n * Fall back to AM/PM when no rules are available.\n *\n * A rule can specify a period as time range, or as a single time value.\n *\n * This functionality is only available when you have loaded the full locale data.\n * See the [\"I18n guide\"](guide/i18n-common-format-data-locale).\n *\n * @param locale A locale code for the locale format rules to use.\n * @returns The rules for the locale, a single time value or array of *from-time, to-time*,\n * or null if no periods are available.\n *\n * @see `getLocaleExtraDayPeriods()`\n * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n-overview)\n *\n * @publicApi\n */\nexport function getLocaleExtraDayPeriodRules(locale: string): (Time|[Time, Time])[] {\n  const data = ɵfindLocaleData(locale);\n  checkFullData(data);\n  const rules = data[ɵLocaleDataIndex.ExtraData][ɵExtraLocaleDataIndex.ExtraDayPeriodsRules] || [];\n  return rules.map((rule: string|[string, string]) => {\n    if (typeof rule === 'string') {\n      return extractTime(rule);\n    }\n    return [extractTime(rule[0]), extractTime(rule[1])];\n  });\n}\n\n/**\n * Retrieves locale-specific day periods, which indicate roughly how a day is broken up\n * in different languages.\n * For example, for `en-US`, periods are morning, noon, afternoon, evening, and midnight.\n *\n * This functionality is only available when you have loaded the full locale data.\n * See the [\"I18n guide\"](guide/i18n-common-format-data-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 The translated day-period strings.\n * @see `getLocaleExtraDayPeriodRules()`\n * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n-overview)\n *\n * @publicApi\n */\nexport function getLocaleExtraDayPeriods(\n    locale: string, formStyle: FormStyle, width: TranslationWidth): string[] {\n  const data = ɵfindLocaleData(locale);\n  checkFullData(data);\n  const dayPeriodsData = <string[][][]>[\n    data[ɵLocaleDataIndex.ExtraData][ɵExtraLocaleDataIndex.ExtraDayPeriodFormats],\n    data[ɵLocaleDataIndex.ExtraData][ɵExtraLocaleDataIndex.ExtraDayPeriodStandalone]\n  ];\n  const dayPeriods = getLastDefinedValue(dayPeriodsData, formStyle) || [];\n  return getLastDefinedValue(dayPeriods, width) || [];\n}\n\n/**\n * Retrieves the writing direction of a specified locale\n * @param locale A locale code for the locale format rules to use.\n * @publicApi\n * @returns 'rtl' or 'ltr'\n * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n-overview)\n */\nexport function getLocaleDirection(locale: string): 'ltr'|'rtl' {\n  const data = ɵfindLocaleData(locale);\n  return data[ɵLocaleDataIndex.Directionality];\n}\n\n/**\n * Retrieves the first value that is defined in an array, going backwards from an index position.\n *\n * To avoid repeating the same data (as when the \"format\" and \"standalone\" forms are the same)\n * add the first value to the locale data arrays, and add other values only if they are different.\n *\n * @param data The data array to retrieve from.\n * @param index A 0-based index into the array to start from.\n * @returns The value immediately before the given index position.\n * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n-overview)\n *\n * @publicApi\n */\nfunction getLastDefinedValue<T>(data: T[], index: number): T {\n  for (let i = index; i > -1; i--) {\n    if (typeof data[i] !== 'undefined') {\n      return data[i];\n    }\n  }\n  throw new Error('Locale data API: locale data undefined');\n}\n\n/**\n * Represents a time value with hours and minutes.\n *\n * @publicApi\n */\nexport type Time = {\n  hours: number,\n  minutes: number\n};\n\n/**\n * Extracts the hours and minutes from a string like \"15:45\"\n */\nfunction extractTime(time: string): Time {\n  const [h, m] = time.split(':');\n  return {hours: +h, minutes: +m};\n}\n\n\n\n/**\n * Retrieves the currency symbol for a given currency code.\n *\n * For example, for the default `en-US` locale, the code `USD` can\n * be represented by the narrow symbol `$` or the wide symbol `US$`.\n *\n * @param code The currency code.\n * @param format The format, `wide` or `narrow`.\n * @param locale A locale code for the locale format rules to use.\n *\n * @returns The symbol, or the currency code if no symbol is available.\n * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n-overview)\n *\n * @publicApi\n */\nexport function getCurrencySymbol(code: string, format: 'wide'|'narrow', locale = 'en'): string {\n  const currency = getLocaleCurrencies(locale)[code] || CURRENCIES_EN[code] || [];\n  const symbolNarrow = currency[ɵCurrencyIndex.SymbolNarrow];\n\n  if (format === 'narrow' && typeof symbolNarrow === 'string') {\n    return symbolNarrow;\n  }\n\n  return currency[ɵCurrencyIndex.Symbol] || code;\n}\n\n// Most currencies have cents, that's why the default is 2\nconst DEFAULT_NB_OF_CURRENCY_DIGITS = 2;\n\n/**\n * Reports the number of decimal digits for a given currency.\n * The value depends upon the presence of cents in that particular currency.\n *\n * @param code The currency code.\n * @returns The number of decimal digits, typically 0 or 2.\n * @see [Internationalization (i18n) Guide](https://angular.io/guide/i18n-overview)\n *\n * @publicApi\n */\nexport function getNumberOfCurrencyDigits(code: string): number {\n  let digits;\n  const currency = CURRENCIES_EN[code];\n  if (currency) {\n    digits = currency[ɵCurrencyIndex.NbOfDigits];\n  }\n  return typeof digits === 'number' ? digits : DEFAULT_NB_OF_CURRENCY_DIGITS;\n}\n"]} |
---|