@intlayer/docs 5.8.1 → 6.0.0-canary.1

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.
Files changed (378) hide show
  1. package/blog/ar/rag_powered_documentation_assistant.md +282 -0
  2. package/blog/de/rag_powered_documentation_assistant.md +282 -0
  3. package/blog/en/rag_powered_documentation_assistant.md +289 -0
  4. package/blog/en-GB/rag_powered_documentation_assistant.md +284 -0
  5. package/blog/es/rag_powered_documentation_assistant.md +308 -0
  6. package/blog/fr/rag_powered_documentation_assistant.md +308 -0
  7. package/blog/hi/rag_powered_documentation_assistant.md +284 -0
  8. package/blog/it/rag_powered_documentation_assistant.md +284 -0
  9. package/blog/ja/rag_powered_documentation_assistant.md +284 -0
  10. package/blog/ko/rag_powered_documentation_assistant.md +283 -0
  11. package/blog/pt/rag_powered_documentation_assistant.md +284 -0
  12. package/blog/ru/rag_powered_documentation_assistant.md +284 -0
  13. package/blog/tr/index.md +69 -0
  14. package/blog/tr/internationalization_and_SEO.md +273 -0
  15. package/blog/tr/intlayer_with_i18next.md +162 -0
  16. package/blog/tr/intlayer_with_next-i18next.md +367 -0
  17. package/blog/tr/intlayer_with_next-intl.md +392 -0
  18. package/blog/tr/intlayer_with_react-i18next.md +346 -0
  19. package/blog/tr/intlayer_with_react-intl.md +345 -0
  20. package/blog/tr/list_i18n_technologies/CMS/drupal.md +143 -0
  21. package/blog/tr/list_i18n_technologies/CMS/wix.md +167 -0
  22. package/blog/tr/list_i18n_technologies/CMS/wordpress.md +188 -0
  23. package/blog/tr/list_i18n_technologies/frameworks/angular.md +125 -0
  24. package/blog/tr/list_i18n_technologies/frameworks/flutter.md +150 -0
  25. package/blog/tr/list_i18n_technologies/frameworks/react-native.md +217 -0
  26. package/blog/tr/list_i18n_technologies/frameworks/react.md +155 -0
  27. package/blog/tr/list_i18n_technologies/frameworks/svelte.md +129 -0
  28. package/blog/tr/list_i18n_technologies/frameworks/vue.md +130 -0
  29. package/blog/tr/next-i18next_vs_next-intl_vs_intlayer.md +170 -0
  30. package/blog/tr/rag_powered_documentation_assistant.md +284 -0
  31. package/blog/tr/react-i18next_vs_react-intl_vs_intlayer.md +162 -0
  32. package/blog/tr/vue-i18n_vs_intlayer.md +276 -0
  33. package/blog/tr/what_is_internationalization.md +166 -0
  34. package/blog/zh/rag_powered_documentation_assistant.md +284 -0
  35. package/dist/cjs/generated/blog.entry.cjs +212 -0
  36. package/dist/cjs/generated/blog.entry.cjs.map +1 -1
  37. package/dist/cjs/generated/docs.entry.cjs +660 -132
  38. package/dist/cjs/generated/docs.entry.cjs.map +1 -1
  39. package/dist/cjs/generated/frequentQuestions.entry.cjs +84 -0
  40. package/dist/cjs/generated/frequentQuestions.entry.cjs.map +1 -1
  41. package/dist/cjs/generated/legal.entry.cjs +6 -0
  42. package/dist/cjs/generated/legal.entry.cjs.map +1 -1
  43. package/dist/esm/generated/blog.entry.mjs +212 -0
  44. package/dist/esm/generated/blog.entry.mjs.map +1 -1
  45. package/dist/esm/generated/docs.entry.mjs +660 -132
  46. package/dist/esm/generated/docs.entry.mjs.map +1 -1
  47. package/dist/esm/generated/frequentQuestions.entry.mjs +84 -0
  48. package/dist/esm/generated/frequentQuestions.entry.mjs.map +1 -1
  49. package/dist/esm/generated/legal.entry.mjs +6 -0
  50. package/dist/esm/generated/legal.entry.mjs.map +1 -1
  51. package/dist/types/generated/blog.entry.d.ts +1 -0
  52. package/dist/types/generated/blog.entry.d.ts.map +1 -1
  53. package/dist/types/generated/docs.entry.d.ts +5 -2
  54. package/dist/types/generated/docs.entry.d.ts.map +1 -1
  55. package/dist/types/generated/frequentQuestions.entry.d.ts.map +1 -1
  56. package/dist/types/generated/legal.entry.d.ts.map +1 -1
  57. package/docs/ar/autoFill.md +41 -40
  58. package/docs/ar/configuration.md +202 -199
  59. package/docs/ar/dictionary/content_file.md +1059 -0
  60. package/docs/ar/intlayer_CMS.md +4 -4
  61. package/docs/ar/intlayer_with_nestjs.md +271 -0
  62. package/docs/ar/intlayer_with_nextjs_page_router.md +1 -1
  63. package/docs/ar/intlayer_with_react_router_v7.md +533 -0
  64. package/docs/ar/intlayer_with_tanstack.md +465 -299
  65. package/docs/ar/intlayer_with_vite+preact.md +7 -7
  66. package/docs/ar/intlayer_with_vite+react.md +7 -7
  67. package/docs/ar/intlayer_with_vite+vue.md +9 -9
  68. package/docs/ar/packages/vite-intlayer/index.md +3 -3
  69. package/docs/ar/readme.md +261 -0
  70. package/docs/ar/testing.md +199 -0
  71. package/docs/de/autoFill.md +42 -19
  72. package/docs/de/configuration.md +155 -147
  73. package/docs/de/dictionary/content_file.md +1059 -0
  74. package/docs/de/intlayer_CMS.md +4 -5
  75. package/docs/de/intlayer_with_nestjs.md +270 -0
  76. package/docs/de/intlayer_with_nextjs_page_router.md +1 -1
  77. package/docs/de/intlayer_with_react_router_v7.md +537 -0
  78. package/docs/de/intlayer_with_tanstack.md +469 -302
  79. package/docs/de/intlayer_with_vite+preact.md +7 -7
  80. package/docs/de/intlayer_with_vite+react.md +7 -7
  81. package/docs/de/intlayer_with_vite+vue.md +9 -9
  82. package/docs/de/packages/vite-intlayer/index.md +3 -3
  83. package/docs/de/readme.md +261 -0
  84. package/docs/de/testing.md +200 -0
  85. package/docs/en/CI_CD.md +4 -6
  86. package/docs/en/autoFill.md +25 -5
  87. package/docs/en/configuration.md +45 -54
  88. package/docs/en/dictionary/content_file.md +1054 -0
  89. package/docs/en/intlayer_CMS.md +8 -7
  90. package/docs/en/intlayer_cli.md +112 -5
  91. package/docs/en/intlayer_with_nestjs.md +268 -0
  92. package/docs/en/intlayer_with_nextjs_page_router.md +1 -1
  93. package/docs/en/intlayer_with_react_router_v7.md +531 -0
  94. package/docs/en/intlayer_with_tanstack.md +463 -294
  95. package/docs/en/intlayer_with_vite+preact.md +8 -8
  96. package/docs/en/intlayer_with_vite+react.md +8 -8
  97. package/docs/en/intlayer_with_vite+vue.md +8 -8
  98. package/docs/en/packages/intlayer/getLocalizedUrl.md +102 -25
  99. package/docs/en/packages/vite-intlayer/index.md +3 -3
  100. package/docs/en/readme.md +261 -0
  101. package/docs/en/testing.md +200 -0
  102. package/docs/en-GB/autoFill.md +29 -6
  103. package/docs/en-GB/configuration.md +79 -71
  104. package/docs/en-GB/dictionary/content_file.md +1084 -0
  105. package/docs/en-GB/intlayer_CMS.md +4 -5
  106. package/docs/en-GB/intlayer_with_nestjs.md +268 -0
  107. package/docs/en-GB/intlayer_with_nextjs_page_router.md +1 -1
  108. package/docs/en-GB/intlayer_with_react_router_v7.md +533 -0
  109. package/docs/en-GB/intlayer_with_tanstack.md +466 -299
  110. package/docs/en-GB/intlayer_with_vite+preact.md +7 -7
  111. package/docs/en-GB/intlayer_with_vite+react.md +7 -7
  112. package/docs/en-GB/intlayer_with_vite+vue.md +9 -9
  113. package/docs/en-GB/packages/vite-intlayer/index.md +3 -3
  114. package/docs/en-GB/readme.md +261 -0
  115. package/docs/en-GB/testing.md +200 -0
  116. package/docs/es/autoFill.md +45 -23
  117. package/docs/es/configuration.md +171 -167
  118. package/docs/es/dictionary/content_file.md +1088 -0
  119. package/docs/es/intlayer_CMS.md +4 -5
  120. package/docs/es/intlayer_with_nestjs.md +268 -0
  121. package/docs/es/intlayer_with_nextjs_page_router.md +1 -1
  122. package/docs/es/intlayer_with_react_router_v7.md +533 -0
  123. package/docs/es/intlayer_with_tanstack.md +469 -280
  124. package/docs/es/intlayer_with_vite+preact.md +7 -7
  125. package/docs/es/intlayer_with_vite+react.md +7 -7
  126. package/docs/es/intlayer_with_vite+vue.md +9 -9
  127. package/docs/es/packages/vite-intlayer/index.md +3 -3
  128. package/docs/es/readme.md +261 -0
  129. package/docs/es/testing.md +200 -0
  130. package/docs/fr/autoFill.md +47 -24
  131. package/docs/fr/configuration.md +213 -198
  132. package/docs/fr/dictionary/content_file.md +1054 -0
  133. package/docs/fr/intlayer_CMS.md +4 -5
  134. package/docs/fr/intlayer_with_nestjs.md +268 -0
  135. package/docs/fr/intlayer_with_nextjs_page_router.md +1 -1
  136. package/docs/fr/intlayer_with_react_router_v7.md +549 -0
  137. package/docs/fr/intlayer_with_tanstack.md +465 -279
  138. package/docs/fr/intlayer_with_vite+preact.md +7 -7
  139. package/docs/fr/intlayer_with_vite+react.md +7 -7
  140. package/docs/fr/intlayer_with_vite+vue.md +9 -9
  141. package/docs/fr/packages/vite-intlayer/index.md +3 -3
  142. package/docs/fr/readme.md +261 -0
  143. package/docs/fr/testing.md +200 -0
  144. package/docs/hi/autoFill.md +47 -25
  145. package/docs/hi/configuration.md +194 -189
  146. package/docs/hi/dictionary/content_file.md +1056 -0
  147. package/docs/hi/intlayer_CMS.md +4 -5
  148. package/docs/hi/intlayer_with_nestjs.md +269 -0
  149. package/docs/hi/intlayer_with_nextjs_page_router.md +1 -1
  150. package/docs/hi/intlayer_with_react_router_v7.md +533 -0
  151. package/docs/hi/intlayer_with_tanstack.md +467 -282
  152. package/docs/hi/intlayer_with_vite+preact.md +7 -7
  153. package/docs/hi/intlayer_with_vite+react.md +7 -7
  154. package/docs/hi/intlayer_with_vite+vue.md +9 -9
  155. package/docs/hi/packages/vite-intlayer/index.md +3 -3
  156. package/docs/hi/readme.md +261 -0
  157. package/docs/hi/testing.md +200 -0
  158. package/docs/it/autoFill.md +46 -24
  159. package/docs/it/configuration.md +169 -161
  160. package/docs/it/dictionary/content_file.md +1061 -0
  161. package/docs/it/intlayer_CMS.md +4 -5
  162. package/docs/it/intlayer_with_nestjs.md +268 -0
  163. package/docs/it/intlayer_with_nextjs_page_router.md +1 -1
  164. package/docs/it/intlayer_with_react_router_v7.md +535 -0
  165. package/docs/it/intlayer_with_tanstack.md +467 -301
  166. package/docs/it/intlayer_with_vite+preact.md +7 -7
  167. package/docs/it/intlayer_with_vite+react.md +7 -7
  168. package/docs/it/intlayer_with_vite+vue.md +9 -9
  169. package/docs/it/packages/vite-intlayer/index.md +3 -3
  170. package/docs/it/readme.md +261 -0
  171. package/docs/it/testing.md +200 -0
  172. package/docs/ja/autoFill.md +45 -23
  173. package/docs/ja/configuration.md +243 -204
  174. package/docs/ja/dictionary/content_file.md +1064 -0
  175. package/docs/ja/intlayer_CMS.md +4 -5
  176. package/docs/ja/intlayer_with_nestjs.md +268 -0
  177. package/docs/ja/intlayer_with_nextjs_page_router.md +1 -1
  178. package/docs/ja/intlayer_with_react_router_v7.md +534 -0
  179. package/docs/ja/intlayer_with_tanstack.md +467 -303
  180. package/docs/ja/intlayer_with_vite+preact.md +7 -7
  181. package/docs/ja/intlayer_with_vite+react.md +7 -7
  182. package/docs/ja/intlayer_with_vite+vue.md +9 -9
  183. package/docs/ja/packages/vite-intlayer/index.md +3 -3
  184. package/docs/ja/readme.md +263 -0
  185. package/docs/ja/testing.md +200 -0
  186. package/docs/ko/autoFill.md +39 -16
  187. package/docs/ko/configuration.md +217 -197
  188. package/docs/ko/dictionary/content_file.md +1060 -0
  189. package/docs/ko/intlayer_CMS.md +4 -5
  190. package/docs/ko/intlayer_with_nestjs.md +268 -0
  191. package/docs/ko/intlayer_with_nextjs_page_router.md +1 -1
  192. package/docs/ko/intlayer_with_react_router_v7.md +540 -0
  193. package/docs/ko/intlayer_with_tanstack.md +466 -302
  194. package/docs/ko/intlayer_with_vite+preact.md +7 -7
  195. package/docs/ko/intlayer_with_vite+react.md +7 -7
  196. package/docs/ko/intlayer_with_vite+vue.md +9 -9
  197. package/docs/ko/packages/vite-intlayer/index.md +3 -3
  198. package/docs/ko/readme.md +261 -0
  199. package/docs/ko/testing.md +200 -0
  200. package/docs/pt/autoFill.md +39 -15
  201. package/docs/pt/configuration.md +165 -147
  202. package/docs/pt/dictionary/content_file.md +1062 -0
  203. package/docs/pt/intlayer_CMS.md +4 -5
  204. package/docs/pt/intlayer_with_nestjs.md +271 -0
  205. package/docs/pt/intlayer_with_nextjs_page_router.md +1 -1
  206. package/docs/pt/intlayer_with_react_router_v7.md +535 -0
  207. package/docs/pt/intlayer_with_tanstack.md +469 -300
  208. package/docs/pt/intlayer_with_vite+preact.md +7 -7
  209. package/docs/pt/intlayer_with_vite+react.md +7 -7
  210. package/docs/pt/intlayer_with_vite+vue.md +9 -9
  211. package/docs/pt/packages/vite-intlayer/index.md +3 -3
  212. package/docs/pt/readme.md +261 -0
  213. package/docs/pt/testing.md +200 -0
  214. package/docs/ru/autoFill.md +52 -30
  215. package/docs/ru/configuration.md +164 -117
  216. package/docs/ru/dictionary/content_file.md +1064 -0
  217. package/docs/ru/intlayer_CMS.md +4 -4
  218. package/docs/ru/intlayer_with_nestjs.md +270 -0
  219. package/docs/ru/intlayer_with_nextjs_page_router.md +1 -1
  220. package/docs/ru/intlayer_with_react_router_v7.md +534 -0
  221. package/docs/ru/intlayer_with_tanstack.md +470 -305
  222. package/docs/ru/intlayer_with_vite+preact.md +7 -7
  223. package/docs/ru/intlayer_with_vite+react.md +7 -7
  224. package/docs/ru/intlayer_with_vite+vue.md +9 -9
  225. package/docs/ru/packages/vite-intlayer/index.md +3 -3
  226. package/docs/ru/readme.md +261 -0
  227. package/docs/ru/testing.md +202 -0
  228. package/docs/tr/CI_CD.md +198 -0
  229. package/docs/tr/autoFill.md +201 -0
  230. package/docs/tr/configuration.md +585 -0
  231. package/docs/tr/dictionary/condition.md +243 -0
  232. package/docs/tr/dictionary/content_file.md +1055 -0
  233. package/docs/tr/dictionary/enumeration.md +251 -0
  234. package/docs/tr/dictionary/file.md +228 -0
  235. package/docs/tr/dictionary/function_fetching.md +218 -0
  236. package/docs/tr/dictionary/gender.md +279 -0
  237. package/docs/tr/dictionary/insertion.md +191 -0
  238. package/docs/tr/dictionary/markdown.md +385 -0
  239. package/docs/tr/dictionary/nesting.md +279 -0
  240. package/docs/tr/dictionary/translation.md +315 -0
  241. package/docs/tr/formatters.md +618 -0
  242. package/docs/tr/how_works_intlayer.md +254 -0
  243. package/docs/tr/index.md +168 -0
  244. package/docs/tr/interest_of_intlayer.md +288 -0
  245. package/docs/tr/intlayer_CMS.md +347 -0
  246. package/docs/tr/intlayer_cli.md +570 -0
  247. package/docs/tr/intlayer_visual_editor.md +269 -0
  248. package/docs/tr/intlayer_with_angular.md +694 -0
  249. package/docs/tr/intlayer_with_create_react_app.md +1218 -0
  250. package/docs/tr/intlayer_with_express.md +415 -0
  251. package/docs/tr/intlayer_with_lynx+react.md +511 -0
  252. package/docs/tr/intlayer_with_nestjs.md +268 -0
  253. package/docs/tr/intlayer_with_nextjs_14.md +1029 -0
  254. package/docs/tr/intlayer_with_nextjs_15.md +1506 -0
  255. package/docs/tr/intlayer_with_nextjs_page_router.md +1484 -0
  256. package/docs/tr/intlayer_with_nuxt.md +773 -0
  257. package/docs/tr/intlayer_with_react_native+expo.md +660 -0
  258. package/docs/tr/intlayer_with_react_router_v7.md +531 -0
  259. package/docs/tr/intlayer_with_tanstack.md +452 -0
  260. package/docs/tr/intlayer_with_vite+preact.md +1673 -0
  261. package/docs/tr/intlayer_with_vite+react.md +1632 -0
  262. package/docs/tr/intlayer_with_vite+solid.md +288 -0
  263. package/docs/tr/intlayer_with_vite+svelte.md +288 -0
  264. package/docs/tr/intlayer_with_vite+vue.md +1042 -0
  265. package/docs/tr/introduction.md +209 -0
  266. package/docs/tr/locale_mapper.md +244 -0
  267. package/docs/tr/mcp_server.md +207 -0
  268. package/docs/tr/packages/@intlayer/api/index.md +58 -0
  269. package/docs/tr/packages/@intlayer/chokidar/index.md +57 -0
  270. package/docs/tr/packages/@intlayer/cli/index.md +47 -0
  271. package/docs/tr/packages/@intlayer/config/index.md +142 -0
  272. package/docs/tr/packages/@intlayer/core/index.md +51 -0
  273. package/docs/tr/packages/@intlayer/design-system/index.md +47 -0
  274. package/docs/tr/packages/@intlayer/dictionary-entry/index.md +53 -0
  275. package/docs/tr/packages/@intlayer/editor/index.md +47 -0
  276. package/docs/tr/packages/@intlayer/editor-react/index.md +47 -0
  277. package/docs/tr/packages/@intlayer/webpack/index.md +61 -0
  278. package/docs/tr/packages/angular-intlayer/index.md +59 -0
  279. package/docs/tr/packages/express-intlayer/index.md +258 -0
  280. package/docs/tr/packages/express-intlayer/t.md +459 -0
  281. package/docs/tr/packages/intlayer/getConfiguration.md +151 -0
  282. package/docs/tr/packages/intlayer/getEnumeration.md +165 -0
  283. package/docs/tr/packages/intlayer/getHTMLTextDir.md +127 -0
  284. package/docs/tr/packages/intlayer/getLocaleLang.md +87 -0
  285. package/docs/tr/packages/intlayer/getLocaleName.md +124 -0
  286. package/docs/tr/packages/intlayer/getLocalizedUrl.md +324 -0
  287. package/docs/tr/packages/intlayer/getMultilingualUrls.md +225 -0
  288. package/docs/tr/packages/intlayer/getPathWithoutLocale.md +81 -0
  289. package/docs/tr/packages/intlayer/getTranslation.md +196 -0
  290. package/docs/tr/packages/intlayer/getTranslationContent.md +195 -0
  291. package/docs/tr/packages/intlayer/index.md +505 -0
  292. package/docs/tr/packages/intlayer-cli/index.md +71 -0
  293. package/docs/tr/packages/intlayer-editor/index.md +139 -0
  294. package/docs/tr/packages/lynx-intlayer/index.md +85 -0
  295. package/docs/tr/packages/next-intlayer/index.md +154 -0
  296. package/docs/tr/packages/next-intlayer/t.md +354 -0
  297. package/docs/tr/packages/next-intlayer/useDictionary.md +270 -0
  298. package/docs/tr/packages/next-intlayer/useIntlayer.md +265 -0
  299. package/docs/tr/packages/next-intlayer/useLocale.md +133 -0
  300. package/docs/tr/packages/nuxt-intlayer/index.md +59 -0
  301. package/docs/tr/packages/preact-intlayer/index.md +55 -0
  302. package/docs/tr/packages/react-intlayer/index.md +148 -0
  303. package/docs/tr/packages/react-intlayer/t.md +304 -0
  304. package/docs/tr/packages/react-intlayer/useDictionary.md +554 -0
  305. package/docs/tr/packages/react-intlayer/useI18n.md +478 -0
  306. package/docs/tr/packages/react-intlayer/useIntlayer.md +253 -0
  307. package/docs/tr/packages/react-intlayer/useLocale.md +212 -0
  308. package/docs/tr/packages/react-native-intlayer/index.md +85 -0
  309. package/docs/tr/packages/react-scripts-intlayer/index.md +82 -0
  310. package/docs/tr/packages/solid-intlayer/index.md +56 -0
  311. package/docs/tr/packages/svelte-intlayer/index.md +55 -0
  312. package/docs/tr/packages/vite-intlayer/index.md +82 -0
  313. package/docs/tr/packages/vue-intlayer/index.md +59 -0
  314. package/docs/tr/per_locale_file.md +321 -0
  315. package/docs/tr/readme.md +261 -0
  316. package/docs/tr/roadmap.md +338 -0
  317. package/docs/tr/testing.md +200 -0
  318. package/docs/tr/vs_code_extension.md +154 -0
  319. package/docs/zh/autoFill.md +40 -18
  320. package/docs/zh/configuration.md +245 -226
  321. package/docs/zh/dictionary/content_file.md +1064 -0
  322. package/docs/zh/intlayer_CMS.md +4 -5
  323. package/docs/zh/intlayer_with_nestjs.md +268 -0
  324. package/docs/zh/intlayer_with_nextjs_page_router.md +1 -1
  325. package/docs/zh/intlayer_with_react_router_v7.md +535 -0
  326. package/docs/zh/intlayer_with_tanstack.md +468 -278
  327. package/docs/zh/intlayer_with_vite+preact.md +7 -7
  328. package/docs/zh/intlayer_with_vite+react.md +7 -7
  329. package/docs/zh/intlayer_with_vite+vue.md +7 -7
  330. package/docs/zh/packages/vite-intlayer/index.md +3 -3
  331. package/docs/zh/readme.md +261 -0
  332. package/docs/zh/testing.md +198 -0
  333. package/frequent_questions/tr/SSR_Next_no_[locale].md +105 -0
  334. package/frequent_questions/tr/array_as_content_declaration.md +72 -0
  335. package/frequent_questions/tr/build_dictionaries.md +59 -0
  336. package/frequent_questions/tr/build_error_CI_CD.md +75 -0
  337. package/frequent_questions/tr/customized_locale_list.md +65 -0
  338. package/frequent_questions/tr/domain_routing.md +114 -0
  339. package/frequent_questions/tr/esbuild_error.md +30 -0
  340. package/frequent_questions/tr/get_locale_cookie.md +142 -0
  341. package/frequent_questions/tr/intlayer_command_undefined.md +156 -0
  342. package/frequent_questions/tr/locale_incorect_in_url.md +74 -0
  343. package/frequent_questions/tr/static_rendering.md +45 -0
  344. package/frequent_questions/tr/translated_path_url.md +56 -0
  345. package/frequent_questions/tr/unknown_command.md +98 -0
  346. package/legal/tr/privacy_notice.md +83 -0
  347. package/legal/tr/terms_of_service.md +55 -0
  348. package/package.json +12 -12
  349. package/src/generated/blog.entry.ts +212 -0
  350. package/src/generated/docs.entry.ts +663 -135
  351. package/src/generated/frequentQuestions.entry.ts +85 -1
  352. package/src/generated/legal.entry.ts +7 -1
  353. package/docs/ar/dictionary/content_extention_customization.md +0 -100
  354. package/docs/ar/dictionary/get_started.md +0 -527
  355. package/docs/de/dictionary/content_extention_customization.md +0 -100
  356. package/docs/de/dictionary/get_started.md +0 -531
  357. package/docs/en/dictionary/content_extention_customization.md +0 -102
  358. package/docs/en/dictionary/get_started.md +0 -529
  359. package/docs/en-GB/dictionary/content_extention_customization.md +0 -100
  360. package/docs/en-GB/dictionary/get_started.md +0 -591
  361. package/docs/es/dictionary/content_extention_customization.md +0 -100
  362. package/docs/es/dictionary/get_started.md +0 -527
  363. package/docs/fr/dictionary/content_extention_customization.md +0 -100
  364. package/docs/fr/dictionary/get_started.md +0 -527
  365. package/docs/hi/dictionary/content_extention_customization.md +0 -100
  366. package/docs/hi/dictionary/get_started.md +0 -527
  367. package/docs/it/dictionary/content_extention_customization.md +0 -113
  368. package/docs/it/dictionary/get_started.md +0 -573
  369. package/docs/ja/dictionary/content_extention_customization.md +0 -113
  370. package/docs/ja/dictionary/get_started.md +0 -576
  371. package/docs/ko/dictionary/content_extention_customization.md +0 -100
  372. package/docs/ko/dictionary/get_started.md +0 -530
  373. package/docs/pt/dictionary/content_extention_customization.md +0 -100
  374. package/docs/pt/dictionary/get_started.md +0 -532
  375. package/docs/ru/dictionary/content_extention_customization.md +0 -100
  376. package/docs/ru/dictionary/get_started.md +0 -575
  377. package/docs/zh/dictionary/content_extention_customization.md +0 -117
  378. package/docs/zh/dictionary/get_started.md +0 -533
@@ -0,0 +1,533 @@
1
+ ---
2
+ createdAt: 2025-09-04
3
+ updatedAt: 2025-09-04
4
+ title: Comenzando con Intlayer en React Router v7
5
+ description: Aprende cómo agregar internacionalización (i18n) a tu aplicación React Router v7 usando Intlayer. Sigue esta guía completa para hacer tu aplicación multilingüe con enrutamiento consciente del locale.
6
+ keywords:
7
+ - Internacionalización
8
+ - Documentación
9
+ - Intlayer
10
+ - React Router v7
11
+ - React
12
+ - i18n
13
+ - TypeScript
14
+ - Enrutamiento por Locale
15
+ slugs:
16
+ - doc
17
+ - environment
18
+ - vite-and-react
19
+ - react-router-v7
20
+ applicationTemplate: https://github.com/AydinTheFirst/react-router-intlayer
21
+ author: AydinTheFirst
22
+ ---
23
+
24
+ # Comenzando con la internacionalización (i18n) usando Intlayer y React Router v7
25
+
26
+ Esta guía demuestra cómo integrar **Intlayer** para una internacionalización fluida en proyectos con React Router v7, con enrutamiento consciente del locale, soporte para TypeScript y prácticas modernas de desarrollo.
27
+
28
+ ## ¿Qué es Intlayer?
29
+
30
+ **Intlayer** es una biblioteca innovadora y de código abierto para internacionalización (i18n) diseñada para simplificar el soporte multilingüe en aplicaciones web modernas.
31
+
32
+ Con Intlayer, puedes:
33
+
34
+ - **Gestionar traducciones fácilmente** usando diccionarios declarativos a nivel de componente.
35
+ - **Localizar dinámicamente metadatos**, rutas y contenido.
36
+ - **Asegurar soporte para TypeScript** con tipos autogenerados, mejorando la autocompletación y la detección de errores.
37
+ - **Beneficiarte de características avanzadas**, como la detección y cambio dinámico de locale.
38
+ - **Habilitar enrutamiento consciente del locale** con el sistema de enrutamiento basado en configuración de React Router v7.
39
+
40
+ ---
41
+
42
+ ## Guía paso a paso para configurar Intlayer en una aplicación con React Router v7
43
+
44
+ ### Paso 1: Instalar dependencias
45
+
46
+ Instala los paquetes necesarios usando tu gestor de paquetes preferido:
47
+
48
+ ```bash packageManager="npm"
49
+ npm install intlayer react-intlayer
50
+ npm install vite-intlayer --save-dev
51
+ ```
52
+
53
+ ```bash packageManager="pnpm"
54
+ pnpm add intlayer react-intlayer
55
+ pnpm add vite-intlayer --save-dev
56
+ ```
57
+
58
+ - **intlayer**
59
+
60
+ - **intlayer**
61
+
62
+ El paquete principal que proporciona herramientas de internacionalización para la gestión de configuración, traducción, [declaración de contenido](https://github.com/aymericzip/intlayer/blob/main/docs/docs/es/dictionary/get_started.md), transpileación y [comandos CLI](https://github.com/aymericzip/intlayer/blob/main/docs/docs/es/intlayer_cli.md).
63
+
64
+ - **react-intlayer**
65
+ El paquete que integra Intlayer con la aplicación React. Proporciona proveedores de contexto y hooks para la internacionalización en React.
66
+
67
+ - **vite-intlayer**
68
+ Incluye el plugin de Vite para integrar Intlayer con el [bundler Vite](https://vite.dev/guide/why.html#why-bundle-for-production), así como middleware para detectar el locale preferido del usuario, gestionar cookies y manejar la redirección de URLs.
69
+
70
+ ### Paso 2: Configuración de tu proyecto
71
+
72
+ Cree un archivo de configuración para configurar los idiomas de su aplicación:
73
+
74
+ ```typescript fileName="intlayer.config.ts" codeFormat="typescript"
75
+ import { type IntlayerConfig, Locales } from "intlayer";
76
+
77
+ const config: IntlayerConfig = {
78
+ internationalization: {
79
+ defaultLocale: Locales.ENGLISH,
80
+ locales: [Locales.ENGLISH, Locales.TURKISH],
81
+ },
82
+ middleware: {
83
+ prefixDefault: true, // Siempre anteponer el prefijo del idioma predeterminado en las URLs
84
+ },
85
+ };
86
+
87
+ export default config;
88
+ ```
89
+
90
+ ```javascript fileName="intlayer.config.mjs" codeFormat="esm"
91
+ import { Locales } from "intlayer";
92
+
93
+ /** @type {import('intlayer').IntlayerConfig} */
94
+ const config = {
95
+ internationalization: {
96
+ defaultLocale: Locales.ENGLISH,
97
+ locales: [Locales.ENGLISH, Locales.TURKISH],
98
+ },
99
+ middleware: {
100
+ prefixDefault: true,
101
+ },
102
+ };
103
+
104
+ export default config;
105
+ ```
106
+
107
+ ```javascript fileName="intlayer.config.cjs" codeFormat="commonjs"
108
+ const { Locales } = require("intlayer");
109
+
110
+ /** @type {import('intlayer').IntlayerConfig} */
111
+ const config = {
112
+ internationalization: {
113
+ defaultLocale: Locales.ENGLISH,
114
+ locales: [Locales.ENGLISH, Locales.TURKISH],
115
+ },
116
+ middleware: {
117
+ prefixDefault: true,
118
+ },
119
+ };
120
+
121
+ module.exports = config;
122
+ ```
123
+
124
+ > A través de este archivo de configuración, puedes configurar URLs localizadas, redirección en middleware, nombres de cookies, la ubicación y extensión de tus declaraciones de contenido, deshabilitar los registros de Intlayer en la consola y más. Para una lista completa de los parámetros disponibles, consulta la [documentación de configuración](https://github.com/aymericzip/intlayer/blob/main/docs/docs/es/configuration.md).
125
+
126
+ ### Paso 3: Configurar las Rutas de React Router v7
127
+
128
+ Configura tu configuración de enrutamiento con rutas conscientes del locale:
129
+
130
+ ```typescript fileName="app/routes.ts" codeFormat="typescript"
131
+ import { layout, route, type RouteConfig } from "@react-router/dev/routes";
132
+
133
+ export default [
134
+ layout("routes/layout.tsx", [
135
+ route("/", "routes/page.tsx"), // Página raíz - redirige al locale
136
+ route("/:lang", "routes/[lang]/page.tsx"), // Página de inicio localizada
137
+ route("/:lang/about", "routes/[lang]/about/page.tsx"), // Página "about" localizada
138
+ ]),
139
+ ] satisfies RouteConfig;
140
+ ```
141
+
142
+ ### Paso 4: Integrar Intlayer en tu Configuración de Vite
143
+
144
+ Agrega el plugin intlayer en tu configuración:
145
+
146
+ ```typescript fileName="vite.config.ts" codeFormat="typescript"
147
+ import { reactRouter } from "@react-router/dev/vite";
148
+ import { defineConfig } from "vite";
149
+ import { intlayerMiddlewarePlugin, intlayerPlugin } from "vite-intlayer";
150
+ import tsconfigPaths from "vite-tsconfig-paths";
151
+
152
+ export default defineConfig({
153
+ plugins: [
154
+ reactRouter(),
155
+ tsconfigPaths(),
156
+ intlayerPlugin(),
157
+ intlayerMiddlewarePlugin(),
158
+ ],
159
+ });
160
+ ```
161
+
162
+ > El plugin `intlayerPlugin()` de Vite se utiliza para integrar Intlayer con Vite. Asegura la construcción de archivos de declaración de contenido y los supervisa en modo de desarrollo. Define variables de entorno de Intlayer dentro de la aplicación Vite. Además, proporciona alias para optimizar el rendimiento.
163
+
164
+ ### Paso 5: Crear Componentes de Layout
165
+
166
+ Configura tu layout raíz y los layouts específicos por locale:
167
+
168
+ #### Layout Raíz
169
+
170
+ ```tsx fileName="app/routes/layout.tsx" codeFormat="typescript"
171
+ // app/routes/layout.tsx
172
+ import { Outlet } from "react-router";
173
+ import { IntlayerProvider } from "react-intlayer";
174
+
175
+ export default function RootLayout() {
176
+ return (
177
+ <IntlayerProvider>
178
+ <Outlet />
179
+ </IntlayerProvider>
180
+ );
181
+ }
182
+ ```
183
+
184
+ ### Paso 6: Declara tu Contenido
185
+
186
+ Crea y gestiona tus declaraciones de contenido para almacenar traducciones:
187
+
188
+ ```tsx fileName="app/routes/[lang]/page.content.ts" contentDeclarationFormat="typescript"
189
+ import { t, type Dictionary } from "intlayer";
190
+
191
+ const pageContent = {
192
+ key: "page",
193
+ content: {
194
+ title: t({
195
+ en: "Welcome to React Router v7 + Intlayer",
196
+ tr: "React Router v7 + Intlayer'a Hoş Geldiniz",
197
+ }),
198
+ description: t({
199
+ en: "Build multilingual applications with ease using React Router v7 and Intlayer.",
200
+ tr: "React Router v7 ve Intlayer kullanarak kolayca çok dilli uygulamalar geliştirin.",
201
+ }),
202
+ aboutLink: t({
203
+ en: "Aprende Sobre Nosotros",
204
+ tr: "Hakkımızda Öğrenin",
205
+ }),
206
+ homeLink: t({
207
+ en: "Inicio",
208
+ tr: "Ana Sayfa",
209
+ }),
210
+ },
211
+ } satisfies Dictionary;
212
+
213
+ export default pageContent;
214
+ ```
215
+
216
+ > Tus declaraciones de contenido pueden definirse en cualquier parte de tu aplicación tan pronto como se incluyan en el directorio `contentDir` (por defecto, `./app`). Y deben coincidir con la extensión de archivo de declaración de contenido (por defecto, `.content.{json,ts,tsx,js,jsx,mjs,mjx,cjs,cjx}`).
217
+
218
+ > Para más detalles, consulta la [documentación de declaración de contenido](https://github.com/aymericzip/intlayer/blob/main/docs/docs/es/dictionary/get_started.md).
219
+
220
+ ### Paso 7: Crear Componentes Conscientes del Locale
221
+
222
+ Crea un componente `LocalizedLink` para la navegación consciente del idioma:
223
+
224
+ ```tsx fileName="app/components/localized-link.tsx" codeFormat="typescript"
225
+ // app/components/localized-link.tsx
226
+ import { getLocalizedUrl } from "intlayer";
227
+ import { useLocale } from "react-intlayer";
228
+ import React from "react";
229
+ import { Link, useLocation } from "react-router";
230
+
231
+ type RouterLinkProps = React.ComponentProps<typeof Link>;
232
+
233
+ export default function LocalizedLink({ to, ...props }: RouterLinkProps) {
234
+ const { locale } = useLocale();
235
+ const location = useLocation();
236
+
237
+ const isExternal = (path: string) =>
238
+ /^([a-z][a-z0-9+.-]*:)?\/\//i.test(path) || path.startsWith("mailto:");
239
+
240
+ if (typeof to === "string") {
241
+ if (to.startsWith("/") && !isExternal(to)) {
242
+ return <Link to={getLocalizedUrl(to, locale)} {...props} />;
243
+ }
244
+ return <Link to={to} {...props} />;
245
+ }
246
+
247
+ if (to && typeof to === "object") {
248
+ const pathname = (to as { pathname?: string }).pathname;
249
+ if (pathname && pathname.startsWith("/") && !isExternal(pathname)) {
250
+ return (
251
+ <Link
252
+ to={{ ...to, pathname: getLocalizedUrl(pathname, locale) }}
253
+ {...props}
254
+ />
255
+ );
256
+ }
257
+ return <Link to={to} {...props} />;
258
+ }
259
+
260
+ return (
261
+ <Link
262
+ to={getLocalizedUrl(location.pathname + location.search, locale)}
263
+ {...props}
264
+ />
265
+ );
266
+ }
267
+ ```
268
+
269
+ ### Paso 8: Utiliza Intlayer en Tus Páginas
270
+
271
+ Accede a tus diccionarios de contenido en toda tu aplicación:
272
+
273
+ #### Página de Redirección Raíz
274
+
275
+ ```tsx fileName="app/routes/page.tsx" codeFormat="typescript"
276
+ // app/routes/page.tsx
277
+ import { useLocale } from "react-intlayer";
278
+ import { Navigate } from "react-router";
279
+
280
+ export default function Page() {
281
+ const { locale } = useLocale();
282
+
283
+ return <Navigate replace to={locale} />;
284
+ }
285
+ ```
286
+
287
+ #### Página de inicio localizada
288
+
289
+ ```tsx fileName="app/routes/[lang]/page.tsx" codeFormat="typescript"
290
+ import { useIntlayer } from "react-intlayer";
291
+ import LocalizedLink from "~/components/localized-link";
292
+
293
+ export default function Page() {
294
+ const content = useIntlayer("page");
295
+
296
+ return (
297
+ <div style={{ padding: "2rem", textAlign: "center" }}>
298
+ <h1>{content.title}</h1>
299
+ <p>{content.description}</p>
300
+ <nav style={{ marginTop: "2rem" }}>
301
+ <LocalizedLink
302
+ to="/about"
303
+ style={{
304
+ display: "inline-block",
305
+ padding: "0.5rem 1rem",
306
+ backgroundColor: "#007bff",
307
+ color: "white",
308
+ textDecoration: "none",
309
+ borderRadius: "4px",
310
+ }}
311
+ >
312
+ {content.aboutLink}
313
+ </LocalizedLink>
314
+ </nav>
315
+ </div>
316
+ );
317
+ }
318
+ ```
319
+
320
+ > Para aprender más sobre el hook `useIntlayer`, consulta la [documentación](https://github.com/aymericzip/intlayer/blob/main/docs/docs/es/packages/react-intlayer/useIntlayer.md).
321
+
322
+ ### Paso 9: Crear un Componente Cambiador de Idioma
323
+
324
+ Crea un componente para permitir a los usuarios cambiar de idioma:
325
+
326
+ ```tsx fileName="app/components/locale-switcher.tsx" codeFormat="typescript"
327
+ import { getLocalizedUrl, getLocaleName } from "intlayer";
328
+ import { useLocale } from "react-intlayer";
329
+ import { useLocation, useNavigate } from "react-router";
330
+
331
+ export default function LocaleSwitcher() {
332
+ const { locale, availableLocales, setLocale } = useLocale();
333
+ const location = useLocation();
334
+ const navigate = useNavigate();
335
+
336
+ const handleLocaleChange = (newLocale: string) => {
337
+ const localizedUrl = getLocalizedUrl(
338
+ location.pathname + location.search,
339
+ newLocale
340
+ );
341
+ setLocale(newLocale);
342
+ navigate(localizedUrl);
343
+ };
344
+
345
+ return (
346
+ <div style={{ margin: "1rem 0" }}>
347
+ <label htmlFor="locale-select">Elegir idioma: </label>
348
+ <select
349
+ id="locale-select"
350
+ value={locale}
351
+ onChange={(e) => handleLocaleChange(e.target.value)}
352
+ style={{ padding: "0.25rem", marginLeft: "0.5rem" }}
353
+ >
354
+ {availableLocales.map((availableLocale) => (
355
+ <option key={availableLocale} value={availableLocale}>
356
+ {getLocaleName(availableLocale)}
357
+ </option>
358
+ ))}
359
+ </select>
360
+ </div>
361
+ );
362
+ }
363
+ ```
364
+
365
+ > Para aprender más sobre el hook `useLocale`, consulta la [documentación](https://github.com/aymericzip/intlayer/blob/main/docs/docs/es/packages/react-intlayer/useLocale.md).
366
+
367
+ ### Paso 10: Añadir gestión de atributos HTML (Opcional)
368
+
369
+ Crea un hook para gestionar los atributos lang y dir del HTML:
370
+
371
+ ```tsx fileName="app/hooks/useI18nHTMLAttributes.tsx" codeFormat="typescript"
372
+ // app/hooks/useI18nHTMLAttributes.tsx
373
+ import { getHTMLTextDir } from "intlayer";
374
+ import { useEffect } from "react";
375
+ import { useLocale } from "react-intlayer";
376
+
377
+ export const useI18nHTMLAttributes = () => {
378
+ const { locale } = useLocale();
379
+
380
+ useEffect(() => {
381
+ document.documentElement.lang = locale;
382
+ document.documentElement.dir = getHTMLTextDir(locale);
383
+ }, [locale]);
384
+ };
385
+ ```
386
+
387
+ Luego úsalo en tu componente raíz:
388
+
389
+ ```tsx fileName="app/root.tsx" codeFormat="typescript"
390
+ // app/routes/layout.tsx
391
+ import { Outlet } from "react-router";
392
+ import { IntlayerProvider } from "react-intlayer";
393
+
394
+ import { useI18nHTMLAttributes } from "app/hooks/useI18nHTMLAttributes"; // importar el hook
395
+
396
+ export default function RootLayout() {
397
+ useI18nHTMLAttributes(); // llamar al hook
398
+
399
+ return (
400
+ <IntlayerProvider>
401
+ <Outlet />
402
+ </IntlayerProvider>
403
+ );
404
+ }
405
+ ```
406
+
407
+ ### Paso 11: Construye y Ejecuta Tu Aplicación
408
+
409
+ Construye los diccionarios de contenido y ejecuta tu aplicación:
410
+
411
+ ```bash packageManager="npm"
412
+ # Construir diccionarios de Intlayer
413
+ npm run intlayer:build
414
+
415
+ # Iniciar servidor de desarrollo
416
+ npm run dev
417
+ ```
418
+
419
+ ```bash packageManager="pnpm"
420
+ # Construir diccionarios de Intlayer
421
+ pnpm intlayer:build
422
+
423
+ # Iniciar servidor de desarrollo
424
+ pnpm dev
425
+ ```
426
+
427
+ ```bash packageManager="yarn"
428
+ # Construir diccionarios de Intlayer
429
+ yarn intlayer:build
430
+
431
+ # Iniciar servidor de desarrollo
432
+ yarn dev
433
+ ```
434
+
435
+ ### Paso 12: Configurar TypeScript (Opcional)
436
+
437
+ Intlayer utiliza la ampliación de módulos para aprovechar las ventajas de TypeScript y fortalecer tu base de código.
438
+
439
+ Asegúrate de que tu configuración de TypeScript incluya los tipos autogenerados:
440
+
441
+ ```json5 fileName="tsconfig.json"
442
+ {
443
+ compilerOptions: {
444
+ // ... tus configuraciones existentes de TypeScript
445
+ },
446
+ include: [
447
+ // ... tus inclusiones existentes
448
+ ".intlayer/**/*.ts", // Incluir los tipos auto-generados
449
+ ],
450
+ }
451
+ ```
452
+
453
+ ### Configuración de Git
454
+
455
+ Se recomienda ignorar los archivos generados por Intlayer. Esto te permite evitar comprometerlos en tu repositorio Git.
456
+
457
+ Para hacerlo, puedes agregar las siguientes instrucciones a tu archivo `.gitignore`:
458
+
459
+ ```plaintext fileName=".gitignore"
460
+ # Ignorar los archivos generados por Intlayer
461
+ .intlayer
462
+ ```
463
+
464
+ ---
465
+
466
+ ## Despliegue en Producción
467
+
468
+ Al desplegar tu aplicación:
469
+
470
+ 1. **Construye tu aplicación:**
471
+
472
+ ```bash
473
+ npm run build
474
+ ```
475
+
476
+ 2. **Construye los diccionarios de Intlayer:**
477
+
478
+ ```bash
479
+ npm run intlayer:build
480
+ ```
481
+
482
+ 3. **Mueve `vite-intlayer` a las dependencias** si usas middleware en producción:
483
+ ```bash
484
+ npm install vite-intlayer --save
485
+ ```
486
+
487
+ Tu aplicación ahora soportará:
488
+
489
+ - **Estructura de URL**: `/en`, `/en/about`, `/tr`, `/tr/about`
490
+ - **Detección automática de idioma** basada en las preferencias del navegador
491
+ - **Enrutamiento consciente del idioma** con React Router v7
492
+ - **Soporte para TypeScript** con tipos auto-generados
493
+ - **Renderizado del lado del servidor** con manejo adecuado del idioma
494
+
495
+ ## Extensión para VS Code
496
+
497
+ Para mejorar tu experiencia de desarrollo con Intlayer, puedes instalar la **Extensión oficial de Intlayer para VS Code**.
498
+
499
+ [Instalar desde el Marketplace de VS Code](https://marketplace.visualstudio.com/items?itemName=intlayer.intlayer-vs-code-extension)
500
+
501
+ Esta extensión proporciona:
502
+
503
+ - **Autocompletado** para las claves de traducción.
504
+ - **Detección de errores en tiempo real** para traducciones faltantes.
505
+ - **Previsualizaciones en línea** del contenido traducido.
506
+ - **Acciones rápidas** para crear y actualizar traducciones fácilmente.
507
+
508
+ Para más detalles sobre cómo usar la extensión, consulta la [documentación de la extensión Intlayer para VS Code](https://intlayer.org/doc/vs-code-extension).
509
+
510
+ ---
511
+
512
+ ## Ir Más Allá
513
+
514
+ Para ir más allá, puedes implementar el [editor visual](https://github.com/aymericzip/intlayer/blob/main/docs/docs/es/intlayer_visual_editor.md) o externalizar tu contenido usando el [CMS](https://github.com/aymericzip/intlayer/blob/main/docs/docs/es/intlayer_CMS.md).
515
+
516
+ ---
517
+
518
+ ## Referencias de la Documentación
519
+
520
+ - [Documentación de Intlayer](https://intlayer.org)
521
+ - [Documentación de React Router v7](https://reactrouter.com/)
522
+ - [Hook useIntlayer](https://github.com/aymericzip/intlayer/blob/main/docs/docs/es/packages/react-intlayer/useIntlayer.md)
523
+ - [Hook useLocale](https://github.com/aymericzip/intlayer/blob/main/docs/docs/es/packages/react-intlayer/useLocale.md)
524
+ - [Declaración de Contenido](https://github.com/aymericzip/intlayer/blob/main/docs/docs/es/dictionary/get_started.md)
525
+ - [Configuración](https://github.com/aymericzip/intlayer/blob/main/docs/docs/es/configuration.md)
526
+
527
+ Esta guía completa proporciona todo lo que necesitas para integrar Intlayer con React Router v7 para una aplicación totalmente internacionalizada con enrutamiento consciente del locale y soporte para TypeScript.
528
+
529
+ ## Historial de la Documentación
530
+
531
+ | Versión | Fecha | Cambios |
532
+ | ------- | --------- | ---------------------------- |
533
+ | 5.8.2 | 2025-09-4 | Añadido para React Router v7 |