UNPKG

@types/luxon

Version:
180 lines (164 loc) 7.32 kB
import { CalendarSystem, NumberingSystem, StringUnitLength, UnitLength } from './misc'; import { Zone } from './zone'; export interface InfoOptions { locale?: string | undefined; } export interface InfoUnitOptions extends InfoOptions { numberingSystem?: NumberingSystem | undefined; } /** @deprecated */ export type UnitOptions = InfoUnitOptions; export interface InfoCalendarOptions extends InfoUnitOptions { outputCalendar?: CalendarSystem | undefined; } /** * The set of available features in this environment. Some features of Luxon are not available in all environments. */ export interface Features { /** * Whether this environment supports relative time formatting */ relative: boolean; } /** * The Info class contains static methods for retrieving general time and date related data. For example, it has methods for finding out if a time zone has a DST, for listing the months in any * supported locale, and for discovering which of Luxon features are available in the current environment. */ export namespace Info { /** * Return whether the specified zone contains a DST. * * @param zone - Zone to check. Defaults to the environment's local zone. Defaults to 'local'. */ function hasDST(zone?: string | Zone): boolean; /** * Return whether the specified zone is a valid IANA specifier. * * @param zone - Zone to check */ function isValidIANAZone(zone: string): boolean; /** * Converts the input into a {@link Zone} instance. * * * If `input` is already a Zone instance, it is returned unchanged. * * If `input` is a string containing a valid time zone name, a Zone instance * with that name is returned. * * If `input` is a string that doesn't refer to a known time zone, a Zone * instance with {@link Zone.isValid} == false is returned. * * If `input is a number, a Zone instance with the specified fixed offset * in minutes is returned. * * If `input` is `null` or `undefined`, the default zone is returned. * * @param input - the value to be converted */ function normalizeZone(input?: string | Zone | number): Zone; /** * Return an array of standalone month names. * @see https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/DateTimeFormat * * @param length - the length of the month representation, such as "numeric", "2-digit", "narrow", "short", "long". Defaults to 'long'. * @param opts - options * @param opts.locale - the locale code * @param opts.numberingSystem - the numbering system. Defaults to null. * @param opts.locObj - an existing locale object to use. Defaults to null. * @param opts.outputCalendar - the calendar. Defaults to 'gregory'. * * @example * Info.months()[0] //=> 'January' * @example * Info.months('short')[0] //=> 'Jan' * @example * Info.months('numeric')[0] //=> '1' * @example * Info.months('short', { locale: 'fr-CA' } )[0] //=> 'janv.' * @example * Info.months('numeric', { locale: 'ar' })[0] //=> '١' * @example * Info.months('long', { outputCalendar: 'islamic' })[0] //=> 'Rabiʻ I' */ function months(length?: UnitLength, opts?: InfoCalendarOptions): string[]; /** * Return an array of format month names. * Format months differ from standalone months in that they're meant to appear next to the day of the month. In some languages, that * changes the string. * See {@link Info#months} * * @param length - the length of the month representation, such as "numeric", "2-digit", "narrow", "short", "long". Defaults to 'long'. * @param opts - options * @param opts.locale - the locale code * @param opts.numberingSystem - the numbering system. Defaults to null. * @param opts.locObj - an existing locale object to use. Defaults to null. * @param opts.outputCalendar - the calendar. Defaults to 'gregory'. */ function monthsFormat(length?: UnitLength, options?: InfoCalendarOptions): string[]; /** * Return an array of standalone week names. * @see https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/DateTimeFormat * * @param length - the length of the weekday representation, such as "narrow", "short", "long". Defaults to 'long'. * @param opts - options * @param opts.locale - the locale code * @param opts.numberingSystem - the numbering system. Defaults to null. * @param opts.locObj - an existing locale object to use. Defaults to null. * * @example * Info.weekdays()[0] //=> 'Monday' * @example * Info.weekdays('short')[0] //=> 'Mon' * @example * Info.weekdays('short', { locale: 'fr-CA' })[0] //=> 'lun.' * @example * Info.weekdays('short', { locale: 'ar' })[0] //=> 'الاثنين' */ function weekdays(length?: StringUnitLength, options?: InfoUnitOptions): string[]; /** * Return an array of format week names. * Format weekdays differ from standalone weekdays in that they're meant to appear next to more date information. In some languages, that * changes the string. * See {@link Info#weekdays} * * @param length - the length of the month representation, such as "narrow", "short", "long". Defaults to 'long'. * @param opts - options * @param opts.locale - the locale code. Defaults to null. * @param opts.numberingSystem - the numbering system. Defaults to null. * @param opts.locObj - an existing locale object to use. Defaults to null. */ function weekdaysFormat(length?: StringUnitLength, options?: InfoUnitOptions): string[]; /** * Return an array of meridiems. * * @param opts - options * @param opts.locale - the locale code * * @example * Info.meridiems() //=> [ 'AM', 'PM' ] * @example * Info.meridiems({ locale: 'my' }) //=> [ 'နံနက်', 'ညနေ' ] */ function meridiems(options?: InfoOptions): string[]; /** * Return an array of eras, such as ['BC', 'AD']. The locale can be specified, but the calendar system is always Gregorian. * * @param length - the length of the era representation, such as "short" or "long". Defaults to 'short'. * @param opts - options * @param opts.locale - the locale code * * @example * Info.eras() //=> [ 'BC', 'AD' ] * @example * Info.eras('long') //=> [ 'Before Christ', 'Anno Domini' ] * @example * Info.eras('long', { locale: 'fr' }) //=> [ 'avant Jésus-Christ', 'après Jésus-Christ' ] */ function eras(length?: StringUnitLength, options?: InfoOptions): string[]; /** * Return the set of available features in this environment. * Some features of Luxon are not available in all environments. For example, on older browsers, timezone support is not available. Use this function to figure out if that's the case. * Keys: * * `relative`: whether this environment supports relative time formatting * * @example * Info.features() //=> { intl: true, intlTokens: false, zones: true, relative: false } */ function features(): Features; }