@intlayer/docs 5.5.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1135) hide show
  1. package/LICENSE +202 -0
  2. package/ar/CI_CD.md +149 -0
  3. package/ar/autoFill.md +157 -0
  4. package/ar/concept/content/file.md +1 -0
  5. package/ar/configuration.md +492 -0
  6. package/ar/dictionary/condition.md +213 -0
  7. package/ar/dictionary/content_extention_customization.md +81 -0
  8. package/ar/dictionary/enumeration.md +221 -0
  9. package/ar/dictionary/file.md +209 -0
  10. package/ar/dictionary/function_fetching.md +190 -0
  11. package/ar/dictionary/get_started.md +490 -0
  12. package/ar/dictionary/insertion.md +161 -0
  13. package/ar/dictionary/markdown.md +343 -0
  14. package/ar/dictionary/nesting.md +249 -0
  15. package/ar/dictionary/translation.md +307 -0
  16. package/ar/header.md +7 -0
  17. package/ar/how_works_intlayer.md +219 -0
  18. package/ar/index.md +125 -0
  19. package/ar/interest_of_intlayer.md +132 -0
  20. package/ar/intlayer_CMS.md +328 -0
  21. package/ar/intlayer_cli.md +258 -0
  22. package/ar/intlayer_visual_editor.md +210 -0
  23. package/ar/intlayer_with_angular.md +3 -0
  24. package/ar/intlayer_with_create_react_app.md +1196 -0
  25. package/ar/intlayer_with_express.md +270 -0
  26. package/ar/intlayer_with_lynx+react.md +482 -0
  27. package/ar/intlayer_with_nextjs_14.md +1260 -0
  28. package/ar/intlayer_with_nextjs_15.md +1311 -0
  29. package/ar/intlayer_with_nextjs_page_router.md +1099 -0
  30. package/ar/intlayer_with_react_native+expo.md +539 -0
  31. package/ar/intlayer_with_vite+preact.md +1679 -0
  32. package/ar/intlayer_with_vite+react.md +1582 -0
  33. package/ar/intlayer_with_vite+solid.md +3 -0
  34. package/ar/intlayer_with_vite+svelte.md +3 -0
  35. package/ar/intlayer_with_vite+vue.md +989 -0
  36. package/ar/introduction.md +190 -0
  37. package/ar/mcp_server.md +150 -0
  38. package/ar/packages/@intlayer/api/index.md +31 -0
  39. package/ar/packages/@intlayer/chokidar/index.md +31 -0
  40. package/ar/packages/@intlayer/cli/index.md +1 -0
  41. package/ar/packages/@intlayer/config/index.md +116 -0
  42. package/ar/packages/@intlayer/core/index.md +25 -0
  43. package/ar/packages/@intlayer/design-system/index.md +21 -0
  44. package/ar/packages/@intlayer/dictionary-entry/index.md +21 -0
  45. package/ar/packages/@intlayer/editor/index.md +21 -0
  46. package/ar/packages/@intlayer/editor-react/index.md +21 -0
  47. package/ar/packages/@intlayer/webpack/index.md +35 -0
  48. package/ar/packages/angular-intlayer/index.md +3 -0
  49. package/ar/packages/express-intlayer/index.md +232 -0
  50. package/ar/packages/express-intlayer/t.md +448 -0
  51. package/ar/packages/intlayer/getConfiguration.md +120 -0
  52. package/ar/packages/intlayer/getEnumeration.md +138 -0
  53. package/ar/packages/intlayer/getHTMLTextDir.md +97 -0
  54. package/ar/packages/intlayer/getLocaleLang.md +61 -0
  55. package/ar/packages/intlayer/getLocaleName.md +93 -0
  56. package/ar/packages/intlayer/getLocalizedUrl.md +221 -0
  57. package/ar/packages/intlayer/getMultilingualUrls.md +198 -0
  58. package/ar/packages/intlayer/getPathWithoutLocale.md +50 -0
  59. package/ar/packages/intlayer/getTranslation.md +175 -0
  60. package/ar/packages/intlayer/getTranslationContent.md +175 -0
  61. package/ar/packages/intlayer/index.md +254 -0
  62. package/ar/packages/intlayer-cli/index.md +41 -0
  63. package/ar/packages/intlayer-editor/index.md +113 -0
  64. package/ar/packages/lynx-intlayer/index.md +58 -0
  65. package/ar/packages/next-intlayer/index.md +267 -0
  66. package/ar/packages/next-intlayer/t.md +341 -0
  67. package/ar/packages/next-intlayer/useDictionary.md +248 -0
  68. package/ar/packages/next-intlayer/useIntlayer.md +237 -0
  69. package/ar/packages/next-intlayer/useIntlayerAsync.md +211 -0
  70. package/ar/packages/next-intlayer/useLocale.md +105 -0
  71. package/ar/packages/preact-intlayer/index.md +3 -0
  72. package/ar/packages/react-intlayer/index.md +261 -0
  73. package/ar/packages/react-intlayer/t.md +283 -0
  74. package/ar/packages/react-intlayer/useDictionary.md +268 -0
  75. package/ar/packages/react-intlayer/useIntlayer.md +225 -0
  76. package/ar/packages/react-intlayer/useIntlayerAsync.md +226 -0
  77. package/ar/packages/react-intlayer/useLocale.md +184 -0
  78. package/ar/packages/react-native-intlayer/index.md +57 -0
  79. package/ar/packages/react-scripts-intlayer/index.md +57 -0
  80. package/ar/packages/solid-intlayer/index.md +3 -0
  81. package/ar/packages/svelte-intlayer/index.md +3 -0
  82. package/ar/packages/vite-intlayer/index.md +53 -0
  83. package/ar/packages/vue-intlayer/index.md +3 -0
  84. package/ar/per_locale_file.md +298 -0
  85. package/ar/privacy_notice.md +61 -0
  86. package/ar/roadmap.md +208 -0
  87. package/ar/terms_of_service.md +33 -0
  88. package/ar/vs_code_extension.md +139 -0
  89. package/de/CI_CD.md +149 -0
  90. package/de/angular-intlayer/index.md +3 -0
  91. package/de/autoFill.md +157 -0
  92. package/de/configuration.md +501 -0
  93. package/de/dictionary/condition.md +213 -0
  94. package/de/dictionary/content_extention_customization.md +81 -0
  95. package/de/dictionary/enumeration.md +221 -0
  96. package/de/dictionary/file.md +207 -0
  97. package/de/dictionary/function_fetching.md +190 -0
  98. package/de/dictionary/get_started.md +466 -0
  99. package/de/dictionary/insertion.md +167 -0
  100. package/de/dictionary/markdown.md +345 -0
  101. package/de/dictionary/nesting.md +252 -0
  102. package/de/dictionary/translation.md +287 -0
  103. package/de/header.md +5 -0
  104. package/de/how_works_intlayer.md +216 -0
  105. package/de/index.md +125 -0
  106. package/de/insertion.md +0 -0
  107. package/de/interest_of_intlayer.md +132 -0
  108. package/de/intlayer_CMS.md +334 -0
  109. package/de/intlayer_cli.md +274 -0
  110. package/de/intlayer_visual_editor.md +210 -0
  111. package/de/intlayer_with_angular.md +3 -0
  112. package/de/intlayer_with_create_react_app.md +1200 -0
  113. package/de/intlayer_with_express.md +268 -0
  114. package/de/intlayer_with_lynx+react.md +482 -0
  115. package/de/intlayer_with_nextjs_14.md +1258 -0
  116. package/de/intlayer_with_nextjs_15.md +1306 -0
  117. package/de/intlayer_with_nextjs_page_router.md +1087 -0
  118. package/de/intlayer_with_react_native+expo.md +539 -0
  119. package/de/intlayer_with_vite+preact.md +1701 -0
  120. package/de/intlayer_with_vite+react.md +1584 -0
  121. package/de/intlayer_with_vite+solid.md +3 -0
  122. package/de/intlayer_with_vite+svelte.md +3 -0
  123. package/de/intlayer_with_vite+vue.md +989 -0
  124. package/de/introduction.md +186 -0
  125. package/de/mcp_server.md +150 -0
  126. package/de/packages/@intlayer/api/index.md +31 -0
  127. package/de/packages/@intlayer/chokidar/index.md +31 -0
  128. package/de/packages/@intlayer/cli/index.md +21 -0
  129. package/de/packages/@intlayer/config/index.md +116 -0
  130. package/de/packages/@intlayer/core/index.md +25 -0
  131. package/de/packages/@intlayer/design-system/index.md +21 -0
  132. package/de/packages/@intlayer/dictionary-entry/index.md +21 -0
  133. package/de/packages/@intlayer/editor/index.md +21 -0
  134. package/de/packages/@intlayer/editor-react/index.md +21 -0
  135. package/de/packages/@intlayer/webpack/index.md +35 -0
  136. package/de/packages/angular-intlayer/index.md +31 -0
  137. package/de/packages/express-intlayer/index.md +229 -0
  138. package/de/packages/express-intlayer/t.md +432 -0
  139. package/de/packages/intlayer/getConfiguration.md +120 -0
  140. package/de/packages/intlayer/getEnumeration.md +140 -0
  141. package/de/packages/intlayer/getHTMLTextDir.md +97 -0
  142. package/de/packages/intlayer/getLocaleLang.md +57 -0
  143. package/de/packages/intlayer/getLocaleName.md +93 -0
  144. package/de/packages/intlayer/getLocalizedUrl.md +221 -0
  145. package/de/packages/intlayer/getMultilingualUrls.md +198 -0
  146. package/de/packages/intlayer/getPathWithoutLocale.md +50 -0
  147. package/de/packages/intlayer/getTranslation.md +166 -0
  148. package/de/packages/intlayer/getTranslationContent.md +166 -0
  149. package/de/packages/intlayer/index.md +478 -0
  150. package/de/packages/intlayer-cli/index.md +41 -0
  151. package/de/packages/intlayer-editor/index.md +113 -0
  152. package/de/packages/lynx-intlayer/index.md +58 -0
  153. package/de/packages/next-intlayer/index.md +263 -0
  154. package/de/packages/next-intlayer/t.md +325 -0
  155. package/de/packages/next-intlayer/useDictionary.md +242 -0
  156. package/de/packages/next-intlayer/useIntlayer.md +237 -0
  157. package/de/packages/next-intlayer/useIntlayerAsync.md +211 -0
  158. package/de/packages/next-intlayer/useLocale.md +105 -0
  159. package/de/packages/preact-intlayer/index.md +3 -0
  160. package/de/packages/react-intlayer/index.md +260 -0
  161. package/de/packages/react-intlayer/t.md +277 -0
  162. package/de/packages/react-intlayer/useDictionary.md +260 -0
  163. package/de/packages/react-intlayer/useIntlayer.md +225 -0
  164. package/de/packages/react-intlayer/useIntlayerAsync.md +226 -0
  165. package/de/packages/react-intlayer/useLocale.md +184 -0
  166. package/de/packages/react-native-intlayer/index.md +57 -0
  167. package/de/packages/react-scripts-intlayer/index.md +57 -0
  168. package/de/packages/solid-intlayer/index.md +3 -0
  169. package/de/packages/svelte-intlayer/index.md +3 -0
  170. package/de/packages/vite-intlayer/index.md +53 -0
  171. package/de/packages/vue-intlayer/index.md +3 -0
  172. package/de/per_locale_file.md +298 -0
  173. package/de/privacy_notice.md +61 -0
  174. package/de/roadmap.md +206 -0
  175. package/de/terms_of_service.md +33 -0
  176. package/de/vs_code_extension.md +139 -0
  177. package/en/CI_CD.md +149 -0
  178. package/en/autoFill.md +157 -0
  179. package/en/configuration.md +506 -0
  180. package/en/dictionary/condition.md +213 -0
  181. package/en/dictionary/content_extention_customization.md +81 -0
  182. package/en/dictionary/enumeration.md +221 -0
  183. package/en/dictionary/file.md +198 -0
  184. package/en/dictionary/function_fetching.md +190 -0
  185. package/en/dictionary/get_started.md +504 -0
  186. package/en/dictionary/insertion.md +167 -0
  187. package/en/dictionary/markdown.md +355 -0
  188. package/en/dictionary/nesting.md +249 -0
  189. package/en/dictionary/translation.md +285 -0
  190. package/en/frequent_questions/build_dictionaries.md +37 -0
  191. package/en/frequent_questions/domain_routing.md +92 -0
  192. package/en/frequent_questions/esbuild_error.md +9 -0
  193. package/en/frequent_questions/get_locale_cookie.md +121 -0
  194. package/en/frequent_questions/intlayer_command_undefined.md +135 -0
  195. package/en/frequent_questions/locale_incorect_in_url.md +52 -0
  196. package/en/frequent_questions/static_rendering.md +24 -0
  197. package/en/frequent_questions/unknown_command.md +76 -0
  198. package/en/header.md +5 -0
  199. package/en/how_works_intlayer.md +219 -0
  200. package/en/index.md +139 -0
  201. package/en/interest_of_intlayer.md +133 -0
  202. package/en/intlayer_CMS.md +334 -0
  203. package/en/intlayer_cli.md +309 -0
  204. package/en/intlayer_visual_editor.md +244 -0
  205. package/en/intlayer_with_angular.md +139 -0
  206. package/en/intlayer_with_create_react_app.md +1209 -0
  207. package/en/intlayer_with_express.md +391 -0
  208. package/en/intlayer_with_lynx+react.md +483 -0
  209. package/en/intlayer_with_nextjs_14.md +1298 -0
  210. package/en/intlayer_with_nextjs_15.md +1347 -0
  211. package/en/intlayer_with_nextjs_page_router.md +1126 -0
  212. package/en/intlayer_with_react_native+expo.md +630 -0
  213. package/en/intlayer_with_vite+preact.md +1659 -0
  214. package/en/intlayer_with_vite+react.md +1605 -0
  215. package/en/intlayer_with_vite+solid.md +254 -0
  216. package/en/intlayer_with_vite+svelte.md +254 -0
  217. package/en/intlayer_with_vite+vue.md +1000 -0
  218. package/en/introduction.md +185 -0
  219. package/en/mcp_server.md +150 -0
  220. package/en/packages/@intlayer/api/index.md +31 -0
  221. package/en/packages/@intlayer/chokidar/index.md +31 -0
  222. package/en/packages/@intlayer/cli/index.md +21 -0
  223. package/en/packages/@intlayer/config/index.md +116 -0
  224. package/en/packages/@intlayer/core/index.md +25 -0
  225. package/en/packages/@intlayer/design-system/index.md +21 -0
  226. package/en/packages/@intlayer/dictionary-entry/index.md +21 -0
  227. package/en/packages/@intlayer/editor/index.md +21 -0
  228. package/en/packages/@intlayer/editor-react/index.md +21 -0
  229. package/en/packages/@intlayer/webpack/index.md +35 -0
  230. package/en/packages/angular-intlayer/index.md +31 -0
  231. package/en/packages/express-intlayer/index.md +229 -0
  232. package/en/packages/express-intlayer/t.md +432 -0
  233. package/en/packages/intlayer/getConfiguration.md +120 -0
  234. package/en/packages/intlayer/getEnumeration.md +138 -0
  235. package/en/packages/intlayer/getHTMLTextDir.md +97 -0
  236. package/en/packages/intlayer/getLocaleLang.md +57 -0
  237. package/en/packages/intlayer/getLocaleName.md +93 -0
  238. package/en/packages/intlayer/getLocalizedUrl.md +221 -0
  239. package/en/packages/intlayer/getMultilingualUrls.md +198 -0
  240. package/en/packages/intlayer/getPathWithoutLocale.md +50 -0
  241. package/en/packages/intlayer/getTranslation.md +166 -0
  242. package/en/packages/intlayer/getTranslationContent.md +166 -0
  243. package/en/packages/intlayer/index.md +476 -0
  244. package/en/packages/intlayer-cli/index.md +41 -0
  245. package/en/packages/intlayer-editor/index.md +113 -0
  246. package/en/packages/lynx-intlayer/index.md +60 -0
  247. package/en/packages/next-intlayer/index.md +263 -0
  248. package/en/packages/next-intlayer/t.md +326 -0
  249. package/en/packages/next-intlayer/useDictionary.md +242 -0
  250. package/en/packages/next-intlayer/useIntlayer.md +237 -0
  251. package/en/packages/next-intlayer/useIntlayerAsync.md +211 -0
  252. package/en/packages/next-intlayer/useLocale.md +105 -0
  253. package/en/packages/preact-intlayer/index.md +31 -0
  254. package/en/packages/react-intlayer/index.md +257 -0
  255. package/en/packages/react-intlayer/t.md +277 -0
  256. package/en/packages/react-intlayer/useDictionary.md +260 -0
  257. package/en/packages/react-intlayer/useIntlayer.md +225 -0
  258. package/en/packages/react-intlayer/useIntlayerAsync.md +226 -0
  259. package/en/packages/react-intlayer/useLocale.md +184 -0
  260. package/en/packages/react-native-intlayer/index.md +59 -0
  261. package/en/packages/react-scripts-intlayer/index.md +57 -0
  262. package/en/packages/solid-intlayer/index.md +31 -0
  263. package/en/packages/svelte-intlayer/index.md +31 -0
  264. package/en/packages/vite-intlayer/index.md +53 -0
  265. package/en/packages/vue-intlayer/index.md +31 -0
  266. package/en/per_locale_file.md +297 -0
  267. package/en/privacy_notice.md +61 -0
  268. package/en/roadmap.md +270 -0
  269. package/en/t.md +163 -0
  270. package/en/terms_of_service.md +33 -0
  271. package/en/vs_code_extension.md +129 -0
  272. package/en-GB/CI_CD.md +149 -0
  273. package/en-GB/autoFill.md +0 -0
  274. package/en-GB/configuration.md +490 -0
  275. package/en-GB/dictionary/condition.md +213 -0
  276. package/en-GB/dictionary/content_extention_customization.md +83 -0
  277. package/en-GB/dictionary/enumeration.md +221 -0
  278. package/en-GB/dictionary/file.md +201 -0
  279. package/en-GB/dictionary/function_fetching.md +190 -0
  280. package/en-GB/dictionary/get_started.md +466 -0
  281. package/en-GB/dictionary/insertion.md +167 -0
  282. package/en-GB/dictionary/markdown.md +343 -0
  283. package/en-GB/dictionary/nesting.md +249 -0
  284. package/en-GB/dictionary/translation.md +285 -0
  285. package/en-GB/header.md +1 -0
  286. package/en-GB/how_works_intlayer.md +217 -0
  287. package/en-GB/index.md +142 -0
  288. package/en-GB/interest_of_intlayer.md +123 -0
  289. package/en-GB/intlayer_CMS.md +334 -0
  290. package/en-GB/intlayer_cli.md +239 -0
  291. package/en-GB/intlayer_visual_editor.md +210 -0
  292. package/en-GB/intlayer_with_angular.md +3 -0
  293. package/en-GB/intlayer_with_create_react_app.md +1192 -0
  294. package/en-GB/intlayer_with_express.md +267 -0
  295. package/en-GB/intlayer_with_lynx+react.md +484 -0
  296. package/en-GB/intlayer_with_nextjs_14.md +1267 -0
  297. package/en-GB/intlayer_with_nextjs_15.md +1308 -0
  298. package/en-GB/intlayer_with_nextjs_page_router.md +1087 -0
  299. package/en-GB/intlayer_with_react_native+expo.md +539 -0
  300. package/en-GB/intlayer_with_vite+preact.md +1648 -0
  301. package/en-GB/intlayer_with_vite+react.md +1430 -0
  302. package/en-GB/intlayer_with_vite+solid.md +3 -0
  303. package/en-GB/intlayer_with_vite+svelte.md +3 -0
  304. package/en-GB/intlayer_with_vite+vue.md +993 -0
  305. package/en-GB/introduction.md +201 -0
  306. package/en-GB/mcp_server.md +150 -0
  307. package/en-GB/packages/@intlayer/api/index.md +31 -0
  308. package/en-GB/packages/@intlayer/chokidar/index.md +31 -0
  309. package/en-GB/packages/@intlayer/cli/index.md +21 -0
  310. package/en-GB/packages/@intlayer/config/index.md +116 -0
  311. package/en-GB/packages/@intlayer/core/index.md +25 -0
  312. package/en-GB/packages/@intlayer/design-system/index.md +21 -0
  313. package/en-GB/packages/@intlayer/dictionary-entry/index.md +21 -0
  314. package/en-GB/packages/@intlayer/editor/index.md +21 -0
  315. package/en-GB/packages/@intlayer/editor-react/index.md +21 -0
  316. package/en-GB/packages/@intlayer/webpack/index.md +35 -0
  317. package/en-GB/packages/angular-intlayer/index.md +3 -0
  318. package/en-GB/packages/express-intlayer/index.md +229 -0
  319. package/en-GB/packages/express-intlayer/t.md +432 -0
  320. package/en-GB/packages/intlayer/getConfiguration.md +120 -0
  321. package/en-GB/packages/intlayer/getEnumeration.md +140 -0
  322. package/en-GB/packages/intlayer/getHTMLTextDir.md +97 -0
  323. package/en-GB/packages/intlayer/getLocaleLang.md +57 -0
  324. package/en-GB/packages/intlayer/getLocaleName.md +93 -0
  325. package/en-GB/packages/intlayer/getLocalizedUrl.md +221 -0
  326. package/en-GB/packages/intlayer/getMultilingualUrls.md +198 -0
  327. package/en-GB/packages/intlayer/getPathWithoutLocale.md +50 -0
  328. package/en-GB/packages/intlayer/getTranslation.md +166 -0
  329. package/en-GB/packages/intlayer/getTranslationContent.md +166 -0
  330. package/en-GB/packages/intlayer/index.md +476 -0
  331. package/en-GB/packages/intlayer-cli/index.md +41 -0
  332. package/en-GB/packages/intlayer-editor/index.md +113 -0
  333. package/en-GB/packages/lynx-intlayer/index.md +58 -0
  334. package/en-GB/packages/next-intlayer/index.md +263 -0
  335. package/en-GB/packages/next-intlayer/t.md +326 -0
  336. package/en-GB/packages/next-intlayer/useDictionary.md +242 -0
  337. package/en-GB/packages/next-intlayer/useIntlayer.md +237 -0
  338. package/en-GB/packages/next-intlayer/useIntlayerAsync.md +211 -0
  339. package/en-GB/packages/next-intlayer/useLocale.md +105 -0
  340. package/en-GB/packages/preact-intlayer/index.md +3 -0
  341. package/en-GB/packages/react-intlayer/index.md +257 -0
  342. package/en-GB/packages/react-intlayer/t.md +277 -0
  343. package/en-GB/packages/react-intlayer/useDictionary.md +260 -0
  344. package/en-GB/packages/react-intlayer/useIntlayer.md +225 -0
  345. package/en-GB/packages/react-intlayer/useIntlayerAsync.md +226 -0
  346. package/en-GB/packages/react-intlayer/useLocale.md +184 -0
  347. package/en-GB/packages/react-native-intlayer/index.md +57 -0
  348. package/en-GB/packages/react-scripts-intlayer/index.md +57 -0
  349. package/en-GB/packages/solid-intlayer/index.md +3 -0
  350. package/en-GB/packages/svelte-intlayer/index.md +3 -0
  351. package/en-GB/packages/vite-intlayer/index.md +53 -0
  352. package/en-GB/packages/vue-intlayer/index.md +3 -0
  353. package/en-GB/per_locale_file.md +298 -0
  354. package/en-GB/privacy_notice.md +57 -0
  355. package/en-GB/roadmap.md +206 -0
  356. package/en-GB/terms_of_service.md +33 -0
  357. package/en-GB/vs_code_extension.md +139 -0
  358. package/es/CI_CD.md +149 -0
  359. package/es/autoFill.md +157 -0
  360. package/es/configuration.md +503 -0
  361. package/es/dictionary/condition.md +213 -0
  362. package/es/dictionary/content_extention_customization.md +81 -0
  363. package/es/dictionary/enumeration.md +221 -0
  364. package/es/dictionary/file.md +206 -0
  365. package/es/dictionary/function_fetching.md +190 -0
  366. package/es/dictionary/get_started.md +466 -0
  367. package/es/dictionary/insertion.md +161 -0
  368. package/es/dictionary/markdown.md +338 -0
  369. package/es/dictionary/nesting.md +249 -0
  370. package/es/dictionary/translation.md +287 -0
  371. package/es/header.md +5 -0
  372. package/es/how_works_intlayer.md +217 -0
  373. package/es/index.md +122 -0
  374. package/es/interest_of_intlayer.md +132 -0
  375. package/es/intlayer_CMS.md +334 -0
  376. package/es/intlayer_cli.md +274 -0
  377. package/es/intlayer_visual_editor.md +210 -0
  378. package/es/intlayer_with_angular.md +3 -0
  379. package/es/intlayer_with_create_react_app.md +1192 -0
  380. package/es/intlayer_with_express.md +276 -0
  381. package/es/intlayer_with_lynx+react.md +475 -0
  382. package/es/intlayer_with_nextjs_14.md +1258 -0
  383. package/es/intlayer_with_nextjs_15.md +1308 -0
  384. package/es/intlayer_with_nextjs_page_router.md +1088 -0
  385. package/es/intlayer_with_react_native+expo.md +180 -0
  386. package/es/intlayer_with_vite+preact.md +1637 -0
  387. package/es/intlayer_with_vite+react.md +1592 -0
  388. package/es/intlayer_with_vite+solid.md +3 -0
  389. package/es/intlayer_with_vite+svelte.md +3 -0
  390. package/es/intlayer_with_vite+vue.md +947 -0
  391. package/es/introduction.md +184 -0
  392. package/es/mcp_server.md +150 -0
  393. package/es/packages/@intlayer/api/index.md +31 -0
  394. package/es/packages/@intlayer/chokidar/index.md +31 -0
  395. package/es/packages/@intlayer/cli/index.md +21 -0
  396. package/es/packages/@intlayer/config/index.md +116 -0
  397. package/es/packages/@intlayer/core/index.md +25 -0
  398. package/es/packages/@intlayer/design-system/index.md +21 -0
  399. package/es/packages/@intlayer/dictionary-entry/index.md +21 -0
  400. package/es/packages/@intlayer/editor/index.md +21 -0
  401. package/es/packages/@intlayer/editor-react/index.md +21 -0
  402. package/es/packages/@intlayer/webpack/index.md +35 -0
  403. package/es/packages/angular-intlayer/index.md +3 -0
  404. package/es/packages/express-intlayer/index.md +229 -0
  405. package/es/packages/express-intlayer/t.md +432 -0
  406. package/es/packages/intlayer/getConfiguration.md +120 -0
  407. package/es/packages/intlayer/getEnumeration.md +138 -0
  408. package/es/packages/intlayer/getHTMLTextDir.md +97 -0
  409. package/es/packages/intlayer/getLocaleLang.md +57 -0
  410. package/es/packages/intlayer/getLocaleName.md +93 -0
  411. package/es/packages/intlayer/getLocalizedUrl.md +221 -0
  412. package/es/packages/intlayer/getMultilingualUrls.md +198 -0
  413. package/es/packages/intlayer/getPathWithoutLocale.md +50 -0
  414. package/es/packages/intlayer/getTranslation.md +166 -0
  415. package/es/packages/intlayer/getTranslationContent.md +166 -0
  416. package/es/packages/intlayer/index.md +478 -0
  417. package/es/packages/intlayer-cli/index.md +41 -0
  418. package/es/packages/intlayer-editor/index.md +115 -0
  419. package/es/packages/lynx-intlayer/index.md +58 -0
  420. package/es/packages/next-intlayer/index.md +263 -0
  421. package/es/packages/next-intlayer/t.md +325 -0
  422. package/es/packages/next-intlayer/useDictionary.md +242 -0
  423. package/es/packages/next-intlayer/useIntlayer.md +237 -0
  424. package/es/packages/next-intlayer/useIntlayerAsync.md +211 -0
  425. package/es/packages/next-intlayer/useLocale.md +105 -0
  426. package/es/packages/preact-intlayer/index.md +3 -0
  427. package/es/packages/react-intlayer/index.md +263 -0
  428. package/es/packages/react-intlayer/t.md +277 -0
  429. package/es/packages/react-intlayer/useDictionary.md +270 -0
  430. package/es/packages/react-intlayer/useIntlayer.md +225 -0
  431. package/es/packages/react-intlayer/useIntlayerAsync.md +226 -0
  432. package/es/packages/react-intlayer/useLocale.md +184 -0
  433. package/es/packages/react-native-intlayer/index.md +57 -0
  434. package/es/packages/react-scripts-intlayer/index.md +57 -0
  435. package/es/packages/solid-intlayer/index.md +3 -0
  436. package/es/packages/svelte-intlayer/index.md +5 -0
  437. package/es/packages/vite-intlayer/index.md +53 -0
  438. package/es/packages/vue-intlayer/index.md +3 -0
  439. package/es/per_locale_file.md +293 -0
  440. package/es/privacy_notice.md +61 -0
  441. package/es/roadmap.md +157 -0
  442. package/es/terms_of_service.md +33 -0
  443. package/es/vs_code_extension.md +139 -0
  444. package/fr/CI_CD.md +149 -0
  445. package/fr/autoFill.md +157 -0
  446. package/fr/configuration.md +481 -0
  447. package/fr/dictionary/condition.md +213 -0
  448. package/fr/dictionary/content_extention_customization.md +81 -0
  449. package/fr/dictionary/enumeration.md +221 -0
  450. package/fr/dictionary/file.md +206 -0
  451. package/fr/dictionary/function_fetching.md +190 -0
  452. package/fr/dictionary/get_started.md +466 -0
  453. package/fr/dictionary/insertion.md +161 -0
  454. package/fr/dictionary/markdown.md +335 -0
  455. package/fr/dictionary/nesting.md +249 -0
  456. package/fr/dictionary/translation.md +287 -0
  457. package/fr/header.md +5 -0
  458. package/fr/how_works_intlayer.md +217 -0
  459. package/fr/index.md +122 -0
  460. package/fr/interest_of_intlayer.md +132 -0
  461. package/fr/intlayer_CMS.md +334 -0
  462. package/fr/intlayer_cli.md +274 -0
  463. package/fr/intlayer_visual_editor.md +210 -0
  464. package/fr/intlayer_with_angular.md +3 -0
  465. package/fr/intlayer_with_create_react_app.md +1192 -0
  466. package/fr/intlayer_with_express.md +270 -0
  467. package/fr/intlayer_with_lynx+react.md +466 -0
  468. package/fr/intlayer_with_nextjs_14.md +1258 -0
  469. package/fr/intlayer_with_nextjs_15.md +1308 -0
  470. package/fr/intlayer_with_nextjs_page_router.md +1085 -0
  471. package/fr/intlayer_with_react_native+expo.md +535 -0
  472. package/fr/intlayer_with_vite+preact.md +1621 -0
  473. package/fr/intlayer_with_vite+react.md +1589 -0
  474. package/fr/intlayer_with_vite+solid.md +3 -0
  475. package/fr/intlayer_with_vite+svelte.md +3 -0
  476. package/fr/intlayer_with_vite+vue.md +947 -0
  477. package/fr/introduction.md +190 -0
  478. package/fr/mcp_server.md +152 -0
  479. package/fr/packages/@intlayer/api/index.md +31 -0
  480. package/fr/packages/@intlayer/chokidar/index.md +31 -0
  481. package/fr/packages/@intlayer/cli/index.md +21 -0
  482. package/fr/packages/@intlayer/config/index.md +116 -0
  483. package/fr/packages/@intlayer/core/index.md +25 -0
  484. package/fr/packages/@intlayer/design-system/index.md +21 -0
  485. package/fr/packages/@intlayer/dictionary-entry/index.md +21 -0
  486. package/fr/packages/@intlayer/editor/index.md +21 -0
  487. package/fr/packages/@intlayer/editor-react/index.md +21 -0
  488. package/fr/packages/@intlayer/webpack/index.md +35 -0
  489. package/fr/packages/angular-intlayer/index.md +3 -0
  490. package/fr/packages/express-intlayer/index.md +238 -0
  491. package/fr/packages/express-intlayer/t.md +432 -0
  492. package/fr/packages/intlayer/getConfiguration.md +120 -0
  493. package/fr/packages/intlayer/getEnumeration.md +138 -0
  494. package/fr/packages/intlayer/getHTMLTextDir.md +97 -0
  495. package/fr/packages/intlayer/getLocaleLang.md +57 -0
  496. package/fr/packages/intlayer/getLocaleName.md +93 -0
  497. package/fr/packages/intlayer/getLocalizedUrl.md +221 -0
  498. package/fr/packages/intlayer/getMultilingualUrls.md +198 -0
  499. package/fr/packages/intlayer/getPathWithoutLocale.md +50 -0
  500. package/fr/packages/intlayer/getTranslation.md +166 -0
  501. package/fr/packages/intlayer/getTranslationContent.md +166 -0
  502. package/fr/packages/intlayer/index.md +476 -0
  503. package/fr/packages/intlayer-cli/index.md +41 -0
  504. package/fr/packages/intlayer-editor/index.md +115 -0
  505. package/fr/packages/lynx-intlayer/index.md +58 -0
  506. package/fr/packages/next-intlayer/index.md +266 -0
  507. package/fr/packages/next-intlayer/t.md +325 -0
  508. package/fr/packages/next-intlayer/useDictionary.md +242 -0
  509. package/fr/packages/next-intlayer/useIntlayer.md +237 -0
  510. package/fr/packages/next-intlayer/useIntlayerAsync.md +211 -0
  511. package/fr/packages/next-intlayer/useLocale.md +105 -0
  512. package/fr/packages/preact-intlayer/index.md +3 -0
  513. package/fr/packages/react-intlayer/index.md +257 -0
  514. package/fr/packages/react-intlayer/t.md +277 -0
  515. package/fr/packages/react-intlayer/useDictionary.md +269 -0
  516. package/fr/packages/react-intlayer/useIntlayer.md +234 -0
  517. package/fr/packages/react-intlayer/useIntlayerAsync.md +226 -0
  518. package/fr/packages/react-intlayer/useLocale.md +184 -0
  519. package/fr/packages/react-native-intlayer/index.md +57 -0
  520. package/fr/packages/react-scripts-intlayer/index.md +57 -0
  521. package/fr/packages/solid-intlayer/index.md +3 -0
  522. package/fr/packages/svelte-intlayer/index.md +3 -0
  523. package/fr/packages/vite-intlayer/index.md +53 -0
  524. package/fr/packages/vue-intlayer/index.md +3 -0
  525. package/fr/per_locale_file.md +297 -0
  526. package/fr/privacy_notice.md +57 -0
  527. package/fr/roadmap.md +206 -0
  528. package/fr/terms_of_service.md +33 -0
  529. package/fr/vs_code_extension.md +139 -0
  530. package/hi/CI_CD.md +149 -0
  531. package/hi/autoFill.md +157 -0
  532. package/hi/configuration.md +509 -0
  533. package/hi/dictionary/condition.md +213 -0
  534. package/hi/dictionary/content_extention_customization.md +81 -0
  535. package/hi/dictionary/enumeration.md +221 -0
  536. package/hi/dictionary/file.md +209 -0
  537. package/hi/dictionary/function_fetching.md +188 -0
  538. package/hi/dictionary/get_started.md +490 -0
  539. package/hi/dictionary/insertion.md +167 -0
  540. package/hi/dictionary/markdown.md +344 -0
  541. package/hi/dictionary/nesting.md +249 -0
  542. package/hi/dictionary/translation.md +307 -0
  543. package/hi/header.md +7 -0
  544. package/hi/how_works_intlayer.md +217 -0
  545. package/hi/index.md +125 -0
  546. package/hi/interest_of_intlayer.md +132 -0
  547. package/hi/intlayer_CMS.md +334 -0
  548. package/hi/intlayer_cli.md +274 -0
  549. package/hi/intlayer_visual_editor.md +210 -0
  550. package/hi/intlayer_with_angular.md +3 -0
  551. package/hi/intlayer_with_create_react_app.md +1395 -0
  552. package/hi/intlayer_with_express.md +273 -0
  553. package/hi/intlayer_with_lynx+react.md +456 -0
  554. package/hi/intlayer_with_nextjs_14.md +1283 -0
  555. package/hi/intlayer_with_nextjs_15.md +1319 -0
  556. package/hi/intlayer_with_nextjs_page_router.md +1097 -0
  557. package/hi/intlayer_with_react_native+expo.md +554 -0
  558. package/hi/intlayer_with_vite+preact.md +1538 -0
  559. package/hi/intlayer_with_vite+react.md +1540 -0
  560. package/hi/intlayer_with_vite+solid.md +3 -0
  561. package/hi/intlayer_with_vite+svelte.md +3 -0
  562. package/hi/intlayer_with_vite+vue.md +840 -0
  563. package/hi/introduction.md +190 -0
  564. package/hi/mcp_server.md +150 -0
  565. package/hi/packages/@intlayer/api/index.md +31 -0
  566. package/hi/packages/@intlayer/chokidar/index.md +31 -0
  567. package/hi/packages/@intlayer/cli/index.md +21 -0
  568. package/hi/packages/@intlayer/config/index.md +116 -0
  569. package/hi/packages/@intlayer/core/index.md +25 -0
  570. package/hi/packages/@intlayer/design-system/index.md +21 -0
  571. package/hi/packages/@intlayer/dictionary-entry/index.md +21 -0
  572. package/hi/packages/@intlayer/editor/index.md +21 -0
  573. package/hi/packages/@intlayer/editor-react/index.md +21 -0
  574. package/hi/packages/@intlayer/webpack/index.md +35 -0
  575. package/hi/packages/angular-intlayer/index.md +3 -0
  576. package/hi/packages/express-intlayer/index.md +232 -0
  577. package/hi/packages/express-intlayer/t.md +445 -0
  578. package/hi/packages/intlayer/getConfiguration.md +120 -0
  579. package/hi/packages/intlayer/getEnumeration.md +138 -0
  580. package/hi/packages/intlayer/getHTMLTextDir.md +97 -0
  581. package/hi/packages/intlayer/getLocaleLang.md +57 -0
  582. package/hi/packages/intlayer/getLocaleName.md +93 -0
  583. package/hi/packages/intlayer/getLocalizedUrl.md +221 -0
  584. package/hi/packages/intlayer/getMultilingualUrls.md +198 -0
  585. package/hi/packages/intlayer/getPathWithoutLocale.md +50 -0
  586. package/hi/packages/intlayer/getTranslation.md +175 -0
  587. package/hi/packages/intlayer/getTranslationContent.md +175 -0
  588. package/hi/packages/intlayer/index.md +314 -0
  589. package/hi/packages/intlayer-cli/index.md +41 -0
  590. package/hi/packages/intlayer-editor/index.md +113 -0
  591. package/hi/packages/lynx-intlayer/index.md +58 -0
  592. package/hi/packages/next-intlayer/index.md +270 -0
  593. package/hi/packages/next-intlayer/t.md +337 -0
  594. package/hi/packages/next-intlayer/useDictionary.md +248 -0
  595. package/hi/packages/next-intlayer/useIntlayer.md +237 -0
  596. package/hi/packages/next-intlayer/useIntlayerAsync.md +211 -0
  597. package/hi/packages/next-intlayer/useLocale.md +105 -0
  598. package/hi/packages/preact-intlayer/index.md +3 -0
  599. package/hi/packages/react-intlayer/index.md +261 -0
  600. package/hi/packages/react-intlayer/t.md +283 -0
  601. package/hi/packages/react-intlayer/useDictionary.md +268 -0
  602. package/hi/packages/react-intlayer/useIntlayer.md +225 -0
  603. package/hi/packages/react-intlayer/useIntlayerAsync.md +226 -0
  604. package/hi/packages/react-intlayer/useLocale.md +184 -0
  605. package/hi/packages/react-native-intlayer/index.md +57 -0
  606. package/hi/packages/react-scripts-intlayer/index.md +57 -0
  607. package/hi/packages/solid-intlayer/index.md +3 -0
  608. package/hi/packages/svelte-intlayer/index.md +3 -0
  609. package/hi/packages/vite-intlayer/index.md +53 -0
  610. package/hi/packages/vue-intlayer/index.md +3 -0
  611. package/hi/per_locale_file.md +298 -0
  612. package/hi/privacy_notice.md +61 -0
  613. package/hi/roadmap.md +206 -0
  614. package/hi/terms_of_service.md +33 -0
  615. package/hi/vs_code_extension.md +139 -0
  616. package/index.cjs +1265 -0
  617. package/index.d.ts +100 -0
  618. package/it/CI_CD.md +149 -0
  619. package/it/autoFill.md +157 -0
  620. package/it/configuration.md +503 -0
  621. package/it/dictionary/condition.md +213 -0
  622. package/it/dictionary/content_extention_customization.md +81 -0
  623. package/it/dictionary/enumeration.md +221 -0
  624. package/it/dictionary/file.md +207 -0
  625. package/it/dictionary/function_fetching.md +190 -0
  626. package/it/dictionary/get_started.md +466 -0
  627. package/it/dictionary/insertion.md +161 -0
  628. package/it/dictionary/markdown.md +343 -0
  629. package/it/dictionary/nesting.md +249 -0
  630. package/it/dictionary/translation.md +287 -0
  631. package/it/header.md +7 -0
  632. package/it/how_works_intlayer.md +217 -0
  633. package/it/index.md +125 -0
  634. package/it/interest_of_intlayer.md +132 -0
  635. package/it/intlayer_CMS.md +334 -0
  636. package/it/intlayer_cli.md +274 -0
  637. package/it/intlayer_visual_editor.md +210 -0
  638. package/it/intlayer_with_angular.md +3 -0
  639. package/it/intlayer_with_create_react_app.md +413 -0
  640. package/it/intlayer_with_express.md +267 -0
  641. package/it/intlayer_with_lynx+react.md +482 -0
  642. package/it/intlayer_with_nextjs_14.md +1269 -0
  643. package/it/intlayer_with_nextjs_15.md +1319 -0
  644. package/it/intlayer_with_nextjs_page_router.md +1095 -0
  645. package/it/intlayer_with_react_native+expo.md +261 -0
  646. package/it/intlayer_with_vite+preact.md +1681 -0
  647. package/it/intlayer_with_vite+react.md +1580 -0
  648. package/it/intlayer_with_vite+solid.md +3 -0
  649. package/it/intlayer_with_vite+svelte.md +3 -0
  650. package/it/intlayer_with_vite+vue.md +989 -0
  651. package/it/introduction.md +192 -0
  652. package/it/mcp_server.md +152 -0
  653. package/it/packages/@intlayer/api/index.md +31 -0
  654. package/it/packages/@intlayer/chokidar/index.md +31 -0
  655. package/it/packages/@intlayer/cli/index.md +21 -0
  656. package/it/packages/@intlayer/config/index.md +116 -0
  657. package/it/packages/@intlayer/core/index.md +25 -0
  658. package/it/packages/@intlayer/design-system/index.md +21 -0
  659. package/it/packages/@intlayer/dictionary-entry/index.md +21 -0
  660. package/it/packages/@intlayer/editor/index.md +21 -0
  661. package/it/packages/@intlayer/editor-react/index.md +21 -0
  662. package/it/packages/@intlayer/webpack/index.md +35 -0
  663. package/it/packages/angular-intlayer/index.md +3 -0
  664. package/it/packages/express-intlayer/index.md +229 -0
  665. package/it/packages/express-intlayer/t.md +432 -0
  666. package/it/packages/intlayer/getConfiguration.md +120 -0
  667. package/it/packages/intlayer/getEnumeration.md +138 -0
  668. package/it/packages/intlayer/getHTMLTextDir.md +97 -0
  669. package/it/packages/intlayer/getLocaleLang.md +57 -0
  670. package/it/packages/intlayer/getLocaleName.md +93 -0
  671. package/it/packages/intlayer/getLocalizedUrl.md +221 -0
  672. package/it/packages/intlayer/getMultilingualUrls.md +200 -0
  673. package/it/packages/intlayer/getPathWithoutLocale.md +50 -0
  674. package/it/packages/intlayer/getTranslation.md +166 -0
  675. package/it/packages/intlayer/getTranslationContent.md +166 -0
  676. package/it/packages/intlayer/index.md +479 -0
  677. package/it/packages/intlayer-cli/index.md +41 -0
  678. package/it/packages/intlayer-editor/index.md +113 -0
  679. package/it/packages/lynx-intlayer/index.md +58 -0
  680. package/it/packages/next-intlayer/index.md +267 -0
  681. package/it/packages/next-intlayer/t.md +326 -0
  682. package/it/packages/next-intlayer/useDictionary.md +242 -0
  683. package/it/packages/next-intlayer/useIntlayer.md +237 -0
  684. package/it/packages/next-intlayer/useIntlayerAsync.md +211 -0
  685. package/it/packages/next-intlayer/useLocale.md +105 -0
  686. package/it/packages/preact-intlayer/index.md +3 -0
  687. package/it/packages/react-intlayer/index.md +260 -0
  688. package/it/packages/react-intlayer/t.md +277 -0
  689. package/it/packages/react-intlayer/useDictionary.md +260 -0
  690. package/it/packages/react-intlayer/useIntlayer.md +225 -0
  691. package/it/packages/react-intlayer/useIntlayerAsync.md +226 -0
  692. package/it/packages/react-intlayer/useLocale.md +184 -0
  693. package/it/packages/react-native-intlayer/index.md +57 -0
  694. package/it/packages/react-scripts-intlayer/index.md +57 -0
  695. package/it/packages/solid-intlayer/index.md +5 -0
  696. package/it/packages/svelte-intlayer/index.md +3 -0
  697. package/it/packages/vite-intlayer/index.md +53 -0
  698. package/it/packages/vue-intlayer/index.md +5 -0
  699. package/it/per_locale_file.md +298 -0
  700. package/it/privacy_notice.md +61 -0
  701. package/it/roadmap.md +206 -0
  702. package/it/terms_of_service.md +33 -0
  703. package/it/vs_code_extension.md +139 -0
  704. package/ja/CI_CD.md +149 -0
  705. package/ja/autoFill.md +157 -0
  706. package/ja/configuration.md +507 -0
  707. package/ja/dictionary/condition.md +213 -0
  708. package/ja/dictionary/content_extention_customization.md +81 -0
  709. package/ja/dictionary/enumeration.md +221 -0
  710. package/ja/dictionary/file.md +209 -0
  711. package/ja/dictionary/function_fetching.md +190 -0
  712. package/ja/dictionary/get_started.md +466 -0
  713. package/ja/dictionary/insertion.md +161 -0
  714. package/ja/dictionary/markdown.md +343 -0
  715. package/ja/dictionary/nesting.md +249 -0
  716. package/ja/dictionary/translation.md +287 -0
  717. package/ja/header.md +7 -0
  718. package/ja/how_works_intlayer.md +217 -0
  719. package/ja/index.md +125 -0
  720. package/ja/interest_of_intlayer.md +132 -0
  721. package/ja/intlayer_CMS.md +334 -0
  722. package/ja/intlayer_cli.md +274 -0
  723. package/ja/intlayer_visual_editor.md +213 -0
  724. package/ja/intlayer_with_angular.md +3 -0
  725. package/ja/intlayer_with_create_react_app.md +1186 -0
  726. package/ja/intlayer_with_express.md +267 -0
  727. package/ja/intlayer_with_lynx+react.md +482 -0
  728. package/ja/intlayer_with_nextjs_14.md +1256 -0
  729. package/ja/intlayer_with_nextjs_15.md +1308 -0
  730. package/ja/intlayer_with_nextjs_page_router.md +1085 -0
  731. package/ja/intlayer_with_react_native+expo.md +537 -0
  732. package/ja/intlayer_with_vite+preact.md +1601 -0
  733. package/ja/intlayer_with_vite+react.md +1555 -0
  734. package/ja/intlayer_with_vite+solid.md +3 -0
  735. package/ja/intlayer_with_vite+svelte.md +3 -0
  736. package/ja/intlayer_with_vite+vue.md +990 -0
  737. package/ja/introduction.md +186 -0
  738. package/ja/mcp_server.md +150 -0
  739. package/ja/packages/@intlayer/api/index.md +31 -0
  740. package/ja/packages/@intlayer/chokidar/index.md +31 -0
  741. package/ja/packages/@intlayer/cli/index.md +21 -0
  742. package/ja/packages/@intlayer/config/index.md +116 -0
  743. package/ja/packages/@intlayer/core/index.md +25 -0
  744. package/ja/packages/@intlayer/design-system/index.md +21 -0
  745. package/ja/packages/@intlayer/dictionary-entry/index.md +21 -0
  746. package/ja/packages/@intlayer/editor/index.md +21 -0
  747. package/ja/packages/@intlayer/editor-react/index.md +21 -0
  748. package/ja/packages/@intlayer/webpack/index.md +35 -0
  749. package/ja/packages/angular-intlayer/index.md +3 -0
  750. package/ja/packages/express-intlayer/index.md +229 -0
  751. package/ja/packages/express-intlayer/t.md +432 -0
  752. package/ja/packages/intlayer/getConfiguration.md +120 -0
  753. package/ja/packages/intlayer/getEnumeration.md +140 -0
  754. package/ja/packages/intlayer/getHTMLTextDir.md +97 -0
  755. package/ja/packages/intlayer/getLocaleLang.md +59 -0
  756. package/ja/packages/intlayer/getLocaleName.md +93 -0
  757. package/ja/packages/intlayer/getLocalizedUrl.md +221 -0
  758. package/ja/packages/intlayer/getMultilingualUrls.md +198 -0
  759. package/ja/packages/intlayer/getPathWithoutLocale.md +50 -0
  760. package/ja/packages/intlayer/getTranslation.md +166 -0
  761. package/ja/packages/intlayer/getTranslationContent.md +166 -0
  762. package/ja/packages/intlayer/index.md +479 -0
  763. package/ja/packages/intlayer-cli/index.md +41 -0
  764. package/ja/packages/intlayer-editor/index.md +115 -0
  765. package/ja/packages/lynx-intlayer/index.md +58 -0
  766. package/ja/packages/next-intlayer/index.md +263 -0
  767. package/ja/packages/next-intlayer/t.md +326 -0
  768. package/ja/packages/next-intlayer/useDictionary.md +242 -0
  769. package/ja/packages/next-intlayer/useIntlayer.md +237 -0
  770. package/ja/packages/next-intlayer/useIntlayerAsync.md +211 -0
  771. package/ja/packages/next-intlayer/useLocale.md +105 -0
  772. package/ja/packages/preact-intlayer/index.md +3 -0
  773. package/ja/packages/react-intlayer/index.md +257 -0
  774. package/ja/packages/react-intlayer/t.md +277 -0
  775. package/ja/packages/react-intlayer/useDictionary.md +260 -0
  776. package/ja/packages/react-intlayer/useIntlayer.md +225 -0
  777. package/ja/packages/react-intlayer/useIntlayerAsync.md +226 -0
  778. package/ja/packages/react-intlayer/useLocale.md +184 -0
  779. package/ja/packages/react-native-intlayer/index.md +57 -0
  780. package/ja/packages/react-scripts-intlayer/index.md +57 -0
  781. package/ja/packages/solid-intlayer/index.md +3 -0
  782. package/ja/packages/svelte-intlayer/index.md +3 -0
  783. package/ja/packages/vite-intlayer/index.md +53 -0
  784. package/ja/packages/vue-intlayer/index.md +3 -0
  785. package/ja/per_locale_file.md +298 -0
  786. package/ja/privacy_notice.md +57 -0
  787. package/ja/roadmap.md +206 -0
  788. package/ja/terms_of_service.md +33 -0
  789. package/ja/vs_code_extension.md +139 -0
  790. package/ko/CI_CD.md +149 -0
  791. package/ko/autoFill.md +157 -0
  792. package/ko/configuration.md +507 -0
  793. package/ko/dictionary/condition.md +213 -0
  794. package/ko/dictionary/content_extention_customization.md +81 -0
  795. package/ko/dictionary/enumeration.md +221 -0
  796. package/ko/dictionary/file.md +207 -0
  797. package/ko/dictionary/function_fetching.md +190 -0
  798. package/ko/dictionary/get_started.md +466 -0
  799. package/ko/dictionary/insertion.md +167 -0
  800. package/ko/dictionary/markdown.md +343 -0
  801. package/ko/dictionary/nesting.md +249 -0
  802. package/ko/dictionary/translation.md +287 -0
  803. package/ko/header.md +7 -0
  804. package/ko/how_works_intlayer.md +216 -0
  805. package/ko/index.md +125 -0
  806. package/ko/interest_of_intlayer.md +132 -0
  807. package/ko/intlayer_CMS.md +334 -0
  808. package/ko/intlayer_cli.md +274 -0
  809. package/ko/intlayer_visual_editor.md +210 -0
  810. package/ko/intlayer_with_angular.md +3 -0
  811. package/ko/intlayer_with_create_react_app.md +1186 -0
  812. package/ko/intlayer_with_express.md +267 -0
  813. package/ko/intlayer_with_lynx+react.md +482 -0
  814. package/ko/intlayer_with_nextjs_14.md +1267 -0
  815. package/ko/intlayer_with_nextjs_15.md +1319 -0
  816. package/ko/intlayer_with_nextjs_page_router.md +1097 -0
  817. package/ko/intlayer_with_react_native+expo.md +537 -0
  818. package/ko/intlayer_with_vite+preact.md +1682 -0
  819. package/ko/intlayer_with_vite+react.md +1582 -0
  820. package/ko/intlayer_with_vite+solid.md +3 -0
  821. package/ko/intlayer_with_vite+svelte.md +3 -0
  822. package/ko/intlayer_with_vite+vue.md +988 -0
  823. package/ko/introduction.md +186 -0
  824. package/ko/mcp_server.md +150 -0
  825. package/ko/packages/@intlayer/api/index.md +31 -0
  826. package/ko/packages/@intlayer/chokidar/index.md +31 -0
  827. package/ko/packages/@intlayer/cli/index.md +21 -0
  828. package/ko/packages/@intlayer/config/index.md +116 -0
  829. package/ko/packages/@intlayer/core/index.md +25 -0
  830. package/ko/packages/@intlayer/design-system/index.md +21 -0
  831. package/ko/packages/@intlayer/dictionary-entry/index.md +21 -0
  832. package/ko/packages/@intlayer/editor/index.md +21 -0
  833. package/ko/packages/@intlayer/editor-react/index.md +21 -0
  834. package/ko/packages/@intlayer/webpack/index.md +35 -0
  835. package/ko/packages/angular-intlayer/index.md +5 -0
  836. package/ko/packages/express-intlayer/index.md +229 -0
  837. package/ko/packages/express-intlayer/t.md +432 -0
  838. package/ko/packages/intlayer/getConfiguration.md +120 -0
  839. package/ko/packages/intlayer/getEnumeration.md +138 -0
  840. package/ko/packages/intlayer/getHTMLTextDir.md +97 -0
  841. package/ko/packages/intlayer/getLocaleLang.md +57 -0
  842. package/ko/packages/intlayer/getLocaleName.md +93 -0
  843. package/ko/packages/intlayer/getLocalizedUrl.md +221 -0
  844. package/ko/packages/intlayer/getMultilingualUrls.md +198 -0
  845. package/ko/packages/intlayer/getPathWithoutLocale.md +50 -0
  846. package/ko/packages/intlayer/getTranslation.md +166 -0
  847. package/ko/packages/intlayer/getTranslationContent.md +166 -0
  848. package/ko/packages/intlayer/index.md +480 -0
  849. package/ko/packages/intlayer-cli/index.md +41 -0
  850. package/ko/packages/intlayer-editor/index.md +113 -0
  851. package/ko/packages/lynx-intlayer/index.md +58 -0
  852. package/ko/packages/next-intlayer/index.md +267 -0
  853. package/ko/packages/next-intlayer/t.md +337 -0
  854. package/ko/packages/next-intlayer/useDictionary.md +242 -0
  855. package/ko/packages/next-intlayer/useIntlayer.md +237 -0
  856. package/ko/packages/next-intlayer/useIntlayerAsync.md +211 -0
  857. package/ko/packages/next-intlayer/useLocale.md +105 -0
  858. package/ko/packages/preact-intlayer/index.md +3 -0
  859. package/ko/packages/react-intlayer/index.md +260 -0
  860. package/ko/packages/react-intlayer/t.md +277 -0
  861. package/ko/packages/react-intlayer/useDictionary.md +268 -0
  862. package/ko/packages/react-intlayer/useIntlayer.md +225 -0
  863. package/ko/packages/react-intlayer/useIntlayerAsync.md +226 -0
  864. package/ko/packages/react-intlayer/useLocale.md +184 -0
  865. package/ko/packages/react-native-intlayer/index.md +57 -0
  866. package/ko/packages/react-scripts-intlayer/index.md +57 -0
  867. package/ko/packages/solid-intlayer/index.md +3 -0
  868. package/ko/packages/svelte-intlayer/index.md +3 -0
  869. package/ko/packages/vite-intlayer/index.md +53 -0
  870. package/ko/packages/vue-intlayer/index.md +3 -0
  871. package/ko/per_locale_file.md +300 -0
  872. package/ko/privacy_notice.md +61 -0
  873. package/ko/roadmap.md +206 -0
  874. package/ko/terms_of_service.md +33 -0
  875. package/ko/vs_code_extension.md +139 -0
  876. package/package.json +96 -0
  877. package/pt/CI_CD.md +149 -0
  878. package/pt/autoFill.md +157 -0
  879. package/pt/configuration.md +503 -0
  880. package/pt/dictionary/condition.md +213 -0
  881. package/pt/dictionary/content_extention_customization.md +81 -0
  882. package/pt/dictionary/enumeration.md +221 -0
  883. package/pt/dictionary/file.md +210 -0
  884. package/pt/dictionary/function_fetching.md +190 -0
  885. package/pt/dictionary/get_started.md +490 -0
  886. package/pt/dictionary/insertion.md +161 -0
  887. package/pt/dictionary/markdown.md +339 -0
  888. package/pt/dictionary/nesting.md +249 -0
  889. package/pt/dictionary/translation.md +322 -0
  890. package/pt/header.md +7 -0
  891. package/pt/how_works_intlayer.md +216 -0
  892. package/pt/index.md +125 -0
  893. package/pt/interest_of_intlayer.md +132 -0
  894. package/pt/intlayer_CMS.md +334 -0
  895. package/pt/intlayer_cli.md +274 -0
  896. package/pt/intlayer_visual_editor.md +210 -0
  897. package/pt/intlayer_with_angular.md +3 -0
  898. package/pt/intlayer_with_create_react_app.md +1204 -0
  899. package/pt/intlayer_with_express.md +270 -0
  900. package/pt/intlayer_with_lynx+react.md +467 -0
  901. package/pt/intlayer_with_nextjs_14.md +1269 -0
  902. package/pt/intlayer_with_nextjs_15.md +1319 -0
  903. package/pt/intlayer_with_nextjs_page_router.md +1109 -0
  904. package/pt/intlayer_with_react_native+expo.md +259 -0
  905. package/pt/intlayer_with_vite+preact.md +1663 -0
  906. package/pt/intlayer_with_vite+react.md +1621 -0
  907. package/pt/intlayer_with_vite+solid.md +3 -0
  908. package/pt/intlayer_with_vite+svelte.md +3 -0
  909. package/pt/intlayer_with_vite+vue.md +989 -0
  910. package/pt/introduction.md +193 -0
  911. package/pt/mcp_server.md +150 -0
  912. package/pt/packages/@intlayer/api/index.md +31 -0
  913. package/pt/packages/@intlayer/chokidar/index.md +31 -0
  914. package/pt/packages/@intlayer/cli/index.md +21 -0
  915. package/pt/packages/@intlayer/config/index.md +116 -0
  916. package/pt/packages/@intlayer/core/index.md +25 -0
  917. package/pt/packages/@intlayer/design-system/index.md +21 -0
  918. package/pt/packages/@intlayer/dictionary-entry/index.md +21 -0
  919. package/pt/packages/@intlayer/editor/index.md +21 -0
  920. package/pt/packages/@intlayer/editor-react/index.md +21 -0
  921. package/pt/packages/@intlayer/webpack/index.md +35 -0
  922. package/pt/packages/angular-intlayer/index.md +3 -0
  923. package/pt/packages/express-intlayer/index.md +232 -0
  924. package/pt/packages/express-intlayer/t.md +267 -0
  925. package/pt/packages/intlayer/getConfiguration.md +120 -0
  926. package/pt/packages/intlayer/getEnumeration.md +138 -0
  927. package/pt/packages/intlayer/getHTMLTextDir.md +97 -0
  928. package/pt/packages/intlayer/getLocaleLang.md +57 -0
  929. package/pt/packages/intlayer/getLocaleName.md +93 -0
  930. package/pt/packages/intlayer/getLocalizedUrl.md +221 -0
  931. package/pt/packages/intlayer/getMultilingualUrls.md +198 -0
  932. package/pt/packages/intlayer/getPathWithoutLocale.md +50 -0
  933. package/pt/packages/intlayer/getTranslation.md +175 -0
  934. package/pt/packages/intlayer/getTranslationContent.md +177 -0
  935. package/pt/packages/intlayer/index.md +484 -0
  936. package/pt/packages/intlayer-cli/index.md +41 -0
  937. package/pt/packages/intlayer-editor/index.md +113 -0
  938. package/pt/packages/lynx-intlayer/index.md +58 -0
  939. package/pt/packages/next-intlayer/index.md +270 -0
  940. package/pt/packages/next-intlayer/t.md +341 -0
  941. package/pt/packages/next-intlayer/useDictionary.md +248 -0
  942. package/pt/packages/next-intlayer/useIntlayer.md +237 -0
  943. package/pt/packages/next-intlayer/useIntlayerAsync.md +211 -0
  944. package/pt/packages/next-intlayer/useLocale.md +105 -0
  945. package/pt/packages/preact-intlayer/index.md +3 -0
  946. package/pt/packages/react-intlayer/index.md +261 -0
  947. package/pt/packages/react-intlayer/t.md +289 -0
  948. package/pt/packages/react-intlayer/useDictionary.md +268 -0
  949. package/pt/packages/react-intlayer/useIntlayer.md +225 -0
  950. package/pt/packages/react-intlayer/useIntlayerAsync.md +226 -0
  951. package/pt/packages/react-intlayer/useLocale.md +184 -0
  952. package/pt/packages/react-native-intlayer/index.md +57 -0
  953. package/pt/packages/react-scripts-intlayer/index.md +57 -0
  954. package/pt/packages/solid-intlayer/index.md +3 -0
  955. package/pt/packages/svelte-intlayer/index.md +3 -0
  956. package/pt/packages/vite-intlayer/index.md +53 -0
  957. package/pt/packages/vue-intlayer/index.md +3 -0
  958. package/pt/per_locale_file.md +298 -0
  959. package/pt/privacy_notice.md +61 -0
  960. package/pt/roadmap.md +206 -0
  961. package/pt/terms_of_service.md +33 -0
  962. package/pt/vs_code_extension.md +139 -0
  963. package/ru/CI_CD.md +149 -0
  964. package/ru/autoFill.md +157 -0
  965. package/ru/configuration.md +507 -0
  966. package/ru/dictionary/condition.md +213 -0
  967. package/ru/dictionary/content_extention_customization.md +81 -0
  968. package/ru/dictionary/enumeration.md +221 -0
  969. package/ru/dictionary/file.md +209 -0
  970. package/ru/dictionary/function_fetching.md +188 -0
  971. package/ru/dictionary/get_started.md +311 -0
  972. package/ru/dictionary/insertion.md +161 -0
  973. package/ru/dictionary/markdown.md +339 -0
  974. package/ru/dictionary/nesting.md +249 -0
  975. package/ru/dictionary/translation.md +322 -0
  976. package/ru/environment/angular.md +3 -0
  977. package/ru/header.md +7 -0
  978. package/ru/how_works_intlayer.md +217 -0
  979. package/ru/index.md +125 -0
  980. package/ru/interest_of_intlayer.md +132 -0
  981. package/ru/intlayer_CMS.md +334 -0
  982. package/ru/intlayer_cli.md +274 -0
  983. package/ru/intlayer_visual_editor.md +210 -0
  984. package/ru/intlayer_with_angular.md +3 -0
  985. package/ru/intlayer_with_create_react_app.md +1196 -0
  986. package/ru/intlayer_with_express.md +273 -0
  987. package/ru/intlayer_with_lynx+react.md +482 -0
  988. package/ru/intlayer_with_nextjs_14.md +1274 -0
  989. package/ru/intlayer_with_nextjs_15.md +1318 -0
  990. package/ru/intlayer_with_nextjs_page_router.md +1100 -0
  991. package/ru/intlayer_with_react_native+expo.md +537 -0
  992. package/ru/intlayer_with_vite+preact.md +1663 -0
  993. package/ru/intlayer_with_vite+react.md +1546 -0
  994. package/ru/intlayer_with_vite+solid.md +3 -0
  995. package/ru/intlayer_with_vite+svelte.md +3 -0
  996. package/ru/intlayer_with_vite+vue.md +987 -0
  997. package/ru/introduction.md +190 -0
  998. package/ru/mcp_server.md +152 -0
  999. package/ru/packages/@intlayer/api/index.md +31 -0
  1000. package/ru/packages/@intlayer/chokidar/index.md +31 -0
  1001. package/ru/packages/@intlayer/cli/index.md +23 -0
  1002. package/ru/packages/@intlayer/config/index.md +116 -0
  1003. package/ru/packages/@intlayer/core/index.md +25 -0
  1004. package/ru/packages/@intlayer/design-system/index.md +21 -0
  1005. package/ru/packages/@intlayer/dictionary-entry/index.md +21 -0
  1006. package/ru/packages/@intlayer/editor/index.md +21 -0
  1007. package/ru/packages/@intlayer/editor-react/index.md +21 -0
  1008. package/ru/packages/@intlayer/webpack/index.md +35 -0
  1009. package/ru/packages/angular-intlayer/index.md +3 -0
  1010. package/ru/packages/express-intlayer/index.md +235 -0
  1011. package/ru/packages/express-intlayer/t.md +445 -0
  1012. package/ru/packages/intlayer/getConfiguration.md +120 -0
  1013. package/ru/packages/intlayer/getEnumeration.md +140 -0
  1014. package/ru/packages/intlayer/getHTMLTextDir.md +97 -0
  1015. package/ru/packages/intlayer/getLocaleLang.md +59 -0
  1016. package/ru/packages/intlayer/getLocaleName.md +93 -0
  1017. package/ru/packages/intlayer/getLocalizedUrl.md +221 -0
  1018. package/ru/packages/intlayer/getMultilingualUrls.md +198 -0
  1019. package/ru/packages/intlayer/getPathWithoutLocale.md +50 -0
  1020. package/ru/packages/intlayer/getTranslation.md +177 -0
  1021. package/ru/packages/intlayer/getTranslationContent.md +175 -0
  1022. package/ru/packages/intlayer/index.md +275 -0
  1023. package/ru/packages/intlayer-cli/index.md +41 -0
  1024. package/ru/packages/intlayer-editor/index.md +115 -0
  1025. package/ru/packages/lynx-intlayer/index.md +58 -0
  1026. package/ru/packages/next-intlayer/index.md +267 -0
  1027. package/ru/packages/next-intlayer/t.md +340 -0
  1028. package/ru/packages/next-intlayer/useDictionary.md +248 -0
  1029. package/ru/packages/next-intlayer/useIntlayer.md +237 -0
  1030. package/ru/packages/next-intlayer/useIntlayerAsync.md +211 -0
  1031. package/ru/packages/next-intlayer/useLocale.md +105 -0
  1032. package/ru/packages/preact-intlayer/index.md +3 -0
  1033. package/ru/packages/react-intlayer/index.md +261 -0
  1034. package/ru/packages/react-intlayer/t.md +289 -0
  1035. package/ru/packages/react-intlayer/useDictionary.md +268 -0
  1036. package/ru/packages/react-intlayer/useIntlayer.md +225 -0
  1037. package/ru/packages/react-intlayer/useIntlayerAsync.md +226 -0
  1038. package/ru/packages/react-intlayer/useLocale.md +184 -0
  1039. package/ru/packages/react-native-intlayer/index.md +57 -0
  1040. package/ru/packages/react-scripts-intlayer/index.md +57 -0
  1041. package/ru/packages/solid-intlayer/index.md +3 -0
  1042. package/ru/packages/svelte-intlayer/index.md +3 -0
  1043. package/ru/packages/vite-intlayer/index.md +53 -0
  1044. package/ru/packages/vue-intlayer/index.md +3 -0
  1045. package/ru/per_locale_file.md +298 -0
  1046. package/ru/privacy_notice.md +61 -0
  1047. package/ru/roadmap.md +206 -0
  1048. package/ru/terms_of_service.md +33 -0
  1049. package/ru/vs_code_extension.md +139 -0
  1050. package/zh/CI_CD.md +149 -0
  1051. package/zh/autoFill.md +157 -0
  1052. package/zh/configuration.md +484 -0
  1053. package/zh/dictionary/condition.md +213 -0
  1054. package/zh/dictionary/content_extention_customization.md +81 -0
  1055. package/zh/dictionary/enumeration.md +221 -0
  1056. package/zh/dictionary/file.md +209 -0
  1057. package/zh/dictionary/function_fetching.md +188 -0
  1058. package/zh/dictionary/get_started.md +490 -0
  1059. package/zh/dictionary/insertion.md +161 -0
  1060. package/zh/dictionary/markdown.md +342 -0
  1061. package/zh/dictionary/nesting.md +249 -0
  1062. package/zh/dictionary/translation.md +287 -0
  1063. package/zh/header.md +7 -0
  1064. package/zh/how_works_intlayer.md +217 -0
  1065. package/zh/index.md +125 -0
  1066. package/zh/interest_of_intlayer.md +132 -0
  1067. package/zh/intlayer_CMS.md +334 -0
  1068. package/zh/intlayer_cli.md +274 -0
  1069. package/zh/intlayer_visual_editor.md +210 -0
  1070. package/zh/intlayer_with_angular.md +3 -0
  1071. package/zh/intlayer_with_create_react_app.md +1196 -0
  1072. package/zh/intlayer_with_express.md +267 -0
  1073. package/zh/intlayer_with_lynx+react.md +484 -0
  1074. package/zh/intlayer_with_nextjs_14.md +1286 -0
  1075. package/zh/intlayer_with_nextjs_15.md +1322 -0
  1076. package/zh/intlayer_with_nextjs_page_router.md +1097 -0
  1077. package/zh/intlayer_with_react_native+expo.md +539 -0
  1078. package/zh/intlayer_with_vite+preact.md +1681 -0
  1079. package/zh/intlayer_with_vite+react.md +1577 -0
  1080. package/zh/intlayer_with_vite+solid.md +3 -0
  1081. package/zh/intlayer_with_vite+svelte.md +3 -0
  1082. package/zh/intlayer_with_vite+vue.md +988 -0
  1083. package/zh/introduction.md +186 -0
  1084. package/zh/mcp_server.md +152 -0
  1085. package/zh/packages/@intlayer/api/index.md +31 -0
  1086. package/zh/packages/@intlayer/chokidar/index.md +31 -0
  1087. package/zh/packages/@intlayer/cli/index.md +21 -0
  1088. package/zh/packages/@intlayer/config/index.md +116 -0
  1089. package/zh/packages/@intlayer/core/index.md +25 -0
  1090. package/zh/packages/@intlayer/design-system/index.md +21 -0
  1091. package/zh/packages/@intlayer/dictionary-entry/index.md +21 -0
  1092. package/zh/packages/@intlayer/editor/index.md +21 -0
  1093. package/zh/packages/@intlayer/editor-react/index.md +21 -0
  1094. package/zh/packages/@intlayer/webpack/index.md +35 -0
  1095. package/zh/packages/angular-intlayer/index.md +3 -0
  1096. package/zh/packages/express-intlayer/index.md +229 -0
  1097. package/zh/packages/express-intlayer/t.md +432 -0
  1098. package/zh/packages/intlayer/getConfiguration.md +120 -0
  1099. package/zh/packages/intlayer/getEnumeration.md +140 -0
  1100. package/zh/packages/intlayer/getHTMLTextDir.md +97 -0
  1101. package/zh/packages/intlayer/getLocaleLang.md +57 -0
  1102. package/zh/packages/intlayer/getLocaleName.md +93 -0
  1103. package/zh/packages/intlayer/getLocalizedUrl.md +221 -0
  1104. package/zh/packages/intlayer/getMultilingualUrls.md +198 -0
  1105. package/zh/packages/intlayer/getPathWithoutLocale.md +50 -0
  1106. package/zh/packages/intlayer/getTranslation.md +166 -0
  1107. package/zh/packages/intlayer/getTranslationContent.md +166 -0
  1108. package/zh/packages/intlayer/index.md +360 -0
  1109. package/zh/packages/intlayer-cli/index.md +41 -0
  1110. package/zh/packages/intlayer-editor/index.md +113 -0
  1111. package/zh/packages/lynx-intlayer/index.md +60 -0
  1112. package/zh/packages/next-intlayer/index.md +267 -0
  1113. package/zh/packages/next-intlayer/t.md +338 -0
  1114. package/zh/packages/next-intlayer/useDictionary.md +242 -0
  1115. package/zh/packages/next-intlayer/useIntlayer.md +237 -0
  1116. package/zh/packages/next-intlayer/useIntlayerAsync.md +211 -0
  1117. package/zh/packages/next-intlayer/useLocale.md +105 -0
  1118. package/zh/packages/preact-intlayer/index.md +3 -0
  1119. package/zh/packages/react-intlayer/index.md +257 -0
  1120. package/zh/packages/react-intlayer/t.md +271 -0
  1121. package/zh/packages/react-intlayer/useDictionary.md +260 -0
  1122. package/zh/packages/react-intlayer/useIntlayer.md +225 -0
  1123. package/zh/packages/react-intlayer/useIntlayerAsync.md +226 -0
  1124. package/zh/packages/react-intlayer/useLocale.md +184 -0
  1125. package/zh/packages/react-native-intlayer/index.md +57 -0
  1126. package/zh/packages/react-scripts-intlayer/index.md +57 -0
  1127. package/zh/packages/solid-intlayer/index.md +3 -0
  1128. package/zh/packages/svelte-intlayer/index.md +3 -0
  1129. package/zh/packages/vite-intlayer/index.md +53 -0
  1130. package/zh/packages/vue-intlayer/index.md +3 -0
  1131. package/zh/per_locale_file.md +298 -0
  1132. package/zh/privacy_notice.md +61 -0
  1133. package/zh/roadmap.md +206 -0
  1134. package/zh/terms_of_service.md +33 -0
  1135. package/zh/vs_code_extension.md +139 -0
@@ -0,0 +1,1605 @@
1
+ # Getting Started Internationalizing (i18n) with Intlayer and Vite and React
2
+
3
+ See [Application Template](https://github.com/aymericzip/intlayer-vite-react-template) on GitHub.
4
+
5
+ ## What is Intlayer?
6
+
7
+ **Intlayer** is an innovative, open-source internationalization (i18n) library designed to simplify multilingual support in modern web applications.
8
+
9
+ With Intlayer, you can:
10
+
11
+ - **Easily manage translations** using declarative dictionaries at the component level.
12
+ - **Dynamically localize metadata**, routes, and content.
13
+ - **Ensure TypeScript support** with autogenerated types, improving autocompletion and error detection.
14
+ - **Benefit from advanced features**, like dynamic locale detection and switching.
15
+
16
+ ---
17
+
18
+ ## Step-by-Step Guide to Set Up Intlayer in a Vite and React Application
19
+
20
+ ### Step 1: Install Dependencies
21
+
22
+ Install the necessary packages using npm:
23
+
24
+ ```bash packageManager="npm"
25
+ npm install intlayer react-intlayer vite-intlayer
26
+ ```
27
+
28
+ ```bash packageManager="pnpm"
29
+ pnpm add intlayer react-intlayer vite-intlayer
30
+ ```
31
+
32
+ ```bash packageManager="yarn"
33
+ yarn add intlayer react-intlayer vite-intlayer
34
+ ```
35
+
36
+ - **intlayer**
37
+
38
+ The core package that provides internationalization tools for configuration management, translation, [content declaration](https://github.com/aymericzip/intlayer/blob/main/docs/en/dictionary/get_started.md), transpilation, and [CLI commands](https://github.com/aymericzip/intlayer/blob/main/docs/en/intlayer_cli.md).
39
+
40
+ - **react-intlayer**
41
+ The package that integrates Intlayer with React application. It provides context providers and hooks for React internationalization.
42
+
43
+ - **vite-intlayer**
44
+ Includes the Vite plugin for integrating Intlayer with the [Vite bundler](https://vite.dev/guide/why.html#why-bundle-for-production), as well as middleware for detecting the user's preferred locale, managing cookies, and handling URL redirection.
45
+
46
+ ### Step 2: Configuration of your project
47
+
48
+ Create a config file to configure the languages of your application:
49
+
50
+ ```typescript fileName="intlayer.config.ts" codeFormat="typescript"
51
+ import { Locales, type IntlayerConfig } from "intlayer";
52
+
53
+ const config: IntlayerConfig = {
54
+ internationalization: {
55
+ locales: [
56
+ Locales.ENGLISH,
57
+ Locales.FRENCH,
58
+ Locales.SPANISH,
59
+ // Your other locales
60
+ ],
61
+ defaultLocale: Locales.ENGLISH,
62
+ },
63
+ };
64
+
65
+ export default config;
66
+ ```
67
+
68
+ ```javascript fileName="intlayer.config.mjs" codeFormat="esm"
69
+ import { Locales } from "intlayer";
70
+
71
+ /** @type {import('intlayer').IntlayerConfig} */
72
+ const config = {
73
+ internationalization: {
74
+ locales: [
75
+ Locales.ENGLISH,
76
+ Locales.FRENCH,
77
+ Locales.SPANISH,
78
+ // Your other locales
79
+ ],
80
+ defaultLocale: Locales.ENGLISH,
81
+ },
82
+ };
83
+
84
+ export default config;
85
+ ```
86
+
87
+ ```javascript fileName="intlayer.config.cjs" codeFormat="commonjs"
88
+ const { Locales } = require("intlayer");
89
+
90
+ /** @type {import('intlayer').IntlayerConfig} */
91
+ const config = {
92
+ internationalization: {
93
+ locales: [
94
+ Locales.ENGLISH,
95
+ Locales.FRENCH,
96
+ Locales.SPANISH,
97
+ // Your other locales
98
+ ],
99
+ defaultLocale: Locales.ENGLISH,
100
+ },
101
+ };
102
+
103
+ module.exports = config;
104
+ ```
105
+
106
+ > Through this configuration file, you can set up localized URLs, middleware redirection, cookie names, the location and extension of your content declarations, disable Intlayer logs in the console, and more. For a complete list of available parameters, refer to the [configuration documentation](https://github.com/aymericzip/intlayer/blob/main/docs/en/configuration.md).
107
+
108
+ ### Step 3: Integrate Intlayer in Your Vite Configuration
109
+
110
+ Add the intlayer plugin into your configuration.
111
+
112
+ ```typescript fileName="vite.config.ts" codeFormat="typescript"
113
+ import { defineConfig } from "vite";
114
+ import react from "@vitejs/plugin-react-swc";
115
+ import { intlayerPlugin } from "vite-intlayer";
116
+
117
+ // https://vitejs.dev/config/
118
+ export default defineConfig({
119
+ plugins: [react(), intlayerPlugin()],
120
+ });
121
+ ```
122
+
123
+ ```javascript fileName="vite.config.mjs" codeFormat="esm"
124
+ import { defineConfig } from "vite";
125
+ import react from "@vitejs/plugin-react-swc";
126
+ import { intlayerPlugin } from "vite-intlayer";
127
+
128
+ // https://vitejs.dev/config/
129
+ export default defineConfig({
130
+ plugins: [react(), intlayerPlugin()],
131
+ });
132
+ ```
133
+
134
+ ```javascript fileName="vite.config.cjs" codeFormat="commonjs"
135
+ const { defineConfig } = require("vite");
136
+ const react = require("@vitejs/plugin-react-swc");
137
+ const { intlayerPlugin } = require("vite-intlayer");
138
+
139
+ // https://vitejs.dev/config/
140
+ module.exports = defineConfig({
141
+ plugins: [react(), intlayerPlugin()],
142
+ });
143
+ ```
144
+
145
+ > The `intlayerPlugin()` Vite plugin is used to integrate Intlayer with Vite. It ensures the building of content declaration files and monitors them in development mode. It defines Intlayer environment variables within the Vite application. Additionally, it provides aliases to optimize performance.
146
+
147
+ ### Step 4: Declare Your Content
148
+
149
+ Create and manage your content declarations to store translations:
150
+
151
+ ```tsx fileName="src/app.content.tsx" contentDeclarationFormat="typescript"
152
+ import { t, type Dictionary } from "intlayer";
153
+ import type { ReactNode } from "react";
154
+
155
+ const appContent = {
156
+ key: "app",
157
+ content: {
158
+ viteLogo: t({
159
+ en: "Vite logo",
160
+ fr: "Logo Vite",
161
+ es: "Logo Vite",
162
+ }),
163
+ reactLogo: t({
164
+ en: "React logo",
165
+ fr: "Logo React",
166
+ es: "Logo React",
167
+ }),
168
+
169
+ title: "Vite + React",
170
+
171
+ count: t({
172
+ en: "count is ",
173
+ fr: "le compte est ",
174
+ es: "el recuento es ",
175
+ }),
176
+
177
+ edit: t<ReactNode>({
178
+ en: (
179
+ <>
180
+ Edit <code>src/App.tsx</code> and save to test HMR
181
+ </>
182
+ ),
183
+ fr: (
184
+ <>
185
+ Éditez <code>src/App.tsx</code> et enregistrez pour tester HMR
186
+ </>
187
+ ),
188
+ es: (
189
+ <>
190
+ Edita <code>src/App.tsx</code> y guarda para probar HMR
191
+ </>
192
+ ),
193
+ }),
194
+
195
+ readTheDocs: t({
196
+ en: "Click on the Vite and React logos to learn more",
197
+ fr: "Cliquez sur les logos Vite et React pour en savoir plus",
198
+ es: "Haga clic en los logotipos de Vite y React para obtener más información",
199
+ }),
200
+ },
201
+ } satisfies Dictionary;
202
+
203
+ export default appContent;
204
+ ```
205
+
206
+ ```javascript fileName="src/app.content.mjs" contentDeclarationFormat="esm"
207
+ import { t } from "intlayer";
208
+
209
+ /** @type {import('intlayer').Dictionary} */
210
+ const appContent = {
211
+ key: "app",
212
+ content: {
213
+ viteLogo: t({
214
+ en: "Vite logo",
215
+ fr: "Logo Vite",
216
+ es: "Logo Vite",
217
+ }),
218
+ reactLogo: t({
219
+ en: "React logo",
220
+ fr: "Logo React",
221
+ es: "Logo React",
222
+ }),
223
+
224
+ title: "Vite + React",
225
+
226
+ count: t({
227
+ en: "count is ",
228
+ fr: "le compte est ",
229
+ es: "el recuento es ",
230
+ }),
231
+
232
+ edit:
233
+ t <
234
+ ReactNode >
235
+ {
236
+ // N'oubliez pas d'importer React si vous utilisez un React node dans votre contenu
237
+ en: (
238
+ <>
239
+ Edit <code>src/App.tsx</code> and save to test HMR
240
+ </>
241
+ ),
242
+ fr: (
243
+ <>
244
+ Éditez <code>src/App.tsx</code> et enregistrez pour tester HMR
245
+ </>
246
+ ),
247
+ es: (
248
+ <>
249
+ Edita <code>src/App.tsx</code> y guarda para probar HMR
250
+ </>
251
+ ),
252
+ },
253
+
254
+ readTheDocs: t({
255
+ en: "Click on the Vite and React logos to learn more",
256
+ fr: "Cliquez sur les logos Vite et React pour en savoir plus",
257
+ es: "Haga clic en los logotipos de Vite y React para obtener más información",
258
+ }),
259
+ },
260
+ };
261
+
262
+ export default appContent;
263
+ ```
264
+
265
+ ```javascript fileName="src/app.content.cjs" contentDeclarationFormat="commonjs"
266
+ const { t } = require("intlayer");
267
+
268
+ /** @type {import('intlayer').Dictionary} */
269
+ const appContent = {
270
+ key: "app",
271
+ content: {
272
+ viteLogo: t({
273
+ en: "Vite logo",
274
+ fr: "Logo Vite",
275
+ es: "Logo Vite",
276
+ }),
277
+ reactLogo: t({
278
+ en: "React logo",
279
+ fr: "Logo React",
280
+ es: "Logo React",
281
+ }),
282
+
283
+ title: "Vite + React",
284
+
285
+ count: t({
286
+ en: "count is ",
287
+ fr: "le compte est ",
288
+ es: "el recuento es ",
289
+ }),
290
+
291
+ edit:
292
+ t <
293
+ ReactNode >
294
+ {
295
+ // N'oubliez pas d'importer React si vous utilisez un React node dans votre contenu
296
+ en: (
297
+ <>
298
+ Edit <code>src/App.tsx</code> and save to test HMR
299
+ </>
300
+ ),
301
+ fr: (
302
+ <>
303
+ Éditez <code>src/App.tsx</code> et enregistrez pour tester HMR
304
+ </>
305
+ ),
306
+ es: (
307
+ <>
308
+ Edita <code>src/App.tsx</code> y guarda para probar HMR
309
+ </>
310
+ ),
311
+ },
312
+
313
+ readTheDocs: t({
314
+ en: "Click on the Vite and React logos to learn more",
315
+ fr: "Cliquez sur les logos Vite et React pour en savoir plus",
316
+ es: "Haga clic en los logotipos de Vite y React para obtener más información",
317
+ }),
318
+ },
319
+ };
320
+
321
+ module.exports = appContent;
322
+ ```
323
+
324
+ ```json fileName="src/app.content.json" contentDeclarationFormat="json"
325
+ {
326
+ "$schema": "https://intlayer.org/schema.json",
327
+ "key": "app",
328
+ "content": {
329
+ "viteLogo": {
330
+ "nodeType": "translation",
331
+ "translation": {
332
+ "en": "Vite logo",
333
+ "fr": "Logo Vite",
334
+ "es": "Logo Vite"
335
+ }
336
+ },
337
+ "reactLogo": {
338
+ "nodeType": "translation",
339
+ "translation": {
340
+ "en": "React logo",
341
+ "fr": "Logo React",
342
+ "es": "Logo React"
343
+ }
344
+ },
345
+ "title": {
346
+ "nodeType": "translation",
347
+ "translation": {
348
+ "en": "Vite + React",
349
+ "fr": "Vite + React",
350
+ "es": "Vite + React"
351
+ }
352
+ },
353
+ "count": {
354
+ "nodeType": "translation",
355
+ "translation": {
356
+ "en": "count is ",
357
+ "fr": "le compte est ",
358
+ "es": "el recuento es "
359
+ }
360
+ },
361
+ "edit": {
362
+ "nodeType": "translation",
363
+ "translation": {
364
+ "en": "Edit src/App.tsx and save to test HMR",
365
+ "fr": "Éditez src/App.tsx et enregistrez pour tester HMR",
366
+ "es": "Edita src/App.tsx y guarda para probar HMR"
367
+ }
368
+ },
369
+ "readTheDocs": {
370
+ "nodeType": "translation",
371
+ "translation": {
372
+ "en": "Click on the Vite and React logos to learn more",
373
+ "fr": "Cliquez sur les logos Vite et React pour en savoir plus",
374
+ "es": "Haga clic en los logotipos de Vite y React para obtener más información"
375
+ }
376
+ }
377
+ }
378
+ }
379
+ ```
380
+
381
+ > Your content declarations can be defined anywhere in your application as soon they are included into the `contentDir` directory (by default, `./src`). And match the content declaration file extension (by default, `.content.{json,ts,tsx,js,jsx,mjs,mjx,cjs,cjx}`).
382
+
383
+ > For more details, refer to the [content declaration documentation](https://github.com/aymericzip/intlayer/blob/main/docs/en/dictionary/get_started.md).
384
+
385
+ > If your content file includes TSX code, you should consider importing `import React from "react";` in your content file.
386
+
387
+ ### Step 5: Utilize Intlayer in Your Code
388
+
389
+ Access your content dictionaries throughout your application:
390
+
391
+ ```tsx {5,9} fileName="src/App.tsx" codeFormat="typescript"
392
+ import { useState, type FC } from "react";
393
+ import reactLogo from "./assets/react.svg";
394
+ import viteLogo from "/vite.svg";
395
+ import "./App.css";
396
+ import { IntlayerProvider, useIntlayer } from "react-intlayer";
397
+
398
+ const AppContent: FC = () => {
399
+ const [count, setCount] = useState(0);
400
+ const content = useIntlayer("app");
401
+
402
+ return (
403
+ <>
404
+ <div>
405
+ <a href="https://vitejs.dev" target="_blank">
406
+ <img src={viteLogo} className="logo" alt={content.viteLogo.value} />
407
+ </a>
408
+ <a href="https://react.dev" target="_blank">
409
+ <img
410
+ src={reactLogo}
411
+ className="logo react"
412
+ alt={content.reactLogo.value}
413
+ />
414
+ </a>
415
+ </div>
416
+ <h1>{content.title}</h1>
417
+ <div className="card">
418
+ <button onClick={() => setCount((count) => count + 1)}>
419
+ {content.count}
420
+ {count}
421
+ </button>
422
+ <p>{content.edit}</p>
423
+ </div>
424
+ <p className="read-the-docs">{content.readTheDocs}</p>
425
+ </>
426
+ );
427
+ };
428
+
429
+ const App: FC = () => (
430
+ <IntlayerProvider>
431
+ <AppContent />
432
+ </IntlayerProvider>
433
+ );
434
+
435
+ export default App;
436
+ ```
437
+
438
+ ```tsx {5,9} fileName="src/App.msx" codeFormat="esm"
439
+ import { useState } from "react";
440
+ import reactLogo from "./assets/react.svg";
441
+ import viteLogo from "/vite.svg";
442
+ import "./App.css";
443
+ import { IntlayerProvider, useIntlayer } from "react-intlayer";
444
+
445
+ const AppContent = () => {
446
+ const [count, setCount] = useState(0);
447
+ const content = useIntlayer("app");
448
+
449
+ return (
450
+ <>
451
+ <div>
452
+ <a href="https://vitejs.dev" target="_blank">
453
+ <img src={viteLogo} className="logo" alt={content.viteLogo.value} />
454
+ </a>
455
+ <a href="https://react.dev" target="_blank">
456
+ <img
457
+ src={reactLogo}
458
+ className="logo react"
459
+ alt={content.reactLogo.value}
460
+ />
461
+ </a>
462
+ </div>
463
+ <h1>{content.title}</h1>
464
+ <div className="card">
465
+ <button onClick={() => setCount((count) => count + 1)}>
466
+ {content.count}
467
+ {count}
468
+ </button>
469
+ <p>{content.edit}</p>
470
+ </div>
471
+ <p className="read-the-docs">{content.readTheDocs}</p>
472
+ </>
473
+ );
474
+ };
475
+
476
+ const App = () => (
477
+ <IntlayerProvider>
478
+ <AppContent />
479
+ </IntlayerProvider>
480
+ );
481
+
482
+ export default App;
483
+ ```
484
+
485
+ ```tsx {5,9} fileName="src/App.csx" codeFormat="commonjs"
486
+ const { useState } = require("react");
487
+ const reactLogo = require("./assets/react.svg");
488
+ const viteLogo = require("/vite.svg");
489
+ require("./App.css");
490
+ const { IntlayerProvider, useIntlayer } = require("react-intlayer");
491
+
492
+ const AppContent = () => {
493
+ const [count, setCount] = useState(0);
494
+ const content = useIntlayer("app");
495
+
496
+ return (
497
+ <>
498
+ <div>
499
+ <a href="https://vitejs.dev" target="_blank">
500
+ <img src={viteLogo} className="logo" alt={content.viteLogo.value} />
501
+ </a>
502
+ <a href="https://react.dev" target="_blank">
503
+ <img
504
+ src={reactLogo}
505
+ className="logo react"
506
+ alt={content.reactLogo.value}
507
+ />
508
+ </a>
509
+ </div>
510
+ <h1>{content.title}</h1>
511
+ <div className="card">
512
+ <button onClick={() => setCount((count) => count + 1)}>
513
+ {content.count}
514
+ {count}
515
+ </button>
516
+ <p>{content.edit}</p>
517
+ </div>
518
+ <p className="read-the-docs">{content.readTheDocs}</p>
519
+ </>
520
+ );
521
+ };
522
+
523
+ const App = () => (
524
+ <IntlayerProvider>
525
+ <AppContent />
526
+ </IntlayerProvider>
527
+ );
528
+
529
+ module.exports = App;
530
+ ```
531
+
532
+ > If you want to use your content in a `string` attribute, such as `alt`, `title`, `href`, `aria-label`, etc., you must call the value of the function, like:
533
+
534
+ > ```jsx
535
+ >
536
+ > ```
537
+
538
+ > <img src={content.image.src.value} alt={content.image.value} />
539
+
540
+ > ```
541
+ >
542
+ > ```
543
+
544
+ > To Learn more about the `useIntlayer` hook, refer to the [documentation](https://github.com/aymericzip/intlayer/blob/main/docs/en/packages/react-intlayer/useIntlayer.md).
545
+
546
+ ### (Optional) Step 6: Change the language of your content
547
+
548
+ To change the language of your content, you can use the `setLocale` function provided by the `useLocale` hook. This function allows you to set the locale of the application and update the content accordingly.
549
+
550
+ ```tsx fileName="src/components/LocaleSwitcher.tsx" codeFormat="typescript"
551
+ import type { FC } from "react";
552
+ import { Locales } from "intlayer";
553
+ import { useLocale } from "react-intlayer";
554
+
555
+ const LocaleSwitcher: FC = () => {
556
+ const { setLocale } = useLocale();
557
+
558
+ return (
559
+ <button onClick={() => setLocale(Locales.English)}>
560
+ Change Language to English
561
+ </button>
562
+ );
563
+ };
564
+ ```
565
+
566
+ ```jsx fileName="src/components/LocaleSwitcher.msx" codeFormat="esm"
567
+ import { Locales } from "intlayer";
568
+ import { useLocale } from "react-intlayer";
569
+
570
+ const LocaleSwitcher = () => {
571
+ const { setLocale } = useLocale();
572
+
573
+ return (
574
+ <button onClick={() => setLocale(Locales.English)}>
575
+ Change Language to English
576
+ </button>
577
+ );
578
+ };
579
+ ```
580
+
581
+ ```jsx fileName="src/components/LocaleSwitcher.csx" codeFormat="commonjs"
582
+ const { Locales } = require("intlayer");
583
+ const { useLocale } = require("react-intlayer");
584
+
585
+ const LocaleSwitcher = () => {
586
+ const { setLocale } = useLocale();
587
+
588
+ return (
589
+ <button onClick={() => setLocale(Locales.English)}>
590
+ Change Language to English
591
+ </button>
592
+ );
593
+ };
594
+ ```
595
+
596
+ > To Learn more about the `useLocale` hook, refer to the [documentation](https://github.com/aymericzip/intlayer/blob/main/docs/en/packages/react-intlayer/useLocale.md).
597
+
598
+ ### (Optional) Step 7: Add localized Routing to your application
599
+
600
+ The purpose of this step is to make unique routes for each language. This is useful for SEO and SEO-friendly URLs.
601
+ Example:
602
+
603
+ ```plaintext
604
+ - https://example.com/about
605
+ - https://example.com/es/about
606
+ - https://example.com/fr/about
607
+ ```
608
+
609
+ > By default, the routes are not prefixed for the default locale. If you want to prefix the default locale, you can set the `middleware.prefixDefault` option to `true` in your configuration. See the [configuration documentation](https://github.com/aymericzip/intlayer/blob/main/docs/en/configuration.md) for more information.
610
+
611
+ To add localized routing to your application, you can create a `LocaleRouter` component that wraps your application's routes and handles locale-based routing. Here is an example using [React Router](https://reactrouter.com/home):
612
+
613
+ ```tsx fileName="src/components/LocaleRouter.tsx" codeFormat="typescript"
614
+ // Importing necessary dependencies and functions
615
+ import { type Locales, configuration, getPathWithoutLocale } from "intlayer"; // Utility functions and types from 'intlayer'
616
+ import type { FC, PropsWithChildren } from "react"; // React types for functional components and props
617
+ import { IntlayerProvider } from "react-intlayer"; // Provider for internationalization context
618
+ import {
619
+ BrowserRouter,
620
+ Routes,
621
+ Route,
622
+ Navigate,
623
+ useLocation,
624
+ } from "react-router-dom"; // Router components for managing navigation
625
+
626
+ // Destructuring configuration from Intlayer
627
+ const { internationalization, middleware } = configuration;
628
+ const { locales, defaultLocale } = internationalization;
629
+
630
+ /**
631
+ * A component that handles localization and wraps children with the appropriate locale context.
632
+ * It manages URL-based locale detection and validation.
633
+ */
634
+ const AppLocalized: FC<PropsWithChildren<{ locale: Locales }>> = ({
635
+ children,
636
+ locale,
637
+ }) => {
638
+ const { pathname, search } = useLocation(); // Get the current URL path
639
+
640
+ // Determine the current locale, falling back to the default if not provided
641
+ const currentLocale = locale ?? defaultLocale;
642
+
643
+ // Remove the locale prefix from the path to construct a base path
644
+ const pathWithoutLocale = getPathWithoutLocale(
645
+ pathname // Current URL path
646
+ );
647
+
648
+ /**
649
+ * If middleware.prefixDefault is true, the default locale should always be prefixed.
650
+ */
651
+ if (middleware.prefixDefault) {
652
+ // Validate the locale
653
+ if (!locale || !locales.includes(locale)) {
654
+ // Redirect to the default locale with the updated path
655
+ return (
656
+ <Navigate
657
+ to={`/${defaultLocale}/${pathWithoutLocale}${search}`}
658
+ replace // Replace the current history entry with the new one
659
+ />
660
+ );
661
+ }
662
+
663
+ // Wrap children with the IntlayerProvider and set the current locale
664
+ return (
665
+ <IntlayerProvider locale={currentLocale}>{children}</IntlayerProvider>
666
+ );
667
+ } else {
668
+ /**
669
+ * When middleware.prefixDefault is false, the default locale is not prefixed.
670
+ * Ensure that the current locale is valid and not the default locale.
671
+ */
672
+ if (
673
+ currentLocale.toString() !== defaultLocale.toString() &&
674
+ !locales
675
+ .filter(
676
+ (locale) => locale.toString() !== defaultLocale.toString() // Exclude the default locale
677
+ )
678
+ .includes(currentLocale) // Check if the current locale is in the list of valid locales
679
+ ) {
680
+ // Redirect to the path without locale prefix
681
+ return <Navigate to={`${pathWithoutLocale}${search}`} replace />;
682
+ }
683
+
684
+ // Wrap children with the IntlayerProvider and set the current locale
685
+ return (
686
+ <IntlayerProvider locale={currentLocale}>{children}</IntlayerProvider>
687
+ );
688
+ }
689
+ };
690
+
691
+ /**
692
+ * A router component that sets up locale-specific routes.
693
+ * It uses React Router to manage navigation and render localized components.
694
+ */
695
+ export const LocaleRouter: FC<PropsWithChildren> = ({ children }) => (
696
+ <BrowserRouter>
697
+ <Routes>
698
+ {locales
699
+ .filter(
700
+ (locale) => middleware.prefixDefault || locale !== defaultLocale
701
+ )
702
+ .map((locale) => (
703
+ <Route
704
+ // Route pattern to capture the locale (e.g., /en/, /fr/) and match all subsequent paths
705
+ path={`/${locale}/*`}
706
+ key={locale}
707
+ element={<AppLocalized locale={locale}>{children}</AppLocalized>} // Wraps children with locale management
708
+ />
709
+ ))}
710
+
711
+ {
712
+ // If prefixing the default locale is disabled, render the children directly at the root path
713
+ !middleware.prefixDefault && (
714
+ <Route
715
+ path="*"
716
+ element={
717
+ <AppLocalized locale={defaultLocale}>{children}</AppLocalized>
718
+ } // Wraps children with locale management
719
+ />
720
+ )
721
+ }
722
+ </Routes>
723
+ </BrowserRouter>
724
+ );
725
+ ```
726
+
727
+ ```jsx fileName="src/components/LocaleRouter.mjx" codeFormat="esm"
728
+ // Importing necessary dependencies and functions
729
+ import { configuration, getPathWithoutLocale } from "intlayer"; // Utility functions and types from 'intlayer'
730
+ // Utility functions and types from 'intlayer'
731
+ import { IntlayerProvider } from "react-intlayer"; // Provider for internationalization context
732
+ import {
733
+ BrowserRouter,
734
+ Routes,
735
+ Route,
736
+ Navigate,
737
+ useLocation,
738
+ } from "react-router-dom"; // Router components for managing navigation
739
+
740
+ // Destructuring configuration from Intlayer
741
+ const { internationalization, middleware } = configuration;
742
+ const { locales, defaultLocale } = internationalization;
743
+
744
+ /**
745
+ * A component that handles localization and wraps children with the appropriate locale context.
746
+ * It manages URL-based locale detection and validation.
747
+ */
748
+ const AppLocalized = ({ children, locale }) => {
749
+ const { pathname, search } = useLocation(); // Get the current URL path
750
+
751
+ // Determine the current locale, falling back to the default if not provided
752
+ const currentLocale = locale ?? defaultLocale;
753
+
754
+ // Remove the locale prefix from the path to construct a base path
755
+ const pathWithoutLocale = getPathWithoutLocale(
756
+ pathname // Current URL path
757
+ );
758
+
759
+ /**
760
+ * If middleware.prefixDefault is true, the default locale should always be prefixed.
761
+ */
762
+ if (middleware.prefixDefault) {
763
+ // Validate the locale
764
+ if (!locale || !locales.includes(locale)) {
765
+ // Redirect to the default locale with the updated path
766
+ return (
767
+ <Navigate
768
+ to={`/${defaultLocale}/${pathWithoutLocale}${search}`}
769
+ replace // Replace the current history entry with the new one
770
+ />
771
+ );
772
+ }
773
+
774
+ // Wrap children with the IntlayerProvider and set the current locale
775
+ return (
776
+ <IntlayerProvider locale={currentLocale}>{children}</IntlayerProvider>
777
+ );
778
+ } else {
779
+ /**
780
+ * When middleware.prefixDefault is false, the default locale is not prefixed.
781
+ * Ensure that the current locale is valid and not the default locale.
782
+ */
783
+ if (
784
+ currentLocale.toString() !== defaultLocale.toString() &&
785
+ !locales
786
+ .filter(
787
+ (locale) => locale.toString() !== defaultLocale.toString() // Exclude the default locale
788
+ )
789
+ .includes(currentLocale) // Check if the current locale is in the list of valid locales
790
+ ) {
791
+ // Redirect to the path without locale prefix
792
+ return <Navigate to={`${pathWithoutLocale}${search}`} replace />;
793
+ }
794
+
795
+ // Wrap children with the IntlayerProvider and set the current locale
796
+ return (
797
+ <IntlayerProvider locale={currentLocale}>{children}</IntlayerProvider>
798
+ );
799
+ }
800
+ };
801
+
802
+ /**
803
+ * A router component that sets up locale-specific routes.
804
+ * It uses React Router to manage navigation and render localized components.
805
+ */
806
+ export const LocaleRouter = ({ children }) => (
807
+ <BrowserRouter>
808
+ <Routes>
809
+ {locales
810
+ .filter(
811
+ (locale) => middleware.prefixDefault || locale !== defaultLocale
812
+ )
813
+ .map((locale) => (
814
+ <Route
815
+ // Route pattern to capture the locale (e.g., /en/, /fr/) and match all subsequent paths
816
+ path={`/${locale}/*`}
817
+ key={locale}
818
+ element={<AppLocalized locale={locale}>{children}</AppLocalized>} // Wraps children with locale management
819
+ />
820
+ ))}
821
+
822
+ {
823
+ // If prefixing the default locale is disabled, render the children directly at the root path
824
+ !middleware.prefixDefault && (
825
+ <Route
826
+ path="*"
827
+ element={
828
+ <AppLocalized locale={defaultLocale}>{children}</AppLocalized>
829
+ } // Wraps children with locale management
830
+ />
831
+ )
832
+ }
833
+ </Routes>
834
+ </BrowserRouter>
835
+ );
836
+ ```
837
+
838
+ ```jsx fileName="src/components/LocaleRouter.cjx" codeFormat="commonjs"
839
+ // Importing necessary dependencies and functions
840
+ const { configuration, getPathWithoutLocale } = require("intlayer"); // Utility functions and types from 'intlayer'
841
+ const { IntlayerProvider, useLocale } = require("react-intlayer"); // Provider for internationalization context
842
+ const {
843
+ BrowserRouter,
844
+ Routes,
845
+ Route,
846
+ Navigate,
847
+ useLocation,
848
+ } = require("react-router-dom"); // Router components for managing navigation
849
+
850
+ // Destructuring configuration from Intlayer
851
+ const { internationalization, middleware } = configuration;
852
+ const { locales, defaultLocale } = internationalization;
853
+
854
+ /**
855
+ * A component that handles localization and wraps children with the appropriate locale context.
856
+ * It manages URL-based locale detection and validation.
857
+ */
858
+ const AppLocalized = ({ children, locale }) => {
859
+ const { pathname, search } = useLocation(); // Get the current URL path
860
+
861
+ // Determine the current locale, falling back to the default if not provided
862
+ const currentLocale = locale ?? defaultLocale;
863
+
864
+ // Remove the locale prefix from the path to construct a base path
865
+ const pathWithoutLocale = getPathWithoutLocale(
866
+ pathname // Current URL path
867
+ );
868
+
869
+ /**
870
+ * If middleware.prefixDefault is true, the default locale should always be prefixed.
871
+ */
872
+ if (middleware.prefixDefault) {
873
+ // Validate the locale
874
+ if (!locale || !locales.includes(locale)) {
875
+ // Redirect to the default locale with the updated path
876
+ return (
877
+ <Navigate
878
+ to={`/${defaultLocale}/${pathWithoutLocale}${search}`}
879
+ replace // Replace the current history entry with the new one
880
+ />
881
+ );
882
+ }
883
+
884
+ // Wrap children with the IntlayerProvider and set the current locale
885
+ return (
886
+ <IntlayerProvider locale={currentLocale}>{children}</IntlayerProvider>
887
+ );
888
+ } else {
889
+ /**
890
+ * When middleware.prefixDefault is false, the default locale is not prefixed.
891
+ * Ensure that the current locale is valid and not the default locale.
892
+ */
893
+ if (
894
+ currentLocale.toString() !== defaultLocale.toString() &&
895
+ !locales
896
+ .filter(
897
+ (locale) => locale.toString() !== defaultLocale.toString() // Exclude the default locale
898
+ )
899
+ .includes(currentLocale) // Check if the current locale is in the list of valid locales
900
+ ) {
901
+ // Redirect to the path without locale prefix
902
+ return <Navigate to={`${pathWithoutLocale}${search}`} replace />;
903
+ }
904
+
905
+ // Wrap children with the IntlayerProvider and set the current locale
906
+ return (
907
+ <IntlayerProvider locale={currentLocale}>{children}</IntlayerProvider>
908
+ );
909
+ }
910
+ };
911
+
912
+ /**
913
+ * A router component that sets up locale-specific routes.
914
+ * It uses React Router to manage navigation and render localized components.
915
+ */
916
+ const LocaleRouter = ({ children }) => (
917
+ <BrowserRouter>
918
+ <Routes>
919
+ {locales
920
+ .filter(
921
+ (locale) => middleware.prefixDefault || locale !== defaultLocale
922
+ )
923
+ .map((locale) => (
924
+ <Route
925
+ // Route pattern to capture the locale (e.g., /en/, /fr/) and match all subsequent paths
926
+ path={`/${locale}/*`}
927
+ key={locale}
928
+ element={<AppLocalized locale={locale}>{children}</AppLocalized>} // Wraps children with locale management
929
+ />
930
+ ))}
931
+
932
+ {
933
+ // If prefixing the default locale is disabled, render the children directly at the root path
934
+ !middleware.prefixDefault && (
935
+ <Route
936
+ path="*"
937
+ element={
938
+ <AppLocalized locale={defaultLocale}>{children}</AppLocalized>
939
+ } // Wraps children with locale management
940
+ />
941
+ )
942
+ }
943
+ </Routes>
944
+ </BrowserRouter>
945
+ );
946
+ ```
947
+
948
+ Then, you can use the `LocaleRouter` component in your application:
949
+
950
+ ```tsx fileName="src/App.tsx" codeFormat="typescript"
951
+ import { LocaleRouter } from "./components/LocaleRouter";
952
+ import type { FC } from "react";
953
+
954
+ // ... Your AppContent component
955
+
956
+ const App: FC = () => (
957
+ <LocaleRouter>
958
+ <AppContent />
959
+ </LocaleRouter>
960
+ );
961
+ ```
962
+
963
+ ```jsx fileName="src/App.mjx" codeFormat="esm"
964
+ import { LocaleRouter } from "./components/LocaleRouter";
965
+
966
+ // ... Your AppContent component
967
+
968
+ const App = () => (
969
+ <LocaleRouter>
970
+ <AppContent />
971
+ </LocaleRouter>
972
+ );
973
+ ```
974
+
975
+ ```jsx fileName="src/App.cjx" codeFormat="commonjs"
976
+ const { LocaleRouter } = require("./components/LocaleRouter");
977
+
978
+ // ... Your AppContent component
979
+
980
+ const App = () => (
981
+ <LocaleRouter>
982
+ <AppContent />
983
+ </LocaleRouter>
984
+ );
985
+ ```
986
+
987
+ In parallel, you can also use the `intLayerMiddlewarePlugin` to add server-side routing to your application. This plugin will automatically detect the current locale based on the URL and set the appropriate locale cookie. If no locale is specified, the plugin will determine the most appropriate locale based on the user's browser language preferences. If no locale is detected, it will redirect to the default locale.
988
+
989
+ ```typescript {3,7} fileName="vite.config.ts" codeFormat="typescript"
990
+ import { defineConfig } from "vite";
991
+ import react from "@vitejs/plugin-react-swc";
992
+ import { intlayerPlugin, intLayerMiddlewarePlugin } from "vite-intlayer";
993
+
994
+ // https://vitejs.dev/config/
995
+ export default defineConfig({
996
+ plugins: [react(), intlayerPlugin(), intLayerMiddlewarePlugin()],
997
+ });
998
+ ```
999
+
1000
+ ```javascript {3,7} fileName="vite.config.mjs" codeFormat="esm"
1001
+ import { defineConfig } from "vite";
1002
+ import react from "@vitejs/plugin-react-swc";
1003
+ import { intlayerPlugin, intLayerMiddlewarePlugin } from "vite-intlayer";
1004
+
1005
+ // https://vitejs.dev/config/
1006
+ export default defineConfig({
1007
+ plugins: [react(), intlayerPlugin(), intLayerMiddlewarePlugin()],
1008
+ });
1009
+ ```
1010
+
1011
+ ```javascript {3,7} fileName="vite.config.cjs" codeFormat="commonjs"
1012
+ const { defineConfig } = require("vite");
1013
+ const react = require("@vitejs/plugin-react-swc");
1014
+ const { intlayerPlugin, intLayerMiddlewarePlugin } = require("vite-intlayer");
1015
+
1016
+ // https://vitejs.dev/config/
1017
+ module.exports = defineConfig({
1018
+ plugins: [react(), intlayerPlugin(), intLayerMiddlewarePlugin()],
1019
+ });
1020
+ ```
1021
+
1022
+ ### (Optional) Step 8: Change the URL when the locale changes
1023
+
1024
+ To change the URL when the locale changes, you can use the `onLocaleChange` prop provided by the `useLocale` hook. In parallel, you can use the `useLocation` and `useNavigate` hooks from `react-router-dom` to update the URL path.
1025
+
1026
+ ```tsx fileName="src/components/LocaleSwitcher.tsx" codeFormat="typescript"
1027
+ import { useLocation, useNavigate } from "react-router-dom";
1028
+ import {
1029
+ Locales,
1030
+ getHTMLTextDir,
1031
+ getLocaleName,
1032
+ getLocalizedUrl,
1033
+ } from "intlayer";
1034
+ import { useLocale } from "react-intlayer";
1035
+ import { type FC } from "react";
1036
+
1037
+ const LocaleSwitcher: FC = () => {
1038
+ const { pathname, search } = useLocation(); // Get the current URL path. Example: /fr/about?foo=bar
1039
+ const navigate = useNavigate();
1040
+
1041
+ const { locale, availableLocales, setLocale } = useLocale({
1042
+ onLocaleChange: (locale) => {
1043
+ // Construct the URL with the updated locale
1044
+ // Example: /es/about?foo=bar
1045
+ const pathWithLocale = getLocalizedUrl(`${pathname}${search}`, locale);
1046
+
1047
+ // Update the URL path
1048
+ navigate(pathWithLocale);
1049
+ },
1050
+ });
1051
+
1052
+ return (
1053
+ <div>
1054
+ <button popoverTarget="localePopover">{getLocaleName(locale)}</button>
1055
+ <div id="localePopover" popover="auto">
1056
+ {availableLocales.map((localeItem) => (
1057
+ <a
1058
+ href={getLocalizedUrl(location.pathname, localeItem)}
1059
+ hrefLang={localeItem}
1060
+ aria-current={locale === localeItem ? "page" : undefined}
1061
+ onClick={(e) => {
1062
+ e.preventDefault();
1063
+ setLocale(localeItem);
1064
+ }}
1065
+ key={localeItem}
1066
+ >
1067
+ <span>
1068
+ {/* Locale - e.g. FR */}
1069
+ {localeItem}
1070
+ </span>
1071
+ <span>
1072
+ {/* Language in its own Locale - e.g. Français */}
1073
+ {getLocaleName(localeItem, locale)}
1074
+ </span>
1075
+ <span dir={getHTMLTextDir(localeItem)} lang={localeItem}>
1076
+ {/* Language in current Locale - e.g. Francés with current locale set to Locales.SPANISH */}
1077
+ {getLocaleName(localeItem)}
1078
+ </span>
1079
+ <span dir="ltr" lang={Locales.ENGLISH}>
1080
+ {/* Language in English - e.g. French */}
1081
+ {getLocaleName(localeItem, Locales.ENGLISH)}
1082
+ </span>
1083
+ </a>
1084
+ ))}
1085
+ </div>
1086
+ </div>
1087
+ );
1088
+ };
1089
+ ```
1090
+
1091
+ ```jsx fileName="src/components/LocaleSwitcher.msx" codeFormat="esm"
1092
+ import { useLocation, useNavigate } from "react-router-dom";
1093
+ import {
1094
+ Locales,
1095
+ getHTMLTextDir,
1096
+ getLocaleName,
1097
+ getLocalizedUrl,
1098
+ } from "intlayer";
1099
+ import { useLocale } from "react-intlayer";
1100
+
1101
+ const LocaleSwitcher = () => {
1102
+ const { pathname, search } = useLocation(); // Get the current URL path. Example: /fr/about?foo=bar
1103
+ const navigate = useNavigate();
1104
+
1105
+ const { locale, availableLocales, setLocale } = useLocale({
1106
+ onLocaleChange: (locale) => {
1107
+ // Construct the URL with the updated locale
1108
+ // Example: /es/about?foo=bar
1109
+ const pathWithLocale = getLocalizedUrl(`${pathname}${search}`, locale);
1110
+
1111
+ // Update the URL path
1112
+ navigate(pathWithLocale);
1113
+ },
1114
+ });
1115
+
1116
+ return (
1117
+ <div>
1118
+ <button popoverTarget="localePopover">{getLocaleName(locale)}</button>
1119
+ <div id="localePopover" popover="auto">
1120
+ {availableLocales.map((localeItem) => (
1121
+ <a
1122
+ href={getLocalizedUrl(location.pathname, localeItem)}
1123
+ hrefLang={localeItem}
1124
+ aria-current={locale === localeItem ? "page" : undefined}
1125
+ onClick={(e) => {
1126
+ e.preventDefault();
1127
+ setLocale(localeItem);
1128
+ }}
1129
+ key={localeItem}
1130
+ >
1131
+ <span>
1132
+ {/* Locale - e.g. FR */}
1133
+ {localeItem}
1134
+ </span>
1135
+ <span>
1136
+ {/* Language in its own Locale - e.g. Français */}
1137
+ {getLocaleName(localeItem, locale)}
1138
+ </span>
1139
+ <span dir={getHTMLTextDir(localeItem)} lang={localeItem}>
1140
+ {/* Language in current Locale - e.g. Francés with current locale set to Locales.SPANISH */}
1141
+ {getLocaleName(localeItem)}
1142
+ </span>
1143
+ <span dir="ltr" lang={Locales.ENGLISH}>
1144
+ {/* Language in English - e.g. French */}
1145
+ {getLocaleName(localeItem, Locales.ENGLISH)}
1146
+ </span>
1147
+ </a>
1148
+ ))}
1149
+ </div>
1150
+ </div>
1151
+ );
1152
+ };
1153
+ ```
1154
+
1155
+ ```jsx fileName="src/components/LocaleSwitcher.csx" codeFormat="commonjs"
1156
+ const { useLocation, useNavigate } = require("react-router-dom");
1157
+ const {
1158
+ Locales,
1159
+ getHTMLTextDir,
1160
+ getLocaleName,
1161
+ getLocalizedUrl,
1162
+ } = require("intlayer");
1163
+ const { useLocale } = require("react-intlayer");
1164
+
1165
+ const LocaleSwitcher = () => {
1166
+ const { pathname, search } = useLocation(); // Get the current URL path. Example: /fr/about?foo=bar
1167
+ const navigate = useNavigate();
1168
+
1169
+ const { locale, availableLocales, setLocale } = useLocale({
1170
+ onLocaleChange: (locale) => {
1171
+ // Construct the URL with the updated locale
1172
+ // Example: /es/about?foo=bar
1173
+ const pathWithLocale = getLocalizedUrl(`${pathname}${search}`, locale);
1174
+
1175
+ // Update the URL path
1176
+ navigate(pathWithLocale);
1177
+ },
1178
+ });
1179
+
1180
+ return (
1181
+ <div>
1182
+ <button popoverTarget="localePopover">{getLocaleName(locale)}</button>
1183
+ <div id="localePopover" popover="auto">
1184
+ {availableLocales.map((localeItem) => (
1185
+ <a
1186
+ href={getLocalizedUrl(location.pathname, localeItem)}
1187
+ hrefLang={localeItem}
1188
+ aria-current={locale === localeItem ? "page" : undefined}
1189
+ onClick={(e) => {
1190
+ e.preventDefault();
1191
+ setLocale(localeItem);
1192
+ }}
1193
+ key={localeItem}
1194
+ >
1195
+ <span>
1196
+ {/* Locale - e.g. FR */}
1197
+ {localeItem}
1198
+ </span>
1199
+ <span>
1200
+ {/* Language in its own Locale - e.g. Français */}
1201
+ {getLocaleName(localeItem, locale)}
1202
+ </span>
1203
+ <span dir={getHTMLTextDir(localeItem)} lang={localeItem}>
1204
+ {/* Language in current Locale - e.g. Francés with current locale set to Locales.SPANISH */}
1205
+ {getLocaleName(localeItem)}
1206
+ </span>
1207
+ <span dir="ltr" lang={Locales.ENGLISH}>
1208
+ {/* Language in English - e.g. French */}
1209
+ {getLocaleName(localeItem, Locales.ENGLISH)}
1210
+ </span>
1211
+ </a>
1212
+ ))}
1213
+ </div>
1214
+ </div>
1215
+ );
1216
+ };
1217
+ ```
1218
+
1219
+ > Documentation references:
1220
+
1221
+ > - [`useLocale` hook](https://github.com/aymericzip/intlayer/blob/main/docs/en/packages/react-intlayer/useLocale.md)
1222
+
1223
+ > - [`getLocaleName` hook](https://github.com/aymericzip/intlayer/blob/main/docs/en/packages/intlayer/getLocaleName.md)
1224
+
1225
+ > - [`getLocalizedUrl` hook](https://github.com/aymericzip/intlayer/blob/main/docs/en/packages/intlayer/getLocalizedUrl.md)
1226
+
1227
+ > - [`getHTMLTextDir` hook](https://github.com/aymericzip/intlayer/blob/main/docs/en/packages/intlayer/getHTMLTextDir.md)
1228
+
1229
+ > - [`hrefLang` attribute](https://developers.google.com/search/docs/specialty/international/localized-versions?hl=fr)
1230
+
1231
+ > - [`lang` attribute](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes/lang)
1232
+
1233
+ > - [`dir` attribute](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes/dir)
1234
+
1235
+ > - [`aria-current` attribute](https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Attributes/aria-current)
1236
+
1237
+ Below is the updated **Step 9** with added explanations and refined code examples:
1238
+
1239
+ ---
1240
+
1241
+ ### (Optional) Step 9: Switch the HTML Language and Direction Attributes
1242
+
1243
+ When your application supports multiple languages, it's crucial to update the `<html>` tag's `lang` and `dir` attributes to match the current locale. Doing so ensures:
1244
+
1245
+ - **Accessibility**: Screen readers and assistive technologies rely on the correct `lang` attribute to pronounce and interpret content accurately.
1246
+ - **Text Rendering**: The `dir` (direction) attribute ensures that text is rendered in the proper order (e.g., left-to-right for English, right-to-left for Arabic or Hebrew), which is essential for readability.
1247
+ - **SEO**: Search engines use the `lang` attribute to determine the language of your page, helping to serve the right localized content in search results.
1248
+
1249
+ By updating these attributes dynamically when the locale changes, you guarantee a consistent and accessible experience for users across all supported languages.
1250
+
1251
+ #### Implementing the Hook
1252
+
1253
+ Create a custom hook to manage the HTML attributes. The hook listens for locale changes and updates the attributes accordingly:
1254
+
1255
+ ```tsx fileName="src/hooks/useI18nHTMLAttributes.tsx" codeFormat="typescript"
1256
+ import { useEffect } from "react";
1257
+ import { useLocale } from "react-intlayer";
1258
+ import { getHTMLTextDir } from "intlayer";
1259
+
1260
+ /**
1261
+ * Updates the HTML <html> element's `lang` and `dir` attributes based on the current locale.
1262
+ * - `lang`: Informs browsers and search engines of the page's language.
1263
+ * - `dir`: Ensures the correct reading order (e.g., 'ltr' for English, 'rtl' for Arabic).
1264
+ *
1265
+ * This dynamic update is essential for proper text rendering, accessibility, and SEO.
1266
+ */
1267
+ export const useI18nHTMLAttributes = () => {
1268
+ const { locale } = useLocale();
1269
+
1270
+ useEffect(() => {
1271
+ // Update the language attribute to the current locale.
1272
+ document.documentElement.lang = locale;
1273
+
1274
+ // Set the text direction based on the current locale.
1275
+ document.documentElement.dir = getHTMLTextDir(locale);
1276
+ }, [locale]);
1277
+ };
1278
+ ```
1279
+
1280
+ ```jsx fileName="src/hooks/useI18nHTMLAttributes.msx" codeFormat="esm"
1281
+ import { useEffect } from "react";
1282
+ import { useLocale } from "react-intlayer";
1283
+ import { getHTMLTextDir } from "intlayer";
1284
+
1285
+ /**
1286
+ * Updates the HTML <html> element's `lang` and `dir` attributes based on the current locale.
1287
+ * - `lang`: Informs browsers and search engines of the page's language.
1288
+ * - `dir`: Ensures the correct reading order (e.g., 'ltr' for English, 'rtl' for Arabic).
1289
+ *
1290
+ * This dynamic update is essential for proper text rendering, accessibility, and SEO.
1291
+ */
1292
+ export const useI18nHTMLAttributes = () => {
1293
+ const { locale } = useLocale();
1294
+
1295
+ useEffect(() => {
1296
+ // Update the language attribute to the current locale.
1297
+ document.documentElement.lang = locale;
1298
+
1299
+ // Set the text direction based on the current locale.
1300
+ document.documentElement.dir = getHTMLTextDir(locale);
1301
+ }, [locale]);
1302
+ };
1303
+ ```
1304
+
1305
+ ```jsx fileName="src/hooks/useI18nHTMLAttributes.csx" codeFormat="commonjs"
1306
+ const { useEffect } = require("react");
1307
+ const { useLocale } = require("react-intlayer");
1308
+ const { getHTMLTextDir } = require("intlayer");
1309
+
1310
+ /**
1311
+ * Updates the HTML <html> element's `lang` and `dir` attributes based on the current locale.
1312
+ * - `lang`: Informs browsers and search engines of the page's language.
1313
+ * - `dir`: Ensures the correct reading order (e.g., 'ltr' for English, 'rtl' for Arabic).
1314
+ *
1315
+ * This dynamic update is essential for proper text rendering, accessibility, and SEO.
1316
+ */
1317
+ const useI18nHTMLAttributes = () => {
1318
+ const { locale } = useLocale();
1319
+
1320
+ useEffect(() => {
1321
+ // Update the language attribute to the current locale.
1322
+ document.documentElement.lang = locale;
1323
+
1324
+ // Set the text direction based on the current locale.
1325
+ document.documentElement.dir = getHTMLTextDir(locale);
1326
+ }, [locale]);
1327
+ };
1328
+
1329
+ module.exports = { useI18nHTMLAttributes };
1330
+ ```
1331
+
1332
+ #### Using the Hook in Your Application
1333
+
1334
+ Integrate the hook into your main component so that the HTML attributes update whenever the locale changes:
1335
+
1336
+ ```tsx fileName="src/App.tsx" codeFormat="typescript"
1337
+ import type { FC } from "react";
1338
+ import { IntlayerProvider, useIntlayer } from "react-intlayer";
1339
+ import { useI18nHTMLAttributes } from "./hooks/useI18nHTMLAttributes";
1340
+ import "./App.css";
1341
+
1342
+ const AppContent: FC = () => {
1343
+ // Apply the hook to update the <html> tag's lang and dir attributes based on the locale.
1344
+ useI18nHTMLAttributes();
1345
+
1346
+ // ... Rest of your component
1347
+ };
1348
+
1349
+ const App: FC = () => (
1350
+ <IntlayerProvider>
1351
+ <AppContent />
1352
+ </IntlayerProvider>
1353
+ );
1354
+
1355
+ export default App;
1356
+ ```
1357
+
1358
+ ```jsx fileName="src/App.msx" codeFormat="esm"
1359
+ import { IntlayerProvider, useIntlayer } from "react-intlayer";
1360
+ import { useI18nHTMLAttributes } from "./hooks/useI18nHTMLAttributes";
1361
+ import "./App.css";
1362
+
1363
+ const AppContent = () => {
1364
+ // Apply the hook to update the <html> tag's lang and dir attributes based on the locale.
1365
+ useI18nHTMLAttributes();
1366
+
1367
+ // ... Rest of your component
1368
+ };
1369
+
1370
+ const App = () => (
1371
+ <IntlayerProvider>
1372
+ <AppContent />
1373
+ </IntlayerProvider>
1374
+ );
1375
+
1376
+ export default App;
1377
+ ```
1378
+
1379
+ ```jsx fileName="src/App.csx" codeFormat="commonjs"
1380
+ const { FC } = require("react");
1381
+ const { IntlayerProvider, useIntlayer } = require("react-intlayer");
1382
+ const { useI18nHTMLAttributes } = require("./hooks/useI18nHTMLAttributes");
1383
+ require("./App.css");
1384
+
1385
+ const AppContent = () => {
1386
+ // Apply the hook to update the <html> tag's lang and dir attributes based on the locale.
1387
+ useI18nHTMLAttributes();
1388
+
1389
+ // ... Rest of your component
1390
+ };
1391
+
1392
+ const App = () => (
1393
+ <IntlayerProvider>
1394
+ <AppContent />
1395
+ </IntlayerProvider>
1396
+ );
1397
+
1398
+ module.exports = App;
1399
+ ```
1400
+
1401
+ By applying these changes, your application will:
1402
+
1403
+ - Ensure the **language** (`lang`) attribute correctly reflects the current locale, which is important for SEO and browser behavior.
1404
+ - Adjust the **text direction** (`dir`) according to the locale, enhancing readability and usability for languages with different reading orders.
1405
+ - Provide a more **accessible** experience, as assistive technologies depend on these attributes to function optimally.
1406
+
1407
+ ### (Optional) Step 10: Creating a Localized Link Component
1408
+
1409
+ To ensure that your application’s navigation respects the current locale, you can create a custom `Link` component. This component automatically prefixes internal URLs with the current language, so that. For example, when a French-speaking user clicks on a link to the "About" page, they are redirected to `/fr/about` instead of `/about`.
1410
+
1411
+ This behavior is useful for several reasons:
1412
+
1413
+ - **SEO and User Experience**: Localized URLs help search engines index language-specific pages correctly and provide users with content in their preferred language.
1414
+ - **Consistency**: By using a localized link throughout your application, you guarantee that navigation stays within the current locale, preventing unexpected language switches.
1415
+ - **Maintainability**: Centralizing the localization logic in a single component simplifies the management of URLs, making your codebase easier to maintain and extend as your application grows.
1416
+
1417
+ Below is the implementation of a localized `Link` component in TypeScript:
1418
+
1419
+ ```tsx fileName="src/components/Link.tsx" codeFormat="typescript"
1420
+ import { getLocalizedUrl } from "intlayer";
1421
+ import {
1422
+ forwardRef,
1423
+ type DetailedHTMLProps,
1424
+ type AnchorHTMLAttributes,
1425
+ } from "react";
1426
+ import { useLocale } from "react-intlayer";
1427
+
1428
+ export interface LinkProps
1429
+ extends DetailedHTMLProps<
1430
+ AnchorHTMLAttributes<HTMLAnchorElement>,
1431
+ HTMLAnchorElement
1432
+ > {}
1433
+
1434
+ /**
1435
+ * Utility function to check whether a given URL is external.
1436
+ * If the URL starts with http:// or https://, it's considered external.
1437
+ */
1438
+ export const checkIsExternalLink = (href?: string): boolean =>
1439
+ /^https?:\/\//.test(href ?? "");
1440
+
1441
+ /**
1442
+ * A custom Link component that adapts the href attribute based on the current locale.
1443
+ * For internal links, it uses `getLocalizedUrl` to prefix the URL with the locale (e.g., /fr/about).
1444
+ * This ensures that navigation stays within the same locale context.
1445
+ */
1446
+ export const Link = forwardRef<HTMLAnchorElement, LinkProps>(
1447
+ ({ href, children, ...props }, ref) => {
1448
+ const { locale } = useLocale();
1449
+ const isExternalLink = checkIsExternalLink(href);
1450
+
1451
+ // If the link is internal and a valid href is provided, get the localized URL.
1452
+ const hrefI18n =
1453
+ href && !isExternalLink ? getLocalizedUrl(href, locale) : href;
1454
+
1455
+ return (
1456
+ <a href={hrefI18n} ref={ref} {...props}>
1457
+ {children}
1458
+ </a>
1459
+ );
1460
+ }
1461
+ );
1462
+
1463
+ Link.displayName = "Link";
1464
+ ```
1465
+
1466
+ ```jsx fileName="src/components/Link.mjx" codeFormat="esm"
1467
+ import { getLocalizedUrl } from "intlayer";
1468
+ import { useLocale } from "react-intlayer";
1469
+ import { forwardRef } from "react";
1470
+
1471
+ /**
1472
+ * Utility function to check whether a given URL is external.
1473
+ * If the URL starts with http:// or https://, it's considered external.
1474
+ */
1475
+ export const checkIsExternalLink = (href?: string): boolean =>
1476
+ /^https?:\/\//.test(href ?? "");
1477
+
1478
+ /**
1479
+ * A custom Link component that adapts the href attribute based on the current locale.
1480
+ * For internal links, it uses `getLocalizedUrl` to prefix the URL with the locale (e.g., /fr/about).
1481
+ * This ensures that navigation stays within the same locale context.
1482
+ */
1483
+ export const Link = forwardRef(({ href, children, ...props }, ref) => {
1484
+ const { locale } = useLocale();
1485
+ const isExternalLink = checkIsExternalLink(href);
1486
+
1487
+ // If the link is internal and a valid href is provided, get the localized URL.
1488
+ const hrefI18n =
1489
+ href && !isExternalLink ? getLocalizedUrl(href, locale) : href;
1490
+
1491
+ return (
1492
+ <a href={hrefI18n} ref={ref} {...props}>
1493
+ {children}
1494
+ </a>
1495
+ );
1496
+ });
1497
+
1498
+ Link.displayName = "Link";
1499
+ ```
1500
+
1501
+ ```jsx fileName="src/components/Link.csx" codeFormat="commonjs"
1502
+ const { getLocalizedUrl } = require("intlayer");
1503
+ const { useLocale } = require("react-intlayer");
1504
+ const { forwardRef } = require("react");
1505
+
1506
+ /**
1507
+ * Utility function to check whether a given URL is external.
1508
+ * If the URL starts with http:// or https://, it's considered external.
1509
+ */
1510
+ const checkIsExternalLink = (href) => /^https?:\/\//.test(href ?? "");
1511
+
1512
+ /**
1513
+ * A custom Link component that adapts the href attribute based on the current locale.
1514
+ * For internal links, it uses `getLocalizedUrl` to prefix the URL with the locale (e.g., /fr/about).
1515
+ * This ensures that navigation stays within the same locale context.
1516
+ */
1517
+ const Link = forwardRef(({ href, children, ...props }, ref) => {
1518
+ const { locale } = useLocale();
1519
+ const isExternalLink = checkIsExternalLink(href);
1520
+
1521
+ // If the link is internal and a valid href is provided, get the localized URL.
1522
+ const localizedHref = isExternalLink ? href : getLocalizedUrl(href, locale);
1523
+
1524
+ return (
1525
+ <a
1526
+ href={localizedHref}
1527
+ ref={ref}
1528
+ {...props}
1529
+ aria-current={isExternalLink ? "external" : undefined}
1530
+ >
1531
+ {children}
1532
+ </a>
1533
+ );
1534
+ });
1535
+
1536
+ Link.displayName = "Link";
1537
+ ```
1538
+
1539
+ #### How It Works
1540
+
1541
+ - **Detecting External Links**:
1542
+ The helper function `checkIsExternalLink` determines whether a URL is external. External links are left unchanged because they do not need localization.
1543
+
1544
+ - **Retrieving the Current Locale**:
1545
+ The `useLocale` hook provides the current locale (e.g., `fr` for French).
1546
+
1547
+ - **Localizing the URL**:
1548
+ For internal links (i.e., non-external), `getLocalizedUrl` is used to automatically prefix the URL with the current locale. This means that if your user is in French, passing `/about` as the `href` will transform it to `/fr/about`.
1549
+
1550
+ - **Returning the Link**:
1551
+ The component returns an `<a>` element with the localized URL, ensuring that navigation is consistent with the locale.
1552
+
1553
+ By integrating this `Link` component across your application, you maintain a coherent and language-aware user experience while also benefitting from improved SEO and usability.
1554
+
1555
+ ### Configure TypeScript
1556
+
1557
+ Intlayer use module augmentation to get benefits of TypeScript and make your codebase stronger.
1558
+
1559
+ ![alt text](https://github.com/aymericzip/intlayer/blob/main/docs/assets/autocompletion.png)
1560
+
1561
+ ![alt text](https://github.com/aymericzip/intlayer/blob/main/docs/assets/translation_error.png)
1562
+
1563
+ Ensure your TypeScript configuration includes the autogenerated types.
1564
+
1565
+ ```json5 fileName="tsconfig.json"
1566
+ {
1567
+ // ... Your existing TypeScript configurations
1568
+ "include": [
1569
+ // ... Your existing TypeScript configurations
1570
+ ".intlayer/**/*.ts", // Include the auto-generated types
1571
+ ],
1572
+ }
1573
+ ```
1574
+
1575
+ ### Git Configuration
1576
+
1577
+ It is recommended to ignore the files generated by Intlayer. This allows you to avoid committing them to your Git repository.
1578
+
1579
+ To do this, you can add the following instructions to your `.gitignore` file:
1580
+
1581
+ ```plaintext
1582
+ # Ignore the files generated by Intlayer
1583
+ .intlayer
1584
+ ```
1585
+
1586
+ ### VS Code Extension
1587
+
1588
+ To improve your development experience with Intlayer, you can install the official **Intlayer VS Code Extension**.
1589
+
1590
+ [Install from the VS Code Marketplace](https://marketplace.visualstudio.com/items?itemName=intlayer.intlayer-vs-code-extension)
1591
+
1592
+ This extension provides:
1593
+
1594
+ - **Autocompletion** for translation keys.
1595
+ - **Real-time error detection** for missing translations.
1596
+ - **Inline previews** of translated content.
1597
+ - **Quick actions** to easily create and update translations.
1598
+
1599
+ For more details on how to use the extension, refer to the [Intlayer VS Code Extension documentation](https://intlayer.org/doc/vs-code-extension).
1600
+
1601
+ ---
1602
+
1603
+ ### Go Further
1604
+
1605
+ To go further, you can implement the [visual editor](https://github.com/aymericzip/intlayer/blob/main/docs/en/intlayer_visual_editor.md) or externalize your content using the [CMS](https://github.com/aymericzip/intlayer/blob/main/docs/en/intlayer_CMS.md).