-
Notifications
You must be signed in to change notification settings - Fork 12.8k
Update bigint declaration file #38526
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Changes from 9 commits
7d5942d
2f468d9
b11a746
b1ad32c
5592f60
af547be
f959c5f
e9410d6
bd99f0a
bab6c28
abf01a3
1b3f4f5
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,3 +1,99 @@ | ||
interface BigIntToLocaleStringOptionsBase { | ||
/** | ||
* The locale matching algorithm to use.The default is "best fit". For information about this option, see the {@link https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Intl#Locale_negotiation Intl page}. | ||
*/ | ||
localeMatcher?: "lookup" | "best fit" | string; | ||
/** | ||
* The formatting style to use , the default is "decimal". | ||
*/ | ||
style?: "decimal" | "percent" | string; | ||
|
||
numberingSystem?: "arab" | "arabext" | "bali" | "beng" | "deva" | "fullwide" | "gujr" | "guru" | "hanidec" | "khmr" | "knda" | "laoo" | "latn" | "limb" | "mlym" | "mong" | "mymr" | "orya" | "tamldec" | "telu" | "thai" | "tibt" | string; | ||
/** | ||
* The unit to use in unit formatting, Possible values are core unit identifiers, defined in UTS #35, Part 2, Section 6. A subset of units from the full list was selected for use in ECMAScript. Pairs of simple units can be concatenated with "-per-" to make a compound unit. There is no default value; if the style is "unit", the unit property must be provided. | ||
*/ | ||
unit?: string; | ||
|
||
/** | ||
* The unit formatting style to use in unit formatting, the defaults is "short". | ||
*/ | ||
unitDisplay?: "long" | "short" | "narrow" | string; | ||
|
||
/** | ||
* The currency to use in currency formatting. Possible values are the ISO 4217 currency codes, such as "USD" for the US dollar, "EUR" for the euro, or "CNY" for the Chinese RMB — see the Current currency & funds code list. There is no default value; if the style is "currency", the currency property must be provided. It is only used when [[Style]] has the value "currency". | ||
*/ | ||
currency?: string; | ||
/** | ||
* How to display the currency in currency formatting. It is only used when [[Style]] has the value "currency". The default is "symbol". | ||
* | ||
* "symbol" to use a localized currency symbol such as €, | ||
* | ||
* "code" to use the ISO currency code, | ||
* | ||
* "name" to use a localized currency name such as "dollar" | ||
*/ | ||
currencyDisplay?: "symbol" | "code" | "name" | string; | ||
|
||
/** | ||
* Whether to use grouping separators, such as thousands separators or thousand/lakh/crore separators. The default is true. | ||
*/ | ||
useGrouping?: boolean; | ||
|
||
/** | ||
* The minimum number of integer digits to use. Possible values are from 1 to 21; the default is 1. | ||
*/ | ||
minimumIntegerDigits?: 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21; | ||
|
||
/** | ||
* The minimum number of fraction digits to use. Possible values are from 0 to 20; the default for plain number and percent formatting is 0; the default for currency formatting is the number of minor unit digits provided by the {@link http://www.currency-iso.org/en/home/tables/table-a1.html ISO 4217 currency codes list} (2 if the list doesn't provide that information). | ||
*/ | ||
minimumFractionDigits?: 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20; | ||
|
||
/** | ||
* The maximum number of fraction digits to use. Possible values are from 0 to 20; the default for plain number formatting is the larger of minimumFractionDigits and 3; the default for currency formatting is the larger of minimumFractionDigits and the number of minor unit digits provided by the {@link http://www.currency-iso.org/en/home/tables/table-a1.html ISO 4217 currency codes list} (2 if the list doesn't provide that information); the default for percent formatting is the larger of minimumFractionDigits and 0. | ||
*/ | ||
maximumFractionDigits?: 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20; | ||
|
||
/** | ||
* The minimum number of significant digits to use. Possible values are from 1 to 21; the default is 1. | ||
*/ | ||
minimumSignificantDigits?: 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21; | ||
/** | ||
* The maximum number of significant digits to use. Possible values are from 1 to 21; the default is 21. | ||
*/ | ||
maximumSignificantDigits?: 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21; | ||
|
||
/** | ||
* The formatting that should be displayed for the number, the defaults is "standard" | ||
* | ||
* "standard" plain number formatting | ||
* | ||
* "scientific" return the order-of-magnitude for formatted number. | ||
* | ||
* "engineering" return the exponent of ten when divisible by three | ||
* | ||
* "compact" string representing exponent, defaults is using the "short" form | ||
*/ | ||
notation?: "standard" | "scientific" | "engineering" | "compact" | string; | ||
|
||
/** | ||
* used only when notation is "compact" | ||
*/ | ||
compactDisplay?: "short" | "long" | string; | ||
} | ||
|
||
interface BigIntToLocaleStringOptionsStyleUnit extends Omit<BigIntToLocaleStringOptionsBase, "style"> { | ||
style: "unit"; | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. All you get for the overhead of these two interfaces+union is the ability to make There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Yeah. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. The tradeoff is that the standard library is more complicated and slower to check. I'd like to go with the simpler single-interface solution and let users avoid the error. |
||
unit: string; | ||
} | ||
|
||
interface BigIntToLocaleStringOptionsStyleCurrency extends Omit<BigIntToLocaleStringOptionsBase, "style"> { | ||
style: "currency"; | ||
currency: string; | ||
} | ||
|
||
type BigIntToLocaleStringOptions = BigIntToLocaleStringOptionsStyleUnit | BigIntToLocaleStringOptionsStyleCurrency | BigIntToLocaleStringOptionsBase; | ||
|
||
interface BigInt { | ||
/** | ||
* Returns a string representation of an object. | ||
|
@@ -6,7 +102,7 @@ interface BigInt { | |
toString(radix?: number): string; | ||
|
||
/** Returns a string representation appropriate to the host environment's current locale. */ | ||
toLocaleString(): string; | ||
toLocaleString(locales?: string, options?: BigIntToLocaleStringOptions): string; | ||
|
||
/** Returns the primitive value of the specified object. */ | ||
valueOf(): bigint; | ||
|
@@ -613,3 +709,10 @@ interface DataView { | |
*/ | ||
setBigUint64(byteOffset: number, value: bigint, littleEndian?: boolean): void; | ||
} | ||
|
||
declare namespace Intl{ | ||
interface NumberFormat { | ||
format(value: number | bigint): string; | ||
resolvedOptions(): ResolvedNumberFormatOptions; | ||
} | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
"x" | string
is currently reduced tostring
and the literals are thrown out. I thinkstring
is fine for now.There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The feature request for supporting this is #33471
Uh oh!
There was an error while loading. Please reload this page.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Do I need to remove these "x", or just leave them here, waiting for the benefit of this feature request?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It's a fairly complex feature and not likely to be in 4.0 or 4.1. We should stick with
string
for all these unions.