@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
|
+
# Comenzando con la Internacionalización (i18n) con Intlayer y React Create App
|
|
2
|
+
|
|
3
|
+
Consulta [Application Template](https://github.com/aymericzip/intlayer-react-cra-template) en GitHub.
|
|
4
|
+
|
|
5
|
+
## ¿Qué es Intlayer?
|
|
6
|
+
|
|
7
|
+
**Intlayer** es una biblioteca innovadora y de código abierto para la internacionalización (i18n) diseñada para simplificar el soporte multilingüe en aplicaciones web modernas.
|
|
8
|
+
|
|
9
|
+
Con Intlayer, puedes:
|
|
10
|
+
|
|
11
|
+
- **Gestionar fácilmente las traducciones** utilizando diccionarios declarativos a nivel de componente.
|
|
12
|
+
- **Localizar dinámicamente metadatos**, rutas y contenido.
|
|
13
|
+
- **Garantizar soporte para TypeScript** con tipos autogenerados, mejorando la autocompletación y la detección de errores.
|
|
14
|
+
- **Aprovechar características avanzadas**, como la detección dinámica de locales y el cambio entre ellos.
|
|
15
|
+
|
|
16
|
+
## Guía paso a paso para configurar Intlayer en una aplicación React
|
|
17
|
+
|
|
18
|
+
### Paso 1: Instalar dependencias
|
|
19
|
+
|
|
20
|
+
Instala los paquetes necesarios usando 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
|
+
El paquete principal que proporciona herramientas de internacionalización para la gestión de configuración, traducción, [declaración de contenido](https://github.com/aymericzip/intlayer/blob/main/docs/es/dictionary/get_started.md), transpilación y [comandos CLI](https://github.com/aymericzip/intlayer/blob/main/docs/es/intlayer_cli.md).
|
|
37
|
+
|
|
38
|
+
- **react-intlayer**
|
|
39
|
+
|
|
40
|
+
El paquete que integra Intlayer con aplicaciones React. Proporciona proveedores de contexto y hooks para la internacionalización en React.
|
|
41
|
+
|
|
42
|
+
- **react-scripts-intlayer**
|
|
43
|
+
|
|
44
|
+
Incluye los comandos y complementos `react-scripts-intlayer` para integrar Intlayer con aplicaciones basadas en Create React App. Estos complementos están basados en [craco](https://craco.js.org/) e incluyen configuración adicional para el empaquetador [Webpack](https://webpack.js.org/).
|
|
45
|
+
|
|
46
|
+
### Paso 2: Configuración de tu proyecto
|
|
47
|
+
|
|
48
|
+
Crea un archivo de configuración para configurar los idiomas de tu aplicación:
|
|
49
|
+
|
|
50
|
+
```typescript fileName="intlayer.config.ts" codeFormat="typescript"
|
|
51
|
+
import { Locales, type IntlayerConfig } from "intlayer";
|
|
52
|
+
|
|
53
|
+
const config: IntlayerConfig = {
|
|
54
|
+
internationalization: {
|
|
55
|
+
locales: [
|
|
56
|
+
Locales.ENGLISH,
|
|
57
|
+
Locales.FRENCH,
|
|
58
|
+
Locales.SPANISH,
|
|
59
|
+
// Tus otros 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
|
+
internationalization: {
|
|
74
|
+
locales: [
|
|
75
|
+
Locales.ENGLISH,
|
|
76
|
+
Locales.FRENCH,
|
|
77
|
+
Locales.SPANISH,
|
|
78
|
+
// Tus otros 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
|
+
internationalization: {
|
|
93
|
+
locales: [
|
|
94
|
+
Locales.ENGLISH,
|
|
95
|
+
Locales.FRENCH,
|
|
96
|
+
Locales.SPANISH,
|
|
97
|
+
// Tus otros locales
|
|
98
|
+
],
|
|
99
|
+
defaultLocale: Locales.ENGLISH,
|
|
100
|
+
},
|
|
101
|
+
};
|
|
102
|
+
|
|
103
|
+
module.exports = config;
|
|
104
|
+
```
|
|
105
|
+
|
|
106
|
+
> A través de este archivo de configuración, puedes configurar URLs localizadas, redirección de middleware, nombres de cookies, la ubicación y extensión de tus declaraciones de contenido, desactivar los logs de Intlayer en la consola y más. Para una lista completa de parámetros disponibles, consulta la [documentación de configuración](https://github.com/aymericzip/intlayer/blob/main/docs/es/configuration.md).
|
|
107
|
+
|
|
108
|
+
### Paso 3: Integrar Intlayer en tu configuración de CRA
|
|
109
|
+
|
|
110
|
+
Cambia tus scripts para usar 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
|
+
> Los scripts `react-scripts-intlayer` están basados en [CRACO](https://craco.js.org/). También puedes implementar tu propia configuración basada en el complemento craco de Intlayer. [Ver ejemplo aquí](https://github.com/aymericzip/intlayer/blob/main/examples/react-app/craco.config.js).
|
|
121
|
+
|
|
122
|
+
### Paso 4: Declarar tu contenido
|
|
123
|
+
|
|
124
|
+
Crea y gestiona tus declaraciones de contenido para almacenar traducciones:
|
|
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
|
+
> Tus declaraciones de contenido pueden definirse en cualquier lugar de tu aplicación siempre que estén incluidas en el directorio `contentDir` (por defecto, `./src`). Y coincidan con la extensión del archivo de declaración de contenido (por defecto, `.content.{json,ts,tsx,js,jsx,mjs,mjx,cjs,cjx}`).
|
|
217
|
+
|
|
218
|
+
> Para más detalles, consulta la [documentación de declaración de contenido](https://github.com/aymericzip/intlayer/blob/main/docs/es/dictionary/get_started.md).
|
|
219
|
+
|
|
220
|
+
> Si tu archivo de contenido incluye código TSX, deberías considerar importar `import React from "react";` en tu archivo de contenido.
|
|
221
|
+
|
|
222
|
+
### Paso 5: Utilizar Intlayer en tu código
|
|
223
|
+
|
|
224
|
+
Accede a tus diccionarios de contenido en toda tu aplicación:
|
|
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
|
+
> Nota: Si deseas usar tu contenido en un atributo `string`, como `alt`, `title`, `href`, `aria-label`, etc., debes llamar al valor de la función, como:
|
|
326
|
+
|
|
327
|
+
> ```jsx
|
|
328
|
+
>
|
|
329
|
+
> ```
|
|
330
|
+
|
|
331
|
+
> <img src={content.image.src.value} alt={content.image.value} />
|
|
332
|
+
|
|
333
|
+
> ```
|
|
334
|
+
>
|
|
335
|
+
> ```
|
|
336
|
+
|
|
337
|
+
> Para aprender más sobre el hook `useIntlayer`, consulta la [documentación](https://github.com/aymericzip/intlayer/blob/main/docs/es/packages/react-intlayer/useIntlayer.md).
|
|
338
|
+
|
|
339
|
+
### (Opcional) Paso 6: Cambiar el idioma de tu contenido
|
|
340
|
+
|
|
341
|
+
Para cambiar el idioma de tu contenido, puedes usar la función `setLocale` proporcionada por el hook `useLocale`. Esta función te permite establecer el local de la aplicación y actualizar el contenido en consecuencia.
|
|
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
|
+
Cambiar idioma a inglés
|
|
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
|
+
Cambiar idioma a inglés
|
|
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
|
+
Cambiar idioma a inglés
|
|
383
|
+
</button>
|
|
384
|
+
);
|
|
385
|
+
};
|
|
386
|
+
```
|
|
387
|
+
|
|
388
|
+
> Para aprender más sobre el hook `useLocale`, consulta la [documentación](https://github.com/aymericzip/intlayer/blob/main/docs/es/packages/react-intlayer/useLocale.md).
|
|
389
|
+
|
|
390
|
+
### (Opcional) Paso 7: Agregar enrutamiento localizado a tu aplicación
|
|
391
|
+
|
|
392
|
+
El propósito de este paso es crear rutas únicas para cada idioma. Esto es útil para SEO y URLs amigables para SEO.
|
|
393
|
+
Ejemplo:
|
|
394
|
+
|
|
395
|
+
```plaintext
|
|
396
|
+
- https://example.com/about
|
|
397
|
+
- https://example.com/es/about
|
|
398
|
+
- https://example.com/fr/about
|
|
399
|
+
```
|
|
400
|
+
|
|
401
|
+
> Por defecto, las rutas no están prefijadas para el local predeterminado. Si deseas prefijar el local predeterminado, puedes establecer la opción `middleware.prefixDefault` en `true` en tu configuración. Consulta la [documentación de configuración](https://github.com/aymericzip/intlayer/blob/main/docs/es/configuration.md) para más información.
|
|
402
|
+
|
|
403
|
+
Para agregar enrutamiento localizado a tu aplicación, puedes crear un componente `LocaleRouter` que envuelva las rutas de tu aplicación y maneje el enrutamiento basado en locales. Aquí tienes un ejemplo usando [React Router](https://reactrouter.com/home):
|
|
404
|
+
|
|
405
|
+
```tsx fileName="src/components/LocaleRouter.tsx" codeFormat="typescript"
|
|
406
|
+
// Importando dependencias y funciones necesarias
|
|
407
|
+
import { type Locales, configuration, getPathWithoutLocale } from "intlayer"; // Funciones y tipos de utilidad de 'intlayer'
|
|
408
|
+
import type { FC, PropsWithChildren } from "react"; // Tipos de React para componentes funcionales y props
|
|
409
|
+
import { IntlayerProvider } from "react-intlayer"; // Proveedor para el contexto de internacionalización
|
|
410
|
+
import {
|
|
411
|
+
BrowserRouter,
|
|
412
|
+
Routes,
|
|
413
|
+
Route,
|
|
414
|
+
Navigate,
|
|
415
|
+
useLocation,
|
|
416
|
+
} from "react-router-dom"; // Componentes de enrutador para gestionar la navegación
|
|
417
|
+
|
|
418
|
+
// Desestructurando configuración de Intlayer
|
|
419
|
+
const { internationalization, middleware } = configuration;
|
|
420
|
+
const { locales, defaultLocale } = internationalization;
|
|
421
|
+
|
|
422
|
+
/**
|
|
423
|
+
* Un componente que maneja la localización y envuelve a los hijos con el contexto de local adecuado.
|
|
424
|
+
* Gestiona la detección y validación basada en la URL.
|
|
425
|
+
*/
|
|
426
|
+
const AppLocalized: FC<PropsWithChildren<{ locale: Locales }>> = ({
|
|
427
|
+
children,
|
|
428
|
+
locale,
|
|
429
|
+
}) => {
|
|
430
|
+
const { pathname, search } = useLocation(); // Obtener la ruta URL actual
|
|
431
|
+
|
|
432
|
+
// Determinar el local actual, usando el predeterminado si no se proporciona
|
|
433
|
+
const currentLocale = locale ?? defaultLocale;
|
|
434
|
+
|
|
435
|
+
// Eliminar el prefijo del local de la ruta para construir una ruta base
|
|
436
|
+
const pathWithoutLocale = getPathWithoutLocale(
|
|
437
|
+
pathname // Ruta URL actual
|
|
438
|
+
);
|
|
439
|
+
|
|
440
|
+
/**
|
|
441
|
+
* Si middleware.prefixDefault es verdadero, el local predeterminado siempre debe estar prefijado.
|
|
442
|
+
*/
|
|
443
|
+
if (middleware.prefixDefault) {
|
|
444
|
+
// Validar el local
|
|
445
|
+
if (!locale || !locales.includes(locale)) {
|
|
446
|
+
// Redirigir al local predeterminado con la ruta actualizada
|
|
447
|
+
return (
|
|
448
|
+
<Navigate
|
|
449
|
+
to={`/${defaultLocale}/${pathWithoutLocale}${search}`}
|
|
450
|
+
replace // Reemplazar la entrada actual del historial con la nueva
|
|
451
|
+
/>
|
|
452
|
+
);
|
|
453
|
+
}
|
|
454
|
+
|
|
455
|
+
// Envolver a los hijos con el IntlayerProvider y establecer el local actual
|
|
456
|
+
return (
|
|
457
|
+
<IntlayerProvider locale={currentLocale}>{children}</IntlayerProvider>
|
|
458
|
+
);
|
|
459
|
+
} else {
|
|
460
|
+
/**
|
|
461
|
+
* Cuando middleware.prefixDefault es falso, el local predeterminado no está prefijado.
|
|
462
|
+
* Asegúrate de que el local actual sea válido y no el local predeterminado.
|
|
463
|
+
*/
|
|
464
|
+
if (
|
|
465
|
+
currentLocale.toString() !== defaultLocale.toString() &&
|
|
466
|
+
!locales
|
|
467
|
+
.filter(
|
|
468
|
+
(locale) => locale.toString() !== defaultLocale.toString() // Excluir el local predeterminado
|
|
469
|
+
)
|
|
470
|
+
.includes(currentLocale) // Verificar si el local actual está en la lista de locales válidos
|
|
471
|
+
) {
|
|
472
|
+
// Redirigir a la ruta sin prefijo de local
|
|
473
|
+
return <Navigate to={`${pathWithoutLocale}${search}`} replace />;
|
|
474
|
+
}
|
|
475
|
+
|
|
476
|
+
// Envolver a los hijos con el IntlayerProvider y establecer el local actual
|
|
477
|
+
return (
|
|
478
|
+
<IntlayerProvider locale={currentLocale}>{children}</IntlayerProvider>
|
|
479
|
+
);
|
|
480
|
+
}
|
|
481
|
+
};
|
|
482
|
+
|
|
483
|
+
/**
|
|
484
|
+
* Un componente de enrutador que configura rutas específicas para locales.
|
|
485
|
+
* Usa React Router para gestionar la navegación y renderizar componentes localizados.
|
|
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
|
+
// Patrón de ruta para capturar el local (por ejemplo, /en/, /fr/) y coincidir con todas las rutas subsecuentes
|
|
497
|
+
path={`/${locale}/*`}
|
|
498
|
+
key={locale}
|
|
499
|
+
element={<AppLocalized locale={locale}>{children}</AppLocalized>} // Envuelve a los hijos con la gestión de locales
|
|
500
|
+
/>
|
|
501
|
+
))}
|
|
502
|
+
|
|
503
|
+
{
|
|
504
|
+
// Si el prefijo del local predeterminado está deshabilitado, renderiza los hijos directamente en la ruta raíz
|
|
505
|
+
!middleware.prefixDefault && (
|
|
506
|
+
<Route
|
|
507
|
+
path="*"
|
|
508
|
+
element={
|
|
509
|
+
<AppLocalized locale={defaultLocale}>{children}</AppLocalized>
|
|
510
|
+
} // Envuelve a los hijos con la gestión de locales
|
|
511
|
+
/>
|
|
512
|
+
)
|
|
513
|
+
}
|
|
514
|
+
</Routes>
|
|
515
|
+
</BrowserRouter>
|
|
516
|
+
);
|
|
517
|
+
```
|
|
518
|
+
|
|
519
|
+
```jsx fileName="src/components/LocaleRouter.mjx" codeFormat="esm"
|
|
520
|
+
// Importando dependencias y funciones necesarias
|
|
521
|
+
import { configuration, getPathWithoutLocale } from "intlayer"; // Funciones y tipos de utilidad de 'intlayer'
|
|
522
|
+
import { IntlayerProvider } from "react-intlayer"; // Proveedor para el contexto de internacionalización
|
|
523
|
+
import {
|
|
524
|
+
BrowserRouter,
|
|
525
|
+
Routes,
|
|
526
|
+
Route,
|
|
527
|
+
Navigate,
|
|
528
|
+
useLocation,
|
|
529
|
+
} from "react-router-dom"; // Componentes de enrutador para gestionar la navegación
|
|
530
|
+
|
|
531
|
+
// Desestructurando configuración de Intlayer
|
|
532
|
+
const { internationalization, middleware } = configuration;
|
|
533
|
+
const { locales, defaultLocale } = internationalization;
|
|
534
|
+
|
|
535
|
+
/**
|
|
536
|
+
* Un componente que maneja la localización y envuelve a los hijos con el contexto de local adecuado.
|
|
537
|
+
* Gestiona la detección y validación basada en la URL.
|
|
538
|
+
*/
|
|
539
|
+
const AppLocalized = ({ children, locale }) => {
|
|
540
|
+
const { pathname, search } = useLocation(); // Obtener la ruta URL actual
|
|
541
|
+
|
|
542
|
+
// Determinar el local actual, usando el predeterminado si no se proporciona
|
|
543
|
+
const currentLocale = locale ?? defaultLocale;
|
|
544
|
+
|
|
545
|
+
// Eliminar el prefijo del local de la ruta para construir una ruta base
|
|
546
|
+
const pathWithoutLocale = getPathWithoutLocale(
|
|
547
|
+
pathname // Ruta URL actual
|
|
548
|
+
);
|
|
549
|
+
|
|
550
|
+
/**
|
|
551
|
+
* Si middleware.prefixDefault es verdadero, el local predeterminado siempre debe estar prefijado.
|
|
552
|
+
*/
|
|
553
|
+
if (middleware.prefixDefault) {
|
|
554
|
+
// Validar el local
|
|
555
|
+
if (!locale || !locales.includes(locale)) {
|
|
556
|
+
// Redirigir al local predeterminado con la ruta actualizada
|
|
557
|
+
return (
|
|
558
|
+
<Navigate
|
|
559
|
+
to={`/${defaultLocale}/${pathWithoutLocale}${search}`}
|
|
560
|
+
replace // Reemplazar la entrada actual del historial con la nueva
|
|
561
|
+
/>
|
|
562
|
+
);
|
|
563
|
+
}
|
|
564
|
+
|
|
565
|
+
// Envolver a los hijos con el IntlayerProvider y establecer el local actual
|
|
566
|
+
return (
|
|
567
|
+
<IntlayerProvider locale={currentLocale}>{children}</IntlayerProvider>
|
|
568
|
+
);
|
|
569
|
+
} else {
|
|
570
|
+
/**
|
|
571
|
+
* Cuando middleware.prefixDefault es falso, el local predeterminado no está prefijado.
|
|
572
|
+
* Asegúrate de que el local actual sea válido y no el local predeterminado.
|
|
573
|
+
*/
|
|
574
|
+
if (
|
|
575
|
+
currentLocale.toString() !== defaultLocale.toString() &&
|
|
576
|
+
!locales
|
|
577
|
+
.filter(
|
|
578
|
+
(locale) => locale.toString() !== defaultLocale.toString() // Excluir el local predeterminado
|
|
579
|
+
)
|
|
580
|
+
.includes(currentLocale) // Verificar si el local actual está en la lista de locales válidos
|
|
581
|
+
) {
|
|
582
|
+
// Redirigir a la ruta sin prefijo de local
|
|
583
|
+
return <Navigate to={`${pathWithoutLocale}${search}`} replace />;
|
|
584
|
+
}
|
|
585
|
+
|
|
586
|
+
// Envolver a los hijos con el IntlayerProvider y establecer el local actual
|
|
587
|
+
return (
|
|
588
|
+
<IntlayerProvider locale={currentLocale}>{children}</IntlayerProvider>
|
|
589
|
+
);
|
|
590
|
+
}
|
|
591
|
+
};
|
|
592
|
+
|
|
593
|
+
/**
|
|
594
|
+
* Un componente de enrutador que configura rutas específicas para locales.
|
|
595
|
+
* Usa React Router para gestionar la navegación y renderizar componentes localizados.
|
|
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
|
+
// Patrón de ruta para capturar el local (por ejemplo, /en/, /fr/) y coincidir con todas las rutas subsecuentes
|
|
607
|
+
path={`/${locale}/*`}
|
|
608
|
+
key={locale}
|
|
609
|
+
element={<AppLocalized locale={locale}>{children}</AppLocalized>} // Envuelve a los hijos con la gestión de locales
|
|
610
|
+
/>
|
|
611
|
+
))}
|
|
612
|
+
|
|
613
|
+
{
|
|
614
|
+
// Si el prefijo del local predeterminado está deshabilitado, renderiza los hijos directamente en la ruta raíz
|
|
615
|
+
!middleware.prefixDefault && (
|
|
616
|
+
<Route
|
|
617
|
+
path="*"
|
|
618
|
+
element={
|
|
619
|
+
<AppLocalized locale={defaultLocale}>{children}</AppLocalized>
|
|
620
|
+
} // Envuelve a los hijos con la gestión de locales
|
|
621
|
+
/>
|
|
622
|
+
)
|
|
623
|
+
}
|
|
624
|
+
</Routes>
|
|
625
|
+
</BrowserRouter>
|
|
626
|
+
);
|
|
627
|
+
```
|
|
628
|
+
|
|
629
|
+
```jsx fileName="src/components/LocaleRouter.cjx" codeFormat="commonjs"
|
|
630
|
+
// Importando dependencias y funciones necesarias
|
|
631
|
+
const { configuration, getPathWithoutLocale } = require("intlayer"); // Funciones y tipos de utilidad de 'intlayer'
|
|
632
|
+
const { IntlayerProvider, useLocale } = require("react-intlayer"); // Proveedor para el contexto de internacionalización
|
|
633
|
+
const {
|
|
634
|
+
BrowserRouter,
|
|
635
|
+
Routes,
|
|
636
|
+
Route,
|
|
637
|
+
Navigate,
|
|
638
|
+
useLocation,
|
|
639
|
+
} = require("react-router-dom"); // Componentes de enrutador para gestionar la navegación
|
|
640
|
+
|
|
641
|
+
// Desestructurando configuración de Intlayer
|
|
642
|
+
const { internationalization, middleware } = configuration;
|
|
643
|
+
const { locales, defaultLocale } = internationalization;
|
|
644
|
+
|
|
645
|
+
/**
|
|
646
|
+
* Un componente que maneja la localización y envuelve a los hijos con el contexto de local adecuado.
|
|
647
|
+
* Gestiona la detección y validación basada en la URL.
|
|
648
|
+
*/
|
|
649
|
+
const AppLocalized = ({ children, locale }) => {
|
|
650
|
+
const { pathname, search } = useLocation(); // Obtener la ruta URL actual
|
|
651
|
+
|
|
652
|
+
// Determinar el local actual, usando el predeterminado si no se proporciona
|
|
653
|
+
const currentLocale = locale ?? defaultLocale;
|
|
654
|
+
|
|
655
|
+
// Eliminar el prefijo del local de la ruta para construir una ruta base
|
|
656
|
+
const pathWithoutLocale = getPathWithoutLocale(
|
|
657
|
+
pathname // Ruta URL actual
|
|
658
|
+
);
|
|
659
|
+
|
|
660
|
+
/**
|
|
661
|
+
* Si middleware.prefixDefault es verdadero, el local predeterminado siempre debe estar prefijado.
|
|
662
|
+
*/
|
|
663
|
+
if (middleware.prefixDefault) {
|
|
664
|
+
// Validar el local
|
|
665
|
+
if (!locale || !locales.includes(locale)) {
|
|
666
|
+
// Redirigir al local predeterminado con la ruta actualizada
|
|
667
|
+
return (
|
|
668
|
+
<Navigate
|
|
669
|
+
to={`/${defaultLocale}/${pathWithoutLocale}${search}`}
|
|
670
|
+
replace // Reemplazar la entrada actual del historial con la nueva
|
|
671
|
+
/>
|
|
672
|
+
);
|
|
673
|
+
}
|
|
674
|
+
|
|
675
|
+
// Envolver a los hijos con el IntlayerProvider y establecer el local actual
|
|
676
|
+
return (
|
|
677
|
+
<IntlayerProvider locale={currentLocale}>{children}</IntlayerProvider>
|
|
678
|
+
);
|
|
679
|
+
} else {
|
|
680
|
+
/**
|
|
681
|
+
* Cuando middleware.prefixDefault es falso, el local predeterminado no está prefijado.
|
|
682
|
+
* Asegúrate de que el local actual sea válido y no el local predeterminado.
|
|
683
|
+
*/
|
|
684
|
+
if (
|
|
685
|
+
currentLocale.toString() !== defaultLocale.toString() &&
|
|
686
|
+
!locales
|
|
687
|
+
.filter(
|
|
688
|
+
(locale) => locale.toString() !== defaultLocale.toString() // Excluir el local predeterminado
|
|
689
|
+
)
|
|
690
|
+
.includes(currentLocale) // Verificar si el local actual está en la lista de locales válidos
|
|
691
|
+
) {
|
|
692
|
+
// Redirigir a la ruta sin prefijo de local
|
|
693
|
+
return <Navigate to={`${pathWithoutLocale}${search}`} replace />;
|
|
694
|
+
}
|
|
695
|
+
|
|
696
|
+
// Envolver a los hijos con el IntlayerProvider y establecer el local actual
|
|
697
|
+
return (
|
|
698
|
+
<IntlayerProvider locale={currentLocale}>{children}</IntlayerProvider>
|
|
699
|
+
);
|
|
700
|
+
}
|
|
701
|
+
};
|
|
702
|
+
|
|
703
|
+
/**
|
|
704
|
+
* Un componente de enrutador que configura rutas específicas para locales.
|
|
705
|
+
* Usa React Router para gestionar la navegación y renderizar componentes localizados.
|
|
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
|
+
// Patrón de ruta para capturar el local (por ejemplo, /en/, /fr/) y coincidir con todas las rutas subsecuentes
|
|
717
|
+
path={`/${locale}/*`}
|
|
718
|
+
key={locale}
|
|
719
|
+
element={<AppLocalized locale={locale}>{children}</AppLocalized>} // Envuelve a los hijos con la gestión de locales
|
|
720
|
+
/>
|
|
721
|
+
))}
|
|
722
|
+
|
|
723
|
+
{
|
|
724
|
+
// Si el prefijo del local predeterminado está deshabilitado, renderiza los hijos directamente en la ruta raíz
|
|
725
|
+
!middleware.prefixDefault && (
|
|
726
|
+
<Route
|
|
727
|
+
path="*"
|
|
728
|
+
element={
|
|
729
|
+
<AppLocalized locale={defaultLocale}>{children}</AppLocalized>
|
|
730
|
+
} // Envuelve a los hijos con la gestión de locales
|
|
731
|
+
/>
|
|
732
|
+
)
|
|
733
|
+
}
|
|
734
|
+
</Routes>
|
|
735
|
+
</BrowserRouter>
|
|
736
|
+
);
|
|
737
|
+
```
|
|
738
|
+
|
|
739
|
+
Luego, puedes usar el componente `LocaleRouter` en tu aplicación:
|
|
740
|
+
|
|
741
|
+
```tsx fileName="src/App.tsx" codeFormat="typescript"
|
|
742
|
+
import { LocaleRouter } from "./components/LocaleRouter";
|
|
743
|
+
import type { FC } from "react";
|
|
744
|
+
|
|
745
|
+
// ... Tu componente 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
|
+
// ... Tu componente 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
|
+
// ... Tu componente AppContent
|
|
770
|
+
|
|
771
|
+
const App = () => (
|
|
772
|
+
<LocaleRouter>
|
|
773
|
+
<AppContent />
|
|
774
|
+
</LocaleRouter>
|
|
775
|
+
);
|
|
776
|
+
```
|
|
777
|
+
|
|
778
|
+
### (Opcional) Paso 8: Cambiar la URL cuando cambia el local
|
|
779
|
+
|
|
780
|
+
Para cambiar la URL cuando cambia el local, puedes usar la prop `onLocaleChange` proporcionada por el hook `useLocale`. Paralelamente, puedes usar los hooks `useLocation` y `useNavigate` de `react-router-dom` para actualizar la ruta 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(); // Obtener la ruta URL actual. Ejemplo: /fr/about?foo=bar
|
|
795
|
+
const navigate = useNavigate();
|
|
796
|
+
|
|
797
|
+
const { locale, availableLocales, setLocale } = useLocale({
|
|
798
|
+
onLocaleChange: (locale) => {
|
|
799
|
+
// Construir la URL con el local actualizado
|
|
800
|
+
// Ejemplo: /es/about?foo=bar
|
|
801
|
+
const pathWithLocale = getLocalizedUrl(`${pathname}${search}`, locale);
|
|
802
|
+
|
|
803
|
+
// Actualizar la ruta 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
|
+
{/* Local - por ejemplo, FR */}
|
|
825
|
+
{localeItem}
|
|
826
|
+
</span>
|
|
827
|
+
<span>
|
|
828
|
+
{/* Idioma en su propio Local - por ejemplo, Français */}
|
|
829
|
+
{getLocaleName(localeItem, locale)}
|
|
830
|
+
</span>
|
|
831
|
+
<span dir={getHTMLTextDir(localeItem)} lang={localeItem}>
|
|
832
|
+
{/* Idioma en el Local actual - por ejemplo, Francés con el local actual configurado en Locales.SPANISH */}
|
|
833
|
+
{getLocaleName(localeItem)}
|
|
834
|
+
</span>
|
|
835
|
+
<span dir="ltr" lang={Locales.ENGLISH}>
|
|
836
|
+
{/* Idioma en inglés - por ejemplo, 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(); // Obtener la ruta URL actual. Ejemplo: /fr/about?foo=bar
|
|
859
|
+
const navigate = useNavigate();
|
|
860
|
+
|
|
861
|
+
const { locale, availableLocales, setLocale } = useLocale({
|
|
862
|
+
onLocaleChange: (locale) => {
|
|
863
|
+
// Construir la URL con el local actualizado
|
|
864
|
+
// Ejemplo: /es/about?foo=bar
|
|
865
|
+
const pathWithLocale = getLocalizedUrl(`${pathname}${search}`, locale);
|
|
866
|
+
|
|
867
|
+
// Actualizar la ruta 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
|
+
{/* Local - por ejemplo, FR */}
|
|
889
|
+
{localeItem}
|
|
890
|
+
</span>
|
|
891
|
+
<span>
|
|
892
|
+
{/* Idioma en su propio Local - por ejemplo, Français */}
|
|
893
|
+
{getLocaleName(localeItem, locale)}
|
|
894
|
+
</span>
|
|
895
|
+
<span dir={getHTMLTextDir(localeItem)} lang={localeItem}>
|
|
896
|
+
{/* Idioma en el Local actual - por ejemplo, Francés con el local actual configurado en Locales.SPANISH */}
|
|
897
|
+
{getLocaleName(localeItem)}
|
|
898
|
+
</span>
|
|
899
|
+
<span dir="ltr" lang={Locales.ENGLISH}>
|
|
900
|
+
{/* Idioma en inglés - por ejemplo, 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(); // Obtener la ruta URL actual. Ejemplo: /fr/about?foo=bar
|
|
923
|
+
const navigate = useNavigate();
|
|
924
|
+
|
|
925
|
+
const { locale, availableLocales, setLocale } = useLocale({
|
|
926
|
+
onLocaleChange: (locale) => {
|
|
927
|
+
// Construir la URL con el local actualizado
|
|
928
|
+
// Ejemplo: /es/about?foo=bar
|
|
929
|
+
const pathWithLocale = getLocalizedUrl(`${pathname}${search}`, locale);
|
|
930
|
+
|
|
931
|
+
// Actualizar la ruta 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
|
+
{/* Local - por ejemplo, FR */}
|
|
953
|
+
{localeItem}
|
|
954
|
+
</span>
|
|
955
|
+
<span>
|
|
956
|
+
{/* Idioma en su propio Local - por ejemplo, Français */}
|
|
957
|
+
{getLocaleName(localeItem, locale)}
|
|
958
|
+
</span>
|
|
959
|
+
<span dir={getHTMLTextDir(localeItem)} lang={localeItem}>
|
|
960
|
+
{/* Idioma en el Local actual - por ejemplo, Francés con el local actual configurado en Locales.SPANISH */}
|
|
961
|
+
{getLocaleName(localeItem)}
|
|
962
|
+
</span>
|
|
963
|
+
<span dir="ltr" lang={Locales.ENGLISH}>
|
|
964
|
+
{/* Idioma en inglés - por ejemplo, French */}
|
|
965
|
+
{getLocaleName(localeItem, Locales.ENGLISH)}
|
|
966
|
+
</span>
|
|
967
|
+
</a>
|
|
968
|
+
))}
|
|
969
|
+
</div>
|
|
970
|
+
</div>
|
|
971
|
+
);
|
|
972
|
+
};
|
|
973
|
+
```
|
|
974
|
+
|
|
975
|
+
> Referencias de documentación:
|
|
976
|
+
|
|
977
|
+
> - [Hook `useLocale`](https://github.com/aymericzip/intlayer/blob/main/docs/es/packages/react-intlayer/useLocale.md)
|
|
978
|
+
|
|
979
|
+
> - [Hook `getLocaleName`](https://github.com/aymericzip/intlayer/blob/main/docs/es/packages/intlayer/getLocaleName.md)
|
|
980
|
+
|
|
981
|
+
> - [Hook `getLocalizedUrl`](https://github.com/aymericzip/intlayer/blob/main/docs/es/packages/intlayer/getLocalizedUrl.md)
|
|
982
|
+
|
|
983
|
+
> - [Hook `getHTMLTextDir`](https://github.com/aymericzip/intlayer/blob/main/docs/es/packages/intlayer/getHTMLTextDir.md)
|
|
984
|
+
|
|
985
|
+
> - [Atributo `hrefLang`](https://developers.google.com/search/docs/specialty/international/localized-versions?hl=fr)
|
|
986
|
+
|
|
987
|
+
> - [Atributo `lang`](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes/lang)
|
|
988
|
+
|
|
989
|
+
> - [Atributo `dir`](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes/dir)
|
|
990
|
+
|
|
991
|
+
> - [Atributo `aria-current`](https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Attributes/aria-current)
|
|
992
|
+
|
|
993
|
+
### (Opcional) Paso 9: Cambiar los atributos de idioma y dirección del HTML
|
|
994
|
+
|
|
995
|
+
Cuando tu aplicación soporta múltiples idiomas, es crucial actualizar los atributos `lang` y `dir` de la etiqueta `<html>` para que coincidan con el local actual. Esto asegura:
|
|
996
|
+
|
|
997
|
+
- **Accesibilidad**: Los lectores de pantalla y tecnologías asistivas dependen del atributo `lang` correcto para pronunciar e interpretar el contenido con precisión.
|
|
998
|
+
- **Renderizado de texto**: El atributo `dir` (dirección) asegura que el texto se renderice en el orden correcto (por ejemplo, de izquierda a derecha para inglés, de derecha a izquierda para árabe o hebreo), lo cual es esencial para la legibilidad.
|
|
999
|
+
- **SEO**: Los motores de búsqueda usan el atributo `lang` para determinar el idioma de tu página, ayudando a servir el contenido localizado correcto en los resultados de búsqueda.
|
|
1000
|
+
|
|
1001
|
+
Al actualizar estos atributos dinámicamente cuando cambia el local, garantizas una experiencia consistente y accesible para los usuarios en todos los idiomas soportados.
|
|
1002
|
+
|
|
1003
|
+
#### Implementando el Hook
|
|
1004
|
+
|
|
1005
|
+
Crea un hook personalizado para gestionar los atributos HTML. El hook escucha los cambios de local y actualiza los atributos en consecuencia:
|
|
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
|
+
* Actualiza los atributos `lang` y `dir` del elemento HTML <html> basado en el local actual.
|
|
1014
|
+
* - `lang`: Informa a los navegadores y motores de búsqueda sobre el idioma de la página.
|
|
1015
|
+
* - `dir`: Asegura el orden de lectura correcto (por ejemplo, 'ltr' para inglés, 'rtl' para árabe).
|
|
1016
|
+
*
|
|
1017
|
+
* Esta actualización dinámica es esencial para un renderizado de texto adecuado, accesibilidad y SEO.
|
|
1018
|
+
*/
|
|
1019
|
+
export const useI18nHTMLAttributes = () => {
|
|
1020
|
+
const { locale } = useLocale();
|
|
1021
|
+
|
|
1022
|
+
useEffect(() => {
|
|
1023
|
+
// Actualizar el atributo de idioma al local actual.
|
|
1024
|
+
document.documentElement.lang = locale;
|
|
1025
|
+
|
|
1026
|
+
// Establecer la dirección del texto basada en el local actual.
|
|
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
|
+
* Actualiza los atributos `lang` y `dir` del elemento HTML <html> basado en el local actual.
|
|
1039
|
+
* - `lang`: Informa a los navegadores y motores de búsqueda sobre el idioma de la página.
|
|
1040
|
+
* - `dir`: Asegura el orden de lectura correcto (por ejemplo, 'ltr' para inglés, 'rtl' para árabe).
|
|
1041
|
+
*
|
|
1042
|
+
* Esta actualización dinámica es esencial para un renderizado de texto adecuado, accesibilidad y SEO.
|
|
1043
|
+
*/
|
|
1044
|
+
export const useI18nHTMLAttributes = () => {
|
|
1045
|
+
const { locale } = useLocale();
|
|
1046
|
+
|
|
1047
|
+
useEffect(() => {
|
|
1048
|
+
// Actualizar el atributo de idioma al local actual.
|
|
1049
|
+
document.documentElement.lang = locale;
|
|
1050
|
+
|
|
1051
|
+
// Establecer la dirección del texto basada en el local actual.
|
|
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
|
+
* Actualiza los atributos `lang` y `dir` del elemento HTML <html> basado en el local actual.
|
|
1064
|
+
* - `lang`: Informa a los navegadores y motores de búsqueda sobre el idioma de la página.
|
|
1065
|
+
* - `dir`: Asegura el orden de lectura correcto (por ejemplo, 'ltr' para inglés, 'rtl' para árabe).
|
|
1066
|
+
*
|
|
1067
|
+
* Esta actualización dinámica es esencial para un renderizado de texto adecuado, accesibilidad y SEO.
|
|
1068
|
+
*/
|
|
1069
|
+
const useI18nHTMLAttributes = () => {
|
|
1070
|
+
const { locale } = useLocale();
|
|
1071
|
+
|
|
1072
|
+
useEffect(() => {
|
|
1073
|
+
// Actualizar el atributo de idioma al local actual.
|
|
1074
|
+
document.documentElement.lang = locale;
|
|
1075
|
+
|
|
1076
|
+
// Establecer la dirección del texto basada en el local actual.
|
|
1077
|
+
document.documentElement.dir = getHTMLTextDir(locale);
|
|
1078
|
+
}, [locale]);
|
|
1079
|
+
};
|
|
1080
|
+
|
|
1081
|
+
module.exports = { useI18nHTMLAttributes };
|
|
1082
|
+
```
|
|
1083
|
+
|
|
1084
|
+
#### Usando el Hook en tu aplicación
|
|
1085
|
+
|
|
1086
|
+
Integra el hook en tu componente principal para que los atributos HTML se actualicen siempre que cambie el local:
|
|
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
|
+
// Aplicar el hook para actualizar los atributos lang y dir de la etiqueta <html> basado en el local.
|
|
1096
|
+
useI18nHTMLAttributes();
|
|
1097
|
+
|
|
1098
|
+
// ... Resto de tu componente
|
|
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
|
+
// Aplicar el hook para actualizar los atributos lang y dir de la etiqueta <html> basado en el local.
|
|
1117
|
+
useI18nHTMLAttributes();
|
|
1118
|
+
|
|
1119
|
+
// ... Resto de tu componente
|
|
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
|
+
// Aplicar el hook para actualizar los atributos lang y dir de la etiqueta <html> basado en el local.
|
|
1139
|
+
useI18nHTMLAttributes();
|
|
1140
|
+
|
|
1141
|
+
// ... Resto de tu componente
|
|
1142
|
+
};
|
|
1143
|
+
|
|
1144
|
+
const App = () => (
|
|
1145
|
+
<IntlayerProvider>
|
|
1146
|
+
<AppContent />
|
|
1147
|
+
</IntlayerProvider>
|
|
1148
|
+
);
|
|
1149
|
+
|
|
1150
|
+
module.exports = App;
|
|
1151
|
+
```
|
|
1152
|
+
|
|
1153
|
+
Al aplicar estos cambios, tu aplicación:
|
|
1154
|
+
|
|
1155
|
+
- Garantizará que el atributo **idioma** (`lang`) refleje correctamente el local actual, lo cual es importante para SEO y el comportamiento del navegador.
|
|
1156
|
+
- Ajustará la **dirección del texto** (`dir`) según el local, mejorando la legibilidad y usabilidad para idiomas con diferentes órdenes de lectura.
|
|
1157
|
+
- Proporcionará una experiencia más **accesible**, ya que las tecnologías asistivas dependen de estos atributos para funcionar de manera óptima.
|
|
1158
|
+
|
|
1159
|
+
### Configurar TypeScript
|
|
1160
|
+
|
|
1161
|
+
Intlayer utiliza la ampliación de módulos para obtener beneficios de TypeScript y fortalecer tu base de código.
|
|
1162
|
+
|
|
1163
|
+

|
|
1164
|
+
|
|
1165
|
+

|
|
1166
|
+
|
|
1167
|
+
Asegúrate de que tu configuración de TypeScript incluya los tipos autogenerados.
|
|
1168
|
+
|
|
1169
|
+
```json5 fileName="tsconfig.json"
|
|
1170
|
+
{
|
|
1171
|
+
// ... Tus configuraciones existentes de TypeScript
|
|
1172
|
+
"include": [
|
|
1173
|
+
// ... Tus configuraciones existentes de TypeScript
|
|
1174
|
+
".intlayer/**/*.ts", // Incluir los tipos autogenerados
|
|
1175
|
+
],
|
|
1176
|
+
}
|
|
1177
|
+
```
|
|
1178
|
+
|
|
1179
|
+
### Configuración de Git
|
|
1180
|
+
|
|
1181
|
+
Se recomienda ignorar los archivos generados por Intlayer. Esto te permite evitar comprometerlos en tu repositorio Git.
|
|
1182
|
+
|
|
1183
|
+
Para hacer esto, puedes agregar las siguientes instrucciones a tu archivo `.gitignore`:
|
|
1184
|
+
|
|
1185
|
+
```plaintext fileName=".gitignore"
|
|
1186
|
+
# Ignorar los archivos generados por Intlayer
|
|
1187
|
+
.intlayer
|
|
1188
|
+
```
|
|
1189
|
+
|
|
1190
|
+
### Ir más allá
|
|
1191
|
+
|
|
1192
|
+
Para ir más allá, puedes implementar el [editor visual](https://github.com/aymericzip/intlayer/blob/main/docs/es/intlayer_visual_editor.md) o externalizar tu contenido utilizando el [CMS](https://github.com/aymericzip/intlayer/blob/main/docs/es/intlayer_CMS.md).
|