@intlayer/docs 5.8.1-canary.0 → 6.0.0-canary.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/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 +13 -13
- 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
package/docs/en/intlayer_CMS.md
CHANGED
|
@@ -262,7 +262,7 @@ The Intlayer CMS is able to hot reload the dictionaries when a change is detecte
|
|
|
262
262
|
|
|
263
263
|
Without the hot reloading, a new build of the application will be needed to display the new content.
|
|
264
264
|
|
|
265
|
-
By activating the [`
|
|
265
|
+
By activating the [`liveSync`](https://intlayer.org/doc/concept/configuration#editor-configuration) configuration, the application will automatically replace the updated content when it is detected.
|
|
266
266
|
|
|
267
267
|
```typescript fileName="intlayer.config.ts" codeFormat="typescript"
|
|
268
268
|
import type { IntlayerConfig } from "intlayer";
|
|
@@ -280,7 +280,7 @@ const config: IntlayerConfig = {
|
|
|
280
280
|
*
|
|
281
281
|
* Default: false
|
|
282
282
|
*/
|
|
283
|
-
|
|
283
|
+
liveSync: true,
|
|
284
284
|
},
|
|
285
285
|
};
|
|
286
286
|
|
|
@@ -302,7 +302,7 @@ const config = {
|
|
|
302
302
|
*
|
|
303
303
|
* Default: false
|
|
304
304
|
*/
|
|
305
|
-
|
|
305
|
+
liveSync: true,
|
|
306
306
|
},
|
|
307
307
|
};
|
|
308
308
|
|
|
@@ -324,7 +324,7 @@ const config = {
|
|
|
324
324
|
*
|
|
325
325
|
* Default: false
|
|
326
326
|
*/
|
|
327
|
-
|
|
327
|
+
liveSync: true,
|
|
328
328
|
},
|
|
329
329
|
};
|
|
330
330
|
|
|
@@ -355,6 +355,7 @@ If you encounter any issues with the CMS, check the following:
|
|
|
355
355
|
|
|
356
356
|
## Doc History
|
|
357
357
|
|
|
358
|
-
| Version | Date | Changes
|
|
359
|
-
| ------- | ---------- |
|
|
360
|
-
|
|
|
358
|
+
| Version | Date | Changes |
|
|
359
|
+
| ------- | ---------- | --------------------------------------- |
|
|
360
|
+
| 6.0.0 | 2025-09-04 | Replace `hotReload` field by `liveSync` |
|
|
361
|
+
| 5.5.10 | 2025-06-29 | Init history |
|
package/docs/en/intlayer_cli.md
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
---
|
|
2
2
|
createdAt: 2024-08-11
|
|
3
|
-
updatedAt: 2025-
|
|
3
|
+
updatedAt: 2025-09-17
|
|
4
4
|
title: CLI
|
|
5
5
|
description: Discover how to use the Intlayer CLI to manage your multilingual website. Follow the steps in this online documentation to set up your project in a few minutes.
|
|
6
6
|
keywords:
|
|
@@ -83,6 +83,20 @@ This command will find your declaration content files as default as `./src/**/*.
|
|
|
83
83
|
- `npx intlayer dictionary build`
|
|
84
84
|
- `npx intlayer dic build`
|
|
85
85
|
|
|
86
|
+
##### Arguments:
|
|
87
|
+
|
|
88
|
+
- **`--base-dir`**: Specify the base directory for the project. To retrieve the intlayer configuration, the command will look for the `intlayer.config.{ts,js,json,cjs,mjs}` file in the base directory.
|
|
89
|
+
|
|
90
|
+
> Example: `npx intlayer build --base-dir ./src`
|
|
91
|
+
|
|
92
|
+
- **`--env`**: Specify the environment (e.g., `development`, `production`). Useful in the case you use environment variables in your intlayer configuration file.
|
|
93
|
+
|
|
94
|
+
> Example: `npx intlayer build --env production`
|
|
95
|
+
|
|
96
|
+
- **`--env-file`**: Provide a custom environment file to load variables from. Useful in the case you use environment variables in your intlayer configuration file.
|
|
97
|
+
|
|
98
|
+
> Example: `npx intlayer build --env-file .env.production.local`
|
|
99
|
+
|
|
86
100
|
### Push dictionaries
|
|
87
101
|
|
|
88
102
|
```bash
|
|
@@ -243,7 +257,7 @@ This command analyzes your content declaration files for potential issues such a
|
|
|
243
257
|
|
|
244
258
|
- **`--output-locales [outputLocales...]`**: Target locales to translate to. If not specified, all locales from your configuration will be used except the source locale.
|
|
245
259
|
|
|
246
|
-
- **`--mode [mode]`**: Translation mode:
|
|
260
|
+
- **`--mode [mode]`**: Translation mode: `complete`, `review`. Default is `complete`. `complete` will fill all missing content, `review` will fill missing content and review existing keys.
|
|
247
261
|
|
|
248
262
|
**Git options:**
|
|
249
263
|
|
|
@@ -296,6 +310,93 @@ npx intlayer fill --file src/home/*.content.ts --source-locale en --output-local
|
|
|
296
310
|
|
|
297
311
|
This command will translate content from English to French and Spanish for all content declaration files in the `src/home/` directory using the GPT-3.5 Turbo model.
|
|
298
312
|
|
|
313
|
+
### Test missing translations
|
|
314
|
+
|
|
315
|
+
```bash
|
|
316
|
+
npx intlayer content test
|
|
317
|
+
```
|
|
318
|
+
|
|
319
|
+
This command analyzes your content declaration files to identify missing translations across all configured locales. It provides a comprehensive report showing which translation keys are missing for which locales, helping you maintain consistency across your multilingual content.
|
|
320
|
+
|
|
321
|
+
##### Example output:
|
|
322
|
+
|
|
323
|
+
```bash
|
|
324
|
+
pnpm intlayer content test
|
|
325
|
+
Missing translations:
|
|
326
|
+
- home-page - tr - src/components/HomePage/homePage.content.ts
|
|
327
|
+
- server-component - es, tr - src/components/ServerComponent/serverComponent.content.ts
|
|
328
|
+
- client-component - pl, tr - src/components/ClientComponent/clientComponent.content.ts
|
|
329
|
+
Locales: en, ru, ja, fr, ko, zh, es, de, ar, it, en-GB, pt, hi, tr, pl
|
|
330
|
+
Required locales: en
|
|
331
|
+
Missing locales: pl, tr, es
|
|
332
|
+
Missing required locales: -
|
|
333
|
+
Total missing locales: 3
|
|
334
|
+
Total missing required locales: 0
|
|
335
|
+
```
|
|
336
|
+
|
|
337
|
+
##### Arguments:
|
|
338
|
+
|
|
339
|
+
**Configuration options:**
|
|
340
|
+
|
|
341
|
+
- **`--env`**: Specify the environment (e.g., `development`, `production`).
|
|
342
|
+
- **`--env-file [envFile]`**: Provide a custom environment file to load variables from.
|
|
343
|
+
- **`--base-dir`**: Specify the base directory for the project.
|
|
344
|
+
|
|
345
|
+
> Example: `npx intlayer content test --base-dir ./src --env-file .env.production.local`
|
|
346
|
+
|
|
347
|
+
**Log options:**
|
|
348
|
+
|
|
349
|
+
- **`--verbose`**: Enable verbose logging for debugging.
|
|
350
|
+
|
|
351
|
+
> Example: `npx intlayer content test --verbose`
|
|
352
|
+
|
|
353
|
+
##### Example:
|
|
354
|
+
|
|
355
|
+
```bash
|
|
356
|
+
npx intlayer content test --verbose
|
|
357
|
+
```
|
|
358
|
+
|
|
359
|
+
##### Example output:
|
|
360
|
+
|
|
361
|
+
```bash
|
|
362
|
+
npx intlayer content list
|
|
363
|
+
Content declaration files:
|
|
364
|
+
- home-page - src/components/HomePage/homePage.content.ts
|
|
365
|
+
- server-component - src/components/ServerComponent/serverComponent.content.ts
|
|
366
|
+
- client-component - src/components/ClientComponent/clientComponent.content.ts
|
|
367
|
+
|
|
368
|
+
Total content declaration files: 3
|
|
369
|
+
```
|
|
370
|
+
|
|
371
|
+
This command will scan all your content declaration files and display:
|
|
372
|
+
|
|
373
|
+
- A detailed list of missing translations with their keys, missing locales, and file paths
|
|
374
|
+
- Summary statistics including total missing locales and missing required locales
|
|
375
|
+
- Color-coded output for easy identification of issues
|
|
376
|
+
|
|
377
|
+
The output helps you quickly identify which translations need to be completed to ensure your application works properly across all configured locales.
|
|
378
|
+
|
|
379
|
+
### List content declaration files
|
|
380
|
+
|
|
381
|
+
```bash
|
|
382
|
+
npx intlayer content list
|
|
383
|
+
```
|
|
384
|
+
|
|
385
|
+
This command displays all content declaration files in your project, showing their dictionary keys and file paths. It's useful for getting an overview of all your content files and verifying that they are properly discovered by Intlayer.
|
|
386
|
+
|
|
387
|
+
##### Example:
|
|
388
|
+
|
|
389
|
+
```bash
|
|
390
|
+
npx intlayer content list
|
|
391
|
+
```
|
|
392
|
+
|
|
393
|
+
This command will output:
|
|
394
|
+
|
|
395
|
+
- A formatted list of all content declaration files with their keys and relative file paths
|
|
396
|
+
- The total count of content declaration files found
|
|
397
|
+
|
|
398
|
+
The output helps you verify that all your content files are properly configured and discoverable by the Intlayer system.
|
|
399
|
+
|
|
299
400
|
### Manage Configuration
|
|
300
401
|
|
|
301
402
|
#### Get Configuration
|
|
@@ -365,7 +466,6 @@ npx intlayer doc translate
|
|
|
365
466
|
> Example: `npx intlayer doc translate --excluded-glob-pattern "docs/internal/**"`
|
|
366
467
|
|
|
367
468
|
- **`--skip-if-modified-before [skipIfModifiedBefore]`**: Skip the file if it has been modified before the given time.
|
|
368
|
-
|
|
369
469
|
- Can be an absolute time as "2025-12-05" (string or Date)
|
|
370
470
|
- Can be a relative time in ms `1 * 60 * 60 * 1000` (1 hour)
|
|
371
471
|
- This option check update time of the file using the `fs.stat` method. So it could be impacted by Git or other tools that modify the file.
|
|
@@ -373,7 +473,6 @@ npx intlayer doc translate
|
|
|
373
473
|
> Example: `npx intlayer doc translate --skip-if-modified-before "2025-12-05"`
|
|
374
474
|
|
|
375
475
|
- **`--skip-if-modified-after [skipIfModifiedAfter]`**: Skip the file if it has been modified within the given time.
|
|
376
|
-
|
|
377
476
|
- Can be an absolute time as "2025-12-05" (string or Date)
|
|
378
477
|
- Can be a relative time in ms `1 * 60 * 60 * 1000` (1 hour)
|
|
379
478
|
- This option check update time of the file using the `fs.stat` method. So it could be impacted by Git or other tools that modify the file.
|
|
@@ -424,7 +523,6 @@ npx intlayer doc translate
|
|
|
424
523
|
**Custom instructions options:**
|
|
425
524
|
|
|
426
525
|
- **`--custom-instructions [customInstructions]`**: Custom instructions added to the prompt. Usefull to apply specific rules regarding formatting, urls translation, etc.
|
|
427
|
-
|
|
428
526
|
- Can be an absolute time as "2025-12-05" (string or Date)
|
|
429
527
|
- Can be a relative time in ms `1 * 60 * 60 * 1000` (1 hour)
|
|
430
528
|
- This option check update time of the file using the `fs.stat` method. So it could be impacted by Git or other tools that modify the file.
|
|
@@ -488,6 +586,8 @@ If you activated one of the git options, the command will only review the part o
|
|
|
488
586
|
"intlayer:push": "npx intlayer push",
|
|
489
587
|
"intlayer:pull": "npx intlayer pull",
|
|
490
588
|
"intlayer:fill": "npx intlayer fill",
|
|
589
|
+
"intlayer:list": "npx intlayer content list",
|
|
590
|
+
"intlayer:test": "npx intlayer content test",
|
|
491
591
|
"intlayer:doc:translate": "npx intlayer doc translate",
|
|
492
592
|
"intlayer:doc:review": "npx intlayer doc review"
|
|
493
593
|
}
|
|
@@ -517,6 +617,8 @@ import {
|
|
|
517
617
|
pull,
|
|
518
618
|
fill,
|
|
519
619
|
build,
|
|
620
|
+
listContentDeclaration,
|
|
621
|
+
testMissingTranslations,
|
|
520
622
|
docTranslate,
|
|
521
623
|
docReview,
|
|
522
624
|
} from "@intlayer/cli";
|
|
@@ -529,6 +631,10 @@ fill();
|
|
|
529
631
|
// ...
|
|
530
632
|
build();
|
|
531
633
|
// ...
|
|
634
|
+
listContentDeclaration();
|
|
635
|
+
// ...
|
|
636
|
+
testMissingTranslations();
|
|
637
|
+
// ...
|
|
532
638
|
docTranslate();
|
|
533
639
|
// ...
|
|
534
640
|
docReview();
|
|
@@ -569,5 +675,6 @@ npx clear-npx-cache
|
|
|
569
675
|
|
|
570
676
|
| Version | Date | Changes |
|
|
571
677
|
| ------- | ---------- | ------------------------------------------- |
|
|
678
|
+
| 6.0.0 | 2025-09-17 | Add content test and list command |
|
|
572
679
|
| 5.5.11 | 2025-07-11 | Update CLI command parameters documentation |
|
|
573
680
|
| 5.5.10 | 2025-06-29 | Init history |
|
|
@@ -0,0 +1,268 @@
|
|
|
1
|
+
---
|
|
2
|
+
createdAt: 2025-09-09
|
|
3
|
+
updatedAt: 2025-09-09
|
|
4
|
+
title: Translate your Nest backend (i18n)
|
|
5
|
+
description: Discover how to make your vite backend multilingual. Follow the documentation to internationalize (i18n) and translate it.
|
|
6
|
+
keywords:
|
|
7
|
+
- Internationalization
|
|
8
|
+
- Documentation
|
|
9
|
+
- Intlayer
|
|
10
|
+
- NestJS
|
|
11
|
+
- JavaScript
|
|
12
|
+
- Backend
|
|
13
|
+
slugs:
|
|
14
|
+
- doc
|
|
15
|
+
- environment
|
|
16
|
+
- nest
|
|
17
|
+
applicationTemplate: https://github.com/AydinTheFirst/nestjs-intlayer
|
|
18
|
+
author: AydinTheFirst
|
|
19
|
+
---
|
|
20
|
+
|
|
21
|
+
# Getting Started internationalizing (i18n) with Intlayer and NestJS
|
|
22
|
+
|
|
23
|
+
`express-intlayer` is a powerful internationalization (i18n) middleware for Express applications, designed to make your backend services globally accessible by providing localized responses based on the client's preferences. Since NestJS is built on top of Express, you can seamlessly integrate `express-intlayer` into your NestJS applications to handle multilingual content effectively.
|
|
24
|
+
|
|
25
|
+
## Why Internationalize Your Backend?
|
|
26
|
+
|
|
27
|
+
Internationalizing your backend is essential for serving a global audience effectively. It allows your application to deliver content and messages in the preferred language of each user. This capability enhances user experience and broadens your application's reach by making it more accessible and relevant to people from different linguistic backgrounds.
|
|
28
|
+
|
|
29
|
+
### Practical Use Cases
|
|
30
|
+
|
|
31
|
+
- **Displaying Backend Errors in User's Language**: When an error occurs, displaying messages in the user's native language improves understanding and reduces frustration. This is especially useful for dynamic error messages that might be shown in front-end components like toasts or modals.
|
|
32
|
+
|
|
33
|
+
- **Retrieving Multilingual Content**: For applications pulling content from a database, internationalization ensures that you can serve this content in multiple languages. This is crucial for platforms like e-commerce sites or content management systems that need to display product descriptions, articles, and other content in the language preferred by the user.
|
|
34
|
+
|
|
35
|
+
- **Sending Multilingual Emails**: Whether it's transactional emails, marketing campaigns, or notifications, sending emails in the recipient’s language can significantly increase engagement and effectiveness.
|
|
36
|
+
|
|
37
|
+
- **Multilingual Push Notifications**: For mobile applications, sending push notifications in a user's preferred language can enhance interaction and retention. This personal touch can make notifications feel more relevant and actionable.
|
|
38
|
+
|
|
39
|
+
- **Other Communications**: Any form of communication from the backend, such as SMS messages, system alerts, or user interface updates, benefits from being in the user's language, ensuring clarity and enhancing the overall user experience.
|
|
40
|
+
|
|
41
|
+
By internationalizing the backend, your application not only respects cultural differences but also aligns better with global market needs, making it a key step in scaling your services worldwide.
|
|
42
|
+
|
|
43
|
+
## Getting Started
|
|
44
|
+
|
|
45
|
+
### Create a new NestJS Project
|
|
46
|
+
|
|
47
|
+
```bash packageManager="npm"
|
|
48
|
+
npm install -g @nestjs/cli
|
|
49
|
+
nest new my-nest-app
|
|
50
|
+
```
|
|
51
|
+
|
|
52
|
+
### Installation
|
|
53
|
+
|
|
54
|
+
To begin using `express-intlayer`, install the package using npm:
|
|
55
|
+
|
|
56
|
+
```bash packageManager="npm"
|
|
57
|
+
npm install intlayer express-intlayer
|
|
58
|
+
```
|
|
59
|
+
|
|
60
|
+
```bash packageManager="pnpm"
|
|
61
|
+
pnpm add intlayer express-intlayer
|
|
62
|
+
```
|
|
63
|
+
|
|
64
|
+
```bash packageManager="yarn"
|
|
65
|
+
yarn add intlayer express-intlayer
|
|
66
|
+
```
|
|
67
|
+
|
|
68
|
+
### Configure tsconfig.json
|
|
69
|
+
|
|
70
|
+
In order to use Intlayer with TypeScript, ensure your `tsconfig.json` is set up to support ES modules. You can do this by setting the `module` and `moduleResolution` options to `nodenext`.
|
|
71
|
+
|
|
72
|
+
```json5 fileName="tsconfig.json"
|
|
73
|
+
{
|
|
74
|
+
compilerOptions: {
|
|
75
|
+
module: "nodenext",
|
|
76
|
+
moduleResolution: "nodenext",
|
|
77
|
+
// ... other options
|
|
78
|
+
},
|
|
79
|
+
}
|
|
80
|
+
```
|
|
81
|
+
|
|
82
|
+
### Setup
|
|
83
|
+
|
|
84
|
+
Configure the internationalization settings by creating an `intlayer.config.ts` in your project root:
|
|
85
|
+
|
|
86
|
+
```typescript fileName="intlayer.config.ts" codeFormat="typescript"
|
|
87
|
+
import { Locales, type IntlayerConfig } from "intlayer";
|
|
88
|
+
|
|
89
|
+
const config: IntlayerConfig = {
|
|
90
|
+
internationalization: {
|
|
91
|
+
locales: [Locales.ENGLISH, Locales.FRENCH, Locales.SPANISH],
|
|
92
|
+
defaultLocale: Locales.ENGLISH,
|
|
93
|
+
},
|
|
94
|
+
};
|
|
95
|
+
|
|
96
|
+
export default config;
|
|
97
|
+
```
|
|
98
|
+
|
|
99
|
+
```javascript fileName="intlayer.config.mjs" codeFormat="esm"
|
|
100
|
+
import { Locales } from "intlayer";
|
|
101
|
+
|
|
102
|
+
/** @type {import('intlayer').IntlayerConfig} */
|
|
103
|
+
const config = {
|
|
104
|
+
internationalization: {
|
|
105
|
+
locales: [Locales.ENGLISH, Locales.FRENCH, Locales.SPANISH],
|
|
106
|
+
defaultLocale: Locales.ENGLISH,
|
|
107
|
+
},
|
|
108
|
+
};
|
|
109
|
+
|
|
110
|
+
export default config;
|
|
111
|
+
```
|
|
112
|
+
|
|
113
|
+
```javascript fileName="intlayer.config.cjs" codeFormat="commonjs"
|
|
114
|
+
const { Locales } = require("intlayer");
|
|
115
|
+
|
|
116
|
+
/** @type {import('intlayer').IntlayerConfig} */
|
|
117
|
+
const config = {
|
|
118
|
+
internationalization: {
|
|
119
|
+
locales: [Locales.ENGLISH, Locales.FRENCH, Locales.SPANISH],
|
|
120
|
+
defaultLocale: Locales.ENGLISH,
|
|
121
|
+
},
|
|
122
|
+
};
|
|
123
|
+
|
|
124
|
+
module.exports = config;
|
|
125
|
+
```
|
|
126
|
+
|
|
127
|
+
### Declare Your Content
|
|
128
|
+
|
|
129
|
+
Create and manage your content declarations to store translations:
|
|
130
|
+
|
|
131
|
+
```typescript fileName="src/app.content.ts" contentDeclarationFormat="typescript"
|
|
132
|
+
import { t, type Dictionary } from "intlayer";
|
|
133
|
+
|
|
134
|
+
const appContent: Dictionary = {
|
|
135
|
+
key: "app",
|
|
136
|
+
content: {
|
|
137
|
+
greet: t({
|
|
138
|
+
en: "Hello World!",
|
|
139
|
+
fr: "Bonjour le monde !",
|
|
140
|
+
es: "¡Hola Mundo!",
|
|
141
|
+
}),
|
|
142
|
+
},
|
|
143
|
+
};
|
|
144
|
+
|
|
145
|
+
export default appContent;
|
|
146
|
+
```
|
|
147
|
+
|
|
148
|
+
> Your content declarations can be defined anywhere in your application as soon as they are included into the `contentDir` directory (by default, `./src`). And match the content declaration file extension (by default, `.content.{json,ts,tsx,js,jsx,mjs,mjx,cjs,cjx}`).
|
|
149
|
+
|
|
150
|
+
> For more details, refer to the [content declaration documentation](/doc/concept/content).
|
|
151
|
+
|
|
152
|
+
### Express Middleware Setup
|
|
153
|
+
|
|
154
|
+
Integrate the `express-intlayer` middleware into your NestJS application to handle internationalization:
|
|
155
|
+
|
|
156
|
+
```typescript fileName="src/app.module.ts" codeFormat="typescript"
|
|
157
|
+
import { MiddlewareConsumer, Module, NestModule } from "@nestjs/common";
|
|
158
|
+
import { AppController } from "./app.controller";
|
|
159
|
+
import { AppService } from "./app.service";
|
|
160
|
+
import { intlayer } from "express-intlayer";
|
|
161
|
+
|
|
162
|
+
@Module({
|
|
163
|
+
imports: [],
|
|
164
|
+
controllers: [AppController],
|
|
165
|
+
providers: [AppService],
|
|
166
|
+
})
|
|
167
|
+
export class AppModule implements NestModule {
|
|
168
|
+
configure(consumer: MiddlewareConsumer) {
|
|
169
|
+
consumer.apply(intlayer()).forRoutes("*"); // Apply to all routes
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
```
|
|
173
|
+
|
|
174
|
+
### Use Translations in Your Services or Controllers
|
|
175
|
+
|
|
176
|
+
You can now use the `getIntlayer` function to access translations in your services or controllers:
|
|
177
|
+
|
|
178
|
+
```typescript fileName="src/app.service.ts" codeFormat="typescript"
|
|
179
|
+
import { Injectable } from "@nestjs/common";
|
|
180
|
+
import { getIntlayer } from "express-intlayer";
|
|
181
|
+
|
|
182
|
+
@Injectable()
|
|
183
|
+
export class AppService {
|
|
184
|
+
getHello(): string {
|
|
185
|
+
return getIntlayer("app").greet;
|
|
186
|
+
}
|
|
187
|
+
}
|
|
188
|
+
```
|
|
189
|
+
|
|
190
|
+
### Compatibility
|
|
191
|
+
|
|
192
|
+
`express-intlayer` is fully compatible with:
|
|
193
|
+
|
|
194
|
+
- [`react-intlayer`](/doc/packages/react-intlayer) for React applications
|
|
195
|
+
- [`next-intlayer`](/doc/packages/next-intlayer) for Next.js applications
|
|
196
|
+
- [`vite-intlayer`](/doc/packages/vite-intlayer) for Vite applications
|
|
197
|
+
|
|
198
|
+
It also works seamlessly with any internationalization solution across various environments, including browsers and API requests. You can customize the middleware to detect locale through headers or cookies:
|
|
199
|
+
|
|
200
|
+
```typescript fileName="intlayer.config.ts" codeFormat="typescript"
|
|
201
|
+
import { Locales, type IntlayerConfig } from "intlayer";
|
|
202
|
+
|
|
203
|
+
const config: IntlayerConfig = {
|
|
204
|
+
// ... Other configuration options
|
|
205
|
+
middleware: {
|
|
206
|
+
headerName: "my-locale-header",
|
|
207
|
+
cookieName: "my-locale-cookie",
|
|
208
|
+
},
|
|
209
|
+
};
|
|
210
|
+
|
|
211
|
+
export default config;
|
|
212
|
+
```
|
|
213
|
+
|
|
214
|
+
By default, `express-intlayer` will interpret the `Accept-Language` header to determine the client's preferred language.
|
|
215
|
+
|
|
216
|
+
> For more information on configuration and advanced topics, visit our [documentation](/doc/concept/configuration).
|
|
217
|
+
|
|
218
|
+
### Configure TypeScript
|
|
219
|
+
|
|
220
|
+
`express-intlayer` leverages the robust capabilities of TypeScript to enhance the internationalization process. TypeScript's static typing ensures that every translation key is accounted for, reducing the risk of missing translations and improving maintainability.
|
|
221
|
+
|
|
222
|
+

|
|
223
|
+
|
|
224
|
+

|
|
225
|
+
|
|
226
|
+
Ensure the autogenerated types (by default at ./types/intlayer.d.ts) are included in your tsconfig.json file.
|
|
227
|
+
|
|
228
|
+
```json5 fileName="tsconfig.json"
|
|
229
|
+
{
|
|
230
|
+
// ... Your existing TypeScript configurations
|
|
231
|
+
include: [
|
|
232
|
+
// ... Your existing TypeScript configurations
|
|
233
|
+
".intlayer/**/*.ts", // Include the auto-generated types
|
|
234
|
+
],
|
|
235
|
+
}
|
|
236
|
+
```
|
|
237
|
+
|
|
238
|
+
### VS Code Extension
|
|
239
|
+
|
|
240
|
+
To improve your development experience with Intlayer, you can install the official **Intlayer VS Code Extension**.
|
|
241
|
+
|
|
242
|
+
[Install from the VS Code Marketplace](https://marketplace.visualstudio.com/items?itemName=intlayer.intlayer-vs-code-extension)
|
|
243
|
+
|
|
244
|
+
This extension provides:
|
|
245
|
+
|
|
246
|
+
- **Autocompletion** for translation keys.
|
|
247
|
+
- **Real-time error detection** for missing translations.
|
|
248
|
+
- **Inline previews** of translated content.
|
|
249
|
+
- **Quick actions** to easily create and update translations.
|
|
250
|
+
|
|
251
|
+
For more details on how to use the extension, refer to the [Intlayer VS Code Extension documentation](https://intlayer.org/doc/vs-code-extension).
|
|
252
|
+
|
|
253
|
+
### Git Configuration
|
|
254
|
+
|
|
255
|
+
It is recommended to ignore the files generated by Intlayer. This allows you to avoid committing them to your Git repository.
|
|
256
|
+
|
|
257
|
+
To do this, you can add the following instructions to your `.gitignore` file:
|
|
258
|
+
|
|
259
|
+
```plaintext fileName=".gitignore"
|
|
260
|
+
# Ignore the files generated by Intlayer
|
|
261
|
+
.intlayer
|
|
262
|
+
```
|
|
263
|
+
|
|
264
|
+
## Doc History
|
|
265
|
+
|
|
266
|
+
| Version | Date | Changes |
|
|
267
|
+
| ------- | ---------- | ----------- |
|
|
268
|
+
| 5.8.0 | 2025-09-09 | Initial doc |
|