UNPKG

@intlify/utils

Version:

Collection of i18n utilities

291 lines (288 loc) 14.5 kB
import { H as HeaderOptions, C as CookieOptions, P as PathOptions, Q as QueryOptions } from './shared/utils.77e85720.js'; export { c as createPathIndexLanguageParser, i as isLocale, n as normalizeLanguageName, p as parseAcceptLanguage, r as registerPathLanguageParser, v as validateLangTag } from './shared/utils.77e85720.js'; /** * get languages from header * * @description parse header string, default `accept-language` header * * @example * example for Web API request on Deno: * * ```ts * import { getHeaderLanguages } from 'https://esm.sh/@intlify/utils/web' * * Deno.serve({ * port: 8080, * }, (req) => { * const langTags = getHeaderLanguages(req) * // ... * return new Response(`accepted languages: ${langTags.join(', ')}` * }) * ``` * * @param {Request} request The {@link Request | request} * @param {HeaderOptions['name']} options.name The header name, which is as default `accept-language`. * @param {HeaderOptions['parser']} options.parser The parser function, which is as default {@link parseDefaultHeader}. If you are specifying more than one in your own format, you need a parser. * * @returns {Array<string>} The array of language tags, if you use `accept-language` header and `*` (any language) or empty string is detected, return an empty array. */ declare function getHeaderLanguages(request: Request, { name, parser, }?: HeaderOptions): string[]; /** * get language from header * * @description parse header string, default `accept-language`. if you use `accept-language`, this function retuns the **first language tag** of `accept-language` header. * * @example * example for Web API request on Deno: * * ```ts * import { getAcceptLanguage } from 'https://esm.sh/@intlify/utils/web' * * Deno.serve({ * port: 8080, * }, (req) => { * const langTag = getHeaderLanguage(req) * // ... * return new Response(`accepted language: ${langTag}` * }) * ``` * * @param {Request} request The {@link Request | request} * @param {HeaderOptions['name']} options.name The header name, which is as default `accept-language`. * @param {HeaderOptions['parser']} options.parser The parser function, which is as default {@link parseDefaultHeader}. If you are specifying more than one in your own format, you need a parser. * * @returns {string} The **first language tag** of header, if header is not exists, or `*` (any language), return empty string. */ declare function getHeaderLanguage(request: Request, { name, parser, }?: HeaderOptions): string; /** * get locales from header * * @description wrap language tags with {@link Intl.Locale | locale}, languages tags will be parsed from `accept-language` header as default. * * @example * example for Web API request on Bun: * * import { getHeaderLocales } from '@intlify/utils/web' * * Bun.serve({ * port: 8080, * fetch(req) { * const locales = getHeaderLocales(req) * // ... * return new Response(`accpected locales: ${locales.map(locale => locale.toString()).join(', ')}`) * }, * }) * ``` * * @param {Request} request The {@link Request | request} * @param {HeaderOptions['name']} options.name The header name, which is as default `accept-language`. * @param {HeaderOptions['parser']} options.parser The parser function, which is as default {@link parseDefaultHeader}. If you are specifying more than one in your own format, you need a parser. * * @throws {RangeError} Throws the {@link RangeError} if header are not a well-formed BCP 47 language tag. * * @returns {Array<Intl.Locale>} The locales that wrapped from header, if you use `accept-language` header and `*` (any language) or empty string is detected, return an empty array. */ declare function getHeaderLocales(request: Request, { name, parser, }?: HeaderOptions): Intl.Locale[]; /** * try to get locales from header * * @description wrap language tags with {@link Intl.Locale | locale}, languages tags will be parsed from `accept-language` header as default. Unlike {@link getHeaderLocales}, this function does not throw an error if the locale cannot be obtained, this function returns `null`. * * @param {Request} request The {@link Request | request} * @param {HeaderOptions['name']} options.name The header name, which is as default `accept-language`. * @param {HeaderOptions['parser']} options.parser The parser function, which is as default {@link parseDefaultHeader}. If you are specifying more than one in your own format, you need a parser. * * @returns {Array<Intl.Locale> | null} The locales that wrapped from header, if you use `accept-language` header and `*` (any language) or empty string is detected, return an empty array. if header are not a well-formed BCP 47 language tag, return `null`. */ declare function tryHeaderLocales(request: Request, { name, parser, }?: HeaderOptions): Intl.Locale[] | null; /** * get locale from header * * @description wrap language tag with {@link Intl.Locale | locale}, languages tags will be parsed from `accept-language` header as default. * * @example * example for Web API request on Bun: * * import { getHeaderLocale } from '@intlify/utils/web' * * Bun.serve({ * port: 8080, * fetch(req) { * const locale = getHeaderLocale(req) * // ... * return new Response(`accpected locale: ${locale.toString()}`) * }, * }) * * @param {Request} request The {@link Request | request} * @param {string} options.lang The default language tag, Optional. default value is `en-US`. You must specify the language tag with the {@link https://datatracker.ietf.org/doc/html/rfc4646#section-2.1 | BCP 47 syntax}. * @param {HeaderOptions['name']} options.name The header name, which is as default `accept-language`. * @param {HeaderOptions['parser']} options.parser The parser function, which is as default {@link parseDefaultHeader}. If you are specifying more than one in your own format, you need a parser. * * @throws {RangeError} Throws the {@link RangeError} if `lang` option or header are not a well-formed BCP 47 language tag. * * @returns {Intl.Locale} The first locale that resolved from header string. if you use `accept-language` header and `*` (any language) or empty string is detected, return `en-US`. */ declare function getHeaderLocale(request: Request, { lang, name, parser, }?: HeaderOptions & { lang?: string; }): Intl.Locale; /** * try to get locale from header * * @description wrap language tag with {@link Intl.Locale | locale}, languages tags will be parsed from `accept-language` header as default. Unlike {@link getHeaderLocale}, this function does not throw an error if the locale cannot be obtained, this function returns `null`. * * @param {Request} request The {@link Request | request} * @param {string} options.lang The default language tag, Optional. default value is `en-US`. You must specify the language tag with the {@link https://datatracker.ietf.org/doc/html/rfc4646#section-2.1 | BCP 47 syntax}. * @param {HeaderOptions['name']} options.name The header name, which is as default `accept-language`. * @param {HeaderOptions['parser']} options.parser The parser function, which is as default {@link parseDefaultHeader}. If you are specifying more than one in your own format, you need a parser. * * @returns {Intl.Locale | null} The first locale that resolved from header string. if you use `accept-language` header and `*` (any language) or empty string is detected, return `en-US`. if `lang` option or header are not a well-formed BCP 47 language tag, return `null`. */ declare function tryHeaderLocale(request: Request, { lang, name, parser, }?: HeaderOptions & { lang?: string; }): Intl.Locale | null; /** * get locale from cookie * * @example * example for Web API request on Deno: * * ```ts * import { getCookieLocale } from 'https://esm.sh/@intlify/utils/web' * * Deno.serve({ * port: 8080, * }, (req) => { * const locale = getCookieLocale(req) * console.log(locale) // output `Intl.Locale` instance * // ... * }) * ``` * * @param {Request} request The {@link Request | request} * @param {string} options.lang The default language tag, default is `en-US`. You must specify the language tag with the {@link https://datatracker.ietf.org/doc/html/rfc4646#section-2.1 | BCP 47 syntax}. * @param {string} options.name The cookie name, default is `i18n_locale` * * @throws {RangeError} Throws a {@link RangeError} if `lang` option or cookie name value are not a well-formed BCP 47 language tag. * * @returns {Intl.Locale} The locale that resolved from cookie */ declare function getCookieLocale(request: Request, { lang, name }?: { lang?: string | undefined; name?: string | undefined; }): Intl.Locale; /** * try to get locale from cookie * * @description Unlike {@link getCookieLocale}, this function does not throw an error if the locale cannot be obtained, this function returns `null`. * * @param {Request} request The {@link Request | request} * @param {string} options.lang The default language tag, default is `en-US`. You must specify the language tag with the {@link https://datatracker.ietf.org/doc/html/rfc4646#section-2.1 | BCP 47 syntax}. * @param {string} options.name The cookie name, default is `i18n_locale` * * @returns {Intl.Locale | null} The locale that resolved from cookie. if `lang` option or cookie name value are not a well-formed BCP 47 language tag, return `null`. */ declare function tryCookieLocale(request: Request, { lang, name }?: { lang?: string | undefined; name?: string | undefined; }): Intl.Locale | null; /** * set locale to the response `Set-Cookie` header. * * @example * example for Web API response on Bun: * * ```ts * import { setCookieLocale } from '@intlify/utils/web' * * Bun.serve({ * port: 8080, * fetch(req) { * const res = new Response('こんにちは、世界!') * setCookieLocale(res, 'ja-JP') * // ... * return res * }, * }) * ``` * * @param {Response} response The {@link Response | response} * @param {string | Intl.Locale} locale The locale value * @param {CookieOptions} options The cookie options, `name` option is `i18n_locale` as default, and `path` option is `/` as default. * * @throws {SyntaxError} Throws the {@link SyntaxError} if `locale` is invalid. */ declare function setCookieLocale(response: Response, locale: string | Intl.Locale, options?: CookieOptions): void; /** * get the locale from the path * * @param {Request} request the {@link Request | request} * @param {PathOptions['lang']} options.lang the language tag, which is as default `'en-US'`. optional * @param {PathOptions['parser']} options.parser the path language parser, default {@link pathLanguageParser}, optional * * @throws {RangeError} Throws the {@link RangeError} if the language in the path, that is not a well-formed BCP 47 language tag. * * @returns {Intl.Locale} The locale that resolved from path */ declare function getPathLocale(request: Request, { lang, parser }?: PathOptions): Intl.Locale; /** * try to get the locale from the path * * @description Unlike {@link getPathLocale}, this function does not throw an error if the locale cannot be obtained, this function returns `null`. * * @param {Request} request the {@link Request | request} * @param {PathOptions['lang']} options.lang the language tag, which is as default `'en-US'`. optional * @param {PathOptions['parser']} options.parser the path language parser, default {@link pathLanguageParser}, optional * * @returns {Intl.Locale | null} The locale that resolved from path. if the language in the path, that is not a well-formed BCP 47 language tag, return `null`. */ declare function tryPathLocale(request: Request, { lang, parser }?: PathOptions): Intl.Locale | null; /** * get the locale from the query * * @param {Request} request the {@link Request | request} * @param {QueryOptions['lang']} options.lang the language tag, which is as default `'en-US'`. optional * @param {QueryOptions['name']} options.name the query param name, default `'locale'`. optional * * @throws {RangeError} Throws the {@link RangeError} if the language in the query, that is not a well-formed BCP 47 language tag. * * @returns {Intl.Locale} The locale that resolved from query */ declare function getQueryLocale(request: Request, { lang, name }?: QueryOptions): Intl.Locale; /** * try to get the locale from the query * * @description Unlike {@link getQueryLocale}, this function does not throw an error if the locale cannot be obtained, this function returns `null`. * * @param {Request} request the {@link Request | request} * @param {QueryOptions['lang']} options.lang the language tag, which is as default `'en-US'`. optional * @param {QueryOptions['name']} options.name the query param name, default `'locale'`. optional * * @returns {Intl.Locale | null} The locale that resolved from query. if the language in the query, that is not a well-formed BCP 47 language tag, return `null`. */ declare function tryQueryLocale(request: Request, { lang, name }?: QueryOptions): Intl.Locale | null; /** * get navigator locales * * @description * This function is a wrapper that maps in {@link Intl.Locale} in `navigator.languages`. * This function return values depends on the environments. if you use this function on the browser, you can get the languages, that are set in the browser, else if you use this function on the server side (Deno only), that value is the languages set in the server. * * @throws Throws the {@link Error} if the `navigator` is not exists. * * @returns {Array<Intl.Locale>} */ declare function getNavigatorLocales(): readonly Intl.Locale[]; /** * get navigator locale * * @description * This function is the {@link Intl.Locale} wrapper of `navigator.language`. * The value depends on the environments. if you use this function on the browser, you can get the languages, that are set in the browser, else if you use this function on the server side (Deno only), that value is the language set in the server. * * @throws Throws the {@link Error} if the `navigator` is not exists. * * @returns {Intl.Locale} */ declare function getNavigatorLocale(): Intl.Locale; export { getCookieLocale, getHeaderLanguage, getHeaderLanguages, getHeaderLocale, getHeaderLocales, getNavigatorLocale, getNavigatorLocales, getPathLocale, getQueryLocale, setCookieLocale, tryCookieLocale, tryHeaderLocale, tryHeaderLocales, tryPathLocale, tryQueryLocale };