| // Copyright (C) 2021 André Bargull. All rights reserved. |
| // This code is governed by the BSD license found in the LICENSE file. |
| |
| /*--- |
| esid: sec-intl.supportedvaluesof |
| description: > |
| The returned "currency" values can be used with NumberFormat. |
| info: | |
| Intl.supportedValuesOf ( key ) |
| |
| 1. Let key be ? ToString(key). |
| ... |
| 4. Else if key is "currency", then |
| a. Let list be ! AvailableCurrencies( ). |
| ... |
| 9. Return ! CreateArrayFromList( list ). |
| |
| AvailableCurrencies ( ) |
| The AvailableCurrencies abstract operation returns a List, ordered as if an |
| Array of the same values had been sorted using %Array.prototype.sort% using |
| undefined as comparefn, that contains unique, well-formed, and upper case |
| canonicalized 3-letter ISO 4217 currency codes, identifying the currencies |
| for which the implementation provides the functionality of Intl.DisplayNames |
| and Intl.NumberFormat objects. |
| locale: [en] |
| features: [Intl-enumeration] |
| ---*/ |
| |
| const currencies = Intl.supportedValuesOf("currency"); |
| |
| for (let currency of currencies) { |
| let obj = new Intl.NumberFormat("en", {style: "currency", currency}); |
| assert.sameValue(obj.resolvedOptions().currency, currency, |
| `${currency} is supported by NumberFormat`); |
| } |
| |
| // Note: We can't test that additional currency values not present in |currencies| |
| // aren't supported by Intl.NumberFormat, because PartitionNumberPattern defaults |
| // to using the currency code itself when the currency is unsupported: |
| // |
| // PartitionNumberPattern, step 8.k.iii: |
| // Let cd be an ILD String value representing currency after x in currencyDisplay form, |
| // which may depend on x in languages having different plural forms. If the |
| // implementation does not have such a representation of currency, use currency itself. |