@intlayer/docs 5.5.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +202 -0
- package/ar/CI_CD.md +149 -0
- package/ar/autoFill.md +157 -0
- package/ar/concept/content/file.md +1 -0
- package/ar/configuration.md +492 -0
- package/ar/dictionary/condition.md +213 -0
- package/ar/dictionary/content_extention_customization.md +81 -0
- package/ar/dictionary/enumeration.md +221 -0
- package/ar/dictionary/file.md +209 -0
- package/ar/dictionary/function_fetching.md +190 -0
- package/ar/dictionary/get_started.md +490 -0
- package/ar/dictionary/insertion.md +161 -0
- package/ar/dictionary/markdown.md +343 -0
- package/ar/dictionary/nesting.md +249 -0
- package/ar/dictionary/translation.md +307 -0
- package/ar/header.md +7 -0
- package/ar/how_works_intlayer.md +219 -0
- package/ar/index.md +125 -0
- package/ar/interest_of_intlayer.md +132 -0
- package/ar/intlayer_CMS.md +328 -0
- package/ar/intlayer_cli.md +258 -0
- package/ar/intlayer_visual_editor.md +210 -0
- package/ar/intlayer_with_angular.md +3 -0
- package/ar/intlayer_with_create_react_app.md +1196 -0
- package/ar/intlayer_with_express.md +270 -0
- package/ar/intlayer_with_lynx+react.md +482 -0
- package/ar/intlayer_with_nextjs_14.md +1260 -0
- package/ar/intlayer_with_nextjs_15.md +1311 -0
- package/ar/intlayer_with_nextjs_page_router.md +1099 -0
- package/ar/intlayer_with_react_native+expo.md +539 -0
- package/ar/intlayer_with_vite+preact.md +1679 -0
- package/ar/intlayer_with_vite+react.md +1582 -0
- package/ar/intlayer_with_vite+solid.md +3 -0
- package/ar/intlayer_with_vite+svelte.md +3 -0
- package/ar/intlayer_with_vite+vue.md +989 -0
- package/ar/introduction.md +190 -0
- package/ar/mcp_server.md +150 -0
- package/ar/packages/@intlayer/api/index.md +31 -0
- package/ar/packages/@intlayer/chokidar/index.md +31 -0
- package/ar/packages/@intlayer/cli/index.md +1 -0
- package/ar/packages/@intlayer/config/index.md +116 -0
- package/ar/packages/@intlayer/core/index.md +25 -0
- package/ar/packages/@intlayer/design-system/index.md +21 -0
- package/ar/packages/@intlayer/dictionary-entry/index.md +21 -0
- package/ar/packages/@intlayer/editor/index.md +21 -0
- package/ar/packages/@intlayer/editor-react/index.md +21 -0
- package/ar/packages/@intlayer/webpack/index.md +35 -0
- package/ar/packages/angular-intlayer/index.md +3 -0
- package/ar/packages/express-intlayer/index.md +232 -0
- package/ar/packages/express-intlayer/t.md +448 -0
- package/ar/packages/intlayer/getConfiguration.md +120 -0
- package/ar/packages/intlayer/getEnumeration.md +138 -0
- package/ar/packages/intlayer/getHTMLTextDir.md +97 -0
- package/ar/packages/intlayer/getLocaleLang.md +61 -0
- package/ar/packages/intlayer/getLocaleName.md +93 -0
- package/ar/packages/intlayer/getLocalizedUrl.md +221 -0
- package/ar/packages/intlayer/getMultilingualUrls.md +198 -0
- package/ar/packages/intlayer/getPathWithoutLocale.md +50 -0
- package/ar/packages/intlayer/getTranslation.md +175 -0
- package/ar/packages/intlayer/getTranslationContent.md +175 -0
- package/ar/packages/intlayer/index.md +254 -0
- package/ar/packages/intlayer-cli/index.md +41 -0
- package/ar/packages/intlayer-editor/index.md +113 -0
- package/ar/packages/lynx-intlayer/index.md +58 -0
- package/ar/packages/next-intlayer/index.md +267 -0
- package/ar/packages/next-intlayer/t.md +341 -0
- package/ar/packages/next-intlayer/useDictionary.md +248 -0
- package/ar/packages/next-intlayer/useIntlayer.md +237 -0
- package/ar/packages/next-intlayer/useIntlayerAsync.md +211 -0
- package/ar/packages/next-intlayer/useLocale.md +105 -0
- package/ar/packages/preact-intlayer/index.md +3 -0
- package/ar/packages/react-intlayer/index.md +261 -0
- package/ar/packages/react-intlayer/t.md +283 -0
- package/ar/packages/react-intlayer/useDictionary.md +268 -0
- package/ar/packages/react-intlayer/useIntlayer.md +225 -0
- package/ar/packages/react-intlayer/useIntlayerAsync.md +226 -0
- package/ar/packages/react-intlayer/useLocale.md +184 -0
- package/ar/packages/react-native-intlayer/index.md +57 -0
- package/ar/packages/react-scripts-intlayer/index.md +57 -0
- package/ar/packages/solid-intlayer/index.md +3 -0
- package/ar/packages/svelte-intlayer/index.md +3 -0
- package/ar/packages/vite-intlayer/index.md +53 -0
- package/ar/packages/vue-intlayer/index.md +3 -0
- package/ar/per_locale_file.md +298 -0
- package/ar/privacy_notice.md +61 -0
- package/ar/roadmap.md +208 -0
- package/ar/terms_of_service.md +33 -0
- package/ar/vs_code_extension.md +139 -0
- package/de/CI_CD.md +149 -0
- package/de/angular-intlayer/index.md +3 -0
- package/de/autoFill.md +157 -0
- package/de/configuration.md +501 -0
- package/de/dictionary/condition.md +213 -0
- package/de/dictionary/content_extention_customization.md +81 -0
- package/de/dictionary/enumeration.md +221 -0
- package/de/dictionary/file.md +207 -0
- package/de/dictionary/function_fetching.md +190 -0
- package/de/dictionary/get_started.md +466 -0
- package/de/dictionary/insertion.md +167 -0
- package/de/dictionary/markdown.md +345 -0
- package/de/dictionary/nesting.md +252 -0
- package/de/dictionary/translation.md +287 -0
- package/de/header.md +5 -0
- package/de/how_works_intlayer.md +216 -0
- package/de/index.md +125 -0
- package/de/insertion.md +0 -0
- package/de/interest_of_intlayer.md +132 -0
- package/de/intlayer_CMS.md +334 -0
- package/de/intlayer_cli.md +274 -0
- package/de/intlayer_visual_editor.md +210 -0
- package/de/intlayer_with_angular.md +3 -0
- package/de/intlayer_with_create_react_app.md +1200 -0
- package/de/intlayer_with_express.md +268 -0
- package/de/intlayer_with_lynx+react.md +482 -0
- package/de/intlayer_with_nextjs_14.md +1258 -0
- package/de/intlayer_with_nextjs_15.md +1306 -0
- package/de/intlayer_with_nextjs_page_router.md +1087 -0
- package/de/intlayer_with_react_native+expo.md +539 -0
- package/de/intlayer_with_vite+preact.md +1701 -0
- package/de/intlayer_with_vite+react.md +1584 -0
- package/de/intlayer_with_vite+solid.md +3 -0
- package/de/intlayer_with_vite+svelte.md +3 -0
- package/de/intlayer_with_vite+vue.md +989 -0
- package/de/introduction.md +186 -0
- package/de/mcp_server.md +150 -0
- package/de/packages/@intlayer/api/index.md +31 -0
- package/de/packages/@intlayer/chokidar/index.md +31 -0
- package/de/packages/@intlayer/cli/index.md +21 -0
- package/de/packages/@intlayer/config/index.md +116 -0
- package/de/packages/@intlayer/core/index.md +25 -0
- package/de/packages/@intlayer/design-system/index.md +21 -0
- package/de/packages/@intlayer/dictionary-entry/index.md +21 -0
- package/de/packages/@intlayer/editor/index.md +21 -0
- package/de/packages/@intlayer/editor-react/index.md +21 -0
- package/de/packages/@intlayer/webpack/index.md +35 -0
- package/de/packages/angular-intlayer/index.md +31 -0
- package/de/packages/express-intlayer/index.md +229 -0
- package/de/packages/express-intlayer/t.md +432 -0
- package/de/packages/intlayer/getConfiguration.md +120 -0
- package/de/packages/intlayer/getEnumeration.md +140 -0
- package/de/packages/intlayer/getHTMLTextDir.md +97 -0
- package/de/packages/intlayer/getLocaleLang.md +57 -0
- package/de/packages/intlayer/getLocaleName.md +93 -0
- package/de/packages/intlayer/getLocalizedUrl.md +221 -0
- package/de/packages/intlayer/getMultilingualUrls.md +198 -0
- package/de/packages/intlayer/getPathWithoutLocale.md +50 -0
- package/de/packages/intlayer/getTranslation.md +166 -0
- package/de/packages/intlayer/getTranslationContent.md +166 -0
- package/de/packages/intlayer/index.md +478 -0
- package/de/packages/intlayer-cli/index.md +41 -0
- package/de/packages/intlayer-editor/index.md +113 -0
- package/de/packages/lynx-intlayer/index.md +58 -0
- package/de/packages/next-intlayer/index.md +263 -0
- package/de/packages/next-intlayer/t.md +325 -0
- package/de/packages/next-intlayer/useDictionary.md +242 -0
- package/de/packages/next-intlayer/useIntlayer.md +237 -0
- package/de/packages/next-intlayer/useIntlayerAsync.md +211 -0
- package/de/packages/next-intlayer/useLocale.md +105 -0
- package/de/packages/preact-intlayer/index.md +3 -0
- package/de/packages/react-intlayer/index.md +260 -0
- package/de/packages/react-intlayer/t.md +277 -0
- package/de/packages/react-intlayer/useDictionary.md +260 -0
- package/de/packages/react-intlayer/useIntlayer.md +225 -0
- package/de/packages/react-intlayer/useIntlayerAsync.md +226 -0
- package/de/packages/react-intlayer/useLocale.md +184 -0
- package/de/packages/react-native-intlayer/index.md +57 -0
- package/de/packages/react-scripts-intlayer/index.md +57 -0
- package/de/packages/solid-intlayer/index.md +3 -0
- package/de/packages/svelte-intlayer/index.md +3 -0
- package/de/packages/vite-intlayer/index.md +53 -0
- package/de/packages/vue-intlayer/index.md +3 -0
- package/de/per_locale_file.md +298 -0
- package/de/privacy_notice.md +61 -0
- package/de/roadmap.md +206 -0
- package/de/terms_of_service.md +33 -0
- package/de/vs_code_extension.md +139 -0
- package/en/CI_CD.md +149 -0
- package/en/autoFill.md +157 -0
- package/en/configuration.md +506 -0
- package/en/dictionary/condition.md +213 -0
- package/en/dictionary/content_extention_customization.md +81 -0
- package/en/dictionary/enumeration.md +221 -0
- package/en/dictionary/file.md +198 -0
- package/en/dictionary/function_fetching.md +190 -0
- package/en/dictionary/get_started.md +504 -0
- package/en/dictionary/insertion.md +167 -0
- package/en/dictionary/markdown.md +355 -0
- package/en/dictionary/nesting.md +249 -0
- package/en/dictionary/translation.md +285 -0
- package/en/frequent_questions/build_dictionaries.md +37 -0
- package/en/frequent_questions/domain_routing.md +92 -0
- package/en/frequent_questions/esbuild_error.md +9 -0
- package/en/frequent_questions/get_locale_cookie.md +121 -0
- package/en/frequent_questions/intlayer_command_undefined.md +135 -0
- package/en/frequent_questions/locale_incorect_in_url.md +52 -0
- package/en/frequent_questions/static_rendering.md +24 -0
- package/en/frequent_questions/unknown_command.md +76 -0
- package/en/header.md +5 -0
- package/en/how_works_intlayer.md +219 -0
- package/en/index.md +139 -0
- package/en/interest_of_intlayer.md +133 -0
- package/en/intlayer_CMS.md +334 -0
- package/en/intlayer_cli.md +309 -0
- package/en/intlayer_visual_editor.md +244 -0
- package/en/intlayer_with_angular.md +139 -0
- package/en/intlayer_with_create_react_app.md +1209 -0
- package/en/intlayer_with_express.md +391 -0
- package/en/intlayer_with_lynx+react.md +483 -0
- package/en/intlayer_with_nextjs_14.md +1298 -0
- package/en/intlayer_with_nextjs_15.md +1347 -0
- package/en/intlayer_with_nextjs_page_router.md +1126 -0
- package/en/intlayer_with_react_native+expo.md +630 -0
- package/en/intlayer_with_vite+preact.md +1659 -0
- package/en/intlayer_with_vite+react.md +1605 -0
- package/en/intlayer_with_vite+solid.md +254 -0
- package/en/intlayer_with_vite+svelte.md +254 -0
- package/en/intlayer_with_vite+vue.md +1000 -0
- package/en/introduction.md +185 -0
- package/en/mcp_server.md +150 -0
- package/en/packages/@intlayer/api/index.md +31 -0
- package/en/packages/@intlayer/chokidar/index.md +31 -0
- package/en/packages/@intlayer/cli/index.md +21 -0
- package/en/packages/@intlayer/config/index.md +116 -0
- package/en/packages/@intlayer/core/index.md +25 -0
- package/en/packages/@intlayer/design-system/index.md +21 -0
- package/en/packages/@intlayer/dictionary-entry/index.md +21 -0
- package/en/packages/@intlayer/editor/index.md +21 -0
- package/en/packages/@intlayer/editor-react/index.md +21 -0
- package/en/packages/@intlayer/webpack/index.md +35 -0
- package/en/packages/angular-intlayer/index.md +31 -0
- package/en/packages/express-intlayer/index.md +229 -0
- package/en/packages/express-intlayer/t.md +432 -0
- package/en/packages/intlayer/getConfiguration.md +120 -0
- package/en/packages/intlayer/getEnumeration.md +138 -0
- package/en/packages/intlayer/getHTMLTextDir.md +97 -0
- package/en/packages/intlayer/getLocaleLang.md +57 -0
- package/en/packages/intlayer/getLocaleName.md +93 -0
- package/en/packages/intlayer/getLocalizedUrl.md +221 -0
- package/en/packages/intlayer/getMultilingualUrls.md +198 -0
- package/en/packages/intlayer/getPathWithoutLocale.md +50 -0
- package/en/packages/intlayer/getTranslation.md +166 -0
- package/en/packages/intlayer/getTranslationContent.md +166 -0
- package/en/packages/intlayer/index.md +476 -0
- package/en/packages/intlayer-cli/index.md +41 -0
- package/en/packages/intlayer-editor/index.md +113 -0
- package/en/packages/lynx-intlayer/index.md +60 -0
- package/en/packages/next-intlayer/index.md +263 -0
- package/en/packages/next-intlayer/t.md +326 -0
- package/en/packages/next-intlayer/useDictionary.md +242 -0
- package/en/packages/next-intlayer/useIntlayer.md +237 -0
- package/en/packages/next-intlayer/useIntlayerAsync.md +211 -0
- package/en/packages/next-intlayer/useLocale.md +105 -0
- package/en/packages/preact-intlayer/index.md +31 -0
- package/en/packages/react-intlayer/index.md +257 -0
- package/en/packages/react-intlayer/t.md +277 -0
- package/en/packages/react-intlayer/useDictionary.md +260 -0
- package/en/packages/react-intlayer/useIntlayer.md +225 -0
- package/en/packages/react-intlayer/useIntlayerAsync.md +226 -0
- package/en/packages/react-intlayer/useLocale.md +184 -0
- package/en/packages/react-native-intlayer/index.md +59 -0
- package/en/packages/react-scripts-intlayer/index.md +57 -0
- package/en/packages/solid-intlayer/index.md +31 -0
- package/en/packages/svelte-intlayer/index.md +31 -0
- package/en/packages/vite-intlayer/index.md +53 -0
- package/en/packages/vue-intlayer/index.md +31 -0
- package/en/per_locale_file.md +297 -0
- package/en/privacy_notice.md +61 -0
- package/en/roadmap.md +270 -0
- package/en/t.md +163 -0
- package/en/terms_of_service.md +33 -0
- package/en/vs_code_extension.md +129 -0
- package/en-GB/CI_CD.md +149 -0
- package/en-GB/autoFill.md +0 -0
- package/en-GB/configuration.md +490 -0
- package/en-GB/dictionary/condition.md +213 -0
- package/en-GB/dictionary/content_extention_customization.md +83 -0
- package/en-GB/dictionary/enumeration.md +221 -0
- package/en-GB/dictionary/file.md +201 -0
- package/en-GB/dictionary/function_fetching.md +190 -0
- package/en-GB/dictionary/get_started.md +466 -0
- package/en-GB/dictionary/insertion.md +167 -0
- package/en-GB/dictionary/markdown.md +343 -0
- package/en-GB/dictionary/nesting.md +249 -0
- package/en-GB/dictionary/translation.md +285 -0
- package/en-GB/header.md +1 -0
- package/en-GB/how_works_intlayer.md +217 -0
- package/en-GB/index.md +142 -0
- package/en-GB/interest_of_intlayer.md +123 -0
- package/en-GB/intlayer_CMS.md +334 -0
- package/en-GB/intlayer_cli.md +239 -0
- package/en-GB/intlayer_visual_editor.md +210 -0
- package/en-GB/intlayer_with_angular.md +3 -0
- package/en-GB/intlayer_with_create_react_app.md +1192 -0
- package/en-GB/intlayer_with_express.md +267 -0
- package/en-GB/intlayer_with_lynx+react.md +484 -0
- package/en-GB/intlayer_with_nextjs_14.md +1267 -0
- package/en-GB/intlayer_with_nextjs_15.md +1308 -0
- package/en-GB/intlayer_with_nextjs_page_router.md +1087 -0
- package/en-GB/intlayer_with_react_native+expo.md +539 -0
- package/en-GB/intlayer_with_vite+preact.md +1648 -0
- package/en-GB/intlayer_with_vite+react.md +1430 -0
- package/en-GB/intlayer_with_vite+solid.md +3 -0
- package/en-GB/intlayer_with_vite+svelte.md +3 -0
- package/en-GB/intlayer_with_vite+vue.md +993 -0
- package/en-GB/introduction.md +201 -0
- package/en-GB/mcp_server.md +150 -0
- package/en-GB/packages/@intlayer/api/index.md +31 -0
- package/en-GB/packages/@intlayer/chokidar/index.md +31 -0
- package/en-GB/packages/@intlayer/cli/index.md +21 -0
- package/en-GB/packages/@intlayer/config/index.md +116 -0
- package/en-GB/packages/@intlayer/core/index.md +25 -0
- package/en-GB/packages/@intlayer/design-system/index.md +21 -0
- package/en-GB/packages/@intlayer/dictionary-entry/index.md +21 -0
- package/en-GB/packages/@intlayer/editor/index.md +21 -0
- package/en-GB/packages/@intlayer/editor-react/index.md +21 -0
- package/en-GB/packages/@intlayer/webpack/index.md +35 -0
- package/en-GB/packages/angular-intlayer/index.md +3 -0
- package/en-GB/packages/express-intlayer/index.md +229 -0
- package/en-GB/packages/express-intlayer/t.md +432 -0
- package/en-GB/packages/intlayer/getConfiguration.md +120 -0
- package/en-GB/packages/intlayer/getEnumeration.md +140 -0
- package/en-GB/packages/intlayer/getHTMLTextDir.md +97 -0
- package/en-GB/packages/intlayer/getLocaleLang.md +57 -0
- package/en-GB/packages/intlayer/getLocaleName.md +93 -0
- package/en-GB/packages/intlayer/getLocalizedUrl.md +221 -0
- package/en-GB/packages/intlayer/getMultilingualUrls.md +198 -0
- package/en-GB/packages/intlayer/getPathWithoutLocale.md +50 -0
- package/en-GB/packages/intlayer/getTranslation.md +166 -0
- package/en-GB/packages/intlayer/getTranslationContent.md +166 -0
- package/en-GB/packages/intlayer/index.md +476 -0
- package/en-GB/packages/intlayer-cli/index.md +41 -0
- package/en-GB/packages/intlayer-editor/index.md +113 -0
- package/en-GB/packages/lynx-intlayer/index.md +58 -0
- package/en-GB/packages/next-intlayer/index.md +263 -0
- package/en-GB/packages/next-intlayer/t.md +326 -0
- package/en-GB/packages/next-intlayer/useDictionary.md +242 -0
- package/en-GB/packages/next-intlayer/useIntlayer.md +237 -0
- package/en-GB/packages/next-intlayer/useIntlayerAsync.md +211 -0
- package/en-GB/packages/next-intlayer/useLocale.md +105 -0
- package/en-GB/packages/preact-intlayer/index.md +3 -0
- package/en-GB/packages/react-intlayer/index.md +257 -0
- package/en-GB/packages/react-intlayer/t.md +277 -0
- package/en-GB/packages/react-intlayer/useDictionary.md +260 -0
- package/en-GB/packages/react-intlayer/useIntlayer.md +225 -0
- package/en-GB/packages/react-intlayer/useIntlayerAsync.md +226 -0
- package/en-GB/packages/react-intlayer/useLocale.md +184 -0
- package/en-GB/packages/react-native-intlayer/index.md +57 -0
- package/en-GB/packages/react-scripts-intlayer/index.md +57 -0
- package/en-GB/packages/solid-intlayer/index.md +3 -0
- package/en-GB/packages/svelte-intlayer/index.md +3 -0
- package/en-GB/packages/vite-intlayer/index.md +53 -0
- package/en-GB/packages/vue-intlayer/index.md +3 -0
- package/en-GB/per_locale_file.md +298 -0
- package/en-GB/privacy_notice.md +57 -0
- package/en-GB/roadmap.md +206 -0
- package/en-GB/terms_of_service.md +33 -0
- package/en-GB/vs_code_extension.md +139 -0
- package/es/CI_CD.md +149 -0
- package/es/autoFill.md +157 -0
- package/es/configuration.md +503 -0
- package/es/dictionary/condition.md +213 -0
- package/es/dictionary/content_extention_customization.md +81 -0
- package/es/dictionary/enumeration.md +221 -0
- package/es/dictionary/file.md +206 -0
- package/es/dictionary/function_fetching.md +190 -0
- package/es/dictionary/get_started.md +466 -0
- package/es/dictionary/insertion.md +161 -0
- package/es/dictionary/markdown.md +338 -0
- package/es/dictionary/nesting.md +249 -0
- package/es/dictionary/translation.md +287 -0
- package/es/header.md +5 -0
- package/es/how_works_intlayer.md +217 -0
- package/es/index.md +122 -0
- package/es/interest_of_intlayer.md +132 -0
- package/es/intlayer_CMS.md +334 -0
- package/es/intlayer_cli.md +274 -0
- package/es/intlayer_visual_editor.md +210 -0
- package/es/intlayer_with_angular.md +3 -0
- package/es/intlayer_with_create_react_app.md +1192 -0
- package/es/intlayer_with_express.md +276 -0
- package/es/intlayer_with_lynx+react.md +475 -0
- package/es/intlayer_with_nextjs_14.md +1258 -0
- package/es/intlayer_with_nextjs_15.md +1308 -0
- package/es/intlayer_with_nextjs_page_router.md +1088 -0
- package/es/intlayer_with_react_native+expo.md +180 -0
- package/es/intlayer_with_vite+preact.md +1637 -0
- package/es/intlayer_with_vite+react.md +1592 -0
- package/es/intlayer_with_vite+solid.md +3 -0
- package/es/intlayer_with_vite+svelte.md +3 -0
- package/es/intlayer_with_vite+vue.md +947 -0
- package/es/introduction.md +184 -0
- package/es/mcp_server.md +150 -0
- package/es/packages/@intlayer/api/index.md +31 -0
- package/es/packages/@intlayer/chokidar/index.md +31 -0
- package/es/packages/@intlayer/cli/index.md +21 -0
- package/es/packages/@intlayer/config/index.md +116 -0
- package/es/packages/@intlayer/core/index.md +25 -0
- package/es/packages/@intlayer/design-system/index.md +21 -0
- package/es/packages/@intlayer/dictionary-entry/index.md +21 -0
- package/es/packages/@intlayer/editor/index.md +21 -0
- package/es/packages/@intlayer/editor-react/index.md +21 -0
- package/es/packages/@intlayer/webpack/index.md +35 -0
- package/es/packages/angular-intlayer/index.md +3 -0
- package/es/packages/express-intlayer/index.md +229 -0
- package/es/packages/express-intlayer/t.md +432 -0
- package/es/packages/intlayer/getConfiguration.md +120 -0
- package/es/packages/intlayer/getEnumeration.md +138 -0
- package/es/packages/intlayer/getHTMLTextDir.md +97 -0
- package/es/packages/intlayer/getLocaleLang.md +57 -0
- package/es/packages/intlayer/getLocaleName.md +93 -0
- package/es/packages/intlayer/getLocalizedUrl.md +221 -0
- package/es/packages/intlayer/getMultilingualUrls.md +198 -0
- package/es/packages/intlayer/getPathWithoutLocale.md +50 -0
- package/es/packages/intlayer/getTranslation.md +166 -0
- package/es/packages/intlayer/getTranslationContent.md +166 -0
- package/es/packages/intlayer/index.md +478 -0
- package/es/packages/intlayer-cli/index.md +41 -0
- package/es/packages/intlayer-editor/index.md +115 -0
- package/es/packages/lynx-intlayer/index.md +58 -0
- package/es/packages/next-intlayer/index.md +263 -0
- package/es/packages/next-intlayer/t.md +325 -0
- package/es/packages/next-intlayer/useDictionary.md +242 -0
- package/es/packages/next-intlayer/useIntlayer.md +237 -0
- package/es/packages/next-intlayer/useIntlayerAsync.md +211 -0
- package/es/packages/next-intlayer/useLocale.md +105 -0
- package/es/packages/preact-intlayer/index.md +3 -0
- package/es/packages/react-intlayer/index.md +263 -0
- package/es/packages/react-intlayer/t.md +277 -0
- package/es/packages/react-intlayer/useDictionary.md +270 -0
- package/es/packages/react-intlayer/useIntlayer.md +225 -0
- package/es/packages/react-intlayer/useIntlayerAsync.md +226 -0
- package/es/packages/react-intlayer/useLocale.md +184 -0
- package/es/packages/react-native-intlayer/index.md +57 -0
- package/es/packages/react-scripts-intlayer/index.md +57 -0
- package/es/packages/solid-intlayer/index.md +3 -0
- package/es/packages/svelte-intlayer/index.md +5 -0
- package/es/packages/vite-intlayer/index.md +53 -0
- package/es/packages/vue-intlayer/index.md +3 -0
- package/es/per_locale_file.md +293 -0
- package/es/privacy_notice.md +61 -0
- package/es/roadmap.md +157 -0
- package/es/terms_of_service.md +33 -0
- package/es/vs_code_extension.md +139 -0
- package/fr/CI_CD.md +149 -0
- package/fr/autoFill.md +157 -0
- package/fr/configuration.md +481 -0
- package/fr/dictionary/condition.md +213 -0
- package/fr/dictionary/content_extention_customization.md +81 -0
- package/fr/dictionary/enumeration.md +221 -0
- package/fr/dictionary/file.md +206 -0
- package/fr/dictionary/function_fetching.md +190 -0
- package/fr/dictionary/get_started.md +466 -0
- package/fr/dictionary/insertion.md +161 -0
- package/fr/dictionary/markdown.md +335 -0
- package/fr/dictionary/nesting.md +249 -0
- package/fr/dictionary/translation.md +287 -0
- package/fr/header.md +5 -0
- package/fr/how_works_intlayer.md +217 -0
- package/fr/index.md +122 -0
- package/fr/interest_of_intlayer.md +132 -0
- package/fr/intlayer_CMS.md +334 -0
- package/fr/intlayer_cli.md +274 -0
- package/fr/intlayer_visual_editor.md +210 -0
- package/fr/intlayer_with_angular.md +3 -0
- package/fr/intlayer_with_create_react_app.md +1192 -0
- package/fr/intlayer_with_express.md +270 -0
- package/fr/intlayer_with_lynx+react.md +466 -0
- package/fr/intlayer_with_nextjs_14.md +1258 -0
- package/fr/intlayer_with_nextjs_15.md +1308 -0
- package/fr/intlayer_with_nextjs_page_router.md +1085 -0
- package/fr/intlayer_with_react_native+expo.md +535 -0
- package/fr/intlayer_with_vite+preact.md +1621 -0
- package/fr/intlayer_with_vite+react.md +1589 -0
- package/fr/intlayer_with_vite+solid.md +3 -0
- package/fr/intlayer_with_vite+svelte.md +3 -0
- package/fr/intlayer_with_vite+vue.md +947 -0
- package/fr/introduction.md +190 -0
- package/fr/mcp_server.md +152 -0
- package/fr/packages/@intlayer/api/index.md +31 -0
- package/fr/packages/@intlayer/chokidar/index.md +31 -0
- package/fr/packages/@intlayer/cli/index.md +21 -0
- package/fr/packages/@intlayer/config/index.md +116 -0
- package/fr/packages/@intlayer/core/index.md +25 -0
- package/fr/packages/@intlayer/design-system/index.md +21 -0
- package/fr/packages/@intlayer/dictionary-entry/index.md +21 -0
- package/fr/packages/@intlayer/editor/index.md +21 -0
- package/fr/packages/@intlayer/editor-react/index.md +21 -0
- package/fr/packages/@intlayer/webpack/index.md +35 -0
- package/fr/packages/angular-intlayer/index.md +3 -0
- package/fr/packages/express-intlayer/index.md +238 -0
- package/fr/packages/express-intlayer/t.md +432 -0
- package/fr/packages/intlayer/getConfiguration.md +120 -0
- package/fr/packages/intlayer/getEnumeration.md +138 -0
- package/fr/packages/intlayer/getHTMLTextDir.md +97 -0
- package/fr/packages/intlayer/getLocaleLang.md +57 -0
- package/fr/packages/intlayer/getLocaleName.md +93 -0
- package/fr/packages/intlayer/getLocalizedUrl.md +221 -0
- package/fr/packages/intlayer/getMultilingualUrls.md +198 -0
- package/fr/packages/intlayer/getPathWithoutLocale.md +50 -0
- package/fr/packages/intlayer/getTranslation.md +166 -0
- package/fr/packages/intlayer/getTranslationContent.md +166 -0
- package/fr/packages/intlayer/index.md +476 -0
- package/fr/packages/intlayer-cli/index.md +41 -0
- package/fr/packages/intlayer-editor/index.md +115 -0
- package/fr/packages/lynx-intlayer/index.md +58 -0
- package/fr/packages/next-intlayer/index.md +266 -0
- package/fr/packages/next-intlayer/t.md +325 -0
- package/fr/packages/next-intlayer/useDictionary.md +242 -0
- package/fr/packages/next-intlayer/useIntlayer.md +237 -0
- package/fr/packages/next-intlayer/useIntlayerAsync.md +211 -0
- package/fr/packages/next-intlayer/useLocale.md +105 -0
- package/fr/packages/preact-intlayer/index.md +3 -0
- package/fr/packages/react-intlayer/index.md +257 -0
- package/fr/packages/react-intlayer/t.md +277 -0
- package/fr/packages/react-intlayer/useDictionary.md +269 -0
- package/fr/packages/react-intlayer/useIntlayer.md +234 -0
- package/fr/packages/react-intlayer/useIntlayerAsync.md +226 -0
- package/fr/packages/react-intlayer/useLocale.md +184 -0
- package/fr/packages/react-native-intlayer/index.md +57 -0
- package/fr/packages/react-scripts-intlayer/index.md +57 -0
- package/fr/packages/solid-intlayer/index.md +3 -0
- package/fr/packages/svelte-intlayer/index.md +3 -0
- package/fr/packages/vite-intlayer/index.md +53 -0
- package/fr/packages/vue-intlayer/index.md +3 -0
- package/fr/per_locale_file.md +297 -0
- package/fr/privacy_notice.md +57 -0
- package/fr/roadmap.md +206 -0
- package/fr/terms_of_service.md +33 -0
- package/fr/vs_code_extension.md +139 -0
- package/hi/CI_CD.md +149 -0
- package/hi/autoFill.md +157 -0
- package/hi/configuration.md +509 -0
- package/hi/dictionary/condition.md +213 -0
- package/hi/dictionary/content_extention_customization.md +81 -0
- package/hi/dictionary/enumeration.md +221 -0
- package/hi/dictionary/file.md +209 -0
- package/hi/dictionary/function_fetching.md +188 -0
- package/hi/dictionary/get_started.md +490 -0
- package/hi/dictionary/insertion.md +167 -0
- package/hi/dictionary/markdown.md +344 -0
- package/hi/dictionary/nesting.md +249 -0
- package/hi/dictionary/translation.md +307 -0
- package/hi/header.md +7 -0
- package/hi/how_works_intlayer.md +217 -0
- package/hi/index.md +125 -0
- package/hi/interest_of_intlayer.md +132 -0
- package/hi/intlayer_CMS.md +334 -0
- package/hi/intlayer_cli.md +274 -0
- package/hi/intlayer_visual_editor.md +210 -0
- package/hi/intlayer_with_angular.md +3 -0
- package/hi/intlayer_with_create_react_app.md +1395 -0
- package/hi/intlayer_with_express.md +273 -0
- package/hi/intlayer_with_lynx+react.md +456 -0
- package/hi/intlayer_with_nextjs_14.md +1283 -0
- package/hi/intlayer_with_nextjs_15.md +1319 -0
- package/hi/intlayer_with_nextjs_page_router.md +1097 -0
- package/hi/intlayer_with_react_native+expo.md +554 -0
- package/hi/intlayer_with_vite+preact.md +1538 -0
- package/hi/intlayer_with_vite+react.md +1540 -0
- package/hi/intlayer_with_vite+solid.md +3 -0
- package/hi/intlayer_with_vite+svelte.md +3 -0
- package/hi/intlayer_with_vite+vue.md +840 -0
- package/hi/introduction.md +190 -0
- package/hi/mcp_server.md +150 -0
- package/hi/packages/@intlayer/api/index.md +31 -0
- package/hi/packages/@intlayer/chokidar/index.md +31 -0
- package/hi/packages/@intlayer/cli/index.md +21 -0
- package/hi/packages/@intlayer/config/index.md +116 -0
- package/hi/packages/@intlayer/core/index.md +25 -0
- package/hi/packages/@intlayer/design-system/index.md +21 -0
- package/hi/packages/@intlayer/dictionary-entry/index.md +21 -0
- package/hi/packages/@intlayer/editor/index.md +21 -0
- package/hi/packages/@intlayer/editor-react/index.md +21 -0
- package/hi/packages/@intlayer/webpack/index.md +35 -0
- package/hi/packages/angular-intlayer/index.md +3 -0
- package/hi/packages/express-intlayer/index.md +232 -0
- package/hi/packages/express-intlayer/t.md +445 -0
- package/hi/packages/intlayer/getConfiguration.md +120 -0
- package/hi/packages/intlayer/getEnumeration.md +138 -0
- package/hi/packages/intlayer/getHTMLTextDir.md +97 -0
- package/hi/packages/intlayer/getLocaleLang.md +57 -0
- package/hi/packages/intlayer/getLocaleName.md +93 -0
- package/hi/packages/intlayer/getLocalizedUrl.md +221 -0
- package/hi/packages/intlayer/getMultilingualUrls.md +198 -0
- package/hi/packages/intlayer/getPathWithoutLocale.md +50 -0
- package/hi/packages/intlayer/getTranslation.md +175 -0
- package/hi/packages/intlayer/getTranslationContent.md +175 -0
- package/hi/packages/intlayer/index.md +314 -0
- package/hi/packages/intlayer-cli/index.md +41 -0
- package/hi/packages/intlayer-editor/index.md +113 -0
- package/hi/packages/lynx-intlayer/index.md +58 -0
- package/hi/packages/next-intlayer/index.md +270 -0
- package/hi/packages/next-intlayer/t.md +337 -0
- package/hi/packages/next-intlayer/useDictionary.md +248 -0
- package/hi/packages/next-intlayer/useIntlayer.md +237 -0
- package/hi/packages/next-intlayer/useIntlayerAsync.md +211 -0
- package/hi/packages/next-intlayer/useLocale.md +105 -0
- package/hi/packages/preact-intlayer/index.md +3 -0
- package/hi/packages/react-intlayer/index.md +261 -0
- package/hi/packages/react-intlayer/t.md +283 -0
- package/hi/packages/react-intlayer/useDictionary.md +268 -0
- package/hi/packages/react-intlayer/useIntlayer.md +225 -0
- package/hi/packages/react-intlayer/useIntlayerAsync.md +226 -0
- package/hi/packages/react-intlayer/useLocale.md +184 -0
- package/hi/packages/react-native-intlayer/index.md +57 -0
- package/hi/packages/react-scripts-intlayer/index.md +57 -0
- package/hi/packages/solid-intlayer/index.md +3 -0
- package/hi/packages/svelte-intlayer/index.md +3 -0
- package/hi/packages/vite-intlayer/index.md +53 -0
- package/hi/packages/vue-intlayer/index.md +3 -0
- package/hi/per_locale_file.md +298 -0
- package/hi/privacy_notice.md +61 -0
- package/hi/roadmap.md +206 -0
- package/hi/terms_of_service.md +33 -0
- package/hi/vs_code_extension.md +139 -0
- package/index.cjs +1265 -0
- package/index.d.ts +100 -0
- package/it/CI_CD.md +149 -0
- package/it/autoFill.md +157 -0
- package/it/configuration.md +503 -0
- package/it/dictionary/condition.md +213 -0
- package/it/dictionary/content_extention_customization.md +81 -0
- package/it/dictionary/enumeration.md +221 -0
- package/it/dictionary/file.md +207 -0
- package/it/dictionary/function_fetching.md +190 -0
- package/it/dictionary/get_started.md +466 -0
- package/it/dictionary/insertion.md +161 -0
- package/it/dictionary/markdown.md +343 -0
- package/it/dictionary/nesting.md +249 -0
- package/it/dictionary/translation.md +287 -0
- package/it/header.md +7 -0
- package/it/how_works_intlayer.md +217 -0
- package/it/index.md +125 -0
- package/it/interest_of_intlayer.md +132 -0
- package/it/intlayer_CMS.md +334 -0
- package/it/intlayer_cli.md +274 -0
- package/it/intlayer_visual_editor.md +210 -0
- package/it/intlayer_with_angular.md +3 -0
- package/it/intlayer_with_create_react_app.md +413 -0
- package/it/intlayer_with_express.md +267 -0
- package/it/intlayer_with_lynx+react.md +482 -0
- package/it/intlayer_with_nextjs_14.md +1269 -0
- package/it/intlayer_with_nextjs_15.md +1319 -0
- package/it/intlayer_with_nextjs_page_router.md +1095 -0
- package/it/intlayer_with_react_native+expo.md +261 -0
- package/it/intlayer_with_vite+preact.md +1681 -0
- package/it/intlayer_with_vite+react.md +1580 -0
- package/it/intlayer_with_vite+solid.md +3 -0
- package/it/intlayer_with_vite+svelte.md +3 -0
- package/it/intlayer_with_vite+vue.md +989 -0
- package/it/introduction.md +192 -0
- package/it/mcp_server.md +152 -0
- package/it/packages/@intlayer/api/index.md +31 -0
- package/it/packages/@intlayer/chokidar/index.md +31 -0
- package/it/packages/@intlayer/cli/index.md +21 -0
- package/it/packages/@intlayer/config/index.md +116 -0
- package/it/packages/@intlayer/core/index.md +25 -0
- package/it/packages/@intlayer/design-system/index.md +21 -0
- package/it/packages/@intlayer/dictionary-entry/index.md +21 -0
- package/it/packages/@intlayer/editor/index.md +21 -0
- package/it/packages/@intlayer/editor-react/index.md +21 -0
- package/it/packages/@intlayer/webpack/index.md +35 -0
- package/it/packages/angular-intlayer/index.md +3 -0
- package/it/packages/express-intlayer/index.md +229 -0
- package/it/packages/express-intlayer/t.md +432 -0
- package/it/packages/intlayer/getConfiguration.md +120 -0
- package/it/packages/intlayer/getEnumeration.md +138 -0
- package/it/packages/intlayer/getHTMLTextDir.md +97 -0
- package/it/packages/intlayer/getLocaleLang.md +57 -0
- package/it/packages/intlayer/getLocaleName.md +93 -0
- package/it/packages/intlayer/getLocalizedUrl.md +221 -0
- package/it/packages/intlayer/getMultilingualUrls.md +200 -0
- package/it/packages/intlayer/getPathWithoutLocale.md +50 -0
- package/it/packages/intlayer/getTranslation.md +166 -0
- package/it/packages/intlayer/getTranslationContent.md +166 -0
- package/it/packages/intlayer/index.md +479 -0
- package/it/packages/intlayer-cli/index.md +41 -0
- package/it/packages/intlayer-editor/index.md +113 -0
- package/it/packages/lynx-intlayer/index.md +58 -0
- package/it/packages/next-intlayer/index.md +267 -0
- package/it/packages/next-intlayer/t.md +326 -0
- package/it/packages/next-intlayer/useDictionary.md +242 -0
- package/it/packages/next-intlayer/useIntlayer.md +237 -0
- package/it/packages/next-intlayer/useIntlayerAsync.md +211 -0
- package/it/packages/next-intlayer/useLocale.md +105 -0
- package/it/packages/preact-intlayer/index.md +3 -0
- package/it/packages/react-intlayer/index.md +260 -0
- package/it/packages/react-intlayer/t.md +277 -0
- package/it/packages/react-intlayer/useDictionary.md +260 -0
- package/it/packages/react-intlayer/useIntlayer.md +225 -0
- package/it/packages/react-intlayer/useIntlayerAsync.md +226 -0
- package/it/packages/react-intlayer/useLocale.md +184 -0
- package/it/packages/react-native-intlayer/index.md +57 -0
- package/it/packages/react-scripts-intlayer/index.md +57 -0
- package/it/packages/solid-intlayer/index.md +5 -0
- package/it/packages/svelte-intlayer/index.md +3 -0
- package/it/packages/vite-intlayer/index.md +53 -0
- package/it/packages/vue-intlayer/index.md +5 -0
- package/it/per_locale_file.md +298 -0
- package/it/privacy_notice.md +61 -0
- package/it/roadmap.md +206 -0
- package/it/terms_of_service.md +33 -0
- package/it/vs_code_extension.md +139 -0
- package/ja/CI_CD.md +149 -0
- package/ja/autoFill.md +157 -0
- package/ja/configuration.md +507 -0
- package/ja/dictionary/condition.md +213 -0
- package/ja/dictionary/content_extention_customization.md +81 -0
- package/ja/dictionary/enumeration.md +221 -0
- package/ja/dictionary/file.md +209 -0
- package/ja/dictionary/function_fetching.md +190 -0
- package/ja/dictionary/get_started.md +466 -0
- package/ja/dictionary/insertion.md +161 -0
- package/ja/dictionary/markdown.md +343 -0
- package/ja/dictionary/nesting.md +249 -0
- package/ja/dictionary/translation.md +287 -0
- package/ja/header.md +7 -0
- package/ja/how_works_intlayer.md +217 -0
- package/ja/index.md +125 -0
- package/ja/interest_of_intlayer.md +132 -0
- package/ja/intlayer_CMS.md +334 -0
- package/ja/intlayer_cli.md +274 -0
- package/ja/intlayer_visual_editor.md +213 -0
- package/ja/intlayer_with_angular.md +3 -0
- package/ja/intlayer_with_create_react_app.md +1186 -0
- package/ja/intlayer_with_express.md +267 -0
- package/ja/intlayer_with_lynx+react.md +482 -0
- package/ja/intlayer_with_nextjs_14.md +1256 -0
- package/ja/intlayer_with_nextjs_15.md +1308 -0
- package/ja/intlayer_with_nextjs_page_router.md +1085 -0
- package/ja/intlayer_with_react_native+expo.md +537 -0
- package/ja/intlayer_with_vite+preact.md +1601 -0
- package/ja/intlayer_with_vite+react.md +1555 -0
- package/ja/intlayer_with_vite+solid.md +3 -0
- package/ja/intlayer_with_vite+svelte.md +3 -0
- package/ja/intlayer_with_vite+vue.md +990 -0
- package/ja/introduction.md +186 -0
- package/ja/mcp_server.md +150 -0
- package/ja/packages/@intlayer/api/index.md +31 -0
- package/ja/packages/@intlayer/chokidar/index.md +31 -0
- package/ja/packages/@intlayer/cli/index.md +21 -0
- package/ja/packages/@intlayer/config/index.md +116 -0
- package/ja/packages/@intlayer/core/index.md +25 -0
- package/ja/packages/@intlayer/design-system/index.md +21 -0
- package/ja/packages/@intlayer/dictionary-entry/index.md +21 -0
- package/ja/packages/@intlayer/editor/index.md +21 -0
- package/ja/packages/@intlayer/editor-react/index.md +21 -0
- package/ja/packages/@intlayer/webpack/index.md +35 -0
- package/ja/packages/angular-intlayer/index.md +3 -0
- package/ja/packages/express-intlayer/index.md +229 -0
- package/ja/packages/express-intlayer/t.md +432 -0
- package/ja/packages/intlayer/getConfiguration.md +120 -0
- package/ja/packages/intlayer/getEnumeration.md +140 -0
- package/ja/packages/intlayer/getHTMLTextDir.md +97 -0
- package/ja/packages/intlayer/getLocaleLang.md +59 -0
- package/ja/packages/intlayer/getLocaleName.md +93 -0
- package/ja/packages/intlayer/getLocalizedUrl.md +221 -0
- package/ja/packages/intlayer/getMultilingualUrls.md +198 -0
- package/ja/packages/intlayer/getPathWithoutLocale.md +50 -0
- package/ja/packages/intlayer/getTranslation.md +166 -0
- package/ja/packages/intlayer/getTranslationContent.md +166 -0
- package/ja/packages/intlayer/index.md +479 -0
- package/ja/packages/intlayer-cli/index.md +41 -0
- package/ja/packages/intlayer-editor/index.md +115 -0
- package/ja/packages/lynx-intlayer/index.md +58 -0
- package/ja/packages/next-intlayer/index.md +263 -0
- package/ja/packages/next-intlayer/t.md +326 -0
- package/ja/packages/next-intlayer/useDictionary.md +242 -0
- package/ja/packages/next-intlayer/useIntlayer.md +237 -0
- package/ja/packages/next-intlayer/useIntlayerAsync.md +211 -0
- package/ja/packages/next-intlayer/useLocale.md +105 -0
- package/ja/packages/preact-intlayer/index.md +3 -0
- package/ja/packages/react-intlayer/index.md +257 -0
- package/ja/packages/react-intlayer/t.md +277 -0
- package/ja/packages/react-intlayer/useDictionary.md +260 -0
- package/ja/packages/react-intlayer/useIntlayer.md +225 -0
- package/ja/packages/react-intlayer/useIntlayerAsync.md +226 -0
- package/ja/packages/react-intlayer/useLocale.md +184 -0
- package/ja/packages/react-native-intlayer/index.md +57 -0
- package/ja/packages/react-scripts-intlayer/index.md +57 -0
- package/ja/packages/solid-intlayer/index.md +3 -0
- package/ja/packages/svelte-intlayer/index.md +3 -0
- package/ja/packages/vite-intlayer/index.md +53 -0
- package/ja/packages/vue-intlayer/index.md +3 -0
- package/ja/per_locale_file.md +298 -0
- package/ja/privacy_notice.md +57 -0
- package/ja/roadmap.md +206 -0
- package/ja/terms_of_service.md +33 -0
- package/ja/vs_code_extension.md +139 -0
- package/ko/CI_CD.md +149 -0
- package/ko/autoFill.md +157 -0
- package/ko/configuration.md +507 -0
- package/ko/dictionary/condition.md +213 -0
- package/ko/dictionary/content_extention_customization.md +81 -0
- package/ko/dictionary/enumeration.md +221 -0
- package/ko/dictionary/file.md +207 -0
- package/ko/dictionary/function_fetching.md +190 -0
- package/ko/dictionary/get_started.md +466 -0
- package/ko/dictionary/insertion.md +167 -0
- package/ko/dictionary/markdown.md +343 -0
- package/ko/dictionary/nesting.md +249 -0
- package/ko/dictionary/translation.md +287 -0
- package/ko/header.md +7 -0
- package/ko/how_works_intlayer.md +216 -0
- package/ko/index.md +125 -0
- package/ko/interest_of_intlayer.md +132 -0
- package/ko/intlayer_CMS.md +334 -0
- package/ko/intlayer_cli.md +274 -0
- package/ko/intlayer_visual_editor.md +210 -0
- package/ko/intlayer_with_angular.md +3 -0
- package/ko/intlayer_with_create_react_app.md +1186 -0
- package/ko/intlayer_with_express.md +267 -0
- package/ko/intlayer_with_lynx+react.md +482 -0
- package/ko/intlayer_with_nextjs_14.md +1267 -0
- package/ko/intlayer_with_nextjs_15.md +1319 -0
- package/ko/intlayer_with_nextjs_page_router.md +1097 -0
- package/ko/intlayer_with_react_native+expo.md +537 -0
- package/ko/intlayer_with_vite+preact.md +1682 -0
- package/ko/intlayer_with_vite+react.md +1582 -0
- package/ko/intlayer_with_vite+solid.md +3 -0
- package/ko/intlayer_with_vite+svelte.md +3 -0
- package/ko/intlayer_with_vite+vue.md +988 -0
- package/ko/introduction.md +186 -0
- package/ko/mcp_server.md +150 -0
- package/ko/packages/@intlayer/api/index.md +31 -0
- package/ko/packages/@intlayer/chokidar/index.md +31 -0
- package/ko/packages/@intlayer/cli/index.md +21 -0
- package/ko/packages/@intlayer/config/index.md +116 -0
- package/ko/packages/@intlayer/core/index.md +25 -0
- package/ko/packages/@intlayer/design-system/index.md +21 -0
- package/ko/packages/@intlayer/dictionary-entry/index.md +21 -0
- package/ko/packages/@intlayer/editor/index.md +21 -0
- package/ko/packages/@intlayer/editor-react/index.md +21 -0
- package/ko/packages/@intlayer/webpack/index.md +35 -0
- package/ko/packages/angular-intlayer/index.md +5 -0
- package/ko/packages/express-intlayer/index.md +229 -0
- package/ko/packages/express-intlayer/t.md +432 -0
- package/ko/packages/intlayer/getConfiguration.md +120 -0
- package/ko/packages/intlayer/getEnumeration.md +138 -0
- package/ko/packages/intlayer/getHTMLTextDir.md +97 -0
- package/ko/packages/intlayer/getLocaleLang.md +57 -0
- package/ko/packages/intlayer/getLocaleName.md +93 -0
- package/ko/packages/intlayer/getLocalizedUrl.md +221 -0
- package/ko/packages/intlayer/getMultilingualUrls.md +198 -0
- package/ko/packages/intlayer/getPathWithoutLocale.md +50 -0
- package/ko/packages/intlayer/getTranslation.md +166 -0
- package/ko/packages/intlayer/getTranslationContent.md +166 -0
- package/ko/packages/intlayer/index.md +480 -0
- package/ko/packages/intlayer-cli/index.md +41 -0
- package/ko/packages/intlayer-editor/index.md +113 -0
- package/ko/packages/lynx-intlayer/index.md +58 -0
- package/ko/packages/next-intlayer/index.md +267 -0
- package/ko/packages/next-intlayer/t.md +337 -0
- package/ko/packages/next-intlayer/useDictionary.md +242 -0
- package/ko/packages/next-intlayer/useIntlayer.md +237 -0
- package/ko/packages/next-intlayer/useIntlayerAsync.md +211 -0
- package/ko/packages/next-intlayer/useLocale.md +105 -0
- package/ko/packages/preact-intlayer/index.md +3 -0
- package/ko/packages/react-intlayer/index.md +260 -0
- package/ko/packages/react-intlayer/t.md +277 -0
- package/ko/packages/react-intlayer/useDictionary.md +268 -0
- package/ko/packages/react-intlayer/useIntlayer.md +225 -0
- package/ko/packages/react-intlayer/useIntlayerAsync.md +226 -0
- package/ko/packages/react-intlayer/useLocale.md +184 -0
- package/ko/packages/react-native-intlayer/index.md +57 -0
- package/ko/packages/react-scripts-intlayer/index.md +57 -0
- package/ko/packages/solid-intlayer/index.md +3 -0
- package/ko/packages/svelte-intlayer/index.md +3 -0
- package/ko/packages/vite-intlayer/index.md +53 -0
- package/ko/packages/vue-intlayer/index.md +3 -0
- package/ko/per_locale_file.md +300 -0
- package/ko/privacy_notice.md +61 -0
- package/ko/roadmap.md +206 -0
- package/ko/terms_of_service.md +33 -0
- package/ko/vs_code_extension.md +139 -0
- package/package.json +96 -0
- package/pt/CI_CD.md +149 -0
- package/pt/autoFill.md +157 -0
- package/pt/configuration.md +503 -0
- package/pt/dictionary/condition.md +213 -0
- package/pt/dictionary/content_extention_customization.md +81 -0
- package/pt/dictionary/enumeration.md +221 -0
- package/pt/dictionary/file.md +210 -0
- package/pt/dictionary/function_fetching.md +190 -0
- package/pt/dictionary/get_started.md +490 -0
- package/pt/dictionary/insertion.md +161 -0
- package/pt/dictionary/markdown.md +339 -0
- package/pt/dictionary/nesting.md +249 -0
- package/pt/dictionary/translation.md +322 -0
- package/pt/header.md +7 -0
- package/pt/how_works_intlayer.md +216 -0
- package/pt/index.md +125 -0
- package/pt/interest_of_intlayer.md +132 -0
- package/pt/intlayer_CMS.md +334 -0
- package/pt/intlayer_cli.md +274 -0
- package/pt/intlayer_visual_editor.md +210 -0
- package/pt/intlayer_with_angular.md +3 -0
- package/pt/intlayer_with_create_react_app.md +1204 -0
- package/pt/intlayer_with_express.md +270 -0
- package/pt/intlayer_with_lynx+react.md +467 -0
- package/pt/intlayer_with_nextjs_14.md +1269 -0
- package/pt/intlayer_with_nextjs_15.md +1319 -0
- package/pt/intlayer_with_nextjs_page_router.md +1109 -0
- package/pt/intlayer_with_react_native+expo.md +259 -0
- package/pt/intlayer_with_vite+preact.md +1663 -0
- package/pt/intlayer_with_vite+react.md +1621 -0
- package/pt/intlayer_with_vite+solid.md +3 -0
- package/pt/intlayer_with_vite+svelte.md +3 -0
- package/pt/intlayer_with_vite+vue.md +989 -0
- package/pt/introduction.md +193 -0
- package/pt/mcp_server.md +150 -0
- package/pt/packages/@intlayer/api/index.md +31 -0
- package/pt/packages/@intlayer/chokidar/index.md +31 -0
- package/pt/packages/@intlayer/cli/index.md +21 -0
- package/pt/packages/@intlayer/config/index.md +116 -0
- package/pt/packages/@intlayer/core/index.md +25 -0
- package/pt/packages/@intlayer/design-system/index.md +21 -0
- package/pt/packages/@intlayer/dictionary-entry/index.md +21 -0
- package/pt/packages/@intlayer/editor/index.md +21 -0
- package/pt/packages/@intlayer/editor-react/index.md +21 -0
- package/pt/packages/@intlayer/webpack/index.md +35 -0
- package/pt/packages/angular-intlayer/index.md +3 -0
- package/pt/packages/express-intlayer/index.md +232 -0
- package/pt/packages/express-intlayer/t.md +267 -0
- package/pt/packages/intlayer/getConfiguration.md +120 -0
- package/pt/packages/intlayer/getEnumeration.md +138 -0
- package/pt/packages/intlayer/getHTMLTextDir.md +97 -0
- package/pt/packages/intlayer/getLocaleLang.md +57 -0
- package/pt/packages/intlayer/getLocaleName.md +93 -0
- package/pt/packages/intlayer/getLocalizedUrl.md +221 -0
- package/pt/packages/intlayer/getMultilingualUrls.md +198 -0
- package/pt/packages/intlayer/getPathWithoutLocale.md +50 -0
- package/pt/packages/intlayer/getTranslation.md +175 -0
- package/pt/packages/intlayer/getTranslationContent.md +177 -0
- package/pt/packages/intlayer/index.md +484 -0
- package/pt/packages/intlayer-cli/index.md +41 -0
- package/pt/packages/intlayer-editor/index.md +113 -0
- package/pt/packages/lynx-intlayer/index.md +58 -0
- package/pt/packages/next-intlayer/index.md +270 -0
- package/pt/packages/next-intlayer/t.md +341 -0
- package/pt/packages/next-intlayer/useDictionary.md +248 -0
- package/pt/packages/next-intlayer/useIntlayer.md +237 -0
- package/pt/packages/next-intlayer/useIntlayerAsync.md +211 -0
- package/pt/packages/next-intlayer/useLocale.md +105 -0
- package/pt/packages/preact-intlayer/index.md +3 -0
- package/pt/packages/react-intlayer/index.md +261 -0
- package/pt/packages/react-intlayer/t.md +289 -0
- package/pt/packages/react-intlayer/useDictionary.md +268 -0
- package/pt/packages/react-intlayer/useIntlayer.md +225 -0
- package/pt/packages/react-intlayer/useIntlayerAsync.md +226 -0
- package/pt/packages/react-intlayer/useLocale.md +184 -0
- package/pt/packages/react-native-intlayer/index.md +57 -0
- package/pt/packages/react-scripts-intlayer/index.md +57 -0
- package/pt/packages/solid-intlayer/index.md +3 -0
- package/pt/packages/svelte-intlayer/index.md +3 -0
- package/pt/packages/vite-intlayer/index.md +53 -0
- package/pt/packages/vue-intlayer/index.md +3 -0
- package/pt/per_locale_file.md +298 -0
- package/pt/privacy_notice.md +61 -0
- package/pt/roadmap.md +206 -0
- package/pt/terms_of_service.md +33 -0
- package/pt/vs_code_extension.md +139 -0
- package/ru/CI_CD.md +149 -0
- package/ru/autoFill.md +157 -0
- package/ru/configuration.md +507 -0
- package/ru/dictionary/condition.md +213 -0
- package/ru/dictionary/content_extention_customization.md +81 -0
- package/ru/dictionary/enumeration.md +221 -0
- package/ru/dictionary/file.md +209 -0
- package/ru/dictionary/function_fetching.md +188 -0
- package/ru/dictionary/get_started.md +311 -0
- package/ru/dictionary/insertion.md +161 -0
- package/ru/dictionary/markdown.md +339 -0
- package/ru/dictionary/nesting.md +249 -0
- package/ru/dictionary/translation.md +322 -0
- package/ru/environment/angular.md +3 -0
- package/ru/header.md +7 -0
- package/ru/how_works_intlayer.md +217 -0
- package/ru/index.md +125 -0
- package/ru/interest_of_intlayer.md +132 -0
- package/ru/intlayer_CMS.md +334 -0
- package/ru/intlayer_cli.md +274 -0
- package/ru/intlayer_visual_editor.md +210 -0
- package/ru/intlayer_with_angular.md +3 -0
- package/ru/intlayer_with_create_react_app.md +1196 -0
- package/ru/intlayer_with_express.md +273 -0
- package/ru/intlayer_with_lynx+react.md +482 -0
- package/ru/intlayer_with_nextjs_14.md +1274 -0
- package/ru/intlayer_with_nextjs_15.md +1318 -0
- package/ru/intlayer_with_nextjs_page_router.md +1100 -0
- package/ru/intlayer_with_react_native+expo.md +537 -0
- package/ru/intlayer_with_vite+preact.md +1663 -0
- package/ru/intlayer_with_vite+react.md +1546 -0
- package/ru/intlayer_with_vite+solid.md +3 -0
- package/ru/intlayer_with_vite+svelte.md +3 -0
- package/ru/intlayer_with_vite+vue.md +987 -0
- package/ru/introduction.md +190 -0
- package/ru/mcp_server.md +152 -0
- package/ru/packages/@intlayer/api/index.md +31 -0
- package/ru/packages/@intlayer/chokidar/index.md +31 -0
- package/ru/packages/@intlayer/cli/index.md +23 -0
- package/ru/packages/@intlayer/config/index.md +116 -0
- package/ru/packages/@intlayer/core/index.md +25 -0
- package/ru/packages/@intlayer/design-system/index.md +21 -0
- package/ru/packages/@intlayer/dictionary-entry/index.md +21 -0
- package/ru/packages/@intlayer/editor/index.md +21 -0
- package/ru/packages/@intlayer/editor-react/index.md +21 -0
- package/ru/packages/@intlayer/webpack/index.md +35 -0
- package/ru/packages/angular-intlayer/index.md +3 -0
- package/ru/packages/express-intlayer/index.md +235 -0
- package/ru/packages/express-intlayer/t.md +445 -0
- package/ru/packages/intlayer/getConfiguration.md +120 -0
- package/ru/packages/intlayer/getEnumeration.md +140 -0
- package/ru/packages/intlayer/getHTMLTextDir.md +97 -0
- package/ru/packages/intlayer/getLocaleLang.md +59 -0
- package/ru/packages/intlayer/getLocaleName.md +93 -0
- package/ru/packages/intlayer/getLocalizedUrl.md +221 -0
- package/ru/packages/intlayer/getMultilingualUrls.md +198 -0
- package/ru/packages/intlayer/getPathWithoutLocale.md +50 -0
- package/ru/packages/intlayer/getTranslation.md +177 -0
- package/ru/packages/intlayer/getTranslationContent.md +175 -0
- package/ru/packages/intlayer/index.md +275 -0
- package/ru/packages/intlayer-cli/index.md +41 -0
- package/ru/packages/intlayer-editor/index.md +115 -0
- package/ru/packages/lynx-intlayer/index.md +58 -0
- package/ru/packages/next-intlayer/index.md +267 -0
- package/ru/packages/next-intlayer/t.md +340 -0
- package/ru/packages/next-intlayer/useDictionary.md +248 -0
- package/ru/packages/next-intlayer/useIntlayer.md +237 -0
- package/ru/packages/next-intlayer/useIntlayerAsync.md +211 -0
- package/ru/packages/next-intlayer/useLocale.md +105 -0
- package/ru/packages/preact-intlayer/index.md +3 -0
- package/ru/packages/react-intlayer/index.md +261 -0
- package/ru/packages/react-intlayer/t.md +289 -0
- package/ru/packages/react-intlayer/useDictionary.md +268 -0
- package/ru/packages/react-intlayer/useIntlayer.md +225 -0
- package/ru/packages/react-intlayer/useIntlayerAsync.md +226 -0
- package/ru/packages/react-intlayer/useLocale.md +184 -0
- package/ru/packages/react-native-intlayer/index.md +57 -0
- package/ru/packages/react-scripts-intlayer/index.md +57 -0
- package/ru/packages/solid-intlayer/index.md +3 -0
- package/ru/packages/svelte-intlayer/index.md +3 -0
- package/ru/packages/vite-intlayer/index.md +53 -0
- package/ru/packages/vue-intlayer/index.md +3 -0
- package/ru/per_locale_file.md +298 -0
- package/ru/privacy_notice.md +61 -0
- package/ru/roadmap.md +206 -0
- package/ru/terms_of_service.md +33 -0
- package/ru/vs_code_extension.md +139 -0
- package/zh/CI_CD.md +149 -0
- package/zh/autoFill.md +157 -0
- package/zh/configuration.md +484 -0
- package/zh/dictionary/condition.md +213 -0
- package/zh/dictionary/content_extention_customization.md +81 -0
- package/zh/dictionary/enumeration.md +221 -0
- package/zh/dictionary/file.md +209 -0
- package/zh/dictionary/function_fetching.md +188 -0
- package/zh/dictionary/get_started.md +490 -0
- package/zh/dictionary/insertion.md +161 -0
- package/zh/dictionary/markdown.md +342 -0
- package/zh/dictionary/nesting.md +249 -0
- package/zh/dictionary/translation.md +287 -0
- package/zh/header.md +7 -0
- package/zh/how_works_intlayer.md +217 -0
- package/zh/index.md +125 -0
- package/zh/interest_of_intlayer.md +132 -0
- package/zh/intlayer_CMS.md +334 -0
- package/zh/intlayer_cli.md +274 -0
- package/zh/intlayer_visual_editor.md +210 -0
- package/zh/intlayer_with_angular.md +3 -0
- package/zh/intlayer_with_create_react_app.md +1196 -0
- package/zh/intlayer_with_express.md +267 -0
- package/zh/intlayer_with_lynx+react.md +484 -0
- package/zh/intlayer_with_nextjs_14.md +1286 -0
- package/zh/intlayer_with_nextjs_15.md +1322 -0
- package/zh/intlayer_with_nextjs_page_router.md +1097 -0
- package/zh/intlayer_with_react_native+expo.md +539 -0
- package/zh/intlayer_with_vite+preact.md +1681 -0
- package/zh/intlayer_with_vite+react.md +1577 -0
- package/zh/intlayer_with_vite+solid.md +3 -0
- package/zh/intlayer_with_vite+svelte.md +3 -0
- package/zh/intlayer_with_vite+vue.md +988 -0
- package/zh/introduction.md +186 -0
- package/zh/mcp_server.md +152 -0
- package/zh/packages/@intlayer/api/index.md +31 -0
- package/zh/packages/@intlayer/chokidar/index.md +31 -0
- package/zh/packages/@intlayer/cli/index.md +21 -0
- package/zh/packages/@intlayer/config/index.md +116 -0
- package/zh/packages/@intlayer/core/index.md +25 -0
- package/zh/packages/@intlayer/design-system/index.md +21 -0
- package/zh/packages/@intlayer/dictionary-entry/index.md +21 -0
- package/zh/packages/@intlayer/editor/index.md +21 -0
- package/zh/packages/@intlayer/editor-react/index.md +21 -0
- package/zh/packages/@intlayer/webpack/index.md +35 -0
- package/zh/packages/angular-intlayer/index.md +3 -0
- package/zh/packages/express-intlayer/index.md +229 -0
- package/zh/packages/express-intlayer/t.md +432 -0
- package/zh/packages/intlayer/getConfiguration.md +120 -0
- package/zh/packages/intlayer/getEnumeration.md +140 -0
- package/zh/packages/intlayer/getHTMLTextDir.md +97 -0
- package/zh/packages/intlayer/getLocaleLang.md +57 -0
- package/zh/packages/intlayer/getLocaleName.md +93 -0
- package/zh/packages/intlayer/getLocalizedUrl.md +221 -0
- package/zh/packages/intlayer/getMultilingualUrls.md +198 -0
- package/zh/packages/intlayer/getPathWithoutLocale.md +50 -0
- package/zh/packages/intlayer/getTranslation.md +166 -0
- package/zh/packages/intlayer/getTranslationContent.md +166 -0
- package/zh/packages/intlayer/index.md +360 -0
- package/zh/packages/intlayer-cli/index.md +41 -0
- package/zh/packages/intlayer-editor/index.md +113 -0
- package/zh/packages/lynx-intlayer/index.md +60 -0
- package/zh/packages/next-intlayer/index.md +267 -0
- package/zh/packages/next-intlayer/t.md +338 -0
- package/zh/packages/next-intlayer/useDictionary.md +242 -0
- package/zh/packages/next-intlayer/useIntlayer.md +237 -0
- package/zh/packages/next-intlayer/useIntlayerAsync.md +211 -0
- package/zh/packages/next-intlayer/useLocale.md +105 -0
- package/zh/packages/preact-intlayer/index.md +3 -0
- package/zh/packages/react-intlayer/index.md +257 -0
- package/zh/packages/react-intlayer/t.md +271 -0
- package/zh/packages/react-intlayer/useDictionary.md +260 -0
- package/zh/packages/react-intlayer/useIntlayer.md +225 -0
- package/zh/packages/react-intlayer/useIntlayerAsync.md +226 -0
- package/zh/packages/react-intlayer/useLocale.md +184 -0
- package/zh/packages/react-native-intlayer/index.md +57 -0
- package/zh/packages/react-scripts-intlayer/index.md +57 -0
- package/zh/packages/solid-intlayer/index.md +3 -0
- package/zh/packages/svelte-intlayer/index.md +3 -0
- package/zh/packages/vite-intlayer/index.md +53 -0
- package/zh/packages/vue-intlayer/index.md +3 -0
- package/zh/per_locale_file.md +298 -0
- package/zh/privacy_notice.md +61 -0
- package/zh/roadmap.md +206 -0
- package/zh/terms_of_service.md +33 -0
- package/zh/vs_code_extension.md +139 -0
|
@@ -0,0 +1,1192 @@
|
|
|
1
|
+
# Démarrage avec l'internationalisation (i18n) avec Intlayer et React Create App
|
|
2
|
+
|
|
3
|
+
Voir [Application Template](https://github.com/aymericzip/intlayer-react-cra-template) sur GitHub.
|
|
4
|
+
|
|
5
|
+
## Qu'est-ce qu'Intlayer ?
|
|
6
|
+
|
|
7
|
+
**Intlayer** est une bibliothèque open-source innovante d'internationalisation (i18n) conçue pour simplifier la prise en charge multilingue dans les applications web modernes.
|
|
8
|
+
|
|
9
|
+
Avec Intlayer, vous pouvez :
|
|
10
|
+
|
|
11
|
+
- **Gérer facilement les traductions** en utilisant des dictionnaires déclaratifs au niveau des composants.
|
|
12
|
+
- **Localiser dynamiquement les métadonnées**, les routes et le contenu.
|
|
13
|
+
- **Assurer la prise en charge de TypeScript** avec des types générés automatiquement, améliorant l'autocomplétion et la détection des erreurs.
|
|
14
|
+
- **Bénéficier de fonctionnalités avancées**, comme la détection et le changement dynamiques de locale.
|
|
15
|
+
|
|
16
|
+
## Guide étape par étape pour configurer Intlayer dans une application React
|
|
17
|
+
|
|
18
|
+
### Étape 1 : Installer les dépendances
|
|
19
|
+
|
|
20
|
+
Installez les packages nécessaires en utilisant npm :
|
|
21
|
+
|
|
22
|
+
```bash packageManager="npm"
|
|
23
|
+
npm install intlayer react-intlayer react-scripts-intlayer
|
|
24
|
+
```
|
|
25
|
+
|
|
26
|
+
```bash packageManager="pnpm"
|
|
27
|
+
pnpm add intlayer react-intlayer react-scripts-intlayer
|
|
28
|
+
```
|
|
29
|
+
|
|
30
|
+
```bash packageManager="yarn"
|
|
31
|
+
yarn add intlayer react-intlayer react-scripts-intlayer
|
|
32
|
+
```
|
|
33
|
+
|
|
34
|
+
- **intlayer**
|
|
35
|
+
|
|
36
|
+
Le package principal qui fournit des outils d'internationalisation pour la gestion de configuration, la traduction, [la déclaration de contenu](https://github.com/aymericzip/intlayer/blob/main/docs/fr/dictionary/get_started.md), la transpilation et les [commandes CLI](https://github.com/aymericzip/intlayer/blob/main/docs/fr/intlayer_cli.md).
|
|
37
|
+
|
|
38
|
+
- **react-intlayer**
|
|
39
|
+
|
|
40
|
+
Le package qui intègre Intlayer avec une application React. Il fournit des fournisseurs de contexte et des hooks pour l'internationalisation dans React.
|
|
41
|
+
|
|
42
|
+
- **react-scripts-intlayer**
|
|
43
|
+
|
|
44
|
+
Inclut les commandes et plugins `react-scripts-intlayer` pour intégrer Intlayer avec une application basée sur Create React App. Ces plugins sont basés sur [craco](https://craco.js.org/) et incluent une configuration supplémentaire pour le bundler [Webpack](https://webpack.js.org/).
|
|
45
|
+
|
|
46
|
+
### Étape 2 : Configuration de votre projet
|
|
47
|
+
|
|
48
|
+
Créez un fichier de configuration pour configurer les langues de votre application :
|
|
49
|
+
|
|
50
|
+
```typescript fileName="intlayer.config.ts" codeFormat="typescript"
|
|
51
|
+
import { Locales, type IntlayerConfig } from "intlayer";
|
|
52
|
+
|
|
53
|
+
const config: IntlayerConfig = {
|
|
54
|
+
internationalisation: {
|
|
55
|
+
locales: [
|
|
56
|
+
Locales.ENGLISH,
|
|
57
|
+
Locales.FRENCH,
|
|
58
|
+
Locales.SPANISH,
|
|
59
|
+
// Vos autres locales
|
|
60
|
+
],
|
|
61
|
+
defaultLocale: Locales.ENGLISH,
|
|
62
|
+
},
|
|
63
|
+
};
|
|
64
|
+
|
|
65
|
+
export default config;
|
|
66
|
+
```
|
|
67
|
+
|
|
68
|
+
```javascript fileName="intlayer.config.mjs" codeFormat="esm"
|
|
69
|
+
import { Locales } from "intlayer";
|
|
70
|
+
|
|
71
|
+
/** @type {import('intlayer').IntlayerConfig} */
|
|
72
|
+
const config = {
|
|
73
|
+
internationalisation: {
|
|
74
|
+
locales: [
|
|
75
|
+
Locales.ENGLISH,
|
|
76
|
+
Locales.FRENCH,
|
|
77
|
+
Locales.SPANISH,
|
|
78
|
+
// Vos autres locales
|
|
79
|
+
],
|
|
80
|
+
defaultLocale: Locales.ENGLISH,
|
|
81
|
+
},
|
|
82
|
+
};
|
|
83
|
+
|
|
84
|
+
export default config;
|
|
85
|
+
```
|
|
86
|
+
|
|
87
|
+
```javascript fileName="intlayer.config.cjs" codeFormat="commonjs"
|
|
88
|
+
const { Locales } = require("intlayer");
|
|
89
|
+
|
|
90
|
+
/** @type {import('intlayer').IntlayerConfig} */
|
|
91
|
+
const config = {
|
|
92
|
+
internationalisation: {
|
|
93
|
+
locales: [
|
|
94
|
+
Locales.ENGLISH,
|
|
95
|
+
Locales.FRENCH,
|
|
96
|
+
Locales.SPANISH,
|
|
97
|
+
// Vos autres locales
|
|
98
|
+
],
|
|
99
|
+
defaultLocale: Locales.ENGLISH,
|
|
100
|
+
},
|
|
101
|
+
};
|
|
102
|
+
|
|
103
|
+
module.exports = config;
|
|
104
|
+
```
|
|
105
|
+
|
|
106
|
+
> Grâce à ce fichier de configuration, vous pouvez configurer des URL localisées, des redirections middleware, des noms de cookies, l'emplacement et l'extension de vos déclarations de contenu, désactiver les logs Intlayer dans la console, et plus encore. Pour une liste complète des paramètres disponibles, consultez la [documentation de configuration](https://github.com/aymericzip/intlayer/blob/main/docs/fr/configuration.md).
|
|
107
|
+
|
|
108
|
+
### Étape 3 : Intégrer Intlayer dans votre configuration CRA
|
|
109
|
+
|
|
110
|
+
Modifiez vos scripts pour utiliser react-intlayer
|
|
111
|
+
|
|
112
|
+
```json fileName="package.json"
|
|
113
|
+
"scripts": {
|
|
114
|
+
"build": "react-scripts-intlayer build",
|
|
115
|
+
"start": "react-scripts-intlayer start",
|
|
116
|
+
"transpile": "intlayer build"
|
|
117
|
+
},
|
|
118
|
+
```
|
|
119
|
+
|
|
120
|
+
> Les scripts `react-scripts-intlayer` sont basés sur [CRACO](https://craco.js.org/). Vous pouvez également implémenter votre propre configuration basée sur le plugin craco d'intlayer. [Voir un exemple ici](https://github.com/aymericzip/intlayer/blob/main/examples/react-app/craco.config.js).
|
|
121
|
+
|
|
122
|
+
### Étape 4 : Déclarez votre contenu
|
|
123
|
+
|
|
124
|
+
Créez et gérez vos déclarations de contenu pour stocker les traductions :
|
|
125
|
+
|
|
126
|
+
```tsx fileName="src/app.content.tsx" codeFormat="typescript"
|
|
127
|
+
import { t, type Dictionary } from "intlayer";
|
|
128
|
+
import React, { type ReactNode } from "react";
|
|
129
|
+
|
|
130
|
+
const appContent = {
|
|
131
|
+
key: "app",
|
|
132
|
+
content: {
|
|
133
|
+
getStarted: t<ReactNode>({
|
|
134
|
+
en: (
|
|
135
|
+
<>
|
|
136
|
+
Edit <code>src/App.tsx</code> and save to reload
|
|
137
|
+
</>
|
|
138
|
+
),
|
|
139
|
+
fr: (
|
|
140
|
+
<>
|
|
141
|
+
Éditez <code>src/App.tsx</code> et enregistrez pour recharger
|
|
142
|
+
</>
|
|
143
|
+
),
|
|
144
|
+
es: (
|
|
145
|
+
<>
|
|
146
|
+
Edita <code>src/App.tsx</code> y guarda para recargar
|
|
147
|
+
</>
|
|
148
|
+
),
|
|
149
|
+
}),
|
|
150
|
+
reactLink: {
|
|
151
|
+
href: "https://reactjs.org",
|
|
152
|
+
content: t({
|
|
153
|
+
en: "Learn React",
|
|
154
|
+
fr: "Apprendre React",
|
|
155
|
+
es: "Aprender React",
|
|
156
|
+
}),
|
|
157
|
+
},
|
|
158
|
+
},
|
|
159
|
+
} satisfies Dictionary;
|
|
160
|
+
|
|
161
|
+
export default appContent;
|
|
162
|
+
```
|
|
163
|
+
|
|
164
|
+
```jsx fileName="src/app.content.mjx" codeFormat="esm"
|
|
165
|
+
import { t } from "intlayer";
|
|
166
|
+
|
|
167
|
+
/** @type {import('intlayer').Dictionary} */
|
|
168
|
+
const appContent = {
|
|
169
|
+
key: "app",
|
|
170
|
+
content: {
|
|
171
|
+
getStarted: t({
|
|
172
|
+
en: "Get started by editing",
|
|
173
|
+
fr: "Commencez par éditer",
|
|
174
|
+
es: "Comience por editar",
|
|
175
|
+
}),
|
|
176
|
+
reactLink: {
|
|
177
|
+
href: "https://reactjs.org",
|
|
178
|
+
content: t({
|
|
179
|
+
en: "Learn React",
|
|
180
|
+
fr: "Apprendre React",
|
|
181
|
+
es: "Aprender React",
|
|
182
|
+
}),
|
|
183
|
+
},
|
|
184
|
+
},
|
|
185
|
+
};
|
|
186
|
+
|
|
187
|
+
export default appContent;
|
|
188
|
+
```
|
|
189
|
+
|
|
190
|
+
```jsx fileName="src/app.content.csx" codeFormat="commonjs"
|
|
191
|
+
const { t } = require("intlayer");
|
|
192
|
+
|
|
193
|
+
/** @type {import('intlayer').Dictionary} */
|
|
194
|
+
const appContent = {
|
|
195
|
+
key: "app",
|
|
196
|
+
content: {
|
|
197
|
+
getStarted: t({
|
|
198
|
+
en: "Get started by editing",
|
|
199
|
+
fr: "Commencez par éditer",
|
|
200
|
+
es: "Comience por editar",
|
|
201
|
+
}),
|
|
202
|
+
reactLink: {
|
|
203
|
+
href: "https://reactjs.org",
|
|
204
|
+
content: t({
|
|
205
|
+
en: "Learn React",
|
|
206
|
+
fr: "Apprendre React",
|
|
207
|
+
es: "Aprender React",
|
|
208
|
+
}),
|
|
209
|
+
},
|
|
210
|
+
},
|
|
211
|
+
};
|
|
212
|
+
|
|
213
|
+
module.exports = appContent;
|
|
214
|
+
```
|
|
215
|
+
|
|
216
|
+
> Vos déclarations de contenu peuvent être définies n'importe où dans votre application tant qu'elles sont incluses dans le répertoire `contentDir` (par défaut, `./src`). Et correspondent à l'extension de fichier de déclaration de contenu (par défaut, `.content.{json,ts,tsx,js,jsx,mjs,mjx,cjs,cjx}`).
|
|
217
|
+
|
|
218
|
+
> Pour plus de détails, consultez la [documentation sur les déclarations de contenu](https://github.com/aymericzip/intlayer/blob/main/docs/fr/dictionary/get_started.md).
|
|
219
|
+
|
|
220
|
+
> Si votre fichier de contenu inclut du code TSX, vous devriez envisager d'importer `import React from "react";` dans votre fichier de contenu.
|
|
221
|
+
|
|
222
|
+
### Étape 5 : Utilisez Intlayer dans votre code
|
|
223
|
+
|
|
224
|
+
Accédez à vos dictionnaires de contenu dans toute votre application :
|
|
225
|
+
|
|
226
|
+
```tsx {4,7} fileName="src/App.tsx" codeFormat="typescript"
|
|
227
|
+
import logo from "./logo.svg";
|
|
228
|
+
import "./App.css";
|
|
229
|
+
import type { FC } from "react";
|
|
230
|
+
import { IntlayerProvider, useIntlayer } from "react-intlayer";
|
|
231
|
+
|
|
232
|
+
const AppContent: FC = () => {
|
|
233
|
+
const content = useIntlayer("app");
|
|
234
|
+
|
|
235
|
+
return (
|
|
236
|
+
<div className="App">
|
|
237
|
+
<img src={logo} className="App-logo" alt="logo" />
|
|
238
|
+
|
|
239
|
+
{content.getStarted}
|
|
240
|
+
<a
|
|
241
|
+
className="App-link"
|
|
242
|
+
href={content.reactLink.href.value}
|
|
243
|
+
target="_blank"
|
|
244
|
+
rel="noopener noreferrer"
|
|
245
|
+
>
|
|
246
|
+
{content.reactLink.content}
|
|
247
|
+
</a>
|
|
248
|
+
</div>
|
|
249
|
+
);
|
|
250
|
+
};
|
|
251
|
+
|
|
252
|
+
const App: FC = () => (
|
|
253
|
+
<IntlayerProvider>
|
|
254
|
+
<AppContent />
|
|
255
|
+
</IntlayerProvider>
|
|
256
|
+
);
|
|
257
|
+
|
|
258
|
+
export default App;
|
|
259
|
+
```
|
|
260
|
+
|
|
261
|
+
```jsx {3,6} fileName="src/App.mjx" codeFormat="esm"
|
|
262
|
+
import "./App.css";
|
|
263
|
+
import logo from "./logo.svg";
|
|
264
|
+
import { IntlayerProvider, useIntlayer } from "react-intlayer";
|
|
265
|
+
|
|
266
|
+
const AppContent = () => {
|
|
267
|
+
const content = useIntlayer("app");
|
|
268
|
+
|
|
269
|
+
return (
|
|
270
|
+
<div className="App">
|
|
271
|
+
<img src={logo} className="App-logo" alt="logo" />
|
|
272
|
+
|
|
273
|
+
{content.getStarted}
|
|
274
|
+
<a
|
|
275
|
+
className="App-link"
|
|
276
|
+
href={content.reactLink.href.value}
|
|
277
|
+
target="_blank"
|
|
278
|
+
rel="noopener noreferrer"
|
|
279
|
+
>
|
|
280
|
+
{content.reactLink.content}
|
|
281
|
+
</a>
|
|
282
|
+
</div>
|
|
283
|
+
);
|
|
284
|
+
};
|
|
285
|
+
|
|
286
|
+
const App = () => (
|
|
287
|
+
<IntlayerProvider>
|
|
288
|
+
<AppContent />
|
|
289
|
+
</IntlayerProvider>
|
|
290
|
+
);
|
|
291
|
+
```
|
|
292
|
+
|
|
293
|
+
```jsx {3,6} fileName="src/App.csx" codeFormat="commonjs"
|
|
294
|
+
require("./App.css");
|
|
295
|
+
const logo = require("./logo.svg");
|
|
296
|
+
const { IntlayerProvider, useIntlayer } = require("react-intlayer");
|
|
297
|
+
|
|
298
|
+
const AppContent = () => {
|
|
299
|
+
const content = useIntlayer("app");
|
|
300
|
+
|
|
301
|
+
return (
|
|
302
|
+
<div className="App">
|
|
303
|
+
<img src={logo} className="App-logo" alt="logo" />
|
|
304
|
+
|
|
305
|
+
{content.getStarted}
|
|
306
|
+
<a
|
|
307
|
+
className="App-link"
|
|
308
|
+
href={content.reactLink.href.value}
|
|
309
|
+
target="_blank"
|
|
310
|
+
rel="noopener noreferrer"
|
|
311
|
+
>
|
|
312
|
+
{content.reactLink.content}
|
|
313
|
+
</a>
|
|
314
|
+
</div>
|
|
315
|
+
);
|
|
316
|
+
};
|
|
317
|
+
|
|
318
|
+
const App = () => (
|
|
319
|
+
<IntlayerProvider>
|
|
320
|
+
<AppContent />
|
|
321
|
+
</IntlayerProvider>
|
|
322
|
+
);
|
|
323
|
+
```
|
|
324
|
+
|
|
325
|
+
> Remarque : Si vous souhaitez utiliser votre contenu dans un attribut `string`, tel que `alt`, `title`, `href`, `aria-label`, etc., vous devez appeler la valeur de la fonction, comme :
|
|
326
|
+
|
|
327
|
+
> ```jsx
|
|
328
|
+
>
|
|
329
|
+
> ```
|
|
330
|
+
|
|
331
|
+
> <img src={content.image.src.value} alt={content.image.value} />
|
|
332
|
+
|
|
333
|
+
> ```
|
|
334
|
+
>
|
|
335
|
+
> ```
|
|
336
|
+
|
|
337
|
+
> Pour en savoir plus sur le hook `useIntlayer`, consultez la [documentation](https://github.com/aymericzip/intlayer/blob/main/docs/fr/packages/react-intlayer/useIntlayer.md).
|
|
338
|
+
|
|
339
|
+
### (Optionnel) Étape 6 : Changer la langue de votre contenu
|
|
340
|
+
|
|
341
|
+
Pour changer la langue de votre contenu, vous pouvez utiliser la fonction `setLocale` fournie par le hook `useLocale`. Cette fonction vous permet de définir la locale de l'application et de mettre à jour le contenu en conséquence.
|
|
342
|
+
|
|
343
|
+
```tsx fileName="src/components/LocaleSwitcher.tsx" codeFormat="typescript"
|
|
344
|
+
import { Locales } from "intlayer";
|
|
345
|
+
import { useLocale } from "react-intlayer";
|
|
346
|
+
|
|
347
|
+
const LocaleSwitcher = () => {
|
|
348
|
+
const { setLocale } = useLocale();
|
|
349
|
+
|
|
350
|
+
return (
|
|
351
|
+
<button onClick={() => setLocale(Locales.English)}>
|
|
352
|
+
Changer la langue en anglais
|
|
353
|
+
</button>
|
|
354
|
+
);
|
|
355
|
+
};
|
|
356
|
+
```
|
|
357
|
+
|
|
358
|
+
```jsx fileName="src/components/LocaleSwitcher.mjx" codeFormat="esm"
|
|
359
|
+
import { Locales } from "intlayer";
|
|
360
|
+
import { useLocale } from "react-intlayer";
|
|
361
|
+
|
|
362
|
+
const LocaleSwitcher = () => {
|
|
363
|
+
const { setLocale } = useLocale();
|
|
364
|
+
|
|
365
|
+
return (
|
|
366
|
+
<button onClick={() => setLocale(Locales.English)}>
|
|
367
|
+
Changer la langue en anglais
|
|
368
|
+
</button>
|
|
369
|
+
);
|
|
370
|
+
};
|
|
371
|
+
```
|
|
372
|
+
|
|
373
|
+
```jsx fileName="src/components/LocaleSwitcher.csx" codeFormat="commonjs"
|
|
374
|
+
const { Locales } = require("intlayer");
|
|
375
|
+
const { useLocale } = require("react-intlayer");
|
|
376
|
+
|
|
377
|
+
const LocaleSwitcher = () => {
|
|
378
|
+
const { setLocale } = useLocale();
|
|
379
|
+
|
|
380
|
+
return (
|
|
381
|
+
<button onClick={() => setLocale(Locales.English)}>
|
|
382
|
+
Changer la langue en anglais
|
|
383
|
+
</button>
|
|
384
|
+
);
|
|
385
|
+
};
|
|
386
|
+
```
|
|
387
|
+
|
|
388
|
+
> Pour en savoir plus sur le hook `useLocale`, consultez la [documentation](https://github.com/aymericzip/intlayer/blob/main/docs/fr/packages/react-intlayer/useLocale.md).
|
|
389
|
+
|
|
390
|
+
### (Optionnel) Étape 7 : Ajouter un routage localisé à votre application
|
|
391
|
+
|
|
392
|
+
L'objectif de cette étape est de créer des routes uniques pour chaque langue. Cela est utile pour le SEO et les URL conviviales pour les moteurs de recherche.
|
|
393
|
+
Exemple :
|
|
394
|
+
|
|
395
|
+
```plaintext
|
|
396
|
+
- https://example.com/about
|
|
397
|
+
- https://example.com/es/about
|
|
398
|
+
- https://example.com/fr/about
|
|
399
|
+
```
|
|
400
|
+
|
|
401
|
+
> Par défaut, les routes ne sont pas préfixées pour la locale par défaut. Si vous souhaitez préfixer la locale par défaut, vous pouvez définir l'option `middleware.prefixDefault` sur `true` dans votre configuration. Consultez la [documentation de configuration](https://github.com/aymericzip/intlayer/blob/main/docs/fr/configuration.md) pour plus d'informations.
|
|
402
|
+
|
|
403
|
+
Pour ajouter un routage localisé à votre application, vous pouvez créer un composant `LocaleRouter` qui enveloppe les routes de votre application et gère le routage basé sur la locale. Voici un exemple utilisant [React Router](https://reactrouter.com/home):
|
|
404
|
+
|
|
405
|
+
```tsx fileName="src/components/LocaleRouter.tsx" codeFormat="typescript"
|
|
406
|
+
// Importation des dépendances nécessaires et des fonctions
|
|
407
|
+
import { type Locales, configuration, getPathWithoutLocale } from "intlayer"; // Fonctions utilitaires et types d'intlayer
|
|
408
|
+
import type { FC, PropsWithChildren } from "react"; // Types React pour les composants fonctionnels et les props
|
|
409
|
+
import { IntlayerProvider } from "react-intlayer"; // Fournisseur pour le contexte d'internationalisation
|
|
410
|
+
import {
|
|
411
|
+
BrowserRouter,
|
|
412
|
+
Routes,
|
|
413
|
+
Route,
|
|
414
|
+
Navigate,
|
|
415
|
+
useLocation,
|
|
416
|
+
} from "react-router-dom"; // Composants de routage pour gérer la navigation
|
|
417
|
+
|
|
418
|
+
// Déstructuration de la configuration depuis Intlayer
|
|
419
|
+
const { internationalisation, middleware } = getConfiguration();
|
|
420
|
+
const { locales, defaultLocale } = internationalisation;
|
|
421
|
+
|
|
422
|
+
/**
|
|
423
|
+
* Un composant qui gère la localisation et enveloppe les enfants avec le contexte de locale approprié.
|
|
424
|
+
* Il gère la détection et la validation basées sur l'URL.
|
|
425
|
+
*/
|
|
426
|
+
const AppLocalized: FC<PropsWithChildren<{ locale: Locales }>> = ({
|
|
427
|
+
children,
|
|
428
|
+
locale,
|
|
429
|
+
}) => {
|
|
430
|
+
const { pathname, search } = useLocation(); // Obtenez le chemin URL actuel
|
|
431
|
+
|
|
432
|
+
// Déterminez la locale actuelle, en revenant à la locale par défaut si elle n'est pas fournie
|
|
433
|
+
const currentLocale = locale ?? defaultLocale;
|
|
434
|
+
|
|
435
|
+
// Supprimez le préfixe de locale du chemin pour construire un chemin de base
|
|
436
|
+
const pathWithoutLocale = getPathWithoutLocale(
|
|
437
|
+
pathname // Chemin URL actuel
|
|
438
|
+
);
|
|
439
|
+
|
|
440
|
+
/**
|
|
441
|
+
* Si middleware.prefixDefault est vrai, la locale par défaut doit toujours être préfixée.
|
|
442
|
+
*/
|
|
443
|
+
if (middleware.prefixDefault) {
|
|
444
|
+
// Validez la locale
|
|
445
|
+
if (!locale || !locales.includes(locale)) {
|
|
446
|
+
// Redirigez vers la locale par défaut avec le chemin mis à jour
|
|
447
|
+
return (
|
|
448
|
+
<Navigate
|
|
449
|
+
to={`/${defaultLocale}/${pathWithoutLocale}${search}`}
|
|
450
|
+
replace // Remplacez l'entrée actuelle de l'historique par la nouvelle
|
|
451
|
+
/>
|
|
452
|
+
);
|
|
453
|
+
}
|
|
454
|
+
|
|
455
|
+
// Enveloppez les enfants avec le fournisseur Intlayer et définissez la locale actuelle
|
|
456
|
+
return (
|
|
457
|
+
<IntlayerProvider locale={currentLocale}>{children}</IntlayerProvider>
|
|
458
|
+
);
|
|
459
|
+
} else {
|
|
460
|
+
/**
|
|
461
|
+
* Lorsque middleware.prefixDefault est faux, la locale par défaut n'est pas préfixée.
|
|
462
|
+
* Assurez-vous que la locale actuelle est valide et n'est pas la locale par défaut.
|
|
463
|
+
*/
|
|
464
|
+
if (
|
|
465
|
+
currentLocale.toString() !== defaultLocale.toString() &&
|
|
466
|
+
!locales
|
|
467
|
+
.filter(
|
|
468
|
+
(locale) => locale.toString() !== defaultLocale.toString() // Excluez la locale par défaut
|
|
469
|
+
)
|
|
470
|
+
.includes(currentLocale) // Vérifiez si la locale actuelle est dans la liste des locales valides
|
|
471
|
+
) {
|
|
472
|
+
// Redirigez vers le chemin sans préfixe de locale
|
|
473
|
+
return <Navigate to={`${pathWithoutLocale}${search}`} replace />;
|
|
474
|
+
}
|
|
475
|
+
|
|
476
|
+
// Enveloppez les enfants avec le fournisseur Intlayer et définissez la locale actuelle
|
|
477
|
+
return (
|
|
478
|
+
<IntlayerProvider locale={currentLocale}>{children}</IntlayerProvider>
|
|
479
|
+
);
|
|
480
|
+
}
|
|
481
|
+
};
|
|
482
|
+
|
|
483
|
+
/**
|
|
484
|
+
* Un composant de routage qui configure des routes spécifiques à la locale.
|
|
485
|
+
* Il utilise React Router pour gérer la navigation et rendre les composants localisés.
|
|
486
|
+
*/
|
|
487
|
+
export const LocaleRouter: FC<PropsWithChildren> = ({ children }) => (
|
|
488
|
+
<BrowserRouter>
|
|
489
|
+
<Routes>
|
|
490
|
+
{locales
|
|
491
|
+
.filter(
|
|
492
|
+
(locale) => middleware.prefixDefault || locale !== defaultLocale
|
|
493
|
+
)
|
|
494
|
+
.map((locale) => (
|
|
495
|
+
<Route
|
|
496
|
+
// Modèle de route pour capturer la locale (par ex., /en/, /fr/) et correspondre à tous les chemins suivants
|
|
497
|
+
path={`/${locale}/*`}
|
|
498
|
+
key={locale}
|
|
499
|
+
element={<AppLocalized locale={locale}>{children}</AppLocalized>} // Enveloppe les enfants avec la gestion de locale
|
|
500
|
+
/>
|
|
501
|
+
))}
|
|
502
|
+
|
|
503
|
+
{
|
|
504
|
+
// Si le préfixage de la locale par défaut est désactivé, rendez les enfants directement à la racine
|
|
505
|
+
!middleware.prefixDefault && (
|
|
506
|
+
<Route
|
|
507
|
+
path="*"
|
|
508
|
+
element={
|
|
509
|
+
<AppLocalized locale={defaultLocale}>{children}</AppLocalized>
|
|
510
|
+
} // Enveloppe les enfants avec la gestion de locale
|
|
511
|
+
/>
|
|
512
|
+
)
|
|
513
|
+
}
|
|
514
|
+
</Routes>
|
|
515
|
+
</BrowserRouter>
|
|
516
|
+
);
|
|
517
|
+
```
|
|
518
|
+
|
|
519
|
+
```jsx fileName="src/components/LocaleRouter.mjx" codeFormat="esm"
|
|
520
|
+
// Importation des dépendances nécessaires et des fonctions
|
|
521
|
+
import { configuration, getPathWithoutLocale } from "intlayer"; // Fonctions utilitaires et types d'intlayer
|
|
522
|
+
import { IntlayerProvider } from "react-intlayer"; // Fournisseur pour le contexte d'internationalisation
|
|
523
|
+
import {
|
|
524
|
+
BrowserRouter,
|
|
525
|
+
Routes,
|
|
526
|
+
Route,
|
|
527
|
+
Navigate,
|
|
528
|
+
useLocation,
|
|
529
|
+
} from "react-router-dom"; // Composants de routage pour gérer la navigation
|
|
530
|
+
|
|
531
|
+
// Déstructuration de la configuration depuis Intlayer
|
|
532
|
+
const { internationalisation, middleware } = getConfiguration();
|
|
533
|
+
const { locales, defaultLocale } = internationalisation;
|
|
534
|
+
|
|
535
|
+
/**
|
|
536
|
+
* Un composant qui gère la localisation et enveloppe les enfants avec le contexte de locale approprié.
|
|
537
|
+
* Il gère la détection et la validation basées sur l'URL.
|
|
538
|
+
*/
|
|
539
|
+
const AppLocalized = ({ children, locale }) => {
|
|
540
|
+
const { pathname, search } = useLocation(); // Obtenez le chemin URL actuel
|
|
541
|
+
|
|
542
|
+
// Déterminez la locale actuelle, en revenant à la locale par défaut si elle n'est pas fournie
|
|
543
|
+
const currentLocale = locale ?? defaultLocale;
|
|
544
|
+
|
|
545
|
+
// Supprimez le préfixe de locale du chemin pour construire un chemin de base
|
|
546
|
+
const pathWithoutLocale = getPathWithoutLocale(
|
|
547
|
+
pathname // Chemin URL actuel
|
|
548
|
+
);
|
|
549
|
+
|
|
550
|
+
/**
|
|
551
|
+
* Si middleware.prefixDefault est vrai, la locale par défaut doit toujours être préfixée.
|
|
552
|
+
*/
|
|
553
|
+
if (middleware.prefixDefault) {
|
|
554
|
+
// Validez la locale
|
|
555
|
+
if (!locale || !locales.includes(locale)) {
|
|
556
|
+
// Redirigez vers la locale par défaut avec le chemin mis à jour
|
|
557
|
+
return (
|
|
558
|
+
<Navigate
|
|
559
|
+
to={`/${defaultLocale}/${pathWithoutLocale}${search}`}
|
|
560
|
+
replace // Remplacez l'entrée actuelle de l'historique par la nouvelle
|
|
561
|
+
/>
|
|
562
|
+
);
|
|
563
|
+
}
|
|
564
|
+
|
|
565
|
+
// Enveloppez les enfants avec le fournisseur Intlayer et définissez la locale actuelle
|
|
566
|
+
return (
|
|
567
|
+
<IntlayerProvider locale={currentLocale}>{children}</IntlayerProvider>
|
|
568
|
+
);
|
|
569
|
+
} else {
|
|
570
|
+
/**
|
|
571
|
+
* Lorsque middleware.prefixDefault est faux, la locale par défaut n'est pas préfixée.
|
|
572
|
+
* Assurez-vous que la locale actuelle est valide et n'est pas la locale par défaut.
|
|
573
|
+
*/
|
|
574
|
+
if (
|
|
575
|
+
currentLocale.toString() !== defaultLocale.toString() &&
|
|
576
|
+
!locales
|
|
577
|
+
.filter(
|
|
578
|
+
(locale) => locale.toString() !== defaultLocale.toString() // Excluez la locale par défaut
|
|
579
|
+
)
|
|
580
|
+
.includes(currentLocale) // Vérifiez si la locale actuelle est dans la liste des locales valides
|
|
581
|
+
) {
|
|
582
|
+
// Redirigez vers le chemin sans préfixe de locale
|
|
583
|
+
return <Navigate to={`${pathWithoutLocale}${search}`} replace />;
|
|
584
|
+
}
|
|
585
|
+
|
|
586
|
+
// Enveloppez les enfants avec le fournisseur Intlayer et définissez la locale actuelle
|
|
587
|
+
return (
|
|
588
|
+
<IntlayerProvider locale={currentLocale}>{children}</IntlayerProvider>
|
|
589
|
+
);
|
|
590
|
+
}
|
|
591
|
+
};
|
|
592
|
+
|
|
593
|
+
/**
|
|
594
|
+
* Un composant de routage qui configure des routes spécifiques à la locale.
|
|
595
|
+
* Il utilise React Router pour gérer la navigation et rendre les composants localisés.
|
|
596
|
+
*/
|
|
597
|
+
export const LocaleRouter = ({ children }) => (
|
|
598
|
+
<BrowserRouter>
|
|
599
|
+
<Routes>
|
|
600
|
+
{locales
|
|
601
|
+
.filter(
|
|
602
|
+
(locale) => middleware.prefixDefault || locale !== defaultLocale
|
|
603
|
+
)
|
|
604
|
+
.map((locale) => (
|
|
605
|
+
<Route
|
|
606
|
+
// Modèle de route pour capturer la locale (par ex., /en/, /fr/) et correspondre à tous les chemins suivants
|
|
607
|
+
path={`/${locale}/*`}
|
|
608
|
+
key={locale}
|
|
609
|
+
element={<AppLocalized locale={locale}>{children}</AppLocalized>} // Enveloppe les enfants avec la gestion de locale
|
|
610
|
+
/>
|
|
611
|
+
))}
|
|
612
|
+
|
|
613
|
+
{
|
|
614
|
+
// Si le préfixage de la locale par défaut est désactivé, rendez les enfants directement à la racine
|
|
615
|
+
!middleware.prefixDefault && (
|
|
616
|
+
<Route
|
|
617
|
+
path="*"
|
|
618
|
+
element={
|
|
619
|
+
<AppLocalized locale={defaultLocale}>{children}</AppLocalized>
|
|
620
|
+
} // Enveloppe les enfants avec la gestion de locale
|
|
621
|
+
/>
|
|
622
|
+
)
|
|
623
|
+
}
|
|
624
|
+
</Routes>
|
|
625
|
+
</BrowserRouter>
|
|
626
|
+
);
|
|
627
|
+
```
|
|
628
|
+
|
|
629
|
+
```jsx fileName="src/components/LocaleRouter.cjx" codeFormat="commonjs"
|
|
630
|
+
// Importation des dépendances nécessaires et des fonctions
|
|
631
|
+
const { configuration, getPathWithoutLocale } = require("intlayer"); // Fonctions utilitaires et types d'intlayer
|
|
632
|
+
const { IntlayerProvider, useLocale } = require("react-intlayer"); // Fournisseur pour le contexte d'internationalisation
|
|
633
|
+
const {
|
|
634
|
+
BrowserRouter,
|
|
635
|
+
Routes,
|
|
636
|
+
Route,
|
|
637
|
+
Navigate,
|
|
638
|
+
useLocation,
|
|
639
|
+
} = require("react-router-dom"); // Composants de routage pour gérer la navigation
|
|
640
|
+
|
|
641
|
+
// Déstructuration de la configuration depuis Intlayer
|
|
642
|
+
const { internationalisation, middleware } = getConfiguration();
|
|
643
|
+
const { locales, defaultLocale } = internationalisation;
|
|
644
|
+
|
|
645
|
+
/**
|
|
646
|
+
* Un composant qui gère la localisation et enveloppe les enfants avec le contexte de locale approprié.
|
|
647
|
+
* Il gère la détection et la validation basées sur l'URL.
|
|
648
|
+
*/
|
|
649
|
+
const AppLocalized = ({ children, locale }) => {
|
|
650
|
+
const { pathname, search } = useLocation(); // Obtenez le chemin URL actuel
|
|
651
|
+
|
|
652
|
+
// Déterminez la locale actuelle, en revenant à la locale par défaut si elle n'est pas fournie
|
|
653
|
+
const currentLocale = locale ?? defaultLocale;
|
|
654
|
+
|
|
655
|
+
// Supprimez le préfixe de locale du chemin pour construire un chemin de base
|
|
656
|
+
const pathWithoutLocale = getPathWithoutLocale(
|
|
657
|
+
pathname // Chemin URL actuel
|
|
658
|
+
);
|
|
659
|
+
|
|
660
|
+
/**
|
|
661
|
+
* Si middleware.prefixDefault est vrai, la locale par défaut doit toujours être préfixée.
|
|
662
|
+
*/
|
|
663
|
+
if (middleware.prefixDefault) {
|
|
664
|
+
// Validez la locale
|
|
665
|
+
if (!locale || !locales.includes(locale)) {
|
|
666
|
+
// Redirigez vers la locale par défaut avec le chemin mis à jour
|
|
667
|
+
return (
|
|
668
|
+
<Navigate
|
|
669
|
+
to={`/${defaultLocale}/${pathWithoutLocale}${search}`}
|
|
670
|
+
replace // Remplacez l'entrée actuelle de l'historique par la nouvelle
|
|
671
|
+
/>
|
|
672
|
+
);
|
|
673
|
+
}
|
|
674
|
+
|
|
675
|
+
// Enveloppez les enfants avec le fournisseur Intlayer et définissez la locale actuelle
|
|
676
|
+
return (
|
|
677
|
+
<IntlayerProvider locale={currentLocale}>{children}</IntlayerProvider>
|
|
678
|
+
);
|
|
679
|
+
} else {
|
|
680
|
+
/**
|
|
681
|
+
* Lorsque middleware.prefixDefault est faux, la locale par défaut n'est pas préfixée.
|
|
682
|
+
* Assurez-vous que la locale actuelle est valide et n'est pas la locale par défaut.
|
|
683
|
+
*/
|
|
684
|
+
if (
|
|
685
|
+
currentLocale.toString() !== defaultLocale.toString() &&
|
|
686
|
+
!locales
|
|
687
|
+
.filter(
|
|
688
|
+
(locale) => locale.toString() !== defaultLocale.toString() // Excluez la locale par défaut
|
|
689
|
+
)
|
|
690
|
+
.includes(currentLocale) // Vérifiez si la locale actuelle est dans la liste des locales valides
|
|
691
|
+
) {
|
|
692
|
+
// Redirigez vers le chemin sans préfixe de locale
|
|
693
|
+
return <Navigate to={`${pathWithoutLocale}${search}`} replace />;
|
|
694
|
+
}
|
|
695
|
+
|
|
696
|
+
// Enveloppez les enfants avec le fournisseur Intlayer et définissez la locale actuelle
|
|
697
|
+
return (
|
|
698
|
+
<IntlayerProvider locale={currentLocale}>{children}</IntlayerProvider>
|
|
699
|
+
);
|
|
700
|
+
}
|
|
701
|
+
};
|
|
702
|
+
|
|
703
|
+
/**
|
|
704
|
+
* Un composant de routage qui configure des routes spécifiques à la locale.
|
|
705
|
+
* Il utilise React Router pour gérer la navigation et rendre les composants localisés.
|
|
706
|
+
*/
|
|
707
|
+
const LocaleRouter = ({ children }) => (
|
|
708
|
+
<BrowserRouter>
|
|
709
|
+
<Routes>
|
|
710
|
+
{locales
|
|
711
|
+
.filter(
|
|
712
|
+
(locale) => middleware.prefixDefault || locale !== defaultLocale
|
|
713
|
+
)
|
|
714
|
+
.map((locale) => (
|
|
715
|
+
<Route
|
|
716
|
+
// Modèle de route pour capturer la locale (par ex., /en/, /fr/) et correspondre à tous les chemins suivants
|
|
717
|
+
path={`/${locale}/*`}
|
|
718
|
+
key={locale}
|
|
719
|
+
element={<AppLocalized locale={locale}>{children}</AppLocalized>} // Enveloppe les enfants avec la gestion de locale
|
|
720
|
+
/>
|
|
721
|
+
))}
|
|
722
|
+
|
|
723
|
+
{
|
|
724
|
+
// Si le préfixage de la locale par défaut est désactivé, rendez les enfants directement à la racine
|
|
725
|
+
!middleware.prefixDefault && (
|
|
726
|
+
<Route
|
|
727
|
+
path="*"
|
|
728
|
+
element={
|
|
729
|
+
<AppLocalized locale={defaultLocale}>{children}</AppLocalized>
|
|
730
|
+
} // Enveloppe les enfants avec la gestion de locale
|
|
731
|
+
/>
|
|
732
|
+
)
|
|
733
|
+
}
|
|
734
|
+
</Routes>
|
|
735
|
+
</BrowserRouter>
|
|
736
|
+
);
|
|
737
|
+
```
|
|
738
|
+
|
|
739
|
+
Ensuite, vous pouvez utiliser le composant `LocaleRouter` dans votre application :
|
|
740
|
+
|
|
741
|
+
```tsx fileName="src/App.tsx" codeFormat="typescript"
|
|
742
|
+
import { LocaleRouter } from "./components/LocaleRouter";
|
|
743
|
+
import type { FC } from "react";
|
|
744
|
+
|
|
745
|
+
// ... Votre composant AppContent
|
|
746
|
+
|
|
747
|
+
const App: FC = () => (
|
|
748
|
+
<LocaleRouter>
|
|
749
|
+
<AppContent />
|
|
750
|
+
</LocaleRouter>
|
|
751
|
+
);
|
|
752
|
+
```
|
|
753
|
+
|
|
754
|
+
```jsx fileName="src/App.mjx" codeFormat="esm"
|
|
755
|
+
import { LocaleRouter } from "./components/LocaleRouter";
|
|
756
|
+
|
|
757
|
+
// ... Votre composant AppContent
|
|
758
|
+
|
|
759
|
+
const App = () => (
|
|
760
|
+
<LocaleRouter>
|
|
761
|
+
<AppContent />
|
|
762
|
+
</LocaleRouter>
|
|
763
|
+
);
|
|
764
|
+
```
|
|
765
|
+
|
|
766
|
+
```jsx fileName="src/App.cjx" codeFormat="commonjs"
|
|
767
|
+
const { LocaleRouter } = require("./components/LocaleRouter");
|
|
768
|
+
|
|
769
|
+
// ... Votre composant AppContent
|
|
770
|
+
|
|
771
|
+
const App = () => (
|
|
772
|
+
<LocaleRouter>
|
|
773
|
+
<AppContent />
|
|
774
|
+
</LocaleRouter>
|
|
775
|
+
);
|
|
776
|
+
```
|
|
777
|
+
|
|
778
|
+
### (Optionnel) Étape 8 : Modifier l'URL lorsque la locale change
|
|
779
|
+
|
|
780
|
+
Pour modifier l'URL lorsque la locale change, vous pouvez utiliser la prop `onLocaleChange` fournie par le hook `useLocale`. En parallèle, vous pouvez utiliser les hooks `useLocation` et `useNavigate` de `react-router-dom` pour mettre à jour le chemin URL.
|
|
781
|
+
|
|
782
|
+
```tsx fileName="src/components/LocaleSwitcher.tsx" codeFormat="typescript"
|
|
783
|
+
import { useLocation, useNavigate } from "react-router-dom";
|
|
784
|
+
import {
|
|
785
|
+
Locales,
|
|
786
|
+
getHTMLTextDir,
|
|
787
|
+
getLocaleName,
|
|
788
|
+
getLocalizedUrl,
|
|
789
|
+
} from "intlayer";
|
|
790
|
+
import { useLocale } from "react-intlayer";
|
|
791
|
+
import { type FC } from "react";
|
|
792
|
+
|
|
793
|
+
const LocaleSwitcher: FC = () => {
|
|
794
|
+
const { pathname, search } = useLocation(); // Obtenez le chemin URL actuel. Exemple : /fr/about?foo=bar
|
|
795
|
+
const navigate = useNavigate();
|
|
796
|
+
|
|
797
|
+
const { locale, availableLocales, setLocale } = useLocale({
|
|
798
|
+
onLocaleChange: (locale) => {
|
|
799
|
+
// Construisez l'URL avec la locale mise à jour
|
|
800
|
+
// Exemple : /es/about?foo=bar
|
|
801
|
+
const pathWithLocale = getLocalizedUrl(`${pathname}${search}`, locale);
|
|
802
|
+
|
|
803
|
+
// Mettez à jour le chemin URL
|
|
804
|
+
navigate(pathWithLocale);
|
|
805
|
+
},
|
|
806
|
+
});
|
|
807
|
+
|
|
808
|
+
return (
|
|
809
|
+
<div>
|
|
810
|
+
<button popoverTarget="localePopover">{getLocaleName(locale)}</button>
|
|
811
|
+
<div id="localePopover" popover="auto">
|
|
812
|
+
{availableLocales.map((localeItem) => (
|
|
813
|
+
<a
|
|
814
|
+
href={getLocalizedUrl(location.pathname, localeItem)}
|
|
815
|
+
hrefLang={localeItem}
|
|
816
|
+
aria-current={locale === localeItem ? "page" : undefined}
|
|
817
|
+
onClick={(e) => {
|
|
818
|
+
e.preventDefault();
|
|
819
|
+
setLocale(localeItem);
|
|
820
|
+
}}
|
|
821
|
+
key={localeItem}
|
|
822
|
+
>
|
|
823
|
+
<span>
|
|
824
|
+
{/* Locale - par ex. FR */}
|
|
825
|
+
{localeItem}
|
|
826
|
+
</span>
|
|
827
|
+
<span>
|
|
828
|
+
{/* Langue dans sa propre Locale - par ex. Français */}
|
|
829
|
+
{getLocaleName(localeItem, locale)}
|
|
830
|
+
</span>
|
|
831
|
+
<span dir={getHTMLTextDir(localeItem)} lang={localeItem}>
|
|
832
|
+
{/* Langue dans la Locale actuelle - par ex. Francés avec la locale actuelle définie sur Locales.SPANISH */}
|
|
833
|
+
{getLocaleName(localeItem)}
|
|
834
|
+
</span>
|
|
835
|
+
<span dir="ltr" lang={Locales.ENGLISH}>
|
|
836
|
+
{/* Langue en anglais - par ex. French */}
|
|
837
|
+
{getLocaleName(localeItem, Locales.ENGLISH)}
|
|
838
|
+
</span>
|
|
839
|
+
</a>
|
|
840
|
+
))}
|
|
841
|
+
</div>
|
|
842
|
+
</div>
|
|
843
|
+
);
|
|
844
|
+
};
|
|
845
|
+
```
|
|
846
|
+
|
|
847
|
+
```jsx fileName="src/components/LocaleSwitcher.msx" codeFormat="esm"
|
|
848
|
+
import { useLocation, useNavigate } from "react-router-dom";
|
|
849
|
+
import {
|
|
850
|
+
Locales,
|
|
851
|
+
getHTMLTextDir,
|
|
852
|
+
getLocaleName,
|
|
853
|
+
getLocalizedUrl,
|
|
854
|
+
} from "intlayer";
|
|
855
|
+
import { useLocale } from "react-intlayer";
|
|
856
|
+
|
|
857
|
+
const LocaleSwitcher = () => {
|
|
858
|
+
const { pathname, search } = useLocation(); // Obtenez le chemin URL actuel. Exemple : /fr/about?foo=bar
|
|
859
|
+
const navigate = useNavigate();
|
|
860
|
+
|
|
861
|
+
const { locale, availableLocales, setLocale } = useLocale({
|
|
862
|
+
onLocaleChange: (locale) => {
|
|
863
|
+
// Construisez l'URL avec la locale mise à jour
|
|
864
|
+
// Exemple : /es/about?foo=bar
|
|
865
|
+
const pathWithLocale = getLocalizedUrl(`${pathname}${search}`, locale);
|
|
866
|
+
|
|
867
|
+
// Mettez à jour le chemin URL
|
|
868
|
+
navigate(pathWithLocale);
|
|
869
|
+
},
|
|
870
|
+
});
|
|
871
|
+
|
|
872
|
+
return (
|
|
873
|
+
<div>
|
|
874
|
+
<button popoverTarget="localePopover">{getLocaleName(locale)}</button>
|
|
875
|
+
<div id="localePopover" popover="auto">
|
|
876
|
+
{availableLocales.map((localeItem) => (
|
|
877
|
+
<a
|
|
878
|
+
href={getLocalizedUrl(location.pathname, localeItem)}
|
|
879
|
+
hrefLang={localeItem}
|
|
880
|
+
aria-current={locale === localeItem ? "page" : undefined}
|
|
881
|
+
onClick={(e) => {
|
|
882
|
+
e.preventDefault();
|
|
883
|
+
setLocale(localeItem);
|
|
884
|
+
}}
|
|
885
|
+
key={localeItem}
|
|
886
|
+
>
|
|
887
|
+
<span>
|
|
888
|
+
{/* Locale - par ex. FR */}
|
|
889
|
+
{localeItem}
|
|
890
|
+
</span>
|
|
891
|
+
<span>
|
|
892
|
+
{/* Langue dans sa propre Locale - par ex. Français */}
|
|
893
|
+
{getLocaleName(localeItem, locale)}
|
|
894
|
+
</span>
|
|
895
|
+
<span dir={getHTMLTextDir(localeItem)} lang={localeItem}>
|
|
896
|
+
{/* Langue dans la Locale actuelle - par ex. Francés avec la locale actuelle définie sur Locales.SPANISH */}
|
|
897
|
+
{getLocaleName(localeItem)}
|
|
898
|
+
</span>
|
|
899
|
+
<span dir="ltr" lang={Locales.ENGLISH}>
|
|
900
|
+
{/* Langue en anglais - par ex. French */}
|
|
901
|
+
{getLocaleName(localeItem, Locales.ENGLISH)}
|
|
902
|
+
</span>
|
|
903
|
+
</a>
|
|
904
|
+
))}
|
|
905
|
+
</div>
|
|
906
|
+
</div>
|
|
907
|
+
);
|
|
908
|
+
};
|
|
909
|
+
```
|
|
910
|
+
|
|
911
|
+
```jsx fileName="src/components/LocaleSwitcher.csx" codeFormat="commonjs"
|
|
912
|
+
const { useLocation, useNavigate } = require("react-router-dom");
|
|
913
|
+
const {
|
|
914
|
+
Locales,
|
|
915
|
+
getHTMLTextDir,
|
|
916
|
+
getLocaleName,
|
|
917
|
+
getLocalizedUrl,
|
|
918
|
+
} = require("intlayer");
|
|
919
|
+
const { useLocale } = require("react-intlayer");
|
|
920
|
+
|
|
921
|
+
const LocaleSwitcher = () => {
|
|
922
|
+
const { pathname, search } = useLocation(); // Obtenez le chemin URL actuel. Exemple : /fr/about?foo=bar
|
|
923
|
+
const navigate = useNavigate();
|
|
924
|
+
|
|
925
|
+
const { locale, availableLocales, setLocale } = useLocale({
|
|
926
|
+
onLocaleChange: (locale) => {
|
|
927
|
+
// Construisez l'URL avec la locale mise à jour
|
|
928
|
+
// Exemple : /es/about?foo=bar
|
|
929
|
+
const pathWithLocale = getLocalizedUrl(`${pathname}${search}`, locale);
|
|
930
|
+
|
|
931
|
+
// Mettez à jour le chemin URL
|
|
932
|
+
navigate(pathWithLocale);
|
|
933
|
+
},
|
|
934
|
+
});
|
|
935
|
+
|
|
936
|
+
return (
|
|
937
|
+
<div>
|
|
938
|
+
<button popoverTarget="localePopover">{getLocaleName(locale)}</button>
|
|
939
|
+
<div id="localePopover" popover="auto">
|
|
940
|
+
{availableLocales.map((localeItem) => (
|
|
941
|
+
<a
|
|
942
|
+
href={getLocalizedUrl(location.pathname, localeItem)}
|
|
943
|
+
hrefLang={localeItem}
|
|
944
|
+
aria-current={locale === localeItem ? "page" : undefined}
|
|
945
|
+
onClick={(e) => {
|
|
946
|
+
e.preventDefault();
|
|
947
|
+
setLocale(localeItem);
|
|
948
|
+
}}
|
|
949
|
+
key={localeItem}
|
|
950
|
+
>
|
|
951
|
+
<span>
|
|
952
|
+
{/* Locale - par ex. FR */}
|
|
953
|
+
{localeItem}
|
|
954
|
+
</span>
|
|
955
|
+
<span>
|
|
956
|
+
{/* Langue dans sa propre Locale - par ex. Français */}
|
|
957
|
+
{getLocaleName(localeItem, locale)}
|
|
958
|
+
</span>
|
|
959
|
+
<span dir={getHTMLTextDir(localeItem)} lang={localeItem}>
|
|
960
|
+
{/* Langue dans la Locale actuelle - par ex. Francés avec la locale actuelle définie sur Locales.SPANISH */}
|
|
961
|
+
{getLocaleName(localeItem)}
|
|
962
|
+
</span>
|
|
963
|
+
<span dir="ltr" lang={Locales.ENGLISH}>
|
|
964
|
+
{/* Langue en anglais - par ex. French */}
|
|
965
|
+
{getLocaleName(localeItem, Locales.ENGLISH)}
|
|
966
|
+
</span>
|
|
967
|
+
</a>
|
|
968
|
+
))}
|
|
969
|
+
</div>
|
|
970
|
+
</div>
|
|
971
|
+
);
|
|
972
|
+
};
|
|
973
|
+
```
|
|
974
|
+
|
|
975
|
+
> Références de documentation :
|
|
976
|
+
|
|
977
|
+
> - [Hook `useLocale`](https://github.com/aymericzip/intlayer/blob/main/docs/fr/packages/react-intlayer/useLocale.md)
|
|
978
|
+
|
|
979
|
+
> - [Hook `getLocaleName`](https://github.com/aymericzip/intlayer/blob/main/docs/fr/packages/intlayer/getLocaleName.md)
|
|
980
|
+
|
|
981
|
+
> - [Hook `getLocalizedUrl`](https://github.com/aymericzip/intlayer/blob/main/docs/fr/packages/intlayer/getLocalizedUrl.md)
|
|
982
|
+
|
|
983
|
+
> - [Hook `getHTMLTextDir`](https://github.com/aymericzip/intlayer/blob/main/docs/fr/packages/intlayer/getHTMLTextDir.md)
|
|
984
|
+
|
|
985
|
+
> - [Attribut `hrefLang`](https://developers.google.com/search/docs/specialty/international/localized-versions?hl=fr)
|
|
986
|
+
|
|
987
|
+
> - [Attribut `lang`](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes/lang)
|
|
988
|
+
|
|
989
|
+
> - [Attribut `dir`](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes/dir)
|
|
990
|
+
|
|
991
|
+
> - [Attribut `aria-current`](https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Attributes/aria-current)
|
|
992
|
+
|
|
993
|
+
### (Optionnel) Étape 9 : Modifier les attributs de langue et de direction HTML
|
|
994
|
+
|
|
995
|
+
Lorsque votre application prend en charge plusieurs langues, il est essentiel de mettre à jour les attributs `lang` et `dir` de la balise `<html>` pour correspondre à la locale actuelle. Cela garantit :
|
|
996
|
+
|
|
997
|
+
- **Accessibilité** : Les lecteurs d'écran et les technologies d'assistance s'appuient sur l'attribut `lang` pour prononcer et interpréter correctement le contenu.
|
|
998
|
+
- **Rendu du texte** : L'attribut `dir` (direction) garantit que le texte est rendu dans le bon ordre (par exemple, de gauche à droite pour l'anglais, de droite à gauche pour l'arabe ou l'hébreu), ce qui est essentiel pour la lisibilité.
|
|
999
|
+
- **SEO** : Les moteurs de recherche utilisent l'attribut `lang` pour déterminer la langue de votre page, aidant à fournir le bon contenu localisé dans les résultats de recherche.
|
|
1000
|
+
|
|
1001
|
+
En mettant à jour ces attributs dynamiquement lorsque la locale change, vous garantissez une expérience cohérente et accessible pour les utilisateurs dans toutes les langues prises en charge.
|
|
1002
|
+
|
|
1003
|
+
#### Implémentation du Hook
|
|
1004
|
+
|
|
1005
|
+
Créez un hook personnalisé pour gérer les attributs HTML. Le hook écoute les changements de locale et met à jour les attributs en conséquence :
|
|
1006
|
+
|
|
1007
|
+
```tsx fileName="src/hooks/useI18nHTMLAttributes.tsx" codeFormat="typescript"
|
|
1008
|
+
import { useEffect } from "react";
|
|
1009
|
+
import { useLocale } from "react-intlayer";
|
|
1010
|
+
import { getHTMLTextDir } from "intlayer";
|
|
1011
|
+
|
|
1012
|
+
/**
|
|
1013
|
+
* Met à jour les attributs `lang` et `dir` de l'élément HTML <html> en fonction de la locale actuelle.
|
|
1014
|
+
* - `lang` : Informe les navigateurs et les moteurs de recherche de la langue de la page.
|
|
1015
|
+
* - `dir` : Garantit l'ordre de lecture correct (par exemple, 'ltr' pour l'anglais, 'rtl' pour l'arabe).
|
|
1016
|
+
*
|
|
1017
|
+
* Cette mise à jour dynamique est essentielle pour un rendu de texte correct, l'accessibilité et le SEO.
|
|
1018
|
+
*/
|
|
1019
|
+
export const useI18nHTMLAttributes = () => {
|
|
1020
|
+
const { locale } = useLocale();
|
|
1021
|
+
|
|
1022
|
+
useEffect(() => {
|
|
1023
|
+
// Mettez à jour l'attribut de langue à la locale actuelle.
|
|
1024
|
+
document.documentElement.lang = locale;
|
|
1025
|
+
|
|
1026
|
+
// Définissez la direction du texte en fonction de la locale actuelle.
|
|
1027
|
+
document.documentElement.dir = getHTMLTextDir(locale);
|
|
1028
|
+
}, [locale]);
|
|
1029
|
+
};
|
|
1030
|
+
```
|
|
1031
|
+
|
|
1032
|
+
```jsx fileName="src/hooks/useI18nHTMLAttributes.msx" codeFormat="esm"
|
|
1033
|
+
import { useEffect } from "react";
|
|
1034
|
+
import { useLocale } from "react-intlayer";
|
|
1035
|
+
import { getHTMLTextDir } from "intlayer";
|
|
1036
|
+
|
|
1037
|
+
/**
|
|
1038
|
+
* Met à jour les attributs `lang` et `dir` de l'élément HTML <html> en fonction de la locale actuelle.
|
|
1039
|
+
* - `lang` : Informe les navigateurs et les moteurs de recherche de la langue de la page.
|
|
1040
|
+
* - `dir` : Garantit l'ordre de lecture correct (par exemple, 'ltr' pour l'anglais, 'rtl' pour l'arabe).
|
|
1041
|
+
*
|
|
1042
|
+
* Cette mise à jour dynamique est essentielle pour un rendu de texte correct, l'accessibilité et le SEO.
|
|
1043
|
+
*/
|
|
1044
|
+
export const useI18nHTMLAttributes = () => {
|
|
1045
|
+
const { locale } = useLocale();
|
|
1046
|
+
|
|
1047
|
+
useEffect(() => {
|
|
1048
|
+
// Mettez à jour l'attribut de langue à la locale actuelle.
|
|
1049
|
+
document.documentElement.lang = locale;
|
|
1050
|
+
|
|
1051
|
+
// Définissez la direction du texte en fonction de la locale actuelle.
|
|
1052
|
+
document.documentElement.dir = getHTMLTextDir(locale);
|
|
1053
|
+
}, [locale]);
|
|
1054
|
+
};
|
|
1055
|
+
```
|
|
1056
|
+
|
|
1057
|
+
```jsx fileName="src/hooks/useI18nHTMLAttributes.csx" codeFormat="commonjs"
|
|
1058
|
+
const { useEffect } = require("react");
|
|
1059
|
+
const { useLocale } = require("react-intlayer");
|
|
1060
|
+
const { getHTMLTextDir } = require("intlayer");
|
|
1061
|
+
|
|
1062
|
+
/**
|
|
1063
|
+
* Met à jour les attributs `lang` et `dir` de l'élément HTML <html> en fonction de la locale actuelle.
|
|
1064
|
+
* - `lang` : Informe les navigateurs et les moteurs de recherche de la langue de la page.
|
|
1065
|
+
* - `dir` : Garantit l'ordre de lecture correct (par exemple, 'ltr' pour l'anglais, 'rtl' pour l'arabe).
|
|
1066
|
+
*
|
|
1067
|
+
* Cette mise à jour dynamique est essentielle pour un rendu de texte correct, l'accessibilité et le SEO.
|
|
1068
|
+
*/
|
|
1069
|
+
const useI18nHTMLAttributes = () => {
|
|
1070
|
+
const { locale } = useLocale();
|
|
1071
|
+
|
|
1072
|
+
useEffect(() => {
|
|
1073
|
+
// Mettez à jour l'attribut de langue à la locale actuelle.
|
|
1074
|
+
document.documentElement.lang = locale;
|
|
1075
|
+
|
|
1076
|
+
// Définissez la direction du texte en fonction de la locale actuelle.
|
|
1077
|
+
document.documentElement.dir = getHTMLTextDir(locale);
|
|
1078
|
+
}, [locale]);
|
|
1079
|
+
};
|
|
1080
|
+
|
|
1081
|
+
module.exports = { useI18nHTMLAttributes };
|
|
1082
|
+
```
|
|
1083
|
+
|
|
1084
|
+
#### Utilisation du Hook dans votre application
|
|
1085
|
+
|
|
1086
|
+
Intégrez le hook dans votre composant principal afin que les attributs HTML soient mis à jour chaque fois que la locale change :
|
|
1087
|
+
|
|
1088
|
+
```tsx fileName="src/App.tsx" codeFormat="typescript"
|
|
1089
|
+
import type { FC } from "react";
|
|
1090
|
+
import { IntlayerProvider, useIntlayer } from "react-intlayer";
|
|
1091
|
+
import { useI18nHTMLAttributes } from "./hooks/useI18nHTMLAttributes";
|
|
1092
|
+
import "./App.css";
|
|
1093
|
+
|
|
1094
|
+
const AppContent: FC = () => {
|
|
1095
|
+
// Appliquez le hook pour mettre à jour les attributs lang et dir de la balise <html> en fonction de la locale.
|
|
1096
|
+
useI18nHTMLAttributes();
|
|
1097
|
+
|
|
1098
|
+
// ... Reste de votre composant
|
|
1099
|
+
};
|
|
1100
|
+
|
|
1101
|
+
const App: FC = () => (
|
|
1102
|
+
<IntlayerProvider>
|
|
1103
|
+
<AppContent />
|
|
1104
|
+
</IntlayerProvider>
|
|
1105
|
+
);
|
|
1106
|
+
|
|
1107
|
+
export default App;
|
|
1108
|
+
```
|
|
1109
|
+
|
|
1110
|
+
```jsx fileName="src/App.msx" codeFormat="esm"
|
|
1111
|
+
import { IntlayerProvider, useIntlayer } from "react-intlayer";
|
|
1112
|
+
import { useI18nHTMLAttributes } from "./hooks/useI18nHTMLAttributes";
|
|
1113
|
+
import "./App.css";
|
|
1114
|
+
|
|
1115
|
+
const AppContent = () => {
|
|
1116
|
+
// Appliquez le hook pour mettre à jour les attributs lang et dir de la balise <html> en fonction de la locale.
|
|
1117
|
+
useI18nHTMLAttributes();
|
|
1118
|
+
|
|
1119
|
+
// ... Reste de votre composant
|
|
1120
|
+
};
|
|
1121
|
+
|
|
1122
|
+
const App = () => (
|
|
1123
|
+
<IntlayerProvider>
|
|
1124
|
+
<AppContent />
|
|
1125
|
+
</IntlayerProvider>
|
|
1126
|
+
);
|
|
1127
|
+
|
|
1128
|
+
export default App;
|
|
1129
|
+
```
|
|
1130
|
+
|
|
1131
|
+
```jsx fileName="src/App.csx" codeFormat="commonjs"
|
|
1132
|
+
const { FC } = require("react");
|
|
1133
|
+
const { IntlayerProvider, useIntlayer } = require("react-intlayer");
|
|
1134
|
+
const { useI18nHTMLAttributes } = require("./hooks/useI18nHTMLAttributes");
|
|
1135
|
+
require("./App.css");
|
|
1136
|
+
|
|
1137
|
+
const AppContent = () => {
|
|
1138
|
+
// Appliquez le hook pour mettre à jour les attributs lang et dir de la balise <html> en fonction de la locale.
|
|
1139
|
+
useI18nHTMLAttributes();
|
|
1140
|
+
|
|
1141
|
+
// ... Reste de votre composant
|
|
1142
|
+
};
|
|
1143
|
+
|
|
1144
|
+
const App = () => (
|
|
1145
|
+
<IntlayerProvider>
|
|
1146
|
+
<AppContent />
|
|
1147
|
+
</IntlayerProvider>
|
|
1148
|
+
);
|
|
1149
|
+
|
|
1150
|
+
module.exports = App;
|
|
1151
|
+
```
|
|
1152
|
+
|
|
1153
|
+
En appliquant ces modifications, votre application :
|
|
1154
|
+
|
|
1155
|
+
- Garantira que l'attribut **langue** (`lang`) reflète correctement la locale actuelle, ce qui est important pour le SEO et le comportement du navigateur.
|
|
1156
|
+
- Ajustera la **direction du texte** (`dir`) en fonction de la locale, améliorant la lisibilité et l'utilisabilité pour les langues avec des ordres de lecture différents.
|
|
1157
|
+
- Fournira une expérience plus **accessible**, car les technologies d'assistance dépendent de ces attributs pour fonctionner de manière optimale.
|
|
1158
|
+
|
|
1159
|
+
### Configurer TypeScript
|
|
1160
|
+
|
|
1161
|
+
Intlayer utilise l'augmentation de module pour bénéficier de TypeScript et renforcer votre base de code.
|
|
1162
|
+
|
|
1163
|
+

|
|
1164
|
+
|
|
1165
|
+

|
|
1166
|
+
|
|
1167
|
+
Assurez-vous que votre configuration TypeScript inclut les types générés automatiquement.
|
|
1168
|
+
|
|
1169
|
+
```json5 fileName="tsconfig.json"
|
|
1170
|
+
{
|
|
1171
|
+
// ... Vos configurations TypeScript existantes
|
|
1172
|
+
"include": [
|
|
1173
|
+
// ... Vos configurations TypeScript existantes
|
|
1174
|
+
".intlayer/**/*.ts", // Inclure les types générés automatiquement
|
|
1175
|
+
],
|
|
1176
|
+
}
|
|
1177
|
+
```
|
|
1178
|
+
|
|
1179
|
+
### Configuration Git
|
|
1180
|
+
|
|
1181
|
+
Il est recommandé d'ignorer les fichiers générés par Intlayer. Cela vous permet d'éviter de les ajouter à votre dépôt Git.
|
|
1182
|
+
|
|
1183
|
+
Pour ce faire, vous pouvez ajouter les instructions suivantes à votre fichier `.gitignore` :
|
|
1184
|
+
|
|
1185
|
+
```plaintext fileName=".gitignore"
|
|
1186
|
+
# Ignorer les fichiers générés par Intlayer
|
|
1187
|
+
.intlayer
|
|
1188
|
+
```
|
|
1189
|
+
|
|
1190
|
+
### Aller plus loin
|
|
1191
|
+
|
|
1192
|
+
Pour aller plus loin, vous pouvez implémenter l'[éditeur visuel](https://github.com/aymericzip/intlayer/blob/main/docs/fr/intlayer_visual_editor.md) ou externaliser votre contenu en utilisant le [CMS](https://github.com/aymericzip/intlayer/blob/main/docs/fr/intlayer_CMS.md).
|