@intlayer/docs 5.8.1 → 6.0.0-canary.1
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/rag_powered_documentation_assistant.md +282 -0
- package/blog/de/rag_powered_documentation_assistant.md +282 -0
- package/blog/en/rag_powered_documentation_assistant.md +289 -0
- package/blog/en-GB/rag_powered_documentation_assistant.md +284 -0
- package/blog/es/rag_powered_documentation_assistant.md +308 -0
- package/blog/fr/rag_powered_documentation_assistant.md +308 -0
- package/blog/hi/rag_powered_documentation_assistant.md +284 -0
- package/blog/it/rag_powered_documentation_assistant.md +284 -0
- package/blog/ja/rag_powered_documentation_assistant.md +284 -0
- package/blog/ko/rag_powered_documentation_assistant.md +283 -0
- package/blog/pt/rag_powered_documentation_assistant.md +284 -0
- package/blog/ru/rag_powered_documentation_assistant.md +284 -0
- package/blog/tr/index.md +69 -0
- package/blog/tr/internationalization_and_SEO.md +273 -0
- package/blog/tr/intlayer_with_i18next.md +162 -0
- package/blog/tr/intlayer_with_next-i18next.md +367 -0
- package/blog/tr/intlayer_with_next-intl.md +392 -0
- package/blog/tr/intlayer_with_react-i18next.md +346 -0
- package/blog/tr/intlayer_with_react-intl.md +345 -0
- package/blog/tr/list_i18n_technologies/CMS/drupal.md +143 -0
- package/blog/tr/list_i18n_technologies/CMS/wix.md +167 -0
- package/blog/tr/list_i18n_technologies/CMS/wordpress.md +188 -0
- package/blog/tr/list_i18n_technologies/frameworks/angular.md +125 -0
- package/blog/tr/list_i18n_technologies/frameworks/flutter.md +150 -0
- package/blog/tr/list_i18n_technologies/frameworks/react-native.md +217 -0
- package/blog/tr/list_i18n_technologies/frameworks/react.md +155 -0
- package/blog/tr/list_i18n_technologies/frameworks/svelte.md +129 -0
- package/blog/tr/list_i18n_technologies/frameworks/vue.md +130 -0
- package/blog/tr/next-i18next_vs_next-intl_vs_intlayer.md +170 -0
- package/blog/tr/rag_powered_documentation_assistant.md +284 -0
- package/blog/tr/react-i18next_vs_react-intl_vs_intlayer.md +162 -0
- package/blog/tr/vue-i18n_vs_intlayer.md +276 -0
- package/blog/tr/what_is_internationalization.md +166 -0
- package/blog/zh/rag_powered_documentation_assistant.md +284 -0
- package/dist/cjs/generated/blog.entry.cjs +212 -0
- package/dist/cjs/generated/blog.entry.cjs.map +1 -1
- package/dist/cjs/generated/docs.entry.cjs +660 -132
- package/dist/cjs/generated/docs.entry.cjs.map +1 -1
- package/dist/cjs/generated/frequentQuestions.entry.cjs +84 -0
- package/dist/cjs/generated/frequentQuestions.entry.cjs.map +1 -1
- package/dist/cjs/generated/legal.entry.cjs +6 -0
- package/dist/cjs/generated/legal.entry.cjs.map +1 -1
- package/dist/esm/generated/blog.entry.mjs +212 -0
- package/dist/esm/generated/blog.entry.mjs.map +1 -1
- package/dist/esm/generated/docs.entry.mjs +660 -132
- package/dist/esm/generated/docs.entry.mjs.map +1 -1
- package/dist/esm/generated/frequentQuestions.entry.mjs +84 -0
- package/dist/esm/generated/frequentQuestions.entry.mjs.map +1 -1
- package/dist/esm/generated/legal.entry.mjs +6 -0
- package/dist/esm/generated/legal.entry.mjs.map +1 -1
- package/dist/types/generated/blog.entry.d.ts +1 -0
- package/dist/types/generated/blog.entry.d.ts.map +1 -1
- package/dist/types/generated/docs.entry.d.ts +5 -2
- package/dist/types/generated/docs.entry.d.ts.map +1 -1
- package/dist/types/generated/frequentQuestions.entry.d.ts.map +1 -1
- package/dist/types/generated/legal.entry.d.ts.map +1 -1
- package/docs/ar/autoFill.md +41 -40
- package/docs/ar/configuration.md +202 -199
- package/docs/ar/dictionary/content_file.md +1059 -0
- package/docs/ar/intlayer_CMS.md +4 -4
- package/docs/ar/intlayer_with_nestjs.md +271 -0
- package/docs/ar/intlayer_with_nextjs_page_router.md +1 -1
- package/docs/ar/intlayer_with_react_router_v7.md +533 -0
- package/docs/ar/intlayer_with_tanstack.md +465 -299
- package/docs/ar/intlayer_with_vite+preact.md +7 -7
- package/docs/ar/intlayer_with_vite+react.md +7 -7
- package/docs/ar/intlayer_with_vite+vue.md +9 -9
- package/docs/ar/packages/vite-intlayer/index.md +3 -3
- package/docs/ar/readme.md +261 -0
- package/docs/ar/testing.md +199 -0
- package/docs/de/autoFill.md +42 -19
- package/docs/de/configuration.md +155 -147
- package/docs/de/dictionary/content_file.md +1059 -0
- package/docs/de/intlayer_CMS.md +4 -5
- package/docs/de/intlayer_with_nestjs.md +270 -0
- package/docs/de/intlayer_with_nextjs_page_router.md +1 -1
- package/docs/de/intlayer_with_react_router_v7.md +537 -0
- package/docs/de/intlayer_with_tanstack.md +469 -302
- package/docs/de/intlayer_with_vite+preact.md +7 -7
- package/docs/de/intlayer_with_vite+react.md +7 -7
- package/docs/de/intlayer_with_vite+vue.md +9 -9
- package/docs/de/packages/vite-intlayer/index.md +3 -3
- package/docs/de/readme.md +261 -0
- package/docs/de/testing.md +200 -0
- package/docs/en/CI_CD.md +4 -6
- package/docs/en/autoFill.md +25 -5
- package/docs/en/configuration.md +45 -54
- package/docs/en/dictionary/content_file.md +1054 -0
- package/docs/en/intlayer_CMS.md +8 -7
- package/docs/en/intlayer_cli.md +112 -5
- package/docs/en/intlayer_with_nestjs.md +268 -0
- package/docs/en/intlayer_with_nextjs_page_router.md +1 -1
- package/docs/en/intlayer_with_react_router_v7.md +531 -0
- package/docs/en/intlayer_with_tanstack.md +463 -294
- package/docs/en/intlayer_with_vite+preact.md +8 -8
- package/docs/en/intlayer_with_vite+react.md +8 -8
- package/docs/en/intlayer_with_vite+vue.md +8 -8
- package/docs/en/packages/intlayer/getLocalizedUrl.md +102 -25
- package/docs/en/packages/vite-intlayer/index.md +3 -3
- package/docs/en/readme.md +261 -0
- package/docs/en/testing.md +200 -0
- package/docs/en-GB/autoFill.md +29 -6
- package/docs/en-GB/configuration.md +79 -71
- package/docs/en-GB/dictionary/content_file.md +1084 -0
- package/docs/en-GB/intlayer_CMS.md +4 -5
- package/docs/en-GB/intlayer_with_nestjs.md +268 -0
- package/docs/en-GB/intlayer_with_nextjs_page_router.md +1 -1
- package/docs/en-GB/intlayer_with_react_router_v7.md +533 -0
- package/docs/en-GB/intlayer_with_tanstack.md +466 -299
- package/docs/en-GB/intlayer_with_vite+preact.md +7 -7
- package/docs/en-GB/intlayer_with_vite+react.md +7 -7
- package/docs/en-GB/intlayer_with_vite+vue.md +9 -9
- package/docs/en-GB/packages/vite-intlayer/index.md +3 -3
- package/docs/en-GB/readme.md +261 -0
- package/docs/en-GB/testing.md +200 -0
- package/docs/es/autoFill.md +45 -23
- package/docs/es/configuration.md +171 -167
- package/docs/es/dictionary/content_file.md +1088 -0
- package/docs/es/intlayer_CMS.md +4 -5
- package/docs/es/intlayer_with_nestjs.md +268 -0
- package/docs/es/intlayer_with_nextjs_page_router.md +1 -1
- package/docs/es/intlayer_with_react_router_v7.md +533 -0
- package/docs/es/intlayer_with_tanstack.md +469 -280
- package/docs/es/intlayer_with_vite+preact.md +7 -7
- package/docs/es/intlayer_with_vite+react.md +7 -7
- package/docs/es/intlayer_with_vite+vue.md +9 -9
- package/docs/es/packages/vite-intlayer/index.md +3 -3
- package/docs/es/readme.md +261 -0
- package/docs/es/testing.md +200 -0
- package/docs/fr/autoFill.md +47 -24
- package/docs/fr/configuration.md +213 -198
- package/docs/fr/dictionary/content_file.md +1054 -0
- package/docs/fr/intlayer_CMS.md +4 -5
- package/docs/fr/intlayer_with_nestjs.md +268 -0
- package/docs/fr/intlayer_with_nextjs_page_router.md +1 -1
- package/docs/fr/intlayer_with_react_router_v7.md +549 -0
- package/docs/fr/intlayer_with_tanstack.md +465 -279
- package/docs/fr/intlayer_with_vite+preact.md +7 -7
- package/docs/fr/intlayer_with_vite+react.md +7 -7
- package/docs/fr/intlayer_with_vite+vue.md +9 -9
- package/docs/fr/packages/vite-intlayer/index.md +3 -3
- package/docs/fr/readme.md +261 -0
- package/docs/fr/testing.md +200 -0
- package/docs/hi/autoFill.md +47 -25
- package/docs/hi/configuration.md +194 -189
- package/docs/hi/dictionary/content_file.md +1056 -0
- package/docs/hi/intlayer_CMS.md +4 -5
- package/docs/hi/intlayer_with_nestjs.md +269 -0
- package/docs/hi/intlayer_with_nextjs_page_router.md +1 -1
- package/docs/hi/intlayer_with_react_router_v7.md +533 -0
- package/docs/hi/intlayer_with_tanstack.md +467 -282
- package/docs/hi/intlayer_with_vite+preact.md +7 -7
- package/docs/hi/intlayer_with_vite+react.md +7 -7
- package/docs/hi/intlayer_with_vite+vue.md +9 -9
- package/docs/hi/packages/vite-intlayer/index.md +3 -3
- package/docs/hi/readme.md +261 -0
- package/docs/hi/testing.md +200 -0
- package/docs/it/autoFill.md +46 -24
- package/docs/it/configuration.md +169 -161
- package/docs/it/dictionary/content_file.md +1061 -0
- package/docs/it/intlayer_CMS.md +4 -5
- package/docs/it/intlayer_with_nestjs.md +268 -0
- package/docs/it/intlayer_with_nextjs_page_router.md +1 -1
- package/docs/it/intlayer_with_react_router_v7.md +535 -0
- package/docs/it/intlayer_with_tanstack.md +467 -301
- package/docs/it/intlayer_with_vite+preact.md +7 -7
- package/docs/it/intlayer_with_vite+react.md +7 -7
- package/docs/it/intlayer_with_vite+vue.md +9 -9
- package/docs/it/packages/vite-intlayer/index.md +3 -3
- package/docs/it/readme.md +261 -0
- package/docs/it/testing.md +200 -0
- package/docs/ja/autoFill.md +45 -23
- package/docs/ja/configuration.md +243 -204
- package/docs/ja/dictionary/content_file.md +1064 -0
- package/docs/ja/intlayer_CMS.md +4 -5
- package/docs/ja/intlayer_with_nestjs.md +268 -0
- package/docs/ja/intlayer_with_nextjs_page_router.md +1 -1
- package/docs/ja/intlayer_with_react_router_v7.md +534 -0
- package/docs/ja/intlayer_with_tanstack.md +467 -303
- package/docs/ja/intlayer_with_vite+preact.md +7 -7
- package/docs/ja/intlayer_with_vite+react.md +7 -7
- package/docs/ja/intlayer_with_vite+vue.md +9 -9
- package/docs/ja/packages/vite-intlayer/index.md +3 -3
- package/docs/ja/readme.md +263 -0
- package/docs/ja/testing.md +200 -0
- package/docs/ko/autoFill.md +39 -16
- package/docs/ko/configuration.md +217 -197
- package/docs/ko/dictionary/content_file.md +1060 -0
- package/docs/ko/intlayer_CMS.md +4 -5
- package/docs/ko/intlayer_with_nestjs.md +268 -0
- package/docs/ko/intlayer_with_nextjs_page_router.md +1 -1
- package/docs/ko/intlayer_with_react_router_v7.md +540 -0
- package/docs/ko/intlayer_with_tanstack.md +466 -302
- package/docs/ko/intlayer_with_vite+preact.md +7 -7
- package/docs/ko/intlayer_with_vite+react.md +7 -7
- package/docs/ko/intlayer_with_vite+vue.md +9 -9
- package/docs/ko/packages/vite-intlayer/index.md +3 -3
- package/docs/ko/readme.md +261 -0
- package/docs/ko/testing.md +200 -0
- package/docs/pt/autoFill.md +39 -15
- package/docs/pt/configuration.md +165 -147
- package/docs/pt/dictionary/content_file.md +1062 -0
- package/docs/pt/intlayer_CMS.md +4 -5
- package/docs/pt/intlayer_with_nestjs.md +271 -0
- package/docs/pt/intlayer_with_nextjs_page_router.md +1 -1
- package/docs/pt/intlayer_with_react_router_v7.md +535 -0
- package/docs/pt/intlayer_with_tanstack.md +469 -300
- package/docs/pt/intlayer_with_vite+preact.md +7 -7
- package/docs/pt/intlayer_with_vite+react.md +7 -7
- package/docs/pt/intlayer_with_vite+vue.md +9 -9
- package/docs/pt/packages/vite-intlayer/index.md +3 -3
- package/docs/pt/readme.md +261 -0
- package/docs/pt/testing.md +200 -0
- package/docs/ru/autoFill.md +52 -30
- package/docs/ru/configuration.md +164 -117
- package/docs/ru/dictionary/content_file.md +1064 -0
- package/docs/ru/intlayer_CMS.md +4 -4
- package/docs/ru/intlayer_with_nestjs.md +270 -0
- package/docs/ru/intlayer_with_nextjs_page_router.md +1 -1
- package/docs/ru/intlayer_with_react_router_v7.md +534 -0
- package/docs/ru/intlayer_with_tanstack.md +470 -305
- package/docs/ru/intlayer_with_vite+preact.md +7 -7
- package/docs/ru/intlayer_with_vite+react.md +7 -7
- package/docs/ru/intlayer_with_vite+vue.md +9 -9
- package/docs/ru/packages/vite-intlayer/index.md +3 -3
- package/docs/ru/readme.md +261 -0
- package/docs/ru/testing.md +202 -0
- package/docs/tr/CI_CD.md +198 -0
- package/docs/tr/autoFill.md +201 -0
- package/docs/tr/configuration.md +585 -0
- package/docs/tr/dictionary/condition.md +243 -0
- package/docs/tr/dictionary/content_file.md +1055 -0
- package/docs/tr/dictionary/enumeration.md +251 -0
- package/docs/tr/dictionary/file.md +228 -0
- package/docs/tr/dictionary/function_fetching.md +218 -0
- package/docs/tr/dictionary/gender.md +279 -0
- package/docs/tr/dictionary/insertion.md +191 -0
- package/docs/tr/dictionary/markdown.md +385 -0
- package/docs/tr/dictionary/nesting.md +279 -0
- package/docs/tr/dictionary/translation.md +315 -0
- package/docs/tr/formatters.md +618 -0
- package/docs/tr/how_works_intlayer.md +254 -0
- package/docs/tr/index.md +168 -0
- package/docs/tr/interest_of_intlayer.md +288 -0
- package/docs/tr/intlayer_CMS.md +347 -0
- package/docs/tr/intlayer_cli.md +570 -0
- package/docs/tr/intlayer_visual_editor.md +269 -0
- package/docs/tr/intlayer_with_angular.md +694 -0
- package/docs/tr/intlayer_with_create_react_app.md +1218 -0
- package/docs/tr/intlayer_with_express.md +415 -0
- package/docs/tr/intlayer_with_lynx+react.md +511 -0
- package/docs/tr/intlayer_with_nestjs.md +268 -0
- package/docs/tr/intlayer_with_nextjs_14.md +1029 -0
- package/docs/tr/intlayer_with_nextjs_15.md +1506 -0
- package/docs/tr/intlayer_with_nextjs_page_router.md +1484 -0
- package/docs/tr/intlayer_with_nuxt.md +773 -0
- package/docs/tr/intlayer_with_react_native+expo.md +660 -0
- package/docs/tr/intlayer_with_react_router_v7.md +531 -0
- package/docs/tr/intlayer_with_tanstack.md +452 -0
- package/docs/tr/intlayer_with_vite+preact.md +1673 -0
- package/docs/tr/intlayer_with_vite+react.md +1632 -0
- package/docs/tr/intlayer_with_vite+solid.md +288 -0
- package/docs/tr/intlayer_with_vite+svelte.md +288 -0
- package/docs/tr/intlayer_with_vite+vue.md +1042 -0
- package/docs/tr/introduction.md +209 -0
- package/docs/tr/locale_mapper.md +244 -0
- package/docs/tr/mcp_server.md +207 -0
- package/docs/tr/packages/@intlayer/api/index.md +58 -0
- package/docs/tr/packages/@intlayer/chokidar/index.md +57 -0
- package/docs/tr/packages/@intlayer/cli/index.md +47 -0
- package/docs/tr/packages/@intlayer/config/index.md +142 -0
- package/docs/tr/packages/@intlayer/core/index.md +51 -0
- package/docs/tr/packages/@intlayer/design-system/index.md +47 -0
- package/docs/tr/packages/@intlayer/dictionary-entry/index.md +53 -0
- package/docs/tr/packages/@intlayer/editor/index.md +47 -0
- package/docs/tr/packages/@intlayer/editor-react/index.md +47 -0
- package/docs/tr/packages/@intlayer/webpack/index.md +61 -0
- package/docs/tr/packages/angular-intlayer/index.md +59 -0
- package/docs/tr/packages/express-intlayer/index.md +258 -0
- package/docs/tr/packages/express-intlayer/t.md +459 -0
- package/docs/tr/packages/intlayer/getConfiguration.md +151 -0
- package/docs/tr/packages/intlayer/getEnumeration.md +165 -0
- package/docs/tr/packages/intlayer/getHTMLTextDir.md +127 -0
- package/docs/tr/packages/intlayer/getLocaleLang.md +87 -0
- package/docs/tr/packages/intlayer/getLocaleName.md +124 -0
- package/docs/tr/packages/intlayer/getLocalizedUrl.md +324 -0
- package/docs/tr/packages/intlayer/getMultilingualUrls.md +225 -0
- package/docs/tr/packages/intlayer/getPathWithoutLocale.md +81 -0
- package/docs/tr/packages/intlayer/getTranslation.md +196 -0
- package/docs/tr/packages/intlayer/getTranslationContent.md +195 -0
- package/docs/tr/packages/intlayer/index.md +505 -0
- package/docs/tr/packages/intlayer-cli/index.md +71 -0
- package/docs/tr/packages/intlayer-editor/index.md +139 -0
- package/docs/tr/packages/lynx-intlayer/index.md +85 -0
- package/docs/tr/packages/next-intlayer/index.md +154 -0
- package/docs/tr/packages/next-intlayer/t.md +354 -0
- package/docs/tr/packages/next-intlayer/useDictionary.md +270 -0
- package/docs/tr/packages/next-intlayer/useIntlayer.md +265 -0
- package/docs/tr/packages/next-intlayer/useLocale.md +133 -0
- package/docs/tr/packages/nuxt-intlayer/index.md +59 -0
- package/docs/tr/packages/preact-intlayer/index.md +55 -0
- package/docs/tr/packages/react-intlayer/index.md +148 -0
- package/docs/tr/packages/react-intlayer/t.md +304 -0
- package/docs/tr/packages/react-intlayer/useDictionary.md +554 -0
- package/docs/tr/packages/react-intlayer/useI18n.md +478 -0
- package/docs/tr/packages/react-intlayer/useIntlayer.md +253 -0
- package/docs/tr/packages/react-intlayer/useLocale.md +212 -0
- package/docs/tr/packages/react-native-intlayer/index.md +85 -0
- package/docs/tr/packages/react-scripts-intlayer/index.md +82 -0
- package/docs/tr/packages/solid-intlayer/index.md +56 -0
- package/docs/tr/packages/svelte-intlayer/index.md +55 -0
- package/docs/tr/packages/vite-intlayer/index.md +82 -0
- package/docs/tr/packages/vue-intlayer/index.md +59 -0
- package/docs/tr/per_locale_file.md +321 -0
- package/docs/tr/readme.md +261 -0
- package/docs/tr/roadmap.md +338 -0
- package/docs/tr/testing.md +200 -0
- package/docs/tr/vs_code_extension.md +154 -0
- package/docs/zh/autoFill.md +40 -18
- package/docs/zh/configuration.md +245 -226
- package/docs/zh/dictionary/content_file.md +1064 -0
- package/docs/zh/intlayer_CMS.md +4 -5
- package/docs/zh/intlayer_with_nestjs.md +268 -0
- package/docs/zh/intlayer_with_nextjs_page_router.md +1 -1
- package/docs/zh/intlayer_with_react_router_v7.md +535 -0
- package/docs/zh/intlayer_with_tanstack.md +468 -278
- package/docs/zh/intlayer_with_vite+preact.md +7 -7
- package/docs/zh/intlayer_with_vite+react.md +7 -7
- package/docs/zh/intlayer_with_vite+vue.md +7 -7
- package/docs/zh/packages/vite-intlayer/index.md +3 -3
- package/docs/zh/readme.md +261 -0
- package/docs/zh/testing.md +198 -0
- package/frequent_questions/tr/SSR_Next_no_[locale].md +105 -0
- package/frequent_questions/tr/array_as_content_declaration.md +72 -0
- package/frequent_questions/tr/build_dictionaries.md +59 -0
- package/frequent_questions/tr/build_error_CI_CD.md +75 -0
- package/frequent_questions/tr/customized_locale_list.md +65 -0
- package/frequent_questions/tr/domain_routing.md +114 -0
- package/frequent_questions/tr/esbuild_error.md +30 -0
- package/frequent_questions/tr/get_locale_cookie.md +142 -0
- package/frequent_questions/tr/intlayer_command_undefined.md +156 -0
- package/frequent_questions/tr/locale_incorect_in_url.md +74 -0
- package/frequent_questions/tr/static_rendering.md +45 -0
- package/frequent_questions/tr/translated_path_url.md +56 -0
- package/frequent_questions/tr/unknown_command.md +98 -0
- package/legal/tr/privacy_notice.md +83 -0
- package/legal/tr/terms_of_service.md +55 -0
- package/package.json +12 -12
- package/src/generated/blog.entry.ts +212 -0
- package/src/generated/docs.entry.ts +663 -135
- package/src/generated/frequentQuestions.entry.ts +85 -1
- package/src/generated/legal.entry.ts +7 -1
- package/docs/ar/dictionary/content_extention_customization.md +0 -100
- package/docs/ar/dictionary/get_started.md +0 -527
- package/docs/de/dictionary/content_extention_customization.md +0 -100
- package/docs/de/dictionary/get_started.md +0 -531
- package/docs/en/dictionary/content_extention_customization.md +0 -102
- package/docs/en/dictionary/get_started.md +0 -529
- package/docs/en-GB/dictionary/content_extention_customization.md +0 -100
- package/docs/en-GB/dictionary/get_started.md +0 -591
- package/docs/es/dictionary/content_extention_customization.md +0 -100
- package/docs/es/dictionary/get_started.md +0 -527
- package/docs/fr/dictionary/content_extention_customization.md +0 -100
- package/docs/fr/dictionary/get_started.md +0 -527
- package/docs/hi/dictionary/content_extention_customization.md +0 -100
- package/docs/hi/dictionary/get_started.md +0 -527
- package/docs/it/dictionary/content_extention_customization.md +0 -113
- package/docs/it/dictionary/get_started.md +0 -573
- package/docs/ja/dictionary/content_extention_customization.md +0 -113
- package/docs/ja/dictionary/get_started.md +0 -576
- package/docs/ko/dictionary/content_extention_customization.md +0 -100
- package/docs/ko/dictionary/get_started.md +0 -530
- package/docs/pt/dictionary/content_extention_customization.md +0 -100
- package/docs/pt/dictionary/get_started.md +0 -532
- package/docs/ru/dictionary/content_extention_customization.md +0 -100
- package/docs/ru/dictionary/get_started.md +0 -575
- package/docs/zh/dictionary/content_extention_customization.md +0 -117
- package/docs/zh/dictionary/get_started.md +0 -533
|
@@ -0,0 +1,535 @@
|
|
|
1
|
+
---
|
|
2
|
+
createdAt: 2025-09-04
|
|
3
|
+
updatedAt: 2025-09-04
|
|
4
|
+
title: Começando a Internacionalizar (i18n) com Intlayer no React Router v7
|
|
5
|
+
description: Aprenda como adicionar internacionalização (i18n) à sua aplicação React Router v7 usando Intlayer. Siga este guia completo para tornar seu app multilíngue com roteamento sensível à localidade.
|
|
6
|
+
keywords:
|
|
7
|
+
- Internacionalização
|
|
8
|
+
- Documentação
|
|
9
|
+
- Intlayer
|
|
10
|
+
- React Router v7
|
|
11
|
+
- React
|
|
12
|
+
- i18n
|
|
13
|
+
- TypeScript
|
|
14
|
+
- Roteamento por Localidade
|
|
15
|
+
slugs:
|
|
16
|
+
- doc
|
|
17
|
+
- environment
|
|
18
|
+
- vite-and-react
|
|
19
|
+
- react-router-v7
|
|
20
|
+
applicationTemplate: https://github.com/AydinTheFirst/react-router-intlayer
|
|
21
|
+
author: AydinTheFirst
|
|
22
|
+
---
|
|
23
|
+
|
|
24
|
+
# Começando a Internacionalizar (i18n) com Intlayer e React Router v7
|
|
25
|
+
|
|
26
|
+
Este guia demonstra como integrar o **Intlayer** para uma internacionalização perfeita em projetos React Router v7 com roteamento sensível à localidade, suporte a TypeScript e práticas modernas de desenvolvimento.
|
|
27
|
+
|
|
28
|
+
## O que é o Intlayer?
|
|
29
|
+
|
|
30
|
+
**Intlayer** é uma biblioteca inovadora e open-source de internacionalização (i18n) projetada para simplificar o suporte multilíngue em aplicações web modernas.
|
|
31
|
+
|
|
32
|
+
Com o Intlayer, você pode:
|
|
33
|
+
|
|
34
|
+
- **Gerenciar traduções facilmente** usando dicionários declarativos no nível do componente.
|
|
35
|
+
- **Localizar dinamicamente metadados**, rotas e conteúdo.
|
|
36
|
+
- **Garantir suporte a TypeScript** com tipos gerados automaticamente, melhorando o autocompletar e a detecção de erros.
|
|
37
|
+
- **Aproveitar recursos avançados**, como detecção e troca dinâmica de localidade.
|
|
38
|
+
- **Habilitar roteamento sensível à localidade** com o sistema de roteamento baseado em configuração do React Router v7.
|
|
39
|
+
|
|
40
|
+
---
|
|
41
|
+
|
|
42
|
+
## Guia Passo a Passo para Configurar o Intlayer em uma Aplicação React Router v7
|
|
43
|
+
|
|
44
|
+
### Passo 1: Instalar Dependências
|
|
45
|
+
|
|
46
|
+
Instale os pacotes necessários usando seu gerenciador de pacotes preferido:
|
|
47
|
+
|
|
48
|
+
```bash packageManager="npm"
|
|
49
|
+
npm install intlayer react-intlayer
|
|
50
|
+
npm install vite-intlayer --save-dev
|
|
51
|
+
```
|
|
52
|
+
|
|
53
|
+
```bash packageManager="pnpm"
|
|
54
|
+
pnpm add intlayer react-intlayer
|
|
55
|
+
pnpm add vite-intlayer --save-dev
|
|
56
|
+
```
|
|
57
|
+
|
|
58
|
+
- **intlayer**
|
|
59
|
+
|
|
60
|
+
- **intlayer**
|
|
61
|
+
|
|
62
|
+
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/get_started.md), transpiração e [comandos CLI](https://github.com/aymericzip/intlayer/blob/main/docs/docs/pt/intlayer_cli.md).
|
|
63
|
+
|
|
64
|
+
- **react-intlayer**
|
|
65
|
+
O pacote que integra o Intlayer com a aplicação React. Ele fornece provedores de contexto e hooks para internacionalização em React.
|
|
66
|
+
|
|
67
|
+
- **vite-intlayer**
|
|
68
|
+
Inclui o plugin do Vite para integrar o Intlayer com o [empacotador Vite](https://vite.dev/guide/why.html#why-bundle-for-production), bem como middleware para detectar a localidade preferida do usuário, gerenciar cookies e lidar com redirecionamento de URL.
|
|
69
|
+
|
|
70
|
+
### Passo 2: Configuração do seu projeto
|
|
71
|
+
|
|
72
|
+
Crie um arquivo de configuração para configurar os idiomas da sua aplicação:
|
|
73
|
+
|
|
74
|
+
```typescript fileName="intlayer.config.ts" codeFormat="typescript"
|
|
75
|
+
import { type IntlayerConfig, Locales } from "intlayer";
|
|
76
|
+
|
|
77
|
+
const config: IntlayerConfig = {
|
|
78
|
+
internationalization: {
|
|
79
|
+
defaultLocale: Locales.ENGLISH,
|
|
80
|
+
locales: [Locales.ENGLISH, Locales.TURKISH],
|
|
81
|
+
},
|
|
82
|
+
middleware: {
|
|
83
|
+
prefixDefault: true, // Sempre prefixar o idioma padrão nas URLs
|
|
84
|
+
},
|
|
85
|
+
};
|
|
86
|
+
|
|
87
|
+
export default config;
|
|
88
|
+
```
|
|
89
|
+
|
|
90
|
+
```javascript fileName="intlayer.config.mjs" codeFormat="esm"
|
|
91
|
+
import { Locales } from "intlayer";
|
|
92
|
+
|
|
93
|
+
/** @type {import('intlayer').IntlayerConfig} */
|
|
94
|
+
const config = {
|
|
95
|
+
internationalization: {
|
|
96
|
+
defaultLocale: Locales.ENGLISH,
|
|
97
|
+
locales: [Locales.ENGLISH, Locales.TURKISH],
|
|
98
|
+
},
|
|
99
|
+
middleware: {
|
|
100
|
+
prefixDefault: true,
|
|
101
|
+
},
|
|
102
|
+
};
|
|
103
|
+
|
|
104
|
+
export default config;
|
|
105
|
+
```
|
|
106
|
+
|
|
107
|
+
```javascript fileName="intlayer.config.cjs" codeFormat="commonjs"
|
|
108
|
+
const { Locales } = require("intlayer");
|
|
109
|
+
|
|
110
|
+
/** @type {import('intlayer').IntlayerConfig} */
|
|
111
|
+
// Configuração do Intlayer
|
|
112
|
+
const config = {
|
|
113
|
+
internationalization: {
|
|
114
|
+
defaultLocale: Locales.ENGLISH,
|
|
115
|
+
locales: [Locales.ENGLISH, Locales.TURKISH],
|
|
116
|
+
},
|
|
117
|
+
middleware: {
|
|
118
|
+
prefixDefault: true,
|
|
119
|
+
},
|
|
120
|
+
};
|
|
121
|
+
|
|
122
|
+
module.exports = config;
|
|
123
|
+
```
|
|
124
|
+
|
|
125
|
+
> Através deste arquivo de configuração, você pode configurar URLs localizadas, redirecionamento via middleware, nomes de cookies, a localização e extensão das suas declarações de conteúdo, desabilitar logs do Intlayer no console, e muito mais. Para uma lista completa dos parâmetros disponíveis, consulte a [documentação de configuração](https://github.com/aymericzip/intlayer/blob/main/docs/docs/pt/configuration.md).
|
|
126
|
+
|
|
127
|
+
### Passo 3: Configurar Rotas do React Router v7
|
|
128
|
+
|
|
129
|
+
Configure sua configuração de rotas com rotas que reconhecem o idioma:
|
|
130
|
+
|
|
131
|
+
```typescript fileName="app/routes.ts" codeFormat="typescript"
|
|
132
|
+
import { layout, route, type RouteConfig } from "@react-router/dev/routes";
|
|
133
|
+
|
|
134
|
+
export default [
|
|
135
|
+
layout("routes/layout.tsx", [
|
|
136
|
+
route("/", "routes/page.tsx"), // Página raiz - redireciona para o idioma
|
|
137
|
+
route("/:lang", "routes/[lang]/page.tsx"), // Página inicial localizada
|
|
138
|
+
route("/:lang/about", "routes/[lang]/about/page.tsx"), // Página sobre localizada
|
|
139
|
+
]),
|
|
140
|
+
] satisfies RouteConfig;
|
|
141
|
+
```
|
|
142
|
+
|
|
143
|
+
### Passo 4: Integrar Intlayer na sua Configuração Vite
|
|
144
|
+
|
|
145
|
+
Adicione o plugin intlayer na sua configuração:
|
|
146
|
+
|
|
147
|
+
```typescript fileName="vite.config.ts" codeFormat="typescript"
|
|
148
|
+
import { reactRouter } from "@react-router/dev/vite";
|
|
149
|
+
import { defineConfig } from "vite";
|
|
150
|
+
import { intlayerMiddlewarePlugin, intlayerPlugin } from "vite-intlayer";
|
|
151
|
+
import tsconfigPaths from "vite-tsconfig-paths";
|
|
152
|
+
|
|
153
|
+
export default defineConfig({
|
|
154
|
+
plugins: [
|
|
155
|
+
reactRouter(),
|
|
156
|
+
tsconfigPaths(),
|
|
157
|
+
intlayerPlugin(),
|
|
158
|
+
intlayerMiddlewarePlugin(),
|
|
159
|
+
],
|
|
160
|
+
});
|
|
161
|
+
```
|
|
162
|
+
|
|
163
|
+
> O plugin Vite `intlayerPlugin()` é 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. Define variáveis de ambiente do Intlayer dentro da aplicação Vite. Além disso, fornece aliases para otimizar o desempenho.
|
|
164
|
+
|
|
165
|
+
### Passo 5: Criar Componentes de Layout
|
|
166
|
+
|
|
167
|
+
Configure seu layout raiz e layouts específicos para cada localidade:
|
|
168
|
+
|
|
169
|
+
#### Layout Raiz
|
|
170
|
+
|
|
171
|
+
```tsx fileName="app/routes/layout.tsx" codeFormat="typescript"
|
|
172
|
+
tsx fileName="app/routes/layout.tsx" codeFormat="typescript"
|
|
173
|
+
// app/routes/layout.tsx
|
|
174
|
+
import { Outlet } from "react-router";
|
|
175
|
+
import { IntlayerProvider } from "react-intlayer";
|
|
176
|
+
|
|
177
|
+
export default function RootLayout() {
|
|
178
|
+
return (
|
|
179
|
+
<IntlayerProvider>
|
|
180
|
+
<Outlet />
|
|
181
|
+
</IntlayerProvider>
|
|
182
|
+
);
|
|
183
|
+
}
|
|
184
|
+
```
|
|
185
|
+
|
|
186
|
+
### Passo 6: Declare Seu Conteúdo
|
|
187
|
+
|
|
188
|
+
Crie e gerencie suas declarações de conteúdo para armazenar traduções:
|
|
189
|
+
|
|
190
|
+
```tsx fileName="app/routes/[lang]/page.content.ts" contentDeclarationFormat="typescript"
|
|
191
|
+
import { t, type Dictionary } from "intlayer";
|
|
192
|
+
|
|
193
|
+
const pageContent = {
|
|
194
|
+
key: "page",
|
|
195
|
+
content: {
|
|
196
|
+
title: t({
|
|
197
|
+
en: "Welcome to React Router v7 + Intlayer",
|
|
198
|
+
tr: "React Router v7 + Intlayer'a Hoş Geldiniz",
|
|
199
|
+
}),
|
|
200
|
+
description: t({
|
|
201
|
+
en: "Build multilingual applications with ease using React Router v7 and Intlayer.",
|
|
202
|
+
tr: "React Router v7 e Intlayer para construir aplicações multilíngues com facilidade.",
|
|
203
|
+
}),
|
|
204
|
+
aboutLink: t({
|
|
205
|
+
en: "Saiba Mais Sobre Nós",
|
|
206
|
+
tr: "Hakkımızda Öğrenin",
|
|
207
|
+
}),
|
|
208
|
+
homeLink: t({
|
|
209
|
+
en: "Início",
|
|
210
|
+
tr: "Ana Sayfa",
|
|
211
|
+
}),
|
|
212
|
+
},
|
|
213
|
+
} satisfies Dictionary;
|
|
214
|
+
|
|
215
|
+
export default pageContent;
|
|
216
|
+
```
|
|
217
|
+
|
|
218
|
+
> Suas declarações de conteúdo podem ser definidas em qualquer lugar da sua aplicação, desde que estejam 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,mjx,cjs,cjx}`).
|
|
219
|
+
|
|
220
|
+
> Para mais detalhes, consulte a [documentação de declaração de conteúdo](https://github.com/aymericzip/intlayer/blob/main/docs/docs/pt/dictionary/get_started.md).
|
|
221
|
+
|
|
222
|
+
### Passo 7: Crie Componentes Sensíveis ao Locale
|
|
223
|
+
|
|
224
|
+
Crie um componente `LocalizedLink` para navegação sensível ao idioma:
|
|
225
|
+
|
|
226
|
+
```tsx fileName="app/components/localized-link.tsx" codeFormat="typescript"
|
|
227
|
+
// app/components/localized-link.tsx
|
|
228
|
+
import { getLocalizedUrl } from "intlayer";
|
|
229
|
+
import { useLocale } from "react-intlayer";
|
|
230
|
+
import React from "react";
|
|
231
|
+
import { Link, useLocation } from "react-router";
|
|
232
|
+
|
|
233
|
+
type RouterLinkProps = React.ComponentProps<typeof Link>;
|
|
234
|
+
|
|
235
|
+
export default function LocalizedLink({ to, ...props }: RouterLinkProps) {
|
|
236
|
+
const { locale } = useLocale();
|
|
237
|
+
const location = useLocation();
|
|
238
|
+
|
|
239
|
+
const isExternal = (path: string) =>
|
|
240
|
+
/^([a-z][a-z0-9+.-]*:)?\/\//i.test(path) || path.startsWith("mailto:");
|
|
241
|
+
|
|
242
|
+
if (typeof to === "string") {
|
|
243
|
+
if (to.startsWith("/") && !isExternal(to)) {
|
|
244
|
+
return <Link to={getLocalizedUrl(to, locale)} {...props} />;
|
|
245
|
+
}
|
|
246
|
+
return <Link to={to} {...props} />;
|
|
247
|
+
}
|
|
248
|
+
|
|
249
|
+
if (to && typeof to === "object") {
|
|
250
|
+
const pathname = (to as { pathname?: string }).pathname;
|
|
251
|
+
if (pathname && pathname.startsWith("/") && !isExternal(pathname)) {
|
|
252
|
+
return (
|
|
253
|
+
<Link
|
|
254
|
+
to={{ ...to, pathname: getLocalizedUrl(pathname, locale) }}
|
|
255
|
+
{...props}
|
|
256
|
+
/>
|
|
257
|
+
);
|
|
258
|
+
}
|
|
259
|
+
return <Link to={to} {...props} />;
|
|
260
|
+
}
|
|
261
|
+
|
|
262
|
+
return (
|
|
263
|
+
<Link
|
|
264
|
+
to={getLocalizedUrl(location.pathname + location.search, locale)}
|
|
265
|
+
{...props}
|
|
266
|
+
/>
|
|
267
|
+
);
|
|
268
|
+
}
|
|
269
|
+
```
|
|
270
|
+
|
|
271
|
+
### Passo 8: Utilize o Intlayer nas Suas Páginas
|
|
272
|
+
|
|
273
|
+
Acesse seus dicionários de conteúdo em toda a sua aplicação:
|
|
274
|
+
|
|
275
|
+
#### Página de Redirecionamento Raiz
|
|
276
|
+
|
|
277
|
+
```tsx fileName="app/routes/page.tsx" codeFormat="typescript"
|
|
278
|
+
// app/routes/page.tsx
|
|
279
|
+
import { useLocale } from "react-intlayer";
|
|
280
|
+
import { Navigate } from "react-router";
|
|
281
|
+
|
|
282
|
+
export default function Page() {
|
|
283
|
+
const { locale } = useLocale();
|
|
284
|
+
|
|
285
|
+
return <Navigate replace to={locale} />;
|
|
286
|
+
}
|
|
287
|
+
```
|
|
288
|
+
|
|
289
|
+
#### Página Inicial Localizada
|
|
290
|
+
|
|
291
|
+
```tsx fileName="app/routes/[lang]/page.tsx" codeFormat="typescript"
|
|
292
|
+
import { useIntlayer } from "react-intlayer";
|
|
293
|
+
import LocalizedLink from "~/components/localized-link";
|
|
294
|
+
|
|
295
|
+
export default function Page() {
|
|
296
|
+
const content = useIntlayer("page");
|
|
297
|
+
|
|
298
|
+
return (
|
|
299
|
+
<div style={{ padding: "2rem", textAlign: "center" }}>
|
|
300
|
+
<h1>{content.title}</h1>
|
|
301
|
+
<p>{content.description}</p>
|
|
302
|
+
<nav style={{ marginTop: "2rem" }}>
|
|
303
|
+
<LocalizedLink
|
|
304
|
+
to="/about"
|
|
305
|
+
style={{
|
|
306
|
+
display: "inline-block",
|
|
307
|
+
padding: "0.5rem 1rem",
|
|
308
|
+
backgroundColor: "#007bff",
|
|
309
|
+
color: "white",
|
|
310
|
+
textDecoration: "none",
|
|
311
|
+
borderRadius: "4px",
|
|
312
|
+
}}
|
|
313
|
+
>
|
|
314
|
+
{content.aboutLink}
|
|
315
|
+
</LocalizedLink>
|
|
316
|
+
</nav>
|
|
317
|
+
</div>
|
|
318
|
+
);
|
|
319
|
+
}
|
|
320
|
+
```
|
|
321
|
+
|
|
322
|
+
> Para saber mais sobre o hook `useIntlayer`, consulte a [documentação](https://github.com/aymericzip/intlayer/blob/main/docs/docs/pt/packages/react-intlayer/useIntlayer.md).
|
|
323
|
+
|
|
324
|
+
### Passo 9: Crie um Componente de Seletor de Idioma
|
|
325
|
+
|
|
326
|
+
Crie um componente para permitir que os usuários mudem de idioma:
|
|
327
|
+
|
|
328
|
+
```tsx fileName="app/components/locale-switcher.tsx" codeFormat="typescript"
|
|
329
|
+
import { getLocalizedUrl, getLocaleName } from "intlayer";
|
|
330
|
+
import { useLocale } from "react-intlayer";
|
|
331
|
+
import { useLocation, useNavigate } from "react-router";
|
|
332
|
+
|
|
333
|
+
export default function LocaleSwitcher() {
|
|
334
|
+
const { locale, availableLocales, setLocale } = useLocale();
|
|
335
|
+
const location = useLocation();
|
|
336
|
+
const navigate = useNavigate();
|
|
337
|
+
|
|
338
|
+
const handleLocaleChange = (newLocale: string) => {
|
|
339
|
+
const localizedUrl = getLocalizedUrl(
|
|
340
|
+
location.pathname + location.search,
|
|
341
|
+
newLocale
|
|
342
|
+
);
|
|
343
|
+
setLocale(newLocale);
|
|
344
|
+
navigate(localizedUrl);
|
|
345
|
+
};
|
|
346
|
+
|
|
347
|
+
return (
|
|
348
|
+
<div style={{ margin: "1rem 0" }}>
|
|
349
|
+
<label htmlFor="locale-select">Escolha o idioma: </label>
|
|
350
|
+
<select
|
|
351
|
+
id="locale-select"
|
|
352
|
+
value={locale}
|
|
353
|
+
onChange={(e) => handleLocaleChange(e.target.value)}
|
|
354
|
+
style={{ padding: "0.25rem", marginLeft: "0.5rem" }}
|
|
355
|
+
>
|
|
356
|
+
{availableLocales.map((availableLocale) => (
|
|
357
|
+
<option key={availableLocale} value={availableLocale}>
|
|
358
|
+
{getLocaleName(availableLocale)}
|
|
359
|
+
</option>
|
|
360
|
+
))}
|
|
361
|
+
</select>
|
|
362
|
+
</div>
|
|
363
|
+
);
|
|
364
|
+
}
|
|
365
|
+
```
|
|
366
|
+
|
|
367
|
+
> Para saber mais sobre o hook `useLocale`, consulte a [documentação](https://github.com/aymericzip/intlayer/blob/main/docs/docs/pt/packages/react-intlayer/useLocale.md).
|
|
368
|
+
|
|
369
|
+
### Passo 10: Adicionar Gerenciamento de Atributos HTML (Opcional)
|
|
370
|
+
|
|
371
|
+
Crie um hook para gerenciar os atributos lang e dir do HTML:
|
|
372
|
+
|
|
373
|
+
```tsx fileName="app/hooks/useI18nHTMLAttributes.tsx" codeFormat="typescript"
|
|
374
|
+
// app/hooks/useI18nHTMLAttributes.tsx
|
|
375
|
+
import { getHTMLTextDir } from "intlayer";
|
|
376
|
+
import { useEffect } from "react";
|
|
377
|
+
import { useLocale } from "react-intlayer";
|
|
378
|
+
|
|
379
|
+
export const useI18nHTMLAttributes = () => {
|
|
380
|
+
const { locale } = useLocale();
|
|
381
|
+
|
|
382
|
+
useEffect(() => {
|
|
383
|
+
document.documentElement.lang = locale;
|
|
384
|
+
document.documentElement.dir = getHTMLTextDir(locale);
|
|
385
|
+
}, [locale]);
|
|
386
|
+
};
|
|
387
|
+
```
|
|
388
|
+
|
|
389
|
+
Então use-o no seu componente raiz:
|
|
390
|
+
|
|
391
|
+
```tsx fileName="app/root.tsx" codeFormat="typescript"
|
|
392
|
+
// app/routes/layout.tsx
|
|
393
|
+
import { Outlet } from "react-router";
|
|
394
|
+
import { IntlayerProvider } from "react-intlayer";
|
|
395
|
+
|
|
396
|
+
import { useI18nHTMLAttributes } from "app/hooks/useI18nHTMLAttributes"; // importa o hook
|
|
397
|
+
|
|
398
|
+
export default function RootLayout() {
|
|
399
|
+
useI18nHTMLAttributes(); // chama o hook
|
|
400
|
+
|
|
401
|
+
return (
|
|
402
|
+
<IntlayerProvider>
|
|
403
|
+
<Outlet />
|
|
404
|
+
</IntlayerProvider>
|
|
405
|
+
);
|
|
406
|
+
}
|
|
407
|
+
```
|
|
408
|
+
|
|
409
|
+
### Passo 11: Compile e Execute Sua Aplicação
|
|
410
|
+
|
|
411
|
+
Construa os dicionários de conteúdo e execute sua aplicação:
|
|
412
|
+
|
|
413
|
+
```bash packageManager="npm"
|
|
414
|
+
# Construir dicionários do Intlayer
|
|
415
|
+
npm run intlayer:build
|
|
416
|
+
|
|
417
|
+
# Iniciar servidor de desenvolvimento
|
|
418
|
+
npm run dev
|
|
419
|
+
```
|
|
420
|
+
|
|
421
|
+
```bash packageManager="pnpm"
|
|
422
|
+
# Construir dicionários do Intlayer
|
|
423
|
+
pnpm intlayer:build
|
|
424
|
+
|
|
425
|
+
# Iniciar servidor de desenvolvimento
|
|
426
|
+
pnpm dev
|
|
427
|
+
```
|
|
428
|
+
|
|
429
|
+
```bash packageManager="yarn"
|
|
430
|
+
# Construir dicionários do Intlayer
|
|
431
|
+
yarn intlayer:build
|
|
432
|
+
|
|
433
|
+
# Iniciar servidor de desenvolvimento
|
|
434
|
+
yarn dev
|
|
435
|
+
```
|
|
436
|
+
|
|
437
|
+
### Passo 12: Configurar TypeScript (Opcional)
|
|
438
|
+
|
|
439
|
+
O Intlayer utiliza a ampliação de módulos para aproveitar os benefícios do TypeScript e tornar sua base de código mais robusta.
|
|
440
|
+
|
|
441
|
+
Certifique-se de que sua configuração do TypeScript inclua os tipos gerados automaticamente:
|
|
442
|
+
|
|
443
|
+
```json5 fileName="tsconfig.json"
|
|
444
|
+
{
|
|
445
|
+
compilerOptions: {
|
|
446
|
+
// ... suas configurações existentes do TypeScript
|
|
447
|
+
},
|
|
448
|
+
include: [
|
|
449
|
+
// ... seus includes existentes
|
|
450
|
+
".intlayer/**/*.ts", // Incluir os tipos gerados automaticamente
|
|
451
|
+
],
|
|
452
|
+
}
|
|
453
|
+
```
|
|
454
|
+
|
|
455
|
+
### Configuração do Git
|
|
456
|
+
|
|
457
|
+
É recomendado ignorar os arquivos gerados pelo Intlayer. Isso permite evitar que eles sejam commitados no seu repositório Git.
|
|
458
|
+
|
|
459
|
+
Para isso, você pode adicionar as seguintes instruções ao seu arquivo `.gitignore`:
|
|
460
|
+
|
|
461
|
+
```plaintext fileName=".gitignore"
|
|
462
|
+
# Ignorar os arquivos gerados pelo Intlayer
|
|
463
|
+
.intlayer
|
|
464
|
+
```
|
|
465
|
+
|
|
466
|
+
---
|
|
467
|
+
|
|
468
|
+
## Implantação em Produção
|
|
469
|
+
|
|
470
|
+
Ao implantar sua aplicação:
|
|
471
|
+
|
|
472
|
+
1. **Compile sua aplicação:**
|
|
473
|
+
|
|
474
|
+
```bash
|
|
475
|
+
npm run build
|
|
476
|
+
```
|
|
477
|
+
|
|
478
|
+
2. **Compile os dicionários do Intlayer:**
|
|
479
|
+
|
|
480
|
+
```bash
|
|
481
|
+
npm run intlayer:build
|
|
482
|
+
```
|
|
483
|
+
|
|
484
|
+
3. **Mova `vite-intlayer` para as dependências** se estiver usando middleware em produção:
|
|
485
|
+
```bash
|
|
486
|
+
npm install vite-intlayer --save
|
|
487
|
+
```
|
|
488
|
+
|
|
489
|
+
Sua aplicação agora suportará:
|
|
490
|
+
|
|
491
|
+
- **Estrutura de URL**: `/en`, `/en/about`, `/tr`, `/tr/about`
|
|
492
|
+
- **Detecção automática de localidade** baseada nas preferências do navegador
|
|
493
|
+
- **Roteamento sensível à localidade** com React Router v7
|
|
494
|
+
- **Suporte a TypeScript** com tipos gerados automaticamente
|
|
495
|
+
- **Renderização do lado servidor** com tratamento adequado da localidade
|
|
496
|
+
|
|
497
|
+
## Extensão VS Code
|
|
498
|
+
|
|
499
|
+
Para melhorar sua experiência de desenvolvimento com o Intlayer, você pode instalar a **Extensão oficial Intlayer para VS Code**.
|
|
500
|
+
|
|
501
|
+
[Instalar no VS Code Marketplace](https://marketplace.visualstudio.com/items?itemName=intlayer.intlayer-vs-code-extension)
|
|
502
|
+
|
|
503
|
+
Esta extensão oferece:
|
|
504
|
+
|
|
505
|
+
- **Autocompletar** para chaves de tradução.
|
|
506
|
+
- **Detecção de erros em tempo real** para traduções ausentes.
|
|
507
|
+
- **Visualizações inline** do conteúdo traduzido.
|
|
508
|
+
- **Ações rápidas** para criar e atualizar traduções facilmente.
|
|
509
|
+
|
|
510
|
+
Para mais detalhes sobre como usar a extensão, consulte a [documentação da Extensão Intlayer para VS Code](https://intlayer.org/doc/vs-code-extension).
|
|
511
|
+
|
|
512
|
+
---
|
|
513
|
+
|
|
514
|
+
## Avançar
|
|
515
|
+
|
|
516
|
+
Para avançar, você pode implementar o [editor visual](https://github.com/aymericzip/intlayer/blob/main/docs/docs/pt/intlayer_visual_editor.md) ou externalizar seu conteúdo usando o [CMS](https://github.com/aymericzip/intlayer/blob/main/docs/docs/pt/intlayer_CMS.md).
|
|
517
|
+
|
|
518
|
+
---
|
|
519
|
+
|
|
520
|
+
## Referências da Documentação
|
|
521
|
+
|
|
522
|
+
- [Documentação Intlayer](https://intlayer.org)
|
|
523
|
+
- [Documentação React Router v7](https://reactrouter.com/)
|
|
524
|
+
- [Hook useIntlayer](https://github.com/aymericzip/intlayer/blob/main/docs/docs/pt/packages/react-intlayer/useIntlayer.md)
|
|
525
|
+
- [useLocale hook](https://github.com/aymericzip/intlayer/blob/main/docs/docs/pt/packages/react-intlayer/useLocale.md)
|
|
526
|
+
- [Declaração de Conteúdo](https://github.com/aymericzip/intlayer/blob/main/docs/docs/pt/dictionary/get_started.md)
|
|
527
|
+
- [Configuração](https://github.com/aymericzip/intlayer/blob/main/docs/docs/pt/configuration.md)
|
|
528
|
+
|
|
529
|
+
Este guia abrangente fornece tudo o que você precisa para integrar o Intlayer com o React Router v7 para uma aplicação totalmente internacionalizada com roteamento sensível à localidade e suporte a TypeScript.
|
|
530
|
+
|
|
531
|
+
## Histórico da Documentação
|
|
532
|
+
|
|
533
|
+
| Versão | Data | Alterações |
|
|
534
|
+
| ------ | --------- | ------------------------------- |
|
|
535
|
+
| 5.8.2 | 2025-09-4 | Adicionado para React Router v7 |
|