intor 2.5.0 → 2.6.0
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/LICENSE +1 -1
- package/README.md +1 -1
- package/dist/core/export/index.js +1 -0
- package/dist/core/src/client/shared/helpers/get-client-locale.js +5 -20
- package/dist/core/src/client/shared/utils/locale/detect-browser-locale.js +2 -8
- package/dist/core/src/client/shared/utils/locale/get-locale-from-cookie.js +5 -12
- package/dist/core/src/config/constants/cookie.js +9 -9
- package/dist/core/src/config/constants/routing.js +13 -14
- package/dist/core/src/config/define-intor-config.js +28 -44
- package/dist/core/src/config/resolvers/resolve-cookie-options.js +4 -4
- package/dist/core/src/config/resolvers/resolve-fallback-locales.js +33 -50
- package/dist/core/src/config/resolvers/resolve-routing-options.js +32 -61
- package/dist/core/src/config/validators/validate-default-locale.js +8 -13
- package/dist/core/src/config/validators/validate-id.js +8 -13
- package/dist/core/src/config/validators/validate-supported-locales.js +8 -13
- package/dist/core/src/core/constants/locale-placeholder.js +0 -1
- package/dist/core/src/core/error/intor-error.js +14 -29
- package/dist/core/src/core/locale/canonicalize-locale.js +7 -18
- package/dist/core/src/core/locale/match-locale.js +24 -50
- package/dist/core/src/core/locale/parse-locale.js +12 -22
- package/dist/core/src/core/logger/get-logger.js +26 -31
- package/dist/core/src/core/logger/global-logger-pool.js +4 -4
- package/dist/core/src/core/messages/internal-metadata.js +1 -1
- package/dist/core/src/core/messages/load-remote-messages/collect-remote-resources.js +13 -22
- package/dist/core/src/core/messages/load-remote-messages/fetch-remote-resource.js +30 -39
- package/dist/core/src/core/messages/load-remote-messages/load-remote-messages.js +72 -89
- package/dist/core/src/core/messages/load-remote-messages/resolve-remote-resources.js +7 -17
- package/dist/core/src/core/messages/merge-messages.js +17 -28
- package/dist/core/src/core/messages/utils/is-valid-messages.js +22 -37
- package/dist/core/src/core/messages/utils/nest-object-from-path.js +5 -17
- package/dist/core/src/core/render/create-html-renderer.js +29 -37
- package/dist/core/src/core/render/utils/escape-html.js +1 -6
- package/dist/core/src/core/render/utils/render-attributes.js +6 -11
- package/dist/core/src/core/translator/create-t-rich.js +6 -15
- package/dist/core/src/core/translator/create-translator.js +16 -24
- package/dist/core/src/core/utils/deep-merge.js +24 -42
- package/dist/core/src/core/utils/normalizers/normalize-cache-key.js +14 -40
- package/dist/core/src/core/utils/normalizers/normalize-pathname.js +19 -37
- package/dist/core/src/core/utils/normalizers/normalize-query.js +6 -20
- package/dist/core/src/core/utils/parse-cookie-header.js +11 -18
- package/dist/core/src/core/utils/resolve-loader-options.js +6 -32
- package/dist/core/src/edge/helpers/get-translator.js +14 -20
- package/dist/core/src/edge/translator/init-translator.js +23 -31
- package/dist/core/src/routing/inbound/helpers/resolve-inbound-from-request.js +21 -28
- package/dist/core/src/routing/inbound/resolve-inbound.js +22 -37
- package/dist/core/src/routing/inbound/resolve-locale/resolve-locale.js +22 -39
- package/dist/core/src/routing/inbound/resolve-pathname/resolve-pathname.js +24 -30
- package/dist/core/src/routing/inbound/resolve-pathname/strategies/all.js +10 -23
- package/dist/core/src/routing/inbound/resolve-pathname/strategies/except-default.js +11 -24
- package/dist/core/src/routing/inbound/resolve-pathname/strategies/none.js +1 -4
- package/dist/core/src/routing/locale/get-locale-from-accept-language.js +21 -36
- package/dist/core/src/routing/locale/get-locale-from-host.js +5 -28
- package/dist/core/src/routing/locale/get-locale-from-pathname.js +11 -37
- package/dist/core/src/routing/locale/get-locale-from-query.js +2 -17
- package/dist/core/src/routing/pathname/canonicalize-pathname.js +25 -67
- package/dist/core/src/routing/pathname/localize-pathname.js +12 -30
- package/dist/core/src/routing/pathname/materialize-pathname.js +9 -44
- package/dist/core/src/routing/pathname/standardize-pathname.js +6 -30
- package/dist/core/src/server/helpers/get-translator.js +26 -23
- package/dist/core/src/server/intor/intor.js +20 -25
- package/dist/core/src/server/messages/load-local-messages/cache/messages-pool.js +4 -7
- package/dist/core/src/server/messages/load-local-messages/load-local-messages.js +76 -92
- package/dist/core/src/server/messages/load-local-messages/read-locale-messages/collect-file-entries/collect-file-entries.js +59 -80
- package/dist/core/src/server/messages/load-local-messages/read-locale-messages/parse-file-entries/parse-file-entries.js +53 -87
- package/dist/core/src/server/messages/load-local-messages/read-locale-messages/parse-file-entries/utils/json-reader.js +3 -6
- package/dist/core/src/server/messages/load-local-messages/read-locale-messages/read-locale-messages.js +23 -35
- package/dist/core/src/server/messages/load-messages.js +56 -69
- package/dist/core/src/server/translator/init-translator.js +28 -30
- package/dist/express/src/adapters/express/create-intor-handler.js +35 -46
- package/dist/express/src/adapters/express/get-translator.js +2 -9
- package/dist/express/src/core/constants/locale-placeholder.js +0 -1
- package/dist/express/src/core/locale/canonicalize-locale.js +7 -18
- package/dist/express/src/core/locale/match-locale.js +24 -50
- package/dist/express/src/core/locale/parse-locale.js +12 -22
- package/dist/express/src/core/utils/normalizers/normalize-pathname.js +19 -37
- package/dist/express/src/core/utils/normalizers/normalize-query.js +6 -20
- package/dist/express/src/core/utils/parse-cookie-header.js +11 -18
- package/dist/express/src/routing/inbound/resolve-inbound.js +22 -37
- package/dist/express/src/routing/inbound/resolve-locale/resolve-locale.js +22 -39
- package/dist/express/src/routing/inbound/resolve-pathname/resolve-pathname.js +24 -30
- package/dist/express/src/routing/inbound/resolve-pathname/strategies/all.js +10 -23
- package/dist/express/src/routing/inbound/resolve-pathname/strategies/except-default.js +11 -24
- package/dist/express/src/routing/inbound/resolve-pathname/strategies/none.js +1 -4
- package/dist/express/src/routing/locale/get-locale-from-accept-language.js +21 -36
- package/dist/express/src/routing/locale/get-locale-from-host.js +5 -28
- package/dist/express/src/routing/locale/get-locale-from-pathname.js +11 -37
- package/dist/express/src/routing/locale/get-locale-from-query.js +2 -17
- package/dist/express/src/routing/pathname/canonicalize-pathname.js +25 -67
- package/dist/express/src/routing/pathname/localize-pathname.js +12 -30
- package/dist/express/src/routing/pathname/materialize-pathname.js +9 -44
- package/dist/express/src/routing/pathname/standardize-pathname.js +6 -30
- package/dist/fastify/src/adapters/fastify/create-intor-handler.js +35 -47
- package/dist/fastify/src/adapters/fastify/get-translator.js +2 -9
- package/dist/fastify/src/adapters/fastify/intor-fastify-plugin.js +29 -38
- package/dist/fastify/src/core/constants/locale-placeholder.js +0 -1
- package/dist/fastify/src/core/locale/canonicalize-locale.js +7 -18
- package/dist/fastify/src/core/locale/match-locale.js +24 -50
- package/dist/fastify/src/core/locale/parse-locale.js +12 -22
- package/dist/fastify/src/core/utils/normalizers/normalize-pathname.js +19 -37
- package/dist/fastify/src/core/utils/normalizers/normalize-query.js +6 -20
- package/dist/fastify/src/core/utils/parse-cookie-header.js +11 -18
- package/dist/fastify/src/routing/inbound/resolve-inbound.js +22 -37
- package/dist/fastify/src/routing/inbound/resolve-locale/resolve-locale.js +22 -39
- package/dist/fastify/src/routing/inbound/resolve-pathname/resolve-pathname.js +24 -30
- package/dist/fastify/src/routing/inbound/resolve-pathname/strategies/all.js +10 -23
- package/dist/fastify/src/routing/inbound/resolve-pathname/strategies/except-default.js +11 -24
- package/dist/fastify/src/routing/inbound/resolve-pathname/strategies/none.js +1 -4
- package/dist/fastify/src/routing/locale/get-locale-from-accept-language.js +21 -36
- package/dist/fastify/src/routing/locale/get-locale-from-host.js +5 -28
- package/dist/fastify/src/routing/locale/get-locale-from-pathname.js +11 -37
- package/dist/fastify/src/routing/locale/get-locale-from-query.js +2 -17
- package/dist/fastify/src/routing/pathname/canonicalize-pathname.js +25 -67
- package/dist/fastify/src/routing/pathname/localize-pathname.js +12 -30
- package/dist/fastify/src/routing/pathname/materialize-pathname.js +9 -44
- package/dist/fastify/src/routing/pathname/standardize-pathname.js +6 -30
- package/dist/hono/src/adapters/hono/create-intor-handler.js +33 -44
- package/dist/hono/src/adapters/hono/get-translator.js +2 -9
- package/dist/hono/src/core/constants/locale-placeholder.js +0 -1
- package/dist/hono/src/core/locale/canonicalize-locale.js +7 -18
- package/dist/hono/src/core/locale/match-locale.js +24 -50
- package/dist/hono/src/core/locale/parse-locale.js +12 -22
- package/dist/hono/src/core/utils/normalizers/normalize-pathname.js +19 -37
- package/dist/hono/src/core/utils/normalizers/normalize-query.js +6 -20
- package/dist/hono/src/core/utils/parse-cookie-header.js +11 -18
- package/dist/hono/src/routing/inbound/resolve-inbound.js +22 -37
- package/dist/hono/src/routing/inbound/resolve-locale/resolve-locale.js +22 -39
- package/dist/hono/src/routing/inbound/resolve-pathname/resolve-pathname.js +24 -30
- package/dist/hono/src/routing/inbound/resolve-pathname/strategies/all.js +10 -23
- package/dist/hono/src/routing/inbound/resolve-pathname/strategies/except-default.js +11 -24
- package/dist/hono/src/routing/inbound/resolve-pathname/strategies/none.js +1 -4
- package/dist/hono/src/routing/locale/get-locale-from-accept-language.js +21 -36
- package/dist/hono/src/routing/locale/get-locale-from-host.js +5 -28
- package/dist/hono/src/routing/locale/get-locale-from-pathname.js +11 -37
- package/dist/hono/src/routing/locale/get-locale-from-query.js +2 -17
- package/dist/hono/src/routing/pathname/canonicalize-pathname.js +25 -67
- package/dist/hono/src/routing/pathname/localize-pathname.js +12 -30
- package/dist/hono/src/routing/pathname/materialize-pathname.js +9 -44
- package/dist/hono/src/routing/pathname/standardize-pathname.js +6 -30
- package/dist/next/export/next/server/index.js +1 -0
- package/dist/next/src/adapters/next/create-intor-handler.js +39 -48
- package/dist/next/src/adapters/next/header-keys.js +9 -0
- package/dist/next/src/adapters/next/link.js +33 -28
- package/dist/next/src/adapters/next/redirect.js +12 -15
- package/dist/next/src/adapters/next/server/get-locale.js +13 -24
- package/dist/next/src/adapters/next/server/get-translator.js +2 -9
- package/dist/next/src/adapters/next/server/intor.js +5 -13
- package/dist/next/src/adapters/next/server/read-intor-url-state.js +13 -0
- package/dist/next/src/adapters/next/use-router.js +47 -66
- package/dist/next/src/client/shared/navigation/execute-navigation.js +20 -38
- package/dist/next/src/client/shared/utils/build-cookie-string.js +18 -27
- package/dist/next/src/client/shared/utils/locale/set-locale-cookie.js +2 -9
- package/dist/next/src/core/constants/locale-placeholder.js +0 -1
- package/dist/next/src/core/locale/canonicalize-locale.js +7 -18
- package/dist/next/src/core/locale/match-locale.js +24 -50
- package/dist/next/src/core/locale/parse-locale.js +12 -22
- package/dist/next/src/core/utils/normalizers/normalize-pathname.js +19 -37
- package/dist/next/src/core/utils/normalizers/normalize-query.js +6 -20
- package/dist/next/src/core/utils/resolve-loader-options.js +6 -29
- package/dist/next/src/policies/shoud-full-reload.js +2 -5
- package/dist/next/src/policies/should-sync-locale.js +1 -4
- package/dist/next/src/routing/inbound/resolve-inbound.js +24 -39
- package/dist/next/src/routing/inbound/resolve-locale/resolve-locale.js +22 -39
- package/dist/next/src/routing/inbound/resolve-pathname/resolve-pathname.js +24 -30
- package/dist/next/src/routing/inbound/resolve-pathname/strategies/all.js +13 -29
- package/dist/next/src/routing/inbound/resolve-pathname/strategies/except-default.js +14 -30
- package/dist/next/src/routing/inbound/resolve-pathname/strategies/none.js +1 -4
- package/dist/next/src/routing/locale/get-locale-from-accept-language.js +21 -36
- package/dist/next/src/routing/locale/get-locale-from-host.js +5 -28
- package/dist/next/src/routing/locale/get-locale-from-pathname.js +11 -37
- package/dist/next/src/routing/locale/get-locale-from-query.js +2 -17
- package/dist/next/src/routing/outbound/decide-strategy.js +9 -9
- package/dist/next/src/routing/outbound/determine-target.js +28 -44
- package/dist/next/src/routing/outbound/resolve-outbound.js +12 -16
- package/dist/next/src/routing/outbound/utils/derive-host-destination.js +5 -9
- package/dist/next/src/routing/outbound/utils/derive-query-destination.js +4 -7
- package/dist/next/src/routing/outbound/utils/is-external-destination.js +1 -7
- package/dist/next/src/routing/pathname/canonicalize-pathname.js +25 -67
- package/dist/next/src/routing/pathname/localize-pathname.js +12 -30
- package/dist/next/src/routing/pathname/materialize-pathname.js +9 -44
- package/dist/next/src/routing/pathname/standardize-pathname.js +6 -30
- package/dist/react/src/client/react/helpers/use-intor.js +25 -44
- package/dist/react/src/client/react/provider/effects/use-locale-effects.js +20 -25
- package/dist/react/src/client/react/provider/effects/use-messages-effects.js +17 -16
- package/dist/react/src/client/react/provider/intor-provider.js +63 -66
- package/dist/react/src/client/react/provider/use-intor-context.js +4 -4
- package/dist/react/src/client/react/render/create-react-renderer.js +18 -24
- package/dist/react/src/client/react/translator/create-t-rich.js +9 -22
- package/dist/react/src/client/react/translator/use-translator.js +11 -16
- package/dist/react/src/client/shared/messages/create-refetch-messages.js +41 -51
- package/dist/react/src/client/shared/provider/effective-state.js +2 -6
- package/dist/react/src/client/shared/utils/build-cookie-string.js +18 -27
- package/dist/react/src/client/shared/utils/locale/get-locale-from-cookie.js +5 -12
- package/dist/react/src/client/shared/utils/locale/set-document-locale.js +2 -8
- package/dist/react/src/client/shared/utils/locale/set-locale-cookie.js +2 -9
- package/dist/react/src/core/logger/get-logger.js +26 -31
- package/dist/react/src/core/logger/global-logger-pool.js +4 -4
- package/dist/react/src/core/messages/load-remote-messages/collect-remote-resources.js +13 -22
- package/dist/react/src/core/messages/load-remote-messages/fetch-remote-resource.js +30 -39
- package/dist/react/src/core/messages/load-remote-messages/load-remote-messages.js +72 -89
- package/dist/react/src/core/messages/load-remote-messages/resolve-remote-resources.js +7 -17
- package/dist/react/src/core/messages/merge-messages.js +17 -28
- package/dist/react/src/core/messages/utils/is-valid-messages.js +22 -37
- package/dist/react/src/core/messages/utils/nest-object-from-path.js +5 -17
- package/dist/react/src/core/utils/deep-merge.js +24 -42
- package/dist/react/src/core/utils/resolve-loader-options.js +6 -29
- package/dist/react/src/policies/should-persist-on-first-visit.js +1 -4
- package/dist/svelte/export/svelte/index.js +0 -6
- package/dist/svelte/src/client/shared/messages/create-refetch-messages.js +41 -51
- package/dist/svelte/src/client/shared/provider/effective-state.js +2 -6
- package/dist/svelte/src/client/shared/utils/build-cookie-string.js +18 -27
- package/dist/svelte/src/client/shared/utils/locale/get-locale-from-cookie.js +5 -12
- package/dist/svelte/src/client/shared/utils/locale/set-document-locale.js +2 -8
- package/dist/svelte/src/client/shared/utils/locale/set-locale-cookie.js +2 -9
- package/dist/svelte/src/client/svelte/provider/create-intor-store.js +59 -63
- package/dist/svelte/src/client/svelte/provider/effects/attach-locale-effects.js +20 -25
- package/dist/svelte/src/client/svelte/provider/effects/attach-messages-effects.js +21 -18
- package/dist/svelte/src/client/svelte/provider/get-intor-context.js +4 -4
- package/dist/svelte/src/client/svelte/translator/use-translator.js +11 -16
- package/dist/svelte/src/core/logger/get-logger.js +26 -31
- package/dist/svelte/src/core/logger/global-logger-pool.js +4 -4
- package/dist/svelte/src/core/messages/load-remote-messages/collect-remote-resources.js +13 -22
- package/dist/svelte/src/core/messages/load-remote-messages/fetch-remote-resource.js +30 -39
- package/dist/svelte/src/core/messages/load-remote-messages/load-remote-messages.js +72 -89
- package/dist/svelte/src/core/messages/load-remote-messages/resolve-remote-resources.js +7 -17
- package/dist/svelte/src/core/messages/merge-messages.js +17 -28
- package/dist/svelte/src/core/messages/utils/is-valid-messages.js +22 -37
- package/dist/svelte/src/core/messages/utils/nest-object-from-path.js +5 -17
- package/dist/svelte/src/core/render/create-html-renderer.js +29 -37
- package/dist/svelte/src/core/render/utils/escape-html.js +1 -6
- package/dist/svelte/src/core/render/utils/render-attributes.js +6 -11
- package/dist/svelte/src/core/translator/create-t-rich.js +6 -15
- package/dist/svelte/src/core/utils/deep-merge.js +24 -42
- package/dist/svelte/src/core/utils/resolve-loader-options.js +6 -29
- package/dist/svelte/src/policies/should-persist-on-first-visit.js +1 -4
- package/dist/svelte-kit/src/adapters/svelte-kit/create-intor-handler.js +37 -57
- package/dist/svelte-kit/src/adapters/svelte-kit/use-navigation.js +29 -27
- package/dist/svelte-kit/src/adapters/svelte-kit/utils/is-svelte-kit-ssg.js +4 -11
- package/dist/svelte-kit/src/client/shared/navigation/execute-navigation.js +19 -37
- package/dist/svelte-kit/src/client/shared/utils/build-cookie-string.js +18 -27
- package/dist/svelte-kit/src/client/shared/utils/locale/set-locale-cookie.js +2 -9
- package/dist/svelte-kit/src/core/constants/locale-placeholder.js +0 -1
- package/dist/svelte-kit/src/core/locale/canonicalize-locale.js +7 -18
- package/dist/svelte-kit/src/core/locale/match-locale.js +24 -50
- package/dist/svelte-kit/src/core/locale/parse-locale.js +12 -22
- package/dist/svelte-kit/src/core/utils/normalizers/normalize-pathname.js +19 -37
- package/dist/svelte-kit/src/core/utils/normalizers/normalize-query.js +6 -20
- package/dist/svelte-kit/src/core/utils/resolve-loader-options.js +6 -29
- package/dist/svelte-kit/src/policies/shoud-full-reload.js +2 -5
- package/dist/svelte-kit/src/policies/should-sync-locale.js +1 -4
- package/dist/svelte-kit/src/routing/inbound/resolve-inbound.js +22 -37
- package/dist/svelte-kit/src/routing/inbound/resolve-locale/resolve-locale.js +22 -39
- package/dist/svelte-kit/src/routing/inbound/resolve-pathname/resolve-pathname.js +24 -30
- package/dist/svelte-kit/src/routing/inbound/resolve-pathname/strategies/all.js +10 -23
- package/dist/svelte-kit/src/routing/inbound/resolve-pathname/strategies/except-default.js +11 -24
- package/dist/svelte-kit/src/routing/inbound/resolve-pathname/strategies/none.js +1 -4
- package/dist/svelte-kit/src/routing/locale/get-locale-from-accept-language.js +21 -36
- package/dist/svelte-kit/src/routing/locale/get-locale-from-host.js +5 -28
- package/dist/svelte-kit/src/routing/locale/get-locale-from-pathname.js +11 -37
- package/dist/svelte-kit/src/routing/locale/get-locale-from-query.js +2 -17
- package/dist/svelte-kit/src/routing/outbound/decide-strategy.js +9 -9
- package/dist/svelte-kit/src/routing/outbound/determine-target.js +28 -44
- package/dist/svelte-kit/src/routing/outbound/resolve-outbound.js +12 -16
- package/dist/svelte-kit/src/routing/outbound/utils/derive-host-destination.js +5 -9
- package/dist/svelte-kit/src/routing/outbound/utils/derive-query-destination.js +4 -7
- package/dist/svelte-kit/src/routing/outbound/utils/is-external-destination.js +1 -7
- package/dist/svelte-kit/src/routing/pathname/canonicalize-pathname.js +25 -67
- package/dist/svelte-kit/src/routing/pathname/localize-pathname.js +12 -30
- package/dist/svelte-kit/src/routing/pathname/materialize-pathname.js +9 -44
- package/dist/svelte-kit/src/routing/pathname/standardize-pathname.js +6 -30
- package/dist/types/export/index.d.ts +1 -1
- package/dist/types/export/index.d.ts.map +1 -1
- package/dist/types/export/next/server/index.d.ts +1 -1
- package/dist/types/export/next/server/index.d.ts.map +1 -1
- package/dist/types/src/adapters/fastify/intor-fastify-plugin.d.ts.map +1 -1
- package/dist/types/src/adapters/next/create-intor-handler.d.ts.map +1 -1
- package/dist/types/src/{core/constants/headers.d.ts → adapters/next/header-keys.d.ts} +3 -2
- package/dist/types/src/adapters/next/header-keys.d.ts.map +1 -0
- package/dist/types/src/adapters/next/server/get-locale.d.ts.map +1 -1
- package/dist/types/src/adapters/next/server/index.d.ts +1 -0
- package/dist/types/src/adapters/next/server/index.d.ts.map +1 -1
- package/dist/types/src/adapters/next/server/read-intor-url-state.d.ts +13 -0
- package/dist/types/src/adapters/next/server/read-intor-url-state.d.ts.map +1 -0
- package/dist/types/src/core/constants/index.d.ts +0 -1
- package/dist/types/src/core/constants/index.d.ts.map +1 -1
- package/dist/types/src/core/constants/locale-placeholder.d.ts +5 -0
- package/dist/types/src/core/constants/locale-placeholder.d.ts.map +1 -1
- package/dist/types/src/core/index.d.ts +1 -1
- package/dist/types/src/core/index.d.ts.map +1 -1
- package/dist/types/src/edge/translator/init-translator.d.ts.map +1 -1
- package/dist/types/src/routing/outbound/decide-strategy.d.ts +1 -1
- package/dist/types/src/routing/outbound/decide-strategy.d.ts.map +1 -1
- package/dist/types/src/server/translator/init-translator.d.ts.map +1 -1
- package/dist/vue/src/client/shared/messages/create-refetch-messages.js +41 -51
- package/dist/vue/src/client/shared/provider/effective-state.js +2 -6
- package/dist/vue/src/client/shared/utils/build-cookie-string.js +18 -27
- package/dist/vue/src/client/shared/utils/locale/get-locale-from-cookie.js +5 -12
- package/dist/vue/src/client/shared/utils/locale/set-document-locale.js +2 -8
- package/dist/vue/src/client/shared/utils/locale/set-locale-cookie.js +2 -9
- package/dist/vue/src/client/vue/helpers/use-intor.js +20 -42
- package/dist/vue/src/client/vue/provider/effects/use-locale-effects.js +23 -24
- package/dist/vue/src/client/vue/provider/effects/use-messages-effects.js +15 -24
- package/dist/vue/src/client/vue/provider/inject-intor-context.js +4 -4
- package/dist/vue/src/client/vue/provider/intor-provider.js +61 -66
- package/dist/vue/src/client/vue/render/create-vue-renderer.js +18 -24
- package/dist/vue/src/client/vue/translator/create-t-rich.js +5 -17
- package/dist/vue/src/client/vue/translator/trans.js +24 -31
- package/dist/vue/src/client/vue/translator/use-translator.js +12 -17
- package/dist/vue/src/core/logger/get-logger.js +26 -31
- package/dist/vue/src/core/logger/global-logger-pool.js +4 -4
- package/dist/vue/src/core/messages/load-remote-messages/collect-remote-resources.js +13 -22
- package/dist/vue/src/core/messages/load-remote-messages/fetch-remote-resource.js +30 -39
- package/dist/vue/src/core/messages/load-remote-messages/load-remote-messages.js +72 -89
- package/dist/vue/src/core/messages/load-remote-messages/resolve-remote-resources.js +7 -17
- package/dist/vue/src/core/messages/merge-messages.js +17 -28
- package/dist/vue/src/core/messages/utils/is-valid-messages.js +22 -37
- package/dist/vue/src/core/messages/utils/nest-object-from-path.js +5 -17
- package/dist/vue/src/core/utils/deep-merge.js +24 -42
- package/dist/vue/src/core/utils/resolve-loader-options.js +6 -29
- package/dist/vue/src/policies/should-persist-on-first-visit.js +1 -4
- package/package.json +53 -65
- package/dist/next/src/core/constants/headers.js +0 -8
- package/dist/types/src/core/constants/headers.d.ts.map +0 -1
|
@@ -4,57 +4,47 @@ import { loadRemoteMessages } from '../../../core/messages/load-remote-messages/
|
|
|
4
4
|
import { mergeMessages } from '../../../core/messages/merge-messages.js';
|
|
5
5
|
import 'intor-translator';
|
|
6
6
|
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
}
|
|
49
|
-
}
|
|
50
|
-
finally {
|
|
51
|
-
// Clear loading state only if this request is still the active one
|
|
52
|
-
if (controller === currentController &&
|
|
53
|
-
!currentController.signal.aborted) {
|
|
54
|
-
onLoadingEnd?.();
|
|
55
|
-
}
|
|
56
|
-
}
|
|
57
|
-
};
|
|
7
|
+
const createRefetchMessages = ({
|
|
8
|
+
config,
|
|
9
|
+
onLoadingStart,
|
|
10
|
+
onLoadingEnd,
|
|
11
|
+
onMessages
|
|
12
|
+
}) => {
|
|
13
|
+
let controller = null;
|
|
14
|
+
return async function refetchMessages(newLocale) {
|
|
15
|
+
const loader = resolveLoaderOptions(config);
|
|
16
|
+
if (!loader || loader.mode !== "remote") return;
|
|
17
|
+
const { namespaces, concurrency, url, headers } = loader;
|
|
18
|
+
controller?.abort();
|
|
19
|
+
const currentController = new AbortController();
|
|
20
|
+
controller = currentController;
|
|
21
|
+
onLoadingStart?.();
|
|
22
|
+
try {
|
|
23
|
+
const loadedMessages = await loadRemoteMessages({
|
|
24
|
+
locale: newLocale,
|
|
25
|
+
fallbackLocales: config.fallbackLocales[newLocale] || [],
|
|
26
|
+
...namespaces !== void 0 ? { namespaces } : {},
|
|
27
|
+
...concurrency !== void 0 ? { concurrency } : {},
|
|
28
|
+
fetch: globalThis.fetch,
|
|
29
|
+
url,
|
|
30
|
+
...headers !== void 0 ? { headers } : {},
|
|
31
|
+
signal: currentController.signal,
|
|
32
|
+
loggerOptions: config.logger
|
|
33
|
+
});
|
|
34
|
+
if (controller === currentController && !currentController.signal.aborted) {
|
|
35
|
+
onMessages?.(
|
|
36
|
+
mergeMessages(config.messages, loadedMessages, {
|
|
37
|
+
config,
|
|
38
|
+
locale: newLocale
|
|
39
|
+
})
|
|
40
|
+
);
|
|
41
|
+
}
|
|
42
|
+
} finally {
|
|
43
|
+
if (controller === currentController && !currentController.signal.aborted) {
|
|
44
|
+
onLoadingEnd?.();
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
};
|
|
58
48
|
};
|
|
59
49
|
|
|
60
50
|
export { createRefetchMessages };
|
|
@@ -1,12 +1,8 @@
|
|
|
1
|
-
// runtime > external > config
|
|
2
|
-
// Always resolves to a non-null message object.
|
|
3
1
|
function resolveEffectiveMessages(runtime, external, configMessages) {
|
|
4
|
-
|
|
2
|
+
return runtime ?? external ?? configMessages ?? {};
|
|
5
3
|
}
|
|
6
|
-
// external > internal
|
|
7
|
-
// Loading is active if either source is truthy
|
|
8
4
|
function resolveEffectiveIsLoading(external, internal) {
|
|
9
|
-
|
|
5
|
+
return !!external || internal;
|
|
10
6
|
}
|
|
11
7
|
|
|
12
8
|
export { resolveEffectiveIsLoading, resolveEffectiveMessages };
|
|
@@ -1,31 +1,22 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Build a serialized cookie string.
|
|
3
|
-
*/
|
|
4
1
|
const buildCookieString = (cookieOptions, value) => {
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
}
|
|
24
|
-
// Add Secure flag if not explicitly disabled
|
|
25
|
-
if (secure !== false) {
|
|
26
|
-
parts.push(`Secure`);
|
|
27
|
-
}
|
|
28
|
-
return parts.join("; ");
|
|
2
|
+
const { name, maxAge, path, domain, sameSite, secure } = cookieOptions;
|
|
3
|
+
const parts = [`${name}=${encodeURIComponent(value)}`];
|
|
4
|
+
if (maxAge !== void 0) {
|
|
5
|
+
const expires = new Date(Date.now() + maxAge * 1e3).toUTCString();
|
|
6
|
+
parts.push(`expires=${expires}`, `max-age=${maxAge}`);
|
|
7
|
+
}
|
|
8
|
+
parts.push(`path=${path ?? "/"}`);
|
|
9
|
+
if (domain) {
|
|
10
|
+
parts.push(`domain=${domain}`);
|
|
11
|
+
}
|
|
12
|
+
if (sameSite) {
|
|
13
|
+
const normalized = sameSite.charAt(0).toUpperCase() + sameSite.slice(1).toLowerCase();
|
|
14
|
+
parts.push(`SameSite=${normalized}`);
|
|
15
|
+
}
|
|
16
|
+
if (secure !== false) {
|
|
17
|
+
parts.push(`Secure`);
|
|
18
|
+
}
|
|
19
|
+
return parts.join("; ");
|
|
29
20
|
};
|
|
30
21
|
|
|
31
22
|
export { buildCookieString };
|
|
@@ -1,16 +1,9 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Gets the locale value from the browser cookie.
|
|
3
|
-
*
|
|
4
|
-
* This function relies on `document.cookie`.
|
|
5
|
-
*/
|
|
6
1
|
function getLocaleFromCookie(cookieName) {
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
return undefined;
|
|
13
|
-
return decodeURIComponent(entry.slice(cookieName.length + 1));
|
|
2
|
+
if (typeof document === "undefined") return void 0;
|
|
3
|
+
const cookies = document.cookie.split(";").map((c) => c.trim());
|
|
4
|
+
const entry = cookies.find((c) => c.startsWith(`${cookieName}=`));
|
|
5
|
+
if (!entry) return void 0;
|
|
6
|
+
return decodeURIComponent(entry.slice(cookieName.length + 1));
|
|
14
7
|
}
|
|
15
8
|
|
|
16
9
|
export { getLocaleFromCookie };
|
|
@@ -1,12 +1,6 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Set the document language attribute.
|
|
3
|
-
*
|
|
4
|
-
* This function relies on `document.documentElement.lang`.
|
|
5
|
-
*/
|
|
6
1
|
function setDocumentLocale(locale) {
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
document.documentElement.lang = locale;
|
|
2
|
+
if (typeof document === "undefined") return;
|
|
3
|
+
document.documentElement.lang = locale;
|
|
10
4
|
}
|
|
11
5
|
|
|
12
6
|
export { setDocumentLocale };
|
|
@@ -1,15 +1,8 @@
|
|
|
1
1
|
import { buildCookieString } from '../build-cookie-string.js';
|
|
2
2
|
|
|
3
|
-
/**
|
|
4
|
-
* Persist locale to a cookie.
|
|
5
|
-
*
|
|
6
|
-
* This function relies on `document.cookie`.
|
|
7
|
-
*/
|
|
8
3
|
const setLocaleCookie = (cookieOptions, locale) => {
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
// Build and apply the cookie string
|
|
12
|
-
document.cookie = buildCookieString(cookieOptions, locale);
|
|
4
|
+
if (typeof document === "undefined") return;
|
|
5
|
+
document.cookie = buildCookieString(cookieOptions, locale);
|
|
13
6
|
};
|
|
14
7
|
|
|
15
8
|
export { setLocaleCookie };
|
|
@@ -2,41 +2,36 @@ import { logry } from 'logry';
|
|
|
2
2
|
import { getGlobalLoggerPool } from './global-logger-pool.js';
|
|
3
3
|
|
|
4
4
|
const DEFAULT_FORMAT_CONFIG = {
|
|
5
|
-
|
|
5
|
+
timestamp: { withDate: false }
|
|
6
6
|
};
|
|
7
7
|
const DEFAULT_RENDER_CONFIG = {
|
|
8
|
-
|
|
9
|
-
|
|
8
|
+
id: { visible: true, prefix: "<", suffix: ">" },
|
|
9
|
+
meta: { lineBreaksAfter: 1 }
|
|
10
10
|
};
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
pool.set(id, logger);
|
|
33
|
-
// Soft LRU: keep pool size under control
|
|
34
|
-
if (pool.size > 1000) {
|
|
35
|
-
for (const key of [...pool.keys()].slice(0, 200)) {
|
|
36
|
-
pool.delete(key);
|
|
37
|
-
}
|
|
11
|
+
function getLogger({
|
|
12
|
+
id = "default",
|
|
13
|
+
preset,
|
|
14
|
+
...options
|
|
15
|
+
}) {
|
|
16
|
+
const pool = getGlobalLoggerPool();
|
|
17
|
+
const existing = pool.get(id);
|
|
18
|
+
if (existing) return existing;
|
|
19
|
+
const baseConfig = preset === void 0 ? {
|
|
20
|
+
formatConfig: DEFAULT_FORMAT_CONFIG,
|
|
21
|
+
renderConfig: DEFAULT_RENDER_CONFIG
|
|
22
|
+
} : { preset };
|
|
23
|
+
const logger = logry({
|
|
24
|
+
id,
|
|
25
|
+
...baseConfig,
|
|
26
|
+
...options
|
|
27
|
+
});
|
|
28
|
+
pool.set(id, logger);
|
|
29
|
+
if (pool.size > 1e3) {
|
|
30
|
+
for (const key of [...pool.keys()].slice(0, 200)) {
|
|
31
|
+
pool.delete(key);
|
|
38
32
|
}
|
|
39
|
-
|
|
33
|
+
}
|
|
34
|
+
return logger;
|
|
40
35
|
}
|
|
41
36
|
|
|
42
37
|
export { getLogger };
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
function getGlobalLoggerPool() {
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
2
|
+
if (!globalThis.__INTOR_LOGGER_POOL__) {
|
|
3
|
+
globalThis.__INTOR_LOGGER_POOL__ = /* @__PURE__ */ new Map();
|
|
4
|
+
}
|
|
5
|
+
return globalThis.__INTOR_LOGGER_POOL__;
|
|
6
6
|
}
|
|
7
7
|
|
|
8
8
|
export { getGlobalLoggerPool };
|
|
@@ -1,25 +1,16 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
// When no namespaces are provided, the locale domain consists of index only
|
|
15
|
-
if (!namespaces || namespaces.length === 0)
|
|
16
|
-
return [indexResource];
|
|
17
|
-
// Namespace-specific resources are nested under their namespace key
|
|
18
|
-
const nsResources = namespaces.map((ns) => ({
|
|
19
|
-
url: `${basePath}/${ns}.json`,
|
|
20
|
-
path: [ns],
|
|
21
|
-
}));
|
|
22
|
-
return [indexResource, ...nsResources];
|
|
1
|
+
function collectRemoteResources({
|
|
2
|
+
locale,
|
|
3
|
+
baseUrl,
|
|
4
|
+
namespaces
|
|
5
|
+
}) {
|
|
6
|
+
const basePath = `${baseUrl}/${locale}`;
|
|
7
|
+
const indexResource = { url: `${basePath}/index.json`, path: [] };
|
|
8
|
+
if (!namespaces || namespaces.length === 0) return [indexResource];
|
|
9
|
+
const nsResources = namespaces.map((ns) => ({
|
|
10
|
+
url: `${basePath}/${ns}.json`,
|
|
11
|
+
path: [ns]
|
|
12
|
+
}));
|
|
13
|
+
return [indexResource, ...nsResources];
|
|
23
14
|
}
|
|
24
15
|
|
|
25
16
|
export { collectRemoteResources };
|
|
@@ -1,47 +1,38 @@
|
|
|
1
1
|
import { getLogger } from '../../logger/get-logger.js';
|
|
2
2
|
import { isValidMessages } from '../utils/is-valid-messages.js';
|
|
3
3
|
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
headers: { "Content-Type": "application/json", ...headers },
|
|
23
|
-
cache: "no-store",
|
|
24
|
-
...(signal !== undefined ? { signal } : {}),
|
|
25
|
-
});
|
|
26
|
-
if (!response.ok) {
|
|
27
|
-
throw new Error(`HTTP ${response.status} ${response.statusText}`);
|
|
28
|
-
}
|
|
29
|
-
// Parse JSON body
|
|
30
|
-
const data = (await response.json());
|
|
31
|
-
// Validate messages structure
|
|
32
|
-
if (!isValidMessages(data)) {
|
|
33
|
-
throw new Error("Invalid messages structure");
|
|
34
|
-
}
|
|
35
|
-
return data;
|
|
4
|
+
async function fetchRemoteResource({
|
|
5
|
+
fetch,
|
|
6
|
+
url,
|
|
7
|
+
headers,
|
|
8
|
+
signal,
|
|
9
|
+
loggerOptions
|
|
10
|
+
}) {
|
|
11
|
+
const baseLogger = getLogger(loggerOptions);
|
|
12
|
+
const logger = baseLogger.child({ scope: "fetch-locale-messages" });
|
|
13
|
+
try {
|
|
14
|
+
const response = await fetch(url, {
|
|
15
|
+
method: "GET",
|
|
16
|
+
headers: { "Content-Type": "application/json", ...headers },
|
|
17
|
+
cache: "no-store",
|
|
18
|
+
...signal !== void 0 ? { signal } : {}
|
|
19
|
+
});
|
|
20
|
+
if (!response.ok) {
|
|
21
|
+
throw new Error(`HTTP ${response.status} ${response.statusText}`);
|
|
36
22
|
}
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
return;
|
|
41
|
-
}
|
|
42
|
-
logger.warn("Failed to fetch remote messages.", { url, error });
|
|
43
|
-
return;
|
|
23
|
+
const data = await response.json();
|
|
24
|
+
if (!isValidMessages(data)) {
|
|
25
|
+
throw new Error("Invalid messages structure");
|
|
44
26
|
}
|
|
27
|
+
return data;
|
|
28
|
+
} catch (error) {
|
|
29
|
+
if (error instanceof Error && error.name === "AbortError") {
|
|
30
|
+
logger.debug("Remote fetch aborted.", { url });
|
|
31
|
+
return;
|
|
32
|
+
}
|
|
33
|
+
logger.warn("Failed to fetch remote messages.", { url, error });
|
|
34
|
+
return;
|
|
35
|
+
}
|
|
45
36
|
}
|
|
46
37
|
|
|
47
38
|
export { fetchRemoteResource };
|
|
@@ -4,98 +4,81 @@ import { collectRemoteResources } from './collect-remote-resources.js';
|
|
|
4
4
|
import { fetchRemoteResource } from './fetch-remote-resource.js';
|
|
5
5
|
import { resolveRemoteResources } from './resolve-remote-resources.js';
|
|
6
6
|
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
7
|
+
const loadRemoteMessages = async ({
|
|
8
|
+
locale,
|
|
9
|
+
fallbackLocales,
|
|
10
|
+
namespaces,
|
|
11
|
+
concurrency,
|
|
12
|
+
fetch,
|
|
13
|
+
url: baseUrl,
|
|
14
|
+
headers,
|
|
15
|
+
signal,
|
|
16
|
+
loggerOptions
|
|
17
|
+
}) => {
|
|
18
|
+
const baseLogger = getLogger(loggerOptions);
|
|
19
|
+
const logger = baseLogger.child({ scope: "load-remote-messages" });
|
|
20
|
+
if (signal?.aborted) {
|
|
21
|
+
logger.debug("Remote message loading aborted before fetch.");
|
|
22
|
+
return;
|
|
23
|
+
}
|
|
24
|
+
const start = performance.now();
|
|
25
|
+
logger.debug("Loading remote messages.", { baseUrl });
|
|
26
|
+
const limit = concurrency ? pLimit(concurrency) : void 0;
|
|
27
|
+
const candidateLocales = [locale, ...fallbackLocales || []];
|
|
28
|
+
let messages;
|
|
29
|
+
for (const candidateLocale of candidateLocales) {
|
|
30
|
+
const isLast = candidateLocale === candidateLocales[candidateLocales.length - 1];
|
|
31
|
+
try {
|
|
32
|
+
const resources = collectRemoteResources({
|
|
33
|
+
locale: candidateLocale,
|
|
34
|
+
baseUrl,
|
|
35
|
+
...namespaces !== void 0 ? { namespaces } : {}
|
|
36
|
+
});
|
|
37
|
+
const fetchUrl = (url) => fetchRemoteResource({
|
|
38
|
+
url,
|
|
39
|
+
...headers !== void 0 ? { headers } : {},
|
|
40
|
+
...signal !== void 0 ? { signal } : {},
|
|
41
|
+
loggerOptions,
|
|
42
|
+
fetch
|
|
43
|
+
});
|
|
44
|
+
const results = await Promise.all(
|
|
45
|
+
resources.map(
|
|
46
|
+
({ url }) => limit ? limit(() => fetchUrl(url)) : fetchUrl(url)
|
|
47
|
+
)
|
|
48
|
+
);
|
|
49
|
+
if (!results.some(Boolean)) continue;
|
|
50
|
+
const resolved = resolveRemoteResources(
|
|
51
|
+
resources.map((res, i) => {
|
|
52
|
+
const data = results[i];
|
|
53
|
+
return { path: res.path, ...data !== void 0 ? { data } : {} };
|
|
54
|
+
})
|
|
55
|
+
);
|
|
56
|
+
messages = { [candidateLocale]: resolved };
|
|
57
|
+
break;
|
|
58
|
+
} catch {
|
|
59
|
+
if (signal?.aborted) {
|
|
60
|
+
logger.debug("Remote message loading aborted.");
|
|
27
61
|
return;
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
// ----------------------------------------------------------------
|
|
34
|
-
const limit = concurrency ? pLimit(concurrency) : undefined;
|
|
35
|
-
const candidateLocales = [locale, ...(fallbackLocales || [])];
|
|
36
|
-
let messages;
|
|
37
|
-
for (const candidateLocale of candidateLocales) {
|
|
38
|
-
const isLast = candidateLocale === candidateLocales[candidateLocales.length - 1];
|
|
39
|
-
try {
|
|
40
|
-
// -----------------------------------------------------------------
|
|
41
|
-
// Collect remote message resources for the locale
|
|
42
|
-
// -----------------------------------------------------------------
|
|
43
|
-
const resources = collectRemoteResources({
|
|
44
|
-
locale: candidateLocale,
|
|
45
|
-
baseUrl,
|
|
46
|
-
...(namespaces !== undefined ? { namespaces } : {}),
|
|
47
|
-
});
|
|
48
|
-
// -----------------------------------------------------------------
|
|
49
|
-
// Fetch all message chunks in parallel
|
|
50
|
-
// -----------------------------------------------------------------
|
|
51
|
-
const fetchUrl = (url) => fetchRemoteResource({
|
|
52
|
-
url,
|
|
53
|
-
...(headers !== undefined ? { headers } : {}),
|
|
54
|
-
...(signal !== undefined ? { signal } : {}),
|
|
55
|
-
loggerOptions,
|
|
56
|
-
fetch,
|
|
57
|
-
});
|
|
58
|
-
const results = await Promise.all(resources.map(({ url }) => limit ? limit(() => fetchUrl(url)) : fetchUrl(url)));
|
|
59
|
-
// Guard: no valid remote resources
|
|
60
|
-
if (!results.some(Boolean))
|
|
61
|
-
continue;
|
|
62
|
-
// -----------------------------------------------------------------
|
|
63
|
-
// Resolve and merge remote message resources
|
|
64
|
-
// -----------------------------------------------------------------
|
|
65
|
-
const resolved = resolveRemoteResources(resources.map((res, i) => {
|
|
66
|
-
const data = results[i];
|
|
67
|
-
return { path: res.path, ...(data !== undefined ? { data } : {}) };
|
|
68
|
-
}));
|
|
69
|
-
// -----------------------------------------------------------------
|
|
70
|
-
// Wrap resolved messages into locale-scoped LocaleMessages
|
|
71
|
-
// -----------------------------------------------------------------
|
|
72
|
-
messages = { [candidateLocale]: resolved };
|
|
73
|
-
break;
|
|
74
|
-
}
|
|
75
|
-
catch {
|
|
76
|
-
if (signal?.aborted) {
|
|
77
|
-
logger.debug("Remote message loading aborted.");
|
|
78
|
-
return;
|
|
79
|
-
}
|
|
80
|
-
if (isLast) {
|
|
81
|
-
logger.warn("Failed to load messages for all candidate locales.", {
|
|
82
|
-
locale,
|
|
83
|
-
fallbackLocales,
|
|
84
|
-
});
|
|
85
|
-
}
|
|
86
|
-
else {
|
|
87
|
-
logger.warn(`Failed to load locale messages for "${candidateLocale}", trying next fallback.`);
|
|
88
|
-
}
|
|
89
|
-
}
|
|
90
|
-
}
|
|
91
|
-
// Final success log with resolved locale and timing
|
|
92
|
-
if (messages) {
|
|
93
|
-
logger.trace("Finished loading remote messages.", {
|
|
94
|
-
loadedLocale: Object.keys(messages)[0],
|
|
95
|
-
duration: `${Math.round(performance.now() - start)} ms`,
|
|
62
|
+
}
|
|
63
|
+
if (isLast) {
|
|
64
|
+
logger.warn("Failed to load messages for all candidate locales.", {
|
|
65
|
+
locale,
|
|
66
|
+
fallbackLocales
|
|
96
67
|
});
|
|
68
|
+
} else {
|
|
69
|
+
logger.warn(
|
|
70
|
+
`Failed to load locale messages for "${candidateLocale}", trying next fallback.`
|
|
71
|
+
);
|
|
72
|
+
}
|
|
97
73
|
}
|
|
98
|
-
|
|
74
|
+
}
|
|
75
|
+
if (messages) {
|
|
76
|
+
logger.trace("Finished loading remote messages.", {
|
|
77
|
+
loadedLocale: Object.keys(messages)[0],
|
|
78
|
+
duration: `${Math.round(performance.now() - start)} ms`
|
|
79
|
+
});
|
|
80
|
+
}
|
|
81
|
+
return messages;
|
|
99
82
|
};
|
|
100
83
|
|
|
101
84
|
export { loadRemoteMessages };
|
|
@@ -1,24 +1,14 @@
|
|
|
1
1
|
import { deepMerge } from '../../utils/deep-merge.js';
|
|
2
2
|
import { nestObjectFromPath } from '../utils/nest-object-from-path.js';
|
|
3
3
|
|
|
4
|
-
/**
|
|
5
|
-
* Resolve remote message resources into a single MessageObject.
|
|
6
|
-
*
|
|
7
|
-
* - Applies semantic nesting based on resource path
|
|
8
|
-
* - Merges all resolved message chunks
|
|
9
|
-
*
|
|
10
|
-
* Always returns a MessageObject.
|
|
11
|
-
* An empty object represents an empty translation domain.
|
|
12
|
-
*/
|
|
13
4
|
function resolveRemoteResources(resources) {
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
return result;
|
|
5
|
+
let result = {};
|
|
6
|
+
for (const { path, data } of resources) {
|
|
7
|
+
if (!data) continue;
|
|
8
|
+
const resolved = path.length > 0 ? nestObjectFromPath(path, data) : data;
|
|
9
|
+
result = deepMerge(result, resolved);
|
|
10
|
+
}
|
|
11
|
+
return result;
|
|
22
12
|
}
|
|
23
13
|
|
|
24
14
|
export { resolveRemoteResources };
|