@intlayer/docs 8.5.1 → 8.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/blog/ar/intlayer_with_i18next.md +1 -1
- package/blog/ar/intlayer_with_next-i18next.md +1 -1
- package/blog/ar/intlayer_with_next-intl.md +1 -1
- package/blog/ar/intlayer_with_react-i18next.md +1 -1
- package/blog/ar/intlayer_with_react-intl.md +1 -1
- package/blog/ar/intlayer_with_vue-i18n.md +1 -1
- package/blog/de/intlayer_with_i18next.md +1 -1
- package/blog/de/intlayer_with_next-i18next.md +1 -1
- package/blog/de/intlayer_with_next-intl.md +1 -1
- package/blog/de/intlayer_with_react-i18next.md +1 -1
- package/blog/de/intlayer_with_react-intl.md +1 -1
- package/blog/de/intlayer_with_vue-i18n.md +1 -1
- package/blog/en/intlayer_with_i18next.md +1 -1
- package/blog/en/intlayer_with_next-i18next.md +1 -1
- package/blog/en/intlayer_with_next-intl.md +1 -1
- package/blog/en/intlayer_with_react-i18next.md +1 -1
- package/blog/en/intlayer_with_react-intl.md +1 -1
- package/blog/en/intlayer_with_vue-i18n.md +1 -1
- package/blog/en-GB/intlayer_with_i18next.md +1 -1
- package/blog/en-GB/intlayer_with_next-i18next.md +1 -1
- package/blog/en-GB/intlayer_with_next-intl.md +1 -1
- package/blog/en-GB/intlayer_with_react-i18next.md +1 -1
- package/blog/en-GB/intlayer_with_react-intl.md +1 -1
- package/blog/en-GB/intlayer_with_vue-i18n.md +1 -1
- package/blog/es/intlayer_with_i18next.md +1 -1
- package/blog/es/intlayer_with_next-i18next.md +1 -1
- package/blog/es/intlayer_with_next-intl.md +1 -1
- package/blog/es/intlayer_with_react-i18next.md +1 -1
- package/blog/es/intlayer_with_react-intl.md +1 -1
- package/blog/es/intlayer_with_vue-i18n.md +1 -1
- package/blog/fr/intlayer_with_i18next.md +1 -1
- package/blog/fr/intlayer_with_next-i18next.md +1 -1
- package/blog/fr/intlayer_with_next-intl.md +1 -1
- package/blog/fr/intlayer_with_react-i18next.md +1 -1
- package/blog/fr/intlayer_with_react-intl.md +1 -1
- package/blog/fr/intlayer_with_vue-i18n.md +1 -1
- package/blog/hi/intlayer_with_i18next.md +1 -1
- package/blog/hi/intlayer_with_next-i18next.md +1 -1
- package/blog/hi/intlayer_with_next-intl.md +1 -1
- package/blog/hi/intlayer_with_react-i18next.md +1 -1
- package/blog/hi/intlayer_with_react-intl.md +1 -1
- package/blog/hi/intlayer_with_vue-i18n.md +1 -1
- package/blog/id/intlayer_with_i18next.md +1 -1
- package/blog/id/intlayer_with_next-i18next.md +1 -1
- package/blog/id/intlayer_with_next-intl.md +1 -1
- package/blog/id/intlayer_with_react-i18next.md +1 -1
- package/blog/id/intlayer_with_react-intl.md +1 -1
- package/blog/id/intlayer_with_vue-i18n.md +1 -1
- package/blog/it/intlayer_with_i18next.md +1 -1
- package/blog/it/intlayer_with_next-i18next.md +1 -1
- package/blog/it/intlayer_with_next-intl.md +1 -1
- package/blog/it/intlayer_with_react-i18next.md +1 -1
- package/blog/it/intlayer_with_react-intl.md +1 -1
- package/blog/it/intlayer_with_vue-i18n.md +1 -1
- package/blog/ja/intlayer_with_i18next.md +1 -1
- package/blog/ja/intlayer_with_next-i18next.md +1 -1
- package/blog/ja/intlayer_with_next-intl.md +1 -1
- package/blog/ja/intlayer_with_react-i18next.md +1 -1
- package/blog/ja/intlayer_with_react-intl.md +1 -1
- package/blog/ja/intlayer_with_vue-i18n.md +1 -1
- package/blog/ko/intlayer_with_i18next.md +1 -1
- package/blog/ko/intlayer_with_next-i18next.md +1 -1
- package/blog/ko/intlayer_with_next-intl.md +1 -1
- package/blog/ko/intlayer_with_react-i18next.md +1 -1
- package/blog/ko/intlayer_with_react-intl.md +1 -1
- package/blog/ko/intlayer_with_vue-i18n.md +1 -1
- package/blog/pl/intlayer_with_i18next.md +1 -1
- package/blog/pl/intlayer_with_next-i18next.md +1 -1
- package/blog/pl/intlayer_with_next-intl.md +1 -1
- package/blog/pl/intlayer_with_react-i18next.md +1 -1
- package/blog/pl/intlayer_with_react-intl.md +1 -1
- package/blog/pl/intlayer_with_vue-i18n.md +1 -1
- package/blog/pt/intlayer_with_i18next.md +1 -1
- package/blog/pt/intlayer_with_next-i18next.md +1 -1
- package/blog/pt/intlayer_with_next-intl.md +1 -1
- package/blog/pt/intlayer_with_react-i18next.md +1 -1
- package/blog/pt/intlayer_with_react-intl.md +1 -1
- package/blog/pt/intlayer_with_vue-i18n.md +1 -1
- package/blog/ru/intlayer_with_i18next.md +1 -1
- package/blog/ru/intlayer_with_next-i18next.md +1 -1
- package/blog/ru/intlayer_with_next-intl.md +1 -1
- package/blog/ru/intlayer_with_react-i18next.md +1 -1
- package/blog/ru/intlayer_with_react-intl.md +1 -1
- package/blog/ru/intlayer_with_vue-i18n.md +1 -1
- package/blog/tr/intlayer_with_i18next.md +1 -1
- package/blog/tr/intlayer_with_next-i18next.md +1 -1
- package/blog/tr/intlayer_with_next-intl.md +1 -1
- package/blog/tr/intlayer_with_react-i18next.md +1 -1
- package/blog/tr/intlayer_with_react-intl.md +1 -1
- package/blog/tr/intlayer_with_vue-i18n.md +1 -1
- package/blog/uk/intlayer_with_i18next.md +1 -1
- package/blog/uk/intlayer_with_next-i18next.md +1 -1
- package/blog/uk/intlayer_with_next-intl.md +1 -1
- package/blog/uk/intlayer_with_react-i18next.md +1 -1
- package/blog/uk/intlayer_with_react-intl.md +1 -1
- package/blog/uk/intlayer_with_vue-i18n.md +1 -1
- package/blog/vi/intlayer_with_i18next.md +1 -1
- package/blog/vi/intlayer_with_next-i18next.md +1 -1
- package/blog/vi/intlayer_with_next-intl.md +1 -1
- package/blog/vi/intlayer_with_react-i18next.md +1 -1
- package/blog/vi/intlayer_with_react-intl.md +1 -1
- package/blog/vi/intlayer_with_vue-i18n.md +1 -1
- package/blog/zh/intlayer_with_i18next.md +1 -1
- package/blog/zh/intlayer_with_next-i18next.md +1 -1
- package/blog/zh/intlayer_with_next-intl.md +1 -1
- package/blog/zh/intlayer_with_react-i18next.md +1 -1
- package/blog/zh/intlayer_with_react-intl.md +1 -1
- package/blog/zh/intlayer_with_vue-i18n.md +1 -1
- package/dist/cjs/generated/docs.entry.cjs +20 -0
- package/dist/cjs/generated/docs.entry.cjs.map +1 -1
- package/dist/esm/generated/docs.entry.mjs +20 -0
- package/dist/esm/generated/docs.entry.mjs.map +1 -1
- package/dist/types/generated/docs.entry.d.ts +1 -0
- package/dist/types/generated/docs.entry.d.ts.map +1 -1
- package/docs/ar/intlayer_CMS.md +1 -1
- package/docs/ar/intlayer_with_adonisjs.md +1 -1
- package/docs/ar/intlayer_with_analog.md +1 -1
- package/docs/ar/intlayer_with_angular.md +1 -1
- package/docs/ar/intlayer_with_create_react_app.md +1 -1
- package/docs/ar/intlayer_with_express.md +1 -1
- package/docs/ar/intlayer_with_fastify.md +1 -1
- package/docs/ar/intlayer_with_hono.md +1 -1
- package/docs/ar/intlayer_with_lynx+react.md +1 -1
- package/docs/ar/intlayer_with_nestjs.md +1 -1
- package/docs/ar/intlayer_with_next-i18next.md +1 -1
- package/docs/ar/intlayer_with_next-intl.md +1 -1
- package/docs/ar/intlayer_with_nextjs_14.md +1 -1
- package/docs/ar/intlayer_with_nextjs_15.md +1 -1
- package/docs/ar/intlayer_with_nextjs_16.md +2 -2
- package/docs/ar/intlayer_with_nextjs_compiler.md +2 -2
- package/docs/ar/intlayer_with_nextjs_no_locale_path.md +1 -1
- package/docs/ar/intlayer_with_nextjs_page_router.md +1 -1
- package/docs/ar/intlayer_with_nuxt.md +1 -1
- package/docs/ar/intlayer_with_react_native+expo.md +1 -1
- package/docs/ar/intlayer_with_react_router_v7.md +4 -6
- package/docs/ar/intlayer_with_react_router_v7_fs_routes.md +4 -6
- package/docs/ar/intlayer_with_svelte_kit.md +5 -5
- package/docs/ar/intlayer_with_tanstack+solid.md +894 -0
- package/docs/ar/intlayer_with_tanstack.md +2 -10
- package/docs/ar/intlayer_with_vite+lit.md +1 -2
- package/docs/ar/intlayer_with_vite+preact.md +2 -2
- package/docs/ar/intlayer_with_vite+react.md +2 -2
- package/docs/ar/intlayer_with_vite+react_compiler.md +1 -1
- package/docs/ar/intlayer_with_vite+solid.md +2 -3
- package/docs/ar/intlayer_with_vite+svelte.md +3 -3
- package/docs/ar/intlayer_with_vite+vanilla.md +2 -2
- package/docs/ar/intlayer_with_vite+vue.md +2 -2
- package/docs/bn/intlayer_with_fastify.md +1 -1
- package/docs/bn/intlayer_with_hono.md +1 -1
- package/docs/bn/intlayer_with_vite+lit.md +1 -2
- package/docs/bn/intlayer_with_vite+vanilla.md +2 -2
- package/docs/cs/intlayer_with_fastify.md +1 -1
- package/docs/cs/intlayer_with_hono.md +1 -1
- package/docs/cs/intlayer_with_vite+lit.md +1 -2
- package/docs/cs/intlayer_with_vite+vanilla.md +2 -2
- package/docs/de/intlayer_CMS.md +1 -1
- package/docs/de/intlayer_with_adonisjs.md +1 -1
- package/docs/de/intlayer_with_analog.md +1 -1
- package/docs/de/intlayer_with_angular.md +1 -1
- package/docs/de/intlayer_with_create_react_app.md +1 -1
- package/docs/de/intlayer_with_express.md +1 -1
- package/docs/de/intlayer_with_fastify.md +1 -1
- package/docs/de/intlayer_with_hono.md +1 -1
- package/docs/de/intlayer_with_lynx+react.md +1 -1
- package/docs/de/intlayer_with_nestjs.md +1 -1
- package/docs/de/intlayer_with_next-i18next.md +1 -1
- package/docs/de/intlayer_with_next-intl.md +1 -1
- package/docs/de/intlayer_with_nextjs_14.md +1 -1
- package/docs/de/intlayer_with_nextjs_15.md +1 -1
- package/docs/de/intlayer_with_nextjs_16.md +2 -2
- package/docs/de/intlayer_with_nextjs_compiler.md +1 -1
- package/docs/de/intlayer_with_nextjs_no_locale_path.md +1 -1
- package/docs/de/intlayer_with_nextjs_page_router.md +1 -1
- package/docs/de/intlayer_with_nuxt.md +1 -1
- package/docs/de/intlayer_with_react_router_v7.md +4 -6
- package/docs/de/intlayer_with_react_router_v7_fs_routes.md +2 -3
- package/docs/de/intlayer_with_svelte_kit.md +5 -5
- package/docs/de/intlayer_with_tanstack+solid.md +970 -0
- package/docs/de/intlayer_with_tanstack.md +98 -30
- package/docs/de/intlayer_with_vite+lit.md +1 -2
- package/docs/de/intlayer_with_vite+preact.md +2 -2
- package/docs/de/intlayer_with_vite+react.md +2 -2
- package/docs/de/intlayer_with_vite+react_compiler.md +1 -1
- package/docs/de/intlayer_with_vite+solid.md +2 -3
- package/docs/de/intlayer_with_vite+svelte.md +3 -3
- package/docs/de/intlayer_with_vite+vanilla.md +2 -2
- package/docs/de/intlayer_with_vite+vue.md +2 -2
- package/docs/en/intlayer_CMS.md +1 -1
- package/docs/en/intlayer_with_adonisjs.md +1 -1
- package/docs/en/intlayer_with_analog.md +1 -1
- package/docs/en/intlayer_with_angular.md +1 -1
- package/docs/en/intlayer_with_create_react_app.md +1 -1
- package/docs/en/intlayer_with_express.md +1 -1
- package/docs/en/intlayer_with_fastify.md +1 -1
- package/docs/en/intlayer_with_hono.md +1 -1
- package/docs/en/intlayer_with_lynx+react.md +1 -1
- package/docs/en/intlayer_with_nestjs.md +1 -1
- package/docs/en/intlayer_with_next-i18next.md +1 -1
- package/docs/en/intlayer_with_next-intl.md +1 -1
- package/docs/en/intlayer_with_nextjs_14.md +1 -1
- package/docs/en/intlayer_with_nextjs_15.md +1 -1
- package/docs/en/intlayer_with_nextjs_16.md +2 -2
- package/docs/en/intlayer_with_nextjs_compiler.md +2 -2
- package/docs/en/intlayer_with_nextjs_no_locale_path.md +1 -1
- package/docs/en/intlayer_with_nextjs_page_router.md +1 -1
- package/docs/en/intlayer_with_nuxt.md +1 -1
- package/docs/en/intlayer_with_react_native+expo.md +1 -1
- package/docs/en/intlayer_with_react_router_v7.md +3 -4
- package/docs/en/intlayer_with_react_router_v7_fs_routes.md +4 -6
- package/docs/en/intlayer_with_svelte_kit.md +4 -4
- package/docs/en/intlayer_with_tanstack+solid.md +973 -0
- package/docs/en/intlayer_with_tanstack.md +83 -12
- package/docs/en/intlayer_with_vite+lit.md +1 -2
- package/docs/en/intlayer_with_vite+preact.md +2 -2
- package/docs/en/intlayer_with_vite+react.md +2 -2
- package/docs/en/intlayer_with_vite+react_compiler.md +1 -1
- package/docs/en/intlayer_with_vite+solid.md +2 -3
- package/docs/en/intlayer_with_vite+svelte.md +7 -8
- package/docs/en/intlayer_with_vite+vanilla.md +2 -2
- package/docs/en/intlayer_with_vite+vue.md +2 -2
- package/docs/en-GB/intlayer_CMS.md +1 -1
- package/docs/en-GB/intlayer_with_adonisjs.md +1 -1
- package/docs/en-GB/intlayer_with_analog.md +1 -1
- package/docs/en-GB/intlayer_with_angular.md +1 -1
- package/docs/en-GB/intlayer_with_create_react_app.md +2 -2
- package/docs/en-GB/intlayer_with_express.md +1 -1
- package/docs/en-GB/intlayer_with_fastify.md +1 -1
- package/docs/en-GB/intlayer_with_hono.md +1 -1
- package/docs/en-GB/intlayer_with_lynx+react.md +2 -2
- package/docs/en-GB/intlayer_with_nestjs.md +1 -1
- package/docs/en-GB/intlayer_with_next-i18next.md +1 -1
- package/docs/en-GB/intlayer_with_next-intl.md +1 -1
- package/docs/en-GB/intlayer_with_nextjs_14.md +1 -1
- package/docs/en-GB/intlayer_with_nextjs_15.md +1 -1
- package/docs/en-GB/intlayer_with_nextjs_16.md +1 -1
- package/docs/en-GB/intlayer_with_nextjs_compiler.md +1 -1
- package/docs/en-GB/intlayer_with_nextjs_no_locale_path.md +1 -1
- package/docs/en-GB/intlayer_with_nextjs_page_router.md +1 -1
- package/docs/en-GB/intlayer_with_nuxt.md +1 -1
- package/docs/en-GB/intlayer_with_react_native+expo.md +1 -1
- package/docs/en-GB/intlayer_with_react_router_v7.md +3 -5
- package/docs/en-GB/intlayer_with_react_router_v7_fs_routes.md +3 -5
- package/docs/en-GB/intlayer_with_svelte_kit.md +4 -4
- package/docs/en-GB/intlayer_with_tanstack+solid.md +968 -0
- package/docs/en-GB/intlayer_with_tanstack.md +75 -10
- package/docs/en-GB/intlayer_with_vite+lit.md +1 -2
- package/docs/en-GB/intlayer_with_vite+preact.md +1 -1
- package/docs/en-GB/intlayer_with_vite+react.md +1 -1
- package/docs/en-GB/intlayer_with_vite+react_compiler.md +1 -1
- package/docs/en-GB/intlayer_with_vite+solid.md +1 -2
- package/docs/en-GB/intlayer_with_vite+svelte.md +2 -2
- package/docs/en-GB/intlayer_with_vite+vanilla.md +2 -2
- package/docs/en-GB/intlayer_with_vite+vue.md +1 -1
- package/docs/es/intlayer_CMS.md +1 -1
- package/docs/es/intlayer_with_adonisjs.md +1 -1
- package/docs/es/intlayer_with_analog.md +1 -1
- package/docs/es/intlayer_with_angular.md +1 -1
- package/docs/es/intlayer_with_create_react_app.md +1 -1
- package/docs/es/intlayer_with_express.md +1 -1
- package/docs/es/intlayer_with_fastify.md +1 -1
- package/docs/es/intlayer_with_hono.md +1 -1
- package/docs/es/intlayer_with_lynx+react.md +1 -1
- package/docs/es/intlayer_with_nestjs.md +1 -1
- package/docs/es/intlayer_with_next-i18next.md +1 -1
- package/docs/es/intlayer_with_next-intl.md +1 -1
- package/docs/es/intlayer_with_nextjs_14.md +1 -1
- package/docs/es/intlayer_with_nextjs_15.md +1 -1
- package/docs/es/intlayer_with_nextjs_16.md +2 -2
- package/docs/es/intlayer_with_nextjs_compiler.md +2 -2
- package/docs/es/intlayer_with_nextjs_no_locale_path.md +1 -1
- package/docs/es/intlayer_with_nextjs_page_router.md +1 -1
- package/docs/es/intlayer_with_nuxt.md +1 -1
- package/docs/es/intlayer_with_react_native+expo.md +1 -1
- package/docs/es/intlayer_with_react_router_v7.md +4 -6
- package/docs/es/intlayer_with_react_router_v7_fs_routes.md +4 -6
- package/docs/es/intlayer_with_svelte_kit.md +5 -5
- package/docs/es/intlayer_with_tanstack+solid.md +970 -0
- package/docs/es/intlayer_with_tanstack.md +98 -30
- package/docs/es/intlayer_with_vite+lit.md +1 -2
- package/docs/es/intlayer_with_vite+preact.md +2 -2
- package/docs/es/intlayer_with_vite+react.md +2 -2
- package/docs/es/intlayer_with_vite+react_compiler.md +1 -1
- package/docs/es/intlayer_with_vite+solid.md +2 -3
- package/docs/es/intlayer_with_vite+svelte.md +3 -3
- package/docs/es/intlayer_with_vite+vanilla.md +2 -2
- package/docs/es/intlayer_with_vite+vue.md +2 -2
- package/docs/es/packages/next-intlayer/index.md +1 -1
- package/docs/es/packages/react-intlayer/index.md +1 -1
- package/docs/fr/intlayer_CMS.md +1 -1
- package/docs/fr/intlayer_with_adonisjs.md +1 -1
- package/docs/fr/intlayer_with_analog.md +1 -1
- package/docs/fr/intlayer_with_angular.md +1 -1
- package/docs/fr/intlayer_with_create_react_app.md +1 -1
- package/docs/fr/intlayer_with_express.md +1 -1
- package/docs/fr/intlayer_with_fastify.md +1 -1
- package/docs/fr/intlayer_with_hono.md +1 -1
- package/docs/fr/intlayer_with_lynx+react.md +1 -1
- package/docs/fr/intlayer_with_nestjs.md +1 -1
- package/docs/fr/intlayer_with_next-i18next.md +1 -1
- package/docs/fr/intlayer_with_next-intl.md +1 -1
- package/docs/fr/intlayer_with_nextjs_14.md +1 -1
- package/docs/fr/intlayer_with_nextjs_15.md +1 -1
- package/docs/fr/intlayer_with_nextjs_16.md +2 -2
- package/docs/fr/intlayer_with_nextjs_compiler.md +2 -2
- package/docs/fr/intlayer_with_nextjs_no_locale_path.md +1 -1
- package/docs/fr/intlayer_with_nextjs_page_router.md +1 -1
- package/docs/fr/intlayer_with_nuxt.md +1 -1
- package/docs/fr/intlayer_with_react_router_v7.md +4 -6
- package/docs/fr/intlayer_with_react_router_v7_fs_routes.md +4 -6
- package/docs/fr/intlayer_with_svelte_kit.md +6 -6
- package/docs/fr/intlayer_with_tanstack+solid.md +970 -0
- package/docs/fr/intlayer_with_tanstack.md +98 -30
- package/docs/fr/intlayer_with_vite+lit.md +1 -2
- package/docs/fr/intlayer_with_vite+preact.md +2 -2
- package/docs/fr/intlayer_with_vite+react.md +2 -2
- package/docs/fr/intlayer_with_vite+react_compiler.md +1 -1
- package/docs/fr/intlayer_with_vite+solid.md +2 -3
- package/docs/fr/intlayer_with_vite+svelte.md +3 -3
- package/docs/fr/intlayer_with_vite+vanilla.md +2 -2
- package/docs/fr/intlayer_with_vite+vue.md +2 -2
- package/docs/fr/packages/react-intlayer/index.md +1 -1
- package/docs/hi/intlayer_CMS.md +1 -1
- package/docs/hi/intlayer_with_adonisjs.md +1 -1
- package/docs/hi/intlayer_with_analog.md +1 -1
- package/docs/hi/intlayer_with_angular.md +1 -1
- package/docs/hi/intlayer_with_create_react_app.md +1 -1
- package/docs/hi/intlayer_with_express.md +1 -1
- package/docs/hi/intlayer_with_fastify.md +1 -1
- package/docs/hi/intlayer_with_hono.md +1 -1
- package/docs/hi/intlayer_with_lynx+react.md +1 -1
- package/docs/hi/intlayer_with_nestjs.md +1 -1
- package/docs/hi/intlayer_with_next-i18next.md +1 -1
- package/docs/hi/intlayer_with_next-intl.md +1 -1
- package/docs/hi/intlayer_with_nextjs_14.md +1 -1
- package/docs/hi/intlayer_with_nextjs_15.md +1 -1
- package/docs/hi/intlayer_with_nextjs_16.md +2 -2
- package/docs/hi/intlayer_with_nextjs_compiler.md +2 -2
- package/docs/hi/intlayer_with_nextjs_no_locale_path.md +1 -1
- package/docs/hi/intlayer_with_nextjs_page_router.md +1 -1
- package/docs/hi/intlayer_with_nuxt.md +1 -1
- package/docs/hi/intlayer_with_react_router_v7.md +4 -6
- package/docs/hi/intlayer_with_react_router_v7_fs_routes.md +4 -6
- package/docs/hi/intlayer_with_svelte_kit.md +5 -5
- package/docs/hi/intlayer_with_tanstack+solid.md +894 -0
- package/docs/hi/intlayer_with_tanstack.md +2 -10
- package/docs/hi/intlayer_with_vite+lit.md +1 -2
- package/docs/hi/intlayer_with_vite+preact.md +2 -2
- package/docs/hi/intlayer_with_vite+react.md +2 -2
- package/docs/hi/intlayer_with_vite+react_compiler.md +1 -1
- package/docs/hi/intlayer_with_vite+solid.md +2 -3
- package/docs/hi/intlayer_with_vite+svelte.md +3 -3
- package/docs/hi/intlayer_with_vite+vanilla.md +2 -2
- package/docs/hi/intlayer_with_vite+vue.md +2 -2
- package/docs/hi/packages/intlayer/index.md +1 -1
- package/docs/id/intlayer_CMS.md +1 -1
- package/docs/id/intlayer_with_adonisjs.md +1 -1
- package/docs/id/intlayer_with_analog.md +1 -1
- package/docs/id/intlayer_with_angular.md +1 -1
- package/docs/id/intlayer_with_create_react_app.md +1 -1
- package/docs/id/intlayer_with_express.md +1 -1
- package/docs/id/intlayer_with_fastify.md +1 -1
- package/docs/id/intlayer_with_hono.md +1 -1
- package/docs/id/intlayer_with_lynx+react.md +1 -1
- package/docs/id/intlayer_with_nestjs.md +1 -1
- package/docs/id/intlayer_with_next-i18next.md +1 -1
- package/docs/id/intlayer_with_next-intl.md +1 -1
- package/docs/id/intlayer_with_nextjs_14.md +1 -1
- package/docs/id/intlayer_with_nextjs_15.md +1 -1
- package/docs/id/intlayer_with_nextjs_16.md +2 -2
- package/docs/id/intlayer_with_nextjs_compiler.md +2 -2
- package/docs/id/intlayer_with_nextjs_no_locale_path.md +1 -1
- package/docs/id/intlayer_with_nextjs_page_router.md +1 -1
- package/docs/id/intlayer_with_nuxt.md +1 -1
- package/docs/id/intlayer_with_react_native+expo.md +1 -1
- package/docs/id/intlayer_with_react_router_v7.md +4 -6
- package/docs/id/intlayer_with_react_router_v7_fs_routes.md +4 -6
- package/docs/id/intlayer_with_svelte_kit.md +5 -5
- package/docs/id/intlayer_with_tanstack+solid.md +894 -0
- package/docs/id/intlayer_with_tanstack.md +2 -10
- package/docs/id/intlayer_with_vite+lit.md +1 -2
- package/docs/id/intlayer_with_vite+preact.md +2 -2
- package/docs/id/intlayer_with_vite+react.md +2 -2
- package/docs/id/intlayer_with_vite+react_compiler.md +1 -1
- package/docs/id/intlayer_with_vite+solid.md +2 -3
- package/docs/id/intlayer_with_vite+svelte.md +3 -3
- package/docs/id/intlayer_with_vite+vanilla.md +2 -2
- package/docs/id/intlayer_with_vite+vue.md +2 -2
- package/docs/it/intlayer_CMS.md +1 -1
- package/docs/it/intlayer_with_adonisjs.md +1 -1
- package/docs/it/intlayer_with_analog.md +1 -1
- package/docs/it/intlayer_with_angular.md +1 -1
- package/docs/it/intlayer_with_create_react_app.md +1 -1
- package/docs/it/intlayer_with_express.md +1 -1
- package/docs/it/intlayer_with_fastify.md +1 -1
- package/docs/it/intlayer_with_hono.md +1 -1
- package/docs/it/intlayer_with_lynx+react.md +1 -1
- package/docs/it/intlayer_with_nestjs.md +1 -1
- package/docs/it/intlayer_with_next-i18next.md +1 -1
- package/docs/it/intlayer_with_next-intl.md +1 -1
- package/docs/it/intlayer_with_nextjs_14.md +1 -1
- package/docs/it/intlayer_with_nextjs_15.md +1 -1
- package/docs/it/intlayer_with_nextjs_16.md +2 -2
- package/docs/it/intlayer_with_nextjs_compiler.md +2 -2
- package/docs/it/intlayer_with_nextjs_no_locale_path.md +1 -1
- package/docs/it/intlayer_with_nextjs_page_router.md +1 -1
- package/docs/it/intlayer_with_nuxt.md +1 -1
- package/docs/it/intlayer_with_react_native+expo.md +1 -1
- package/docs/it/intlayer_with_react_router_v7.md +4 -6
- package/docs/it/intlayer_with_react_router_v7_fs_routes.md +4 -6
- package/docs/it/intlayer_with_svelte_kit.md +6 -6
- package/docs/it/intlayer_with_tanstack+solid.md +970 -0
- package/docs/it/intlayer_with_tanstack.md +98 -32
- package/docs/it/intlayer_with_vite+lit.md +1 -2
- package/docs/it/intlayer_with_vite+preact.md +2 -2
- package/docs/it/intlayer_with_vite+react.md +2 -2
- package/docs/it/intlayer_with_vite+react_compiler.md +1 -1
- package/docs/it/intlayer_with_vite+solid.md +2 -3
- package/docs/it/intlayer_with_vite+svelte.md +3 -3
- package/docs/it/intlayer_with_vite+vanilla.md +2 -2
- package/docs/it/intlayer_with_vite+vue.md +2 -2
- package/docs/ja/intlayer_CMS.md +1 -1
- package/docs/ja/intlayer_with_adonisjs.md +1 -1
- package/docs/ja/intlayer_with_analog.md +1 -1
- package/docs/ja/intlayer_with_angular.md +1 -1
- package/docs/ja/intlayer_with_create_react_app.md +1 -1
- package/docs/ja/intlayer_with_express.md +1 -1
- package/docs/ja/intlayer_with_fastify.md +1 -1
- package/docs/ja/intlayer_with_hono.md +1 -1
- package/docs/ja/intlayer_with_lynx+react.md +1 -1
- package/docs/ja/intlayer_with_nestjs.md +1 -1
- package/docs/ja/intlayer_with_next-i18next.md +1 -1
- package/docs/ja/intlayer_with_next-intl.md +1 -1
- package/docs/ja/intlayer_with_nextjs_14.md +1 -1
- package/docs/ja/intlayer_with_nextjs_15.md +1 -1
- package/docs/ja/intlayer_with_nextjs_16.md +2 -2
- package/docs/ja/intlayer_with_nextjs_compiler.md +2 -2
- package/docs/ja/intlayer_with_nextjs_no_locale_path.md +1 -1
- package/docs/ja/intlayer_with_nextjs_page_router.md +1 -1
- package/docs/ja/intlayer_with_nuxt.md +1 -1
- package/docs/ja/intlayer_with_react_router_v7.md +2 -3
- package/docs/ja/intlayer_with_react_router_v7_fs_routes.md +4 -6
- package/docs/ja/intlayer_with_svelte_kit.md +1 -1
- package/docs/ja/intlayer_with_tanstack+solid.md +972 -0
- package/docs/ja/intlayer_with_tanstack.md +780 -94
- package/docs/ja/intlayer_with_vite+lit.md +1 -2
- package/docs/ja/intlayer_with_vite+preact.md +1 -1
- package/docs/ja/intlayer_with_vite+react.md +1 -1
- package/docs/ja/intlayer_with_vite+react_compiler.md +1 -1
- package/docs/ja/intlayer_with_vite+solid.md +2 -3
- package/docs/ja/intlayer_with_vite+svelte.md +3 -3
- package/docs/ja/intlayer_with_vite+vanilla.md +2 -2
- package/docs/ja/intlayer_with_vite+vue.md +2 -2
- package/docs/ko/intlayer_CMS.md +1 -1
- package/docs/ko/intlayer_with_adonisjs.md +1 -1
- package/docs/ko/intlayer_with_analog.md +1 -1
- package/docs/ko/intlayer_with_angular.md +1 -1
- package/docs/ko/intlayer_with_create_react_app.md +1 -1
- package/docs/ko/intlayer_with_express.md +1 -1
- package/docs/ko/intlayer_with_fastify.md +1 -1
- package/docs/ko/intlayer_with_hono.md +1 -1
- package/docs/ko/intlayer_with_lynx+react.md +1 -1
- package/docs/ko/intlayer_with_nestjs.md +1 -1
- package/docs/ko/intlayer_with_next-i18next.md +1 -1
- package/docs/ko/intlayer_with_next-intl.md +1 -1
- package/docs/ko/intlayer_with_nextjs_14.md +1 -1
- package/docs/ko/intlayer_with_nextjs_15.md +1 -1
- package/docs/ko/intlayer_with_nextjs_16.md +2 -2
- package/docs/ko/intlayer_with_nextjs_compiler.md +2 -2
- package/docs/ko/intlayer_with_nextjs_no_locale_path.md +1 -1
- package/docs/ko/intlayer_with_nextjs_page_router.md +1 -1
- package/docs/ko/intlayer_with_nuxt.md +1 -1
- package/docs/ko/intlayer_with_react_native+expo.md +1 -1
- package/docs/ko/intlayer_with_react_router_v7.md +4 -6
- package/docs/ko/intlayer_with_react_router_v7_fs_routes.md +4 -6
- package/docs/ko/intlayer_with_svelte_kit.md +5 -5
- package/docs/ko/intlayer_with_tanstack+solid.md +970 -0
- package/docs/ko/intlayer_with_tanstack.md +97 -103
- package/docs/ko/intlayer_with_vite+lit.md +1 -2
- package/docs/ko/intlayer_with_vite+preact.md +2 -2
- package/docs/ko/intlayer_with_vite+react.md +2 -2
- package/docs/ko/intlayer_with_vite+react_compiler.md +1 -1
- package/docs/ko/intlayer_with_vite+solid.md +2 -3
- package/docs/ko/intlayer_with_vite+svelte.md +3 -3
- package/docs/ko/intlayer_with_vite+vanilla.md +2 -2
- package/docs/ko/intlayer_with_vite+vue.md +2 -2
- package/docs/nl/intlayer_with_fastify.md +1 -1
- package/docs/nl/intlayer_with_hono.md +1 -1
- package/docs/nl/intlayer_with_vite+lit.md +1 -2
- package/docs/nl/intlayer_with_vite+vanilla.md +2 -2
- package/docs/pl/intlayer_CMS.md +1 -1
- package/docs/pl/intlayer_with_adonisjs.md +1 -1
- package/docs/pl/intlayer_with_analog.md +1 -1
- package/docs/pl/intlayer_with_angular.md +1 -1
- package/docs/pl/intlayer_with_create_react_app.md +1 -1
- package/docs/pl/intlayer_with_express.md +1 -1
- package/docs/pl/intlayer_with_fastify.md +1 -1
- package/docs/pl/intlayer_with_hono.md +1 -1
- package/docs/pl/intlayer_with_lynx+react.md +1 -1
- package/docs/pl/intlayer_with_nestjs.md +1 -1
- package/docs/pl/intlayer_with_next-i18next.md +1 -1
- package/docs/pl/intlayer_with_next-intl.md +1 -1
- package/docs/pl/intlayer_with_nextjs_14.md +1 -1
- package/docs/pl/intlayer_with_nextjs_15.md +1 -1
- package/docs/pl/intlayer_with_nextjs_16.md +2 -2
- package/docs/pl/intlayer_with_nextjs_compiler.md +2 -2
- package/docs/pl/intlayer_with_nextjs_no_locale_path.md +1 -1
- package/docs/pl/intlayer_with_nextjs_page_router.md +1 -1
- package/docs/pl/intlayer_with_nuxt.md +1 -1
- package/docs/pl/intlayer_with_react_native+expo.md +1 -1
- package/docs/pl/intlayer_with_react_router_v7.md +4 -6
- package/docs/pl/intlayer_with_react_router_v7_fs_routes.md +4 -6
- package/docs/pl/intlayer_with_svelte_kit.md +5 -5
- package/docs/pl/intlayer_with_tanstack+solid.md +894 -0
- package/docs/pl/intlayer_with_tanstack.md +2 -10
- package/docs/pl/intlayer_with_vite+lit.md +1 -2
- package/docs/pl/intlayer_with_vite+preact.md +2 -2
- package/docs/pl/intlayer_with_vite+react.md +2 -2
- package/docs/pl/intlayer_with_vite+react_compiler.md +1 -1
- package/docs/pl/intlayer_with_vite+solid.md +2 -3
- package/docs/pl/intlayer_with_vite+svelte.md +3 -3
- package/docs/pl/intlayer_with_vite+vanilla.md +2 -2
- package/docs/pl/intlayer_with_vite+vue.md +2 -2
- package/docs/pt/intlayer_CMS.md +1 -1
- package/docs/pt/intlayer_with_adonisjs.md +1 -1
- package/docs/pt/intlayer_with_analog.md +1 -1
- package/docs/pt/intlayer_with_angular.md +1 -1
- package/docs/pt/intlayer_with_create_react_app.md +1 -1
- package/docs/pt/intlayer_with_express.md +1 -1
- package/docs/pt/intlayer_with_fastify.md +1 -1
- package/docs/pt/intlayer_with_hono.md +1 -1
- package/docs/pt/intlayer_with_lynx+react.md +1 -1
- package/docs/pt/intlayer_with_nestjs.md +1 -1
- package/docs/pt/intlayer_with_next-i18next.md +1 -1
- package/docs/pt/intlayer_with_next-intl.md +1 -1
- package/docs/pt/intlayer_with_nextjs_14.md +1 -1
- package/docs/pt/intlayer_with_nextjs_15.md +1 -1
- package/docs/pt/intlayer_with_nextjs_16.md +2 -2
- package/docs/pt/intlayer_with_nextjs_compiler.md +2 -2
- package/docs/pt/intlayer_with_nextjs_no_locale_path.md +1 -1
- package/docs/pt/intlayer_with_nextjs_page_router.md +1 -1
- package/docs/pt/intlayer_with_nuxt.md +1 -1
- package/docs/pt/intlayer_with_react_native+expo.md +1 -1
- package/docs/pt/intlayer_with_react_router_v7.md +3 -4
- package/docs/pt/intlayer_with_react_router_v7_fs_routes.md +4 -6
- package/docs/pt/intlayer_with_svelte_kit.md +6 -6
- package/docs/pt/intlayer_with_tanstack+solid.md +970 -0
- package/docs/pt/intlayer_with_tanstack.md +98 -32
- package/docs/pt/intlayer_with_vite+lit.md +1 -2
- package/docs/pt/intlayer_with_vite+preact.md +2 -2
- package/docs/pt/intlayer_with_vite+react.md +2 -2
- package/docs/pt/intlayer_with_vite+react_compiler.md +1 -1
- package/docs/pt/intlayer_with_vite+solid.md +2 -3
- package/docs/pt/intlayer_with_vite+svelte.md +3 -3
- package/docs/pt/intlayer_with_vite+vanilla.md +2 -2
- package/docs/pt/intlayer_with_vite+vue.md +2 -2
- package/docs/ru/intlayer_CMS.md +1 -1
- package/docs/ru/intlayer_with_adonisjs.md +1 -1
- package/docs/ru/intlayer_with_analog.md +1 -1
- package/docs/ru/intlayer_with_angular.md +1 -1
- package/docs/ru/intlayer_with_create_react_app.md +1 -1
- package/docs/ru/intlayer_with_express.md +1 -1
- package/docs/ru/intlayer_with_fastify.md +1 -1
- package/docs/ru/intlayer_with_hono.md +1 -1
- package/docs/ru/intlayer_with_lynx+react.md +1 -1
- package/docs/ru/intlayer_with_nestjs.md +1 -1
- package/docs/ru/intlayer_with_next-i18next.md +1 -1
- package/docs/ru/intlayer_with_next-intl.md +1 -1
- package/docs/ru/intlayer_with_nextjs_14.md +1 -1
- package/docs/ru/intlayer_with_nextjs_15.md +1 -1
- package/docs/ru/intlayer_with_nextjs_16.md +2 -2
- package/docs/ru/intlayer_with_nextjs_compiler.md +2 -2
- package/docs/ru/intlayer_with_nextjs_no_locale_path.md +1 -1
- package/docs/ru/intlayer_with_nextjs_page_router.md +1 -1
- package/docs/ru/intlayer_with_nuxt.md +1 -1
- package/docs/ru/intlayer_with_react_native+expo.md +1 -1
- package/docs/ru/intlayer_with_react_router_v7.md +4 -6
- package/docs/ru/intlayer_with_react_router_v7_fs_routes.md +4 -6
- package/docs/ru/intlayer_with_svelte_kit.md +5 -5
- package/docs/ru/intlayer_with_tanstack+solid.md +970 -0
- package/docs/ru/intlayer_with_tanstack.md +101 -35
- package/docs/ru/intlayer_with_vite+lit.md +1 -2
- package/docs/ru/intlayer_with_vite+preact.md +2 -2
- package/docs/ru/intlayer_with_vite+react.md +2 -2
- package/docs/ru/intlayer_with_vite+react_compiler.md +1 -1
- package/docs/ru/intlayer_with_vite+solid.md +2 -3
- package/docs/ru/intlayer_with_vite+svelte.md +3 -3
- package/docs/ru/intlayer_with_vite+vanilla.md +2 -2
- package/docs/ru/intlayer_with_vite+vue.md +2 -2
- package/docs/tr/intlayer_CMS.md +1 -1
- package/docs/tr/intlayer_with_adonisjs.md +1 -1
- package/docs/tr/intlayer_with_analog.md +1 -1
- package/docs/tr/intlayer_with_angular.md +1 -1
- package/docs/tr/intlayer_with_create_react_app.md +1 -1
- package/docs/tr/intlayer_with_express.md +1 -1
- package/docs/tr/intlayer_with_fastify.md +1 -1
- package/docs/tr/intlayer_with_hono.md +1 -1
- package/docs/tr/intlayer_with_lynx+react.md +1 -1
- package/docs/tr/intlayer_with_nestjs.md +1 -1
- package/docs/tr/intlayer_with_next-i18next.md +1 -1
- package/docs/tr/intlayer_with_next-intl.md +1 -1
- package/docs/tr/intlayer_with_nextjs_14.md +1 -1
- package/docs/tr/intlayer_with_nextjs_15.md +1 -1
- package/docs/tr/intlayer_with_nextjs_16.md +2 -2
- package/docs/tr/intlayer_with_nextjs_compiler.md +2 -2
- package/docs/tr/intlayer_with_nextjs_no_locale_path.md +1 -1
- package/docs/tr/intlayer_with_nextjs_page_router.md +1 -1
- package/docs/tr/intlayer_with_nuxt.md +1 -1
- package/docs/tr/intlayer_with_react_native+expo.md +1 -1
- package/docs/tr/intlayer_with_react_router_v7.md +4 -6
- package/docs/tr/intlayer_with_react_router_v7_fs_routes.md +4 -6
- package/docs/tr/intlayer_with_svelte_kit.md +5 -5
- package/docs/tr/intlayer_with_tanstack+solid.md +895 -0
- package/docs/tr/intlayer_with_tanstack.md +2 -10
- package/docs/tr/intlayer_with_vite+lit.md +1 -2
- package/docs/tr/intlayer_with_vite+preact.md +2 -2
- package/docs/tr/intlayer_with_vite+react.md +2 -2
- package/docs/tr/intlayer_with_vite+react_compiler.md +1 -1
- package/docs/tr/intlayer_with_vite+solid.md +2 -3
- package/docs/tr/intlayer_with_vite+svelte.md +3 -3
- package/docs/tr/intlayer_with_vite+vanilla.md +2 -2
- package/docs/tr/intlayer_with_vite+vue.md +2 -2
- package/docs/uk/intlayer_CMS.md +1 -1
- package/docs/uk/intlayer_with_adonisjs.md +1 -1
- package/docs/uk/intlayer_with_analog.md +1 -1
- package/docs/uk/intlayer_with_angular.md +1 -1
- package/docs/uk/intlayer_with_create_react_app.md +1 -1
- package/docs/uk/intlayer_with_express.md +1 -1
- package/docs/uk/intlayer_with_fastify.md +1 -1
- package/docs/uk/intlayer_with_hono.md +1 -1
- package/docs/uk/intlayer_with_lynx+react.md +1 -1
- package/docs/uk/intlayer_with_nestjs.md +1 -1
- package/docs/uk/intlayer_with_next-i18next.md +1 -1
- package/docs/uk/intlayer_with_next-intl.md +1 -1
- package/docs/uk/intlayer_with_nextjs_14.md +1 -1
- package/docs/uk/intlayer_with_nextjs_15.md +1 -1
- package/docs/uk/intlayer_with_nextjs_16.md +2 -2
- package/docs/uk/intlayer_with_nextjs_compiler.md +2 -2
- package/docs/uk/intlayer_with_nextjs_no_locale_path.md +1 -1
- package/docs/uk/intlayer_with_nextjs_page_router.md +1 -1
- package/docs/uk/intlayer_with_nuxt.md +1 -1
- package/docs/uk/intlayer_with_react_native+expo.md +1 -1
- package/docs/uk/intlayer_with_react_router_v7.md +3 -4
- package/docs/uk/intlayer_with_react_router_v7_fs_routes.md +4 -6
- package/docs/uk/intlayer_with_svelte_kit.md +4 -4
- package/docs/uk/intlayer_with_tanstack+solid.md +894 -0
- package/docs/uk/intlayer_with_tanstack.md +2 -10
- package/docs/uk/intlayer_with_vite+lit.md +1 -2
- package/docs/uk/intlayer_with_vite+preact.md +2 -2
- package/docs/uk/intlayer_with_vite+react.md +2 -2
- package/docs/uk/intlayer_with_vite+react_compiler.md +1 -1
- package/docs/uk/intlayer_with_vite+solid.md +2 -3
- package/docs/uk/intlayer_with_vite+svelte.md +3 -3
- package/docs/uk/intlayer_with_vite+vanilla.md +2 -2
- package/docs/uk/intlayer_with_vite+vue.md +2 -2
- package/docs/ur/intlayer_with_fastify.md +1 -1
- package/docs/ur/intlayer_with_hono.md +1 -1
- package/docs/ur/intlayer_with_vite+lit.md +1 -2
- package/docs/ur/intlayer_with_vite+vanilla.md +1 -1
- package/docs/vi/cli/index.md +1 -1
- package/docs/vi/intlayer_CMS.md +1 -1
- package/docs/vi/intlayer_with_adonisjs.md +1 -1
- package/docs/vi/intlayer_with_analog.md +1 -1
- package/docs/vi/intlayer_with_angular.md +1 -1
- package/docs/vi/intlayer_with_create_react_app.md +1 -1
- package/docs/vi/intlayer_with_express.md +1 -1
- package/docs/vi/intlayer_with_fastify.md +1 -1
- package/docs/vi/intlayer_with_hono.md +1 -1
- package/docs/vi/intlayer_with_lynx+react.md +1 -1
- package/docs/vi/intlayer_with_nestjs.md +1 -1
- package/docs/vi/intlayer_with_next-i18next.md +1 -1
- package/docs/vi/intlayer_with_next-intl.md +1 -1
- package/docs/vi/intlayer_with_nextjs_14.md +1 -1
- package/docs/vi/intlayer_with_nextjs_15.md +1 -1
- package/docs/vi/intlayer_with_nextjs_16.md +2 -2
- package/docs/vi/intlayer_with_nextjs_compiler.md +2 -2
- package/docs/vi/intlayer_with_nextjs_no_locale_path.md +1 -1
- package/docs/vi/intlayer_with_nextjs_page_router.md +1 -1
- package/docs/vi/intlayer_with_nuxt.md +1 -1
- package/docs/vi/intlayer_with_react_native+expo.md +1 -1
- package/docs/vi/intlayer_with_react_router_v7.md +4 -6
- package/docs/vi/intlayer_with_react_router_v7_fs_routes.md +4 -6
- package/docs/vi/intlayer_with_svelte_kit.md +5 -5
- package/docs/vi/intlayer_with_tanstack+solid.md +894 -0
- package/docs/vi/intlayer_with_tanstack.md +2 -10
- package/docs/vi/intlayer_with_vite+lit.md +1 -2
- package/docs/vi/intlayer_with_vite+preact.md +2 -2
- package/docs/vi/intlayer_with_vite+react.md +2 -2
- package/docs/vi/intlayer_with_vite+react_compiler.md +1 -1
- package/docs/vi/intlayer_with_vite+solid.md +2 -3
- package/docs/vi/intlayer_with_vite+svelte.md +3 -3
- package/docs/vi/intlayer_with_vite+vanilla.md +2 -2
- package/docs/vi/intlayer_with_vite+vue.md +2 -2
- package/docs/zh/intlayer_CMS.md +1 -1
- package/docs/zh/intlayer_with_adonisjs.md +1 -1
- package/docs/zh/intlayer_with_analog.md +1 -1
- package/docs/zh/intlayer_with_angular.md +1 -1
- package/docs/zh/intlayer_with_create_react_app.md +1 -1
- package/docs/zh/intlayer_with_express.md +1 -1
- package/docs/zh/intlayer_with_fastify.md +1 -1
- package/docs/zh/intlayer_with_hono.md +1 -1
- package/docs/zh/intlayer_with_lynx+react.md +1 -1
- package/docs/zh/intlayer_with_nestjs.md +1 -1
- package/docs/zh/intlayer_with_next-i18next.md +1 -1
- package/docs/zh/intlayer_with_next-intl.md +1 -1
- package/docs/zh/intlayer_with_nextjs_14.md +1 -1
- package/docs/zh/intlayer_with_nextjs_15.md +1 -1
- package/docs/zh/intlayer_with_nextjs_16.md +2 -2
- package/docs/zh/intlayer_with_nextjs_compiler.md +2 -2
- package/docs/zh/intlayer_with_nextjs_no_locale_path.md +1 -1
- package/docs/zh/intlayer_with_nextjs_page_router.md +1 -1
- package/docs/zh/intlayer_with_nuxt.md +1 -1
- package/docs/zh/intlayer_with_react_native+expo.md +1 -1
- package/docs/zh/intlayer_with_react_router_v7.md +4 -6
- package/docs/zh/intlayer_with_react_router_v7_fs_routes.md +4 -6
- package/docs/zh/intlayer_with_svelte_kit.md +5 -5
- package/docs/zh/intlayer_with_tanstack+solid.md +970 -0
- package/docs/zh/intlayer_with_tanstack.md +98 -106
- package/docs/zh/intlayer_with_vite+lit.md +1 -2
- package/docs/zh/intlayer_with_vite+preact.md +2 -2
- package/docs/zh/intlayer_with_vite+react.md +2 -2
- package/docs/zh/intlayer_with_vite+react_compiler.md +1 -1
- package/docs/zh/intlayer_with_vite+solid.md +2 -3
- package/docs/zh/intlayer_with_vite+svelte.md +3 -3
- package/docs/zh/intlayer_with_vite+vanilla.md +2 -2
- package/docs/zh/intlayer_with_vite+vue.md +2 -2
- package/package.json +8 -8
- package/src/generated/docs.entry.ts +20 -0
|
@@ -0,0 +1,970 @@
|
|
|
1
|
+
---
|
|
2
|
+
createdAt: 2025-03-25
|
|
3
|
+
updatedAt: 2026-03-29
|
|
4
|
+
title: i18n Tanstack Start - Como traduzir uma aplicação Tanstack Start usando Solid.js em 2026
|
|
5
|
+
description: Aprenda como adicionar internacionalização (i18n) à sua aplicação Tanstack Start usando Intlayer e Solid.js. Siga este guia completo para tornar sua aplicação multilíngue com roteamento ciente de localidade.
|
|
6
|
+
keywords:
|
|
7
|
+
- Internacionalização
|
|
8
|
+
- Documentação
|
|
9
|
+
- Intlayer
|
|
10
|
+
- Tanstack Start
|
|
11
|
+
- Solid
|
|
12
|
+
- i18n
|
|
13
|
+
- TypeScript
|
|
14
|
+
- Roteamento de Localidade
|
|
15
|
+
- Sitemap
|
|
16
|
+
slugs:
|
|
17
|
+
- doc
|
|
18
|
+
- environment
|
|
19
|
+
- tanstack-start
|
|
20
|
+
applicationTemplate: https://github.com/aymericzip/intlayer-tanstack-start-solid-template
|
|
21
|
+
youtubeVideo: https://www.youtube.com/watch?v=_XTdKVWaeqg
|
|
22
|
+
history:
|
|
23
|
+
- version: 8.5.1
|
|
24
|
+
date: 2026-03-25
|
|
25
|
+
changes: "Adicionado para Tanstack Start Solid.js"
|
|
26
|
+
---
|
|
27
|
+
|
|
28
|
+
# Traduza seu site Tanstack Start com Solid.js usando Intlayer | Internacionalização (i18n)
|
|
29
|
+
|
|
30
|
+
## Índice
|
|
31
|
+
|
|
32
|
+
<TOC/>
|
|
33
|
+
|
|
34
|
+
Este guia demonstra como integrar o **Intlayer** para uma internacionalização perfeita em projetos Tanstack Start com Solid.js, roteamento ciente de localidade, suporte a TypeScript e práticas de desenvolvimento modernas.
|
|
35
|
+
|
|
36
|
+
## O que é o Intlayer?
|
|
37
|
+
|
|
38
|
+
O **Intlayer** é uma biblioteca de internacionalização (i18n) inovadora e de código aberto, projetada para simplificar o suporte multilíngue em aplicações web modernas.
|
|
39
|
+
|
|
40
|
+
Com o Intlayer, você pode:
|
|
41
|
+
|
|
42
|
+
- **Gerenciar traduções facilmente** usando dicionários declarativos ao nível do componente.
|
|
43
|
+
- **Localizar metadados, rotas e conteúdo dinamicamente**.
|
|
44
|
+
- **Garantir o suporte a TypeScript** com tipos autogerados, melhorando o autocompletar e a detecção de erros.
|
|
45
|
+
- **Beneficiar-se de recursos avançados**, como detecção e troca dinâmica de localidade.
|
|
46
|
+
- **Habilitar roteamento ciente de localidade** com o sistema de roteamento baseado em arquivos do Tanstack Start.
|
|
47
|
+
|
|
48
|
+
---
|
|
49
|
+
|
|
50
|
+
## Guia Passo a Passo para Configurar o Intlayer numa Aplicação Tanstack Start
|
|
51
|
+
|
|
52
|
+
<Tabs defaultTab="video">
|
|
53
|
+
<Tab label="Vídeo" value="video">
|
|
54
|
+
|
|
55
|
+
<iframe title="A melhor solução i18n para Tanstack Start? Descubra o Intlayer" class="m-auto aspect-16/9 w-full overflow-hidden rounded-lg border-0" allow="autoplay; gyroscope;" loading="lazy" width="1080" height="auto" src="https://www.youtube.com/embed/_XTdKVWaeqg?autoplay=0&origin=http://intlayer.org&controls=0&rel=1"/>
|
|
56
|
+
|
|
57
|
+
</Tab>
|
|
58
|
+
<Tab label="Código" value="code">
|
|
59
|
+
|
|
60
|
+
<iframe
|
|
61
|
+
src="https://stackblitz.com/github/aymericzip/intlayer-tanstack-start-solid-template?embed=1&ctl=1&file=intlayer.config.ts"
|
|
62
|
+
className="m-auto overflow-hidden rounded-lg border-0 max-md:size-full max-md:h-[700px] md:aspect-16/9 md:w-full"
|
|
63
|
+
title="Demo CodeSandbox - Como Internacionalizar sua aplicação usando o Intlayer"
|
|
64
|
+
sandbox="allow-forms allow-modals allow-popups allow-presentation allow-same-origin allow-scripts"
|
|
65
|
+
loading="lazy"
|
|
66
|
+
/>
|
|
67
|
+
|
|
68
|
+
</Tab>
|
|
69
|
+
</Tabs>
|
|
70
|
+
|
|
71
|
+
Veja o [Modelo de Aplicação](https://github.com/aymericzip/intlayer-tanstack-start-solid-template) no GitHub.
|
|
72
|
+
|
|
73
|
+
### Passo 1: Criar o Projeto
|
|
74
|
+
|
|
75
|
+
Comece criando um novo projeto TanStack Start seguindo o guia [Iniciar novo projeto](https://tanstack.com/start/latest/docs/framework/solid/quick-start) no site do TanStack Start.
|
|
76
|
+
|
|
77
|
+
### Passo 2: Instalar os Pacotes Intlayer
|
|
78
|
+
|
|
79
|
+
Instale os pacotes necessários usando o seu gerenciador de pacotes preferido:
|
|
80
|
+
|
|
81
|
+
```bash packageManager="npm"
|
|
82
|
+
npm install intlayer solid-intlayer
|
|
83
|
+
npm install vite-intlayer --save-dev
|
|
84
|
+
npx intlayer init
|
|
85
|
+
```
|
|
86
|
+
|
|
87
|
+
```bash packageManager="pnpm"
|
|
88
|
+
pnpm add intlayer solid-intlayer
|
|
89
|
+
pnpm add vite-intlayer --save-dev
|
|
90
|
+
pnpm intlayer init
|
|
91
|
+
```
|
|
92
|
+
|
|
93
|
+
```bash packageManager="yarn"
|
|
94
|
+
yarn add intlayer solid-intlayer
|
|
95
|
+
yarn add vite-intlayer --save-dev
|
|
96
|
+
yarn intlayer init
|
|
97
|
+
```
|
|
98
|
+
|
|
99
|
+
```bash packageManager="bun"
|
|
100
|
+
bun add intlayer solid-intlayer
|
|
101
|
+
bun add vite-intlayer --dev
|
|
102
|
+
bun x intlayer init
|
|
103
|
+
```
|
|
104
|
+
|
|
105
|
+
- **intlayer**
|
|
106
|
+
|
|
107
|
+
O pacote principal que fornece ferramentas de internacionalização para gerenciamento de configuração, tradução, [declaração de conteúdo](https://github.com/aymericzip/intlayer/blob/main/docs/docs/pt/dictionary/content_file.md), transpilação e [comandos CLI](https://github.com/aymericzip/intlayer/blob/main/docs/docs/pt/cli/index.md).
|
|
108
|
+
|
|
109
|
+
- **solid-intlayer**
|
|
110
|
+
O pacote que integra o Intlayer com a aplicação Solid. Ele fornece provedores de contexto e hooks para a internacionalização em Solid.
|
|
111
|
+
|
|
112
|
+
- **vite-intlayer**
|
|
113
|
+
Inclui o plugin Vite para integrar o Intlayer com o [bundler Vite](https://vite.dev/guide/why.html#why-bundle-for-production), bem como o middleware para detectar a localidade preferida do usuário, gerenciar cookies e lidar com redirecionamento de URL.
|
|
114
|
+
|
|
115
|
+
### Passo 3: Configuração do seu projeto
|
|
116
|
+
|
|
117
|
+
Crie um arquivo de configuração para configurar as línguas da sua aplicação:
|
|
118
|
+
|
|
119
|
+
```typescript fileName="intlayer.config.ts"
|
|
120
|
+
import type { IntlayerConfig } from "intlayer";
|
|
121
|
+
|
|
122
|
+
import { Locales } from "intlayer";
|
|
123
|
+
|
|
124
|
+
const config: IntlayerConfig = {
|
|
125
|
+
internationalization: {
|
|
126
|
+
defaultLocale: Locales.ENGLISH,
|
|
127
|
+
locales: [Locales.ENGLISH, Locales.FRENCH, Locales.SPANISH],
|
|
128
|
+
},
|
|
129
|
+
};
|
|
130
|
+
|
|
131
|
+
export default config;
|
|
132
|
+
```
|
|
133
|
+
|
|
134
|
+
> Através deste arquivo de configuração, você pode configurar URLs localizadas, redirecionamento de middleware, nomes de cookies, a localização e extensão das suas declarações de conteúdo, desativar logs do Intlayer no console e muito mais. Para uma lista completa de parâmetros disponíveis, consulte a [documentação de configuração](https://github.com/aymericzip/intlayer/blob/main/docs/docs/pt/configuration.md).
|
|
135
|
+
|
|
136
|
+
### Passo 4: Integrar o Intlayer na sua Configuração Vite
|
|
137
|
+
|
|
138
|
+
Adicione o plugin intlayer na sua configuração:
|
|
139
|
+
|
|
140
|
+
```typescript fileName="vite.config.ts"
|
|
141
|
+
import { intlayer } from "vite-intlayer";
|
|
142
|
+
import { defineConfig } from "vite";
|
|
143
|
+
import { devtools } from "@tanstack/devtools-vite";
|
|
144
|
+
import { tanstackStart } from "@tanstack/solid-start/plugin/vite";
|
|
145
|
+
import solidPlugin from "vite-plugin-solid";
|
|
146
|
+
|
|
147
|
+
export default defineConfig({
|
|
148
|
+
plugins: [
|
|
149
|
+
devtools(),
|
|
150
|
+
tanstackStart({
|
|
151
|
+
router: {
|
|
152
|
+
routeFileIgnorePattern:
|
|
153
|
+
".content.(ts|tsx|js|mjs|cjs|jsx|json|jsonc|json5)$",
|
|
154
|
+
},
|
|
155
|
+
}),
|
|
156
|
+
solidPlugin({ ssr: true }),
|
|
157
|
+
intlayer(),
|
|
158
|
+
],
|
|
159
|
+
});
|
|
160
|
+
```
|
|
161
|
+
|
|
162
|
+
> O plugin Vite `intlayer()` é usado para integrar o Intlayer com o Vite. Ele garante a construção dos arquivos de declaração de conteúdo e os monitora no modo de desenvolvimento. Ele define as variáveis de ambiente do Intlayer dentro da aplicação Vite. Adicionalmente, ele fornece aliases para otimizar a performance.
|
|
163
|
+
|
|
164
|
+
### Passo 5: Criar o Layout Raiz (Root Layout)
|
|
165
|
+
|
|
166
|
+
Configure o seu layout raiz para suportar internacionalização usando `useMatches` para detectar a localidade atual e definindo os atributos `lang` e `dir` na tag `html`.
|
|
167
|
+
|
|
168
|
+
```tsx fileName="src/routes/__root.tsx"
|
|
169
|
+
import {
|
|
170
|
+
HeadContent,
|
|
171
|
+
Outlet,
|
|
172
|
+
Scripts,
|
|
173
|
+
createRootRouteWithContext,
|
|
174
|
+
useMatches,
|
|
175
|
+
} from "@tanstack/solid-router";
|
|
176
|
+
import { TanStackRouterDevtools } from "@tanstack/solid-router-devtools";
|
|
177
|
+
import { HydrationScript } from "solid-js/web";
|
|
178
|
+
import { Suspense } from "solid-js";
|
|
179
|
+
import { IntlayerProvider } from "solid-intlayer";
|
|
180
|
+
import { defaultLocale, getHTMLTextDir, type Locale } from "intlayer";
|
|
181
|
+
|
|
182
|
+
export const Route = createRootRouteWithContext()({
|
|
183
|
+
shellComponent: RootComponent,
|
|
184
|
+
});
|
|
185
|
+
|
|
186
|
+
type Params = {
|
|
187
|
+
locale: Locale;
|
|
188
|
+
};
|
|
189
|
+
|
|
190
|
+
function RootComponent() {
|
|
191
|
+
const matches = useMatches();
|
|
192
|
+
|
|
193
|
+
// Tenta encontrar a localidade nos parâmetros de qualquer correspondência ativa
|
|
194
|
+
// Isso assume que você usa o segmento dinâmico "/{-$locale}" na sua árvore de rotas
|
|
195
|
+
const locale =
|
|
196
|
+
(
|
|
197
|
+
matches().find((match) => match.routeId === "/{-$locale}/")
|
|
198
|
+
?.params as Params
|
|
199
|
+
)?.locale ?? defaultLocale;
|
|
200
|
+
|
|
201
|
+
return (
|
|
202
|
+
<html dir={getHTMLTextDir(locale)} lang={locale}>
|
|
203
|
+
<head>
|
|
204
|
+
<HydrationScript />
|
|
205
|
+
</head>
|
|
206
|
+
<body>
|
|
207
|
+
<HeadContent />
|
|
208
|
+
<IntlayerProvider locale={locale}>
|
|
209
|
+
<Suspense>
|
|
210
|
+
<Outlet />
|
|
211
|
+
<TanStackRouterDevtools />
|
|
212
|
+
</Suspense>
|
|
213
|
+
</IntlayerProvider>
|
|
214
|
+
<Scripts />
|
|
215
|
+
</body>
|
|
216
|
+
</html>
|
|
217
|
+
);
|
|
218
|
+
}
|
|
219
|
+
```
|
|
220
|
+
|
|
221
|
+
### Passo 6: Criar o Layout de Localidade (Opcional)
|
|
222
|
+
|
|
223
|
+
Crie um layout que lide com o prefixo de localidade e realize a validação. Este layout garantirá que apenas localidades válidas sejam processadas.
|
|
224
|
+
|
|
225
|
+
> Este passo é opcional se você não precisar validar o prefixo de localidade ao nível da rota.
|
|
226
|
+
|
|
227
|
+
```tsx fileName="src/routes/{-$locale}/route.tsx"
|
|
228
|
+
import { createFileRoute, Outlet, redirect } from "@tanstack/solid-router";
|
|
229
|
+
import { validatePrefix } from "intlayer";
|
|
230
|
+
|
|
231
|
+
export const Route = createFileRoute("/{-$locale}")({
|
|
232
|
+
beforeLoad: ({ params }) => {
|
|
233
|
+
const localeParam = params.locale;
|
|
234
|
+
|
|
235
|
+
// Validar o prefixo de localidade
|
|
236
|
+
const { isValid, localePrefix } = validatePrefix(localeParam);
|
|
237
|
+
|
|
238
|
+
if (!isValid) {
|
|
239
|
+
throw redirect({
|
|
240
|
+
to: "/{-$locale}/404",
|
|
241
|
+
params: { locale: localePrefix },
|
|
242
|
+
replace: true,
|
|
243
|
+
});
|
|
244
|
+
}
|
|
245
|
+
},
|
|
246
|
+
component: Outlet,
|
|
247
|
+
});
|
|
248
|
+
```
|
|
249
|
+
|
|
250
|
+
> Aqui, `{-$locale}` é um parâmetro de rota dinâmico que é substituído pela localidade atual. Esta notação torna o slot opcional, permitindo que funcione com modos de roteamento como `'prefix-no-default'` etc.
|
|
251
|
+
|
|
252
|
+
> Esteja ciente de que este slot pode causar problemas se você usar múltiplos segmentos dinâmicos na mesma rota (ex: `/{-$locale}/outro-caminho/$outroCaminhoDinamico/...`).
|
|
253
|
+
> Para o modo `'prefix-all'`, você pode preferir mudar o slot para `$locale`.
|
|
254
|
+
> Para o modo `'no-prefix'` ou `'search-params'`, você pode remover o slot inteiramente.
|
|
255
|
+
|
|
256
|
+
### Passo 7: Declarar o Seu Conteúdo
|
|
257
|
+
|
|
258
|
+
Crie e gerencie as suas declarações de conteúdo para armazenar traduções:
|
|
259
|
+
|
|
260
|
+
```tsx fileName="src/contents/page.content.ts"
|
|
261
|
+
import type { Dictionary } from "intlayer";
|
|
262
|
+
|
|
263
|
+
import { t } from "intlayer";
|
|
264
|
+
|
|
265
|
+
const appContent = {
|
|
266
|
+
content: {
|
|
267
|
+
links: {
|
|
268
|
+
about: t({
|
|
269
|
+
en: "About",
|
|
270
|
+
es: "Acerca de",
|
|
271
|
+
fr: "À propos",
|
|
272
|
+
}),
|
|
273
|
+
home: t({
|
|
274
|
+
en: "Home",
|
|
275
|
+
es: "Inicio",
|
|
276
|
+
fr: "Accueil",
|
|
277
|
+
}),
|
|
278
|
+
},
|
|
279
|
+
meta: {
|
|
280
|
+
title: t({
|
|
281
|
+
en: "Welcome to Intlayer + TanStack Router",
|
|
282
|
+
es: "Bienvenido a Intlayer + TanStack Router",
|
|
283
|
+
fr: "Bienvenue à Intlayer + TanStack Router",
|
|
284
|
+
}),
|
|
285
|
+
description: t({
|
|
286
|
+
en: "This is an example of using Intlayer with TanStack Router",
|
|
287
|
+
es: "Este es un ejemplo de uso de Intlayer con TanStack Router",
|
|
288
|
+
fr: "Ceci est un exemple d'utilisation d'Intlayer avec TanStack Router",
|
|
289
|
+
}),
|
|
290
|
+
},
|
|
291
|
+
},
|
|
292
|
+
key: "app",
|
|
293
|
+
} satisfies Dictionary;
|
|
294
|
+
|
|
295
|
+
export default appContent;
|
|
296
|
+
```
|
|
297
|
+
|
|
298
|
+
> As suas declarações de conteúdo podem ser definidas em qualquer lugar da sua aplicação, desde que sejam incluídas no diretório `contentDir` (por padrão, `./app`). E correspondam à extensão do arquivo de declaração de conteúdo (por padrão, `.content.{json,ts,tsx,js,jsx,mjs,cjs}`).
|
|
299
|
+
|
|
300
|
+
> Para mais detalhes, consulte a [documentação de declaração de conteúdo](https://github.com/aymericzip/intlayer/blob/main/docs/docs/pt/dictionary/content_file.md).
|
|
301
|
+
|
|
302
|
+
### Passo 8: Utilizar Componentes e Hooks Cientes de Localidade
|
|
303
|
+
|
|
304
|
+
Crie um componente `LocalizedLink` para navegação ciente de localidade:
|
|
305
|
+
|
|
306
|
+
```tsx fileName="src/components/LocalizedLink.tsx"
|
|
307
|
+
import { Link, type LinkProps } from "@tanstack/solid-router";
|
|
308
|
+
import { getPrefix } from "intlayer";
|
|
309
|
+
import { useLocale } from "solid-intlayer";
|
|
310
|
+
import type { JSX } from "solid-js";
|
|
311
|
+
|
|
312
|
+
export const LOCALE_ROUTE = "{-$locale}" as const;
|
|
313
|
+
|
|
314
|
+
export type RemoveLocaleParam<TVal> = TVal extends string
|
|
315
|
+
? RemoveLocaleFromString<TVal>
|
|
316
|
+
: TVal;
|
|
317
|
+
|
|
318
|
+
export type To = RemoveLocaleParam<LinkProps["to"]>;
|
|
319
|
+
|
|
320
|
+
type CollapseDoubleSlashes<TString extends string> =
|
|
321
|
+
TString extends `${infer THead}//${infer TTail}`
|
|
322
|
+
? CollapseDoubleSlashes<`${THead}/${TTail}`>
|
|
323
|
+
: TString;
|
|
324
|
+
|
|
325
|
+
export type LocalizedLinkProps = Omit<LinkProps, "to"> & {
|
|
326
|
+
to?: To;
|
|
327
|
+
} & JSX.AnchorHTMLAttributes<HTMLAnchorElement>;
|
|
328
|
+
|
|
329
|
+
type RemoveAll<
|
|
330
|
+
TString extends string,
|
|
331
|
+
TSub extends string,
|
|
332
|
+
> = TString extends `${infer THead}${TSub}${infer TTail}`
|
|
333
|
+
? RemoveAll<`${THead}${TTail}`, TSub>
|
|
334
|
+
: TString;
|
|
335
|
+
|
|
336
|
+
type RemoveLocaleFromString<TString extends string> = CollapseDoubleSlashes<
|
|
337
|
+
RemoveAll<TString, typeof LOCALE_ROUTE>
|
|
338
|
+
>;
|
|
339
|
+
|
|
340
|
+
export const LocalizedLink = (props: LocalizedLinkProps) => {
|
|
341
|
+
const { locale } = useLocale();
|
|
342
|
+
|
|
343
|
+
return (
|
|
344
|
+
<Link
|
|
345
|
+
{...props}
|
|
346
|
+
params={{
|
|
347
|
+
locale: getPrefix(locale()).localePrefix,
|
|
348
|
+
...(typeof props.params === "object" ? props.params : {}),
|
|
349
|
+
}}
|
|
350
|
+
to={`/${LOCALE_ROUTE}${props.to ?? ""}` as LinkProps["to"]}
|
|
351
|
+
/>
|
|
352
|
+
);
|
|
353
|
+
};
|
|
354
|
+
```
|
|
355
|
+
|
|
356
|
+
Este componente tem dois objetivos:
|
|
357
|
+
|
|
358
|
+
- Remover o prefixo desnecessário `{-$locale}` da URL.
|
|
359
|
+
- Injetar o parâmetro de localidade na URL para garantir que o usuário seja diretamente redirecionado para a rota localizada.
|
|
360
|
+
|
|
361
|
+
Depois, podemos criar um hook `useLocalizedNavigate` para navegação programática:
|
|
362
|
+
|
|
363
|
+
```tsx fileName="src/hooks/useLocalizedNavigate.tsx"
|
|
364
|
+
import { useNavigate } from "@tanstack/solid-router";
|
|
365
|
+
import { getLocalizedUrl } from "intlayer";
|
|
366
|
+
import { useLocale } from "solid-intlayer";
|
|
367
|
+
|
|
368
|
+
export const useLocalizedNavigate = () => {
|
|
369
|
+
const navigate = useNavigate();
|
|
370
|
+
const { locale } = useLocale();
|
|
371
|
+
|
|
372
|
+
const localizedNavigate = (to: string) => {
|
|
373
|
+
const localizedTo = getLocalizedUrl(to, locale());
|
|
374
|
+
return navigate({ to: localizedTo });
|
|
375
|
+
};
|
|
376
|
+
|
|
377
|
+
return localizedNavigate;
|
|
378
|
+
};
|
|
379
|
+
```
|
|
380
|
+
|
|
381
|
+
### Passo 9: Utilizar o Intlayer em Suas Páginas
|
|
382
|
+
|
|
383
|
+
Acesse seus dicionários de conteúdo através da sua aplicação:
|
|
384
|
+
|
|
385
|
+
#### Página Inicial Localizada
|
|
386
|
+
|
|
387
|
+
```tsx fileName="src/routes/{-$locale}/index.tsx"
|
|
388
|
+
import { createFileRoute } from "@tanstack/solid-router";
|
|
389
|
+
import { useIntlayer } from "solid-intlayer";
|
|
390
|
+
import { LocalizedLink } from "@/components/LocalizedLink";
|
|
391
|
+
|
|
392
|
+
export const Route = createFileRoute("/{-$locale}/")({
|
|
393
|
+
component: RouteComponent,
|
|
394
|
+
});
|
|
395
|
+
|
|
396
|
+
function RouteComponent() {
|
|
397
|
+
const content = useIntlayer("index-page");
|
|
398
|
+
|
|
399
|
+
return (
|
|
400
|
+
<main>
|
|
401
|
+
<h1>{content().heroTitle}</h1>
|
|
402
|
+
<p>{content().heroDesc}</p>
|
|
403
|
+
<div>
|
|
404
|
+
<LocalizedLink to="/">{content().navHome}</LocalizedLink>
|
|
405
|
+
<LocalizedLink to="/about">{content().navAbout}</LocalizedLink>
|
|
406
|
+
</div>
|
|
407
|
+
</main>
|
|
408
|
+
);
|
|
409
|
+
}
|
|
410
|
+
```
|
|
411
|
+
|
|
412
|
+
> No Solid, `useIntlayer` retorna uma função **accessor** (ex: `content()`). Você deve chamar esta função para acessar o conteúdo reativo.
|
|
413
|
+
>
|
|
414
|
+
> Para aprender mais sobre o hook `useIntlayer`, consulte a [documentação](https://github.com/aymericzip/intlayer/blob/main/docs/docs/pt/packages/solid-intlayer/useIntlayer.md).
|
|
415
|
+
|
|
416
|
+
### Passo 10: Criar um Componente Seletor de Localidade (Locale Switcher)
|
|
417
|
+
|
|
418
|
+
Crie um componente para permitir que os usuários mudem de língua:
|
|
419
|
+
|
|
420
|
+
```tsx fileName="src/components/LocaleSwitcher.tsx"
|
|
421
|
+
import { useLocation } from "@tanstack/solid-router";
|
|
422
|
+
import { getLocaleName, getPathWithoutLocale, getPrefix } from "intlayer";
|
|
423
|
+
import { For } from "solid-js";
|
|
424
|
+
import { useIntlayer, useLocale } from "solid-intlayer";
|
|
425
|
+
import { LocalizedLink, type To } from "./LocalizedLink";
|
|
426
|
+
|
|
427
|
+
export const LocaleSwitcher = () => {
|
|
428
|
+
const content = useIntlayer("locale-switcher");
|
|
429
|
+
const location = useLocation();
|
|
430
|
+
|
|
431
|
+
const { availableLocales, locale, setLocale } = useLocale();
|
|
432
|
+
|
|
433
|
+
const pathWithoutLocale = () => getPathWithoutLocale(location().pathname);
|
|
434
|
+
|
|
435
|
+
return (
|
|
436
|
+
<div class="flex flex-row gap-2">
|
|
437
|
+
<For each={availableLocales}>
|
|
438
|
+
{(localeEl) => (
|
|
439
|
+
<LocalizedLink
|
|
440
|
+
aria-current={localeEl === locale() ? "page" : undefined}
|
|
441
|
+
onClick={() => setLocale(localeEl)}
|
|
442
|
+
params={{ locale: getPrefix(localeEl).localePrefix }}
|
|
443
|
+
to={pathWithoutLocale() as To}
|
|
444
|
+
>
|
|
445
|
+
{getLocaleName(localeEl)}
|
|
446
|
+
</LocalizedLink>
|
|
447
|
+
)}
|
|
448
|
+
</For>
|
|
449
|
+
</div>
|
|
450
|
+
);
|
|
451
|
+
};
|
|
452
|
+
|
|
453
|
+
export default LocaleSwitcher;
|
|
454
|
+
```
|
|
455
|
+
|
|
456
|
+
> No Solid, `locale` de `useLocale` é um **signal accessor**. Use `locale()` (com parênteses) para ler o seu valor atual de forma reativa.
|
|
457
|
+
>
|
|
458
|
+
> Para aprender mais sobre o hook `useLocale`, consulte la [documentação](https://github.com/aymericzip/intlayer/blob/main/docs/docs/pt/packages/solid-intlayer/useLocale.md).
|
|
459
|
+
|
|
460
|
+
### Passo 11: Gerenciamento de Atributos HTML
|
|
461
|
+
|
|
462
|
+
Como visto no Passo 5, você pode gerenciar os atributos `lang` e `dir` da tag `html` usando `useMatches` no seu componente raiz. Isso garante que os atributos corretos sejam definidos no servidor e no cliente.
|
|
463
|
+
|
|
464
|
+
```tsx fileName="src/routes/__root.tsx"
|
|
465
|
+
const RootComponent: ParentComponent = (props) => {
|
|
466
|
+
const matches = useMatches();
|
|
467
|
+
|
|
468
|
+
// Tentar encontrar a localidade nos parâmetros de qualquer correspondência ativa
|
|
469
|
+
const locale =
|
|
470
|
+
(
|
|
471
|
+
matches().find((match) => match.routeId === "/{-$locale}/")
|
|
472
|
+
?.params as Params
|
|
473
|
+
)?.locale ?? defaultLocale;
|
|
474
|
+
|
|
475
|
+
return (
|
|
476
|
+
<html dir={getHTMLTextDir(locale)} lang={locale}>
|
|
477
|
+
{/* ... */}
|
|
478
|
+
</html>
|
|
479
|
+
);
|
|
480
|
+
};
|
|
481
|
+
```
|
|
482
|
+
|
|
483
|
+
---
|
|
484
|
+
|
|
485
|
+
### Passo 12: Adicionar Middleware (Opcional)
|
|
486
|
+
|
|
487
|
+
Você também pode usar o `intlayerProxy` para adicionar roteamento do lado do servidor à sua aplicação. Este plugin detectará automaticamente a localidade atual baseada na URL e definirá o cookie de localidade apropriado. Se nenhuma localidade for especificada, o plugin determinará a localidade mais apropriada baseada nas preferências de língua do navegador do usuário. Se nenhuma localidade for detectada, ele redirecionará para a localidade padrão.
|
|
488
|
+
|
|
489
|
+
> Note que para usar o `intlayerProxy` em produção, você precisa trocar o pacote `vite-intlayer` de `devDependencies` para `dependencies`.
|
|
490
|
+
|
|
491
|
+
```typescript {7,14-17} fileName="vite.config.ts"
|
|
492
|
+
import { tanstackStart } from "@tanstack/solid-start/plugin/vite";
|
|
493
|
+
import solid from "vite-plugin-solid";
|
|
494
|
+
import { nitro } from "nitro/vite";
|
|
495
|
+
import { defineConfig } from "vite";
|
|
496
|
+
import { intlayer, intlayerProxy } from "vite-intlayer";
|
|
497
|
+
|
|
498
|
+
export default defineConfig({
|
|
499
|
+
plugins: [
|
|
500
|
+
intlayerProxy(), // O proxy deve ser colocado antes do servidor se você usar o Nitro
|
|
501
|
+
nitro(),
|
|
502
|
+
intlayer(),
|
|
503
|
+
tanstackStart({
|
|
504
|
+
router: {
|
|
505
|
+
routeFileIgnorePattern:
|
|
506
|
+
".content.(ts|tsx|js|mjs|cjs|jsx|json|jsonc|json5)$",
|
|
507
|
+
},
|
|
508
|
+
}),
|
|
509
|
+
solid(),
|
|
510
|
+
],
|
|
511
|
+
});
|
|
512
|
+
```
|
|
513
|
+
|
|
514
|
+
---
|
|
515
|
+
|
|
516
|
+
### Passo 13: Internacionalizar Seus Metadados (Opcional)
|
|
517
|
+
|
|
518
|
+
Você também pode usar a função `getIntlayer` para acessar seus dicionários de conteúdo dentro do loader `head` para metadados cientes de localidade:
|
|
519
|
+
|
|
520
|
+
```tsx fileName="src/routes/{-$locale}/index.tsx"
|
|
521
|
+
import { createFileRoute } from "@tanstack/solid-router";
|
|
522
|
+
import { getIntlayer } from "intlayer";
|
|
523
|
+
|
|
524
|
+
export const Route = createFileRoute("/{-$locale}/")({
|
|
525
|
+
component: RouteComponent,
|
|
526
|
+
head: ({ params }) => {
|
|
527
|
+
const { locale } = params;
|
|
528
|
+
const metaContent = getIntlayer("page-metadata", locale);
|
|
529
|
+
|
|
530
|
+
return {
|
|
531
|
+
meta: [
|
|
532
|
+
{ title: metaContent.title },
|
|
533
|
+
{ content: metaContent.description, name: "description" },
|
|
534
|
+
],
|
|
535
|
+
};
|
|
536
|
+
},
|
|
537
|
+
});
|
|
538
|
+
```
|
|
539
|
+
|
|
540
|
+
---
|
|
541
|
+
|
|
542
|
+
### Passo 14: Recuperar a localidade nas suas server actions (Opcional)
|
|
543
|
+
|
|
544
|
+
Você pode querer acessar a localidade atual de dentro das suas server actions ou endpoints de API.
|
|
545
|
+
Você pode fazer isso usando o helper `getLocale` do `intlayer`.
|
|
546
|
+
|
|
547
|
+
Aqui está um exemplo usando as server functions do TanStack Start:
|
|
548
|
+
|
|
549
|
+
```tsx fileName="src/routes/{-$locale}/index.tsx"
|
|
550
|
+
import { createServerFn } from "@tanstack/solid-start";
|
|
551
|
+
import {
|
|
552
|
+
getRequestHeader,
|
|
553
|
+
getRequestHeaders,
|
|
554
|
+
} from "@tanstack/solid-start/server";
|
|
555
|
+
import { getCookie, getIntlayer, getLocale } from "intlayer";
|
|
556
|
+
|
|
557
|
+
export const getLocaleServer = createServerFn().handler(async () => {
|
|
558
|
+
const locale = await getLocale({
|
|
559
|
+
// Obter o cookie da requisição (padrão: 'INTLAYER_LOCALE')
|
|
560
|
+
getCookie: (name) => {
|
|
561
|
+
const cookieString = getRequestHeader("cookie");
|
|
562
|
+
|
|
563
|
+
return getCookie(name, cookieString);
|
|
564
|
+
},
|
|
565
|
+
// Obter o header da requisição (padrão: 'x-intlayer-locale')
|
|
566
|
+
// Fallback usando negociação Accept-Language
|
|
567
|
+
getHeader: (name) => getRequestHeader(name),
|
|
568
|
+
});
|
|
569
|
+
|
|
570
|
+
// Recuperar algum conteúdo usando getIntlayer()
|
|
571
|
+
const content = getIntlayer("app", locale);
|
|
572
|
+
|
|
573
|
+
return { locale, content };
|
|
574
|
+
});
|
|
575
|
+
```
|
|
576
|
+
|
|
577
|
+
---
|
|
578
|
+
|
|
579
|
+
### Passo 15: Gerenciar páginas não encontradas (Opcional)
|
|
580
|
+
|
|
581
|
+
Quando um usuário visita uma página inexistente, você pode exibir uma página personalizada de não encontrado e o prefixo de localidade pode impactar a maneira como a página de não encontrado é disparada.
|
|
582
|
+
|
|
583
|
+
#### Entendendo o Processamento de 404 do TanStack Router com Prefixos de Localidade
|
|
584
|
+
|
|
585
|
+
No TanStack Router, processar páginas 404 com rotas localizadas requer uma abordagem multicamada:
|
|
586
|
+
|
|
587
|
+
1. **Rota de 404 dedicada**: Uma rota específica para exibir a UI do 404
|
|
588
|
+
2. **Validação ao nível da rota**: Valida os prefixos de localidade e redireciona os inválidos para o 404
|
|
589
|
+
3. **Rota catch-all**: Captura quaisquer caminhos não correspondentes dentro do segmento de localidade
|
|
590
|
+
|
|
591
|
+
```tsx fileName="src/routes/{-$locale}/404.tsx"
|
|
592
|
+
import { createFileRoute } from "@tanstack/solid-router";
|
|
593
|
+
|
|
594
|
+
// Isso cria uma rota /[locale]/404 dedicada
|
|
595
|
+
// Ela é usada tanto como uma rota direta quanto importada como um componente em outros arquivos
|
|
596
|
+
export const Route = createFileRoute("/{-$locale}/404")({
|
|
597
|
+
component: NotFoundComponent,
|
|
598
|
+
});
|
|
599
|
+
|
|
600
|
+
// Exportado separadamente para que possa ser reutilizado em notFoundComponent e rotas catch-all
|
|
601
|
+
export function NotFoundComponent() {
|
|
602
|
+
return (
|
|
603
|
+
<div>
|
|
604
|
+
<h1>404</h1>
|
|
605
|
+
</div>
|
|
606
|
+
);
|
|
607
|
+
}
|
|
608
|
+
```
|
|
609
|
+
|
|
610
|
+
```tsx fileName="src/routes/{-$locale}/route.tsx"
|
|
611
|
+
import { createFileRoute, Outlet, redirect } from "@tanstack/solid-router";
|
|
612
|
+
import { validatePrefix } from "intlayer";
|
|
613
|
+
import { NotFoundComponent } from "./404";
|
|
614
|
+
|
|
615
|
+
export const Route = createFileRoute("/{-$locale}")({
|
|
616
|
+
// beforeLoad executa antes da rota renderizar (tanto no servidor quanto no cliente)
|
|
617
|
+
// É o lugar ideal para validar o prefixo de localidade
|
|
618
|
+
beforeLoad: ({ params }) => {
|
|
619
|
+
const localeParam = params.locale;
|
|
620
|
+
|
|
621
|
+
// validatePrefix verifica se a localidade é válida de acordo com a sua configuração do intlayer
|
|
622
|
+
const { isValid, localePrefix } = validatePrefix(localeParam);
|
|
623
|
+
|
|
624
|
+
if (!isValid) {
|
|
625
|
+
// Prefixo de localidade inválido - redireciona para a página 404 com um prefixo de localidade válido
|
|
626
|
+
throw redirect({
|
|
627
|
+
to: "/{-$locale}/404",
|
|
628
|
+
params: { locale: localePrefix },
|
|
629
|
+
});
|
|
630
|
+
}
|
|
631
|
+
},
|
|
632
|
+
component: Outlet,
|
|
633
|
+
// notFoundComponent é chamado quando uma rota filha não existe
|
|
634
|
+
// ex: /en/pagina-nao-existente dispara isso dentro do layout /en
|
|
635
|
+
notFoundComponent: NotFoundComponent,
|
|
636
|
+
});
|
|
637
|
+
```
|
|
638
|
+
|
|
639
|
+
```tsx fileName="src/routes/{-$locale}/$.tsx"
|
|
640
|
+
import { createFileRoute } from "@tanstack/solid-router";
|
|
641
|
+
|
|
642
|
+
import { NotFoundComponent } from "./404";
|
|
643
|
+
|
|
644
|
+
// A rota $ (splat/catch-all) corresponde a qualquer caminho que não corresponda a outras rotas
|
|
645
|
+
// ex: /en/algum/caminho/profundamente/aninhado/invalido
|
|
646
|
+
// Isso garante que TODOS os caminhos não correspondentes dentro de uma localidade mostrem a página 404
|
|
647
|
+
// Sem isso, caminhos profundos não correspondentes poderiam mostrar uma página em branco ou erro
|
|
648
|
+
export const Route = createFileRoute("/{-$locale}/$")({
|
|
649
|
+
component: NotFoundComponent,
|
|
650
|
+
});
|
|
651
|
+
```
|
|
652
|
+
|
|
653
|
+
### (Opcional) Passo 15: Extrair o conteúdo dos seus componentes
|
|
654
|
+
|
|
655
|
+
Se você tem uma base de código existente, transformar milhares de arquivos pode ser demorado.
|
|
656
|
+
|
|
657
|
+
Para facilitar este processo, o Intlayer propõe um [compilador](https://github.com/aymericzip/intlayer/blob/main/docs/docs/pt/compiler.md) / [extrator](https://github.com/aymericzip/intlayer/blob/main/docs/docs/pt/cli/extract.md) para transformar os seus componentes e extrair o conteúdo.
|
|
658
|
+
|
|
659
|
+
Para configurá-lo, você pode adicionar uma seção `compiler` no seu arquivo `intlayer.config.ts`:
|
|
660
|
+
|
|
661
|
+
```typescript fileName="intlayer.config.ts" codeFormat="typescript"
|
|
662
|
+
import { type IntlayerConfig } from "intlayer";
|
|
663
|
+
|
|
664
|
+
const config: IntlayerConfig = {
|
|
665
|
+
// ... Resto da sua configuração
|
|
666
|
+
compiler: {
|
|
667
|
+
/**
|
|
668
|
+
* Indica se o compilador deve ser habilitado.
|
|
669
|
+
*/
|
|
670
|
+
enabled: true,
|
|
671
|
+
|
|
672
|
+
/**
|
|
673
|
+
* Define o caminho dos arquivos de saída
|
|
674
|
+
*/
|
|
675
|
+
output: ({ fileName, extension }) => `./${fileName}${extension}`,
|
|
676
|
+
|
|
677
|
+
/**
|
|
678
|
+
* Indica se os componentes devem ser salvos após serem transformados.
|
|
679
|
+
*
|
|
680
|
+
* - Se `true`, o compilador reescreverá o arquivo do componente no disco. Assim, a transformação será permanente, e o compilador pulará a transformação para o próximo processo. Dessa forma, o compilador pode transformar a aplicação e depois pode ser removido.
|
|
681
|
+
*
|
|
682
|
+
* - Se `false`, o compilador injetará a chamada de função `useIntlayer()` no código apenas no output da build, mantendo a base de código intacta. A transformação será feita apenas em memória.
|
|
683
|
+
*/
|
|
684
|
+
saveComponents: false,
|
|
685
|
+
|
|
686
|
+
/**
|
|
687
|
+
* Prefixo da chave do dicionário
|
|
688
|
+
*/
|
|
689
|
+
dictionaryKeyPrefix: "",
|
|
690
|
+
},
|
|
691
|
+
};
|
|
692
|
+
|
|
693
|
+
export default config;
|
|
694
|
+
```
|
|
695
|
+
|
|
696
|
+
```javascript fileName="intlayer.config.mjs" codeFormat="esm"
|
|
697
|
+
/** @type {import('intlayer').IntlayerConfig} */
|
|
698
|
+
const config = {
|
|
699
|
+
// ... Resto da sua configuração
|
|
700
|
+
compiler: {
|
|
701
|
+
/**
|
|
702
|
+
* Indica se o compilador deve ser habilitado.
|
|
703
|
+
*/
|
|
704
|
+
enabled: true,
|
|
705
|
+
|
|
706
|
+
/**
|
|
707
|
+
* Define o caminho dos arquivos de saída
|
|
708
|
+
*/
|
|
709
|
+
output: ({ fileName, extension }) => `./${fileName}${extension}`,
|
|
710
|
+
|
|
711
|
+
/**
|
|
712
|
+
* Indica se os componentes devem ser salvos após serem transformados.
|
|
713
|
+
*
|
|
714
|
+
* - Se `true`, o compilador reescreverá o arquivo do componente no disco. Assim, a transformação será permanente, e o compilador pulará a transformação para o próximo processo. Dessa forma, o compilador pode transformar a aplicação e depois pode ser removido.
|
|
715
|
+
*
|
|
716
|
+
* - Se `false`, o compilador injetará a chamada de função `useIntlayer()` no código apenas no output da build, mantendo a base de código intacta. A transformação será feita apenas em memória.
|
|
717
|
+
*/
|
|
718
|
+
saveComponents: false,
|
|
719
|
+
|
|
720
|
+
/**
|
|
721
|
+
* Prefixo da chave do dicionário
|
|
722
|
+
*/
|
|
723
|
+
dictionaryKeyPrefix: "",
|
|
724
|
+
},
|
|
725
|
+
};
|
|
726
|
+
|
|
727
|
+
export default config;
|
|
728
|
+
```
|
|
729
|
+
|
|
730
|
+
```javascript fileName="intlayer.config.cjs" codeFormat="commonjs"
|
|
731
|
+
/** @type {import('intlayer').IntlayerConfig} */
|
|
732
|
+
const config = {
|
|
733
|
+
// ... Resto da sua configuração
|
|
734
|
+
compiler: {
|
|
735
|
+
/**
|
|
736
|
+
* Indica se o compilador deve ser habilitado.
|
|
737
|
+
*/
|
|
738
|
+
enabled: true,
|
|
739
|
+
|
|
740
|
+
/**
|
|
741
|
+
* Define o caminho dos arquivos de saída
|
|
742
|
+
*/
|
|
743
|
+
output: ({ fileName, extension }) => `./${fileName}${extension}`,
|
|
744
|
+
|
|
745
|
+
/**
|
|
746
|
+
* Indica se os componentes devem ser salvos após serem transformados.
|
|
747
|
+
*
|
|
748
|
+
* - Se `true`, o compilador reescreverá o arquivo do componente no disco. Assim, a transformação será permanente, e o compilador pulará a transformação para o próximo processo. Dessa forma, o compilador pode transformar a aplicação e depois pode ser removido.
|
|
749
|
+
*
|
|
750
|
+
* - Se `false`, o compilador injetará a chamada de função `useIntlayer()` no código apenas no output da build, mantendo a base de código intacta. A transformação será feita apenas em memória.
|
|
751
|
+
*/
|
|
752
|
+
saveComponents: false,
|
|
753
|
+
|
|
754
|
+
/**
|
|
755
|
+
* Prefixo da chave do dicionário
|
|
756
|
+
*/
|
|
757
|
+
dictionaryKeyPrefix: "",
|
|
758
|
+
},
|
|
759
|
+
};
|
|
760
|
+
|
|
761
|
+
module.exports = config;
|
|
762
|
+
```
|
|
763
|
+
|
|
764
|
+
<Tabs>
|
|
765
|
+
<Tab value='Comando extract'>
|
|
766
|
+
|
|
767
|
+
Rode o extrator para transformar os seus componentes e extrair o conteúdo
|
|
768
|
+
|
|
769
|
+
```bash packageManager="npm"
|
|
770
|
+
npx intlayer extract
|
|
771
|
+
```
|
|
772
|
+
|
|
773
|
+
```bash packageManager="pnpm"
|
|
774
|
+
pnpm intlayer extract
|
|
775
|
+
```
|
|
776
|
+
|
|
777
|
+
```bash packageManager="yarn"
|
|
778
|
+
yarn intlayer extract
|
|
779
|
+
```
|
|
780
|
+
|
|
781
|
+
```bash packageManager="bun"
|
|
782
|
+
bun x intlayer extract
|
|
783
|
+
```
|
|
784
|
+
|
|
785
|
+
</Tab>
|
|
786
|
+
<Tab value='Compilador Babel'>
|
|
787
|
+
|
|
788
|
+
Atualize o seu `vite.config.ts` para incluir o plugin `intlayerCompiler`:
|
|
789
|
+
|
|
790
|
+
```ts fileName="vite.config.ts"
|
|
791
|
+
import { intlayer, intlayerCompiler } from "vite-intlayer";
|
|
792
|
+
import { defineConfig } from "vite";
|
|
793
|
+
import { devtools } from "@tanstack/devtools-vite";
|
|
794
|
+
import { tanstackStart } from "@tanstack/solid-start/plugin/vite";
|
|
795
|
+
import solidPlugin from "vite-plugin-solid";
|
|
796
|
+
|
|
797
|
+
export default defineConfig({
|
|
798
|
+
plugins: [
|
|
799
|
+
devtools(),
|
|
800
|
+
tanstackStart({
|
|
801
|
+
router: {
|
|
802
|
+
routeFileIgnorePattern:
|
|
803
|
+
".content.(ts|tsx|js|mjs|cjs|jsx|json|jsonc|json5)$",
|
|
804
|
+
},
|
|
805
|
+
}),
|
|
806
|
+
solidPlugin({ ssr: true }),
|
|
807
|
+
intlayer(),
|
|
808
|
+
intlayerCompiler(),
|
|
809
|
+
],
|
|
810
|
+
});
|
|
811
|
+
```
|
|
812
|
+
|
|
813
|
+
```bash packageManager="npm"
|
|
814
|
+
npm run build # Ou rpm run dev
|
|
815
|
+
```
|
|
816
|
+
|
|
817
|
+
```bash packageManager="pnpm"
|
|
818
|
+
pnpm run build # Ou pnpm run dev
|
|
819
|
+
```
|
|
820
|
+
|
|
821
|
+
```bash packageManager="yarn"
|
|
822
|
+
yarn build # Ou yarn dev
|
|
823
|
+
```
|
|
824
|
+
|
|
825
|
+
```bash packageManager="bun"
|
|
826
|
+
bun run build # Ou bun run dev
|
|
827
|
+
```
|
|
828
|
+
|
|
829
|
+
</Tab>
|
|
830
|
+
</Tabs>
|
|
831
|
+
|
|
832
|
+
---
|
|
833
|
+
|
|
834
|
+
### Passo 16: Gerar um Sitemap (Opcional)
|
|
835
|
+
|
|
836
|
+
O Intlayer vem com um gerador de sitemap integrado para ajudá-lo a criar facilmente um sitemap para sua aplicação. Ele cuida das rotas localizadas e adiciona os metadados necessários para os mecanismos de busca.
|
|
837
|
+
|
|
838
|
+
> O sitemap gerado pelo Intlayer suporta o namespace `xhtml:link` (Hreflang XML Extensions). Ao contrário dos geradores de sitemap padrão que apenas listam URLs brutos, o Intlayer cria automaticamente os links bidirecionais necessários entre todas as versões de idioma de uma página (por exemplo, `/about`, `/about?lang=fr` e `/about?lang=es`). Isso garante que os mecanismos de busca indexem e sirvam corretamente a versão de idioma certa para o público certo.
|
|
839
|
+
|
|
840
|
+
Para usá-lo, você primeiro precisa configurar o seu `vite.config.ts` para habilitar a pré-renderização de suas rotas localizadas e desabilitar a geração de sitemap padrão do TanStack Start.
|
|
841
|
+
|
|
842
|
+
```typescript fileName="vite.config.ts"
|
|
843
|
+
import { localeMap, localeFlatMap } from "intlayer";
|
|
844
|
+
// ... outras importações
|
|
845
|
+
|
|
846
|
+
export const pathList = ["", "/about", "/404"];
|
|
847
|
+
|
|
848
|
+
const localizedPages = localeFlatMap(({ urlPrefix }) =>
|
|
849
|
+
pathList.map((path) => ({
|
|
850
|
+
path: `${urlPrefix}${path}`,
|
|
851
|
+
prerender: {
|
|
852
|
+
enabled: true,
|
|
853
|
+
},
|
|
854
|
+
}))
|
|
855
|
+
);
|
|
856
|
+
|
|
857
|
+
export default defineConfig({
|
|
858
|
+
plugins: [
|
|
859
|
+
// ... outros plugins
|
|
860
|
+
tanstackStart({
|
|
861
|
+
// ... outras configurações
|
|
862
|
+
sitemap: {
|
|
863
|
+
enabled: false,
|
|
864
|
+
},
|
|
865
|
+
prerender: {
|
|
866
|
+
enabled: true,
|
|
867
|
+
crawlLinks: false,
|
|
868
|
+
concurrency: 10,
|
|
869
|
+
},
|
|
870
|
+
pages: localizedPages,
|
|
871
|
+
}),
|
|
872
|
+
],
|
|
873
|
+
});
|
|
874
|
+
```
|
|
875
|
+
|
|
876
|
+
Em seguida, crie uma rota `src/routes/sitemap[.]xml.ts` que use a função `generateSitemap`:
|
|
877
|
+
|
|
878
|
+
```typescript fileName="src/routes/sitemap[.]xml.ts"
|
|
879
|
+
import { createFileRoute } from "@tanstack/solid-router";
|
|
880
|
+
import { generateSitemap } from "intlayer";
|
|
881
|
+
|
|
882
|
+
const SITE_URL = (
|
|
883
|
+
import.meta.env.VITE_SITE_URL ?? "http://localhost:3000"
|
|
884
|
+
).replace(/\/$/, "");
|
|
885
|
+
|
|
886
|
+
export const Route = createFileRoute("/sitemap.xml")({
|
|
887
|
+
server: {
|
|
888
|
+
handlers: {
|
|
889
|
+
GET: async () => {
|
|
890
|
+
const sitemap = generateSitemap(
|
|
891
|
+
[
|
|
892
|
+
{ path: "/", changefreq: "daily", priority: 1.0 },
|
|
893
|
+
{ path: "/about", changefreq: "monthly", priority: 0.8 },
|
|
894
|
+
],
|
|
895
|
+
{ siteUrl: SITE_URL }
|
|
896
|
+
);
|
|
897
|
+
|
|
898
|
+
return new Response(sitemap, {
|
|
899
|
+
headers: { "Content-Type": "application/xml" },
|
|
900
|
+
});
|
|
901
|
+
},
|
|
902
|
+
},
|
|
903
|
+
},
|
|
904
|
+
});
|
|
905
|
+
```
|
|
906
|
+
|
|
907
|
+
---
|
|
908
|
+
|
|
909
|
+
### Passo 17: Configurar TypeScript (Opcional)
|
|
910
|
+
|
|
911
|
+
O Intlayer usa a ampliação de módulo para obter os benefícios do TypeScript e tornar a sua base de código mais forte.
|
|
912
|
+
|
|
913
|
+
Certifique-se de que a sua configuração do TypeScript inclua os tipos autogerados:
|
|
914
|
+
|
|
915
|
+
```json5 fileName="tsconfig.json"
|
|
916
|
+
{
|
|
917
|
+
// ... as suas configurações existentes
|
|
918
|
+
include: [
|
|
919
|
+
// ... os seus includes existentes
|
|
920
|
+
".intlayer/**/*.ts", // Incluir os tipos autogerados
|
|
921
|
+
],
|
|
922
|
+
}
|
|
923
|
+
```
|
|
924
|
+
|
|
925
|
+
---
|
|
926
|
+
|
|
927
|
+
### Configuração Git
|
|
928
|
+
|
|
929
|
+
É recomendado ignorar os arquivos gerados pelo Intlayer. Isso permite que você evite committá-los no seu repositório Git.
|
|
930
|
+
|
|
931
|
+
Para fazer isso, você pode adicionar as seguintes instruções ao seu arquivo `.gitignore`:
|
|
932
|
+
|
|
933
|
+
```plaintext fileName=".gitignore"
|
|
934
|
+
# Ignorar os arquivos gerados pelo Intlayer
|
|
935
|
+
.intlayer
|
|
936
|
+
```
|
|
937
|
+
|
|
938
|
+
---
|
|
939
|
+
|
|
940
|
+
## Extensão VS Code
|
|
941
|
+
|
|
942
|
+
Para melhorar a sua experiência de desenvolvimento com o Intlayer, você pode instalar a **Extensão oficial do Intlayer VS Code**.
|
|
943
|
+
|
|
944
|
+
[Instalar a partir do VS Code Marketplace](https://marketplace.visualstudio.com/items?itemName=intlayer.intlayer-vs-code-extension)
|
|
945
|
+
|
|
946
|
+
Esta extensão oferece:
|
|
947
|
+
|
|
948
|
+
- **Autocompletar** para chaves de tradução.
|
|
949
|
+
- **Detecção de erros em tempo real** para traduções ausentes.
|
|
950
|
+
- **Previsões inline** de conteúdo traduzido.
|
|
951
|
+
- **Ações rápidas** para criar e atualizar traduções facilmente.
|
|
952
|
+
|
|
953
|
+
Para mais detalhes sobre como usar a extensão, consulte a [documentação da Extensão Intlayer VS Code](https://intlayer.org/doc/vs-code-extension).
|
|
954
|
+
|
|
955
|
+
---
|
|
956
|
+
|
|
957
|
+
## Ir Além
|
|
958
|
+
|
|
959
|
+
Para ir mais além, você pode implementar o [editor visual](https://github.com/aymericzip/intlayer/blob/main/docs/docs/pt/intlayer_visual_editor.md) ou externalizar o seu conteúdo usando o [CMS](https://github.com/aymericzip/intlayer/blob/main/docs/docs/pt/intlayer_CMS.md).
|
|
960
|
+
|
|
961
|
+
---
|
|
962
|
+
|
|
963
|
+
## Referências de Documentação
|
|
964
|
+
|
|
965
|
+
- [Documentação do Intlayer](https://intlayer.org)
|
|
966
|
+
- [Documentação do Tanstack Start](https://tanstack.com/start/latest)
|
|
967
|
+
- [hook useIntlayer](https://github.com/aymericzip/intlayer/blob/main/docs/docs/pt/packages/solid-intlayer/useIntlayer.md)
|
|
968
|
+
- [hook useLocale](https://github.com/aymericzip/intlayer/blob/main/docs/docs/pt/packages/solid-intlayer/useLocale.md)
|
|
969
|
+
- [Declaração de Conteúdo](https://github.com/aymericzip/intlayer/blob/main/docs/docs/pt/dictionary/content_file.md)
|
|
970
|
+
- [Configuração](https://github.com/aymericzip/intlayer/blob/main/docs/docs/pt/configuration.md)
|