@intlayer/docs 5.8.1 → 6.0.0-canary.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/blog/ar/rag_powered_documentation_assistant.md +282 -0
- package/blog/de/rag_powered_documentation_assistant.md +282 -0
- package/blog/en/rag_powered_documentation_assistant.md +289 -0
- package/blog/en-GB/rag_powered_documentation_assistant.md +284 -0
- package/blog/es/rag_powered_documentation_assistant.md +308 -0
- package/blog/fr/rag_powered_documentation_assistant.md +308 -0
- package/blog/hi/rag_powered_documentation_assistant.md +284 -0
- package/blog/it/rag_powered_documentation_assistant.md +284 -0
- package/blog/ja/rag_powered_documentation_assistant.md +284 -0
- package/blog/ko/rag_powered_documentation_assistant.md +283 -0
- package/blog/pt/rag_powered_documentation_assistant.md +284 -0
- package/blog/ru/rag_powered_documentation_assistant.md +284 -0
- package/blog/tr/index.md +69 -0
- package/blog/tr/internationalization_and_SEO.md +273 -0
- package/blog/tr/intlayer_with_i18next.md +162 -0
- package/blog/tr/intlayer_with_next-i18next.md +367 -0
- package/blog/tr/intlayer_with_next-intl.md +392 -0
- package/blog/tr/intlayer_with_react-i18next.md +346 -0
- package/blog/tr/intlayer_with_react-intl.md +345 -0
- package/blog/tr/list_i18n_technologies/CMS/drupal.md +143 -0
- package/blog/tr/list_i18n_technologies/CMS/wix.md +167 -0
- package/blog/tr/list_i18n_technologies/CMS/wordpress.md +188 -0
- package/blog/tr/list_i18n_technologies/frameworks/angular.md +125 -0
- package/blog/tr/list_i18n_technologies/frameworks/flutter.md +150 -0
- package/blog/tr/list_i18n_technologies/frameworks/react-native.md +217 -0
- package/blog/tr/list_i18n_technologies/frameworks/react.md +155 -0
- package/blog/tr/list_i18n_technologies/frameworks/svelte.md +129 -0
- package/blog/tr/list_i18n_technologies/frameworks/vue.md +130 -0
- package/blog/tr/next-i18next_vs_next-intl_vs_intlayer.md +170 -0
- package/blog/tr/rag_powered_documentation_assistant.md +284 -0
- package/blog/tr/react-i18next_vs_react-intl_vs_intlayer.md +162 -0
- package/blog/tr/vue-i18n_vs_intlayer.md +276 -0
- package/blog/tr/what_is_internationalization.md +166 -0
- package/blog/zh/rag_powered_documentation_assistant.md +284 -0
- package/dist/cjs/generated/blog.entry.cjs +212 -0
- package/dist/cjs/generated/blog.entry.cjs.map +1 -1
- package/dist/cjs/generated/docs.entry.cjs +660 -132
- package/dist/cjs/generated/docs.entry.cjs.map +1 -1
- package/dist/cjs/generated/frequentQuestions.entry.cjs +84 -0
- package/dist/cjs/generated/frequentQuestions.entry.cjs.map +1 -1
- package/dist/cjs/generated/legal.entry.cjs +6 -0
- package/dist/cjs/generated/legal.entry.cjs.map +1 -1
- package/dist/esm/generated/blog.entry.mjs +212 -0
- package/dist/esm/generated/blog.entry.mjs.map +1 -1
- package/dist/esm/generated/docs.entry.mjs +660 -132
- package/dist/esm/generated/docs.entry.mjs.map +1 -1
- package/dist/esm/generated/frequentQuestions.entry.mjs +84 -0
- package/dist/esm/generated/frequentQuestions.entry.mjs.map +1 -1
- package/dist/esm/generated/legal.entry.mjs +6 -0
- package/dist/esm/generated/legal.entry.mjs.map +1 -1
- package/dist/types/generated/blog.entry.d.ts +1 -0
- package/dist/types/generated/blog.entry.d.ts.map +1 -1
- package/dist/types/generated/docs.entry.d.ts +5 -2
- package/dist/types/generated/docs.entry.d.ts.map +1 -1
- package/dist/types/generated/frequentQuestions.entry.d.ts.map +1 -1
- package/dist/types/generated/legal.entry.d.ts.map +1 -1
- package/docs/ar/autoFill.md +41 -40
- package/docs/ar/configuration.md +202 -199
- package/docs/ar/dictionary/content_file.md +1059 -0
- package/docs/ar/intlayer_CMS.md +4 -4
- package/docs/ar/intlayer_with_nestjs.md +271 -0
- package/docs/ar/intlayer_with_nextjs_page_router.md +1 -1
- package/docs/ar/intlayer_with_react_router_v7.md +533 -0
- package/docs/ar/intlayer_with_tanstack.md +465 -299
- package/docs/ar/intlayer_with_vite+preact.md +7 -7
- package/docs/ar/intlayer_with_vite+react.md +7 -7
- package/docs/ar/intlayer_with_vite+vue.md +9 -9
- package/docs/ar/packages/vite-intlayer/index.md +3 -3
- package/docs/ar/readme.md +261 -0
- package/docs/ar/testing.md +199 -0
- package/docs/de/autoFill.md +42 -19
- package/docs/de/configuration.md +155 -147
- package/docs/de/dictionary/content_file.md +1059 -0
- package/docs/de/intlayer_CMS.md +4 -5
- package/docs/de/intlayer_with_nestjs.md +270 -0
- package/docs/de/intlayer_with_nextjs_page_router.md +1 -1
- package/docs/de/intlayer_with_react_router_v7.md +537 -0
- package/docs/de/intlayer_with_tanstack.md +469 -302
- package/docs/de/intlayer_with_vite+preact.md +7 -7
- package/docs/de/intlayer_with_vite+react.md +7 -7
- package/docs/de/intlayer_with_vite+vue.md +9 -9
- package/docs/de/packages/vite-intlayer/index.md +3 -3
- package/docs/de/readme.md +261 -0
- package/docs/de/testing.md +200 -0
- package/docs/en/CI_CD.md +4 -6
- package/docs/en/autoFill.md +25 -5
- package/docs/en/configuration.md +45 -54
- package/docs/en/dictionary/content_file.md +1054 -0
- package/docs/en/intlayer_CMS.md +8 -7
- package/docs/en/intlayer_cli.md +112 -5
- package/docs/en/intlayer_with_nestjs.md +268 -0
- package/docs/en/intlayer_with_nextjs_page_router.md +1 -1
- package/docs/en/intlayer_with_react_router_v7.md +531 -0
- package/docs/en/intlayer_with_tanstack.md +463 -294
- package/docs/en/intlayer_with_vite+preact.md +8 -8
- package/docs/en/intlayer_with_vite+react.md +8 -8
- package/docs/en/intlayer_with_vite+vue.md +8 -8
- package/docs/en/packages/intlayer/getLocalizedUrl.md +102 -25
- package/docs/en/packages/vite-intlayer/index.md +3 -3
- package/docs/en/readme.md +261 -0
- package/docs/en/testing.md +200 -0
- package/docs/en-GB/autoFill.md +29 -6
- package/docs/en-GB/configuration.md +79 -71
- package/docs/en-GB/dictionary/content_file.md +1084 -0
- package/docs/en-GB/intlayer_CMS.md +4 -5
- package/docs/en-GB/intlayer_with_nestjs.md +268 -0
- package/docs/en-GB/intlayer_with_nextjs_page_router.md +1 -1
- package/docs/en-GB/intlayer_with_react_router_v7.md +533 -0
- package/docs/en-GB/intlayer_with_tanstack.md +466 -299
- package/docs/en-GB/intlayer_with_vite+preact.md +7 -7
- package/docs/en-GB/intlayer_with_vite+react.md +7 -7
- package/docs/en-GB/intlayer_with_vite+vue.md +9 -9
- package/docs/en-GB/packages/vite-intlayer/index.md +3 -3
- package/docs/en-GB/readme.md +261 -0
- package/docs/en-GB/testing.md +200 -0
- package/docs/es/autoFill.md +45 -23
- package/docs/es/configuration.md +171 -167
- package/docs/es/dictionary/content_file.md +1088 -0
- package/docs/es/intlayer_CMS.md +4 -5
- package/docs/es/intlayer_with_nestjs.md +268 -0
- package/docs/es/intlayer_with_nextjs_page_router.md +1 -1
- package/docs/es/intlayer_with_react_router_v7.md +533 -0
- package/docs/es/intlayer_with_tanstack.md +469 -280
- package/docs/es/intlayer_with_vite+preact.md +7 -7
- package/docs/es/intlayer_with_vite+react.md +7 -7
- package/docs/es/intlayer_with_vite+vue.md +9 -9
- package/docs/es/packages/vite-intlayer/index.md +3 -3
- package/docs/es/readme.md +261 -0
- package/docs/es/testing.md +200 -0
- package/docs/fr/autoFill.md +47 -24
- package/docs/fr/configuration.md +213 -198
- package/docs/fr/dictionary/content_file.md +1054 -0
- package/docs/fr/intlayer_CMS.md +4 -5
- package/docs/fr/intlayer_with_nestjs.md +268 -0
- package/docs/fr/intlayer_with_nextjs_page_router.md +1 -1
- package/docs/fr/intlayer_with_react_router_v7.md +549 -0
- package/docs/fr/intlayer_with_tanstack.md +465 -279
- package/docs/fr/intlayer_with_vite+preact.md +7 -7
- package/docs/fr/intlayer_with_vite+react.md +7 -7
- package/docs/fr/intlayer_with_vite+vue.md +9 -9
- package/docs/fr/packages/vite-intlayer/index.md +3 -3
- package/docs/fr/readme.md +261 -0
- package/docs/fr/testing.md +200 -0
- package/docs/hi/autoFill.md +47 -25
- package/docs/hi/configuration.md +194 -189
- package/docs/hi/dictionary/content_file.md +1056 -0
- package/docs/hi/intlayer_CMS.md +4 -5
- package/docs/hi/intlayer_with_nestjs.md +269 -0
- package/docs/hi/intlayer_with_nextjs_page_router.md +1 -1
- package/docs/hi/intlayer_with_react_router_v7.md +533 -0
- package/docs/hi/intlayer_with_tanstack.md +467 -282
- package/docs/hi/intlayer_with_vite+preact.md +7 -7
- package/docs/hi/intlayer_with_vite+react.md +7 -7
- package/docs/hi/intlayer_with_vite+vue.md +9 -9
- package/docs/hi/packages/vite-intlayer/index.md +3 -3
- package/docs/hi/readme.md +261 -0
- package/docs/hi/testing.md +200 -0
- package/docs/it/autoFill.md +46 -24
- package/docs/it/configuration.md +169 -161
- package/docs/it/dictionary/content_file.md +1061 -0
- package/docs/it/intlayer_CMS.md +4 -5
- package/docs/it/intlayer_with_nestjs.md +268 -0
- package/docs/it/intlayer_with_nextjs_page_router.md +1 -1
- package/docs/it/intlayer_with_react_router_v7.md +535 -0
- package/docs/it/intlayer_with_tanstack.md +467 -301
- package/docs/it/intlayer_with_vite+preact.md +7 -7
- package/docs/it/intlayer_with_vite+react.md +7 -7
- package/docs/it/intlayer_with_vite+vue.md +9 -9
- package/docs/it/packages/vite-intlayer/index.md +3 -3
- package/docs/it/readme.md +261 -0
- package/docs/it/testing.md +200 -0
- package/docs/ja/autoFill.md +45 -23
- package/docs/ja/configuration.md +243 -204
- package/docs/ja/dictionary/content_file.md +1064 -0
- package/docs/ja/intlayer_CMS.md +4 -5
- package/docs/ja/intlayer_with_nestjs.md +268 -0
- package/docs/ja/intlayer_with_nextjs_page_router.md +1 -1
- package/docs/ja/intlayer_with_react_router_v7.md +534 -0
- package/docs/ja/intlayer_with_tanstack.md +467 -303
- package/docs/ja/intlayer_with_vite+preact.md +7 -7
- package/docs/ja/intlayer_with_vite+react.md +7 -7
- package/docs/ja/intlayer_with_vite+vue.md +9 -9
- package/docs/ja/packages/vite-intlayer/index.md +3 -3
- package/docs/ja/readme.md +263 -0
- package/docs/ja/testing.md +200 -0
- package/docs/ko/autoFill.md +39 -16
- package/docs/ko/configuration.md +217 -197
- package/docs/ko/dictionary/content_file.md +1060 -0
- package/docs/ko/intlayer_CMS.md +4 -5
- package/docs/ko/intlayer_with_nestjs.md +268 -0
- package/docs/ko/intlayer_with_nextjs_page_router.md +1 -1
- package/docs/ko/intlayer_with_react_router_v7.md +540 -0
- package/docs/ko/intlayer_with_tanstack.md +466 -302
- package/docs/ko/intlayer_with_vite+preact.md +7 -7
- package/docs/ko/intlayer_with_vite+react.md +7 -7
- package/docs/ko/intlayer_with_vite+vue.md +9 -9
- package/docs/ko/packages/vite-intlayer/index.md +3 -3
- package/docs/ko/readme.md +261 -0
- package/docs/ko/testing.md +200 -0
- package/docs/pt/autoFill.md +39 -15
- package/docs/pt/configuration.md +165 -147
- package/docs/pt/dictionary/content_file.md +1062 -0
- package/docs/pt/intlayer_CMS.md +4 -5
- package/docs/pt/intlayer_with_nestjs.md +271 -0
- package/docs/pt/intlayer_with_nextjs_page_router.md +1 -1
- package/docs/pt/intlayer_with_react_router_v7.md +535 -0
- package/docs/pt/intlayer_with_tanstack.md +469 -300
- package/docs/pt/intlayer_with_vite+preact.md +7 -7
- package/docs/pt/intlayer_with_vite+react.md +7 -7
- package/docs/pt/intlayer_with_vite+vue.md +9 -9
- package/docs/pt/packages/vite-intlayer/index.md +3 -3
- package/docs/pt/readme.md +261 -0
- package/docs/pt/testing.md +200 -0
- package/docs/ru/autoFill.md +52 -30
- package/docs/ru/configuration.md +164 -117
- package/docs/ru/dictionary/content_file.md +1064 -0
- package/docs/ru/intlayer_CMS.md +4 -4
- package/docs/ru/intlayer_with_nestjs.md +270 -0
- package/docs/ru/intlayer_with_nextjs_page_router.md +1 -1
- package/docs/ru/intlayer_with_react_router_v7.md +534 -0
- package/docs/ru/intlayer_with_tanstack.md +470 -305
- package/docs/ru/intlayer_with_vite+preact.md +7 -7
- package/docs/ru/intlayer_with_vite+react.md +7 -7
- package/docs/ru/intlayer_with_vite+vue.md +9 -9
- package/docs/ru/packages/vite-intlayer/index.md +3 -3
- package/docs/ru/readme.md +261 -0
- package/docs/ru/testing.md +202 -0
- package/docs/tr/CI_CD.md +198 -0
- package/docs/tr/autoFill.md +201 -0
- package/docs/tr/configuration.md +585 -0
- package/docs/tr/dictionary/condition.md +243 -0
- package/docs/tr/dictionary/content_file.md +1055 -0
- package/docs/tr/dictionary/enumeration.md +251 -0
- package/docs/tr/dictionary/file.md +228 -0
- package/docs/tr/dictionary/function_fetching.md +218 -0
- package/docs/tr/dictionary/gender.md +279 -0
- package/docs/tr/dictionary/insertion.md +191 -0
- package/docs/tr/dictionary/markdown.md +385 -0
- package/docs/tr/dictionary/nesting.md +279 -0
- package/docs/tr/dictionary/translation.md +315 -0
- package/docs/tr/formatters.md +618 -0
- package/docs/tr/how_works_intlayer.md +254 -0
- package/docs/tr/index.md +168 -0
- package/docs/tr/interest_of_intlayer.md +288 -0
- package/docs/tr/intlayer_CMS.md +347 -0
- package/docs/tr/intlayer_cli.md +570 -0
- package/docs/tr/intlayer_visual_editor.md +269 -0
- package/docs/tr/intlayer_with_angular.md +694 -0
- package/docs/tr/intlayer_with_create_react_app.md +1218 -0
- package/docs/tr/intlayer_with_express.md +415 -0
- package/docs/tr/intlayer_with_lynx+react.md +511 -0
- package/docs/tr/intlayer_with_nestjs.md +268 -0
- package/docs/tr/intlayer_with_nextjs_14.md +1029 -0
- package/docs/tr/intlayer_with_nextjs_15.md +1506 -0
- package/docs/tr/intlayer_with_nextjs_page_router.md +1484 -0
- package/docs/tr/intlayer_with_nuxt.md +773 -0
- package/docs/tr/intlayer_with_react_native+expo.md +660 -0
- package/docs/tr/intlayer_with_react_router_v7.md +531 -0
- package/docs/tr/intlayer_with_tanstack.md +452 -0
- package/docs/tr/intlayer_with_vite+preact.md +1673 -0
- package/docs/tr/intlayer_with_vite+react.md +1632 -0
- package/docs/tr/intlayer_with_vite+solid.md +288 -0
- package/docs/tr/intlayer_with_vite+svelte.md +288 -0
- package/docs/tr/intlayer_with_vite+vue.md +1042 -0
- package/docs/tr/introduction.md +209 -0
- package/docs/tr/locale_mapper.md +244 -0
- package/docs/tr/mcp_server.md +207 -0
- package/docs/tr/packages/@intlayer/api/index.md +58 -0
- package/docs/tr/packages/@intlayer/chokidar/index.md +57 -0
- package/docs/tr/packages/@intlayer/cli/index.md +47 -0
- package/docs/tr/packages/@intlayer/config/index.md +142 -0
- package/docs/tr/packages/@intlayer/core/index.md +51 -0
- package/docs/tr/packages/@intlayer/design-system/index.md +47 -0
- package/docs/tr/packages/@intlayer/dictionary-entry/index.md +53 -0
- package/docs/tr/packages/@intlayer/editor/index.md +47 -0
- package/docs/tr/packages/@intlayer/editor-react/index.md +47 -0
- package/docs/tr/packages/@intlayer/webpack/index.md +61 -0
- package/docs/tr/packages/angular-intlayer/index.md +59 -0
- package/docs/tr/packages/express-intlayer/index.md +258 -0
- package/docs/tr/packages/express-intlayer/t.md +459 -0
- package/docs/tr/packages/intlayer/getConfiguration.md +151 -0
- package/docs/tr/packages/intlayer/getEnumeration.md +165 -0
- package/docs/tr/packages/intlayer/getHTMLTextDir.md +127 -0
- package/docs/tr/packages/intlayer/getLocaleLang.md +87 -0
- package/docs/tr/packages/intlayer/getLocaleName.md +124 -0
- package/docs/tr/packages/intlayer/getLocalizedUrl.md +324 -0
- package/docs/tr/packages/intlayer/getMultilingualUrls.md +225 -0
- package/docs/tr/packages/intlayer/getPathWithoutLocale.md +81 -0
- package/docs/tr/packages/intlayer/getTranslation.md +196 -0
- package/docs/tr/packages/intlayer/getTranslationContent.md +195 -0
- package/docs/tr/packages/intlayer/index.md +505 -0
- package/docs/tr/packages/intlayer-cli/index.md +71 -0
- package/docs/tr/packages/intlayer-editor/index.md +139 -0
- package/docs/tr/packages/lynx-intlayer/index.md +85 -0
- package/docs/tr/packages/next-intlayer/index.md +154 -0
- package/docs/tr/packages/next-intlayer/t.md +354 -0
- package/docs/tr/packages/next-intlayer/useDictionary.md +270 -0
- package/docs/tr/packages/next-intlayer/useIntlayer.md +265 -0
- package/docs/tr/packages/next-intlayer/useLocale.md +133 -0
- package/docs/tr/packages/nuxt-intlayer/index.md +59 -0
- package/docs/tr/packages/preact-intlayer/index.md +55 -0
- package/docs/tr/packages/react-intlayer/index.md +148 -0
- package/docs/tr/packages/react-intlayer/t.md +304 -0
- package/docs/tr/packages/react-intlayer/useDictionary.md +554 -0
- package/docs/tr/packages/react-intlayer/useI18n.md +478 -0
- package/docs/tr/packages/react-intlayer/useIntlayer.md +253 -0
- package/docs/tr/packages/react-intlayer/useLocale.md +212 -0
- package/docs/tr/packages/react-native-intlayer/index.md +85 -0
- package/docs/tr/packages/react-scripts-intlayer/index.md +82 -0
- package/docs/tr/packages/solid-intlayer/index.md +56 -0
- package/docs/tr/packages/svelte-intlayer/index.md +55 -0
- package/docs/tr/packages/vite-intlayer/index.md +82 -0
- package/docs/tr/packages/vue-intlayer/index.md +59 -0
- package/docs/tr/per_locale_file.md +321 -0
- package/docs/tr/readme.md +261 -0
- package/docs/tr/roadmap.md +338 -0
- package/docs/tr/testing.md +200 -0
- package/docs/tr/vs_code_extension.md +154 -0
- package/docs/zh/autoFill.md +40 -18
- package/docs/zh/configuration.md +245 -226
- package/docs/zh/dictionary/content_file.md +1064 -0
- package/docs/zh/intlayer_CMS.md +4 -5
- package/docs/zh/intlayer_with_nestjs.md +268 -0
- package/docs/zh/intlayer_with_nextjs_page_router.md +1 -1
- package/docs/zh/intlayer_with_react_router_v7.md +535 -0
- package/docs/zh/intlayer_with_tanstack.md +468 -278
- package/docs/zh/intlayer_with_vite+preact.md +7 -7
- package/docs/zh/intlayer_with_vite+react.md +7 -7
- package/docs/zh/intlayer_with_vite+vue.md +7 -7
- package/docs/zh/packages/vite-intlayer/index.md +3 -3
- package/docs/zh/readme.md +261 -0
- package/docs/zh/testing.md +198 -0
- package/frequent_questions/tr/SSR_Next_no_[locale].md +105 -0
- package/frequent_questions/tr/array_as_content_declaration.md +72 -0
- package/frequent_questions/tr/build_dictionaries.md +59 -0
- package/frequent_questions/tr/build_error_CI_CD.md +75 -0
- package/frequent_questions/tr/customized_locale_list.md +65 -0
- package/frequent_questions/tr/domain_routing.md +114 -0
- package/frequent_questions/tr/esbuild_error.md +30 -0
- package/frequent_questions/tr/get_locale_cookie.md +142 -0
- package/frequent_questions/tr/intlayer_command_undefined.md +156 -0
- package/frequent_questions/tr/locale_incorect_in_url.md +74 -0
- package/frequent_questions/tr/static_rendering.md +45 -0
- package/frequent_questions/tr/translated_path_url.md +56 -0
- package/frequent_questions/tr/unknown_command.md +98 -0
- package/legal/tr/privacy_notice.md +83 -0
- package/legal/tr/terms_of_service.md +55 -0
- package/package.json +12 -12
- package/src/generated/blog.entry.ts +212 -0
- package/src/generated/docs.entry.ts +663 -135
- package/src/generated/frequentQuestions.entry.ts +85 -1
- package/src/generated/legal.entry.ts +7 -1
- package/docs/ar/dictionary/content_extention_customization.md +0 -100
- package/docs/ar/dictionary/get_started.md +0 -527
- package/docs/de/dictionary/content_extention_customization.md +0 -100
- package/docs/de/dictionary/get_started.md +0 -531
- package/docs/en/dictionary/content_extention_customization.md +0 -102
- package/docs/en/dictionary/get_started.md +0 -529
- package/docs/en-GB/dictionary/content_extention_customization.md +0 -100
- package/docs/en-GB/dictionary/get_started.md +0 -591
- package/docs/es/dictionary/content_extention_customization.md +0 -100
- package/docs/es/dictionary/get_started.md +0 -527
- package/docs/fr/dictionary/content_extention_customization.md +0 -100
- package/docs/fr/dictionary/get_started.md +0 -527
- package/docs/hi/dictionary/content_extention_customization.md +0 -100
- package/docs/hi/dictionary/get_started.md +0 -527
- package/docs/it/dictionary/content_extention_customization.md +0 -113
- package/docs/it/dictionary/get_started.md +0 -573
- package/docs/ja/dictionary/content_extention_customization.md +0 -113
- package/docs/ja/dictionary/get_started.md +0 -576
- package/docs/ko/dictionary/content_extention_customization.md +0 -100
- package/docs/ko/dictionary/get_started.md +0 -530
- package/docs/pt/dictionary/content_extention_customization.md +0 -100
- package/docs/pt/dictionary/get_started.md +0 -532
- package/docs/ru/dictionary/content_extention_customization.md +0 -100
- package/docs/ru/dictionary/get_started.md +0 -575
- package/docs/zh/dictionary/content_extention_customization.md +0 -117
- package/docs/zh/dictionary/get_started.md +0 -533
|
@@ -0,0 +1,585 @@
|
|
|
1
|
+
---
|
|
2
|
+
createdAt: 2024-08-13
|
|
3
|
+
updatedAt: 2025-09-16
|
|
4
|
+
title: Yapılandırma
|
|
5
|
+
description: Uygulamanız için Intlayer'ı nasıl yapılandıracağınızı öğrenin. Intlayer'ı ihtiyaçlarınıza göre özelleştirmek için mevcut çeşitli ayarları ve seçenekleri anlayın.
|
|
6
|
+
keywords:
|
|
7
|
+
- Yapılandırma
|
|
8
|
+
- Ayarlar
|
|
9
|
+
- Özelleştirme
|
|
10
|
+
- Intlayer
|
|
11
|
+
- Seçenekler
|
|
12
|
+
slugs:
|
|
13
|
+
- doc
|
|
14
|
+
- concept
|
|
15
|
+
- configuration
|
|
16
|
+
---
|
|
17
|
+
|
|
18
|
+
# Intlayer Yapılandırma Dokümantasyonu
|
|
19
|
+
|
|
20
|
+
## Genel Bakış
|
|
21
|
+
|
|
22
|
+
Intlayer yapılandırma dosyaları, uluslararasılaştırma, ara katman (middleware) ve içerik işleme gibi eklentinin çeşitli yönlerinin özelleştirilmesine olanak tanır. Bu belge, yapılandırmadaki her bir özelliğin ayrıntılı açıklamasını sağlar.
|
|
23
|
+
|
|
24
|
+
---
|
|
25
|
+
|
|
26
|
+
## Yapılandırma Dosyası Desteği
|
|
27
|
+
|
|
28
|
+
Intlayer, JSON, JS, MJS ve TS yapılandırma dosyası formatlarını kabul eder:
|
|
29
|
+
|
|
30
|
+
- `intlayer.config.ts`
|
|
31
|
+
- `intlayer.config.js`
|
|
32
|
+
- `intlayer.config.json`
|
|
33
|
+
- `intlayer.config.cjs`
|
|
34
|
+
- `intlayer.config.mjs`
|
|
35
|
+
- `.intlayerrc`
|
|
36
|
+
|
|
37
|
+
---
|
|
38
|
+
|
|
39
|
+
## Örnek yapılandırma dosyası
|
|
40
|
+
|
|
41
|
+
```typescript fileName="intlayer.config.ts" codeFormat="typescript"
|
|
42
|
+
import { Locales, type IntlayerConfig } from "intlayer";
|
|
43
|
+
|
|
44
|
+
const config: IntlayerConfig = {
|
|
45
|
+
internationalization: {
|
|
46
|
+
locales: [Locales.ENGLISH], // Desteklenen diller
|
|
47
|
+
},
|
|
48
|
+
content: {
|
|
49
|
+
autoFill: "./{{fileName}}.content.json", // İçeriğin otomatik doldurulacağı dosya yolu
|
|
50
|
+
contentDir: ["src", "../ui-library"], // İçerik dizinleri
|
|
51
|
+
},
|
|
52
|
+
middleware: {
|
|
53
|
+
noPrefix: false, // Önek kullanımı
|
|
54
|
+
},
|
|
55
|
+
editor: {
|
|
56
|
+
applicationURL: "https://example.com", // Uygulama URL'si
|
|
57
|
+
},
|
|
58
|
+
ai: {
|
|
59
|
+
apiKey: process.env.OPENAI_API_KEY, // AI API anahtarı
|
|
60
|
+
applicationContext: "This is a test application", // Uygulama bağlamı
|
|
61
|
+
},
|
|
62
|
+
build: {
|
|
63
|
+
importMode: "dynamic", // İçe aktarma modu
|
|
64
|
+
},
|
|
65
|
+
};
|
|
66
|
+
|
|
67
|
+
export default config;
|
|
68
|
+
```
|
|
69
|
+
|
|
70
|
+
```javascript fileName="intlayer.config.cjs" codeFormat="commonjs"
|
|
71
|
+
const { Locales } = require("intlayer");
|
|
72
|
+
|
|
73
|
+
/** @type {import('intlayer').IntlayerConfig} */
|
|
74
|
+
const config = {
|
|
75
|
+
internationalization: {
|
|
76
|
+
locales: [Locales.ENGLISH], // Desteklenen diller
|
|
77
|
+
},
|
|
78
|
+
content: {
|
|
79
|
+
contentDir: ["src", "../ui-library"], // İçerik dizinleri
|
|
80
|
+
},
|
|
81
|
+
middleware: {
|
|
82
|
+
noPrefix: false, // Önek kullanımı
|
|
83
|
+
},
|
|
84
|
+
editor: {
|
|
85
|
+
applicationURL: "https://example.com", // Uygulama URL'si
|
|
86
|
+
},
|
|
87
|
+
ai: {
|
|
88
|
+
apiKey: process.env.OPENAI_API_KEY, // AI API anahtarı
|
|
89
|
+
applicationContext: "Bu bir test uygulamasıdır", // Uygulama bağlamı
|
|
90
|
+
},
|
|
91
|
+
build: {
|
|
92
|
+
importMode: "dynamic", // İçe aktarma modu
|
|
93
|
+
},
|
|
94
|
+
};
|
|
95
|
+
|
|
96
|
+
module.exports = config;
|
|
97
|
+
```
|
|
98
|
+
|
|
99
|
+
```json5 fileName=".intlayerrc" codeFormat="json"
|
|
100
|
+
{
|
|
101
|
+
"internationalization": {
|
|
102
|
+
"locales": ["en"], // Desteklenen diller
|
|
103
|
+
},
|
|
104
|
+
"content": {
|
|
105
|
+
"contentDir": ["src", "../ui-library"], // İçerik dizinleri
|
|
106
|
+
},
|
|
107
|
+
"middleware": {
|
|
108
|
+
"noPrefix": false, // Önek kullanımı
|
|
109
|
+
},
|
|
110
|
+
"editor": {
|
|
111
|
+
"applicationURL": "https://example.com", // Uygulama URL'si
|
|
112
|
+
},
|
|
113
|
+
"ai": {
|
|
114
|
+
"apiKey": "XXXX",
|
|
115
|
+
"applicationContext": "Bu bir test uygulamasıdır",
|
|
116
|
+
},
|
|
117
|
+
"build": {
|
|
118
|
+
"importMode": "dynamic",
|
|
119
|
+
},
|
|
120
|
+
}
|
|
121
|
+
```
|
|
122
|
+
|
|
123
|
+
---
|
|
124
|
+
|
|
125
|
+
## Konfigürasyon Referansı
|
|
126
|
+
|
|
127
|
+
Aşağıdaki bölümler, Intlayer için mevcut olan çeşitli konfigürasyon ayarlarını açıklamaktadır.
|
|
128
|
+
|
|
129
|
+
---
|
|
130
|
+
|
|
131
|
+
### Uluslararasılaştırma Konfigürasyonu
|
|
132
|
+
|
|
133
|
+
Uygulama için mevcut yerel ayarları ve varsayılan yerel ayarı içeren uluslararasılaştırma ile ilgili ayarları tanımlar.
|
|
134
|
+
|
|
135
|
+
#### Özellikler
|
|
136
|
+
|
|
137
|
+
- **locales**:
|
|
138
|
+
- _Tür_: `string[]`
|
|
139
|
+
- _Varsayılan_: `['en']`
|
|
140
|
+
- _Açıklama_: Uygulamada desteklenen yerel ayarların listesi.
|
|
141
|
+
- _Örnek_: `['en', 'fr', 'es']`
|
|
142
|
+
|
|
143
|
+
- **requiredLocales**:
|
|
144
|
+
- _Tür_: `string[]`
|
|
145
|
+
- _Varsayılan_: `[]`
|
|
146
|
+
- _Açıklama_: Uygulamada zorunlu olan yerel ayarların listesi.
|
|
147
|
+
- _Örnek_: `[]`
|
|
148
|
+
- _Not_: Boşsa, `strict` modda tüm yerel ayarlar gereklidir.
|
|
149
|
+
- _Not_: Gereken yerel ayarların `locales` alanında da tanımlandığından emin olun.
|
|
150
|
+
- **strictMode**:
|
|
151
|
+
- _Tür_: `string`
|
|
152
|
+
- _Varsayılan_: `inclusive`
|
|
153
|
+
- _Açıklama_: Typescript kullanarak uluslararasılaştırılmış içeriğin güçlü uygulamalarını sağlar.
|
|
154
|
+
- _Not_: "strict" olarak ayarlanırsa, çeviri `t` fonksiyonu her bildirilen yerel ayarın tanımlanmasını gerektirir. Bir yerel ayar eksikse veya yapılandırmanızda bildirilmemişse, hata verir.
|
|
155
|
+
- _Not_: "inclusive" olarak ayarlanırsa, çeviri `t` fonksiyonu her bildirilen yerel ayarın tanımlanmasını gerektirir. Bir yerel ayar eksikse uyarı verir. Ancak yapılandırmanızda bildirilmemiş ama mevcut olan bir yerel ayarı kabul eder.
|
|
156
|
+
- _Not_: "loose" olarak ayarlanırsa, çeviri `t` fonksiyonu mevcut olan herhangi bir yerel ayarı kabul edecektir.
|
|
157
|
+
|
|
158
|
+
- **defaultLocale**:
|
|
159
|
+
- _Tür_: `string`
|
|
160
|
+
- _Varsayılan_: `'en'`
|
|
161
|
+
- _Açıklama_: İstenen yerel ayar bulunamadığında kullanılan varsayılan yerel ayar.
|
|
162
|
+
- _Örnek_: `'en'`
|
|
163
|
+
- _Not_: URL, çerez veya başlıkta yerel ayar belirtilmediğinde kullanılacak yerel ayarı belirlemek için kullanılır.
|
|
164
|
+
|
|
165
|
+
---
|
|
166
|
+
|
|
167
|
+
### Editör Yapılandırması
|
|
168
|
+
|
|
169
|
+
Entegre editörle ilgili ayarları, sunucu portu ve aktiflik durumu dahil olmak üzere tanımlar.
|
|
170
|
+
|
|
171
|
+
#### Özellikler
|
|
172
|
+
|
|
173
|
+
- **applicationURL**:
|
|
174
|
+
- _Tür_: `string`
|
|
175
|
+
- _Varsayılan_: `http://localhost:3000`
|
|
176
|
+
- _Açıklama_: Uygulamanın URL'si. Güvenlik nedenleriyle editörün kaynağını kısıtlamak için kullanılır.
|
|
177
|
+
- _Örnek_:
|
|
178
|
+
- `'http://localhost:3000'`
|
|
179
|
+
- `'https://example.com'`
|
|
180
|
+
- `process.env.INTLAYER_EDITOR_URL`
|
|
181
|
+
- _Not_: Uygulamanın URL'si. Güvenlik nedenleriyle editörün kaynağını kısıtlamak için kullanılır. `'*'` olarak ayarlanırsa, editöre herhangi bir kaynaktan erişilebilir.
|
|
182
|
+
|
|
183
|
+
- **port**:
|
|
184
|
+
- _Tür_: `number`
|
|
185
|
+
- _Varsayılan_: `8000`
|
|
186
|
+
- _Açıklama_: Görsel editör sunucusunun kullandığı port.
|
|
187
|
+
|
|
188
|
+
- **editorURL**:
|
|
189
|
+
- _Tür_: `string`
|
|
190
|
+
- _Varsayılan_: `'http://localhost:8000'`
|
|
191
|
+
- _Açıklama_: Editör sunucusunun URL'si. Güvenlik nedenleriyle editörün kaynağını kısıtlamak için kullanılır.
|
|
192
|
+
- `'http://localhost:3000'`
|
|
193
|
+
- `'https://example.com'`
|
|
194
|
+
- `process.env.INTLAYER_EDITOR_URL`
|
|
195
|
+
- _Not_: Uygulamadan erişilecek editör sunucusunun URL'si. Güvenlik nedenleriyle uygulamayla etkileşime girebilecek kaynakları kısıtlamak için kullanılır. `'*'` olarak ayarlanırsa, editöre herhangi bir kaynaktan erişilebilir. Port değiştirildiğinde veya editör farklı bir alan adında barındırılıyorsa ayarlanmalıdır.
|
|
196
|
+
|
|
197
|
+
- **cmsURL**:
|
|
198
|
+
- _Tür_: `string`
|
|
199
|
+
- _Varsayılan_: `'https://intlayer.org'`
|
|
200
|
+
- _Açıklama_: Intlayer CMS'nin URL'si.
|
|
201
|
+
- _Örnek_: `'https://intlayer.org'`
|
|
202
|
+
- _Not_: Intlayer CMS'nin URL'si.
|
|
203
|
+
|
|
204
|
+
- **backendURL**:
|
|
205
|
+
- _Tür_: `string`
|
|
206
|
+
- _Varsayılan_: `https://back.intlayer.org`
|
|
207
|
+
- _Açıklama_: Backend sunucusunun URL'si.
|
|
208
|
+
- _Örnek_: `http://localhost:4000`
|
|
209
|
+
|
|
210
|
+
- **enabled**:
|
|
211
|
+
- _Tür_: `boolean`
|
|
212
|
+
- _Varsayılan_: `true`
|
|
213
|
+
- _Açıklama_: Uygulamanın görsel editörle etkileşimde bulunup bulunmadığını belirtir.
|
|
214
|
+
- _Örnek_: `process.env.NODE_ENV !== 'production'`
|
|
215
|
+
- _Not_: Eğer true ise, editör uygulamayla etkileşimde bulunabilir. Eğer false ise, editör uygulamayla etkileşimde bulunamaz. Her durumda, editör yalnızca görsel editör tarafından etkinleştirilebilir. Belirli ortamlar için editörün devre dışı bırakılması, güvenliği sağlamak için bir yöntemdir.
|
|
216
|
+
|
|
217
|
+
- **clientId**:
|
|
218
|
+
- _Tür_: `string` | `undefined`
|
|
219
|
+
- _Varsayılan_: `undefined`
|
|
220
|
+
- _Açıklama_: clientId ve clientSecret, intlayer paketlerinin backend ile oAuth2 kimlik doğrulaması kullanarak kimlik doğrulaması yapmasını sağlar. Bir erişim belirteci, projeyle ilişkili kullanıcıyı doğrulamak için kullanılır. Bir erişim belirteci almak için https://intlayer.org/dashboard/project adresine gidip bir hesap oluşturun.
|
|
221
|
+
- _Örnek_: `true`
|
|
222
|
+
- _Not_: Önemli: clientId ve clientSecret gizli tutulmalı ve kamuya açık şekilde paylaşılmamalıdır. Lütfen bunları ortam değişkenleri gibi güvenli bir yerde sakladığınızdan emin olun.
|
|
223
|
+
|
|
224
|
+
- **clientSecret**:
|
|
225
|
+
- _Tür_: `string` | `undefined`
|
|
226
|
+
- _Varsayılan_: `undefined`
|
|
227
|
+
- _Açıklama_: clientId ve clientSecret, intlayer paketlerinin backend ile oAuth2 kimlik doğrulaması kullanarak doğrulanmasını sağlar. Bir erişim belirteci, projeyle ilişkili kullanıcıyı doğrulamak için kullanılır. Bir erişim belirteci almak için https://intlayer.org/dashboard/project adresine gidip bir hesap oluşturun.
|
|
228
|
+
- _Örnek_: `true`
|
|
229
|
+
- _Not_: Önemli: clientId ve clientSecret gizli tutulmalı ve kamuya açık şekilde paylaşılmamalıdır. Lütfen bunları ortam değişkenleri gibi güvenli bir yerde sakladığınızdan emin olun.
|
|
230
|
+
|
|
231
|
+
- **dictionaryPriorityStrategy**:
|
|
232
|
+
- _Tür_: `string`
|
|
233
|
+
- _Varsayılan_: `'local_first'`
|
|
234
|
+
- _Açıklama_: Hem yerel hem de uzak sözlüklerin mevcut olduğu durumlarda sözlüklerin önceliklendirilme stratejisi. `'distant_first'` olarak ayarlanırsa, uygulama uzak sözlüklere yerel sözlüklerden daha fazla öncelik verir. `'local_first'` olarak ayarlanırsa, uygulama yerel sözlüklere uzak sözlüklerden daha fazla öncelik verir.
|
|
235
|
+
- _Örnek_: `'distant_first'`
|
|
236
|
+
|
|
237
|
+
- **liveSync**:
|
|
238
|
+
- _Tür_: `boolean`
|
|
239
|
+
- _Varsayılan_: `false`
|
|
240
|
+
- _Açıklama_: CMS / Görsel Editör / Backend üzerinde bir değişiklik algılandığında uygulama sunucusunun içeriği sıcak yeniden yükleyip yüklemeyeceğini belirtir.
|
|
241
|
+
- _Örnek_: `true`
|
|
242
|
+
- _Not_: Örneğin, yeni bir sözlük eklendiğinde veya güncellendiğinde, uygulama sayfada görüntülenecek içeriği günceller.
|
|
243
|
+
- _Not_: Canlı senkronizasyon, uygulamanın içeriğini başka bir sunucuya dışa aktarmayı gerektirir. Bu, uygulamanın performansını biraz etkileyebilir. Bunu sınırlamak için, uygulamanın ve canlı senkronizasyon sunucusunun aynı makinede barındırılmasını öneriyoruz. Ayrıca, canlı senkronizasyon ile `optimize` kombinasyonu, canlı senkronizasyon sunucusuna önemli sayıda istek gönderebilir. Altyapınıza bağlı olarak, her iki seçeneği ve kombinasyonlarını test etmenizi öneririz.
|
|
244
|
+
|
|
245
|
+
- **liveSyncPort**:
|
|
246
|
+
- _Tür_: `number`
|
|
247
|
+
- _Varsayılan_: `4000`
|
|
248
|
+
- _Açıklama_: Canlı senkronizasyon sunucusunun portu.
|
|
249
|
+
- _Örnek_: `4000`
|
|
250
|
+
- _Not_: Canlı senkronizasyon sunucusunun portu.
|
|
251
|
+
|
|
252
|
+
- **liveSyncURL**:
|
|
253
|
+
- _Tür_: `string`
|
|
254
|
+
- _Varsayılan_: `'http://localhost:{liveSyncPort}'`
|
|
255
|
+
- _Açıklama_: Canlı senkronizasyon sunucusunun URL'si.
|
|
256
|
+
- _Örnek_: `'https://example.com'`
|
|
257
|
+
- _Not_: Varsayılan olarak localhost'a işaret eder ancak uzak bir canlı senkronizasyon sunucusu durumunda herhangi bir URL'ye değiştirilebilir.
|
|
258
|
+
|
|
259
|
+
### Ara Katman (Middleware) Yapılandırması
|
|
260
|
+
|
|
261
|
+
Uygulamanın çerezleri, başlıkları ve yerel yönetimi için URL öneklerini nasıl yönettiğini kontrol eden ayarlar.
|
|
262
|
+
|
|
263
|
+
#### Özellikler
|
|
264
|
+
|
|
265
|
+
- **headerName**:
|
|
266
|
+
- _Tür_: `string`
|
|
267
|
+
- _Varsayılan_: `'x-intlayer-locale'`
|
|
268
|
+
- _Açıklama_: Yerel ayarı belirlemek için kullanılan HTTP başlığının adı.
|
|
269
|
+
- _Örnek_: `'x-custom-locale'`
|
|
270
|
+
- _Not_: API tabanlı yerel belirleme için faydalıdır.
|
|
271
|
+
|
|
272
|
+
- **cookieName**:
|
|
273
|
+
- _Tür_: `string`
|
|
274
|
+
- _Varsayılan_: `'intlayer-locale'`
|
|
275
|
+
- _Açıklama_: Yerel ayarı saklamak için kullanılan çerezin adı.
|
|
276
|
+
- _Örnek_: `'custom-locale'`
|
|
277
|
+
- _Not_: Oturumlar arasında yerel ayarın korunması için kullanılır.
|
|
278
|
+
|
|
279
|
+
- **prefixDefault**:
|
|
280
|
+
- _Tür_: `boolean`
|
|
281
|
+
- _Varsayılan_: `false`
|
|
282
|
+
- _Açıklama_: Varsayılan yerel ayarın URL'de dahil edilip edilmeyeceği.
|
|
283
|
+
- _Örnek_: `true`
|
|
284
|
+
- _Not_:
|
|
285
|
+
- Eğer `true` ve `defaultLocale = 'en'` ise: yol = `/en/dashboard` veya `/fr/dashboard`
|
|
286
|
+
- Eğer `false` ve `defaultLocale = 'en'` ise: yol = `/dashboard` veya `/fr/dashboard`
|
|
287
|
+
|
|
288
|
+
- **basePath**:
|
|
289
|
+
- _Tür_: `string`
|
|
290
|
+
- _Varsayılan_: `''`
|
|
291
|
+
- _Açıklama_: Uygulama URL'leri için temel yol.
|
|
292
|
+
- _Örnek_: `'/my-app'`
|
|
293
|
+
- _Not_:
|
|
294
|
+
- Uygulama `https://example.com/my-app` adresinde barındırılıyorsa
|
|
295
|
+
- Temel yol `'/my-app'` olur
|
|
296
|
+
- URL `https://example.com/my-app/en` olacaktır
|
|
297
|
+
- Eğer base path ayarlanmazsa, URL `https://example.com/en` olacaktır.
|
|
298
|
+
|
|
299
|
+
- **serverSetCookie**:
|
|
300
|
+
- _Tür_: `string`
|
|
301
|
+
- _Varsayılan_: `'always'`
|
|
302
|
+
- _Açıklama_: Sunucuda locale çerezinin ayarlanma kuralı.
|
|
303
|
+
- _Seçenekler_: `'always'`, `'never'`
|
|
304
|
+
- _Örnek_: `'never'`
|
|
305
|
+
- _Not_: Locale çerezinin her istekte mi yoksa hiç mi ayarlanacağını kontrol eder.
|
|
306
|
+
|
|
307
|
+
- **noPrefix**:
|
|
308
|
+
- _Tür_: `boolean`
|
|
309
|
+
- _Varsayılan_: `false`
|
|
310
|
+
- _Açıklama_: URL'lerden locale önekinin çıkarılıp çıkarılmayacağı.
|
|
311
|
+
- _Örnek_: `true`
|
|
312
|
+
- _Not_:
|
|
313
|
+
- Eğer `true` ise: URL'de önek olmaz
|
|
314
|
+
- Eğer `false` ise: URL'de önek olur
|
|
315
|
+
- `basePath = '/my-app'` örneği:
|
|
316
|
+
- Eğer `noPrefix = false` ise: URL `https://example.com/my-app/en` olur
|
|
317
|
+
- Eğer `noPrefix = true` ise: URL `https://example.com` olur
|
|
318
|
+
|
|
319
|
+
- **detectLocaleOnPrefetchNoPrefix**:
|
|
320
|
+
- _Tür_: `boolean`
|
|
321
|
+
- _Varsayılan_: `false`
|
|
322
|
+
- _Açıklama_: Next.js önceden getirme (prefetch) istekleri sırasında locale tespitinin yapılıp yapılmayacağını kontrol eder.
|
|
323
|
+
- _Örnek_: `true`
|
|
324
|
+
- _Not_: Bu ayar, Next.js'in locale önceden getirme işlemini nasıl yönettiğini etkiler:
|
|
325
|
+
- **Örnek senaryo:**
|
|
326
|
+
- Kullanıcının tarayıcı dili `'fr'`
|
|
327
|
+
- Mevcut sayfa `/fr/about`
|
|
328
|
+
- Bağlantı `/about` sayfasını önceden getiriyor
|
|
329
|
+
- **`detectLocaleOnPrefetchNoPrefix: true` ile:**
|
|
330
|
+
- Önceden getirme, tarayıcıdan `'fr'` locale bilgisini algılar
|
|
331
|
+
- Önceden getirme `/fr/about` sayfasına yönlendirilir
|
|
332
|
+
- **`detectLocaleOnPrefetchNoPrefix: false` (varsayılan) ile:**
|
|
333
|
+
- Önceden getirme varsayılan locale kullanır
|
|
334
|
+
- Önceden getirme `/en/about` sayfasına yönlendirilir (varsayılanın `'en'` olduğu varsayılır)
|
|
335
|
+
- **`true` ne zaman kullanılmalı:**
|
|
336
|
+
- Uygulamanız yerelleştirilmemiş dahili bağlantılar kullanıyorsa (örneğin `<a href="/about">`)
|
|
337
|
+
- Normal ve önceden getirme (prefetch) istekleri arasında tutarlı locale tespit davranışı istiyorsanız
|
|
338
|
+
- **`false` (varsayılan) ne zaman kullanılmalı:**
|
|
339
|
+
- Uygulamanız locale önekli bağlantılar kullanıyorsa (örneğin `<a href="/fr/about">`)
|
|
340
|
+
- Önceden getirme performansını optimize etmek istiyorsanız
|
|
341
|
+
- Olası yönlendirme döngülerinden kaçınmak istiyorsanız
|
|
342
|
+
|
|
343
|
+
---
|
|
344
|
+
|
|
345
|
+
### İçerik Yapılandırması
|
|
346
|
+
|
|
347
|
+
Uygulama içindeki içerik yönetimi ile ilgili ayarlar; dizin isimleri, dosya uzantıları ve türetilmiş yapılandırmalar dahil.
|
|
348
|
+
|
|
349
|
+
#### Özellikler
|
|
350
|
+
|
|
351
|
+
- **autoFill**:
|
|
352
|
+
- _Tür_: `boolean | string | { [key in Locales]?: string }`
|
|
353
|
+
- _Varsayılan_: `undefined`
|
|
354
|
+
- _Açıklama_: İçeriğin yapay zeka kullanılarak otomatik olarak nasıl doldurulacağını belirtir. `intlayer.config.ts` dosyasında global olarak tanımlanabilir.
|
|
355
|
+
- _Örnek_: true
|
|
356
|
+
- _Örnek_: `'./{{fileName}}.content.json'`
|
|
357
|
+
- _Örnek_: `{ fr: './{{fileName}}.fr.content.json', es: './{{fileName}}.es.content.json' }`
|
|
358
|
+
- _Not_: Otomatik doldurma yapılandırması. Şunlar olabilir:
|
|
359
|
+
- boolean: Tüm yereller için otomatik doldurmayı etkinleştirir
|
|
360
|
+
- string: Değişkenler içeren tek bir dosya yolu veya şablon
|
|
361
|
+
- object: Yerel bazında dosya yolları
|
|
362
|
+
|
|
363
|
+
- **watch**:
|
|
364
|
+
- _Tür_: `boolean`
|
|
365
|
+
- _Varsayılan_: `process.env.NODE_ENV === 'development'`
|
|
366
|
+
- _Açıklama_: Intlayer'ın uygulamadaki içerik beyan dosyalarındaki değişiklikleri izleyip ilgili sözlükleri yeniden oluşturup oluşturmayacağını belirtir.
|
|
367
|
+
|
|
368
|
+
- **fileExtensions**:
|
|
369
|
+
- _Tür_: `string[]`
|
|
370
|
+
- _Varsayılan_: `['.content.ts', '.content.js', '.content.cjs', '.content.mjs', '.content.json', '.content.tsx', '.content.jsx']`
|
|
371
|
+
- _Açıklama_: Sözlükler oluşturulurken aranacak dosya uzantıları.
|
|
372
|
+
- _Örnek_: `['.data.ts', '.data.js', '.data.json']`
|
|
373
|
+
- _Not_: Dosya uzantılarının özelleştirilmesi çakışmaları önlemeye yardımcı olabilir.
|
|
374
|
+
|
|
375
|
+
- **baseDir**:
|
|
376
|
+
- _Tür_: `string`
|
|
377
|
+
- _Varsayılan_: `process.cwd()`
|
|
378
|
+
- _Açıklama_: Projenin temel dizini.
|
|
379
|
+
- _Örnek_: `'/path/to/project'`
|
|
380
|
+
- _Not_: Tüm Intlayer ile ilgili dizinlerin çözülmesinde kullanılır.
|
|
381
|
+
|
|
382
|
+
- **dictionaryOutput**:
|
|
383
|
+
- _Tür_: `string[]`
|
|
384
|
+
- _Varsayılan_: `['intlayer']`
|
|
385
|
+
- _Açıklama_: Kullanılacak sözlük çıktısı türü, örn. `'intlayer'` veya `'i18next'`.
|
|
386
|
+
|
|
387
|
+
- **contentDir**:
|
|
388
|
+
- _Tür_: `string[]`
|
|
389
|
+
- _Varsayılan_: `['.']`
|
|
390
|
+
- _Örnek_: `['src', '../../ui-library', require.resolve("@my-package/content")]`
|
|
391
|
+
- _Açıklama_: İçeriğin depolandığı dizin yolu.
|
|
392
|
+
|
|
393
|
+
- **dictionariesDir**:
|
|
394
|
+
- _Tür_: `string`
|
|
395
|
+
- _Varsayılan_: `'.intlayer/dictionaries'`
|
|
396
|
+
- _Açıklama_: Ara sonuçların veya çıktıların depolanacağı dizin yolu.
|
|
397
|
+
|
|
398
|
+
- **moduleAugmentationDir**:
|
|
399
|
+
- _Tür_: `string`
|
|
400
|
+
- _Varsayılan_: `'.intlayer/types'`
|
|
401
|
+
- _Açıklama_: Modül genişletme için dizin, daha iyi IDE önerileri ve tip kontrolü sağlar.
|
|
402
|
+
- _Örnek_: `'intlayer-types'`
|
|
403
|
+
- _Not_: Bunu `tsconfig.json` dosyanıza eklediğinizden emin olun.
|
|
404
|
+
|
|
405
|
+
- **unmergedDictionariesDir**:
|
|
406
|
+
- _Tür_: `string`
|
|
407
|
+
- _Varsayılan_: `'.intlayer/unmerged_dictionary'`
|
|
408
|
+
- _Açıklama_: Birleştirilmemiş sözlüklerin depolanacağı dizin.
|
|
409
|
+
- _Örnek_: `'translations'`
|
|
410
|
+
|
|
411
|
+
- **dictionariesDir**:
|
|
412
|
+
- _Tür_: `string`
|
|
413
|
+
- _Varsayılan_: `'.intlayer/dictionary'`
|
|
414
|
+
- _Açıklama_: Yerelleştirme sözlüklerinin saklandığı dizin.
|
|
415
|
+
- _Örnek_: `'translations'`
|
|
416
|
+
|
|
417
|
+
- **i18nextResourcesDir**:
|
|
418
|
+
- _Tür_: `string`
|
|
419
|
+
- _Varsayılan_: `'i18next_dictionary'`
|
|
420
|
+
- _Açıklama_: i18n sözlüklerinin saklandığı dizin.
|
|
421
|
+
- _Örnek_: `'translations'`
|
|
422
|
+
- _Not_: Bu dizinin i18next çıktı türü için yapılandırıldığından emin olun.
|
|
423
|
+
|
|
424
|
+
- **typesDir**:
|
|
425
|
+
- _Tür_: `string`
|
|
426
|
+
- _Varsayılan_: `'types'`
|
|
427
|
+
- _Açıklama_: Sözlük türlerinin saklandığı dizin.
|
|
428
|
+
- _Örnek_: `'intlayer-types'`
|
|
429
|
+
|
|
430
|
+
- **mainDir**:
|
|
431
|
+
- _Tür_: `string`
|
|
432
|
+
- _Varsayılan_: `'main'`
|
|
433
|
+
- _Açıklama_: Ana uygulama dosyalarının saklandığı dizin.
|
|
434
|
+
- _Örnek_: `'intlayer-main'`
|
|
435
|
+
|
|
436
|
+
- **excludedPath**:
|
|
437
|
+
- _Tür_: `string[]`
|
|
438
|
+
- _Varsayılan_: `['node_modules']`
|
|
439
|
+
- _Açıklama_: İçerik aramasından hariç tutulan dizinler.
|
|
440
|
+
- _Not_: Bu ayar henüz kullanılmamaktadır, ancak gelecekte uygulanması planlanmaktadır.
|
|
441
|
+
|
|
442
|
+
### Logger Yapılandırması
|
|
443
|
+
|
|
444
|
+
Logger'ı kontrol eden ayarlar, kullanılacak önek dahil.
|
|
445
|
+
|
|
446
|
+
#### Özellikler
|
|
447
|
+
|
|
448
|
+
- **mode**:
|
|
449
|
+
- _Tür_: `string`
|
|
450
|
+
- _Varsayılan_: `default`
|
|
451
|
+
- _Açıklama_: Logger modunu belirtir.
|
|
452
|
+
- _Seçenekler_: `default`, `verbose`, `disabled`
|
|
453
|
+
- _Örnek_: `default`
|
|
454
|
+
- _Not_: Logger modu. Verbose modu daha fazla bilgi kaydeder, ancak hata ayıklama amaçlı kullanılabilir. Disabled modu logger'ı devre dışı bırakır.
|
|
455
|
+
|
|
456
|
+
- **prefix**:
|
|
457
|
+
- _Tür_: `string`
|
|
458
|
+
- _Varsayılan_: `'[intlayer] '`
|
|
459
|
+
- _Açıklama_: Logger'ın öneki.
|
|
460
|
+
- _Örnek_: `'[my custom prefix] '`
|
|
461
|
+
- _Not_: Günlüğün ön eki.
|
|
462
|
+
|
|
463
|
+
### AI Yapılandırması
|
|
464
|
+
|
|
465
|
+
Intlayer'ın AI özelliklerini kontrol eden ayarlar, sağlayıcı, model ve API anahtarı dahil.
|
|
466
|
+
|
|
467
|
+
Bu yapılandırma, bir erişim anahtarı kullanarak [Intlayer Kontrol Paneli](https://intlayer.org/dashboard/project) üzerinden kayıtlıysanız isteğe bağlıdır. Intlayer, ihtiyaçlarınız için en verimli ve maliyet-etkin AI çözümünü otomatik olarak yönetecektir. Varsayılan seçenekleri kullanmak, Intlayer'ın en uygun modelleri kullanmak için sürekli güncellenmesi nedeniyle uzun vadeli bakım kolaylığı sağlar.
|
|
468
|
+
|
|
469
|
+
Kendi API anahtarınızı veya belirli bir modeli kullanmayı tercih ediyorsanız, özel AI yapılandırmanızı tanımlayabilirsiniz.
|
|
470
|
+
Bu AI yapılandırması, Intlayer ortamınız genelinde kullanılacaktır. CLI komutları, bu ayarları komutlar için varsayılan olarak kullanacaktır (örneğin `fill`), ayrıca SDK, Görsel Editör ve CMS de bu ayarları kullanır. Belirli kullanım durumları için bu varsayılan değerleri komut parametreleriyle geçersiz kılabilirsiniz.
|
|
471
|
+
|
|
472
|
+
Intlayer, artırılmış esneklik ve seçenek için birden fazla AI sağlayıcısını destekler. Şu anda desteklenen sağlayıcılar şunlardır:
|
|
473
|
+
|
|
474
|
+
- **OpenAI** (varsayılan)
|
|
475
|
+
- **Anthropic Claude**
|
|
476
|
+
- **Mistral AI**
|
|
477
|
+
- **DeepSeek**
|
|
478
|
+
- **Google Gemini**
|
|
479
|
+
- **Meta Llama**
|
|
480
|
+
|
|
481
|
+
#### Özellikler
|
|
482
|
+
|
|
483
|
+
- **provider**:
|
|
484
|
+
- _Tür_: `string`
|
|
485
|
+
- _Varsayılan_: `'openai'`
|
|
486
|
+
- _Açıklama_: Intlayer'ın AI özellikleri için kullanılacak sağlayıcı.
|
|
487
|
+
- _Seçenekler_: `'openai'`, `'anthropic'`, `'mistral'`, `'deepseek'`, `'gemini'`
|
|
488
|
+
- _Örnek_: `'anthropic'`
|
|
489
|
+
- _Not_: Farklı sağlayıcılar farklı API anahtarları gerektirebilir ve farklı fiyatlandırma modellerine sahip olabilir.
|
|
490
|
+
|
|
491
|
+
- **model**:
|
|
492
|
+
- _Tür_: `string`
|
|
493
|
+
- _Varsayılan_: Yok
|
|
494
|
+
- _Açıklama_: Intlayer'ın yapay zeka özellikleri için kullanılacak model.
|
|
495
|
+
- _Örnek_: `'gpt-4o-2024-11-20'`
|
|
496
|
+
- _Not_: Kullanılacak spesifik model sağlayıcıya göre değişir.
|
|
497
|
+
|
|
498
|
+
- **temperature**:
|
|
499
|
+
- _Tür_: `number`
|
|
500
|
+
- _Varsayılan_: Yok
|
|
501
|
+
- _Açıklama_: Sıcaklık, yapay zekanın yanıtlarının rastgeleliğini kontrol eder.
|
|
502
|
+
- _Örnek_: `0.1`
|
|
503
|
+
- _Not_: Daha yüksek bir sıcaklık, yapay zekayı daha yaratıcı ve daha az tahmin edilebilir yapar.
|
|
504
|
+
|
|
505
|
+
- **apiKey**:
|
|
506
|
+
- _Tür_: `string`
|
|
507
|
+
- _Varsayılan_: Yok
|
|
508
|
+
- _Açıklama_: Seçilen sağlayıcı için API anahtarınız.
|
|
509
|
+
- _Not_: Önemli: API anahtarları gizli tutulmalı ve kamuya açık şekilde paylaşılmamalıdır. Lütfen bunları ortam değişkenleri gibi güvenli bir yerde sakladığınızdan emin olun.
|
|
510
|
+
|
|
511
|
+
- **applicationContext**:
|
|
512
|
+
- _Tür_: `string`
|
|
513
|
+
- _Varsayılan_: Yok
|
|
514
|
+
- _Açıklama_: AI modeline uygulamanız hakkında ek bağlam sağlar, böylece daha doğru ve bağlama uygun çeviriler oluşturmasına yardımcı olur. Bu, uygulamanızın alanı, hedef kitlesi, tonu veya belirli terminolojisi hakkında bilgiler içerebilir.
|
|
515
|
+
|
|
516
|
+
### Derleme Yapılandırması
|
|
517
|
+
|
|
518
|
+
Intlayer'ın uygulamanızın uluslararasılaştırmasını nasıl optimize edip derleyeceğini kontrol eden ayarlar.
|
|
519
|
+
|
|
520
|
+
Derleme seçenekleri `@intlayer/babel` ve `@intlayer/swc` eklentilerine uygulanır.
|
|
521
|
+
|
|
522
|
+
> Geliştirme modunda, Intlayer geliştirme deneyimini basitleştirmek için sözlüklerde statik importlar kullanır.
|
|
523
|
+
|
|
524
|
+
> Optimize edildiğinde, Intlayer chunking'i optimize etmek için sözlük çağrılarını değiştirir, böylece nihai paket yalnızca gerçekten kullanılan sözlükleri import eder.
|
|
525
|
+
|
|
526
|
+
#### Özellikler
|
|
527
|
+
|
|
528
|
+
- **optimize**:
|
|
529
|
+
- _Tür_: `boolean`
|
|
530
|
+
- _Varsayılan_: `process.env.NODE_ENV === 'production'`
|
|
531
|
+
- _Açıklama_: Derlemenin optimize edilip edilmeyeceğini kontrol eder.
|
|
532
|
+
- _Örnek_: `true`
|
|
533
|
+
- _Not_: Etkinleştirildiğinde, Intlayer chunking'i optimize etmek için tüm sözlük çağrılarını değiştirir. Böylece nihai paket yalnızca kullanılan sözlükleri import eder. Tüm importlar, sözlüklerin yüklenmesi sırasında asenkron işlemi önlemek için statik import olarak kalır.
|
|
534
|
+
- _Not_: Intlayer, `useIntlayer` çağrılarının tümünü `importMode` seçeneği ile tanımlanan moda ve `getIntlayer` çağrılarını `getDictionary` ile değiştirir.
|
|
535
|
+
- _Not_: Bu seçenek `@intlayer/babel` ve `@intlayer/swc` eklentilerine dayanır.
|
|
536
|
+
- _Not_: `useIntlayer` çağrılarında tüm anahtarların statik olarak tanımlandığından emin olun. Örneğin `useIntlayer('navbar')`.
|
|
537
|
+
|
|
538
|
+
- **importMode**:
|
|
539
|
+
- _Tür_: `'static' | 'dynamic' | 'live'`
|
|
540
|
+
- _Varsayılan_: `'static'`
|
|
541
|
+
- _Açıklama_: Sözlüklerin nasıl içe aktarılacağını kontrol eder.
|
|
542
|
+
- _Örnek_: `'dynamic'`
|
|
543
|
+
- _Not_: Mevcut modlar:
|
|
544
|
+
- "static": Sözlükler statik olarak içe aktarılır. `useIntlayer` `useDictionary` ile değiştirilir.
|
|
545
|
+
- "dynamic": Sözlükler Suspense kullanılarak dinamik olarak içe aktarılır. `useIntlayer` `useDictionaryDynamic` ile değiştirilir.
|
|
546
|
+
- "live": Sözlükler, canlı senkronizasyon API'si kullanılarak dinamik olarak getirilir. `useIntlayer` fonksiyonunu `useDictionaryFetch` ile değiştirir.
|
|
547
|
+
- _Not_: Dinamik importlar Suspense'e dayanır ve render performansını biraz etkileyebilir.
|
|
548
|
+
- _Not_: Devre dışı bırakılırsa, kullanılmasalar bile tüm yereller aynı anda yüklenecektir.
|
|
549
|
+
- _Not_: Bu seçenek `@intlayer/babel` ve `@intlayer/swc` eklentilerine bağlıdır.
|
|
550
|
+
- _Not_: `useIntlayer` çağrılarında tüm anahtarların statik olarak tanımlandığından emin olun. Örneğin `useIntlayer('navbar')`.
|
|
551
|
+
- _Not_: `optimize` devre dışı bırakılırsa, bu seçenek göz ardı edilir.
|
|
552
|
+
- _Not_: Eğer "live" olarak ayarlanırsa, yalnızca uzak içerik içeren ve "live" bayrağı olarak ayarlanmış sözlükler canlı mod olarak dönüştürülür. Diğerleri, sorgu sayısını optimize etmek ve yükleme performansını artırmak için dinamik modda dinamik olarak içe aktarılır.
|
|
553
|
+
- _Not_: Canlı mod, sözlükleri almak için canlı senkronizasyon API'sini kullanır. API çağrısı başarısız olursa, sözlükler dinamik modda dinamik olarak içe aktarılır.
|
|
554
|
+
- _Not_: Bu seçenek `getIntlayer`, `getDictionary`, `useDictionary`, `useDictionaryAsync` ve `useDictionaryDynamic` fonksiyonlarını etkilemez.
|
|
555
|
+
|
|
556
|
+
- **traversePattern**:
|
|
557
|
+
- _Tür_: `string[]`
|
|
558
|
+
- _Varsayılan_: `['**\/*.{js,ts,mjs,cjs,jsx,tsx,mjx,cjx}', '!**\/node_modules/**']`
|
|
559
|
+
- _Açıklama_: Optimizasyon sırasında hangi dosyaların taranacağını tanımlayan desenler.
|
|
560
|
+
- _Örnek_: `['src/**\/*.{ts,tsx}', '../ui-library/**\/*.{ts,tsx}', '!**/node_modules/**']`
|
|
561
|
+
- _Not_: Optimizasyonu ilgili kod dosyalarıyla sınırlamak ve derleme performansını artırmak için bunu kullanın.
|
|
562
|
+
- _Not_: Bu seçenek `optimize` devre dışı bırakılırsa dikkate alınmaz.
|
|
563
|
+
- _Not_: Glob deseni kullanın.
|
|
564
|
+
|
|
565
|
+
## Doküman Geçmişi
|
|
566
|
+
|
|
567
|
+
| Sürüm | Tarih | Değişiklikler |
|
|
568
|
+
| ----- | ---------- | -------------------------- |
|
|
569
|
+
| 6.0.0 | 2025-09-16 | `live` import modu eklendi |
|
|
570
|
+
|
|
571
|
+
- _Açıklama_: Optimizasyon sırasında hangi dosyaların taranacağını tanımlayan desenler.
|
|
572
|
+
- _Örnek_: `['src/**\/*.{ts,tsx}', '../ui-library/**\/*.{ts,tsx}', '!**/node_modules/**']`
|
|
573
|
+
- _Not_: Optimizasyonu ilgili kod dosyalarıyla sınırlamak ve derleme performansını artırmak için kullanın.
|
|
574
|
+
- _Not_: Bu seçenek `optimize` devre dışı bırakılırsa göz ardı edilir.
|
|
575
|
+
- _Not_: Glob deseni kullanın.
|
|
576
|
+
|
|
577
|
+
## Doküman Geçmişi
|
|
578
|
+
|
|
579
|
+
| Sürüm | Tarih | Değişiklikler |
|
|
580
|
+
| ------ | ---------- | -------------------------------------------------------------------------------------------------- |
|
|
581
|
+
| 6.0.0 | 2025-09-16 | `live` import modu eklendi |
|
|
582
|
+
| 6.0.0 | 2025-09-04 | `hotReload` alanı `liveSync` ile değiştirildi ve `liveSyncPort` ile `liveSyncURL` alanları eklendi |
|
|
583
|
+
| 5.6.1 | 2025-07-25 | `activateDynamicImport` seçeneği `importMode` ile değiştirildi |
|
|
584
|
+
| 5.6.0 | 2025-07-13 | Varsayılan contentDir `['src']`'den `['.']` olarak değiştirildi |
|
|
585
|
+
| 5.5.11 | 2025-06-29 | `docs` komutları eklendi |
|