@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,1260 @@
|
|
|
1
|
+
# البدء في التدويل (i18n) باستخدام Intlayer و Next.js 14 مع App Router
|
|
2
|
+
|
|
3
|
+
انظر [Template Application](https://github.com/aymericzip/intlayer-next-14-template) على GitHub.
|
|
4
|
+
|
|
5
|
+
## ما هو Intlayer؟
|
|
6
|
+
|
|
7
|
+
**Intlayer** هو مكتبة تدويل (i18n) مبتكرة ومفتوحة المصدر مصممة لتبسيط دعم اللغات المتعددة في تطبيقات الويب الحديثة. يتكامل Intlayer بسلاسة مع إطار العمل الحديث **Next.js 14**، بما في ذلك **App Router** القوي. تم تحسينه للعمل مع **مكونات الخادم** لتقديم فعال ومتوافق تمامًا مع [**Turbopack**](https://nextjs.org/docs/architecture/turbopack) (من Next.js >= 15).
|
|
8
|
+
|
|
9
|
+
مع Intlayer، يمكنك:
|
|
10
|
+
|
|
11
|
+
- **إدارة الترجمات بسهولة** باستخدام القواميس التصريحية على مستوى المكونات.
|
|
12
|
+
- **تدويل البيانات الوصفية، المسارات، والمحتوى ديناميكيًا**.
|
|
13
|
+
- **الوصول إلى الترجمات في مكونات العميل والخادم**.
|
|
14
|
+
- **ضمان دعم TypeScript** مع أنواع مولدة تلقائيًا، مما يحسن الإكمال التلقائي واكتشاف الأخطاء.
|
|
15
|
+
- **الاستفادة من الميزات المتقدمة**، مثل اكتشاف اللغة الديناميكي والتبديل.
|
|
16
|
+
|
|
17
|
+
> يتوافق Intlayer مع Next.js 12، 13، 14، و15. إذا كنت تستخدم Next.js Page Router، يمكنك الرجوع إلى هذا [الدليل](https://github.com/aymericzip/intlayer/blob/main/docs/ar/intlayer_with_nextjs_page_router.md). بالنسبة لـ Next.js 15 مع أو بدون turbopack، راجع هذا [الدليل](https://github.com/aymericzip/intlayer/blob/main/docs/ar/intlayer_with_nextjs_15.md).
|
|
18
|
+
|
|
19
|
+
---
|
|
20
|
+
|
|
21
|
+
## دليل خطوة بخطوة لإعداد Intlayer في تطبيق Next.js
|
|
22
|
+
|
|
23
|
+
### الخطوة 1: تثبيت التبعيات
|
|
24
|
+
|
|
25
|
+
قم بتثبيت الحزم اللازمة باستخدام npm:
|
|
26
|
+
|
|
27
|
+
```bash packageManager="npm"
|
|
28
|
+
npm install intlayer next-intlayer
|
|
29
|
+
```
|
|
30
|
+
|
|
31
|
+
```bash packageManager="pnpm"
|
|
32
|
+
pnpm add intlayer next-intlayer
|
|
33
|
+
```
|
|
34
|
+
|
|
35
|
+
```bash packageManager="yarn"
|
|
36
|
+
yarn add intlayer next-intlayer
|
|
37
|
+
```
|
|
38
|
+
|
|
39
|
+
- **intlayer**
|
|
40
|
+
|
|
41
|
+
الحزمة الأساسية التي توفر أدوات التدويل لإدارة التكوين، الترجمة، [إعلان المحتوى](https://github.com/aymericzip/intlayer/blob/main/docs/ar/dictionary/get_started.md)، الترجمة، و[أوامر CLI](https://github.com/aymericzip/intlayer/blob/main/docs/ar/intlayer_cli.md).
|
|
42
|
+
|
|
43
|
+
- **next-intlayer**
|
|
44
|
+
|
|
45
|
+
الحزمة التي تدمج Intlayer مع Next.js. توفر موفري السياق وخطافات لتدويل Next.js. بالإضافة إلى ذلك، تتضمن مكون إضافي لـ Next.js لدمج Intlayer مع [Webpack](https://webpack.js.org/) أو [Turbopack](https://nextjs.org/docs/app/api-reference/turbopack)، بالإضافة إلى وسيط لاكتشاف اللغة المفضلة للمستخدم، إدارة الكوكيز، والتعامل مع إعادة توجيه URL.
|
|
46
|
+
|
|
47
|
+
### الخطوة 2: تكوين مشروعك
|
|
48
|
+
|
|
49
|
+
قم بإنشاء ملف تكوين لتحديد لغات تطبيقك:
|
|
50
|
+
|
|
51
|
+
```typescript fileName="intlayer.config.ts" codeFormat="typescript"
|
|
52
|
+
import { Locales, type IntlayerConfig } from "intlayer";
|
|
53
|
+
|
|
54
|
+
const config: IntlayerConfig = {
|
|
55
|
+
internationalization: {
|
|
56
|
+
locales: [
|
|
57
|
+
Locales.ENGLISH,
|
|
58
|
+
Locales.FRENCH,
|
|
59
|
+
Locales.SPANISH,
|
|
60
|
+
// لغاتك الأخرى
|
|
61
|
+
],
|
|
62
|
+
defaultLocale: Locales.ENGLISH,
|
|
63
|
+
},
|
|
64
|
+
};
|
|
65
|
+
|
|
66
|
+
export default config;
|
|
67
|
+
```
|
|
68
|
+
|
|
69
|
+
```javascript fileName="intlayer.config.mjs" codeFormat="esm"
|
|
70
|
+
import { Locales } from "intlayer";
|
|
71
|
+
|
|
72
|
+
/** @type {import('intlayer').IntlayerConfig} */
|
|
73
|
+
const config = {
|
|
74
|
+
internationalization: {
|
|
75
|
+
locales: [
|
|
76
|
+
Locales.ENGLISH,
|
|
77
|
+
Locales.FRENCH,
|
|
78
|
+
Locales.SPANISH,
|
|
79
|
+
// لغاتك الأخرى
|
|
80
|
+
],
|
|
81
|
+
defaultLocale: Locales.ENGLISH,
|
|
82
|
+
},
|
|
83
|
+
};
|
|
84
|
+
|
|
85
|
+
export default config;
|
|
86
|
+
```
|
|
87
|
+
|
|
88
|
+
```javascript fileName="intlayer.config.cjs" codeFormat="commonjs"
|
|
89
|
+
const { Locales } = require("intlayer");
|
|
90
|
+
|
|
91
|
+
/** @type {import('intlayer').IntlayerConfig} */
|
|
92
|
+
const config = {
|
|
93
|
+
internationalization: {
|
|
94
|
+
locales: [
|
|
95
|
+
Locales.ENGLISH,
|
|
96
|
+
Locales.FRENCH,
|
|
97
|
+
Locales.SPANISH,
|
|
98
|
+
// لغاتك الأخرى
|
|
99
|
+
],
|
|
100
|
+
defaultLocale: Locales.ENGLISH,
|
|
101
|
+
},
|
|
102
|
+
};
|
|
103
|
+
|
|
104
|
+
module.exports = config;
|
|
105
|
+
```
|
|
106
|
+
|
|
107
|
+
> من خلال ملف التكوين هذا، يمكنك إعداد عناوين URL المحلية، إعادة توجيه الوسيط، أسماء الكوكيز، موقع وامتداد إعلانات المحتوى الخاصة بك، تعطيل سجلات Intlayer في وحدة التحكم، والمزيد. للحصول على قائمة كاملة بالمعلمات المتاحة، راجع [وثائق التكوين](https://github.com/aymericzip/intlayer/blob/main/docs/ar/configuration.md).
|
|
108
|
+
|
|
109
|
+
### الخطوة 3: دمج Intlayer في تكوين Next.js الخاص بك
|
|
110
|
+
|
|
111
|
+
قم بتكوين إعداد Next.js الخاص بك لاستخدام Intlayer:
|
|
112
|
+
|
|
113
|
+
```typescript fileName="next.config.mjs"
|
|
114
|
+
import { withIntlayer } from "next-intlayer/server";
|
|
115
|
+
|
|
116
|
+
/** @type {import('next').NextConfig} */
|
|
117
|
+
const nextConfig = {};
|
|
118
|
+
|
|
119
|
+
export default withIntlayer(nextConfig);
|
|
120
|
+
```
|
|
121
|
+
|
|
122
|
+
> يتم استخدام مكون `withIntlayer()` الإضافي لـ Next.js لدمج Intlayer مع Next.js. يضمن بناء ملفات إعلان المحتوى ومراقبتها في وضع التطوير. يحدد متغيرات بيئة Intlayer داخل بيئات [Webpack](https://webpack.js.org/) أو [Turbopack](https://nextjs.org/docs/app/api-reference/turbopack). بالإضافة إلى ذلك، يوفر أسماء مستعارة لتحسين الأداء ويضمن التوافق مع مكونات الخادم.
|
|
123
|
+
|
|
124
|
+
### الخطوة 4: تكوين الوسيط لاكتشاف اللغة
|
|
125
|
+
|
|
126
|
+
قم بإعداد الوسيط لاكتشاف اللغة المفضلة للمستخدم:
|
|
127
|
+
|
|
128
|
+
```typescript fileName="src/middleware.ts" codeFormat="typescript"
|
|
129
|
+
export { intlayerMiddleware as middleware } from "next-intlayer/middleware";
|
|
130
|
+
|
|
131
|
+
export const config = {
|
|
132
|
+
matcher:
|
|
133
|
+
"/((?!api|static|assets|robots|sitemap|sw|service-worker|manifest|.*\\..*|_next).*)",
|
|
134
|
+
};
|
|
135
|
+
```
|
|
136
|
+
|
|
137
|
+
```javascript fileName="src/middleware.mjs" codeFormat="esm"
|
|
138
|
+
export { intlayerMiddleware as middleware } from "next-intlayer/middleware";
|
|
139
|
+
|
|
140
|
+
export const config = {
|
|
141
|
+
matcher:
|
|
142
|
+
"/((?!api|static|assets|robots|sitemap|sw|service-worker|manifest|.*\\..*|_next).*)",
|
|
143
|
+
};
|
|
144
|
+
```
|
|
145
|
+
|
|
146
|
+
```javascript fileName="src/middleware.cjs" codeFormat="commonjs"
|
|
147
|
+
const { intlayerMiddleware } = require("next-intlayer/middleware");
|
|
148
|
+
|
|
149
|
+
const config = {
|
|
150
|
+
matcher:
|
|
151
|
+
"/((?!api|static|assets|robots|sitemap|sw|service-worker|manifest|.*\\..*|_next).*)",
|
|
152
|
+
};
|
|
153
|
+
|
|
154
|
+
module.exports = { middleware: intlayerMiddleware, config };
|
|
155
|
+
```
|
|
156
|
+
|
|
157
|
+
> يتم استخدام `intlayerMiddleware` لاكتشاف اللغة المفضلة للمستخدم وإعادة توجيههم إلى عنوان URL المناسب كما هو محدد في [التكوين](https://github.com/aymericzip/intlayer/blob/main/docs/ar/configuration.md). بالإضافة إلى ذلك، يتيح حفظ اللغة المفضلة للمستخدم في كوكيز.
|
|
158
|
+
|
|
159
|
+
> قم بتعديل معلمة `matcher` لتطابق مسارات تطبيقك. لمزيد من التفاصيل، راجع [وثائق Next.js حول تكوين المطابقة](https://nextjs.org/docs/app/building-your-application/routing/middleware).
|
|
160
|
+
|
|
161
|
+
### الخطوة 5: تحديد مسارات اللغة الديناميكية
|
|
162
|
+
|
|
163
|
+
قم بإزالة كل شيء من `RootLayout` واستبدله بالكود التالي:
|
|
164
|
+
|
|
165
|
+
```tsx fileName="src/app/layout.tsx" codeFormat="typescript"
|
|
166
|
+
import type { PropsWithChildren, FC } from "react";
|
|
167
|
+
import "./globals.css";
|
|
168
|
+
|
|
169
|
+
const RootLayout: FC<PropsWithChildren> = ({ children }) => children;
|
|
170
|
+
|
|
171
|
+
export default RootLayout;
|
|
172
|
+
```
|
|
173
|
+
|
|
174
|
+
```jsx fileName="src/app/layout.mjx" codeFormat="esm"
|
|
175
|
+
import "./globals.css";
|
|
176
|
+
|
|
177
|
+
const RootLayout = ({ children }) => children;
|
|
178
|
+
|
|
179
|
+
export default RootLayout;
|
|
180
|
+
```
|
|
181
|
+
|
|
182
|
+
```jsx fileName="src/app/layout.csx" codeFormat="commonjs"
|
|
183
|
+
require("./globals.css");
|
|
184
|
+
|
|
185
|
+
const RootLayout = ({ children }) => children;
|
|
186
|
+
|
|
187
|
+
module.exports = {
|
|
188
|
+
default: RootLayout,
|
|
189
|
+
generateStaticParams,
|
|
190
|
+
};
|
|
191
|
+
```
|
|
192
|
+
|
|
193
|
+
> الحفاظ على مكون `RootLayout` فارغًا يسمح بتعيين سمات [`lang`](https://developer.mozilla.org/fr/docs/Web/HTML/Global_attributes/lang) و[`dir`](https://developer.mozilla.org/fr/docs/Web/HTML/Global_attributes/dir) إلى علامة `<html>`.
|
|
194
|
+
|
|
195
|
+
لتنفيذ التوجيه الديناميكي، قم بتوفير المسار للغة عن طريق إضافة تخطيط جديد في دليل `[locale]` الخاص بك:
|
|
196
|
+
|
|
197
|
+
```tsx fileName="src/app/[locale]/layout.tsx" codeFormat="typescript"
|
|
198
|
+
import type { Next14LayoutIntlayer } from "next-intlayer";
|
|
199
|
+
import { Inter } from "next/font/google";
|
|
200
|
+
import { getHTMLTextDir } from "intlayer";
|
|
201
|
+
|
|
202
|
+
const inter = Inter({ subsets: ["latin"] });
|
|
203
|
+
|
|
204
|
+
const LocaleLayout: Next14LayoutIntlayer = ({
|
|
205
|
+
children,
|
|
206
|
+
params: { locale },
|
|
207
|
+
}) => (
|
|
208
|
+
<html lang={locale} dir={getHTMLTextDir(locale)}>
|
|
209
|
+
<body className={inter.className}>{children}</body>
|
|
210
|
+
</html>
|
|
211
|
+
);
|
|
212
|
+
```
|
|
213
|
+
|
|
214
|
+
import { Inter } from "next/font/google";
|
|
215
|
+
import { getHTMLTextDir } from "intlayer";
|
|
216
|
+
|
|
217
|
+
const inter = Inter({ subsets: ["latin"] });
|
|
218
|
+
|
|
219
|
+
const LocaleLayout = ({ children, params: { locale } }) => (
|
|
220
|
+
|
|
221
|
+
<html lang={locale} dir={getHTMLTextDir(locale)}>
|
|
222
|
+
<body className={inter.className}>{children}</body>
|
|
223
|
+
</html>
|
|
224
|
+
);
|
|
225
|
+
|
|
226
|
+
export default LocaleLayout;
|
|
227
|
+
|
|
228
|
+
````
|
|
229
|
+
|
|
230
|
+
```jsx fileName="src/app/[locale]/layout.csx" codeFormat="commonjs"
|
|
231
|
+
const { Inter } = require("next/font/google");
|
|
232
|
+
const { getHTMLTextDir } = require("intlayer");
|
|
233
|
+
|
|
234
|
+
const inter = Inter({ subsets: ["latin"] });
|
|
235
|
+
|
|
236
|
+
const LocaleLayout = ({ children, params: { locale } }) => (
|
|
237
|
+
<html lang={locale} dir={getHTMLTextDir(locale)}>
|
|
238
|
+
<body className={inter.className}>{children}</body>
|
|
239
|
+
</html>
|
|
240
|
+
);
|
|
241
|
+
|
|
242
|
+
module.exports = LocaleLayout;
|
|
243
|
+
````
|
|
244
|
+
|
|
245
|
+
> يتم استخدام جزء المسار `[locale]` لتحديد اللغة المحلية. على سبيل المثال: `/ar/about` يشير إلى `ar` و `/fr/about` يشير إلى `fr`.
|
|
246
|
+
|
|
247
|
+
ثم قم بتنفيذ وظيفة `generateStaticParams` في تخطيط التطبيق الخاص بك.
|
|
248
|
+
|
|
249
|
+
```tsx {1} fileName="src/app/[locale]/layout.tsx" codeFormat="typescript"
|
|
250
|
+
export { generateStaticParams } from "next-intlayer"; // السطر للإدراج
|
|
251
|
+
|
|
252
|
+
const LocaleLayout: Next14LayoutIntlayer = ({
|
|
253
|
+
children,
|
|
254
|
+
params: { locale },
|
|
255
|
+
}) => {
|
|
256
|
+
/*... بقية الكود */
|
|
257
|
+
};
|
|
258
|
+
|
|
259
|
+
export default LocaleLayout;
|
|
260
|
+
```
|
|
261
|
+
|
|
262
|
+
```jsx {1} fileName="src/app/[locale]/layout.mjx" codeFormat="esm"
|
|
263
|
+
export { generateStaticParams } from "next-intlayer"; // السطر للإدراج
|
|
264
|
+
|
|
265
|
+
const LocaleLayout = ({ children, params: { locale } }) => {
|
|
266
|
+
/*... بقية الكود */
|
|
267
|
+
};
|
|
268
|
+
|
|
269
|
+
export default LocaleLayout;
|
|
270
|
+
```
|
|
271
|
+
|
|
272
|
+
```jsx {1,7} fileName="src/app/[locale]/layout.csx" codeFormat="commonjs"
|
|
273
|
+
const { generateStaticParams } = require("next-intlayer"); // السطر للإدراج
|
|
274
|
+
|
|
275
|
+
const LocaleLayout = ({ children, params: { locale } }) => {
|
|
276
|
+
/*... بقية الكود */
|
|
277
|
+
};
|
|
278
|
+
|
|
279
|
+
module.exports = LocaleLayout;
|
|
280
|
+
```
|
|
281
|
+
|
|
282
|
+
> تضمن `generateStaticParams` أن يقوم تطبيقك ببناء الصفحات الضرورية مسبقًا لجميع اللغات المحلية، مما يقلل من الحساب أثناء وقت التشغيل ويحسن تجربة المستخدم. لمزيد من التفاصيل، راجع [وثائق Next.js حول generateStaticParams](https://nextjs.org/docs/app/building-your-application/rendering/static-and-dynamic-rendering#generate-static-params).
|
|
283
|
+
|
|
284
|
+
### الخطوة 6: إعلان المحتوى الخاص بك
|
|
285
|
+
|
|
286
|
+
قم بإنشاء وإدارة إعلانات المحتوى الخاصة بك لتخزين الترجمات:
|
|
287
|
+
|
|
288
|
+
```typescript fileName="src/app/[locale]/page.content.ts" contentDeclarationFormat="typescript"
|
|
289
|
+
import { t, type Dictionary } from "intlayer";
|
|
290
|
+
|
|
291
|
+
const pageContent = {
|
|
292
|
+
key: "page",
|
|
293
|
+
content: {
|
|
294
|
+
getStarted: {
|
|
295
|
+
main: t({
|
|
296
|
+
ar: "ابدأ بالتعديل",
|
|
297
|
+
en: "Get started by editing",
|
|
298
|
+
fr: "Commencez par éditer",
|
|
299
|
+
es: "Comience por editar",
|
|
300
|
+
}),
|
|
301
|
+
pageLink: "src/app/page.tsx",
|
|
302
|
+
},
|
|
303
|
+
},
|
|
304
|
+
} satisfies Dictionary;
|
|
305
|
+
|
|
306
|
+
export default pageContent;
|
|
307
|
+
```
|
|
308
|
+
|
|
309
|
+
```javascript fileName="src/app/[locale]/page.content.mjs" contentDeclarationFormat="esm"
|
|
310
|
+
import { t } from "intlayer";
|
|
311
|
+
|
|
312
|
+
/** @type {import('intlayer').Dictionary} */
|
|
313
|
+
const pageContent = {
|
|
314
|
+
key: "page",
|
|
315
|
+
content: {
|
|
316
|
+
getStarted: {
|
|
317
|
+
main: t({
|
|
318
|
+
ar: "ابدأ بالتعديل",
|
|
319
|
+
en: "Get started by editing",
|
|
320
|
+
fr: "Commencez par éditer",
|
|
321
|
+
es: "Comience por editar",
|
|
322
|
+
}),
|
|
323
|
+
pageLink: "src/app/page.tsx",
|
|
324
|
+
},
|
|
325
|
+
},
|
|
326
|
+
};
|
|
327
|
+
|
|
328
|
+
export default pageContent;
|
|
329
|
+
```
|
|
330
|
+
|
|
331
|
+
```javascript fileName="src/app/[locale]/page.content.cjs" contentDeclarationFormat="commonjs"
|
|
332
|
+
const { t } = require("intlayer");
|
|
333
|
+
|
|
334
|
+
/** @type {import('intlayer').Dictionary} */
|
|
335
|
+
const pageContent = {
|
|
336
|
+
key: "page",
|
|
337
|
+
content: {
|
|
338
|
+
getStarted: {
|
|
339
|
+
main: t({
|
|
340
|
+
ar: "ابدأ بالتعديل",
|
|
341
|
+
en: "Get started by editing",
|
|
342
|
+
fr: "Commencez par éditer",
|
|
343
|
+
es: "Comience por editar",
|
|
344
|
+
}),
|
|
345
|
+
pageLink: "src/app/page.tsx",
|
|
346
|
+
},
|
|
347
|
+
},
|
|
348
|
+
};
|
|
349
|
+
|
|
350
|
+
module.exports = pageContent;
|
|
351
|
+
```
|
|
352
|
+
|
|
353
|
+
```json fileName="src/app/[locale]/page.content.json" contentDeclarationFormat="json"
|
|
354
|
+
{
|
|
355
|
+
"$schema": "https://intlayer.org/schema.json",
|
|
356
|
+
"key": "page",
|
|
357
|
+
"content": {
|
|
358
|
+
"getStarted": {
|
|
359
|
+
"nodeType": "translation",
|
|
360
|
+
"translation": {
|
|
361
|
+
"ar": "ابدأ بالتعديل",
|
|
362
|
+
"en": "Get started by editing",
|
|
363
|
+
"fr": "Commencez par éditer",
|
|
364
|
+
"es": "Comience por editar"
|
|
365
|
+
}
|
|
366
|
+
},
|
|
367
|
+
"pageLink": {
|
|
368
|
+
"nodeType": "translation",
|
|
369
|
+
"translation": {
|
|
370
|
+
"ar": "src/app/page.tsx",
|
|
371
|
+
"en": "src/app/page.tsx",
|
|
372
|
+
"fr": "src/app/page.tsx",
|
|
373
|
+
"es": "src/app/page.tsx"
|
|
374
|
+
}
|
|
375
|
+
}
|
|
376
|
+
}
|
|
377
|
+
}
|
|
378
|
+
```
|
|
379
|
+
|
|
380
|
+
> يمكن تعريف إعلانات المحتوى الخاصة بك في أي مكان في تطبيقك طالما تم تضمينها في دليل `contentDir` (افتراضيًا، `./src`). وتطابق امتداد ملف إعلان المحتوى (افتراضيًا، `.content.{json,ts,tsx,js,jsx,mjs,mjx,cjs,cjx}`). لمزيد من التفاصيل، راجع [وثائق إعلان المحتوى](https://github.com/aymericzip/intlayer/blob/main/docs/ar/dictionary/get_started.md).
|
|
381
|
+
|
|
382
|
+
### الخطوة 7: استخدام المحتوى في الكود الخاص بك
|
|
383
|
+
|
|
384
|
+
الوصول إلى قواميس المحتوى الخاصة بك في جميع أنحاء التطبيق الخاص بك:
|
|
385
|
+
|
|
386
|
+
```tsx fileName="src/app/[locale]/page.tsx" codeFormat="typescript"
|
|
387
|
+
import { ClientComponentExample } from "@components/ClientComponentExample";
|
|
388
|
+
import { ServerComponentExample } from "@components/ServerComponentExample";
|
|
389
|
+
import { type Next14PageIntlayer, IntlayerClientProvider } from "next-intlayer";
|
|
390
|
+
import { IntlayerServerProvider, useIntlayer } from "next-intlayer/server";
|
|
391
|
+
|
|
392
|
+
const Page: Next14PageIntlayer = ({ params: { locale } }) => {
|
|
393
|
+
const content = useIntlayer("page", locale);
|
|
394
|
+
|
|
395
|
+
return (
|
|
396
|
+
<>
|
|
397
|
+
<p>
|
|
398
|
+
{content.getStarted.main}
|
|
399
|
+
<code>{content.getStarted.pageLink}</code>
|
|
400
|
+
</p>
|
|
401
|
+
|
|
402
|
+
<IntlayerServerProvider locale={locale}>
|
|
403
|
+
<IntlayerClientProvider locale={locale}>
|
|
404
|
+
<ServerComponentExample />
|
|
405
|
+
<ClientComponentExample />
|
|
406
|
+
</IntlayerClientProvider>
|
|
407
|
+
</IntlayerServerProvider>
|
|
408
|
+
</>
|
|
409
|
+
);
|
|
410
|
+
};
|
|
411
|
+
|
|
412
|
+
export default Page;
|
|
413
|
+
```
|
|
414
|
+
|
|
415
|
+
```jsx fileName="src/app/[locale]/page.mjx" codeFormat="esm"
|
|
416
|
+
import { ClientComponentExample } from "@components/ClientComponentExample";
|
|
417
|
+
import { ServerComponentExample } from "@components/ServerComponentExample";
|
|
418
|
+
import { IntlayerClientProvider } from "next-intlayer";
|
|
419
|
+
import { IntlayerServerProvider, useIntlayer } from "next-intlayer/server";
|
|
420
|
+
|
|
421
|
+
const Page = ({ params: { locale } }) => {
|
|
422
|
+
const content = useIntlayer("page", locale);
|
|
423
|
+
|
|
424
|
+
return (
|
|
425
|
+
<>
|
|
426
|
+
<p>
|
|
427
|
+
{content.getStarted.main}
|
|
428
|
+
<code>{content.getStarted.pageLink}</code>
|
|
429
|
+
</p>
|
|
430
|
+
|
|
431
|
+
<IntlayerClientProvider locale={locale}>
|
|
432
|
+
<IntlayerServerProvider locale={locale}>
|
|
433
|
+
<ClientComponentExample />
|
|
434
|
+
<ServerComponentExample />
|
|
435
|
+
</IntlayerServerProvider>
|
|
436
|
+
</IntlayerClientProvider>
|
|
437
|
+
</>
|
|
438
|
+
);
|
|
439
|
+
};
|
|
440
|
+
```
|
|
441
|
+
|
|
442
|
+
```jsx fileName="src/app/[locale]/page.csx" codeFormat="commonjs"
|
|
443
|
+
const { IntlayerClientProvider } = require("next-intlayer");
|
|
444
|
+
const { IntlayerServerProvider, useIntlayer } = require("next-intlayer/server");
|
|
445
|
+
|
|
446
|
+
const Page = ({ params: { locale } }) => {
|
|
447
|
+
const content = useIntlayer("page", locale);
|
|
448
|
+
|
|
449
|
+
return (
|
|
450
|
+
<>
|
|
451
|
+
<p>
|
|
452
|
+
{content.getStarted.main}
|
|
453
|
+
<code>{content.getStarted.pageLink}</code>
|
|
454
|
+
</p>
|
|
455
|
+
|
|
456
|
+
<IntlayerClientProvider locale={locale}>
|
|
457
|
+
<IntlayerServerProvider locale={locale}>
|
|
458
|
+
<ClientComponentExample />
|
|
459
|
+
<ServerComponentExample />
|
|
460
|
+
</IntlayerServerProvider>
|
|
461
|
+
</IntlayerClientProvider>
|
|
462
|
+
</>
|
|
463
|
+
);
|
|
464
|
+
};
|
|
465
|
+
```
|
|
466
|
+
|
|
467
|
+
- **`IntlayerClientProvider`** تُستخدم لتوفير اللغة المحلية لمكونات الجانب العميل. يمكن وضعها في أي مكون رئيسي، بما في ذلك التخطيط. ومع ذلك، يُوصى بوضعها في التخطيط لأن Next.js يشارك كود التخطيط عبر الصفحات، مما يجعله أكثر كفاءة. باستخدام `IntlayerClientProvider` في التخطيط، تتجنب إعادة تهيئته لكل صفحة، مما يحسن الأداء ويحافظ على سياق توطين متسق في جميع أنحاء التطبيق الخاص بك.
|
|
468
|
+
- **`IntlayerServerProvider`** تُستخدم لتوفير اللغة المحلية للأطفال على الخادم. لا يمكن تعيينها في التخطيط.
|
|
469
|
+
|
|
470
|
+
```tsx {4,7} fileName="src/components/ClientComponentExample.tsx" codeFormat="typescript"
|
|
471
|
+
"use client";
|
|
472
|
+
|
|
473
|
+
import type { FC } from "react";
|
|
474
|
+
import { useIntlayer } from "next-intlayer";
|
|
475
|
+
|
|
476
|
+
const ClientComponentExample: FC = () => {
|
|
477
|
+
const content = useIntlayer("client-component-example"); // إنشاء إعلان محتوى ذو صلة
|
|
478
|
+
|
|
479
|
+
return (
|
|
480
|
+
<div>
|
|
481
|
+
<h2>{content.title}</h2>
|
|
482
|
+
<p>{content.content}</p>
|
|
483
|
+
</div>
|
|
484
|
+
);
|
|
485
|
+
};
|
|
486
|
+
```
|
|
487
|
+
|
|
488
|
+
```jsx {3,6} fileName="src/components/ClientComponentExample.mjx" codeFormat="esm"
|
|
489
|
+
"use client";
|
|
490
|
+
|
|
491
|
+
import { useIntlayer } from "next-intlayer";
|
|
492
|
+
|
|
493
|
+
const ClientComponentExample = () => {
|
|
494
|
+
const content = useIntlayer("client-component-example"); // إنشاء إعلان محتوى ذو صلة
|
|
495
|
+
|
|
496
|
+
return (
|
|
497
|
+
<div>
|
|
498
|
+
<h2>{content.title}</h2>
|
|
499
|
+
<p>{content.content}</p>
|
|
500
|
+
</div>
|
|
501
|
+
);
|
|
502
|
+
};
|
|
503
|
+
```
|
|
504
|
+
|
|
505
|
+
```jsx {3,6} fileName="src/components/ClientComponentExample.csx" codeFormat="commonjs"
|
|
506
|
+
"use client";
|
|
507
|
+
|
|
508
|
+
const { useIntlayer } = require("next-intlayer");
|
|
509
|
+
|
|
510
|
+
const ClientComponentExample = () => {
|
|
511
|
+
const content = useIntlayer("client-component-example"); // إنشاء إعلان محتوى ذو صلة
|
|
512
|
+
|
|
513
|
+
return (
|
|
514
|
+
<div>
|
|
515
|
+
<h2>{content.title}</h2>
|
|
516
|
+
<p>{content.content}</p>
|
|
517
|
+
</div>
|
|
518
|
+
);
|
|
519
|
+
};
|
|
520
|
+
```
|
|
521
|
+
|
|
522
|
+
```tsx {2} fileName="src/components/ServerComponentExample.tsx" codeFormat="typescript"
|
|
523
|
+
import type { FC } from "react";
|
|
524
|
+
import { useIntlayer } from "next-intlayer/server";
|
|
525
|
+
|
|
526
|
+
const ServerComponentExample: FC = () => {
|
|
527
|
+
const content = useIntlayer("server-component-example"); // إنشاء إعلان محتوى ذو صلة
|
|
528
|
+
|
|
529
|
+
return (
|
|
530
|
+
<div>
|
|
531
|
+
<h2>{content.title}</h2>
|
|
532
|
+
<p>{content.content}</p>
|
|
533
|
+
</div>
|
|
534
|
+
);
|
|
535
|
+
};
|
|
536
|
+
```
|
|
537
|
+
|
|
538
|
+
```jsx {1} fileName="src/components/ServerComponentExample.mjx" codeFormat="esm"
|
|
539
|
+
import { useIntlayer } from "next-intlayer/server";
|
|
540
|
+
|
|
541
|
+
const ServerComponentExample = () => {
|
|
542
|
+
const content = useIntlayer("server-component-example"); // إنشاء إعلان محتوى ذو صلة
|
|
543
|
+
|
|
544
|
+
return (
|
|
545
|
+
<div>
|
|
546
|
+
<h2>{content.title}</h2>
|
|
547
|
+
<p>{content.content}</p>
|
|
548
|
+
</div>
|
|
549
|
+
);
|
|
550
|
+
};
|
|
551
|
+
```
|
|
552
|
+
|
|
553
|
+
```jsx {1} fileName="src/components/ServerComponentExample.csx" codeFormat="commonjs"
|
|
554
|
+
const { useIntlayer } = require("next-intlayer/server");
|
|
555
|
+
|
|
556
|
+
const ServerComponentExample = () => {
|
|
557
|
+
const content = useIntlayer("server-component-example"); // إنشاء إعلان محتوى ذو صلة
|
|
558
|
+
|
|
559
|
+
return (
|
|
560
|
+
<div>
|
|
561
|
+
<h2>{content.title}</h2>
|
|
562
|
+
<p>{content.content}</p>
|
|
563
|
+
</div>
|
|
564
|
+
);
|
|
565
|
+
};
|
|
566
|
+
```
|
|
567
|
+
|
|
568
|
+
> إذا كنت تريد استخدام المحتوى الخاص بك في سمة `string`، مثل `alt`، `title`، `href`، `aria-label`، إلخ، يجب عليك استدعاء قيمة الوظيفة، مثل:
|
|
569
|
+
|
|
570
|
+
> ```jsx
|
|
571
|
+
>
|
|
572
|
+
> ```
|
|
573
|
+
|
|
574
|
+
> <img src={content.image.src.value} alt={content.image.value} />
|
|
575
|
+
|
|
576
|
+
> ```
|
|
577
|
+
>
|
|
578
|
+
> ```
|
|
579
|
+
|
|
580
|
+
> لمعرفة المزيد عن الخطاف `useIntlayer`، راجع [التوثيق](https://github.com/aymericzip/intlayer/blob/main/docs/ar/packages/next-intlayer/useIntlayer.md).
|
|
581
|
+
|
|
582
|
+
### (اختياري) الخطوة 8: تدويل البيانات الوصفية الخاصة بك
|
|
583
|
+
|
|
584
|
+
في حال كنت ترغب في تدويل البيانات الوصفية الخاصة بك، مثل عنوان الصفحة، يمكنك استخدام وظيفة `generateMetadata` المقدمة من Next.js. داخل الوظيفة، استخدم وظيفة `getTranslation` لترجمة البيانات الوصفية الخاصة بك.
|
|
585
|
+
|
|
586
|
+
````typescript fileName="src/app/[locale]/layout.tsx or src/app/[locale]/page.tsx" codeFormat="typescript"
|
|
587
|
+
import {
|
|
588
|
+
type IConfigLocales,
|
|
589
|
+
getTranslation,
|
|
590
|
+
getMultilingualUrls,
|
|
591
|
+
} from "intlayer";
|
|
592
|
+
import type { Metadata } from "next";
|
|
593
|
+
import type { LocalParams } from "next-intlayer";
|
|
594
|
+
|
|
595
|
+
export const generateMetadata = ({
|
|
596
|
+
params: { locale },
|
|
597
|
+
}: LocalParams): Metadata => {
|
|
598
|
+
const t = <T>(content: IConfigLocales<T>) => getTranslation(content, locale);
|
|
599
|
+
|
|
600
|
+
/**
|
|
601
|
+
* ينشئ كائنًا يحتوي على جميع الروابط لكل لغة.
|
|
602
|
+
*
|
|
603
|
+
* مثال:
|
|
604
|
+
* ```ts
|
|
605
|
+
* getMultilingualUrls('/about');
|
|
606
|
+
*
|
|
607
|
+
* // النتيجة
|
|
608
|
+
* // {
|
|
609
|
+
* // en: '/about',
|
|
610
|
+
* // fr: '/fr/about',
|
|
611
|
+
* // es: '/es/about',
|
|
612
|
+
* // }
|
|
613
|
+
* ```
|
|
614
|
+
*/
|
|
615
|
+
const multilingualUrls = getMultilingualUrls("/");
|
|
616
|
+
|
|
617
|
+
return {
|
|
618
|
+
title: t<string>({
|
|
619
|
+
ar: "عنواني",
|
|
620
|
+
en: "My title",
|
|
621
|
+
fr: "Mon titre",
|
|
622
|
+
es: "Mi título",
|
|
623
|
+
}),
|
|
624
|
+
description: t({
|
|
625
|
+
ar: "وصف صفحتي",
|
|
626
|
+
en: "My description",
|
|
627
|
+
fr: "Ma description",
|
|
628
|
+
es: "Mi descripción",
|
|
629
|
+
}),
|
|
630
|
+
alternates: {
|
|
631
|
+
canonical: multilingualUrls[locale as keyof typeof multilingualUrls],
|
|
632
|
+
languages: { ...multilingualUrls, "x-default": "/" },
|
|
633
|
+
},
|
|
634
|
+
openGraph: {
|
|
635
|
+
url: multilingualUrls[locale],
|
|
636
|
+
},
|
|
637
|
+
};
|
|
638
|
+
};
|
|
639
|
+
|
|
640
|
+
// ... بقية الكود
|
|
641
|
+
````
|
|
642
|
+
|
|
643
|
+
````javascript fileName="src/app/[locale]/layout.msx or src/app/[locale]/page.msx" codeFormat="javascript"
|
|
644
|
+
import { getTranslation, getMultilingualUrls } from "intlayer";
|
|
645
|
+
|
|
646
|
+
export const generateMetadata = ({ params: { locale } }) => {
|
|
647
|
+
const t = (content) => getTranslation(content, locale);
|
|
648
|
+
|
|
649
|
+
/**
|
|
650
|
+
* ينشئ كائنًا يحتوي على جميع الروابط لكل لغة.
|
|
651
|
+
*
|
|
652
|
+
* مثال:
|
|
653
|
+
* ```ts
|
|
654
|
+
* getMultilingualUrls('/about');
|
|
655
|
+
*
|
|
656
|
+
* // النتيجة
|
|
657
|
+
* // {
|
|
658
|
+
* // en: '/about',
|
|
659
|
+
* // fr: '/fr/about',
|
|
660
|
+
* // es: '/es/about',
|
|
661
|
+
* // }
|
|
662
|
+
* ```
|
|
663
|
+
*/
|
|
664
|
+
const multilingualUrls = getMultilingualUrls("/");
|
|
665
|
+
|
|
666
|
+
return {
|
|
667
|
+
title: t({
|
|
668
|
+
ar: "عنواني",
|
|
669
|
+
en: "My title",
|
|
670
|
+
fr: "Mon titre",
|
|
671
|
+
es: "Mi título",
|
|
672
|
+
}),
|
|
673
|
+
description: t({
|
|
674
|
+
ar: "وصف صفحتي",
|
|
675
|
+
en: "My description",
|
|
676
|
+
fr: "Ma description",
|
|
677
|
+
es: "Mi descripción",
|
|
678
|
+
}),
|
|
679
|
+
alternates: {
|
|
680
|
+
canonical: multilingualUrls[locale],
|
|
681
|
+
languages: { ...multilingualUrls, "x-default": "/" },
|
|
682
|
+
},
|
|
683
|
+
openGraph: {
|
|
684
|
+
url: multilingualUrls[locale],
|
|
685
|
+
},
|
|
686
|
+
};
|
|
687
|
+
};
|
|
688
|
+
|
|
689
|
+
// ... بقية الكود
|
|
690
|
+
````
|
|
691
|
+
|
|
692
|
+
````javascript fileName="src/app/[locale]/layout.cjs or src/app/[locale]/page.cjs" codeFormat="javascript"
|
|
693
|
+
const { getTranslation, getMultilingualUrls } = require("intlayer");
|
|
694
|
+
|
|
695
|
+
module.exports.generateMetadata = ({ params: { locale } }) => {
|
|
696
|
+
const t = (content) => getTranslation(content, locale);
|
|
697
|
+
|
|
698
|
+
/**
|
|
699
|
+
* ينشئ كائنًا يحتوي على جميع الروابط لكل لغة.
|
|
700
|
+
*
|
|
701
|
+
* مثال:
|
|
702
|
+
* ```ts
|
|
703
|
+
* getMultilingualUrls('/about');
|
|
704
|
+
*
|
|
705
|
+
* // النتيجة
|
|
706
|
+
* // {
|
|
707
|
+
* // en: '/about',
|
|
708
|
+
* // fr: '/fr/about',
|
|
709
|
+
* // es: '/es/about',
|
|
710
|
+
* // }
|
|
711
|
+
* ```
|
|
712
|
+
*/
|
|
713
|
+
const multilingualUrls = getMultilingualUrls("/");
|
|
714
|
+
|
|
715
|
+
return {
|
|
716
|
+
title: t({
|
|
717
|
+
ar: "عنواني",
|
|
718
|
+
en: "My title",
|
|
719
|
+
fr: "Mon titre",
|
|
720
|
+
es: "Mi título",
|
|
721
|
+
}),
|
|
722
|
+
description: t({
|
|
723
|
+
ar: "وصف صفحتي",
|
|
724
|
+
en: "My description",
|
|
725
|
+
fr: "Ma description",
|
|
726
|
+
es: "Mi descripción",
|
|
727
|
+
}),
|
|
728
|
+
alternates: {
|
|
729
|
+
canonical: multilingualUrls[locale],
|
|
730
|
+
languages: { ...multilingualUrls, "x-default": "/" },
|
|
731
|
+
},
|
|
732
|
+
openGraph: {
|
|
733
|
+
url: multilingualUrls[locale],
|
|
734
|
+
},
|
|
735
|
+
};
|
|
736
|
+
};
|
|
737
|
+
|
|
738
|
+
// ... بقية الكود
|
|
739
|
+
````
|
|
740
|
+
|
|
741
|
+
> لمعرفة المزيد عن تحسين البيانات الوصفية [راجع التوثيق الرسمي لـ Next.js](https://nextjs.org/docs/app/building-your-application/optimizing/metadata).
|
|
742
|
+
|
|
743
|
+
### (اختياري) الخطوة 9: تدويل ملف sitemap.xml و robots.txt
|
|
744
|
+
|
|
745
|
+
لتدويل ملف `sitemap.xml` و `robots.txt`، يمكنك استخدام وظيفة `getMultilingualUrls` المقدمة من Intlayer. تتيح لك هذه الوظيفة إنشاء روابط متعددة اللغات لخريطة الموقع.
|
|
746
|
+
|
|
747
|
+
```tsx fileName="src/app/sitemap.ts" codeFormat="typescript"
|
|
748
|
+
import { getMultilingualUrls } from "intlayer";
|
|
749
|
+
import type { MetadataRoute } from "next";
|
|
750
|
+
|
|
751
|
+
const sitemap = (): MetadataRoute.Sitemap => [
|
|
752
|
+
{
|
|
753
|
+
url: "https://example.com",
|
|
754
|
+
alternates: {
|
|
755
|
+
languages: getMultilingualUrls("https://example.com"),
|
|
756
|
+
},
|
|
757
|
+
},
|
|
758
|
+
{
|
|
759
|
+
url: "https://example.com/login",
|
|
760
|
+
alternates: {
|
|
761
|
+
languages: getMultilingualUrls("https://example.com/login"),
|
|
762
|
+
},
|
|
763
|
+
},
|
|
764
|
+
{
|
|
765
|
+
url: "https://example.com/register",
|
|
766
|
+
alternates: {
|
|
767
|
+
languages: getMultilingualUrls("https://example.com/register"),
|
|
768
|
+
},
|
|
769
|
+
},
|
|
770
|
+
];
|
|
771
|
+
|
|
772
|
+
export default sitemap;
|
|
773
|
+
|
|
774
|
+
import { getMultilingualUrls } from "intlayer";
|
|
775
|
+
|
|
776
|
+
const sitemap = () => [
|
|
777
|
+
{
|
|
778
|
+
url: "https://example.com",
|
|
779
|
+
alternates: {
|
|
780
|
+
languages: getMultilingualUrls("https://example.com"),
|
|
781
|
+
},
|
|
782
|
+
},
|
|
783
|
+
{
|
|
784
|
+
url: "https://example.com/login",
|
|
785
|
+
alternates: {
|
|
786
|
+
languages: getMultilingualUrls("https://example.com/login"),
|
|
787
|
+
},
|
|
788
|
+
},
|
|
789
|
+
{
|
|
790
|
+
url: "https://example.com/register",
|
|
791
|
+
alternates: {
|
|
792
|
+
languages: getMultilingualUrls("https://example.com/register"),
|
|
793
|
+
},
|
|
794
|
+
},
|
|
795
|
+
];
|
|
796
|
+
|
|
797
|
+
export default sitemap;
|
|
798
|
+
```
|
|
799
|
+
|
|
800
|
+
```jsx fileName="src/app/sitemap.csx" codeFormat="commonjs"
|
|
801
|
+
const { getMultilingualUrls } = require("intlayer");
|
|
802
|
+
|
|
803
|
+
const sitemap = () => [
|
|
804
|
+
{
|
|
805
|
+
url: "https://example.com",
|
|
806
|
+
alternates: {
|
|
807
|
+
languages: getMultilingualUrls("https://example.com"),
|
|
808
|
+
},
|
|
809
|
+
},
|
|
810
|
+
{
|
|
811
|
+
url: "https://example.com/login",
|
|
812
|
+
alternates: {
|
|
813
|
+
languages: getMultilingualUrls("https://example.com/login"),
|
|
814
|
+
},
|
|
815
|
+
},
|
|
816
|
+
{
|
|
817
|
+
url: "https://example.com/register",
|
|
818
|
+
alternates: {
|
|
819
|
+
languages: getMultilingualUrls("https://example.com/register"),
|
|
820
|
+
},
|
|
821
|
+
},
|
|
822
|
+
];
|
|
823
|
+
|
|
824
|
+
module.exports = sitemap;
|
|
825
|
+
```
|
|
826
|
+
|
|
827
|
+
```tsx fileName="src/app/robots.ts" codeFormat="typescript"
|
|
828
|
+
import type { MetadataRoute } from "next";
|
|
829
|
+
import { getMultilingualUrls } from "intlayer";
|
|
830
|
+
|
|
831
|
+
const getAllMultilingualUrls = (urls: string[]) =>
|
|
832
|
+
urls.flatMap((url) => Object.values(getMultilingualUrls(url)) as string[]);
|
|
833
|
+
|
|
834
|
+
const robots = (): MetadataRoute.Robots => ({
|
|
835
|
+
rules: {
|
|
836
|
+
userAgent: "*",
|
|
837
|
+
allow: ["/"],
|
|
838
|
+
disallow: getAllMultilingualUrls(["/login", "/register"]),
|
|
839
|
+
},
|
|
840
|
+
host: "https://example.com",
|
|
841
|
+
sitemap: `https://example.com/sitemap.xml`,
|
|
842
|
+
});
|
|
843
|
+
|
|
844
|
+
export default robots;
|
|
845
|
+
```
|
|
846
|
+
|
|
847
|
+
```jsx fileName="src/app/robots.mjx" codeFormat="esm"
|
|
848
|
+
import { getMultilingualUrls } from "intlayer";
|
|
849
|
+
|
|
850
|
+
const getAllMultilingualUrls = (urls) =>
|
|
851
|
+
urls.flatMap((url) => Object.values(getMultilingualUrls(url)));
|
|
852
|
+
|
|
853
|
+
const robots = () => ({
|
|
854
|
+
rules: {
|
|
855
|
+
userAgent: "*",
|
|
856
|
+
allow: ["/"],
|
|
857
|
+
disallow: getAllMultilingualUrls(["/login", "/register"]),
|
|
858
|
+
},
|
|
859
|
+
host: "https://example.com",
|
|
860
|
+
sitemap: `https://example.com/sitemap.xml`,
|
|
861
|
+
});
|
|
862
|
+
|
|
863
|
+
export default robots;
|
|
864
|
+
```
|
|
865
|
+
|
|
866
|
+
```jsx fileName="src/app/robots.csx" codeFormat="commonjs"
|
|
867
|
+
const { getMultilingualUrls } = require("intlayer");
|
|
868
|
+
|
|
869
|
+
const getAllMultilingualUrls = (urls) =>
|
|
870
|
+
urls.flatMap((url) => Object.values(getMultilingualUrls(url)));
|
|
871
|
+
|
|
872
|
+
const robots = () => ({
|
|
873
|
+
rules: {
|
|
874
|
+
userAgent: "*",
|
|
875
|
+
allow: ["/"],
|
|
876
|
+
disallow: getAllMultilingualUrls(["/login", "/register"]),
|
|
877
|
+
},
|
|
878
|
+
host: "https://example.com",
|
|
879
|
+
sitemap: `https://example.com/sitemap.xml`,
|
|
880
|
+
});
|
|
881
|
+
|
|
882
|
+
module.exports = robots;
|
|
883
|
+
```
|
|
884
|
+
|
|
885
|
+
> تعرف على المزيد حول تحسين خريطة الموقع [في الوثائق الرسمية لـ Next.js](https://nextjs.org/docs/app/api-reference/file-conventions/metadata/sitemap). تعرف على المزيد حول تحسين robots.txt [في الوثائق الرسمية لـ Next.js](https://nextjs.org/docs/app/api-reference/file-conventions/metadata/robots).
|
|
886
|
+
|
|
887
|
+
### (اختياري) الخطوة 10: تغيير لغة المحتوى الخاص بك
|
|
888
|
+
|
|
889
|
+
لتغيير لغة المحتوى الخاص بك في Next.js، الطريقة الموصى بها هي استخدام مكون `Link` لإعادة توجيه المستخدمين إلى الصفحة المحلية المناسبة. يتيح مكون `Link` جلب الصفحة مسبقًا، مما يساعد على تجنب إعادة تحميل الصفحة بالكامل.
|
|
890
|
+
|
|
891
|
+
```tsx fileName="src/components/LocaleSwitcher.tsx" codeFormat="typescript"
|
|
892
|
+
"use client";
|
|
893
|
+
|
|
894
|
+
import {
|
|
895
|
+
Locales,
|
|
896
|
+
getHTMLTextDir,
|
|
897
|
+
getLocaleName,
|
|
898
|
+
getLocalizedUrl,
|
|
899
|
+
} from "intlayer";
|
|
900
|
+
import { useLocale } from "next-intlayer";
|
|
901
|
+
import { type FC } from "react";
|
|
902
|
+
import Link from "next/link";
|
|
903
|
+
|
|
904
|
+
const LocaleSwitcher: FC = () => {
|
|
905
|
+
const { locale, pathWithoutLocale, availableLocales } = useLocale();
|
|
906
|
+
const { setLocaleCookie } = useLocaleCookie();
|
|
907
|
+
|
|
908
|
+
return (
|
|
909
|
+
<div>
|
|
910
|
+
<button popoverTarget="localePopover">{getLocaleName(locale)}</button>
|
|
911
|
+
<div id="localePopover" popover="auto">
|
|
912
|
+
{availableLocales.map((localeItem) => (
|
|
913
|
+
<Link
|
|
914
|
+
href={getLocalizedUrl(pathWithoutLocale, localeItem)}
|
|
915
|
+
hrefLang={localeItem}
|
|
916
|
+
key={localeItem}
|
|
917
|
+
aria-current={locale === localeItem ? "page" : undefined}
|
|
918
|
+
onClick={() => setLocaleCookie(localeItem)}
|
|
919
|
+
>
|
|
920
|
+
<span>
|
|
921
|
+
{/* اللغة المحلية - مثال: FR */}
|
|
922
|
+
{localeItem}
|
|
923
|
+
</span>
|
|
924
|
+
<span>
|
|
925
|
+
{/* اللغة في لغتها المحلية - مثال: Français */}
|
|
926
|
+
{getLocaleName(localeItem, locale)}
|
|
927
|
+
</span>
|
|
928
|
+
<span dir={getHTMLTextDir(localeItem)} lang={localeItem}>
|
|
929
|
+
{/* اللغة في اللغة الحالية - مثال: Francés مع تعيين اللغة الحالية إلى Locales.SPANISH */}
|
|
930
|
+
{getLocaleName(localeItem)}
|
|
931
|
+
</span>
|
|
932
|
+
<span dir="ltr" lang={Locales.ENGLISH}>
|
|
933
|
+
{/* اللغة باللغة الإنجليزية - مثال: French */}
|
|
934
|
+
{getLocaleName(localeItem, Locales.ENGLISH)}
|
|
935
|
+
</span>
|
|
936
|
+
</Link>
|
|
937
|
+
))}
|
|
938
|
+
</div>
|
|
939
|
+
</div>
|
|
940
|
+
);
|
|
941
|
+
};
|
|
942
|
+
```
|
|
943
|
+
|
|
944
|
+
```jsx fileName="src/components/LocaleSwitcher.msx" codeFormat="esm"
|
|
945
|
+
"use client";
|
|
946
|
+
|
|
947
|
+
import {
|
|
948
|
+
Locales,
|
|
949
|
+
getHTMLTextDir,
|
|
950
|
+
getLocaleName,
|
|
951
|
+
getLocalizedUrl,
|
|
952
|
+
} from "intlayer";
|
|
953
|
+
import { useLocale } from "next-intlayer";
|
|
954
|
+
import Link from "next/link";
|
|
955
|
+
|
|
956
|
+
const LocaleSwitcher = () => {
|
|
957
|
+
const { locale, pathWithoutLocale, availableLocales } = useLocale();
|
|
958
|
+
const { setLocaleCookie } = useLocaleCookie();
|
|
959
|
+
|
|
960
|
+
return (
|
|
961
|
+
<div>
|
|
962
|
+
<button popoverTarget="localePopover">{getLocaleName(locale)}</button>
|
|
963
|
+
<div id="localePopover" popover="auto">
|
|
964
|
+
{availableLocales.map((localeItem) => (
|
|
965
|
+
<Link
|
|
966
|
+
href={getLocalizedUrl(pathWithoutLocale, localeItem)}
|
|
967
|
+
hrefLang={localeItem}
|
|
968
|
+
key={localeItem}
|
|
969
|
+
aria-current={locale === localeItem ? "page" : undefined}
|
|
970
|
+
onClick={() => setLocaleCookie(localeItem)}
|
|
971
|
+
>
|
|
972
|
+
<span>
|
|
973
|
+
{/* اللغة المحلية - مثال: FR */}
|
|
974
|
+
{localeItem}
|
|
975
|
+
</span>
|
|
976
|
+
<span>
|
|
977
|
+
{/* اللغة في لغتها المحلية - مثال: Français */}
|
|
978
|
+
{getLocaleName(localeItem, locale)}
|
|
979
|
+
</span>
|
|
980
|
+
<span dir={getHTMLTextDir(localeItem)} lang={localeItem}>
|
|
981
|
+
{/* اللغة في اللغة الحالية - مثال: Francés مع تعيين اللغة الحالية إلى Locales.SPANISH */}
|
|
982
|
+
{getLocaleName(localeItem)}
|
|
983
|
+
</span>
|
|
984
|
+
<span dir="ltr" lang={Locales.ENGLISH}>
|
|
985
|
+
{/* اللغة باللغة الإنجليزية - مثال: French */}
|
|
986
|
+
{getLocaleName(localeItem, Locales.ENGLISH)}
|
|
987
|
+
</span>
|
|
988
|
+
</Link>
|
|
989
|
+
))}
|
|
990
|
+
</div>
|
|
991
|
+
</div>
|
|
992
|
+
);
|
|
993
|
+
};
|
|
994
|
+
```
|
|
995
|
+
|
|
996
|
+
```jsx fileName="src/components/LocaleSwitcher.csx" codeFormat="commonjs"
|
|
997
|
+
"use client";
|
|
998
|
+
|
|
999
|
+
const {
|
|
1000
|
+
Locales,
|
|
1001
|
+
getHTMLTextDir,
|
|
1002
|
+
getLocaleName,
|
|
1003
|
+
getLocalizedUrl,
|
|
1004
|
+
} = require("intlayer");
|
|
1005
|
+
const { useLocale } = require("next-intlayer");
|
|
1006
|
+
const Link = require("next/link");
|
|
1007
|
+
|
|
1008
|
+
const LocaleSwitcher = () => {
|
|
1009
|
+
const { locale, pathWithoutLocale, availableLocales } = useLocale();
|
|
1010
|
+
const { setLocaleCookie } = useLocaleCookie();
|
|
1011
|
+
|
|
1012
|
+
return (
|
|
1013
|
+
<div>
|
|
1014
|
+
<button popoverTarget="localePopover">{getLocaleName(locale)}</button>
|
|
1015
|
+
<div id="localePopover" popover="auto">
|
|
1016
|
+
{availableLocales.map((localeItem) => (
|
|
1017
|
+
<Link
|
|
1018
|
+
href={getLocalizedUrl(pathWithoutLocale, localeItem)}
|
|
1019
|
+
hrefLang={localeItem}
|
|
1020
|
+
key={localeItem}
|
|
1021
|
+
aria-current={locale === localeItem ? "page" : undefined}
|
|
1022
|
+
onClick={() => setLocaleCookie(localeItem)}
|
|
1023
|
+
>
|
|
1024
|
+
<span>
|
|
1025
|
+
{/* اللغة المحلية - مثال: FR */}
|
|
1026
|
+
{localeItem}
|
|
1027
|
+
</span>
|
|
1028
|
+
<span>
|
|
1029
|
+
{/* اللغة في لغتها المحلية - مثال: Français */}
|
|
1030
|
+
{getLocaleName(localeItem, locale)}
|
|
1031
|
+
</span>
|
|
1032
|
+
<span dir={getHTMLTextDir(localeItem)} lang={localeItem}>
|
|
1033
|
+
{/* اللغة في اللغة الحالية - مثال: Francés مع تعيين اللغة الحالية إلى Locales.SPANISH */}
|
|
1034
|
+
---
|
|
1035
|
+
</span>
|
|
1036
|
+
<span dir="ltr" lang={Locales.ENGLISH}>
|
|
1037
|
+
{/* اللغة بالإنجليزية - على سبيل المثال الفرنسية */}
|
|
1038
|
+
{getLocaleName(localeItem, Locales.ENGLISH)}
|
|
1039
|
+
</span>
|
|
1040
|
+
</Link>
|
|
1041
|
+
))}
|
|
1042
|
+
</div>
|
|
1043
|
+
</div>
|
|
1044
|
+
);
|
|
1045
|
+
};
|
|
1046
|
+
```
|
|
1047
|
+
|
|
1048
|
+
> مراجع التوثيق:
|
|
1049
|
+
|
|
1050
|
+
> - [`useLocale` hook](https://github.com/aymericzip/intlayer/blob/main/docs/ar/packages/next-intlayer/useLocale.md)
|
|
1051
|
+
|
|
1052
|
+
> - [`getLocaleName` hook](https://github.com/aymericzip/intlayer/blob/main/docs/ar/packages/intlayer/getLocaleName.md)
|
|
1053
|
+
|
|
1054
|
+
> - [`getLocalizedUrl` hook](https://github.com/aymericzip/intlayer/blob/main/docs/ar/packages/intlayer/getLocalizedUrl.md)
|
|
1055
|
+
|
|
1056
|
+
> - [`getHTMLTextDir` hook](https://github.com/aymericzip/intlayer/blob/main/docs/ar/packages/intlayer/getHTMLTextDir.md)
|
|
1057
|
+
|
|
1058
|
+
> - [`hrefLang` attribute](https://developers.google.com/search/docs/specialty/international/localized-versions?hl=ar)
|
|
1059
|
+
|
|
1060
|
+
> - [`lang` attribute](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes/lang)
|
|
1061
|
+
|
|
1062
|
+
> - [`dir` attribute](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes/dir)
|
|
1063
|
+
|
|
1064
|
+
> - [`aria-current` attribute](https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Attributes/aria-current)
|
|
1065
|
+
|
|
1066
|
+
### (اختياري) الخطوة 11: إنشاء مكون رابط محلي
|
|
1067
|
+
|
|
1068
|
+
لضمان أن التنقل في تطبيقك يحترم اللغة الحالية، يمكنك إنشاء مكون `Link` مخصص. يقوم هذا المكون تلقائيًا بإضافة بادئة لعناوين URL الداخلية باللغة الحالية. على سبيل المثال، عندما ينقر مستخدم يتحدث الفرنسية على رابط إلى صفحة "حول"، يتم توجيهه إلى `/ar/about` بدلاً من `/about`.
|
|
1069
|
+
|
|
1070
|
+
هذا السلوك مفيد لعدة أسباب:
|
|
1071
|
+
|
|
1072
|
+
- **تحسين محركات البحث وتجربة المستخدم**: تساعد عناوين URL المحلية محركات البحث على فهرسة الصفحات الخاصة باللغة بشكل صحيح وتقديم محتوى للمستخدمين بلغتهم المفضلة.
|
|
1073
|
+
- **الاتساق**: باستخدام رابط محلي في جميع أنحاء تطبيقك، تضمن أن التنقل يظل ضمن اللغة الحالية، مما يمنع التبديل غير المتوقع للغة.
|
|
1074
|
+
- **سهولة الصيانة**: تبسيط منطق التوطين في مكون واحد يجعل إدارة عناوين URL أسهل، مما يجعل قاعدة الكود الخاصة بك أسهل في الصيانة والتوسيع مع نمو تطبيقك.
|
|
1075
|
+
|
|
1076
|
+
فيما يلي تنفيذ مكون `Link` المحلي باستخدام TypeScript:
|
|
1077
|
+
|
|
1078
|
+
```tsx fileName="src/components/Link.tsx" codeFormat="typescript"
|
|
1079
|
+
"use client";
|
|
1080
|
+
|
|
1081
|
+
import { getLocalizedUrl } from "intlayer";
|
|
1082
|
+
import NextLink, { type LinkProps as NextLinkProps } from "next/link";
|
|
1083
|
+
import { useLocale } from "next-intlayer";
|
|
1084
|
+
import { forwardRef, PropsWithChildren, type ForwardedRef } from "react";
|
|
1085
|
+
|
|
1086
|
+
/**
|
|
1087
|
+
* وظيفة مساعدة للتحقق مما إذا كان عنوان URL معين خارجيًا.
|
|
1088
|
+
* إذا بدأ عنوان URL بـ http:// أو https://، فإنه يعتبر خارجيًا.
|
|
1089
|
+
*/
|
|
1090
|
+
export const checkIsExternalLink = (href?: string): boolean =>
|
|
1091
|
+
/^https?:\/\//.test(href ?? "");
|
|
1092
|
+
|
|
1093
|
+
/**
|
|
1094
|
+
* مكون رابط مخصص يتكيف مع خاصية href بناءً على اللغة الحالية.
|
|
1095
|
+
* بالنسبة للروابط الداخلية، يستخدم `getLocalizedUrl` لإضافة بادئة للعنوان باللغة (مثل /ar/about).
|
|
1096
|
+
* يضمن ذلك أن يظل التنقل ضمن سياق اللغة نفسها.
|
|
1097
|
+
*/
|
|
1098
|
+
export const Link = forwardRef<
|
|
1099
|
+
HTMLAnchorElement,
|
|
1100
|
+
PropsWithChildren<NextLinkProps>
|
|
1101
|
+
>(({ href, children, ...props }, ref: ForwardedRef<HTMLAnchorElement>) => {
|
|
1102
|
+
const { locale } = useLocale();
|
|
1103
|
+
const isExternalLink = checkIsExternalLink(href.toString());
|
|
1104
|
+
|
|
1105
|
+
// إذا كان الرابط داخليًا وتم توفير href صالح، احصل على عنوان URL المحلي.
|
|
1106
|
+
const hrefI18n: NextLinkProps["href"] =
|
|
1107
|
+
href && !isExternalLink ? getLocalizedUrl(href.toString(), locale) : href;
|
|
1108
|
+
|
|
1109
|
+
return (
|
|
1110
|
+
<NextLink href={hrefI18n} ref={ref} {...props}>
|
|
1111
|
+
{children}
|
|
1112
|
+
</NextLink>
|
|
1113
|
+
);
|
|
1114
|
+
});
|
|
1115
|
+
|
|
1116
|
+
Link.displayName = "Link";
|
|
1117
|
+
```
|
|
1118
|
+
|
|
1119
|
+
```jsx fileName="src/components/Link.mjx" codeFormat="esm"
|
|
1120
|
+
'use client';
|
|
1121
|
+
|
|
1122
|
+
import { getLocalizedUrl } from 'intlayer';
|
|
1123
|
+
import NextLink, { type LinkProps as NextLinkProps } from 'next/link';
|
|
1124
|
+
import { useLocale } from 'next-intlayer';
|
|
1125
|
+
import { forwardRef, PropsWithChildren, type ForwardedRef } from 'react';
|
|
1126
|
+
|
|
1127
|
+
/**
|
|
1128
|
+
* وظيفة مساعدة للتحقق مما إذا كان عنوان URL معين خارجيًا.
|
|
1129
|
+
* إذا بدأ عنوان URL بـ http:// أو https://، فإنه يعتبر خارجيًا.
|
|
1130
|
+
*/
|
|
1131
|
+
export const checkIsExternalLink = (href) =>
|
|
1132
|
+
/^https?:\/\//.test(href ?? '');
|
|
1133
|
+
|
|
1134
|
+
/**
|
|
1135
|
+
* مكون رابط مخصص يتكيف مع خاصية href بناءً على اللغة الحالية.
|
|
1136
|
+
* بالنسبة للروابط الداخلية، يستخدم `getLocalizedUrl` لإضافة بادئة للعنوان باللغة (مثل /ar/about).
|
|
1137
|
+
* يضمن ذلك أن يظل التنقل ضمن سياق اللغة نفسها.
|
|
1138
|
+
*/
|
|
1139
|
+
export const Link = forwardRef(({ href, children, ...props }, ref) => {
|
|
1140
|
+
const { locale } = useLocale();
|
|
1141
|
+
const isExternalLink = checkIsExternalLink(href.toString());
|
|
1142
|
+
|
|
1143
|
+
// إذا كان الرابط داخليًا وتم توفير href صالح، احصل على عنوان URL المحلي.
|
|
1144
|
+
const hrefI18n =
|
|
1145
|
+
href && !isExternalLink ? getLocalizedUrl(href.toString(), locale) : href;
|
|
1146
|
+
|
|
1147
|
+
return (
|
|
1148
|
+
<NextLink href={hrefI18n} ref={ref} {...props}>
|
|
1149
|
+
{children}
|
|
1150
|
+
</NextLink>
|
|
1151
|
+
);
|
|
1152
|
+
});
|
|
1153
|
+
|
|
1154
|
+
Link.displayName = 'Link';
|
|
1155
|
+
```
|
|
1156
|
+
|
|
1157
|
+
```jsx fileName="src/components/Link.csx" codeFormat="commonjs"
|
|
1158
|
+
'use client';
|
|
1159
|
+
|
|
1160
|
+
const { getLocalizedUrl } = require("intlayer");
|
|
1161
|
+
const NextLink = require("next/link");
|
|
1162
|
+
const { useLocale } = require("next-intlayer");
|
|
1163
|
+
const { forwardRef } = require("react");
|
|
1164
|
+
|
|
1165
|
+
/**
|
|
1166
|
+
* وظيفة مساعدة للتحقق مما إذا كان عنوان URL معين خارجيًا.
|
|
1167
|
+
* إذا بدأ عنوان URL بـ http:// أو https://، فإنه يعتبر خارجيًا.
|
|
1168
|
+
*/
|
|
1169
|
+
const checkIsExternalLink = (href) =>
|
|
1170
|
+
/^https?:\/\//.test(href ?? '');
|
|
1171
|
+
|
|
1172
|
+
|
|
1173
|
+
const Link = forwardRef(({ href, children, ...props }, ref) => {
|
|
1174
|
+
const { locale } = useLocale();
|
|
1175
|
+
const isExternalLink = checkIsExternalLink(href.toString());
|
|
1176
|
+
|
|
1177
|
+
// إذا كان الرابط داخليًا وتم توفير href صالح، احصل على عنوان URL المحلي.
|
|
1178
|
+
const hrefI18n: NextLinkProps['href'] =
|
|
1179
|
+
href && !isExternalLink ? getLocalizedUrl(href.toString(), locale) : href;
|
|
1180
|
+
|
|
1181
|
+
return (
|
|
1182
|
+
<NextLink href={hrefI18n} ref={ref} {...props}>
|
|
1183
|
+
{children}
|
|
1184
|
+
</NextLink>
|
|
1185
|
+
);
|
|
1186
|
+
});
|
|
1187
|
+
|
|
1188
|
+
Link.displayName = 'Link';
|
|
1189
|
+
```
|
|
1190
|
+
|
|
1191
|
+
#### كيف يعمل
|
|
1192
|
+
|
|
1193
|
+
- **اكتشاف الروابط الخارجية**:
|
|
1194
|
+
تحدد وظيفة المساعدة `checkIsExternalLink` ما إذا كان عنوان URL خارجيًا. يتم ترك الروابط الخارجية دون تغيير لأنها لا تحتاج إلى توطين.
|
|
1195
|
+
|
|
1196
|
+
- **استرجاع اللغة الحالية**:
|
|
1197
|
+
يوفر الخطاف `useLocale` اللغة الحالية (مثل `ar` للعربية).
|
|
1198
|
+
|
|
1199
|
+
- **توطين عنوان URL**:
|
|
1200
|
+
بالنسبة للروابط الداخلية (أي غير الخارجية)، يتم استخدام `getLocalizedUrl` لإضافة بادئة تلقائيًا للعنوان باللغة الحالية. هذا يعني أنه إذا كان المستخدم يستخدم اللغة العربية، فإن تمرير `/about` كـ `href` سيحولها إلى `/ar/about`.
|
|
1201
|
+
|
|
1202
|
+
- **إرجاع الرابط**:
|
|
1203
|
+
يقوم المكون بإرجاع عنصر `<a>` مع عنوان URL المحلي، مما يضمن أن التنقل يتماشى مع اللغة.
|
|
1204
|
+
|
|
1205
|
+
من خلال دمج هذا المكون `Link` في جميع أنحاء تطبيقك، تحافظ على تجربة مستخدم متماسكة وواعية باللغة مع الاستفادة أيضًا من تحسين محركات البحث وسهولة الاستخدام.
|
|
1206
|
+
|
|
1207
|
+
### (اختياري) الخطوة 12: تحسين حجم الحزمة
|
|
1208
|
+
|
|
1209
|
+
`next-intlayer` का उपयोग करते समय, डिफ़ॉल्ट रूप से प्रत्येक पृष्ठ के लिए शब्दकोश बंडल में शामिल होते हैं। बंडल आकार को अनुकूलित करने के लिए, Intlayer एक वैकल्पिक SWC प्लगइन प्रदान करता है जो मैक्रोज़ का उपयोग करके `useIntlayer` कॉल को बुद्धिमानी से बदलता है। यह सुनिश्चित करता है कि शब्दकोश केवल उन पृष्ठों के बंडल में शामिल हों जो वास्तव में उनका उपयोग करते हैं।
|
|
1210
|
+
|
|
1211
|
+
इस अनुकूलन को सक्षम करने के लिए, `@intlayer/swc` पैकेज इंस्टॉल करें। एक बार इंस्टॉल हो जाने पर, `next-intlayer` स्वचालित रूप से प्लगइन का पता लगाएगा और उसका उपयोग करेगा:
|
|
1212
|
+
|
|
1213
|
+
```bash packageManager="npm"
|
|
1214
|
+
npm install @intlayer/swc --save-dev
|
|
1215
|
+
```
|
|
1216
|
+
|
|
1217
|
+
```bash packageManager="pnpm"
|
|
1218
|
+
pnpm add @intlayer/swc --save-dev
|
|
1219
|
+
```
|
|
1220
|
+
|
|
1221
|
+
```bash packageManager="yarn"
|
|
1222
|
+
yarn add @intlayer/swc --save-dev
|
|
1223
|
+
```
|
|
1224
|
+
|
|
1225
|
+
> ملاحظة: هذا التحسين متاح فقط لـ Next.js 13 وما فوق.
|
|
1226
|
+
|
|
1227
|
+
> ملاحظة: لم يتم تثبيت هذه الحزمة افتراضيًا لأن مكونات SWC لا تزال تجريبية على Next.js. قد يتغير ذلك في المستقبل.
|
|
1228
|
+
|
|
1229
|
+
### تكوين TypeScript
|
|
1230
|
+
|
|
1231
|
+
يستخدم Intlayer توسيع الوحدات للحصول على فوائد TypeScript وجعل قاعدة الكود الخاصة بك أقوى.
|
|
1232
|
+
|
|
1233
|
+

|
|
1234
|
+
|
|
1235
|
+

|
|
1236
|
+
|
|
1237
|
+
تأكد من أن تكوين TypeScript الخاص بك يتضمن الأنواع التي يتم إنشاؤها تلقائيًا.
|
|
1238
|
+
|
|
1239
|
+
```json5 fileName="tsconfig.json"
|
|
1240
|
+
{
|
|
1241
|
+
// ... تكوينات TypeScript الحالية الخاصة بك
|
|
1242
|
+
"include": [
|
|
1243
|
+
// ... تكوينات TypeScript الحالية الخاصة بك
|
|
1244
|
+
".intlayer/**/*.ts", // تضمين الأنواع التي يتم إنشاؤها تلقائيًا
|
|
1245
|
+
],
|
|
1246
|
+
}
|
|
1247
|
+
```
|
|
1248
|
+
|
|
1249
|
+
### تكوين Git
|
|
1250
|
+
|
|
1251
|
+
يوصى بتجاهل الملفات التي يتم إنشاؤها بواسطة Intlayer. يتيح لك ذلك تجنب إضافتها إلى مستودع Git الخاص بك.
|
|
1252
|
+
|
|
1253
|
+
للقيام بذلك، يمكنك إضافة التعليمات التالية إلى ملف `.gitignore` الخاص بك:
|
|
1254
|
+
|
|
1255
|
+
```plaintext fileName=".gitignore"
|
|
1256
|
+
# تجاهل الملفات التي يتم إنشاؤها بواسطة Intlayer
|
|
1257
|
+
.intlayer
|
|
1258
|
+
```
|
|
1259
|
+
|
|
1260
|
+
### المزيد
|