@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: Iniziare con Intlayer in React Router v7
|
|
5
|
+
description: Scopri come aggiungere l'internazionalizzazione (i18n) alla tua applicazione React Router v7 utilizzando Intlayer. Segui questa guida completa per rendere la tua app multilingue con il routing consapevole della localizzazione.
|
|
6
|
+
keywords:
|
|
7
|
+
- Internazionalizzazione
|
|
8
|
+
- Documentazione
|
|
9
|
+
- Intlayer
|
|
10
|
+
- React Router v7
|
|
11
|
+
- React
|
|
12
|
+
- i18n
|
|
13
|
+
- TypeScript
|
|
14
|
+
- Routing Locale
|
|
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
|
+
# Iniziare con l'internazionalizzazione (i18n) usando Intlayer e React Router v7
|
|
25
|
+
|
|
26
|
+
Questa guida dimostra come integrare **Intlayer** per un'internazionalizzazione senza soluzione di continuità nei progetti React Router v7 con routing consapevole della localizzazione, supporto TypeScript e pratiche di sviluppo moderne.
|
|
27
|
+
|
|
28
|
+
## Cos'è Intlayer?
|
|
29
|
+
|
|
30
|
+
**Intlayer** è una libreria innovativa e open-source per l'internazionalizzazione (i18n) progettata per semplificare il supporto multilingue nelle applicazioni web moderne.
|
|
31
|
+
|
|
32
|
+
Con Intlayer, puoi:
|
|
33
|
+
|
|
34
|
+
- **Gestire facilmente le traduzioni** utilizzando dizionari dichiarativi a livello di componente.
|
|
35
|
+
- **Localizzare dinamicamente metadati**, rotte e contenuti.
|
|
36
|
+
- **Garantire il supporto TypeScript** con tipi generati automaticamente, migliorando l'autocompletamento e il rilevamento degli errori.
|
|
37
|
+
- **Beneficiare di funzionalità avanzate**, come il rilevamento e il cambio dinamico della localizzazione.
|
|
38
|
+
- **Abilitare il routing consapevole della localizzazione** con il sistema di routing basato su configurazione di React Router v7.
|
|
39
|
+
|
|
40
|
+
---
|
|
41
|
+
|
|
42
|
+
## Guida passo-passo per configurare Intlayer in un'applicazione React Router v7
|
|
43
|
+
|
|
44
|
+
### Passo 1: Installare le dipendenze
|
|
45
|
+
|
|
46
|
+
Installa i pacchetti necessari utilizzando il tuo gestore di pacchetti preferito:
|
|
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
|
+
Il pacchetto principale che fornisce strumenti di internazionalizzazione per la gestione della configurazione, la traduzione, la [dichiarazione dei contenuti](https://github.com/aymericzip/intlayer/blob/main/docs/docs/it/dictionary/get_started.md), la traspilazione e i [comandi CLI](https://github.com/aymericzip/intlayer/blob/main/docs/docs/it/intlayer_cli.md).
|
|
63
|
+
|
|
64
|
+
- **react-intlayer**
|
|
65
|
+
Il pacchetto che integra Intlayer con l'applicazione React. Fornisce provider di contesto e hook per l'internazionalizzazione in React.
|
|
66
|
+
|
|
67
|
+
- **vite-intlayer**
|
|
68
|
+
Include il plugin Vite per integrare Intlayer con il [bundler Vite](https://vite.dev/guide/why.html#why-bundle-for-production), oltre a middleware per rilevare la localizzazione preferita dall'utente, gestire i cookie e gestire il reindirizzamento degli URL.
|
|
69
|
+
|
|
70
|
+
### Passo 2: Configurazione del tuo progetto
|
|
71
|
+
|
|
72
|
+
Crea un file di configurazione per configurare le lingue della tua applicazione:
|
|
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, // Prefissa sempre la lingua predefinita negli URL
|
|
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
|
+
// Configurazione per Intlayer
|
|
112
|
+
const config = {
|
|
113
|
+
internationalization: {
|
|
114
|
+
defaultLocale: Locales.ENGLISH, // Lingua predefinita
|
|
115
|
+
locales: [Locales.ENGLISH, Locales.TURKISH], // Lingue supportate
|
|
116
|
+
},
|
|
117
|
+
middleware: {
|
|
118
|
+
prefixDefault: true, // Prefissa sempre la lingua predefinita negli URL
|
|
119
|
+
},
|
|
120
|
+
};
|
|
121
|
+
|
|
122
|
+
module.exports = config;
|
|
123
|
+
```
|
|
124
|
+
|
|
125
|
+
> Attraverso questo file di configurazione, puoi impostare URL localizzati, reindirizzamenti middleware, nomi dei cookie, la posizione e l'estensione delle tue dichiarazioni di contenuto, disabilitare i log di Intlayer nella console e altro ancora. Per un elenco completo dei parametri disponibili, consulta la [documentazione di configurazione](https://github.com/aymericzip/intlayer/blob/main/docs/docs/it/configuration.md).
|
|
126
|
+
|
|
127
|
+
### Passo 3: Configurare le Rotte di React Router v7
|
|
128
|
+
|
|
129
|
+
Configura la tua configurazione di routing con rotte consapevoli della localizzazione:
|
|
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"), // Pagina radice - reindirizza alla localizzazione
|
|
137
|
+
route("/:lang", "routes/[lang]/page.tsx"), // Pagina iniziale localizzata
|
|
138
|
+
route("/:lang/about", "routes/[lang]/about/page.tsx"), // Pagina "about" localizzata
|
|
139
|
+
]),
|
|
140
|
+
] satisfies RouteConfig;
|
|
141
|
+
```
|
|
142
|
+
|
|
143
|
+
### Passo 4: Integrare Intlayer nella Configurazione di Vite
|
|
144
|
+
|
|
145
|
+
Aggiungi il plugin intlayer nella tua configurazione:
|
|
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
|
+
> Il plugin Vite `intlayerPlugin()` viene utilizzato per integrare Intlayer con Vite. Garantisce la creazione dei file di dichiarazione del contenuto e li monitora in modalità sviluppo. Definisce le variabili d'ambiente di Intlayer all'interno dell'applicazione Vite. Inoltre, fornisce alias per ottimizzare le prestazioni.
|
|
164
|
+
|
|
165
|
+
### Passo 5: Creare i Componenti Layout
|
|
166
|
+
|
|
167
|
+
Configura il layout principale e i layout specifici per la localizzazione:
|
|
168
|
+
|
|
169
|
+
#### Layout Principale
|
|
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: Dichiara il Tuo Contenuto
|
|
187
|
+
|
|
188
|
+
Crea e gestisci le tue dichiarazioni di contenuto per memorizzare le traduzioni:
|
|
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 per creare facilmente applicazioni multilingue.",
|
|
203
|
+
}),
|
|
204
|
+
aboutLink: t({
|
|
205
|
+
en: "Scopri di noi",
|
|
206
|
+
tr: "Hakkımızda Öğrenin",
|
|
207
|
+
}),
|
|
208
|
+
homeLink: t({
|
|
209
|
+
en: "Home",
|
|
210
|
+
tr: "Ana Sayfa",
|
|
211
|
+
}),
|
|
212
|
+
},
|
|
213
|
+
} satisfies Dictionary;
|
|
214
|
+
|
|
215
|
+
export default pageContent;
|
|
216
|
+
```
|
|
217
|
+
|
|
218
|
+
> Le tue dichiarazioni di contenuto possono essere definite ovunque nella tua applicazione non appena sono incluse nella directory `contentDir` (di default, `./app`). E devono corrispondere all'estensione del file di dichiarazione del contenuto (di default, `.content.{json,ts,tsx,js,jsx,mjs,mjx,cjs,cjx}`).
|
|
219
|
+
|
|
220
|
+
> Per maggiori dettagli, consulta la [documentazione sulla dichiarazione del contenuto](https://github.com/aymericzip/intlayer/blob/main/docs/docs/it/dictionary/get_started.md).
|
|
221
|
+
|
|
222
|
+
### Passo 7: Crea Componenti Consapevoli della Locale
|
|
223
|
+
|
|
224
|
+
Crea un componente `LocalizedLink` per una navigazione consapevole della localizzazione:
|
|
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: Utilizza Intlayer nelle Tue Pagine
|
|
272
|
+
|
|
273
|
+
Accedi ai tuoi dizionari di contenuti in tutta l'applicazione:
|
|
274
|
+
|
|
275
|
+
#### Pagina di Reindirizzamento Root
|
|
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
|
+
#### Pagina Home Localizzata
|
|
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
|
+
> Per saperne di più sull'hook `useIntlayer`, consulta la [documentazione](https://github.com/aymericzip/intlayer/blob/main/docs/docs/it/packages/react-intlayer/useIntlayer.md).
|
|
323
|
+
|
|
324
|
+
### Passo 9: Crea un componente per il selettore di lingua
|
|
325
|
+
|
|
326
|
+
Crea un componente per permettere agli utenti di cambiare lingua:
|
|
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">Scegli la lingua: </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
|
+
> Per saperne di più sull'hook `useLocale`, consulta la [documentazione](https://github.com/aymericzip/intlayer/blob/main/docs/docs/it/packages/react-intlayer/useLocale.md).
|
|
368
|
+
|
|
369
|
+
### Passo 10: Aggiungere la Gestione degli Attributi HTML (Opzionale)
|
|
370
|
+
|
|
371
|
+
Crea un hook per gestire gli attributi lang e dir dell'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
|
+
Quindi usalo nel tuo componente root:
|
|
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 il hook
|
|
397
|
+
|
|
398
|
+
export default function RootLayout() {
|
|
399
|
+
useI18nHTMLAttributes(); // chiama il hook
|
|
400
|
+
|
|
401
|
+
return (
|
|
402
|
+
<IntlayerProvider>
|
|
403
|
+
<Outlet />
|
|
404
|
+
</IntlayerProvider>
|
|
405
|
+
);
|
|
406
|
+
}
|
|
407
|
+
```
|
|
408
|
+
|
|
409
|
+
### Passo 11: Compila ed Esegui la Tua Applicazione
|
|
410
|
+
|
|
411
|
+
Costruisci i dizionari di contenuto e avvia la tua applicazione:
|
|
412
|
+
|
|
413
|
+
```bash packageManager="npm"
|
|
414
|
+
# Costruisci i dizionari di Intlayer
|
|
415
|
+
npm run intlayer:build
|
|
416
|
+
|
|
417
|
+
# Avvia il server di sviluppo
|
|
418
|
+
npm run dev
|
|
419
|
+
```
|
|
420
|
+
|
|
421
|
+
```bash packageManager="pnpm"
|
|
422
|
+
# Costruisci i dizionari di Intlayer
|
|
423
|
+
pnpm intlayer:build
|
|
424
|
+
|
|
425
|
+
# Avvia il server di sviluppo
|
|
426
|
+
pnpm dev
|
|
427
|
+
```
|
|
428
|
+
|
|
429
|
+
```bash packageManager="yarn"
|
|
430
|
+
# Costruisci i dizionari di Intlayer
|
|
431
|
+
yarn intlayer:build
|
|
432
|
+
|
|
433
|
+
# Avvia il server di sviluppo
|
|
434
|
+
yarn dev
|
|
435
|
+
```
|
|
436
|
+
|
|
437
|
+
### Passo 12: Configura TypeScript (Opzionale)
|
|
438
|
+
|
|
439
|
+
Intlayer utilizza l'augmentazione dei moduli per sfruttare i vantaggi di TypeScript e rendere il tuo codice più robusto.
|
|
440
|
+
|
|
441
|
+
Assicurati che la tua configurazione di TypeScript includa i tipi generati automaticamente:
|
|
442
|
+
|
|
443
|
+
```json5 fileName="tsconfig.json"
|
|
444
|
+
{
|
|
445
|
+
compilerOptions: {
|
|
446
|
+
// ... le tue configurazioni TypeScript esistenti
|
|
447
|
+
},
|
|
448
|
+
include: [
|
|
449
|
+
// ... i tuoi include esistenti
|
|
450
|
+
".intlayer/**/*.ts", // Includi i tipi generati automaticamente
|
|
451
|
+
],
|
|
452
|
+
}
|
|
453
|
+
```
|
|
454
|
+
|
|
455
|
+
### Configurazione Git
|
|
456
|
+
|
|
457
|
+
Si consiglia di ignorare i file generati da Intlayer. Questo ti permette di evitare di committarli nel tuo repository Git.
|
|
458
|
+
|
|
459
|
+
Per farlo, puoi aggiungere le seguenti istruzioni al tuo file `.gitignore`:
|
|
460
|
+
|
|
461
|
+
```plaintext fileName=".gitignore"
|
|
462
|
+
# Ignora i file generati da Intlayer
|
|
463
|
+
.intlayer
|
|
464
|
+
```
|
|
465
|
+
|
|
466
|
+
---
|
|
467
|
+
|
|
468
|
+
## Distribuzione in Produzione
|
|
469
|
+
|
|
470
|
+
Quando distribuisci la tua applicazione:
|
|
471
|
+
|
|
472
|
+
1. **Compila la tua applicazione:**
|
|
473
|
+
|
|
474
|
+
```bash
|
|
475
|
+
npm run build
|
|
476
|
+
```
|
|
477
|
+
|
|
478
|
+
2. **Compila i dizionari di Intlayer:**
|
|
479
|
+
|
|
480
|
+
```bash
|
|
481
|
+
npm run intlayer:build
|
|
482
|
+
```
|
|
483
|
+
|
|
484
|
+
3. **Sposta `vite-intlayer` nelle dipendenze** se usi il middleware in produzione:
|
|
485
|
+
```bash
|
|
486
|
+
npm install vite-intlayer --save
|
|
487
|
+
```
|
|
488
|
+
|
|
489
|
+
La tua applicazione supporterà ora:
|
|
490
|
+
|
|
491
|
+
- **Struttura URL**: `/en`, `/en/about`, `/tr`, `/tr/about`
|
|
492
|
+
- **Rilevamento automatico della lingua** basato sulle preferenze del browser
|
|
493
|
+
- **Routing consapevole della lingua** con React Router v7
|
|
494
|
+
- **Supporto TypeScript** con tipi generati automaticamente
|
|
495
|
+
- **Rendering lato server** con gestione corretta della lingua
|
|
496
|
+
|
|
497
|
+
## Estensione VS Code
|
|
498
|
+
|
|
499
|
+
Per migliorare la tua esperienza di sviluppo con Intlayer, puoi installare la **Estensione ufficiale Intlayer per VS Code**.
|
|
500
|
+
|
|
501
|
+
[Installa dal Marketplace di VS Code](https://marketplace.visualstudio.com/items?itemName=intlayer.intlayer-vs-code-extension)
|
|
502
|
+
|
|
503
|
+
Questa estensione offre:
|
|
504
|
+
|
|
505
|
+
- **Completamento automatico** per le chiavi di traduzione.
|
|
506
|
+
- **Rilevamento in tempo reale degli errori** per traduzioni mancanti.
|
|
507
|
+
- **Anteprime inline** dei contenuti tradotti.
|
|
508
|
+
- **Azioni rapide** per creare e aggiornare facilmente le traduzioni.
|
|
509
|
+
|
|
510
|
+
Per maggiori dettagli su come utilizzare l'estensione, consulta la [documentazione dell'estensione Intlayer per VS Code](https://intlayer.org/doc/vs-code-extension).
|
|
511
|
+
|
|
512
|
+
---
|
|
513
|
+
|
|
514
|
+
## Vai oltre
|
|
515
|
+
|
|
516
|
+
Per andare oltre, puoi implementare l'[editor visuale](https://github.com/aymericzip/intlayer/blob/main/docs/docs/it/intlayer_visual_editor.md) o esternalizzare i tuoi contenuti utilizzando il [CMS](https://github.com/aymericzip/intlayer/blob/main/docs/docs/it/intlayer_CMS.md).
|
|
517
|
+
|
|
518
|
+
---
|
|
519
|
+
|
|
520
|
+
## Riferimenti alla documentazione
|
|
521
|
+
|
|
522
|
+
- [Documentazione Intlayer](https://intlayer.org)
|
|
523
|
+
- [Documentazione React Router v7](https://reactrouter.com/)
|
|
524
|
+
- [Hook useIntlayer](https://github.com/aymericzip/intlayer/blob/main/docs/docs/it/packages/react-intlayer/useIntlayer.md)
|
|
525
|
+
- [useLocale hook](https://github.com/aymericzip/intlayer/blob/main/docs/docs/it/packages/react-intlayer/useLocale.md)
|
|
526
|
+
- [Dichiarazione del Contenuto](https://github.com/aymericzip/intlayer/blob/main/docs/docs/it/dictionary/get_started.md)
|
|
527
|
+
- [Configurazione](https://github.com/aymericzip/intlayer/blob/main/docs/docs/it/configuration.md)
|
|
528
|
+
|
|
529
|
+
Questa guida completa fornisce tutto il necessario per integrare Intlayer con React Router v7 per un'applicazione completamente internazionalizzata con routing consapevole della localizzazione e supporto TypeScript.
|
|
530
|
+
|
|
531
|
+
## Cronologia della Documentazione
|
|
532
|
+
|
|
533
|
+
| Versione | Data | Modifiche |
|
|
534
|
+
| -------- | --------- | ---------------------------- |
|
|
535
|
+
| 5.8.2 | 2025-09-4 | Aggiunto per React Router v7 |
|