@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,1621 @@
1
+ # Commencer avec l'internationalisation (i18n) avec Intlayer, Vite et Preact
2
+
3
+ > Ce package est en développement. Voir le [problème](https://github.com/aymericzip/intlayer/issues/118) pour plus d'informations. Montrez votre intérêt pour Intlayer pour Preact en aimant le problème.
4
+
5
+ Voir le [Modèle d'application](https://github.com/aymericzip/intlayer-vite-preact-template) sur GitHub.
6
+
7
+ ## Qu'est-ce qu'Intlayer ?
8
+
9
+ **Intlayer** est une bibliothèque innovante et open-source d'internationalisation (i18n) conçue pour simplifier le support multilingue dans les applications web modernes.
10
+
11
+ Avec Intlayer, vous pouvez :
12
+
13
+ - **Gérer facilement les traductions** en utilisant des dictionnaires déclaratifs au niveau des composants.
14
+ - **Localiser dynamiquement les métadonnées**, les routes et le contenu.
15
+ - **Assurer la prise en charge de TypeScript** avec des types générés automatiquement, améliorant l'autocomplétion et la détection des erreurs.
16
+ - **Bénéficier de fonctionnalités avancées**, comme la détection et le changement dynamiques de la langue.
17
+
18
+ ---
19
+
20
+ ## Guide étape par étape pour configurer Intlayer dans une application Vite et Preact
21
+
22
+ ### Étape 1 : Installer les dépendances
23
+
24
+ Installez les packages nécessaires en utilisant npm :
25
+
26
+ ```bash packageManager="npm"
27
+ npm install intlayer preact-intlayer vite-intlayer
28
+ ```
29
+
30
+ ```bash packageManager="pnpm"
31
+ pnpm add intlayer preact-intlayer vite-intlayer
32
+ ```
33
+
34
+ ```bash packageManager="yarn"
35
+ yarn add intlayer preact-intlayer vite-intlayer
36
+ ```
37
+
38
+ - **intlayer**
39
+
40
+ Le package principal qui fournit des outils d'internationalisation pour la gestion de la configuration, la traduction, [la déclaration de contenu](https://github.com/aymericzip/intlayer/blob/main/docs/fr/dictionary/get_started.md), la transpilation et les [commandes CLI](https://github.com/aymericzip/intlayer/blob/main/docs/fr/intlayer_cli.md).
41
+
42
+ - **preact-intlayer**
43
+ Le package qui intègre Intlayer avec une application Preact. Il fournit des fournisseurs de contexte et des hooks pour l'internationalisation avec Preact.
44
+
45
+ - **vite-intlayer**
46
+ Inclut le plugin Vite pour intégrer Intlayer avec le [bundler Vite](https://vite.dev/guide/why.html#why-bundle-for-production), ainsi qu'un middleware pour détecter la langue préférée de l'utilisateur, gérer les cookies et gérer la redirection des URL.
47
+
48
+ ### Étape 2 : Configuration de votre projet
49
+
50
+ Créez un fichier de configuration pour configurer les langues de votre application :
51
+
52
+ ```typescript fileName="intlayer.config.ts" codeFormat="typescript"
53
+ import { Locales, type IntlayerConfig } from "intlayer";
54
+
55
+ const config: IntlayerConfig = {
56
+ internationalisation: {
57
+ locales: [
58
+ Locales.ENGLISH,
59
+ Locales.FRENCH,
60
+ Locales.SPANISH,
61
+ // Vos autres langues
62
+ ],
63
+ defaultLocale: Locales.ENGLISH,
64
+ },
65
+ };
66
+
67
+ export default config;
68
+ ```
69
+
70
+ ```javascript fileName="intlayer.config.mjs" codeFormat="esm"
71
+ import { Locales } from "intlayer";
72
+
73
+ /** @type {import('intlayer').IntlayerConfig} */
74
+ const config = {
75
+ internationalisation: {
76
+ locales: [
77
+ Locales.ENGLISH,
78
+ Locales.FRENCH,
79
+ Locales.SPANISH,
80
+ // Vos autres langues
81
+ ],
82
+ defaultLocale: Locales.ENGLISH,
83
+ },
84
+ };
85
+
86
+ export default config;
87
+ ```
88
+
89
+ ```javascript fileName="intlayer.config.cjs" codeFormat="commonjs"
90
+ const { Locales } = require("intlayer");
91
+
92
+ /** @type {import('intlayer').IntlayerConfig} */
93
+ const config = {
94
+ internationalisation: {
95
+ locales: [
96
+ Locales.ENGLISH,
97
+ Locales.FRENCH,
98
+ Locales.SPANISH,
99
+ // Vos autres langues
100
+ ],
101
+ defaultLocale: Locales.ENGLISH,
102
+ },
103
+ };
104
+
105
+ module.exports = config;
106
+ ```
107
+
108
+ > Grâce à ce fichier de configuration, vous pouvez configurer les URL localisées, la redirection via middleware, les noms de cookies, l'emplacement et l'extension de vos déclarations de contenu, désactiver les journaux Intlayer dans la console, et plus encore. Pour une liste complète des paramètres disponibles, consultez la [documentation de configuration](https://github.com/aymericzip/intlayer/blob/main/docs/fr/configuration.md).
109
+
110
+ ### Étape 3 : Intégrer Intlayer dans votre configuration Vite
111
+
112
+ Ajoutez le plugin intlayer dans votre configuration.
113
+
114
+ ```typescript fileName="vite.config.ts" codeFormat="typescript"
115
+ import { defineConfig } from "vite";
116
+ import preact from "@preact/preset-vite";
117
+ import { intlayerPlugin } from "vite-intlayer";
118
+
119
+ // https://vitejs.dev/config/
120
+ export default defineConfig({
121
+ plugins: [preact(), intlayerPlugin()],
122
+ });
123
+ ```
124
+
125
+ ```javascript fileName="vite.config.mjs" codeFormat="esm"
126
+ import { defineConfig } from "vite";
127
+ import preact from "@preact/preset-vite";
128
+ import { intlayerPlugin } from "vite-intlayer";
129
+
130
+ // https://vitejs.dev/config/
131
+ export default defineConfig({
132
+ plugins: [preact(), intlayerPlugin()],
133
+ });
134
+ ```
135
+
136
+ ```javascript fileName="vite.config.cjs" codeFormat="commonjs"
137
+ const { defineConfig } = require("vite");
138
+ const preact = require("@preact/preset-vite");
139
+ const { intlayerPlugin } = require("vite-intlayer");
140
+
141
+ // https://vitejs.dev/config/
142
+ module.exports = defineConfig({
143
+ plugins: [preact(), intlayerPlugin()],
144
+ });
145
+ ```
146
+
147
+ > Le plugin `intlayerPlugin()` de Vite est utilisé pour intégrer Intlayer avec Vite. Il garantit la construction des fichiers de déclaration de contenu et les surveille en mode développement. Il définit les variables d'environnement Intlayer dans l'application Vite. De plus, il fournit des alias pour optimiser les performances.
148
+
149
+ ### Étape 4 : Déclarez votre contenu
150
+
151
+ Créez et gérez vos déclarations de contenu pour stocker les traductions :
152
+
153
+ ```tsx fileName="src/app.content.tsx" contentDeclarationFormat="typescript"
154
+ import { t, type Dictionary } from "intlayer";
155
+
156
+ const appContent = {
157
+ key: "app",
158
+ content: {
159
+ viteLogo: t({
160
+ fr: "Logo Vite",
161
+ en: "Vite logo",
162
+ es: "Logo Vite",
163
+ }),
164
+ preactLogo: t({
165
+ fr: "Logo Preact",
166
+ en: "Preact logo",
167
+ es: "Logo Preact",
168
+ }),
169
+
170
+ title: "Vite + Preact",
171
+
172
+ count: t({
173
+ fr: "le compte est ",
174
+ en: "count is ",
175
+ es: "el recuento es ",
176
+ }),
177
+
178
+ edit: t({
179
+ en: "Edit src/app.tsx and save to test HMR",
180
+ fr: "Éditez src/app.tsx et enregistrez pour tester HMR",
181
+ es: "Edita src/app.tsx y guarda para probar HMR",
182
+ }),
183
+
184
+ readTheDocs: t({
185
+ fr: "Cliquez sur les logos Vite et Preact pour en savoir plus",
186
+ en: "Click on the Vite and Preact logos to learn more",
187
+ es: "Haga clic en los logotipos de Vite y Preact para obtener más información",
188
+ }),
189
+ },
190
+ } satisfies Dictionary;
191
+
192
+ export default appContent;
193
+ ```
194
+
195
+ ```javascript fileName="src/app.content.mjs" contentDeclarationFormat="esm"
196
+ import { t } from "intlayer";
197
+ // import { h } from 'preact'; // Nécessaire si vous utilisez JSX directement dans .mjs
198
+
199
+ /** @type {import('intlayer').Dictionary} */
200
+ const appContent = {
201
+ key: "app",
202
+ content: {
203
+ viteLogo: t({
204
+ fr: "Logo Vite",
205
+ en: "Vite logo",
206
+ es: "Logo Vite",
207
+ }),
208
+ preactLogo: t({
209
+ fr: "Logo Preact",
210
+ en: "Preact logo",
211
+ es: "Logo Preact",
212
+ }),
213
+
214
+ title: "Vite + Preact",
215
+
216
+ count: t({
217
+ fr: "le compte est ",
218
+ en: "count is ",
219
+ es: "el recuento es ",
220
+ }),
221
+
222
+ edit: t({
223
+ en: "Edit src/app.tsx and save to test HMR",
224
+ fr: "Éditez src/app.tsx et enregistrez pour tester HMR",
225
+ es: "Edita src/app.tsx y guarda para probar HMR",
226
+ }),
227
+
228
+ readTheDocs: t({
229
+ fr: "Cliquez sur les logos Vite et Preact pour en savoir plus",
230
+ en: "Click on the Vite and Preact logos to learn more",
231
+ es: "Haga clic en los logotipos de Vite y Preact para obtener más información",
232
+ }),
233
+ },
234
+ };
235
+
236
+ export default appContent;
237
+ ```
238
+
239
+ ```javascript fileName="src/app.content.cjs" contentDeclarationFormat="commonjs"
240
+ const { t } = require("intlayer");
241
+
242
+ // const { h } = require('preact'); // Nécessaire si vous utilisez JSX directement dans .cjs
243
+
244
+ /** @type {import('intlayer').Dictionary} */
245
+ const appContent = {
246
+ key: "app",
247
+ content: {
248
+ viteLogo: t({
249
+ fr: "Logo Vite",
250
+ en: "Vite logo",
251
+ es: "Logo Vite",
252
+ }),
253
+ preactLogo: t({
254
+ fr: "Logo Preact",
255
+ en: "Preact logo",
256
+ es: "Logo Preact",
257
+ }),
258
+
259
+ title: "Vite + Preact",
260
+
261
+ count: t({
262
+ fr: "le compte est ",
263
+ en: "count is ",
264
+ es: "el recuento es ",
265
+ }),
266
+
267
+ edit: t({
268
+ en: "Edit src/app.tsx and save to test HMR",
269
+ fr: "Éditez src/app.tsx et enregistrez pour tester HMR",
270
+ es: "Edita src/app.tsx y guarda para probar HMR",
271
+ }),
272
+
273
+ readTheDocs: t({
274
+ fr: "Cliquez sur les logos Vite et Preact pour en savoir plus",
275
+ en: "Click on the Vite and Preact logos to learn more",
276
+ es: "Haga clic en los logotipos de Vite y Preact para obtener más información",
277
+ }),
278
+ },
279
+ };
280
+
281
+ module.exports = appContent;
282
+ ```
283
+
284
+ ```json fileName="src/app.content.json" contentDeclarationFormat="json"
285
+ {
286
+ "$schema": "https://intlayer.org/schema.json",
287
+ "key": "app",
288
+ "content": {
289
+ "viteLogo": {
290
+ "nodeType": "translation",
291
+ "translation": {
292
+ "fr": "Logo Vite",
293
+ "en": "Vite logo",
294
+ "es": "Logo Vite"
295
+ }
296
+ },
297
+ "preactLogo": {
298
+ "nodeType": "translation",
299
+ "translation": {
300
+ "fr": "Logo Preact",
301
+ "en": "Preact logo",
302
+ "es": "Logo Preact"
303
+ }
304
+ },
305
+ "title": {
306
+ "nodeType": "translation",
307
+ "translation": {
308
+ "fr": "Vite + Preact",
309
+ "en": "Vite + Preact",
310
+ "es": "Vite + Preact"
311
+ }
312
+ },
313
+ "count": {
314
+ "nodeType": "translation",
315
+ "translation": {
316
+ "fr": "le compte est ",
317
+ "en": "count is ",
318
+ "es": "el recuento es "
319
+ }
320
+ },
321
+ "edit": {
322
+ "nodeType": "translation",
323
+ "translation": {
324
+ "fr": "Éditez src/app.tsx et enregistrez pour tester HMR",
325
+ "en": "Edit src/app.tsx and save to test HMR",
326
+ "es": "Edita src/app.tsx y guarda para probar HMR"
327
+ }
328
+ },
329
+ "readTheDocs": {
330
+ "nodeType": "translation",
331
+ "translation": {
332
+ "fr": "Cliquez sur les logos Vite et Preact pour en savoir plus",
333
+ "en": "Click on the Vite and Preact logos to learn more",
334
+ "es": "Haga clic en los logotipos de Vite y Preact para obtener más información"
335
+ }
336
+ }
337
+ }
338
+ }
339
+ ```
340
+
341
+ > Vos déclarations de contenu peuvent être définies n'importe où dans votre application tant qu'elles sont incluses dans le répertoire `contentDir` (par défaut, `./src`). Et correspondent à l'extension de fichier de déclaration de contenu (par défaut, `.content.{json,ts,tsx,js,jsx,mjs,mjx,cjs,cjx}`).
342
+
343
+ > Pour plus de détails, consultez la [documentation sur les déclarations de contenu](https://github.com/aymericzip/intlayer/blob/main/docs/fr/dictionary/get_started.md).
344
+
345
+ > Si votre fichier de contenu inclut du code TSX, vous devrez peut-être importer `import { h } from "preact";` ou vous assurer que votre pragma JSX est correctement configuré pour Preact.
346
+
347
+ ### Étape 5 : Utilisez Intlayer dans votre code
348
+
349
+ Accédez à vos dictionnaires de contenu dans toute votre application :
350
+
351
+ ```tsx {6,10} fileName="src/app.tsx" codeFormat="typescript"
352
+ import { useState } from "preact/hooks";
353
+ import type { FunctionalComponent } from "preact";
354
+ import preactLogo from "./assets/preact.svg"; // Supposons que vous avez un fichier preact.svg
355
+ import viteLogo from "/vite.svg";
356
+ import "./app.css"; // Supposons que votre fichier CSS s'appelle app.css
357
+ import { IntlayerProvider, useIntlayer } from "preact-intlayer";
358
+
359
+ const AppContent: FunctionalComponent = () => {
360
+ const [count, setCount] = useState(0);
361
+ const content = useIntlayer("app");
362
+
363
+ return (
364
+ <>
365
+ <div>
366
+ <a href="https://vitejs.dev" target="_blank">
367
+ <img src={viteLogo} class="logo" alt={content.viteLogo.value} />
368
+ </a>
369
+ <a href="https://preactjs.com" target="_blank">
370
+ <img
371
+ src={preactLogo}
372
+ class="logo preact"
373
+ alt={content.preactLogo.value}
374
+ />
375
+ </a>
376
+ </div>
377
+ <h1>{content.title}</h1>
378
+ <div class="card">
379
+ <button onClick={() => setCount((count) => count + 1)}>
380
+ {content.count}
381
+ {count}
382
+ </button>
383
+ <p>{content.edit}</p>
384
+ </div>
385
+ <p class="read-the-docs">{content.readTheDocs}</p>
386
+ </>
387
+ );
388
+ };
389
+
390
+ const App: FunctionalComponent = () => (
391
+ <IntlayerProvider>
392
+ <AppContent />
393
+ </IntlayerProvider>
394
+ );
395
+
396
+ export default App;
397
+ ```
398
+
399
+ ```jsx {5,9} fileName="src/app.jsx" codeFormat="esm"
400
+ import { useState } from "preact/hooks";
401
+ import preactLogo from "./assets/preact.svg";
402
+ import viteLogo from "/vite.svg";
403
+ import "./app.css";
404
+ import { IntlayerProvider, useIntlayer } from "preact-intlayer";
405
+
406
+ const AppContent = () => {
407
+ const [count, setCount] = useState(0);
408
+ const content = useIntlayer("app");
409
+
410
+ return (
411
+ <>
412
+ <div>
413
+ <a href="https://vitejs.dev" target="_blank">
414
+ <img src={viteLogo} class="logo" alt={content.viteLogo.value} />
415
+ </a>
416
+ <a href="https://preactjs.com" target="_blank">
417
+ <img
418
+ src={preactLogo}
419
+ class="logo preact"
420
+ alt={content.preactLogo.value}
421
+ />
422
+ </a>
423
+ </div>
424
+ <h1>{content.title}</h1>
425
+ <div class="card">
426
+ <button onClick={() => setCount((count) => count + 1)}>
427
+ {content.count}
428
+ {count}
429
+ </button>
430
+ <p>{content.edit}</p>
431
+ </div>
432
+ <p class="read-the-docs">{content.readTheDocs}</p>
433
+ </>
434
+ );
435
+ };
436
+
437
+ const App = () => (
438
+ <IntlayerProvider>
439
+ <AppContent />
440
+ </IntlayerProvider>
441
+ );
442
+
443
+ export default App;
444
+ ```
445
+
446
+ ```jsx {5,9} fileName="src/app.cjsx" codeFormat="commonjs"
447
+ const { useState } = require("preact/hooks");
448
+ const preactLogo = require("./assets/preact.svg");
449
+ const viteLogo = require("/vite.svg");
450
+ require("./app.css");
451
+ const { IntlayerProvider, useIntlayer } = require("preact-intlayer");
452
+
453
+ const AppContent = () => {
454
+ const [count, setCount] = useState(0);
455
+ const content = useIntlayer("app");
456
+
457
+ return (
458
+ <>
459
+ <div>
460
+ <a href="https://vitejs.dev" target="_blank">
461
+ <img src={viteLogo} class="logo" alt={content.viteLogo.value} />
462
+ </a>
463
+ <a href="https://preactjs.com" target="_blank">
464
+ <img
465
+ src={preactLogo}
466
+ class="logo preact"
467
+ alt={content.preactLogo.value}
468
+ />
469
+ </a>
470
+ </div>
471
+ <h1>{content.title}</h1>
472
+ <div class="card">
473
+ <button onClick={() => setCount((count) => count + 1)}>
474
+ {content.count}
475
+ {count}
476
+ </button>
477
+ <p>{content.edit}</p>
478
+ </div>
479
+ <p class="read-the-docs">{content.readTheDocs}</p>
480
+ </>
481
+ );
482
+ };
483
+
484
+ const App = () => (
485
+ <IntlayerProvider>
486
+ <AppContent />
487
+ </IntlayerProvider>
488
+ );
489
+
490
+ module.exports = App;
491
+ ```
492
+
493
+ > Si vous souhaitez utiliser votre contenu dans un attribut `string`, tel que `alt`, `title`, `href`, `aria-label`, etc., vous devez appeler la valeur de la fonction, comme :
494
+
495
+ > ```jsx
496
+ >
497
+ > ```
498
+
499
+ > <img src={content.image.src.value} alt={content.image.value} />
500
+
501
+ > ```
502
+ >
503
+ > ```
504
+
505
+ > Remarque : Dans Preact, `className` est généralement écrit comme `class`.
506
+
507
+ > Pour en savoir plus sur le hook `useIntlayer`, consultez la [documentation](https://github.com/aymericzip/intlayer/blob/main/docs/fr/packages/react-intlayer/useIntlayer.md) (L'API est similaire pour `preact-intlayer`).
508
+
509
+ ### (Optionnel) Étape 6 : Changez la langue de votre contenu
510
+
511
+ Pour changer la langue de votre contenu, vous pouvez utiliser la fonction `setLocale` fournie par le hook `useLocale`. Cette fonction vous permet de définir la langue de l'application et de mettre à jour le contenu en conséquence.
512
+
513
+ ```tsx fileName="src/components/LocaleSwitcher.tsx" codeFormat="typescript"
514
+ import type { FunctionalComponent } from "preact";
515
+ import { Locales } from "intlayer";
516
+ import { useLocale } from "preact-intlayer";
517
+
518
+ const LocaleSwitcher: FunctionalComponent = () => {
519
+ const { setLocale } = useLocale();
520
+
521
+ return (
522
+ <button onClick={() => setLocale(Locales.FRENCH)}>
523
+ Changer la langue en Français
524
+ </button>
525
+ );
526
+ };
527
+
528
+ export default LocaleSwitcher;
529
+ ```
530
+
531
+ ```jsx fileName="src/components/LocaleSwitcher.jsx" codeFormat="esm"
532
+ import { Locales } from "intlayer";
533
+ import { useLocale } from "preact-intlayer";
534
+
535
+ const LocaleSwitcher = () => {
536
+ const { setLocale } = useLocale();
537
+
538
+ return (
539
+ <button onClick={() => setLocale(Locales.FRENCH)}>
540
+ Changer la langue en Français
541
+ </button>
542
+ );
543
+ };
544
+
545
+ export default LocaleSwitcher;
546
+ ```
547
+
548
+ ```jsx fileName="src/components/LocaleSwitcher.cjsx" codeFormat="commonjs"
549
+ const { Locales } = require("intlayer");
550
+ const { useLocale } = require("preact-intlayer");
551
+
552
+ const LocaleSwitcher = () => {
553
+ const { setLocale } = useLocale();
554
+
555
+ return (
556
+ <button onClick={() => setLocale(Locales.FRENCH)}>
557
+ Changer la langue en Français
558
+ </button>
559
+ );
560
+ };
561
+
562
+ module.exports = LocaleSwitcher;
563
+ ```
564
+
565
+ > Pour en savoir plus sur le hook `useLocale`, consultez la [documentation](https://github.com/aymericzip/intlayer/blob/main/docs/fr/packages/react-intlayer/useLocale.md) (L'API est similaire pour `preact-intlayer`).
566
+
567
+ ### (Optionnel) Étape 7 : Ajouter un routage localisé à votre application
568
+
569
+ L'objectif de cette étape est de créer des routes uniques pour chaque langue. Cela est utile pour le SEO et les URL adaptées au référencement.
570
+ Exemple :
571
+
572
+ ```plaintext
573
+ - https://example.com/about
574
+ - https://example.com/es/about
575
+ - https://example.com/fr/about
576
+ ```
577
+
578
+ > Par défaut, les routes ne sont pas préfixées pour la langue par défaut. Si vous souhaitez préfixer la langue par défaut, vous pouvez définir l'option `middleware.prefixDefault` sur `true` dans votre configuration. Consultez la [documentation de configuration](https://github.com/aymericzip/intlayer/blob/main/docs/fr/configuration.md) pour plus d'informations.
579
+
580
+ Pour ajouter un routage localisé à votre application, vous pouvez créer un composant `LocaleRouter` qui enveloppe les routes de votre application et gère le routage basé sur la langue. Voici un exemple utilisant [preact-iso](https://github.com/preactjs/preact-iso) :
581
+
582
+ Tout d'abord, installez `preact-iso` :
583
+
584
+ ```bash packageManager="npm"
585
+ npm install preact-iso
586
+ ```
587
+
588
+ ```bash packageManager="pnpm"
589
+ pnpm add preact-iso
590
+ ```
591
+
592
+ ```bash packageManager="yarn"
593
+ yarn add preact-iso
594
+ ```
595
+
596
+ ```tsx fileName="src/components/LocaleRouter.tsx" codeFormat="typescript"
597
+ import { type Locales, configuration, getPathWithoutLocale } from "intlayer";
598
+ import { ComponentChildren, FunctionalComponent } from "preact";
599
+ import { IntlayerProvider } from "preact-intlayer";
600
+ import { LocationProvider, useLocation } from "preact-iso";
601
+ import { useEffect } from "preact/hooks";
602
+
603
+ const { internationalization, middleware } = configuration;
604
+ const { locales, defaultLocale } = internationalization;
605
+
606
+ const Navigate: FunctionalComponent<{ to: string; replace?: boolean }> = ({
607
+ to,
608
+ replace,
609
+ }) => {
610
+ const { route } = useLocation();
611
+ useEffect(() => {
612
+ route(to, replace);
613
+ }, [to, replace, route]);
614
+ return null;
615
+ };
616
+
617
+ /**
618
+ * Un composant qui gère la localisation et enveloppe les enfants avec le contexte de langue approprié.
619
+ * Il gère la détection et la validation de la langue basée sur l'URL.
620
+ */
621
+ const AppLocalized: FunctionalComponent<{
622
+ children: ComponentChildren;
623
+ locale?: Locales;
624
+ }> = ({ children, locale }) => {
625
+ const { path: pathname, url } = useLocation();
626
+
627
+ if (!url) {
628
+ return null;
629
+ }
630
+
631
+ const search = url.substring(pathname.length);
632
+
633
+ // Détermine la langue actuelle, en utilisant la langue par défaut si non fournie
634
+ const currentLocale = locale ?? defaultLocale;
635
+
636
+ // Supprime le préfixe de langue du chemin pour construire un chemin de base
637
+ const pathWithoutLocale = getPathWithoutLocale(
638
+ pathname // Chemin actuel de l'URL
639
+ );
640
+
641
+ /**
642
+ * Si middleware.prefixDefault est vrai, la langue par défaut doit toujours être préfixée.
643
+ */
644
+ if (middleware.prefixDefault) {
645
+ // Valide la langue
646
+ if (!locale || !locales.includes(locale)) {
647
+ // Redirige vers la langue par défaut avec le chemin mis à jour
648
+ return (
649
+ <Navigate
650
+ to={`/${defaultLocale}/${pathWithoutLocale}${search}`}
651
+ replace // Remplace l'entrée actuelle de l'historique par la nouvelle
652
+ />
653
+ );
654
+ }
655
+
656
+ // Enveloppe les enfants avec IntlayerProvider et définit la langue actuelle
657
+ return (
658
+ <IntlayerProvider locale={currentLocale}>{children}</IntlayerProvider>
659
+ );
660
+ } else {
661
+ /**
662
+ * Lorsque middleware.prefixDefault est faux, la langue par défaut n'est pas préfixée.
663
+ * Assurez-vous que la langue actuelle est valide et n'est pas la langue par défaut.
664
+ */
665
+ if (
666
+ currentLocale.toString() !== defaultLocale.toString() &&
667
+ !locales
668
+ .filter(
669
+ (loc) => loc.toString() !== defaultLocale.toString() // Exclut la langue par défaut
670
+ )
671
+ .includes(currentLocale) // Vérifie si la langue actuelle est dans la liste des langues valides
672
+ ) {
673
+ // Redirige vers le chemin sans préfixe de langue
674
+ return <Navigate to={`${pathWithoutLocale}${search}`} replace />;
675
+ }
676
+
677
+ // Enveloppe les enfants avec IntlayerProvider et définit la langue actuelle
678
+ return (
679
+ <IntlayerProvider locale={currentLocale}>{children}</IntlayerProvider>
680
+ );
681
+ }
682
+ };
683
+
684
+ const RouterContent: FunctionalComponent<{
685
+ children: ComponentChildren;
686
+ }> = ({ children }) => {
687
+ const { path } = useLocation();
688
+
689
+ if (!path) {
690
+ return null;
691
+ }
692
+
693
+ const pathLocale = path.split("/")[1] as Locales;
694
+
695
+ const isLocaleRoute = locales
696
+ .filter((locale) => middleware.prefixDefault || locale !== defaultLocale)
697
+ .some((locale) => locale.toString() === pathLocale);
698
+
699
+ if (isLocaleRoute) {
700
+ return <AppLocalized locale={pathLocale}>{children}</AppLocalized>;
701
+ }
702
+
703
+ return (
704
+ <AppLocalized
705
+ locale={!middleware.prefixDefault ? defaultLocale : undefined}
706
+ >
707
+ {children}
708
+ </AppLocalized>
709
+ );
710
+ };
711
+
712
+ /**
713
+ * Un composant de routeur qui configure des routes spécifiques à la langue.
714
+ * Il utilise preact-iso pour gérer la navigation et rendre des composants localisés.
715
+ */
716
+ export const LocaleRouter: FunctionalComponent<{
717
+ children: ComponentChildren;
718
+ }> = ({ children }) => (
719
+ <LocationProvider>
720
+ <RouterContent>{children}</RouterContent>
721
+ </LocationProvider>
722
+ );
723
+ ```
724
+
725
+ ```jsx fileName="src/components/LocaleRouter.jsx" codeFormat="esm"
726
+ // Importation des dépendances et fonctions nécessaires
727
+ import { configuration, getPathWithoutLocale } from "intlayer";
728
+ import { IntlayerProvider } from "preact-intlayer";
729
+ import { LocationProvider, useLocation } from "preact-iso";
730
+ import { useEffect } from "preact/hooks";
731
+ import { h } from "preact"; // Requis pour JSX
732
+
733
+ // Déstructuration de la configuration depuis Intlayer
734
+ const { internationalization, middleware } = configuration;
735
+ const { locales, defaultLocale } = internationalization;
736
+
737
+ const Navigate = ({ to, replace }) => {
738
+ const { route } = useLocation();
739
+ useEffect(() => {
740
+ route(to, replace);
741
+ }, [to, replace, route]);
742
+ return null;
743
+ };
744
+
745
+ /**
746
+ * Un composant qui gère la localisation et enveloppe les enfants avec le contexte de langue approprié.
747
+ * Il gère la détection et la validation de la langue basée sur l'URL.
748
+ */
749
+ const AppLocalized = ({ children, locale }) => {
750
+ const { path: pathname, url } = useLocation();
751
+
752
+ if (!url) {
753
+ return null;
754
+ }
755
+
756
+ const search = url.substring(pathname.length);
757
+
758
+ // Détermine la langue actuelle, en utilisant la langue par défaut si non fournie
759
+ const currentLocale = locale ?? defaultLocale;
760
+
761
+ // Supprime le préfixe de langue du chemin pour construire un chemin de base
762
+ const pathWithoutLocale = getPathWithoutLocale(
763
+ pathname // Chemin actuel de l'URL
764
+ );
765
+
766
+ /**
767
+ ...
768
+
769
+ /**
770
+ * Si middleware.prefixDefault est vrai, la locale par défaut doit toujours être préfixée.
771
+ */
772
+ if (middleware.prefixDefault) {
773
+ // Valider la locale
774
+ if (!locale || !locales.includes(locale)) {
775
+ // Rediriger vers la locale par défaut avec le chemin mis à jour
776
+ return (
777
+ <Navigate
778
+ to={`/${defaultLocale}/${pathWithoutLocale}${search}`}
779
+ replace // Remplacer l'entrée actuelle de l'historique par la nouvelle
780
+ />
781
+ );
782
+ }
783
+
784
+ // Envelopper les enfants avec IntlayerProvider et définir la locale actuelle
785
+ return (
786
+ <IntlayerProvider locale={currentLocale}>{children}</IntlayerProvider>
787
+ );
788
+ } else {
789
+ /**
790
+ * Lorsque middleware.prefixDefault est faux, la locale par défaut n'est pas préfixée.
791
+ * Assurez-vous que la locale actuelle est valide et n'est pas la locale par défaut.
792
+ */
793
+ if (
794
+ currentLocale.toString() !== defaultLocale.toString() &&
795
+ !locales
796
+ .filter(
797
+ (loc) => loc.toString() !== defaultLocale.toString() // Exclure la locale par défaut
798
+ )
799
+ .includes(currentLocale) // Vérifier si la locale actuelle est dans la liste des locales valides
800
+ ) {
801
+ // Rediriger vers le chemin sans préfixe de locale
802
+ return <Navigate to={`${pathWithoutLocale}${search}`} replace />;
803
+ }
804
+
805
+ // Envelopper les enfants avec IntlayerProvider et définir la locale actuelle
806
+ return (
807
+ <IntlayerProvider locale={currentLocale}>{children}</IntlayerProvider>
808
+ );
809
+ }
810
+ };
811
+
812
+ const RouterContent = ({ children }) => {
813
+ const { path } = useLocation();
814
+
815
+ if (!path) {
816
+ return null;
817
+ }
818
+
819
+ const pathLocale = path.split("/")[1];
820
+
821
+ const isLocaleRoute = locales
822
+ .filter((locale) => middleware.prefixDefault || locale !== defaultLocale)
823
+ .some((locale) => locale.toString() === pathLocale);
824
+
825
+ if (isLocaleRoute) {
826
+ return <AppLocalized locale={pathLocale}>{children}</AppLocalized>;
827
+ }
828
+
829
+ return (
830
+ <AppLocalized
831
+ locale={!middleware.prefixDefault ? defaultLocale : undefined}
832
+ >
833
+ {children}
834
+ </AppLocalized>
835
+ );
836
+ };
837
+
838
+ /**
839
+ * Un composant routeur qui configure des routes spécifiques à la locale.
840
+ * Il utilise preact-iso pour gérer la navigation et rendre des composants localisés.
841
+ */
842
+ export const LocaleRouter = ({ children }) => (
843
+ <LocationProvider>
844
+ <RouterContent>{children}</RouterContent>
845
+ </LocationProvider>
846
+ );
847
+ ```
848
+
849
+ ```jsx fileName="src/components/LocaleRouter.cjsx" codeFormat="commonjs"
850
+ // Importation des dépendances et fonctions nécessaires
851
+ const { configuration, getPathWithoutLocale } = require("intlayer");
852
+ const { IntlayerProvider } = require("preact-intlayer");
853
+ const { LocationProvider, useLocation } = require("preact-iso");
854
+ const { useEffect } = require("preact/hooks");
855
+ const { h } = require("preact"); // Requis pour JSX
856
+
857
+ // Déstructuration de la configuration depuis Intlayer
858
+ const { internationalization, middleware } = configuration;
859
+ const { locales, defaultLocale } = internationalization;
860
+
861
+ const Navigate = ({ to, replace }) => {
862
+ const { route } = useLocation();
863
+ useEffect(() => {
864
+ route(to, replace);
865
+ }, [to, replace, route]);
866
+ return null;
867
+ };
868
+
869
+ /**
870
+ * Un composant qui gère la localisation et enveloppe les enfants avec le contexte de locale approprié.
871
+ * Il gère la détection et la validation de la locale basée sur l'URL.
872
+ */
873
+ const AppLocalized = ({ children, locale }) => {
874
+ const { path: pathname, url } = useLocation();
875
+
876
+ if (!url) {
877
+ return null;
878
+ }
879
+
880
+ const search = url.substring(pathname.length);
881
+
882
+ // Déterminer la locale actuelle, en revenant à la locale par défaut si non fournie
883
+ const currentLocale = locale ?? defaultLocale;
884
+
885
+ // Supprimer le préfixe de locale du chemin pour construire un chemin de base
886
+ const pathWithoutLocale = getPathWithoutLocale(
887
+ pathname // Chemin URL actuel
888
+ );
889
+
890
+ /**
891
+ * Si middleware.prefixDefault est vrai, la locale par défaut doit toujours être préfixée.
892
+ */
893
+ if (middleware.prefixDefault) {
894
+ // Valider la locale
895
+ if (!locale || !locales.includes(locale)) {
896
+ // Rediriger vers la locale par défaut avec le chemin mis à jour
897
+ return (
898
+ <Navigate
899
+ to={`/${defaultLocale}/${pathWithoutLocale}${search}`}
900
+ replace // Remplacer l'entrée actuelle de l'historique par la nouvelle
901
+ />
902
+ );
903
+ }
904
+
905
+ // Envelopper les enfants avec IntlayerProvider et définir la locale actuelle
906
+ return (
907
+ <IntlayerProvider locale={currentLocale}>{children}</IntlayerProvider>
908
+ );
909
+ } else {
910
+ /**
911
+ * Lorsque middleware.prefixDefault est faux, la locale par défaut n'est pas préfixée.
912
+ * Assurez-vous que la locale actuelle est valide et n'est pas la locale par défaut.
913
+ */
914
+ if (
915
+ currentLocale.toString() !== defaultLocale.toString() &&
916
+ !locales
917
+ .filter(
918
+ (loc) => loc.toString() !== defaultLocale.toString() // Exclure la locale par défaut
919
+ )
920
+ .includes(currentLocale) // Vérifier si la locale actuelle est dans la liste des locales valides
921
+ ) {
922
+ // Rediriger vers le chemin sans préfixe de locale
923
+ return <Navigate to={`${pathWithoutLocale}${search}`} replace />;
924
+ }
925
+
926
+ // Envelopper les enfants avec IntlayerProvider et définir la locale actuelle
927
+ return (
928
+ <IntlayerProvider locale={currentLocale}>{children}</IntlayerProvider>
929
+ );
930
+ }
931
+ };
932
+
933
+ const RouterContent = ({ children }) => {
934
+ const { path } = useLocation();
935
+
936
+ if (!path) {
937
+ return null;
938
+ }
939
+
940
+ const pathLocale = path.split("/")[1];
941
+
942
+ const isLocaleRoute = locales
943
+ .filter((locale) => middleware.prefixDefault || locale !== defaultLocale)
944
+ .some((locale) => locale.toString() === pathLocale);
945
+
946
+ if (isLocaleRoute) {
947
+ return <AppLocalized locale={pathLocale}>{children}</AppLocalized>;
948
+ }
949
+
950
+ return (
951
+ <AppLocalized
952
+ locale={!middleware.prefixDefault ? defaultLocale : undefined}
953
+ >
954
+ {children}
955
+ </AppLocalized>
956
+ );
957
+ };
958
+
959
+ /**
960
+ * Un composant routeur qui configure des routes spécifiques à la locale.
961
+ * Il utilise preact-iso pour gérer la navigation et rendre des composants localisés.
962
+ */
963
+ const LocaleRouter = ({ children }) => (
964
+ <LocationProvider>
965
+ <RouterContent>{children}</RouterContent>
966
+ </LocationProvider>
967
+ );
968
+
969
+ module.exports = { LocaleRouter };
970
+ ```
971
+
972
+ Ensuite, vous pouvez utiliser le composant `LocaleRouter` dans votre application :
973
+
974
+ ```tsx fileName="src/app.tsx" codeFormat="typescript"
975
+ import { LocaleRouter } from "./components/LocaleRouter";
976
+ import type { FunctionalComponent } from "preact";
977
+ // ... Votre composant AppContent (défini à l'étape 5)
978
+
979
+ const App: FunctionalComponent = () => (
980
+ <LocaleRouter>
981
+ <AppContent />
982
+ </LocaleRouter>
983
+ );
984
+
985
+ export default App;
986
+ ```
987
+
988
+ ```jsx fileName="src/app.jsx" codeFormat="esm"
989
+ import { LocaleRouter } from "./components/LocaleRouter";
990
+ // ... Votre composant AppContent (défini à l'étape 5)
991
+
992
+ const App = () => (
993
+ <LocaleRouter>
994
+ <AppContent />
995
+ </LocaleRouter>
996
+ );
997
+
998
+ export default App;
999
+ ```
1000
+
1001
+ ```jsx fileName="src/app.cjsx" codeFormat="commonjs"
1002
+ const { LocaleRouter } = require("./components/LocaleRouter");
1003
+ // ... Votre composant AppContent (défini à l'étape 5)
1004
+
1005
+ const App = () => (
1006
+ <LocaleRouter>
1007
+ <AppContent />
1008
+ </LocaleRouter>
1009
+ );
1010
+
1011
+ module.exports = App;
1012
+ ```
1013
+
1014
+ En parallèle, vous pouvez également utiliser le `intLayerMiddlewarePlugin` pour ajouter un routage côté serveur à votre application. Ce plugin détectera automatiquement la locale actuelle en fonction de l'URL et définira le cookie de locale approprié. Si aucune locale n'est spécifiée, le plugin déterminera la locale la plus appropriée en fonction des préférences linguistiques du navigateur de l'utilisateur. Si aucune locale n'est détectée, il redirigera vers la locale par défaut.
1015
+
1016
+ ```typescript {3,7} fileName="vite.config.ts" codeFormat="typescript"
1017
+ import { defineConfig } from "vite";
1018
+ import preact from "@preact/preset-vite";
1019
+ import { intlayerPlugin, intLayerMiddlewarePlugin } from "vite-intlayer";
1020
+
1021
+ // https://vitejs.dev/config/
1022
+ export default defineConfig({
1023
+ plugins: [preact(), intlayerPlugin(), intLayerMiddlewarePlugin()],
1024
+ });
1025
+ ```
1026
+
1027
+ ```javascript {3,7} fileName="vite.config.mjs" codeFormat="esm"
1028
+ import { defineConfig } from "vite";
1029
+ import preact from "@preact/preset-vite";
1030
+ import { intlayerPlugin, intLayerMiddlewarePlugin } from "vite-intlayer";
1031
+
1032
+ // https://vitejs.dev/config/
1033
+
1034
+ const { defineConfig } = require("vite");
1035
+ const preact = require("@preact/preset-vite");
1036
+ const { intlayerPlugin, intLayerMiddlewarePlugin } = require("vite-intlayer");
1037
+
1038
+ // https://vitejs.dev/config/
1039
+ module.exports = defineConfig({
1040
+ plugins: [preact(), intlayerPlugin(), intLayerMiddlewarePlugin()],
1041
+ });
1042
+ ```
1043
+
1044
+ ### (Optionnel) Étape 8 : Modifier l'URL lorsque la langue change
1045
+
1046
+ Pour modifier l'URL lorsque la langue change, vous pouvez utiliser la propriété `onLocaleChange` fournie par le hook `useLocale`. En parallèle, vous pouvez utiliser `useLocation` et `route` de `preact-iso` pour mettre à jour le chemin de l'URL.
1047
+
1048
+ ```tsx fileName="src/components/LocaleSwitcher.tsx" codeFormat="typescript"
1049
+ import { useLocation, route } from "preact-iso";
1050
+ import {
1051
+ Locales,
1052
+ getHTMLTextDir,
1053
+ getLocaleName,
1054
+ getLocalizedUrl,
1055
+ } from "intlayer";
1056
+ import { useLocale } from "preact-intlayer";
1057
+ import type { FunctionalComponent } from "preact";
1058
+
1059
+ const LocaleSwitcher: FunctionalComponent = () => {
1060
+ const location = useLocation();
1061
+ const { locale, availableLocales, setLocale } = useLocale({
1062
+ onLocaleChange: (newLocale) => {
1063
+ const currentFullPath = location.url; // preact-iso fournit l'URL complète
1064
+ // Construire l'URL avec la langue mise à jour
1065
+ // Exemple : /fr/about?foo=bar
1066
+ const pathWithLocale = getLocalizedUrl(currentFullPath, newLocale);
1067
+
1068
+ // Mettre à jour le chemin de l'URL
1069
+ route(pathWithLocale, true); // true pour remplacer
1070
+ },
1071
+ });
1072
+
1073
+ return (
1074
+ <div>
1075
+ <button popovertarget="localePopover">{getLocaleName(locale)}</button>
1076
+ <div id="localePopover" popover="auto">
1077
+ {availableLocales.map((localeItem) => (
1078
+ <a
1079
+ href={getLocalizedUrl(location.url, localeItem)}
1080
+ hreflang={localeItem}
1081
+ aria-current={locale === localeItem ? "page" : undefined}
1082
+ onClick={(e) => {
1083
+ e.preventDefault();
1084
+ setLocale(localeItem);
1085
+ // La navigation programmatique après avoir défini la langue sera gérée par onLocaleChange
1086
+ }}
1087
+ key={localeItem}
1088
+ >
1089
+ <span>
1090
+ {/* Langue - ex. FR */}
1091
+ {localeItem}
1092
+ </span>
1093
+ <span>
1094
+ {/* Langue dans sa propre locale - ex. Français */}
1095
+ {getLocaleName(localeItem, localeItem)}
1096
+ </span>
1097
+ <span dir={getHTMLTextDir(localeItem)} lang={localeItem}>
1098
+ {/* Langue dans la locale actuelle - ex. Francés avec la locale actuelle définie sur Locales.SPANISH */}
1099
+ {getLocaleName(localeItem, locale)}
1100
+ </span>
1101
+ <span dir="ltr" lang={Locales.ENGLISH}>
1102
+ {/* Langue en anglais - ex. French */}
1103
+ {getLocaleName(localeItem, Locales.ENGLISH)}
1104
+ </span>
1105
+ </a>
1106
+ ))}
1107
+ </div>
1108
+ </div>
1109
+ );
1110
+ };
1111
+
1112
+ export default LocaleSwitcher;
1113
+ ```
1114
+
1115
+ ```jsx fileName="src/components/LocaleSwitcher.jsx" codeFormat="esm"
1116
+ import { useLocation, route } from "preact-iso";
1117
+ import {
1118
+ Locales,
1119
+ getHTMLTextDir,
1120
+ getLocaleName,
1121
+ getLocalizedUrl,
1122
+ } from "intlayer";
1123
+ import { useLocale } from "preact-intlayer";
1124
+ import { h } from "preact"; // Pour JSX
1125
+
1126
+ const LocaleSwitcher = () => {
1127
+ const location = useLocation();
1128
+ const { locale, availableLocales, setLocale } = useLocale({
1129
+ onLocaleChange: (newLocale) => {
1130
+ const currentFullPath = location.url;
1131
+ const pathWithLocale = getLocalizedUrl(currentFullPath, newLocale);
1132
+ route(pathWithLocale, true);
1133
+ },
1134
+ });
1135
+
1136
+ return (
1137
+ <div>
1138
+ <button popovertarget="localePopover">{getLocaleName(locale)}</button>
1139
+ <div id="localePopover" popover="auto">
1140
+ {availableLocales.map((localeItem) => (
1141
+ <a
1142
+ href={getLocalizedUrl(location.url, localeItem)}
1143
+ hreflang={localeItem}
1144
+ aria-current={locale === localeItem ? "page" : undefined}
1145
+ onClick={(e) => {
1146
+ e.preventDefault();
1147
+ setLocale(localeItem);
1148
+ }}
1149
+ key={localeItem}
1150
+ >
1151
+ <span>{localeItem}</span>
1152
+ <span>{getLocaleName(localeItem, localeItem)}</span>
1153
+ <span dir={getHTMLTextDir(localeItem)} lang={localeItem}>
1154
+ {getLocaleName(localeItem, locale)}
1155
+ </span>
1156
+ <span dir="ltr" lang={Locales.ENGLISH}>
1157
+ {getLocaleName(localeItem, Locales.ENGLISH)}
1158
+ </span>
1159
+ </a>
1160
+ ))}
1161
+ </div>
1162
+ </div>
1163
+ );
1164
+ };
1165
+
1166
+ export default LocaleSwitcher;
1167
+ ```
1168
+
1169
+ ```jsx fileName="src/components/LocaleSwitcher.cjsx" codeFormat="commonjs"
1170
+ const { useLocation, route } = require("preact-iso");
1171
+ const {
1172
+ Locales,
1173
+ getHTMLTextDir,
1174
+ getLocaleName,
1175
+ getLocalizedUrl,
1176
+ } = require("intlayer");
1177
+ const { useLocale } = require("preact-intlayer");
1178
+ const { h } = require("preact"); // Pour JSX
1179
+
1180
+ const LocaleSwitcher = () => {
1181
+ const location = useLocation();
1182
+ const { locale, availableLocales, setLocale } = useLocale({
1183
+ onLocaleChange: (newLocale) => {
1184
+ const currentFullPath = location.url;
1185
+ const pathWithLocale = getLocalizedUrl(currentFullPath, newLocale);
1186
+ route(pathWithLocale, true);
1187
+ },
1188
+ });
1189
+
1190
+ return (
1191
+ <div>
1192
+ <button popovertarget="localePopover">{getLocaleName(locale)}</button>
1193
+ <div id="localePopover" popover="auto">
1194
+ {availableLocales.map((localeItem) => (
1195
+ <a
1196
+ href={getLocalizedUrl(location.url, localeItem)}
1197
+ hreflang={localeItem}
1198
+ aria-current={locale === localeItem ? "page" : undefined}
1199
+ onClick={(e) => {
1200
+ e.preventDefault();
1201
+ setLocale(localeItem);
1202
+ }}
1203
+ key={localeItem}
1204
+ >
1205
+ <span>{localeItem}</span>
1206
+ <span>{getLocaleName(localeItem, localeItem)}</span>
1207
+ <span dir={getHTMLTextDir(localeItem)} lang={localeItem}>
1208
+ {getLocaleName(localeItem, locale)}
1209
+ </span>
1210
+ <span dir="ltr" lang={Locales.ENGLISH}>
1211
+ {getLocaleName(localeItem, Locales.ENGLISH)}
1212
+ </span>
1213
+ </a>
1214
+ ))}
1215
+ </div>
1216
+ </div>
1217
+ );
1218
+ };
1219
+
1220
+ module.exports = LocaleSwitcher;
1221
+ ```
1222
+
1223
+ > Références de la documentation :
1224
+
1225
+ > - [`useLocale` hook](https://github.com/aymericzip/intlayer/blob/main/docs/fr/packages/react-intlayer/useLocale.md) (L'API est similaire pour `preact-intlayer`)
1226
+
1227
+ > - [`getLocaleName` hook](https://github.com/aymericzip/intlayer/blob/main/docs/fr/packages/intlayer/getLocaleName.md)
1228
+
1229
+ > - [`getLocalizedUrl` hook](https://github.com/aymericzip/intlayer/blob/main/docs/fr/packages/intlayer/getLocalizedUrl.md)
1230
+
1231
+ > - [`getHTMLTextDir` hook](https://github.com/aymericzip/intlayer/blob/main/docs/fr/packages/intlayer/getHTMLTextDir.md)
1232
+
1233
+ > - [`hreflang` attribute](https://developers.google.com/search/docs/specialty/international/localized-versions?hl=fr)
1234
+
1235
+ > - [`lang` attribute](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes/lang)
1236
+
1237
+ > - [`dir` attribute](https://developer.mozilla.org/en-US/docs/Web/HTML/Global_attributes/dir)
1238
+
1239
+ > - [`aria-current` attribute](https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Attributes/aria-current)
1240
+
1241
+ > - [Popover API](https://developer.mozilla.org/en-US/docs/Web/API/Popover_API)
1242
+
1243
+ ---
1244
+
1245
+ ### (Optionnel) Étape 9 : Changer les attributs de langue et de direction HTML
1246
+
1247
+ Lorsque votre application prend en charge plusieurs langues, il est crucial de mettre à jour les attributs `lang` et `dir` de la balise `<html>` pour correspondre à la langue actuelle. Cela garantit :
1248
+
1249
+ - **Accessibilité** : Les lecteurs d'écran et les technologies d'assistance s'appuient sur l'attribut `lang` correct pour prononcer et interpréter le contenu avec précision.
1250
+
1251
+ - **SEO** : Les moteurs de recherche utilisent l'attribut `lang` pour déterminer la langue de votre page, aidant à fournir le contenu localisé approprié dans les résultats de recherche.
1252
+
1253
+ En mettant à jour ces attributs dynamiquement lorsque la langue change, vous garantissez une expérience cohérente et accessible pour les utilisateurs dans toutes les langues prises en charge.
1254
+
1255
+ #### Implémentation du Hook
1256
+
1257
+ Créez un hook personnalisé pour gérer les attributs HTML. Le hook écoute les changements de langue et met à jour les attributs en conséquence :
1258
+
1259
+ ```tsx fileName="src/hooks/useI18nHTMLAttributes.tsx" codeFormat="typescript"
1260
+ import { useEffect } from "preact/hooks";
1261
+ import { useLocale } from "preact-intlayer";
1262
+ import { getHTMLTextDir } from "intlayer";
1263
+
1264
+ /**
1265
+ * Met à jour les attributs `lang` et `dir` de l'élément HTML <html> en fonction de la langue actuelle.
1266
+ * - `lang` : Informe les navigateurs et moteurs de recherche de la langue de la page.
1267
+ * - `dir` : Assure le bon ordre de lecture (par exemple, 'ltr' pour l'anglais, 'rtl' pour l'arabe).
1268
+ *
1269
+ * Cette mise à jour dynamique est essentielle pour un rendu correct du texte, l'accessibilité et le SEO.
1270
+ */
1271
+ export const useI18nHTMLAttributes = () => {
1272
+ const { locale } = useLocale();
1273
+
1274
+ useEffect(() => {
1275
+ // Met à jour l'attribut de langue avec la langue actuelle.
1276
+ document.documentElement.lang = locale;
1277
+
1278
+ // Définit la direction du texte en fonction de la langue actuelle.
1279
+ document.documentElement.dir = getHTMLTextDir(locale);
1280
+ }, [locale]);
1281
+ };
1282
+ ```
1283
+
1284
+ ```jsx fileName="src/hooks/useI18nHTMLAttributes.jsx" codeFormat="esm"
1285
+ import { useEffect } from "preact/hooks";
1286
+ import { useLocale } from "preact-intlayer";
1287
+ import { getHTMLTextDir } from "intlayer";
1288
+
1289
+ /**
1290
+ * Met à jour les attributs `lang` et `dir` de l'élément HTML <html> en fonction de la langue actuelle.
1291
+ */
1292
+ export const useI18nHTMLAttributes = () => {
1293
+ const { locale } = useLocale();
1294
+
1295
+ useEffect(() => {
1296
+ document.documentElement.lang = locale;
1297
+ document.documentElement.dir = getHTMLTextDir(locale);
1298
+ }, [locale]);
1299
+ };
1300
+ ```
1301
+
1302
+ ```jsx fileName="src/hooks/useI18nHTMLAttributes.cjsx" codeFormat="commonjs"
1303
+ const { useEffect } = require("preact/hooks");
1304
+ const { useLocale } = require("preact-intlayer");
1305
+ const { getHTMLTextDir } = require("intlayer");
1306
+
1307
+ /**
1308
+ * Met à jour les attributs `lang` et `dir` de l'élément HTML <html> en fonction de la langue actuelle.
1309
+ */
1310
+ const useI18nHTMLAttributes = () => {
1311
+ const { locale } = useLocale();
1312
+
1313
+ useEffect(() => {
1314
+ document.documentElement.lang = locale;
1315
+ document.documentElement.dir = getHTMLTextDir(locale);
1316
+ }, [locale]);
1317
+ };
1318
+
1319
+ module.exports = { useI18nHTMLAttributes };
1320
+ ```
1321
+
1322
+ #### Utilisation du Hook dans votre application
1323
+
1324
+ Intégrez le hook dans votre composant principal pour que les attributs HTML soient mis à jour à chaque changement de langue :
1325
+
1326
+ ```tsx fileName="src/app.tsx" codeFormat="typescript"
1327
+ import type { FunctionalComponent } from "preact";
1328
+ import { IntlayerProvider } from "preact-intlayer"; // useIntlayer déjà importé si AppContent en a besoin
1329
+ import { useI18nHTMLAttributes } from "./hooks/useI18nHTMLAttributes";
1330
+ import "./app.css";
1331
+ // Définition de AppContent depuis l'étape 5
1332
+
1333
+ const AppWithHooks: FunctionalComponent = () => {
1334
+ // Applique le hook pour mettre à jour les attributs lang et dir de la balise <html> en fonction de la langue.
1335
+ useI18nHTMLAttributes();
1336
+
1337
+ // Supposons que AppContent est votre composant principal d'affichage de contenu depuis l'étape 5
1338
+ return <AppContent />;
1339
+ };
1340
+
1341
+ const App: FunctionalComponent = () => (
1342
+ <IntlayerProvider>
1343
+ <AppWithHooks />
1344
+ </IntlayerProvider>
1345
+ );
1346
+
1347
+ export default App;
1348
+ ```
1349
+
1350
+ ```jsx fileName="src/app.jsx" codeFormat="esm"
1351
+ import { IntlayerProvider } from "preact-intlayer";
1352
+ import { useI18nHTMLAttributes } from "./hooks/useI18nHTMLAttributes";
1353
+ import "./app.css";
1354
+ // Définition de AppContent depuis l'étape 5
1355
+
1356
+ const AppWithHooks = () => {
1357
+ useI18nHTMLAttributes();
1358
+ return <AppContent />;
1359
+ };
1360
+
1361
+ const App = () => (
1362
+ <IntlayerProvider>
1363
+ <AppWithHooks />
1364
+ </IntlayerProvider>
1365
+ );
1366
+
1367
+ export default App;
1368
+ ```
1369
+
1370
+ ```jsx fileName="src/app.cjsx" codeFormat="commonjs"
1371
+ const { IntlayerProvider } = require("preact-intlayer");
1372
+ const { useI18nHTMLAttributes } = require("./hooks/useI18nHTMLAttributes");
1373
+ require("./app.css");
1374
+ // Définition de AppContent depuis l'étape 5
1375
+
1376
+ const AppWithHooks = () => {
1377
+ useI18nHTMLAttributes();
1378
+ return <AppContent />;
1379
+ };
1380
+
1381
+ const App = () => (
1382
+ <IntlayerProvider>
1383
+ <AppWithHooks />
1384
+ </IntlayerProvider>
1385
+ );
1386
+
1387
+ module.exports = App;
1388
+ ```
1389
+
1390
+ En appliquant ces modifications, votre application :
1391
+
1392
+ - Garantira que l'attribut **langue** (`lang`) reflète correctement la langue actuelle, ce qui est important pour le SEO et le comportement des navigateurs.
1393
+ - Ajustera la **direction du texte** (`dir`) en fonction de la langue, améliorant la lisibilité et l'utilisabilité pour les langues avec des ordres de lecture différents.
1394
+ - Fournira une expérience plus **accessible**, car les technologies d'assistance dépendent de ces attributs pour fonctionner de manière optimale.
1395
+
1396
+ ### (Optionnel) Étape 10 : Création d'un composant de lien localisé
1397
+
1398
+ Pour garantir que la navigation dans votre application respecte la langue actuelle, vous pouvez créer un composant `Link` personnalisé. Ce composant préfixe automatiquement les URL internes avec la langue actuelle.
1399
+
1400
+ Ce comportement est utile pour plusieurs raisons :
1401
+
1402
+ - **SEO et expérience utilisateur** : Les URL localisées aident les moteurs de recherche à indexer correctement les pages spécifiques à une langue et fournissent aux utilisateurs un contenu dans leur langue préférée.
1403
+ - **Cohérence** : En utilisant un lien localisé dans toute votre application, vous garantissez que la navigation reste dans la langue actuelle, évitant les changements de langue inattendus.
1404
+ - **Maintenabilité** : Centraliser la logique de localisation dans un seul composant simplifie la gestion des URL.
1405
+
1406
+ Pour Preact avec `preact-iso`, les balises `<a>` standard sont généralement utilisées pour la navigation, et `preact-iso` gère le routage. Si vous avez besoin d'une navigation programmatique au clic (par exemple, pour effectuer des actions avant de naviguer), vous pouvez utiliser la fonction `route` de `useLocation`. Voici comment créer un composant d'ancre personnalisé qui localise les URL :
1407
+
1408
+ ```tsx fileName="src/components/LocalizedLink.tsx" codeFormat="typescript"
1409
+ import { getLocalizedUrl } from "intlayer";
1410
+ import { useLocale, useLocation, route } from "preact-intlayer"; // Supposons que useLocation et route peuvent être de preact-iso via preact-intlayer s'ils sont réexportés, ou importés directement
1411
+ // Si non réexportés, importez directement : import { useLocation, route } from "preact-iso";
1412
+ import type { JSX } from "preact"; // Pour HTMLAttributes
1413
+ import { forwardRef } from "preact/compat"; // Pour transmettre les refs
1414
+
1415
+ export interface LocalizedLinkProps
1416
+ extends JSX.HTMLAttributes<HTMLAnchorElement> {
1417
+ href: string;
1418
+ replace?: boolean; // Optionnel : pour remplacer l'état de l'historique
1419
+ }
1420
+
1421
+ /**
1422
+ * Fonction utilitaire pour vérifier si une URL donnée est externe.
1423
+ * Si l'URL commence par http:// ou https://, elle est considérée comme externe.
1424
+ */
1425
+ export const checkIsExternalLink = (href?: string): boolean =>
1426
+ /^https?:\/\//.test(href ?? "");
1427
+
1428
+ /**
1429
+ * Un composant Link personnalisé qui adapte l'attribut href en fonction de la langue actuelle.
1430
+ * Pour les liens internes, il utilise `getLocalizedUrl` pour préfixer l'URL avec la langue (par exemple, /fr/about).
1431
+ * Cela garantit que la navigation reste dans le même contexte linguistique.
1432
+ * Il utilise une balise <a> standard mais peut déclencher une navigation côté client en utilisant la fonction `route` de preact-iso.
1433
+ */
1434
+ export const LocalizedLink = forwardRef<HTMLAnchorElement, LocalizedLinkProps>(
1435
+ ({ href, children, onClick, replace = false, ...props }, ref) => {
1436
+ const { locale } = useLocale();
1437
+ const location = useLocation(); // de preact-iso
1438
+ const isExternalLink = checkIsExternalLink(href);
1439
+
1440
+ const hrefI18n =
1441
+ href && !isExternalLink ? getLocalizedUrl(href, locale) : href;
1442
+
1443
+ const handleClick = (event: JSX.TargetedMouseEvent<HTMLAnchorElement>) => {
1444
+ if (onClick) {
1445
+ onClick(event);
1446
+ }
1447
+ if (
1448
+ !isExternalLink &&
1449
+ href && // Assurez-vous que href est défini
1450
+ event.button === 0 && // Clic gauche
1451
+ !event.metaKey &&
1452
+
1453
+ import { getLocalizedUrl } from "intlayer";
1454
+ import { useLocale } from "preact-intlayer";
1455
+ import { useLocation, route } from "preact-iso"; // Importé depuis preact-iso
1456
+ import { forwardRef } from "preact/compat";
1457
+ import { h } from "preact"; // Pour JSX
1458
+
1459
+ export const checkIsExternalLink = (href) => /^https?:\/\//.test(href ?? "");
1460
+
1461
+ export const LocalizedLink = forwardRef(
1462
+ ({ href, children, onClick, replace = false, ...props }, ref) => {
1463
+ const { locale } = useLocale();
1464
+ const location = useLocation();
1465
+ const isExternalLink = checkIsExternalLink(href);
1466
+
1467
+ const hrefI18n =
1468
+ href && !isExternalLink ? getLocalizedUrl(href, locale) : href;
1469
+
1470
+ const handleClick = (event) => {
1471
+ if (onClick) {
1472
+ onClick(event);
1473
+ }
1474
+ if (
1475
+ !isExternalLink &&
1476
+ href &&
1477
+ event.button === 0 &&
1478
+ !event.metaKey &&
1479
+ !event.ctrlKey &&
1480
+ !event.shiftKey &&
1481
+ !event.altKey &&
1482
+ !props.target
1483
+ ) {
1484
+ event.preventDefault();
1485
+ if (location.url !== hrefI18n) {
1486
+ route(hrefI18n, replace);
1487
+ }
1488
+ }
1489
+ };
1490
+
1491
+ return (
1492
+ <a href={hrefI18n} ref={ref} onClick={handleClick} {...props}>
1493
+ {children}
1494
+ </a>
1495
+ );
1496
+ }
1497
+ );
1498
+ ```
1499
+
1500
+ ```jsx fileName="src/components/LocalizedLink.cjsx" codeFormat="commonjs"
1501
+ const { getLocalizedUrl } = require("intlayer");
1502
+ const { useLocale } = require("preact-intlayer");
1503
+ const { useLocation, route } = require("preact-iso"); // Importé depuis preact-iso
1504
+ const { forwardRef } = require("preact/compat");
1505
+ const { h } = require("preact"); // Pour JSX
1506
+
1507
+ const checkIsExternalLink = (href) => /^https?:\/\//.test(href ?? "");
1508
+
1509
+ const LocalizedLink = forwardRef(
1510
+ ({ href, children, onClick, replace = false, ...props }, ref) => {
1511
+ const { locale } = useLocale();
1512
+ const location = useLocation();
1513
+ const isExternalLink = checkIsExternalLink(href);
1514
+
1515
+ const hrefI18n =
1516
+ href && !isExternalLink ? getLocalizedUrl(href, locale) : href;
1517
+
1518
+ const handleClick = (event) => {
1519
+ if (onClick) {
1520
+ onClick(event);
1521
+ }
1522
+ if (
1523
+ !isExternalLink &&
1524
+ href &&
1525
+ event.button === 0 &&
1526
+ !event.metaKey &&
1527
+ !event.ctrlKey &&
1528
+ !event.shiftKey &&
1529
+ !event.altKey &&
1530
+ !props.target
1531
+ ) {
1532
+ event.preventDefault();
1533
+ if (location.url !== hrefI18n) {
1534
+ route(hrefI18n, replace);
1535
+ }
1536
+ }
1537
+ };
1538
+
1539
+ return (
1540
+ <a href={hrefI18n} ref={ref} onClick={handleClick} {...props}>
1541
+ {children}
1542
+ </a>
1543
+ );
1544
+ }
1545
+ );
1546
+
1547
+ module.exports = { LocalizedLink, checkIsExternalLink };
1548
+ ```
1549
+
1550
+ #### Comment cela fonctionne
1551
+
1552
+ - **Détection des liens externes** :
1553
+ La fonction utilitaire `checkIsExternalLink` détermine si une URL est externe. Les liens externes ne sont pas modifiés.
1554
+ - **Récupération de la locale actuelle** :
1555
+ Le hook `useLocale` fournit la locale actuelle.
1556
+ - **Localisation de l'URL** :
1557
+ Pour les liens internes, `getLocalizedUrl` ajoute un préfixe à l'URL avec la locale actuelle.
1558
+ - **Navigation côté client** :
1559
+ La fonction `handleClick` vérifie s'il s'agit d'un lien interne et si la navigation standard doit être empêchée. Si c'est le cas, elle utilise la fonction `route` de `preact-iso` (obtenue via `useLocation` ou directement importée) pour effectuer une navigation côté client. Cela permet un comportement de type SPA sans rechargement complet de la page.
1560
+ - **Retour du lien** :
1561
+ Le composant retourne un élément `<a>` avec l'URL localisée et le gestionnaire de clic personnalisé.
1562
+
1563
+ ### Configurer TypeScript
1564
+
1565
+ Intlayer utilise l'augmentation de module pour tirer parti de TypeScript et renforcer votre base de code.
1566
+
1567
+ ![alt text](https://github.com/aymericzip/intlayer/blob/main/docs/assets/autocompletion.png)
1568
+
1569
+ ![alt text](https://github.com/aymericzip/intlayer/blob/main/docs/assets/translation_error.png)
1570
+
1571
+ Assurez-vous que votre configuration TypeScript inclut les types générés automatiquement.
1572
+
1573
+ ```json5 fileName="tsconfig.json"
1574
+ {
1575
+ // ... Vos configurations TypeScript existantes
1576
+ "compilerOptions": {
1577
+ // ...
1578
+ "jsx": "react-jsx",
1579
+ "jsxImportSource": "preact", // Recommandé pour Preact 10+
1580
+ // ...
1581
+ },
1582
+ "include": [
1583
+ // ... Vos configurations TypeScript existantes
1584
+ ".intlayer/**/*.ts", // Inclure les types générés automatiquement
1585
+ ],
1586
+ }
1587
+ ```
1588
+
1589
+ > Assurez-vous que votre `tsconfig.json` est configuré pour Preact, en particulier `jsx` et `jsxImportSource` ou `jsxFactory`/`jsxFragmentFactory` pour les anciennes versions de Preact si vous n'utilisez pas les paramètres par défaut de `preset-vite`.
1590
+
1591
+ ### Configuration Git
1592
+
1593
+ Il est recommandé d'ignorer les fichiers générés par Intlayer. Cela vous permet d'éviter de les ajouter à votre dépôt Git.
1594
+
1595
+ Pour ce faire, vous pouvez ajouter les instructions suivantes à votre fichier `.gitignore` :
1596
+
1597
+ ```plaintext
1598
+ # Ignorer les fichiers générés par Intlayer
1599
+ .intlayer
1600
+ ```
1601
+
1602
+ ### Extension VS Code
1603
+
1604
+ Pour améliorer votre expérience de développement avec Intlayer, vous pouvez installer l'extension officielle **Intlayer VS Code Extension**.
1605
+
1606
+ [Installer depuis le VS Code Marketplace](https://marketplace.visualstudio.com/items?itemName=intlayer.intlayer-vs-code-extension)
1607
+
1608
+ Cette extension fournit :
1609
+
1610
+ - **Autocomplétion** pour les clés de traduction.
1611
+ - **Détection d'erreurs en temps réel** pour les traductions manquantes.
1612
+ - **Aperçus en ligne** du contenu traduit.
1613
+ - **Actions rapides** pour créer et mettre à jour facilement les traductions.
1614
+
1615
+ Pour plus de détails sur l'utilisation de l'extension, consultez la [documentation de l'extension Intlayer VS Code](https://intlayer.org/doc/vs-code-extension).
1616
+
1617
+ ---
1618
+
1619
+ ### Aller plus loin
1620
+
1621
+ Pour aller plus loin, vous pouvez implémenter l'[éditeur visuel](https://github.com/aymericzip/intlayer/blob/main/docs/fr/intlayer_visual_editor.md) ou externaliser votre contenu en utilisant le [CMS](https://github.com/aymericzip/intlayer/blob/main/docs/fr/intlayer_CMS.md).