intor 2.2.13 → 2.2.15
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/exports/config/index.d.ts +2 -0
- package/dist/exports/config/index.js +4 -0
- package/dist/exports/index.d.ts +5 -0
- package/dist/exports/index.js +11 -0
- package/dist/exports/next/index.d.ts +3 -0
- package/dist/exports/next/index.js +9 -0
- package/dist/exports/next/middleware/index.d.ts +2 -0
- package/dist/exports/next/middleware/index.js +2 -0
- package/dist/exports/next/server/index.d.ts +2 -0
- package/dist/exports/next/server/index.js +2 -0
- package/dist/exports/react/index.d.ts +2 -0
- package/dist/exports/react/index.js +6 -0
- package/dist/exports/server/index.d.ts +2 -0
- package/dist/exports/server/index.js +7 -0
- package/dist/src/adapters/next/middleware/handle-prefix/handle-prefix-all.d.ts +12 -0
- package/dist/src/adapters/next/middleware/handle-prefix/handle-prefix-all.js +60 -0
- package/dist/src/adapters/next/middleware/handle-prefix/handle-prefix-except-default.d.ts +16 -0
- package/dist/src/adapters/next/middleware/handle-prefix/handle-prefix-except-default.js +81 -0
- package/dist/src/adapters/next/middleware/handle-prefix/handle-prefix-none.d.ts +10 -0
- package/dist/src/adapters/next/middleware/handle-prefix/handle-prefix-none.js +22 -0
- package/dist/src/adapters/next/middleware/index.d.ts +2 -0
- package/dist/src/adapters/next/middleware/intor-middleware.d.ts +6 -0
- package/dist/src/adapters/next/middleware/intor-middleware.js +22 -0
- package/dist/src/adapters/next/middleware/utils/create-response.d.ts +17 -0
- package/dist/src/adapters/next/middleware/utils/create-response.js +42 -0
- package/dist/src/adapters/next/middleware/utils/determine-initial-locale.d.ts +8 -0
- package/dist/src/adapters/next/middleware/utils/determine-initial-locale.js +28 -0
- package/dist/src/adapters/next/middleware/utils/set-locale-cookie-edge.d.ts +15 -0
- package/dist/src/adapters/next/middleware/utils/set-locale-cookie-edge.js +24 -0
- package/dist/src/adapters/next/middleware/utils/set-pathname-header.d.ts +12 -0
- package/dist/src/adapters/next/middleware/utils/set-pathname-header.js +13 -0
- package/dist/src/adapters/next/navigation/index.d.ts +4 -0
- package/dist/src/adapters/next/navigation/link.d.ts +16 -0
- package/dist/src/adapters/next/navigation/link.js +25 -0
- package/dist/src/adapters/next/navigation/redirect.d.ts +16 -0
- package/dist/src/adapters/next/navigation/redirect.js +36 -0
- package/dist/src/adapters/next/navigation/use-pathname.d.ts +17 -0
- package/dist/src/adapters/next/navigation/use-pathname.js +49 -0
- package/dist/src/adapters/next/navigation/use-router.d.ts +20 -0
- package/dist/src/adapters/next/navigation/use-router.js +31 -0
- package/dist/src/adapters/next/navigation/utils/should-full-reload.d.ts +7 -0
- package/dist/src/adapters/next/navigation/utils/should-full-reload.js +19 -0
- package/dist/src/adapters/next/navigation/utils/use-locale-switch.d.ts +16 -0
- package/dist/src/adapters/next/navigation/utils/use-locale-switch.js +58 -0
- package/dist/src/adapters/next/server/get-i18n-context.d.ts +9 -0
- package/dist/src/adapters/next/server/get-i18n-context.js +47 -0
- package/dist/src/adapters/next/server/get-translator.d.ts +30 -0
- package/dist/src/adapters/next/server/get-translator.js +19 -0
- package/dist/src/adapters/next/server/index.d.ts +2 -0
- package/dist/src/adapters/next/shared/constants/pathname-header-name.d.ts +1 -0
- package/dist/src/adapters/next/shared/constants/pathname-header-name.js +4 -0
- package/dist/src/adapters/next/shared/utils/locale-prefix-pathname.d.ts +16 -0
- package/dist/src/adapters/next/shared/utils/locale-prefix-pathname.js +33 -0
- package/dist/src/adapters/next/shared/utils/localize-pathname.d.ts +18 -0
- package/dist/src/adapters/next/shared/utils/localize-pathname.js +36 -0
- package/dist/src/client/react/contexts/config/context.d.ts +3 -0
- package/dist/src/client/react/contexts/config/context.js +6 -0
- package/dist/src/client/react/contexts/config/hook.d.ts +2 -0
- package/dist/src/client/react/contexts/config/hook.js +12 -0
- package/dist/src/client/react/contexts/config/index.d.ts +2 -0
- package/dist/src/client/react/contexts/config/provider.d.ts +2 -0
- package/dist/src/client/react/contexts/config/provider.js +11 -0
- package/dist/src/client/react/contexts/config/types.d.ts +10 -0
- package/dist/src/client/react/contexts/intor-provider/index.d.ts +2 -0
- package/dist/src/client/react/contexts/intor-provider/intor-provider.d.ts +2 -0
- package/dist/src/client/react/contexts/intor-provider/intor-provider.js +17 -0
- package/dist/src/client/react/contexts/intor-provider/types.d.ts +14 -0
- package/dist/src/client/react/contexts/locale/context.d.ts +3 -0
- package/dist/src/client/react/contexts/locale/context.js +6 -0
- package/dist/src/client/react/contexts/locale/hook.d.ts +1 -0
- package/dist/src/client/react/contexts/locale/hook.js +12 -0
- package/dist/src/client/react/contexts/locale/index.d.ts +2 -0
- package/dist/src/client/react/contexts/locale/provider.d.ts +3 -0
- package/dist/src/client/react/contexts/locale/provider.js +48 -0
- package/dist/src/client/react/contexts/locale/types.d.ts +13 -0
- package/dist/src/client/react/contexts/locale/utils/change-locale.d.ts +22 -0
- package/dist/src/client/react/contexts/locale/utils/change-locale.js +35 -0
- package/dist/src/client/react/contexts/locale/utils/use-init-locale-cookie.d.ts +8 -0
- package/dist/src/client/react/contexts/locale/utils/use-init-locale-cookie.js +28 -0
- package/dist/src/client/react/contexts/messages/context.d.ts +3 -0
- package/dist/src/client/react/contexts/messages/context.js +6 -0
- package/dist/src/client/react/contexts/messages/hook.d.ts +2 -0
- package/dist/src/client/react/contexts/messages/hook.js +12 -0
- package/dist/src/client/react/contexts/messages/index.d.ts +2 -0
- package/dist/src/client/react/contexts/messages/provider.d.ts +3 -0
- package/dist/src/client/react/contexts/messages/provider.js +32 -0
- package/dist/src/client/react/contexts/messages/types.d.ts +15 -0
- package/dist/src/client/react/contexts/messages/utils/use-refetch-messages.d.ts +16 -0
- package/dist/src/client/react/contexts/messages/utils/use-refetch-messages.js +57 -0
- package/dist/src/client/react/contexts/translate-handlers/context.d.ts +2 -0
- package/dist/src/client/react/contexts/translate-handlers/context.js +6 -0
- package/dist/src/client/react/contexts/translate-handlers/hook.d.ts +2 -0
- package/dist/src/client/react/contexts/translate-handlers/hook.js +10 -0
- package/dist/src/client/react/contexts/translate-handlers/index.d.ts +3 -0
- package/dist/src/client/react/contexts/translate-handlers/provider.d.ts +2 -0
- package/dist/src/client/react/contexts/translate-handlers/provider.js +11 -0
- package/dist/src/client/react/contexts/translate-handlers/types.d.ts +7 -0
- package/dist/src/client/react/contexts/translator/context.d.ts +3 -0
- package/dist/src/client/react/contexts/translator/context.js +6 -0
- package/dist/src/client/react/contexts/translator/hook.d.ts +2 -0
- package/dist/src/client/react/contexts/translator/hook.js +12 -0
- package/dist/src/client/react/contexts/translator/index.d.ts +2 -0
- package/dist/src/client/react/contexts/translator/provider.d.ts +2 -0
- package/dist/src/client/react/contexts/translator/provider.js +53 -0
- package/dist/src/client/react/contexts/translator/types.d.ts +11 -0
- package/dist/src/client/react/hooks/use-translator.d.ts +12 -0
- package/dist/src/client/react/hooks/use-translator.js +38 -0
- package/dist/src/client/react/index.d.ts +4 -0
- package/dist/src/client/shared/utils/get-initial-locale.d.ts +11 -0
- package/dist/src/client/shared/utils/get-initial-locale.js +21 -0
- package/dist/src/config/constants/cache.constants.d.ts +2 -0
- package/dist/src/config/constants/cache.constants.js +7 -0
- package/dist/src/config/constants/cookie.constants.d.ts +2 -0
- package/dist/src/config/constants/cookie.constants.js +14 -0
- package/dist/src/config/constants/routing.constants.d.ts +2 -0
- package/dist/src/config/constants/routing.constants.js +11 -0
- package/dist/src/config/define-intor-config.d.ts +2 -0
- package/dist/src/config/define-intor-config.js +34 -0
- package/dist/src/config/index.d.ts +5 -0
- package/dist/src/config/resolvers/resolve-cache-options.d.ts +2 -0
- package/dist/src/config/resolvers/resolve-cache-options.js +10 -0
- package/dist/src/config/resolvers/resolve-cookie-options.d.ts +11 -0
- package/dist/src/config/resolvers/resolve-cookie-options.js +19 -0
- package/dist/src/config/resolvers/resolve-fallback-locales.d.ts +3 -0
- package/dist/src/config/resolvers/resolve-fallback-locales.js +33 -0
- package/dist/src/config/resolvers/resolve-routing-options.d.ts +13 -0
- package/dist/src/config/resolvers/resolve-routing-options.js +28 -0
- package/dist/src/config/types/cache.types.d.ts +7 -0
- package/dist/src/config/types/cookie.types.d.ts +23 -0
- package/dist/src/config/types/intor-config.types.d.ts +41 -0
- package/dist/src/config/types/loader.types.d.ts +38 -0
- package/dist/src/config/types/logger.types.d.ts +7 -0
- package/dist/src/config/types/routing.types.d.ts +15 -0
- package/dist/src/config/types/translator.types.d.ts +4 -0
- package/dist/src/config/validators/validate-default-locale.d.ts +3 -0
- package/dist/src/config/validators/validate-default-locale.js +24 -0
- package/dist/src/config/validators/validate-supported-locales.d.ts +7 -0
- package/dist/src/config/validators/validate-supported-locales.js +22 -0
- package/dist/src/server/index.d.ts +4 -0
- package/dist/src/server/intor/index.d.ts +2 -0
- package/dist/src/server/intor/intor.d.ts +14 -0
- package/dist/src/server/intor/intor.js +67 -0
- package/dist/src/server/intor/types.d.ts +14 -0
- package/dist/src/server/messages/index.d.ts +7 -0
- package/dist/src/server/messages/load-local-messages/index.d.ts +2 -0
- package/dist/src/server/messages/load-local-messages/load-local-messages.d.ts +11 -0
- package/dist/src/server/messages/load-local-messages/load-local-messages.js +85 -0
- package/dist/src/server/messages/load-local-messages/read-locale-messages/collect-file-entries/collect-file-entries.d.ts +29 -0
- package/dist/src/server/messages/load-local-messages/read-locale-messages/collect-file-entries/collect-file-entries.js +95 -0
- package/dist/src/server/messages/load-local-messages/read-locale-messages/collect-file-entries/index.d.ts +1 -0
- package/dist/src/server/messages/load-local-messages/read-locale-messages/collect-file-entries/types.d.ts +15 -0
- package/dist/src/server/messages/load-local-messages/read-locale-messages/index.d.ts +2 -0
- package/dist/src/server/messages/load-local-messages/read-locale-messages/parse-file-entries/index.d.ts +1 -0
- package/dist/src/server/messages/load-local-messages/read-locale-messages/parse-file-entries/parse-file-entries.d.ts +34 -0
- package/dist/src/server/messages/load-local-messages/read-locale-messages/parse-file-entries/parse-file-entries.js +85 -0
- package/dist/src/server/messages/load-local-messages/read-locale-messages/parse-file-entries/types.d.ts +18 -0
- package/dist/src/server/messages/load-local-messages/read-locale-messages/parse-file-entries/utils/json-reader.d.ts +6 -0
- package/dist/src/server/messages/load-local-messages/read-locale-messages/parse-file-entries/utils/json-reader.js +12 -0
- package/dist/src/server/messages/load-local-messages/read-locale-messages/parse-file-entries/utils/nest-object-from-path.d.ts +14 -0
- package/dist/src/server/messages/load-local-messages/read-locale-messages/parse-file-entries/utils/nest-object-from-path.js +21 -0
- package/dist/src/server/messages/load-local-messages/read-locale-messages/read-locale-messages.d.ts +10 -0
- package/dist/src/server/messages/load-local-messages/read-locale-messages/read-locale-messages.js +31 -0
- package/dist/src/server/messages/load-local-messages/read-locale-messages/types.d.ts +23 -0
- package/dist/src/server/messages/load-local-messages/types.d.ts +21 -0
- package/dist/src/server/messages/load-messages.d.ts +11 -0
- package/dist/src/server/messages/load-messages.js +77 -0
- package/dist/src/server/messages/load-remote-messages/fetch-locale-messages/fetch-locale-messages.d.ts +9 -0
- package/dist/src/server/messages/load-remote-messages/fetch-locale-messages/fetch-locale-messages.js +50 -0
- package/dist/src/server/messages/load-remote-messages/fetch-locale-messages/index.d.ts +1 -0
- package/dist/src/server/messages/load-remote-messages/fetch-locale-messages/types.d.ts +13 -0
- package/dist/src/server/messages/load-remote-messages/fetch-locale-messages/utils/build-search-params.d.ts +5 -0
- package/dist/src/server/messages/load-remote-messages/fetch-locale-messages/utils/build-search-params.js +25 -0
- package/dist/src/server/messages/load-remote-messages/index.d.ts +2 -0
- package/dist/src/server/messages/load-remote-messages/load-remote-messages.d.ts +9 -0
- package/dist/src/server/messages/load-remote-messages/load-remote-messages.js +79 -0
- package/dist/src/server/messages/load-remote-messages/types.d.ts +20 -0
- package/dist/src/server/messages/shared/global-messages-pool.d.ts +15 -0
- package/dist/src/server/messages/shared/global-messages-pool.js +10 -0
- package/dist/src/server/messages/shared/types.d.ts +39 -0
- package/dist/src/server/messages/shared/utils/is-valid-messages.d.ts +15 -0
- package/dist/src/server/messages/shared/utils/is-valid-messages.js +36 -0
- package/dist/src/server/messages/types.d.ts +15 -0
- package/dist/src/server/shared/logger/get-logger.d.ts +11 -0
- package/dist/src/server/shared/logger/get-logger.js +34 -0
- package/dist/src/server/shared/logger/global-logger-pool.d.ts +15 -0
- package/dist/src/server/shared/logger/global-logger-pool.js +8 -0
- package/dist/src/server/translator/get-translator.d.ts +33 -0
- package/dist/src/server/translator/get-translator.js +39 -0
- package/dist/src/server/translator/index.d.ts +1 -0
- package/dist/src/shared/constants/prefix-placeholder.d.ts +1 -0
- package/dist/src/shared/constants/prefix-placeholder.js +4 -0
- package/dist/src/shared/error/index.d.ts +1 -0
- package/dist/src/shared/error/intor-error.d.ts +16 -0
- package/dist/src/shared/error/intor-error.js +21 -0
- package/dist/src/shared/types/generated.types.d.ts +30 -0
- package/dist/src/shared/types/translator-instance.types.d.ts +33 -0
- package/dist/src/shared/utils/client/build-cookie-string.d.ts +9 -0
- package/dist/src/shared/utils/client/build-cookie-string.js +33 -0
- package/dist/src/shared/utils/client/set-locale-cookie-browser.d.ts +13 -0
- package/dist/src/shared/utils/client/set-locale-cookie-browser.js +21 -0
- package/dist/src/shared/utils/index.d.ts +8 -0
- package/dist/src/shared/utils/locale/normalize-locale.d.ts +4 -0
- package/dist/src/shared/utils/locale/normalize-locale.js +42 -0
- package/dist/src/shared/utils/locale/resolve-preferred-locale.d.ts +5 -0
- package/dist/src/shared/utils/locale/resolve-preferred-locale.js +26 -0
- package/dist/src/shared/utils/merge-messages.d.ts +6 -0
- package/dist/src/shared/utils/merge-messages.js +13 -0
- package/dist/src/shared/utils/normalize-cache-key.d.ts +3 -0
- package/dist/src/shared/utils/normalize-cache-key.js +29 -0
- package/dist/src/shared/utils/pathname/extract-pathname.d.ts +28 -0
- package/dist/src/shared/utils/pathname/extract-pathname.js +58 -0
- package/dist/src/shared/utils/pathname/normalize-pathname.d.ts +12 -0
- package/dist/src/shared/utils/pathname/normalize-pathname.js +43 -0
- package/dist/src/shared/utils/pathname/standardize-pathname.d.ts +18 -0
- package/dist/src/shared/utils/pathname/standardize-pathname.js +30 -0
- package/dist/src/shared/utils/resolve-namespaces.d.ts +10 -0
- package/dist/src/shared/utils/resolve-namespaces.js +33 -0
- package/package.json +28 -30
- package/dist/config/index.cjs +0 -198
- package/dist/config/index.d.cts +0 -145
- package/dist/config/index.d.ts +0 -145
- package/dist/config/index.js +0 -193
- package/dist/index.cjs +0 -234
- package/dist/index.d.cts +0 -224
- package/dist/index.d.ts +0 -224
- package/dist/index.js +0 -214
- package/dist/next/index.cjs +0 -940
- package/dist/next/index.d.cts +0 -282
- package/dist/next/index.d.ts +0 -282
- package/dist/next/index.js +0 -907
- package/dist/next/middleware/index.cjs +0 -387
- package/dist/next/middleware/index.d.cts +0 -128
- package/dist/next/middleware/index.d.ts +0 -128
- package/dist/next/middleware/index.js +0 -384
- package/dist/next/server/index.cjs +0 -734
- package/dist/next/server/index.d.cts +0 -277
- package/dist/next/server/index.d.ts +0 -277
- package/dist/next/server/index.js +0 -723
- package/dist/react/index.cjs +0 -649
- package/dist/react/index.d.cts +0 -224
- package/dist/react/index.d.ts +0 -224
- package/dist/react/index.js +0 -620
- package/dist/server/index.cjs +0 -696
- package/dist/server/index.d.cts +0 -377
- package/dist/server/index.d.ts +0 -377
- package/dist/server/index.js +0 -680
package/dist/server/index.d.ts
DELETED
|
@@ -1,377 +0,0 @@
|
|
|
1
|
-
import { Level, NormalizerConfig, FormatterConfig, LoggerPreset } from 'logry/edge';
|
|
2
|
-
import { Locale, LocaleMessages, FallbackLocalesMap, NestedMessage, ScopedLeafKeys, LocalizedLeafKeys, Replacement, TranslateHandlers, LocalizedNodeKeys } from 'intor-translator';
|
|
3
|
-
import Keyv from 'keyv';
|
|
4
|
-
import { Logger } from 'logry';
|
|
5
|
-
|
|
6
|
-
type CookieRawOptions = {
|
|
7
|
-
/** Enable cookie usage (read/write) - default: true */
|
|
8
|
-
enabled?: boolean;
|
|
9
|
-
/** Allow the system to automatically set cookies - default: true */
|
|
10
|
-
autoSetCookie?: boolean;
|
|
11
|
-
/** default: "intor.i18n.locale" */
|
|
12
|
-
name?: string;
|
|
13
|
-
/** default: null */
|
|
14
|
-
domain?: string | null;
|
|
15
|
-
/** default: "/" */
|
|
16
|
-
path?: string;
|
|
17
|
-
/** default: 60 * 60 * 24 * 365 (365 days) */
|
|
18
|
-
maxAge?: number;
|
|
19
|
-
/** default: false */
|
|
20
|
-
httpOnly?: boolean;
|
|
21
|
-
/** default: process.env.NODE_ENV !== "development" */
|
|
22
|
-
secure?: boolean;
|
|
23
|
-
/** default: lax */
|
|
24
|
-
sameSite?: "lax" | "strict" | "none";
|
|
25
|
-
};
|
|
26
|
-
type CookieResolvedOptions = Required<Omit<CookieRawOptions, "domain">> & {
|
|
27
|
-
domain: string | null;
|
|
28
|
-
};
|
|
29
|
-
|
|
30
|
-
/**
|
|
31
|
-
* ```ts
|
|
32
|
-
* {
|
|
33
|
-
* default: ["ui", "meta"],
|
|
34
|
-
* "/auth": ["auth", "admin"],
|
|
35
|
-
* }
|
|
36
|
-
* // When pathname is "/" => namespaces: ["ui", "meta"]
|
|
37
|
-
* // When pathname is "/auth" => namespaces: ["ui", "meta", "auth", "admin"]
|
|
38
|
-
* ```
|
|
39
|
-
*/
|
|
40
|
-
type RouteNamespaces = {
|
|
41
|
-
[key: string]: string[];
|
|
42
|
-
} | {
|
|
43
|
-
[key: string]: string[];
|
|
44
|
-
default: string[];
|
|
45
|
-
};
|
|
46
|
-
interface RemoteHeaders {
|
|
47
|
-
authorization?: string;
|
|
48
|
-
"x-api-key"?: string;
|
|
49
|
-
[key: string]: string | undefined;
|
|
50
|
-
}
|
|
51
|
-
type BaseLoaderOptions = {
|
|
52
|
-
rootDir?: string;
|
|
53
|
-
namespaces?: string[];
|
|
54
|
-
routeNamespaces?: RouteNamespaces;
|
|
55
|
-
concurrency?: number;
|
|
56
|
-
};
|
|
57
|
-
type LocalLoader = BaseLoaderOptions & {
|
|
58
|
-
type: "local";
|
|
59
|
-
};
|
|
60
|
-
type RemoteLoader = BaseLoaderOptions & {
|
|
61
|
-
type: "remote";
|
|
62
|
-
remoteUrl: string;
|
|
63
|
-
remoteHeaders?: RemoteHeaders;
|
|
64
|
-
fullReload?: boolean;
|
|
65
|
-
};
|
|
66
|
-
type LoaderOptions = LocalLoader | RemoteLoader;
|
|
67
|
-
|
|
68
|
-
type LoggerOptions = {
|
|
69
|
-
level?: Level;
|
|
70
|
-
normalizerConfig?: NormalizerConfig;
|
|
71
|
-
formatterConfig?: FormatterConfig;
|
|
72
|
-
preset?: LoggerPreset;
|
|
73
|
-
};
|
|
74
|
-
|
|
75
|
-
declare const routingPrefix: readonly ["none", "all", "except-default"];
|
|
76
|
-
declare const routingFirstVisitLocaleSource: readonly ["default", "browser"];
|
|
77
|
-
type RoutingRawOptions = {
|
|
78
|
-
/** default: "none" */
|
|
79
|
-
prefix?: (typeof routingPrefix)[number];
|
|
80
|
-
firstVisit?: {
|
|
81
|
-
/** default: "browser" */
|
|
82
|
-
localeSource?: (typeof routingFirstVisitLocaleSource)[number];
|
|
83
|
-
/** default: true */
|
|
84
|
-
redirect?: boolean;
|
|
85
|
-
};
|
|
86
|
-
/** default: "" */
|
|
87
|
-
basePath?: string;
|
|
88
|
-
};
|
|
89
|
-
type RoutingResolvedOptions = Required<RoutingRawOptions>;
|
|
90
|
-
|
|
91
|
-
type CacheRawOptions = {
|
|
92
|
-
/** default: process.env.NODE_ENV === "production" */
|
|
93
|
-
enabled?: boolean;
|
|
94
|
-
/** default: 60\*60\*1000 (1 hour) */
|
|
95
|
-
ttl?: number;
|
|
96
|
-
};
|
|
97
|
-
type CacheResolvedOptions = Required<CacheRawOptions>;
|
|
98
|
-
|
|
99
|
-
type TranslatorOptions = {
|
|
100
|
-
loadingMessage?: string;
|
|
101
|
-
placeholder?: string;
|
|
102
|
-
};
|
|
103
|
-
|
|
104
|
-
type IntorResolvedConfig = ({
|
|
105
|
-
loader: LoaderOptions;
|
|
106
|
-
supportedLocales: readonly Locale[];
|
|
107
|
-
} | {
|
|
108
|
-
loader?: undefined;
|
|
109
|
-
supportedLocales: readonly Locale[];
|
|
110
|
-
}) & {
|
|
111
|
-
readonly id: string;
|
|
112
|
-
readonly messages?: LocaleMessages;
|
|
113
|
-
readonly defaultLocale: Locale;
|
|
114
|
-
readonly fallbackLocales: FallbackLocalesMap;
|
|
115
|
-
readonly translator?: TranslatorOptions;
|
|
116
|
-
readonly cookie: CookieResolvedOptions;
|
|
117
|
-
readonly routing: RoutingResolvedOptions;
|
|
118
|
-
readonly logger?: LoggerOptions;
|
|
119
|
-
readonly cache: CacheResolvedOptions;
|
|
120
|
-
};
|
|
121
|
-
|
|
122
|
-
declare const PREFIX_PLACEHOLDER = "{locale}";
|
|
123
|
-
|
|
124
|
-
/**
|
|
125
|
-
* Conditional type for generated types.
|
|
126
|
-
* - Returns `Then` if `IntorGeneratedTypes` exists, otherwise `Else`.
|
|
127
|
-
*/
|
|
128
|
-
type IfGen<Then, Else = never> = IntorGeneratedTypes extends void ? Else : Then;
|
|
129
|
-
/**
|
|
130
|
-
* Union of all configuration keys.
|
|
131
|
-
* - Defaults to `string` if `IntorGeneratedTypes` does not exist.
|
|
132
|
-
*/
|
|
133
|
-
type GenConfigKeys = IfGen<keyof IntorGeneratedTypes, string>;
|
|
134
|
-
/**
|
|
135
|
-
* Configuration shape for a given config key.
|
|
136
|
-
* - If `IntorGeneratedTypes` is not defined, falls back to default shape.
|
|
137
|
-
* Otherwise, picks `Locales` and `Messages` according to the key.
|
|
138
|
-
*/
|
|
139
|
-
type GenConfig<CK extends GenConfigKeys = "__default__"> = IntorGeneratedTypes extends void ? {
|
|
140
|
-
Locales: string;
|
|
141
|
-
Messages: LocaleMessages;
|
|
142
|
-
} : CK extends keyof IntorGeneratedTypes ? {
|
|
143
|
-
Locales: IntorGeneratedTypes[CK]["Locales"];
|
|
144
|
-
Messages: {
|
|
145
|
-
[K in IntorGeneratedTypes[CK]["Locales"]]: IntorGeneratedTypes[CK]["Messages"][typeof PREFIX_PLACEHOLDER];
|
|
146
|
-
};
|
|
147
|
-
} : never;
|
|
148
|
-
/** Extracts messages for a given config key */
|
|
149
|
-
type GenMessages<CK extends GenConfigKeys = "__default__"> = GenConfig<CK>["Messages"];
|
|
150
|
-
/** Extracts locales for a given config key */
|
|
151
|
-
type GenLocale<CK extends GenConfigKeys = "__default__"> = GenConfig<CK>["Locales"];
|
|
152
|
-
|
|
153
|
-
interface I18nContext {
|
|
154
|
-
locale: GenLocale;
|
|
155
|
-
pathname: string;
|
|
156
|
-
}
|
|
157
|
-
type GetI18nContext = (config: IntorResolvedConfig) => Promise<I18nContext>;
|
|
158
|
-
interface IntorResult {
|
|
159
|
-
config: IntorResolvedConfig;
|
|
160
|
-
initialLocale: Locale;
|
|
161
|
-
pathname: string;
|
|
162
|
-
messages: LocaleMessages;
|
|
163
|
-
}
|
|
164
|
-
|
|
165
|
-
/**
|
|
166
|
-
* Represents a collection of localized messages.
|
|
167
|
-
*
|
|
168
|
-
* - Each key is a namespace or message identifier, and the value is a
|
|
169
|
-
* `NestedMessage` object that can contain nested message structures.
|
|
170
|
-
*
|
|
171
|
-
* @example
|
|
172
|
-
* ```ts
|
|
173
|
-
* const messages: Messages = {
|
|
174
|
-
* ui: {
|
|
175
|
-
* greeting: "Hello",
|
|
176
|
-
* farewell: "Goodbye"
|
|
177
|
-
* },
|
|
178
|
-
* errors: {
|
|
179
|
-
* network: "Network error occurred"
|
|
180
|
-
* }
|
|
181
|
-
* };
|
|
182
|
-
* ```
|
|
183
|
-
*/
|
|
184
|
-
type Messages = Record<string, NestedMessage>;
|
|
185
|
-
/**
|
|
186
|
-
* A function that reads messages from a given file path.
|
|
187
|
-
*
|
|
188
|
-
* - This function is expected to return a `Promise` that resolves to a `Messages` object.
|
|
189
|
-
* - It can be implemented to support different file formats such as JSON, YAML, or others.
|
|
190
|
-
*
|
|
191
|
-
* @param filePath - The path to the message file to read.
|
|
192
|
-
* @returns A Promise that resolves to a `Messages` object.
|
|
193
|
-
*
|
|
194
|
-
* @example
|
|
195
|
-
* ```ts
|
|
196
|
-
* const reader: MessagesReader = async (filePath) => {
|
|
197
|
-
* const content = await fs.promises.readFile(filePath, "utf-8");
|
|
198
|
-
* return JSON.parse(content) as Messages;
|
|
199
|
-
* };
|
|
200
|
-
* ```
|
|
201
|
-
*/
|
|
202
|
-
type MessagesReader = (filePath: string) => Promise<Messages>;
|
|
203
|
-
|
|
204
|
-
type LoadMessagesOptions = {
|
|
205
|
-
config: IntorResolvedConfig;
|
|
206
|
-
locale: Locale;
|
|
207
|
-
pathname?: string;
|
|
208
|
-
extraOptions?: {
|
|
209
|
-
exts?: string[];
|
|
210
|
-
messagesReader?: MessagesReader;
|
|
211
|
-
};
|
|
212
|
-
allowCacheWrite?: boolean;
|
|
213
|
-
};
|
|
214
|
-
type LoadMessagesResult<C extends GenConfigKeys = "__default__"> = Promise<GenMessages<C> | undefined>;
|
|
215
|
-
|
|
216
|
-
/**
|
|
217
|
-
* Load messages for a given locale and pathname.
|
|
218
|
-
*
|
|
219
|
-
* - Resolve namespaces based on config and pathname.
|
|
220
|
-
* - Support both **local local** and **remote API** loaders.
|
|
221
|
-
* - Apply fallback locales if needed.
|
|
222
|
-
* - Cache messages if enabled (handled by underlying loader, not this function directly).
|
|
223
|
-
*/
|
|
224
|
-
declare const loadMessages: <C extends GenConfigKeys = "__default__">({ config, locale, pathname, extraOptions: { exts, messagesReader }, allowCacheWrite, }: LoadMessagesOptions) => LoadMessagesResult<C>;
|
|
225
|
-
|
|
226
|
-
/**
|
|
227
|
-
* Global messages pool (cross-module + hot-reload safe)
|
|
228
|
-
*/
|
|
229
|
-
type MessagesPool = Keyv<LocaleMessages>;
|
|
230
|
-
declare global {
|
|
231
|
-
var __INTOR_MESSAGES_POOL__: MessagesPool | undefined;
|
|
232
|
-
}
|
|
233
|
-
/**
|
|
234
|
-
* Optional: clear all cache
|
|
235
|
-
* Useful in tests or dynamic reloads.
|
|
236
|
-
*/
|
|
237
|
-
declare function clearMessagesPool(): void;
|
|
238
|
-
|
|
239
|
-
interface LoadLocalMessagesOptions {
|
|
240
|
-
pool?: MessagesPool;
|
|
241
|
-
rootDir?: string;
|
|
242
|
-
locale: string;
|
|
243
|
-
fallbackLocales?: string[];
|
|
244
|
-
namespaces?: string[];
|
|
245
|
-
extraOptions?: {
|
|
246
|
-
concurrency?: number;
|
|
247
|
-
cacheOptions?: CacheResolvedOptions;
|
|
248
|
-
loggerOptions?: LoggerOptions & {
|
|
249
|
-
id?: string;
|
|
250
|
-
};
|
|
251
|
-
exts?: string[];
|
|
252
|
-
messagesReader?: MessagesReader;
|
|
253
|
-
};
|
|
254
|
-
allowCacheWrite?: boolean;
|
|
255
|
-
}
|
|
256
|
-
|
|
257
|
-
/**
|
|
258
|
-
* Load local messages from the file system.
|
|
259
|
-
*
|
|
260
|
-
* - Load messages for a target locale with optional fallback locales.
|
|
261
|
-
* - Support filtering by specific namespaces.
|
|
262
|
-
* - Cache messages if enabled.
|
|
263
|
-
* - Limit concurrent file reads for performance.
|
|
264
|
-
*/
|
|
265
|
-
declare const loadLocalMessages: ({ pool, rootDir, locale, fallbackLocales, namespaces, extraOptions: { concurrency, cacheOptions, loggerOptions, exts, messagesReader, }, allowCacheWrite, }: LoadLocalMessagesOptions) => Promise<LocaleMessages | undefined>;
|
|
266
|
-
|
|
267
|
-
interface LoadRemoteMessagesOptions {
|
|
268
|
-
pool?: MessagesPool;
|
|
269
|
-
rootDir?: string;
|
|
270
|
-
locale: string;
|
|
271
|
-
fallbackLocales: string[];
|
|
272
|
-
namespaces?: string[];
|
|
273
|
-
remoteUrl: string;
|
|
274
|
-
remoteHeaders?: RemoteHeaders;
|
|
275
|
-
extraOptions?: {
|
|
276
|
-
cacheOptions?: CacheResolvedOptions;
|
|
277
|
-
loggerOptions?: LoggerOptions & {
|
|
278
|
-
id?: string;
|
|
279
|
-
};
|
|
280
|
-
};
|
|
281
|
-
allowCacheWrite?: boolean;
|
|
282
|
-
}
|
|
283
|
-
|
|
284
|
-
/**
|
|
285
|
-
* Load locale messages from a remote API.
|
|
286
|
-
*
|
|
287
|
-
* - Fetch messages for a target locale with optional fallback locales.
|
|
288
|
-
* - Cache messages if enabled.
|
|
289
|
-
*/
|
|
290
|
-
declare const loadRemoteMessages: ({ pool, rootDir, remoteUrl, remoteHeaders, locale, fallbackLocales, namespaces, extraOptions: { cacheOptions, loggerOptions, }, allowCacheWrite, }: LoadRemoteMessagesOptions) => Promise<LocaleMessages | undefined>;
|
|
291
|
-
|
|
292
|
-
/**
|
|
293
|
-
* Entry point for initializing Intor.
|
|
294
|
-
*
|
|
295
|
-
* 1. Resolve context via adapter or fallback values.
|
|
296
|
-
* 2. Load messages if loader is enabled.
|
|
297
|
-
* 3. Merge static messages with loaded messages.
|
|
298
|
-
*/
|
|
299
|
-
declare const intor: (config: IntorResolvedConfig, i18nContext: GetI18nContext | Partial<I18nContext>, loadMessagesOptions?: {
|
|
300
|
-
exts?: string[];
|
|
301
|
-
messagesReader?: MessagesReader;
|
|
302
|
-
}) => Promise<IntorResult>;
|
|
303
|
-
|
|
304
|
-
/** Base properties shared by all translator instances. */
|
|
305
|
-
interface TranslatorBaseProps<M = unknown> {
|
|
306
|
-
/** `messages`: The message object containing all translations. */
|
|
307
|
-
messages: M;
|
|
308
|
-
/** Current locale in use. */
|
|
309
|
-
locale: Locale<M>;
|
|
310
|
-
}
|
|
311
|
-
/** Properties specific to client-side translator behavior. */
|
|
312
|
-
interface TranslatorClientProps<M = unknown> {
|
|
313
|
-
/** `isLoading`: Indicates whether translations are currently loading. */
|
|
314
|
-
isLoading: boolean;
|
|
315
|
-
/** `setLocale`: Function to update the current locale. */
|
|
316
|
-
setLocale: (locale: Locale<M>) => void;
|
|
317
|
-
}
|
|
318
|
-
/**
|
|
319
|
-
* Conditional key type for TranslatorInstance.
|
|
320
|
-
* - Resolves to `ScopedLeafKeys` if a pre-key `PK` is provided,
|
|
321
|
-
* otherwise resolves to `LocalizedLeafKeys`.
|
|
322
|
-
*/
|
|
323
|
-
type Key<M, PK> = IfGen<PK extends string ? ScopedLeafKeys<M, PK> : LocalizedLeafKeys<M>, string>;
|
|
324
|
-
/**
|
|
325
|
-
* Translator instance type.
|
|
326
|
-
* Combines base props, client props, and core translation methods.
|
|
327
|
-
*/
|
|
328
|
-
type TranslatorInstance<M, PK extends string | undefined = undefined> = {
|
|
329
|
-
/** Check if a given key exists in the messages. */
|
|
330
|
-
hasKey: (key?: Key<M, PK>, targetLocale?: Locale<M>) => boolean;
|
|
331
|
-
/** Translate a given key into its string representation. */
|
|
332
|
-
t: <Result = string>(key?: Key<M, PK>, replacements?: Replacement) => Result;
|
|
333
|
-
} & TranslatorBaseProps<M> & TranslatorClientProps<M>;
|
|
334
|
-
|
|
335
|
-
/**
|
|
336
|
-
* Create a translator instance for a specific locale and pathname
|
|
337
|
-
*
|
|
338
|
-
* - Loads messages using the provided config, locale, and pathname.
|
|
339
|
-
* - Initializes a translator with `t`, `hasKey`, and optional scoped methods.
|
|
340
|
-
* - Supports optional `preKey` to create a scoped translator for nested keys.
|
|
341
|
-
*/
|
|
342
|
-
declare function getTranslator<CK extends GenConfigKeys = "__default__">(options: {
|
|
343
|
-
config: IntorResolvedConfig;
|
|
344
|
-
locale: GenLocale;
|
|
345
|
-
pathname?: string;
|
|
346
|
-
handlers?: TranslateHandlers;
|
|
347
|
-
extraOptions?: {
|
|
348
|
-
exts?: string[];
|
|
349
|
-
messagesReader?: MessagesReader;
|
|
350
|
-
};
|
|
351
|
-
}): Promise<TranslatorInstance<GenMessages<CK>>>;
|
|
352
|
-
declare function getTranslator<CK extends GenConfigKeys = "__default__", PK extends string = LocalizedNodeKeys<GenMessages<CK>>>(options: {
|
|
353
|
-
config: IntorResolvedConfig;
|
|
354
|
-
locale: GenLocale;
|
|
355
|
-
pathname?: string;
|
|
356
|
-
handlers?: TranslateHandlers;
|
|
357
|
-
extraOptions?: {
|
|
358
|
-
exts?: string[];
|
|
359
|
-
messagesReader?: MessagesReader;
|
|
360
|
-
};
|
|
361
|
-
preKey?: PK;
|
|
362
|
-
}): Promise<TranslatorInstance<GenMessages<CK>, PK>>;
|
|
363
|
-
|
|
364
|
-
/**
|
|
365
|
-
* Global logger pool (cross-module + hot-reload safe)
|
|
366
|
-
*/
|
|
367
|
-
type LoggerPool = Map<string, Logger>;
|
|
368
|
-
declare global {
|
|
369
|
-
var __INTOR_LOGGER_POOL__: LoggerPool | undefined;
|
|
370
|
-
}
|
|
371
|
-
/**
|
|
372
|
-
* Optional: clear all cache
|
|
373
|
-
* Useful in tests or dynamic reloads.
|
|
374
|
-
*/
|
|
375
|
-
declare function clearLoggerPool(): void;
|
|
376
|
-
|
|
377
|
-
export { type I18nContext, type IntorResult, type LoadLocalMessagesOptions, type LoadRemoteMessagesOptions, type Messages, type MessagesReader, clearLoggerPool, clearMessagesPool, getTranslator, intor, loadLocalMessages, loadMessages, loadRemoteMessages };
|