@intlayer/docs 8.9.8 → 8.10.0-canary.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (792) hide show
  1. package/README.md +14 -0
  2. package/docs/ar/benchmark/nextjs.md +20 -11
  3. package/docs/ar/benchmark/solid.md +14 -5
  4. package/docs/ar/benchmark/svelte.md +14 -5
  5. package/docs/ar/benchmark/tanstack.md +16 -7
  6. package/docs/ar/benchmark/vue.md +14 -5
  7. package/docs/ar/configuration.md +6 -6
  8. package/docs/ar/custom_domains.md +11 -11
  9. package/docs/ar/dictionary/content_file.md +41 -0
  10. package/docs/ar/dictionary/markdown.md +402 -82
  11. package/docs/ar/intlayer_with_analog.md +1 -1
  12. package/docs/ar/intlayer_with_angular.md +1 -1
  13. package/docs/ar/intlayer_with_astro.md +1 -1
  14. package/docs/ar/intlayer_with_astro_lit.md +2 -2
  15. package/docs/ar/intlayer_with_astro_preact.md +3 -3
  16. package/docs/ar/intlayer_with_astro_react.md +2 -2
  17. package/docs/ar/intlayer_with_astro_solid.md +3 -3
  18. package/docs/ar/intlayer_with_astro_svelte.md +1 -1
  19. package/docs/ar/intlayer_with_astro_vanilla.md +1 -1
  20. package/docs/ar/intlayer_with_astro_vue.md +1 -1
  21. package/docs/ar/intlayer_with_nextjs_14.md +2 -2
  22. package/docs/ar/intlayer_with_nextjs_15.md +2 -2
  23. package/docs/ar/intlayer_with_nextjs_16.md +1 -1
  24. package/docs/ar/intlayer_with_nextjs_page_router.md +2 -2
  25. package/docs/ar/intlayer_with_nuxt.md +1 -1
  26. package/docs/ar/intlayer_with_react_native+expo.md +2 -2
  27. package/docs/ar/intlayer_with_react_router_v7.md +1 -1
  28. package/docs/ar/intlayer_with_react_router_v7_fs_routes.md +1 -1
  29. package/docs/ar/intlayer_with_storybook.md +7 -7
  30. package/docs/ar/intlayer_with_svelte_kit.md +1 -1
  31. package/docs/ar/intlayer_with_tanstack+solid.md +1 -1
  32. package/docs/ar/intlayer_with_tanstack.md +1 -1
  33. package/docs/ar/intlayer_with_vanilla.md +2 -2
  34. package/docs/ar/intlayer_with_vite+lit.md +1 -1
  35. package/docs/ar/intlayer_with_vite+preact.md +1 -1
  36. package/docs/ar/intlayer_with_vite+react.md +1 -1
  37. package/docs/ar/intlayer_with_vite+react_compiler.md +1 -1
  38. package/docs/ar/intlayer_with_vite+svelte.md +2 -2
  39. package/docs/ar/intlayer_with_vite+vanilla.md +4 -4
  40. package/docs/ar/intlayer_with_vite+vue.md +1 -1
  41. package/docs/ar/readme.md +13 -0
  42. package/docs/bn/cli/init.md +1 -1
  43. package/docs/bn/configuration.md +6 -6
  44. package/docs/bn/custom_domains.md +11 -11
  45. package/docs/bn/intlayer_with_storybook.md +7 -7
  46. package/docs/bn/intlayer_with_vanilla.md +2 -2
  47. package/docs/bn/intlayer_with_vite+lit.md +3 -3
  48. package/docs/bn/intlayer_with_vite+vanilla.md +5 -5
  49. package/docs/cs/cli/init.md +1 -1
  50. package/docs/cs/configuration.md +6 -6
  51. package/docs/cs/custom_domains.md +11 -11
  52. package/docs/cs/intlayer_with_storybook.md +7 -7
  53. package/docs/cs/intlayer_with_vanilla.md +2 -2
  54. package/docs/cs/intlayer_with_vite+lit.md +3 -3
  55. package/docs/cs/intlayer_with_vite+vanilla.md +5 -5
  56. package/docs/de/benchmark/nextjs.md +15 -6
  57. package/docs/de/benchmark/solid.md +14 -5
  58. package/docs/de/benchmark/svelte.md +14 -5
  59. package/docs/de/benchmark/tanstack.md +15 -6
  60. package/docs/de/benchmark/vue.md +14 -5
  61. package/docs/de/configuration.md +6 -6
  62. package/docs/de/custom_domains.md +11 -11
  63. package/docs/de/dictionary/content_file.md +41 -0
  64. package/docs/de/dictionary/markdown.md +297 -91
  65. package/docs/de/intlayer_with_analog.md +1 -1
  66. package/docs/de/intlayer_with_angular.md +1 -1
  67. package/docs/de/intlayer_with_astro.md +1 -1
  68. package/docs/de/intlayer_with_astro_lit.md +2 -2
  69. package/docs/de/intlayer_with_astro_preact.md +3 -3
  70. package/docs/de/intlayer_with_astro_react.md +2 -2
  71. package/docs/de/intlayer_with_astro_solid.md +3 -3
  72. package/docs/de/intlayer_with_astro_svelte.md +1 -1
  73. package/docs/de/intlayer_with_astro_vanilla.md +1 -1
  74. package/docs/de/intlayer_with_astro_vue.md +1 -1
  75. package/docs/de/intlayer_with_nextjs_14.md +2 -2
  76. package/docs/de/intlayer_with_nextjs_15.md +2 -2
  77. package/docs/de/intlayer_with_nextjs_16.md +1 -1
  78. package/docs/de/intlayer_with_nextjs_page_router.md +2 -2
  79. package/docs/de/intlayer_with_nuxt.md +1 -1
  80. package/docs/de/intlayer_with_react_native+expo.md +2 -2
  81. package/docs/de/intlayer_with_react_router_v7.md +1 -1
  82. package/docs/de/intlayer_with_react_router_v7_fs_routes.md +1 -1
  83. package/docs/de/intlayer_with_storybook.md +7 -7
  84. package/docs/de/intlayer_with_svelte_kit.md +1 -1
  85. package/docs/de/intlayer_with_tanstack+solid.md +1 -1
  86. package/docs/de/intlayer_with_tanstack.md +1 -1
  87. package/docs/de/intlayer_with_vanilla.md +2 -2
  88. package/docs/de/intlayer_with_vite+lit.md +2 -2
  89. package/docs/de/intlayer_with_vite+preact.md +2 -2
  90. package/docs/de/intlayer_with_vite+react.md +2 -2
  91. package/docs/de/intlayer_with_vite+react_compiler.md +2 -2
  92. package/docs/de/intlayer_with_vite+solid.md +1 -1
  93. package/docs/de/intlayer_with_vite+svelte.md +3 -3
  94. package/docs/de/intlayer_with_vite+vanilla.md +5 -5
  95. package/docs/de/intlayer_with_vite+vue.md +2 -2
  96. package/docs/de/readme.md +13 -0
  97. package/docs/en/agent_skills.md +2 -2
  98. package/docs/en/benchmark/___nextjs.md +1 -1
  99. package/docs/en/benchmark/___tanstack.md +2 -2
  100. package/docs/en/benchmark/nextjs.md +11 -2
  101. package/docs/en/benchmark/solid.md +10 -1
  102. package/docs/en/benchmark/svelte.md +10 -1
  103. package/docs/en/benchmark/tanstack.md +10 -1
  104. package/docs/en/benchmark/vue.md +10 -1
  105. package/docs/en/configuration.md +7 -7
  106. package/docs/en/custom_domains.md +11 -11
  107. package/docs/en/dictionary/content_file.md +41 -0
  108. package/docs/en/dictionary/markdown.md +259 -26
  109. package/docs/en/intlayer_with_analog.md +1 -1
  110. package/docs/en/intlayer_with_angular.md +1 -1
  111. package/docs/en/intlayer_with_astro.md +1 -1
  112. package/docs/en/intlayer_with_astro_lit.md +4 -4
  113. package/docs/en/intlayer_with_astro_preact.md +3 -3
  114. package/docs/en/intlayer_with_astro_react.md +2 -2
  115. package/docs/en/intlayer_with_astro_solid.md +3 -3
  116. package/docs/en/intlayer_with_astro_svelte.md +1 -1
  117. package/docs/en/intlayer_with_astro_vanilla.md +1 -1
  118. package/docs/en/intlayer_with_astro_vue.md +1 -1
  119. package/docs/en/intlayer_with_nextjs_14.md +1 -1
  120. package/docs/en/intlayer_with_nextjs_15.md +1 -1
  121. package/docs/en/intlayer_with_nextjs_page_router.md +2 -2
  122. package/docs/en/intlayer_with_nuxt.md +1 -1
  123. package/docs/en/intlayer_with_react_native+expo.md +1 -1
  124. package/docs/en/intlayer_with_react_router_v7.md +1 -1
  125. package/docs/en/intlayer_with_react_router_v7_fs_routes.md +1 -1
  126. package/docs/en/intlayer_with_storybook.md +7 -7
  127. package/docs/en/intlayer_with_svelte_kit.md +1 -1
  128. package/docs/en/intlayer_with_tanstack+solid.md +1 -1
  129. package/docs/en/intlayer_with_tanstack.md +1 -1
  130. package/docs/en/intlayer_with_vanilla.md +2 -2
  131. package/docs/en/intlayer_with_vite+lit.md +2 -2
  132. package/docs/en/intlayer_with_vite+preact.md +1 -1
  133. package/docs/en/intlayer_with_vite+react.md +1 -1
  134. package/docs/en/intlayer_with_vite+react_compiler.md +1 -1
  135. package/docs/en/intlayer_with_vite+svelte.md +2 -2
  136. package/docs/en/intlayer_with_vite+vanilla.md +4 -4
  137. package/docs/en/intlayer_with_vite+vue.md +1 -1
  138. package/docs/en/readme.md +13 -0
  139. package/docs/en-GB/agent_skills.md +2 -2
  140. package/docs/en-GB/benchmark/nextjs.md +16 -7
  141. package/docs/en-GB/benchmark/solid.md +14 -5
  142. package/docs/en-GB/benchmark/svelte.md +14 -5
  143. package/docs/en-GB/benchmark/tanstack.md +16 -7
  144. package/docs/en-GB/benchmark/vue.md +14 -5
  145. package/docs/en-GB/cli/init.md +1 -1
  146. package/docs/en-GB/configuration.md +7 -7
  147. package/docs/en-GB/custom_domains.md +11 -11
  148. package/docs/en-GB/dictionary/content_file.md +41 -0
  149. package/docs/en-GB/dictionary/markdown.md +377 -57
  150. package/docs/en-GB/intlayer_with_analog.md +1 -1
  151. package/docs/en-GB/intlayer_with_angular.md +1 -1
  152. package/docs/en-GB/intlayer_with_astro.md +1 -1
  153. package/docs/en-GB/intlayer_with_astro_lit.md +2 -2
  154. package/docs/en-GB/intlayer_with_astro_preact.md +3 -3
  155. package/docs/en-GB/intlayer_with_astro_react.md +2 -2
  156. package/docs/en-GB/intlayer_with_astro_solid.md +3 -3
  157. package/docs/en-GB/intlayer_with_astro_svelte.md +1 -1
  158. package/docs/en-GB/intlayer_with_astro_vanilla.md +1 -1
  159. package/docs/en-GB/intlayer_with_astro_vue.md +1 -1
  160. package/docs/en-GB/intlayer_with_nextjs_14.md +2 -2
  161. package/docs/en-GB/intlayer_with_nextjs_15.md +2 -2
  162. package/docs/en-GB/intlayer_with_nextjs_16.md +1 -1
  163. package/docs/en-GB/intlayer_with_nextjs_page_router.md +2 -2
  164. package/docs/en-GB/intlayer_with_nuxt.md +1 -1
  165. package/docs/en-GB/intlayer_with_react_native+expo.md +2 -2
  166. package/docs/en-GB/intlayer_with_react_router_v7.md +1 -1
  167. package/docs/en-GB/intlayer_with_react_router_v7_fs_routes.md +1 -1
  168. package/docs/en-GB/intlayer_with_storybook.md +7 -7
  169. package/docs/en-GB/intlayer_with_svelte_kit.md +1 -1
  170. package/docs/en-GB/intlayer_with_tanstack+solid.md +1 -1
  171. package/docs/en-GB/intlayer_with_tanstack.md +1 -1
  172. package/docs/en-GB/intlayer_with_vanilla.md +2 -2
  173. package/docs/en-GB/intlayer_with_vite+lit.md +2 -2
  174. package/docs/en-GB/intlayer_with_vite+preact.md +1 -1
  175. package/docs/en-GB/intlayer_with_vite+react.md +1 -1
  176. package/docs/en-GB/intlayer_with_vite+react_compiler.md +1 -1
  177. package/docs/en-GB/intlayer_with_vite+svelte.md +2 -2
  178. package/docs/en-GB/intlayer_with_vite+vanilla.md +4 -4
  179. package/docs/en-GB/intlayer_with_vite+vue.md +1 -1
  180. package/docs/en-GB/readme.md +13 -0
  181. package/docs/es/agent_skills.md +2 -2
  182. package/docs/es/benchmark/nextjs.md +15 -6
  183. package/docs/es/benchmark/solid.md +14 -5
  184. package/docs/es/benchmark/svelte.md +14 -5
  185. package/docs/es/benchmark/tanstack.md +15 -6
  186. package/docs/es/benchmark/vue.md +14 -5
  187. package/docs/es/configuration.md +1 -1
  188. package/docs/es/custom_domains.md +11 -11
  189. package/docs/es/dictionary/content_file.md +41 -0
  190. package/docs/es/dictionary/markdown.md +316 -110
  191. package/docs/es/intlayer_with_analog.md +1 -1
  192. package/docs/es/intlayer_with_angular.md +1 -1
  193. package/docs/es/intlayer_with_astro.md +1 -1
  194. package/docs/es/intlayer_with_astro_lit.md +2 -2
  195. package/docs/es/intlayer_with_astro_preact.md +3 -3
  196. package/docs/es/intlayer_with_astro_react.md +2 -2
  197. package/docs/es/intlayer_with_astro_solid.md +3 -3
  198. package/docs/es/intlayer_with_astro_svelte.md +1 -1
  199. package/docs/es/intlayer_with_astro_vanilla.md +1 -1
  200. package/docs/es/intlayer_with_astro_vue.md +1 -1
  201. package/docs/es/intlayer_with_nextjs_14.md +2 -2
  202. package/docs/es/intlayer_with_nextjs_15.md +2 -2
  203. package/docs/es/intlayer_with_nextjs_16.md +1 -1
  204. package/docs/es/intlayer_with_nextjs_page_router.md +2 -2
  205. package/docs/es/intlayer_with_nuxt.md +1 -1
  206. package/docs/es/intlayer_with_react_native+expo.md +2 -2
  207. package/docs/es/intlayer_with_react_router_v7.md +1 -1
  208. package/docs/es/intlayer_with_react_router_v7_fs_routes.md +1 -1
  209. package/docs/es/intlayer_with_storybook.md +5 -5
  210. package/docs/es/intlayer_with_svelte_kit.md +1 -1
  211. package/docs/es/intlayer_with_tanstack+solid.md +1 -1
  212. package/docs/es/intlayer_with_tanstack.md +1 -1
  213. package/docs/es/intlayer_with_vanilla.md +2 -2
  214. package/docs/es/intlayer_with_vite+lit.md +2 -2
  215. package/docs/es/intlayer_with_vite+preact.md +2 -2
  216. package/docs/es/intlayer_with_vite+react.md +2 -2
  217. package/docs/es/intlayer_with_vite+react_compiler.md +2 -2
  218. package/docs/es/intlayer_with_vite+solid.md +1 -1
  219. package/docs/es/intlayer_with_vite+svelte.md +3 -3
  220. package/docs/es/intlayer_with_vite+vanilla.md +4 -4
  221. package/docs/es/intlayer_with_vite+vue.md +2 -2
  222. package/docs/es/readme.md +13 -0
  223. package/docs/fr/agent_skills.md +2 -2
  224. package/docs/fr/benchmark/nextjs.md +20 -11
  225. package/docs/fr/benchmark/solid.md +14 -5
  226. package/docs/fr/benchmark/svelte.md +14 -5
  227. package/docs/fr/benchmark/tanstack.md +16 -7
  228. package/docs/fr/benchmark/vue.md +14 -5
  229. package/docs/fr/configuration.md +6 -6
  230. package/docs/fr/custom_domains.md +11 -11
  231. package/docs/fr/dictionary/content_file.md +41 -0
  232. package/docs/fr/dictionary/markdown.md +320 -114
  233. package/docs/fr/intlayer_with_analog.md +1 -1
  234. package/docs/fr/intlayer_with_angular.md +1 -1
  235. package/docs/fr/intlayer_with_astro.md +1 -1
  236. package/docs/fr/intlayer_with_astro_lit.md +4 -4
  237. package/docs/fr/intlayer_with_astro_preact.md +3 -3
  238. package/docs/fr/intlayer_with_astro_react.md +2 -2
  239. package/docs/fr/intlayer_with_astro_solid.md +3 -3
  240. package/docs/fr/intlayer_with_astro_svelte.md +1 -1
  241. package/docs/fr/intlayer_with_astro_vanilla.md +1 -1
  242. package/docs/fr/intlayer_with_astro_vue.md +1 -1
  243. package/docs/fr/intlayer_with_nextjs_14.md +2 -2
  244. package/docs/fr/intlayer_with_nextjs_15.md +2 -2
  245. package/docs/fr/intlayer_with_nextjs_16.md +1 -1
  246. package/docs/fr/intlayer_with_nextjs_page_router.md +2 -2
  247. package/docs/fr/intlayer_with_nuxt.md +1 -1
  248. package/docs/fr/intlayer_with_react_native+expo.md +2 -2
  249. package/docs/fr/intlayer_with_react_router_v7.md +1 -1
  250. package/docs/fr/intlayer_with_react_router_v7_fs_routes.md +1 -1
  251. package/docs/fr/intlayer_with_storybook.md +7 -7
  252. package/docs/fr/intlayer_with_svelte_kit.md +1 -1
  253. package/docs/fr/intlayer_with_tanstack+solid.md +1 -1
  254. package/docs/fr/intlayer_with_tanstack.md +1 -1
  255. package/docs/fr/intlayer_with_vanilla.md +2 -2
  256. package/docs/fr/intlayer_with_vite+lit.md +3 -3
  257. package/docs/fr/intlayer_with_vite+preact.md +2 -2
  258. package/docs/fr/intlayer_with_vite+react.md +2 -2
  259. package/docs/fr/intlayer_with_vite+react_compiler.md +2 -2
  260. package/docs/fr/intlayer_with_vite+solid.md +1 -1
  261. package/docs/fr/intlayer_with_vite+svelte.md +3 -3
  262. package/docs/fr/intlayer_with_vite+vanilla.md +5 -5
  263. package/docs/fr/intlayer_with_vite+vue.md +2 -2
  264. package/docs/fr/readme.md +15 -0
  265. package/docs/hi/benchmark/nextjs.md +20 -11
  266. package/docs/hi/benchmark/solid.md +14 -5
  267. package/docs/hi/benchmark/svelte.md +14 -5
  268. package/docs/hi/benchmark/tanstack.md +16 -7
  269. package/docs/hi/benchmark/vue.md +14 -5
  270. package/docs/hi/cli/init.md +1 -1
  271. package/docs/hi/configuration.md +6 -6
  272. package/docs/hi/custom_domains.md +11 -11
  273. package/docs/hi/dictionary/content_file.md +41 -0
  274. package/docs/hi/dictionary/markdown.md +394 -74
  275. package/docs/hi/intlayer_with_analog.md +1 -1
  276. package/docs/hi/intlayer_with_angular.md +1 -1
  277. package/docs/hi/intlayer_with_astro.md +1 -1
  278. package/docs/hi/intlayer_with_astro_lit.md +2 -2
  279. package/docs/hi/intlayer_with_astro_preact.md +3 -3
  280. package/docs/hi/intlayer_with_astro_react.md +2 -2
  281. package/docs/hi/intlayer_with_astro_solid.md +3 -3
  282. package/docs/hi/intlayer_with_astro_svelte.md +1 -1
  283. package/docs/hi/intlayer_with_astro_vanilla.md +1 -1
  284. package/docs/hi/intlayer_with_astro_vue.md +1 -1
  285. package/docs/hi/intlayer_with_nextjs_14.md +2 -2
  286. package/docs/hi/intlayer_with_nextjs_15.md +2 -2
  287. package/docs/hi/intlayer_with_nextjs_16.md +1 -1
  288. package/docs/hi/intlayer_with_nextjs_page_router.md +2 -2
  289. package/docs/hi/intlayer_with_nuxt.md +1 -1
  290. package/docs/hi/intlayer_with_react_native+expo.md +2 -2
  291. package/docs/hi/intlayer_with_react_router_v7.md +1 -1
  292. package/docs/hi/intlayer_with_react_router_v7_fs_routes.md +1 -1
  293. package/docs/hi/intlayer_with_storybook.md +7 -7
  294. package/docs/hi/intlayer_with_svelte_kit.md +1 -1
  295. package/docs/hi/intlayer_with_tanstack+solid.md +1 -1
  296. package/docs/hi/intlayer_with_tanstack.md +1 -1
  297. package/docs/hi/intlayer_with_vanilla.md +2 -2
  298. package/docs/hi/intlayer_with_vite+lit.md +3 -3
  299. package/docs/hi/intlayer_with_vite+preact.md +2 -2
  300. package/docs/hi/intlayer_with_vite+react.md +2 -2
  301. package/docs/hi/intlayer_with_vite+react_compiler.md +2 -2
  302. package/docs/hi/intlayer_with_vite+solid.md +1 -1
  303. package/docs/hi/intlayer_with_vite+svelte.md +3 -3
  304. package/docs/hi/intlayer_with_vite+vanilla.md +5 -5
  305. package/docs/hi/intlayer_with_vite+vue.md +2 -2
  306. package/docs/hi/readme.md +14 -1
  307. package/docs/id/agent_skills.md +2 -2
  308. package/docs/id/benchmark/nextjs.md +20 -11
  309. package/docs/id/benchmark/solid.md +14 -5
  310. package/docs/id/benchmark/svelte.md +14 -5
  311. package/docs/id/benchmark/tanstack.md +16 -7
  312. package/docs/id/benchmark/vue.md +14 -5
  313. package/docs/id/cli/init.md +1 -1
  314. package/docs/id/configuration.md +6 -6
  315. package/docs/id/custom_domains.md +11 -11
  316. package/docs/id/dictionary/content_file.md +41 -0
  317. package/docs/id/dictionary/markdown.md +398 -78
  318. package/docs/id/intlayer_with_analog.md +1 -1
  319. package/docs/id/intlayer_with_angular.md +1 -1
  320. package/docs/id/intlayer_with_astro.md +1 -1
  321. package/docs/id/intlayer_with_astro_lit.md +2 -2
  322. package/docs/id/intlayer_with_astro_preact.md +3 -3
  323. package/docs/id/intlayer_with_astro_react.md +2 -2
  324. package/docs/id/intlayer_with_astro_solid.md +3 -3
  325. package/docs/id/intlayer_with_astro_svelte.md +1 -1
  326. package/docs/id/intlayer_with_astro_vanilla.md +1 -1
  327. package/docs/id/intlayer_with_astro_vue.md +1 -1
  328. package/docs/id/intlayer_with_nextjs_14.md +1 -1
  329. package/docs/id/intlayer_with_nextjs_15.md +1 -1
  330. package/docs/id/intlayer_with_nextjs_16.md +1 -1
  331. package/docs/id/intlayer_with_nextjs_page_router.md +2 -2
  332. package/docs/id/intlayer_with_nuxt.md +1 -1
  333. package/docs/id/intlayer_with_react_native+expo.md +1 -1
  334. package/docs/id/intlayer_with_react_router_v7.md +1 -1
  335. package/docs/id/intlayer_with_react_router_v7_fs_routes.md +1 -1
  336. package/docs/id/intlayer_with_storybook.md +7 -7
  337. package/docs/id/intlayer_with_svelte_kit.md +1 -1
  338. package/docs/id/intlayer_with_tanstack+solid.md +1 -1
  339. package/docs/id/intlayer_with_tanstack.md +1 -1
  340. package/docs/id/intlayer_with_vanilla.md +2 -2
  341. package/docs/id/intlayer_with_vite+lit.md +2 -2
  342. package/docs/id/intlayer_with_vite+preact.md +1 -1
  343. package/docs/id/intlayer_with_vite+react.md +1 -1
  344. package/docs/id/intlayer_with_vite+react_compiler.md +1 -1
  345. package/docs/id/intlayer_with_vite+svelte.md +2 -2
  346. package/docs/id/intlayer_with_vite+vanilla.md +4 -4
  347. package/docs/id/intlayer_with_vite+vue.md +1 -1
  348. package/docs/id/readme.md +13 -0
  349. package/docs/it/benchmark/nextjs.md +18 -9
  350. package/docs/it/benchmark/solid.md +14 -5
  351. package/docs/it/benchmark/svelte.md +14 -5
  352. package/docs/it/benchmark/tanstack.md +16 -7
  353. package/docs/it/benchmark/vue.md +14 -5
  354. package/docs/it/configuration.md +6 -6
  355. package/docs/it/custom_domains.md +11 -11
  356. package/docs/it/dictionary/content_file.md +41 -0
  357. package/docs/it/dictionary/markdown.md +318 -117
  358. package/docs/it/intlayer_with_analog.md +1 -1
  359. package/docs/it/intlayer_with_angular.md +1 -1
  360. package/docs/it/intlayer_with_astro.md +1 -1
  361. package/docs/it/intlayer_with_astro_lit.md +2 -2
  362. package/docs/it/intlayer_with_astro_preact.md +3 -3
  363. package/docs/it/intlayer_with_astro_react.md +2 -2
  364. package/docs/it/intlayer_with_astro_solid.md +3 -3
  365. package/docs/it/intlayer_with_astro_svelte.md +1 -1
  366. package/docs/it/intlayer_with_astro_vanilla.md +1 -1
  367. package/docs/it/intlayer_with_astro_vue.md +1 -1
  368. package/docs/it/intlayer_with_nextjs_14.md +2 -2
  369. package/docs/it/intlayer_with_nextjs_15.md +2 -2
  370. package/docs/it/intlayer_with_nextjs_16.md +1 -1
  371. package/docs/it/intlayer_with_nextjs_page_router.md +2 -2
  372. package/docs/it/intlayer_with_nuxt.md +1 -1
  373. package/docs/it/intlayer_with_react_native+expo.md +2 -2
  374. package/docs/it/intlayer_with_react_router_v7.md +1 -1
  375. package/docs/it/intlayer_with_react_router_v7_fs_routes.md +1 -1
  376. package/docs/it/intlayer_with_storybook.md +7 -7
  377. package/docs/it/intlayer_with_svelte_kit.md +1 -1
  378. package/docs/it/intlayer_with_tanstack+solid.md +1 -1
  379. package/docs/it/intlayer_with_tanstack.md +1 -1
  380. package/docs/it/intlayer_with_vanilla.md +2 -2
  381. package/docs/it/intlayer_with_vite+lit.md +2 -2
  382. package/docs/it/intlayer_with_vite+preact.md +2 -2
  383. package/docs/it/intlayer_with_vite+react.md +2 -2
  384. package/docs/it/intlayer_with_vite+react_compiler.md +2 -2
  385. package/docs/it/intlayer_with_vite+solid.md +1 -1
  386. package/docs/it/intlayer_with_vite+svelte.md +3 -3
  387. package/docs/it/intlayer_with_vite+vanilla.md +5 -5
  388. package/docs/it/intlayer_with_vite+vue.md +1 -1
  389. package/docs/it/readme.md +13 -0
  390. package/docs/ja/benchmark/nextjs.md +15 -6
  391. package/docs/ja/benchmark/solid.md +10 -1
  392. package/docs/ja/benchmark/svelte.md +10 -1
  393. package/docs/ja/benchmark/tanstack.md +15 -6
  394. package/docs/ja/benchmark/vue.md +10 -1
  395. package/docs/ja/configuration.md +1 -1
  396. package/docs/ja/custom_domains.md +9 -9
  397. package/docs/ja/dictionary/content_file.md +41 -0
  398. package/docs/ja/intlayer_with_analog.md +1 -1
  399. package/docs/ja/intlayer_with_angular.md +1 -1
  400. package/docs/ja/intlayer_with_astro.md +1 -1
  401. package/docs/ja/intlayer_with_astro_lit.md +2 -2
  402. package/docs/ja/intlayer_with_astro_preact.md +2 -2
  403. package/docs/ja/intlayer_with_astro_react.md +1 -1
  404. package/docs/ja/intlayer_with_astro_solid.md +1 -1
  405. package/docs/ja/intlayer_with_astro_svelte.md +1 -1
  406. package/docs/ja/intlayer_with_astro_vanilla.md +1 -1
  407. package/docs/ja/intlayer_with_astro_vue.md +1 -1
  408. package/docs/ja/intlayer_with_nextjs_14.md +2 -2
  409. package/docs/ja/intlayer_with_nextjs_15.md +2 -2
  410. package/docs/ja/intlayer_with_nextjs_16.md +1 -1
  411. package/docs/ja/intlayer_with_nextjs_page_router.md +2 -2
  412. package/docs/ja/intlayer_with_nuxt.md +1 -1
  413. package/docs/ja/intlayer_with_react_native+expo.md +2 -2
  414. package/docs/ja/intlayer_with_react_router_v7.md +2 -2
  415. package/docs/ja/intlayer_with_react_router_v7_fs_routes.md +1 -1
  416. package/docs/ja/intlayer_with_storybook.md +5 -5
  417. package/docs/ja/intlayer_with_svelte_kit.md +1 -1
  418. package/docs/ja/intlayer_with_tanstack+solid.md +1 -1
  419. package/docs/ja/intlayer_with_tanstack.md +1 -1
  420. package/docs/ja/intlayer_with_vanilla.md +2 -2
  421. package/docs/ja/intlayer_with_vite+lit.md +1 -1
  422. package/docs/ja/intlayer_with_vite+preact.md +1 -1
  423. package/docs/ja/intlayer_with_vite+react.md +1 -1
  424. package/docs/ja/intlayer_with_vite+react_compiler.md +1 -1
  425. package/docs/ja/intlayer_with_vite+svelte.md +2 -2
  426. package/docs/ja/intlayer_with_vite+vanilla.md +2 -2
  427. package/docs/ja/intlayer_with_vite+vue.md +1 -1
  428. package/docs/ja/readme.md +13 -0
  429. package/docs/ko/benchmark/nextjs.md +15 -6
  430. package/docs/ko/benchmark/solid.md +13 -4
  431. package/docs/ko/benchmark/svelte.md +13 -4
  432. package/docs/ko/benchmark/tanstack.md +15 -6
  433. package/docs/ko/benchmark/vue.md +13 -4
  434. package/docs/ko/configuration.md +1 -1
  435. package/docs/ko/custom_domains.md +9 -9
  436. package/docs/ko/dictionary/content_file.md +41 -0
  437. package/docs/ko/dictionary/markdown.md +325 -119
  438. package/docs/ko/intlayer_with_analog.md +1 -1
  439. package/docs/ko/intlayer_with_angular.md +1 -1
  440. package/docs/ko/intlayer_with_astro.md +1 -1
  441. package/docs/ko/intlayer_with_astro_lit.md +2 -2
  442. package/docs/ko/intlayer_with_astro_preact.md +2 -2
  443. package/docs/ko/intlayer_with_astro_react.md +1 -1
  444. package/docs/ko/intlayer_with_astro_solid.md +1 -1
  445. package/docs/ko/intlayer_with_astro_svelte.md +1 -1
  446. package/docs/ko/intlayer_with_astro_vanilla.md +1 -1
  447. package/docs/ko/intlayer_with_astro_vue.md +1 -1
  448. package/docs/ko/intlayer_with_nextjs_14.md +2 -2
  449. package/docs/ko/intlayer_with_nextjs_15.md +2 -2
  450. package/docs/ko/intlayer_with_nextjs_16.md +1 -1
  451. package/docs/ko/intlayer_with_nextjs_page_router.md +2 -2
  452. package/docs/ko/intlayer_with_nuxt.md +1 -1
  453. package/docs/ko/intlayer_with_react_native+expo.md +2 -2
  454. package/docs/ko/intlayer_with_react_router_v7.md +1 -1
  455. package/docs/ko/intlayer_with_react_router_v7_fs_routes.md +1 -1
  456. package/docs/ko/intlayer_with_storybook.md +5 -5
  457. package/docs/ko/intlayer_with_svelte_kit.md +1 -1
  458. package/docs/ko/intlayer_with_tanstack+solid.md +1 -1
  459. package/docs/ko/intlayer_with_tanstack.md +1 -1
  460. package/docs/ko/intlayer_with_vanilla.md +2 -2
  461. package/docs/ko/intlayer_with_vite+lit.md +2 -2
  462. package/docs/ko/intlayer_with_vite+preact.md +2 -2
  463. package/docs/ko/intlayer_with_vite+react.md +2 -2
  464. package/docs/ko/intlayer_with_vite+react_compiler.md +2 -2
  465. package/docs/ko/intlayer_with_vite+solid.md +1 -1
  466. package/docs/ko/intlayer_with_vite+svelte.md +3 -3
  467. package/docs/ko/intlayer_with_vite+vanilla.md +3 -3
  468. package/docs/ko/intlayer_with_vite+vue.md +2 -2
  469. package/docs/ko/readme.md +13 -0
  470. package/docs/nl/configuration.md +6 -6
  471. package/docs/nl/custom_domains.md +11 -11
  472. package/docs/nl/intlayer_with_storybook.md +7 -7
  473. package/docs/nl/intlayer_with_vanilla.md +2 -2
  474. package/docs/nl/intlayer_with_vite+lit.md +2 -2
  475. package/docs/nl/intlayer_with_vite+vanilla.md +4 -4
  476. package/docs/pl/agent_skills.md +2 -2
  477. package/docs/pl/benchmark/nextjs.md +20 -11
  478. package/docs/pl/benchmark/solid.md +15 -6
  479. package/docs/pl/benchmark/svelte.md +15 -6
  480. package/docs/pl/benchmark/tanstack.md +16 -7
  481. package/docs/pl/benchmark/vue.md +16 -7
  482. package/docs/pl/configuration.md +6 -6
  483. package/docs/pl/custom_domains.md +11 -11
  484. package/docs/pl/dictionary/content_file.md +41 -0
  485. package/docs/pl/dictionary/markdown.md +303 -98
  486. package/docs/pl/intlayer_with_analog.md +1 -1
  487. package/docs/pl/intlayer_with_angular.md +1 -1
  488. package/docs/pl/intlayer_with_astro.md +1 -1
  489. package/docs/pl/intlayer_with_astro_lit.md +2 -2
  490. package/docs/pl/intlayer_with_astro_preact.md +3 -3
  491. package/docs/pl/intlayer_with_astro_react.md +2 -2
  492. package/docs/pl/intlayer_with_astro_solid.md +3 -3
  493. package/docs/pl/intlayer_with_astro_svelte.md +1 -1
  494. package/docs/pl/intlayer_with_astro_vanilla.md +1 -1
  495. package/docs/pl/intlayer_with_astro_vue.md +1 -1
  496. package/docs/pl/intlayer_with_nextjs_14.md +1 -1
  497. package/docs/pl/intlayer_with_nextjs_15.md +1 -1
  498. package/docs/pl/intlayer_with_nextjs_16.md +1 -1
  499. package/docs/pl/intlayer_with_nextjs_page_router.md +2 -2
  500. package/docs/pl/intlayer_with_nuxt.md +1 -1
  501. package/docs/pl/intlayer_with_react_native+expo.md +1 -1
  502. package/docs/pl/intlayer_with_react_router_v7.md +1 -1
  503. package/docs/pl/intlayer_with_react_router_v7_fs_routes.md +1 -1
  504. package/docs/pl/intlayer_with_storybook.md +7 -7
  505. package/docs/pl/intlayer_with_svelte_kit.md +1 -1
  506. package/docs/pl/intlayer_with_tanstack+solid.md +1 -1
  507. package/docs/pl/intlayer_with_tanstack.md +1 -1
  508. package/docs/pl/intlayer_with_vanilla.md +2 -2
  509. package/docs/pl/intlayer_with_vite+lit.md +3 -3
  510. package/docs/pl/intlayer_with_vite+preact.md +2 -2
  511. package/docs/pl/intlayer_with_vite+react.md +2 -2
  512. package/docs/pl/intlayer_with_vite+react_compiler.md +2 -2
  513. package/docs/pl/intlayer_with_vite+solid.md +1 -1
  514. package/docs/pl/intlayer_with_vite+svelte.md +3 -3
  515. package/docs/pl/intlayer_with_vite+vanilla.md +5 -5
  516. package/docs/pl/intlayer_with_vite+vue.md +2 -2
  517. package/docs/pl/readme.md +13 -0
  518. package/docs/pt/benchmark/nextjs.md +20 -11
  519. package/docs/pt/benchmark/solid.md +14 -5
  520. package/docs/pt/benchmark/svelte.md +14 -5
  521. package/docs/pt/benchmark/tanstack.md +16 -7
  522. package/docs/pt/benchmark/vue.md +14 -5
  523. package/docs/pt/configuration.md +6 -6
  524. package/docs/pt/custom_domains.md +11 -11
  525. package/docs/pt/dictionary/content_file.md +41 -0
  526. package/docs/pt/dictionary/markdown.md +303 -98
  527. package/docs/pt/intlayer_with_analog.md +1 -1
  528. package/docs/pt/intlayer_with_angular.md +1 -1
  529. package/docs/pt/intlayer_with_astro.md +1 -1
  530. package/docs/pt/intlayer_with_astro_lit.md +1 -1
  531. package/docs/pt/intlayer_with_astro_preact.md +3 -3
  532. package/docs/pt/intlayer_with_astro_react.md +2 -2
  533. package/docs/pt/intlayer_with_astro_solid.md +3 -3
  534. package/docs/pt/intlayer_with_astro_svelte.md +1 -1
  535. package/docs/pt/intlayer_with_astro_vanilla.md +1 -1
  536. package/docs/pt/intlayer_with_astro_vue.md +1 -1
  537. package/docs/pt/intlayer_with_nextjs_14.md +2 -2
  538. package/docs/pt/intlayer_with_nextjs_15.md +2 -2
  539. package/docs/pt/intlayer_with_nextjs_16.md +1 -1
  540. package/docs/pt/intlayer_with_nextjs_page_router.md +2 -2
  541. package/docs/pt/intlayer_with_nuxt.md +1 -1
  542. package/docs/pt/intlayer_with_react_native+expo.md +2 -2
  543. package/docs/pt/intlayer_with_react_router_v7_fs_routes.md +1 -1
  544. package/docs/pt/intlayer_with_storybook.md +7 -7
  545. package/docs/pt/intlayer_with_svelte_kit.md +1 -1
  546. package/docs/pt/intlayer_with_tanstack+solid.md +1 -1
  547. package/docs/pt/intlayer_with_tanstack.md +1 -1
  548. package/docs/pt/intlayer_with_vanilla.md +2 -2
  549. package/docs/pt/intlayer_with_vite+lit.md +3 -3
  550. package/docs/pt/intlayer_with_vite+preact.md +2 -2
  551. package/docs/pt/intlayer_with_vite+react.md +2 -2
  552. package/docs/pt/intlayer_with_vite+react_compiler.md +2 -2
  553. package/docs/pt/intlayer_with_vite+solid.md +1 -1
  554. package/docs/pt/intlayer_with_vite+svelte.md +3 -3
  555. package/docs/pt/intlayer_with_vite+vanilla.md +5 -5
  556. package/docs/pt/intlayer_with_vite+vue.md +1 -1
  557. package/docs/pt/readme.md +13 -0
  558. package/docs/ru/agent_skills.md +1 -1
  559. package/docs/ru/benchmark/index.md +2 -2
  560. package/docs/ru/benchmark/nextjs.md +28 -19
  561. package/docs/ru/benchmark/solid.md +16 -7
  562. package/docs/ru/benchmark/svelte.md +17 -8
  563. package/docs/ru/benchmark/tanstack.md +20 -11
  564. package/docs/ru/benchmark/vue.md +19 -10
  565. package/docs/ru/bundle_optimization.md +1 -1
  566. package/docs/ru/cli/index.md +23 -23
  567. package/docs/ru/cli/init.md +7 -7
  568. package/docs/ru/cli/standalone.md +5 -5
  569. package/docs/ru/compiler.md +3 -3
  570. package/docs/ru/configuration.md +8 -8
  571. package/docs/ru/custom_domains.md +12 -12
  572. package/docs/ru/dictionary/content_file.md +41 -0
  573. package/docs/ru/dictionary/html.md +6 -6
  574. package/docs/ru/dictionary/markdown.md +100 -500
  575. package/docs/ru/interest_of_intlayer.md +3 -3
  576. package/docs/ru/intlayer_with_analog.md +1 -1
  577. package/docs/ru/intlayer_with_angular.md +1 -1
  578. package/docs/ru/intlayer_with_astro.md +2 -2
  579. package/docs/ru/intlayer_with_astro_lit.md +5 -5
  580. package/docs/ru/intlayer_with_astro_preact.md +4 -4
  581. package/docs/ru/intlayer_with_astro_react.md +3 -3
  582. package/docs/ru/intlayer_with_astro_solid.md +4 -4
  583. package/docs/ru/intlayer_with_astro_svelte.md +2 -2
  584. package/docs/ru/intlayer_with_astro_vanilla.md +2 -2
  585. package/docs/ru/intlayer_with_astro_vue.md +2 -2
  586. package/docs/ru/intlayer_with_fastify.md +1 -1
  587. package/docs/ru/intlayer_with_nextjs_14.md +2 -2
  588. package/docs/ru/intlayer_with_nextjs_15.md +2 -2
  589. package/docs/ru/intlayer_with_nextjs_16.md +1 -1
  590. package/docs/ru/intlayer_with_nextjs_page_router.md +2 -2
  591. package/docs/ru/intlayer_with_nuxt.md +1 -1
  592. package/docs/ru/intlayer_with_react_native+expo.md +2 -2
  593. package/docs/ru/intlayer_with_react_router_v7.md +1 -1
  594. package/docs/ru/intlayer_with_react_router_v7_fs_routes.md +1 -1
  595. package/docs/ru/intlayer_with_storybook.md +10 -10
  596. package/docs/ru/intlayer_with_svelte_kit.md +1 -1
  597. package/docs/ru/intlayer_with_tanstack+solid.md +7 -7
  598. package/docs/ru/intlayer_with_tanstack.md +1 -1
  599. package/docs/ru/intlayer_with_vanilla.md +4 -4
  600. package/docs/ru/intlayer_with_vite+lit.md +5 -5
  601. package/docs/ru/intlayer_with_vite+preact.md +2 -2
  602. package/docs/ru/intlayer_with_vite+react.md +2 -2
  603. package/docs/ru/intlayer_with_vite+react_compiler.md +2 -2
  604. package/docs/ru/intlayer_with_vite+solid.md +1 -1
  605. package/docs/ru/intlayer_with_vite+svelte.md +3 -3
  606. package/docs/ru/intlayer_with_vite+vanilla.md +7 -7
  607. package/docs/ru/intlayer_with_vite+vue.md +2 -2
  608. package/docs/ru/readme.md +13 -0
  609. package/docs/tr/benchmark/nextjs.md +16 -7
  610. package/docs/tr/benchmark/solid.md +14 -5
  611. package/docs/tr/benchmark/svelte.md +14 -5
  612. package/docs/tr/benchmark/tanstack.md +16 -7
  613. package/docs/tr/benchmark/vue.md +14 -5
  614. package/docs/tr/configuration.md +6 -6
  615. package/docs/tr/custom_domains.md +11 -11
  616. package/docs/tr/dictionary/content_file.md +41 -0
  617. package/docs/tr/dictionary/markdown.md +320 -116
  618. package/docs/tr/intlayer_with_analog.md +1 -1
  619. package/docs/tr/intlayer_with_angular.md +1 -1
  620. package/docs/tr/intlayer_with_astro.md +1 -1
  621. package/docs/tr/intlayer_with_astro_lit.md +2 -2
  622. package/docs/tr/intlayer_with_astro_preact.md +3 -3
  623. package/docs/tr/intlayer_with_astro_react.md +2 -2
  624. package/docs/tr/intlayer_with_astro_solid.md +3 -3
  625. package/docs/tr/intlayer_with_astro_svelte.md +1 -1
  626. package/docs/tr/intlayer_with_astro_vanilla.md +1 -1
  627. package/docs/tr/intlayer_with_astro_vue.md +1 -1
  628. package/docs/tr/intlayer_with_nextjs_15.md +2 -2
  629. package/docs/tr/intlayer_with_nextjs_16.md +1 -1
  630. package/docs/tr/intlayer_with_nextjs_page_router.md +2 -2
  631. package/docs/tr/intlayer_with_nuxt.md +1 -1
  632. package/docs/tr/intlayer_with_react_native+expo.md +2 -2
  633. package/docs/tr/intlayer_with_react_router_v7.md +1 -1
  634. package/docs/tr/intlayer_with_react_router_v7_fs_routes.md +1 -1
  635. package/docs/tr/intlayer_with_storybook.md +7 -7
  636. package/docs/tr/intlayer_with_svelte_kit.md +1 -1
  637. package/docs/tr/intlayer_with_tanstack+solid.md +1 -1
  638. package/docs/tr/intlayer_with_tanstack.md +1 -1
  639. package/docs/tr/intlayer_with_vanilla.md +2 -2
  640. package/docs/tr/intlayer_with_vite+lit.md +3 -3
  641. package/docs/tr/intlayer_with_vite+preact.md +2 -2
  642. package/docs/tr/intlayer_with_vite+react.md +2 -2
  643. package/docs/tr/intlayer_with_vite+react_compiler.md +2 -2
  644. package/docs/tr/intlayer_with_vite+solid.md +1 -1
  645. package/docs/tr/intlayer_with_vite+svelte.md +3 -3
  646. package/docs/tr/intlayer_with_vite+vanilla.md +5 -5
  647. package/docs/tr/intlayer_with_vite+vue.md +2 -2
  648. package/docs/tr/readme.md +13 -0
  649. package/docs/uk/agent_skills.md +1 -1
  650. package/docs/uk/benchmark/index.md +2 -2
  651. package/docs/uk/benchmark/nextjs.md +29 -20
  652. package/docs/uk/benchmark/solid.md +16 -7
  653. package/docs/uk/benchmark/svelte.md +17 -8
  654. package/docs/uk/benchmark/tanstack.md +21 -12
  655. package/docs/uk/benchmark/vue.md +20 -11
  656. package/docs/uk/bundle_optimization.md +1 -1
  657. package/docs/uk/cli/index.md +21 -21
  658. package/docs/uk/cli/init.md +9 -9
  659. package/docs/uk/cli/standalone.md +16 -16
  660. package/docs/uk/compiler.md +3 -3
  661. package/docs/uk/configuration.md +8 -8
  662. package/docs/uk/custom_domains.md +12 -12
  663. package/docs/uk/dictionary/content_file.md +41 -0
  664. package/docs/uk/dictionary/markdown.md +405 -85
  665. package/docs/uk/interest_of_intlayer.md +2 -2
  666. package/docs/uk/intlayer_with_analog.md +1 -1
  667. package/docs/uk/intlayer_with_angular.md +1 -1
  668. package/docs/uk/intlayer_with_astro.md +2 -2
  669. package/docs/uk/intlayer_with_astro_lit.md +3 -3
  670. package/docs/uk/intlayer_with_astro_preact.md +4 -4
  671. package/docs/uk/intlayer_with_astro_react.md +3 -3
  672. package/docs/uk/intlayer_with_astro_solid.md +4 -4
  673. package/docs/uk/intlayer_with_astro_svelte.md +2 -2
  674. package/docs/uk/intlayer_with_astro_vanilla.md +2 -2
  675. package/docs/uk/intlayer_with_astro_vue.md +2 -2
  676. package/docs/uk/intlayer_with_fastify.md +1 -1
  677. package/docs/uk/intlayer_with_nextjs_14.md +1 -1
  678. package/docs/uk/intlayer_with_nextjs_15.md +1 -1
  679. package/docs/uk/intlayer_with_nextjs_16.md +1 -1
  680. package/docs/uk/intlayer_with_nextjs_page_router.md +2 -2
  681. package/docs/uk/intlayer_with_nuxt.md +1 -1
  682. package/docs/uk/intlayer_with_react_native+expo.md +1 -1
  683. package/docs/uk/intlayer_with_react_router_v7.md +1 -1
  684. package/docs/uk/intlayer_with_react_router_v7_fs_routes.md +1 -1
  685. package/docs/uk/intlayer_with_storybook.md +9 -9
  686. package/docs/uk/intlayer_with_svelte_kit.md +1 -1
  687. package/docs/uk/intlayer_with_tanstack+solid.md +4 -4
  688. package/docs/uk/intlayer_with_tanstack.md +1 -1
  689. package/docs/uk/intlayer_with_vanilla.md +3 -3
  690. package/docs/uk/intlayer_with_vite+lit.md +4 -4
  691. package/docs/uk/intlayer_with_vite+preact.md +2 -2
  692. package/docs/uk/intlayer_with_vite+react.md +2 -2
  693. package/docs/uk/intlayer_with_vite+react_compiler.md +2 -2
  694. package/docs/uk/intlayer_with_vite+solid.md +1 -1
  695. package/docs/uk/intlayer_with_vite+svelte.md +3 -3
  696. package/docs/uk/intlayer_with_vite+vanilla.md +6 -6
  697. package/docs/uk/intlayer_with_vite+vue.md +2 -2
  698. package/docs/uk/readme.md +13 -0
  699. package/docs/ur/cli/init.md +1 -1
  700. package/docs/ur/configuration.md +6 -6
  701. package/docs/ur/custom_domains.md +11 -11
  702. package/docs/ur/intlayer_with_storybook.md +7 -7
  703. package/docs/ur/intlayer_with_vanilla.md +2 -2
  704. package/docs/ur/intlayer_with_vite+lit.md +2 -2
  705. package/docs/ur/intlayer_with_vite+vanilla.md +4 -4
  706. package/docs/vi/agent_skills.md +2 -2
  707. package/docs/vi/benchmark/nextjs.md +20 -11
  708. package/docs/vi/benchmark/solid.md +14 -5
  709. package/docs/vi/benchmark/svelte.md +14 -5
  710. package/docs/vi/benchmark/tanstack.md +16 -7
  711. package/docs/vi/benchmark/vue.md +14 -5
  712. package/docs/vi/cli/init.md +1 -1
  713. package/docs/vi/configuration.md +6 -6
  714. package/docs/vi/custom_domains.md +11 -11
  715. package/docs/vi/dictionary/content_file.md +41 -0
  716. package/docs/vi/dictionary/markdown.md +408 -88
  717. package/docs/vi/intlayer_with_analog.md +1 -1
  718. package/docs/vi/intlayer_with_angular.md +1 -1
  719. package/docs/vi/intlayer_with_astro.md +1 -1
  720. package/docs/vi/intlayer_with_astro_lit.md +2 -2
  721. package/docs/vi/intlayer_with_astro_preact.md +3 -3
  722. package/docs/vi/intlayer_with_astro_react.md +2 -2
  723. package/docs/vi/intlayer_with_astro_solid.md +3 -3
  724. package/docs/vi/intlayer_with_astro_svelte.md +1 -1
  725. package/docs/vi/intlayer_with_astro_vanilla.md +1 -1
  726. package/docs/vi/intlayer_with_astro_vue.md +1 -1
  727. package/docs/vi/intlayer_with_nextjs_14.md +1 -1
  728. package/docs/vi/intlayer_with_nextjs_15.md +1 -1
  729. package/docs/vi/intlayer_with_nextjs_16.md +1 -1
  730. package/docs/vi/intlayer_with_nextjs_page_router.md +2 -2
  731. package/docs/vi/intlayer_with_nuxt.md +1 -1
  732. package/docs/vi/intlayer_with_react_native+expo.md +1 -1
  733. package/docs/vi/intlayer_with_react_router_v7.md +1 -1
  734. package/docs/vi/intlayer_with_react_router_v7_fs_routes.md +1 -1
  735. package/docs/vi/intlayer_with_storybook.md +7 -7
  736. package/docs/vi/intlayer_with_svelte_kit.md +1 -1
  737. package/docs/vi/intlayer_with_tanstack+solid.md +1 -1
  738. package/docs/vi/intlayer_with_tanstack.md +1 -1
  739. package/docs/vi/intlayer_with_vanilla.md +2 -2
  740. package/docs/vi/intlayer_with_vite+lit.md +2 -2
  741. package/docs/vi/intlayer_with_vite+preact.md +1 -1
  742. package/docs/vi/intlayer_with_vite+react.md +1 -1
  743. package/docs/vi/intlayer_with_vite+react_compiler.md +1 -1
  744. package/docs/vi/intlayer_with_vite+svelte.md +2 -2
  745. package/docs/vi/intlayer_with_vite+vanilla.md +4 -4
  746. package/docs/vi/intlayer_with_vite+vue.md +1 -1
  747. package/docs/vi/readme.md +13 -0
  748. package/docs/zh/benchmark/nextjs.md +20 -11
  749. package/docs/zh/benchmark/solid.md +10 -1
  750. package/docs/zh/benchmark/svelte.md +10 -1
  751. package/docs/zh/benchmark/tanstack.md +16 -7
  752. package/docs/zh/benchmark/vue.md +10 -1
  753. package/docs/zh/cli/init.md +1 -1
  754. package/docs/zh/configuration.md +6 -6
  755. package/docs/zh/custom_domains.md +11 -11
  756. package/docs/zh/dictionary/content_file.md +41 -0
  757. package/docs/zh/dictionary/markdown.md +313 -111
  758. package/docs/zh/intlayer_with_analog.md +1 -1
  759. package/docs/zh/intlayer_with_angular.md +1 -1
  760. package/docs/zh/intlayer_with_astro.md +1 -1
  761. package/docs/zh/intlayer_with_astro_lit.md +2 -2
  762. package/docs/zh/intlayer_with_astro_preact.md +3 -3
  763. package/docs/zh/intlayer_with_astro_react.md +2 -2
  764. package/docs/zh/intlayer_with_astro_solid.md +3 -3
  765. package/docs/zh/intlayer_with_astro_svelte.md +1 -1
  766. package/docs/zh/intlayer_with_astro_vanilla.md +1 -1
  767. package/docs/zh/intlayer_with_astro_vue.md +1 -1
  768. package/docs/zh/intlayer_with_nextjs_14.md +2 -2
  769. package/docs/zh/intlayer_with_nextjs_15.md +2 -2
  770. package/docs/zh/intlayer_with_nextjs_16.md +1 -1
  771. package/docs/zh/intlayer_with_nextjs_page_router.md +2 -2
  772. package/docs/zh/intlayer_with_nuxt.md +1 -1
  773. package/docs/zh/intlayer_with_react_native+expo.md +2 -2
  774. package/docs/zh/intlayer_with_react_router_v7.md +1 -1
  775. package/docs/zh/intlayer_with_react_router_v7_fs_routes.md +1 -1
  776. package/docs/zh/intlayer_with_storybook.md +7 -7
  777. package/docs/zh/intlayer_with_svelte_kit.md +1 -1
  778. package/docs/zh/intlayer_with_tanstack+solid.md +1 -1
  779. package/docs/zh/intlayer_with_tanstack.md +1 -1
  780. package/docs/zh/intlayer_with_vanilla.md +2 -2
  781. package/docs/zh/intlayer_with_vite+lit.md +2 -2
  782. package/docs/zh/intlayer_with_vite+preact.md +1 -1
  783. package/docs/zh/intlayer_with_vite+react.md +1 -1
  784. package/docs/zh/intlayer_with_vite+react_compiler.md +1 -1
  785. package/docs/zh/intlayer_with_vite+svelte.md +2 -2
  786. package/docs/zh/intlayer_with_vite+vanilla.md +4 -4
  787. package/docs/zh/intlayer_with_vite+vue.md +1 -1
  788. package/docs/zh/readme.md +13 -0
  789. package/frequent_questions/ru/intlayerNode.md +2 -2
  790. package/frequent_questions/uk/intlayerNode.md +2 -2
  791. package/package.json +7 -7
  792. package/docs/ja/dictionary/markdown.md +0 -631
@@ -1,6 +1,6 @@
1
1
  ---
2
2
  createdAt: 2026-04-20
3
- updatedAt: 2026-04-21
3
+ updatedAt: 2026-05-18
4
4
  title: Найкраще i18n рішення для Next.js у 2026 році - Звіт бенчмарку
5
5
  description: Порівняйте бібліотеки інтернаціоналізації (i18n) для Next.js, такі як next-intl, next-i18next та Intlayer. Детальний звіт про продуктивність за розміром бандла, витоком та реактивністю.
6
6
  keywords:
@@ -17,12 +17,15 @@ slugs:
17
17
  author: Aymeric PINEAU
18
18
  applicationTemplate: https://github.com/intlayer-org/benchmark-i18n
19
19
  history:
20
+ - version: 8.9.8
21
+ date: 2026-05-18
22
+ changes: "Додати порівняння зірок GitHub"
20
23
  - version: 8.7.5
21
24
  date: 2026-01-06
22
25
  changes: "Ініціалізація бенчмарку"
23
26
  ---
24
27
 
25
- # Бібліотеки i18n для Next.js Звіт бенчмарку 2026
28
+ # Бібліотеки i18n для Next.js - Звіт бенчмарку 2026
26
29
 
27
30
  Ця сторінка є звітом бенчмарку i18n рішень на Next.js.
28
31
 
@@ -55,9 +58,9 @@ style="border:none;"
55
58
 
56
59
  Наприклад, у найгірших випадках інтернаціоналізована сторінка може стати майже в 4 рази важчою.
57
60
 
58
- Інший вплив бібліотек i18n сповільнення розробки. Перетворення компонентів на багатомовний контент багатьма мовами займає багато часу.
61
+ Інший вплив бібліотек i18n - сповільнення розробки. Перетворення компонентів на багатомовний контент багатьма мовами займає багато часу.
59
62
 
60
- Оскільки це складна проблема, існує багато рішень деякі зосереджені на DX (досвід розробника), інші на продуктивності чи масштабованості тощо.
63
+ Оскільки це складна проблема, існує багато рішень - деякі зосереджені на DX (досвід розробника), інші на продуктивності чи масштабованості тощо.
61
64
 
62
65
  Intlayer намагається оптимізувати всі ці параметри одночасно.
63
66
 
@@ -85,17 +88,17 @@ Intlayer намагається оптимізувати всі ці парам
85
88
 
86
89
  **Динамічне завантаження**
87
90
 
88
- Навіть якщо ви оголошуєте роути на кшталт `[locale]/page.tsx`, використовуючи Webpack або Turbopack, і навіть якщо визначено `generateStaticParams`, бандлер не розглядає `locale` як статичну константу. Це означає, що він може додати контент для всіх мов у кожну сторінку. Основний спосіб обмежити це завантажувати контент через динамічний імпорт (наприклад, `import('./locales/${locale}.json')`).
91
+ Навіть якщо ви оголошуєте роути на кшталт `[locale]/page.tsx`, використовуючи Webpack або Turbopack, і навіть якщо визначено `generateStaticParams`, бандлер не розглядає `locale` як статичну константу. Це означає, що він може додати контент для всіх мов у кожну сторінку. Основний спосіб обмежити це - завантажувати контент через динамічний імпорт (наприклад, `import('./locales/${locale}.json')`).
89
92
 
90
93
  На етапі збірки (build time) Next.js створює один JS-бандл на локаль (наприклад, `./locales_uk_12345.js`). Після того, як сайт надіслано клієнту, під час запуску сторінки браузер робить додатковий HTTP-запит для потрібного JS-файлу.
91
94
 
92
- > Інший спосіб вирішення цієї проблеми використання `fetch()` для динамічного завантаження JSON. Саме так працює `Tolgee`, коли JSON знаходиться в `/public`, або `next-translate`, який використовує `getStaticProps` для завантаження контенту. Процес ідентичний: браузер робить додатковий HTTP-запит для завантаження ресурсу.
95
+ > Інший спосіб вирішення цієї проблеми - використання `fetch()` для динамічного завантаження JSON. Саме так працює `Tolgee`, коли JSON знаходиться в `/public`, або `next-translate`, який використовує `getStaticProps` для завантаження контенту. Процес ідентичний: браузер робить додатковий HTTP-запит для завантаження ресурсу.
93
96
 
94
97
  **Розділення контенту (Content splitting)**
95
98
 
96
99
  Якщо ви використовуєте синтаксис на кшталт `const t = useTranslation()` + `t('my-object.my-sub-object.my-key')`, зазвичай весь JSON має бути в бандлі, щоб бібліотека могла розібрати його та знайти ключ. Велика частина цього контенту передається клієнту, навіть якщо вона не використовується на сторінці.
97
100
 
98
- Щоб мінімізувати це, деякі бібліотеки просять вас вказувати для кожної сторінки, які простори імен завантажувати наприклад, `next-i18next`, `next-intl`, `lingui`, `next-translate`, `next-international`.
101
+ Щоб мінімізувати це, деякі бібліотеки просять вас вказувати для кожної сторінки, які простори імен завантажувати - наприклад, `next-i18next`, `next-intl`, `lingui`, `next-translate`, `next-international`.
99
102
 
100
103
  Натомість `Paraglide` додає додатковий крок перед збіркою, щоб перетворити JSON на плоскі символи на кшталт `const en_my_var = () => 'my value'`. Теоретично це дозволяє видаляти невикористаний контент на сторінці. Як ми побачимо, цей метод все одно має свої компроміси.
101
104
 
@@ -140,9 +143,9 @@ Intlayer намагається оптимізувати всі ці парам
140
143
 
141
144
  Я запускав один і той самий багатомовний додаток у реальному браузері для кожного стеку, а потім фіксував, що насправді передавалося через мережу і скільки часу це займало. Розміри вказані **після звичайного веб-стиснення**, оскільки це ближче до того, що люди реально завантажують.
142
145
 
143
- - **Розмір бібліотеки інтернаціоналізації**: Після складання, видалення невикористаного коду та мінімізації, розмір бібліотеки i18n це розмір коду провайдерів (наприклад, `NextIntlClientProvider`) + хуків (наприклад, `useTranslations`) у порожньому компоненті. Це не включає завантаження файлів перекладу. Це показує, наскільки "важкою" є бібліотека ще до появи вашого контенту.
146
+ - **Розмір бібліотеки інтернаціоналізації**: Після складання, видалення невикористаного коду та мінімізації, розмір бібліотеки i18n - це розмір коду провайдерів (наприклад, `NextIntlClientProvider`) + хуків (наприклад, `useTranslations`) у порожньому компоненті. Це не включає завантаження файлів перекладу. Це показує, наскільки "важкою" є бібліотека ще до появи вашого контенту.
144
147
 
145
- - **JavaScript на сторінку**: Для кожного тестового маршруту скільки скриптів завантажує браузер під час візиту, усереднено за сторінками тесту (і за локалями). Важкі сторінки це повільні сторінки.
148
+ - **JavaScript на сторінку**: Для кожного тестового маршруту - скільки скриптів завантажує браузер під час візиту, усереднено за сторінками тесту (і за локалями). Важкі сторінки - це повільні сторінки.
146
149
 
147
150
  - **Витік з інших локалей (Leakage)**: Це контент тієї ж сторінки, але іншою мовою, який помилково завантажується на сторінку, що перевіряється. Цей контент є зайвим і його слід уникати (наприклад, контент сторінки `/fr/about` у бандлі сторінки `/en/about`).
148
151
 
@@ -150,7 +153,7 @@ Intlayer намагається оптимізувати всі ці парам
150
153
 
151
154
  - **Середній розмір бандла компонента**: Окремі UI-елементи вимірюються **по одному**, а не ховаються всередині одного гігантського загального показника додатку. Це показує, чи інтернаціоналізація "роздуває" звичайні компоненти. Наприклад, якщо ваш компонент перерендериться, він завантажуватиме всі ці дані з пам'яті. Прив'язка гігантського JSON до будь-якого компонента схожа на підключення великого сховища невикористаних даних, що сповільнює продуктивність ваших компонентів.
152
155
 
153
- - **Швидкість реакції на перемикання мови**: Я перемикаю мову через власний інтерфейс додатку і заміряю час до моменту, коли сторінка явно оновилася те, що помітить відвідувач.
156
+ - **Швидкість реакції на перемикання мови**: Я перемикаю мову через власний інтерфейс додатку і заміряю час до моменту, коли сторінка явно оновилася - те, що помітить відвідувач.
154
157
 
155
158
  - **Робота рендерингу після зміни мови**: Вужчий показник: скільки зусиль витратив інтерфейс на перемальовування для нової мови після початку перемикання. Корисно, коли "відчутний" час і вартість роботи фреймворку відрізняються.
156
159
 
@@ -158,11 +161,17 @@ Intlayer намагається оптимізувати всі ці парам
158
161
 
159
162
  - **Час гідратації (Hydration)**: Час, який клієнт витрачає на перетворення HTML від сервера на інтерактивний інтерфейс. Прочерк у таблицях означає, що дана реалізація не надала надійних даних про гідратацію в цьому тесті.
160
163
 
164
+ ## Зірки на GitHub
165
+
166
+ Зірки на GitHub є потужним індикатором популярності проекту, довіри спільноти та довгострокової актуальності. Хоча вони не є прямим показником технічної якості, вони відображають, скільки розробників вважають проект корисним, стежать за його розвитком і, ймовірно, впровадять його. Для оцінки цінності проекту зірки допомагають порівняти інтерес до альтернатив і дають уявлення про зростання екосистеми.
167
+
168
+ [![Star History Chart](https://api.star-history.com/chart?repos=i18next%2Fnext-i18next%2Camannn%2Fnext-intl%2Clingui%2Fjs-lingui%2Cvinissimus%2Fnext-translate%2Cinostudio%2Fnext-international%2Copral%2paraglide-js%2Ctolgee%2Ftolgee-js%2Caymericzip%2Fintlayer&type=date&legend=top-left)](https://www.star-history.com/#i18next/next-i18next&amannn/next-intl&lingui/js-lingui&vinissimus/next-translate&inostudio/next-international&opral/paraglide-js&tolgee/tolgee-js&aymericzip/intlayer)
169
+
161
170
  ## Детальні результати
162
171
 
163
- ### 1 Рішення, яких слід уникати
172
+ ### 1 - Рішення, яких слід уникати
164
173
 
165
- Деяких рішень, таких як `gt-next` або `lingo.dev`, явно варто уникати. Вони поєднують прив'язку до вендора (vendor lock-in) із засміченням кодової бази. Попри багато годин спроб їх впровадження, я так і не зміг забезпечити їх стабільну роботу ні на TanStack Start, ні на Next.js.
174
+ Деяких рішень, таких як `gt-next` або `lingo.dev`, явно варто уникати. Вони поєднують прив'язку до вендора (vendor lock-in) із засміченням кодової бази. Попри багато годин спроб їх впровадження, я так і не зміг забезпечити їх стабільну роботу - ні на TanStack Start, ні на Next.js.
166
175
 
167
176
  Виявлені проблеми:
168
177
 
@@ -176,12 +185,12 @@ Intlayer намагається оптимізувати всі ці парам
176
185
 
177
186
  **(Lingo.dev)** (`@lingo.dev/compiler@0.4.0`):
178
187
 
179
- - Перевищено квоту AI, що повністю блокує збірку ви не можете випустити продукт у продакшн без оплати.
188
+ - Перевищено квоту AI, що повністю блокує збірку - ви не можете випустити продукт у продакшн без оплати.
180
189
  - Компілятор пропустив майже 40% перекладеного контенту. Мені довелося переписувати всі `.map` у плоскі блоки компонентів, щоб це запрацювало.
181
190
  - Їхній CLI працює нестабільно і часто без причини скидає конфігураційний файл.
182
191
  - Під час збірки він повністю стирав згенеровані JSON-файли при додаванні нового контенту. У результаті кілька ключів могли знищити понад 300 наявних.
183
192
 
184
- ### 2 Експериментальні рішення
193
+ ### 2 - Експериментальні рішення
185
194
 
186
195
  **(Wuchale)** (`wuchale@0.22.11`):
187
196
 
@@ -193,9 +202,9 @@ Intlayer намагається оптимізувати всі ці парам
193
202
  Особисто мені не подобається необхідність регенерувати JS-файли перед кожним пушем, що створює постійний ризик конфліктів під час злиття через PR. Інструмент також здається більш орієнтованим на Vite, ніж на Next.js.
194
203
  Нарешті, порівняно з іншими рішеннями, Paraglide не використовує стор (наприклад, React context) для отримання поточної локалі для рендерингу. Для кожного обробленого вузла він запитує локаль з localStorage / cookie тощо. Це призводить до виконання непотрібної логіки, що впливає на реактивність компонентів.
195
204
 
196
- > Примітка щодо paraglide: це рішення впроваджує код у вашу кодову базу для імпорту, в результаті чого показник 'розмір бібліотеки' у звіті бенчмарку становить майже 0. Генерація коду це добре, оскільки функція, що використовується, міститиме лише необхідну логіку (повний префікс проти відсутності префікса, кукі проти сховища тощо). Для порівняння, Intlayer виконує цю фільтрацію через впровадження змінних середовища під час збірки, щоб змусити бандлер видалити невикористаний контент (tree-shaking) залежно від логіки. Завдяки цьому paraglide та intlayer виявляються в 6-10 разів легшими рішеннями, ніж i18next або next-intl.
205
+ > Примітка щодо paraglide: це рішення впроваджує код у вашу кодову базу для імпорту, в результаті чого показник 'розмір бібліотеки' у звіті бенчмарку становить майже 0. Генерація коду - це добре, оскільки функція, що використовується, міститиме лише необхідну логіку (повний префікс проти відсутності префікса, кукі проти сховища тощо). Для порівняння, Intlayer виконує цю фільтрацію через впровадження змінних середовища під час збірки, щоб змусити бандлер видалити невикористаний контент (tree-shaking) залежно від логіки. Завдяки цьому paraglide та intlayer виявляються в 6-10 разів легшими рішеннями, ніж i18next або next-intl.
197
206
 
198
- ### 3 Прийнятні рішення
207
+ ### 3 - Прийнятні рішення
199
208
 
200
209
  **(Tolgee)** (`@tolgee/react@7.0.0`):
201
210
 
@@ -203,11 +212,11 @@ Intlayer намагається оптимізувати всі ці парам
203
212
 
204
213
  **(Next Intl)** (`next-intl@4.9.1`):
205
214
 
206
- `next-intl` це зараз найбільш трендовий варіант, який ШІ-агенти просувають найбільше, але на мій погляд, помилково. Почати роботу легко. На практиці ж оптимізація для обмеження витоків є складною. Поєднання динамічного завантаження + просторів імен + типів TypeScript сильно сповільнює розробку. Пакет також досить важкий (~13 КБ для `NextIntlClientProvider` + `useTranslations`, що майже вдвічі більше за `next-intlayer`). **next-intl** раніше блокував статичний рендеринг сторінок Next.js. Він надає хелпер `setRequestLocale()`. Здається, це частково вирішено для централізованих файлів на кшталт `en.json` / `fr.json`, але статичний рендеринг все одно ламається, коли контент розділений на простори імен, як-от `en/shared.json` / `fr/shared.json` / `es/shared.json`.
215
+ `next-intl` - це зараз найбільш трендовий варіант, який ШІ-агенти просувають найбільше, але на мій погляд, помилково. Почати роботу легко. На практиці ж оптимізація для обмеження витоків є складною. Поєднання динамічного завантаження + просторів імен + типів TypeScript сильно сповільнює розробку. Пакет також досить важкий (~13 КБ для `NextIntlClientProvider` + `useTranslations`, що майже вдвічі більше за `next-intlayer`). **next-intl** раніше блокував статичний рендеринг сторінок Next.js. Він надає хелпер `setRequestLocale()`. Здається, це частково вирішено для централізованих файлів на кшталт `en.json` / `fr.json`, але статичний рендеринг все одно ламається, коли контент розділений на простори імен, як-от `en/shared.json` / `fr/shared.json` / `es/shared.json`.
207
216
 
208
217
  **(Next I18next)** (`next-i18next@16.0.5`):
209
218
 
210
- `next-i18next` це, мабуть, найпопулярніший варіант, оскільки він був одним із перших рішень i18n для JS-додатків. Він має багато плагінів від спільноти. Має ті ж основні недоліки, що й `next-intl`. Пакет особливо важкий (~18 КБ для `I18nProvider` + `useTranslation`, приблизно втричі більше за `next-intlayer`).
219
+ `next-i18next` - це, мабуть, найпопулярніший варіант, оскільки він був одним із перших рішень i18n для JS-додатків. Він має багато плагінів від спільноти. Має ті ж основні недоліки, що й `next-intl`. Пакет особливо важкий (~18 КБ для `I18nProvider` + `useTranslation`, приблизно втричі більше за `next-intlayer`).
211
220
 
212
221
  Формати повідомлень також відрізняються: `next-intl` використовує ICU MessageFormat, тоді як `i18next` використовує власний формат.
213
222
 
@@ -219,11 +228,11 @@ Intlayer намагається оптимізувати всі ці парам
219
228
 
220
229
  `Lingui` часто хвалять. Особисто мені робочий процес із `lingui extract` / `lingui compile` здався складнішим за альтернативи, без явних переваг. Також помічені непослідовні синтаксиси, які плутають ШІ (наприклад, `t()`, `t''`, `i18n.t()`, `<Trans>`).
221
230
 
222
- ### 4 Рекомендації
231
+ ### 4 - Рекомендації
223
232
 
224
233
  **(Next Translate)** (`next-translate@3.1.2`):
225
234
 
226
- `next-translate` моя основна рекомендація, якщо вам подобається API у стилі `t()`. Він елегантно працює через `next-translate-plugin`, завантажуючи простори імен через `getStaticProps` за допомогою завантажувача Webpack / Turbopack. Це також найлегший варіант у цьому списку (~2.5 КБ). Визначення просторів імен для сторінок або маршрутів у конфігу добре продумане і простіше в підтримці, ніж у **next-intl** чи **next-i18next**. У версії `3.1.2` я помітив, що статичний рендеринг не працював; Next.js переходив до динамічного рендерингу.
235
+ `next-translate` - моя основна рекомендація, якщо вам подобається API у стилі `t()`. Він елегантно працює через `next-translate-plugin`, завантажуючи простори імен через `getStaticProps` за допомогою завантажувача Webpack / Turbopack. Це також найлегший варіант у цьому списку (~2.5 КБ). Визначення просторів імен для сторінок або маршрутів у конфігу добре продумане і простіше в підтримці, ніж у **next-intl** чи **next-i18next**. У версії `3.1.2` я помітив, що статичний рендеринг не працював; Next.js переходив до динамічного рендерингу.
227
236
 
228
237
  **(Intlayer)** (`next-intlayer@8.7.12`):
229
238
 
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  createdAt: 2026-04-20
3
- updatedAt: 2026-04-21
4
- title: Найкраще i18n рішення для Solid у 2026 році Звіт про бенчмарк
3
+ updatedAt: 2026-05-18
4
+ title: Найкраще i18n рішення для Solid у 2026 році - Звіт про бенчмарк
5
5
  description: Порівняйте бібліотеки інтернаціоналізації (i18n) для Solid, такі як solid-primitives, solid-i18next та Intlayer. Детальний звіт про продуктивність щодо розміру бандла, витоків та реактивності.
6
6
  keywords:
7
7
  - benchmark
@@ -17,12 +17,15 @@ slugs:
17
17
  author: Aymeric PINEAU
18
18
  applicationTemplate: https://github.com/intlayer-org/benchmark-i18n-solid-template
19
19
  history:
20
+ - version: 8.9.8
21
+ date: 2026-05-18
22
+ changes: "Додати порівняння зірок GitHub"
20
23
  - version: 8.7.12
21
24
  date: 2026-01-06
22
25
  changes: "Ініціалізація бенчмарку"
23
26
  ---
24
27
 
25
- # Бібліотеки i18n для Solid Звіт про бенчмарк 2026
28
+ # Бібліотеки i18n для Solid - Звіт про бенчмарк 2026
26
29
 
27
30
  Ця сторінка є звітом про бенчмарк рішень i18n на Solid.
28
31
 
@@ -99,7 +102,7 @@ style="border:none;"
99
102
  - `solid-i18next` (v17.0.2)
100
103
  - `@inlang/paraglide-js` (v2.17.0)
101
104
 
102
- Фреймворк `Solid` з багатомовним додатком із **10 сторінок** і **10 мов**.
105
+ Фреймворк - `Solid` з багатомовним додатком із **10 сторінок** і **10 мов**.
103
106
 
104
107
  Ми порівняли **чотири стратегії завантаження**:
105
108
 
@@ -115,13 +118,19 @@ style="border:none;"
115
118
  - **Scoped static**: Зберігає код організованим (логічне розділення) без складних додаткових мережевих запитів.
116
119
  - **Scoped dynamic**: Найкращий підхід для _code splitting_ та продуктивності. Мінімізує пам'ять, завантажуючи лише те, що потрібно поточному перегляду та активній локалі.
117
120
 
121
+ ## Зірки на GitHub
122
+
123
+ Зірки на GitHub є потужним індикатором популярності проекту, довіри спільноти та довгострокової актуальності. Хоча вони не є прямим показником технічної якості, вони відображають, скільки розробників вважають проект корисним, стежать за його розвитком і, ймовірно, впровадять його. Для оцінки цінності проекту зірки допомагають порівняти інтерес до альтернатив і дають уявлення про зростання екосистеми.
124
+
125
+ [![Star History Chart](https://api.star-history.com/chart?repos=solidjs-community%2Fsolid-primitives%2Cmbarzda%2Fsolid-i18next%2Copral%2paraglide-js%2Caymericzip%2Fintlayer&type=date&legend=top-left)](https://www.star-history.com/#solidjs-community/solid-primitives&mbarzda/solid-i18next&opral/paraglide-js&aymericzip/intlayer)
126
+
118
127
  ## Результати детально
119
128
 
120
- ### 1 Рішення, яких слід уникати
129
+ ### 1 - Рішення, яких слід уникати
121
130
 
122
131
  > В екосистемі Solid немає очевидних рішень, яких слід уникати.
123
132
 
124
- ### 2 Прийнятні рішення
133
+ ### 2 - Прийнятні рішення
125
134
 
126
135
  **(solid-i18next)** (`solid-i18next@17.0.2`):
127
136
 
@@ -142,7 +151,7 @@ Solid primitive надзвичайно легкий і ефективний. Я
142
151
  Особисто я не прихильник того, щоб перегенерувати файли JS перед кожним пушем, що створює постійний ризик конфліктів при злитті через PR.
143
152
  Нарешті, у порівнянні з іншими рішеннями, Paraglide не використовує стор (наприклад, Solid signal) для отримання поточної локалі для рендерингу контенту. Для кожного розібраного вузла він запитуватиме локаль з localStorage / cookie тощо. Це призводить до виконання непотрібної логіки, яка впливає на реактивність компонентів.
144
153
 
145
- ### 3 Рекомендації
154
+ ### 3 - Рекомендації
146
155
 
147
156
  **(Intlayer)** (`solid-intlayer@8.7.12`):
148
157
 
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  createdAt: 2026-04-20
3
- updatedAt: 2026-04-21
4
- title: Найкраще i18n рішення для Svelte у 2026 році Звіт про бенчмарк
3
+ updatedAt: 2026-05-18
4
+ title: Найкраще i18n рішення для Svelte у 2026 році - Звіт про бенчмарк
5
5
  description: Порівняйте бібліотеки інтернаціоналізації (i18n) для Svelte, такі як svelte-i18n, Paraglide та Intlayer. Детальний звіт про продуктивність щодо розміру бандла, витоків та реактивності.
6
6
  keywords:
7
7
  - benchmark
@@ -17,12 +17,15 @@ slugs:
17
17
  author: Aymeric PINEAU
18
18
  applicationTemplate: https://github.com/intlayer-org/benchmark-i18n-svelte-template
19
19
  history:
20
+ - version: 8.9.8
21
+ date: 2026-05-18
22
+ changes: "Додати порівняння зірок GitHub"
20
23
  - version: 8.7.12
21
24
  date: 2026-01-06
22
25
  changes: "Ініціалізація бенчмарку"
23
26
  ---
24
27
 
25
- # Бібліотеки i18n для Svelte Звіт про бенчмарк 2026
28
+ # Бібліотеки i18n для Svelte - Звіт про бенчмарк 2026
26
29
 
27
30
  Ця сторінка є звітом про бенчмарк рішень i18n на Svelte.
28
31
 
@@ -97,7 +100,7 @@ style="border:none;"
97
100
  - `svelte-i18n` (v4.0.1)
98
101
  - `@inlang/paraglide-js` (v2.17.0)
99
102
 
100
- Фреймворк `Svelte` з багатомовним додатком із **10 сторінок** і **10 мов**.
103
+ Фреймворк - `Svelte` з багатомовним додатком із **10 сторінок** і **10 мов**.
101
104
 
102
105
  Ми порівняли **чотири стратегії завантаження**:
103
106
 
@@ -113,13 +116,19 @@ style="border:none;"
113
116
  - **Scoped static**: Зберігає код організованим (логічне розділення) без складних додаткових мережевих запитів.
114
117
  - **Scoped dynamic**: Найкращий підхід для _code splitting_ та продуктивності. Мінімізує пам'ять, завантажуючи лише те, що потрібно поточному перегляду та активній локалі.
115
118
 
119
+ ## Зірки на GitHub
120
+
121
+ Зірки на GitHub є потужним індикатором популярності проекту, довіри спільноти та довгострокової актуальності. Хоча вони не є прямим показником технічної якості, вони відображають, скільки розробників вважають проект корисним, стежать за його розвитком і, ймовірно, впровадять його. Для оцінки цінності проекту зірки допомагають порівняти інтерес до альтернатив і дають уявлення про зростання екосистеми.
122
+
123
+ [![Star History Chart](https://api.star-history.com/chart?repos=kaisermann%2Fsvelte-i18n%2Copral%2paraglide-js%2Caymericzip%2Fintlayer&type=date&legend=top-left)](https://www.star-history.com/#kaisermann/svelte-i18n&opral/paraglide-js&aymericzip/intlayer)
124
+
116
125
  ## Результати детально
117
126
 
118
- ### 1 Рішення, яких слід уникати
127
+ ### 1 - Рішення, яких слід уникати
119
128
 
120
129
  > В екосистемі Svelte немає очевидних рішень, яких слід уникати.
121
130
 
122
- ### 2 Прийнятні рішення
131
+ ### 2 - Прийнятні рішення
123
132
 
124
133
  **(Paraglide)** (`@inlang/paraglide-js@2.17.0`):
125
134
 
@@ -129,13 +138,13 @@ style="border:none;"
129
138
  Особисто я не прихильник того, щоб перегенерувати файли JS перед кожним пушем, що створює постійний ризик конфліктів при злитті через PR. Інструмент також здається більш зосередженим на Vite, ніж на Next.js.
130
139
  Нарешті, у порівнянні з іншими рішеннями, Paraglide не використовує стор (наприклад, Svelte store) для отримання поточної локалі для рендерингу контенту. Для кожного розібраного вузла він запитуватиме локаль з localStorage / cookie тощо. Це призводить до виконання непотрібної логіки, яка впливає на реактивність компонентів.
131
140
 
132
- > Примітка щодо paraglide: рішення впорскує код у вашу кодову базу для імпорту; як результат, метрика 'lib size' у звіті бенчмарку становить майже 0. Генерація коду це добре, тому що використана функція включатиме лише необхідну логіку (префікс скрізь проти відсутності префікса, кукі проти сховища тощо). Для порівняння, Intlayer виконує цю фільтрацію за допомогою впорскування змінних оточення під час збірки, щоб змусити бандлер виконувати tree-shaking контенту залежно від логіки. Завдяки цьому paraglide та intlayer стають у 6–10 разів легшими рішеннями, ніж i18next або next-intl.
141
+ > Примітка щодо paraglide: рішення впорскує код у вашу кодову базу для імпорту; як результат, метрика 'lib size' у звіті бенчмарку становить майже 0. Генерація коду - це добре, тому що використана функція включатиме лише необхідну логіку (префікс скрізь проти відсутності префікса, кукі проти сховища тощо). Для порівняння, Intlayer виконує цю фільтрацію за допомогою впорскування змінних оточення під час збірки, щоб змусити бандлер виконувати tree-shaking контенту залежно від логіки. Завдяки цьому paraglide та intlayer стають у 6–10 разів легшими рішеннями, ніж i18next або next-intl.
133
142
 
134
143
  **(svelte-i18n)** (`svelte-i18n@3.4.0`):
135
144
 
136
145
  Це рішення задовольняє всі потреби i18n у проєкті Svelte. Але як і у випадку з i18next або іншими великими i18n рішеннями, воно трохи важке (~15.9kb, що приблизно в 7 разів більше за `svelte-intlayer`).
137
146
 
138
- ### 3 Рекомендації
147
+ ### 3 - Рекомендації
139
148
 
140
149
  **(Intlayer)** (`svelte-intlayer@8.7.12`):
141
150
 
@@ -1,6 +1,6 @@
1
1
  ---
2
2
  createdAt: 2026-04-20
3
- updatedAt: 2026-04-21
3
+ updatedAt: 2026-05-18
4
4
  title: Найкраще i18n рішення для TanStack Start у 2026 році - Звіт бенчмарку
5
5
  description: Порівняйте бібліотеки інтернаціоналізації для TanStack Start, такі як react-i18next, use-intl та Intlayer. Детальний звіт про продуктивність за розміром бандла, витоком та реактивністю.
6
6
  keywords:
@@ -17,12 +17,15 @@ slugs:
17
17
  author: Aymeric PINEAU
18
18
  applicationTemplate: https://github.com/intlayer-org/benchmark-i18n-tanstack-start-template
19
19
  history:
20
+ - version: 8.9.8
21
+ date: 2026-05-18
22
+ changes: "Додати порівняння зірок GitHub"
20
23
  - version: 8.7.5
21
24
  date: 2026-01-06
22
25
  changes: "Ініціалізація бенчмарку"
23
26
  ---
24
27
 
25
- # Бібліотеки i18n для TanStack Start Звіт бенчмарку 2026
28
+ # Бібліотеки i18n для TanStack Start - Звіт бенчмарку 2026
26
29
 
27
30
  Ця сторінка є звітом бенчмарку i18n рішень на TanStack Start.
28
31
 
@@ -105,7 +108,7 @@ history:
105
108
  - `gt-react` (vlatest)
106
109
  - `lingo.dev` (v0.133.9)
107
110
 
108
- Фреймворк `TanStack Start` з багатомовним додатком на **10 сторінок** та **10 мов**.
111
+ Фреймворк - `TanStack Start` з багатомовним додатком на **10 сторінок** та **10 мов**.
109
112
 
110
113
  Ми порівняли **чотири стратегії завантаження**:
111
114
 
@@ -121,9 +124,15 @@ history:
121
124
  - **Scoped static**: Зберігає код структурованим (логічний поділ) без складних мережевих запитів.
122
125
  - **Scoped dynamic**: Найкращий підхід для _розділення коду_ (code splitting) та продуктивності. Мінімізує обсяг пам'яті, завантажуючи лише те, що потрібно поточному перегляду та активній локалі.
123
126
 
127
+ ## Зірки на GitHub
128
+
129
+ Зірки на GitHub є потужним індикатором популярності проекту, довіри спільноти та довгострокової актуальності. Хоча вони не є прямим показником технічної якості, вони відображають, скільки розробників вважають проект корисним, стежать за його розвитком і, ймовірно, впровадять його. Для оцінки цінності проекту зірки допомагають порівняти інтерес до альтернатив і дають уявлення про зростання екосистеми.
130
+
131
+ [![Star History Chart](https://api.star-history.com/chart?repos=formatjs%2Fformatjs%2Ci18next%2Freact-i18next%2Clingui%2Fjs-lingui%2Camannn%2Fnext-intl%2Copral%2paraglide-js%2Ctolgee%2Ftolgee-js%2Caymericzip%2Fintlayer&type=date&legend=top-left)](https://www.star-history.com/#formatjs/formatjs&i18next/react-i18next&lingui/js-lingui&amannn/next-intl&opral/paraglide-js&tolgee/tolgee-js&aymericzip/intlayer)
132
+
124
133
  ## Детальні результати
125
134
 
126
- ### 1 Рішення, яких слід уникати
135
+ ### 1 - Рішення, яких слід уникати
127
136
 
128
137
  Деяких рішень, таких як `gt-react` або `lingo.dev`, явно варто триматися подалі. Вони поєднують прив'язку до вендора із засміченням вашої кодової бази. Гірше того: попри багато годин спроб їх впровадження, я так і не зміг забезпечити їх коректну роботу на TanStack Start (аналогічно до `gt-next` на Next.js).
129
138
 
@@ -145,19 +154,19 @@ history:
145
154
  - Під час збірки він повністю стирав згенеровані JSON-файли при додаванні нового контенту. У результаті лише кілька ключів могли знищити сотні наявних.
146
155
  - Я стикнувся з проблемами реактивності бібліотеки в TanStack Start: при зміні локалі довелося примусово перерендерити провайдер, щоб це запрацювало.
147
156
 
148
- ### 2 Експериментальні рішення
157
+ ### 2 - Експериментальні рішення
149
158
 
150
159
  **(Wuchale)** (`wuchale@0.22.11`):
151
160
 
152
161
  Ідея `Wuchale` цікава, але поки що не є життєздатним рішенням. Я зіткнувся з проблемами реактивності бібліотеки і був змушений примусово перерендерити провайдер, щоб додаток запрацював на TanStack Start. Документація також досить нечітка, що ускладнює освоєння.
153
162
 
154
- ### 3 Прийнятні рішення
163
+ ### 3 - Прийнятні рішення
155
164
 
156
165
  **(Paraglide)** (`@inlang/paraglide-js@2.15.1`):
157
166
 
158
167
  `Paraglide` пропонує інноваційний, добре продуманий підхід. Проте в цьому тесті рекламований компанією tree-shaking не спрацював ні для моєї реалізації на Next.js, ні для TanStack Start. Робочий процес і DX також складніші за інші варіанти. Особисто я не прихильник необхідності регенерувати JS-файли перед кожним пушем, що створює постійний ризик конфліктів під час злиття для розробників через PR.
159
168
 
160
- > Примітка щодо paraglide: це рішення впорскує код у вашу кодову базу для імпорту; як наслідок, метрика 'lib size' у звіті бенчмарку становить майже 0. Генерація коду це добре, оскільки використовувана функція включатиме лише необхідну логіку (префікс усюди проти відсутності префікса, куки проти сховища тощо). Для порівняння, Intlayer виконує це фільтрування за допомогою впорскування змінних оточення в збірку, щоб змусити бандлер виконати tree-shake контенту залежно від логіки. Завдяки цьому paraglide та intlayer врешті-решт стають у 6–10 разів легшими рішеннями, ніж i18next або next-intl.
169
+ > Примітка щодо paraglide: це рішення впорскує код у вашу кодову базу для імпорту; як наслідок, метрика 'lib size' у звіті бенчмарку становить майже 0. Генерація коду - це добре, оскільки використовувана функція включатиме лише необхідну логіку (префікс усюди проти відсутності префікса, куки проти сховища тощо). Для порівняння, Intlayer виконує це фільтрування за допомогою впорскування змінних оточення в збірку, щоб змусити бандлер виконати tree-shake контенту залежно від логіки. Завдяки цьому paraglide та intlayer врешті-решт стають у 6–10 разів легшими рішеннями, ніж i18next або next-intl.
161
170
 
162
171
  **(Tolgee)** (`@tolgee/react@7.0.0`):
163
172
 
@@ -167,17 +176,17 @@ history:
167
176
 
168
177
  **(use-intl)** (`use-intl@4.9.1`):
169
178
 
170
- `use-intl` це зараз наймодніша частина "intl" в екосистемі React (та ж родина, що й `next-intl`), яку часто просувають ШІ-агенти, але на мій погляд помилково в контексті продуктивності. Почати роботу досить просто. На практиці ж процес оптимізації та обмеження витоків є досить складним. Аналогічно, поєднання динамічного завантаження + просторів імен + типів TypeScript сильно сповільнює розробку.
179
+ `use-intl` - це зараз наймодніша частина "intl" в екосистемі React (та ж родина, що й `next-intl`), яку часто просувають ШІ-агенти, але на мій погляд - помилково в контексті продуктивності. Почати роботу досить просто. На практиці ж процес оптимізації та обмеження витоків є досить складним. Аналогічно, поєднання динамічного завантаження + просторів імен + типів TypeScript сильно сповільнює розробку.
171
180
 
172
181
  У TanStack Start ви уникаєте специфічних пасток Next.js (`setRequestLocale`, статичний рендеринг), але основна проблема та ж сама: без суворої дисципліни бандл швидко перевантажується повідомленнями, а підтримка просторів імен для кожного маршруту стає виснажливою.
173
182
 
174
183
  **(react-i18next)** (`react-i18next@17.0.2`):
175
184
 
176
- `react-i18next` це, мабуть, найпопулярніший варіант, оскільки він був одним із перших, хто задовольнив потреби i18n у JS-додатках. Він також має великий набір плагінів від спільноти для конкретних проблем.
185
+ `react-i18next` - це, мабуть, найпопулярніший варіант, оскільки він був одним із перших, хто задовольнив потреби i18n у JS-додатках. Він також має великий набір плагінів від спільноти для конкретних проблем.
177
186
 
178
187
  Проте він має ті ж недоліки, що й стеки на базі `t('a.b.c')`: оптимізація можлива, але забирає багато часу, а великі проекти ризикують скотитися до поганих практик (простори імен + динамічне завантаження + типи).
179
188
 
180
- Формати повідомлень також відрізняються: `use-intl` використовує ICU MessageFormat, тоді як `i18next` має власний формат це ускладнює інструментарій або міграцію, якщо ви їх змішуєте.
189
+ Формати повідомлень також відрізняються: `use-intl` використовує ICU MessageFormat, тоді як `i18next` має власний формат - це ускладнює інструментарій або міграцію, якщо ви їх змішуєте.
181
190
 
182
191
  **(Lingui)** (`@lingui/core@5.3.0`):
183
192
 
@@ -185,9 +194,9 @@ history:
185
194
 
186
195
  **(react-intl)** (`react-intl@10.1.1`):
187
196
 
188
- `react-intl` це продуктивна реалізація від команди Format.js. DX залишається багатослівним: `const intl = useIntl()` + `intl.formatMessage({ id: "xx.xx" })` додає складності, додаткової роботи JavaScript та прив'язує глобальний екземпляр i18n до багатьох вузлів у React-дереві.
197
+ `react-intl` - це продуктивна реалізація від команди Format.js. DX залишається багатослівним: `const intl = useIntl()` + `intl.formatMessage({ id: "xx.xx" })` додає складності, додаткової роботи JavaScript та прив'язує глобальний екземпляр i18n до багатьох вузлів у React-дереві.
189
198
 
190
- ### 4 Рекомендації
199
+ ### 4 - Рекомендації
191
200
 
192
201
  Цей бенчмарк TanStack Start не має прямого еквівалента `next-translate` (Next.js плагін + `getStaticProps`). Командам, які справді хочуть API у стилі `t()` зі зрілою екосистемою, `react-i18next` та `use-intl` залишаються "розумним" вибором, але будьте готові витратити багато часу на оптимізацію для уникнення витоків.
193
202
 
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  createdAt: 2026-04-20
3
- updatedAt: 2026-04-21
4
- title: Найкраще i18n рішення для Vue у 2026 році Звіт про бенчмарк
3
+ updatedAt: 2026-05-18
4
+ title: Найкраще i18n рішення для Vue у 2026 році - Звіт про бенчмарк
5
5
  description: Порівняйте бібліотеки інтернаціоналізації (i18n) для Vue, такі як vue-i18n, fluent-vue та Intlayer. Детальний звіт про продуктивність щодо розміру бандла, витоків та реактивності.
6
6
  keywords:
7
7
  - benchmark
@@ -17,12 +17,15 @@ slugs:
17
17
  author: Aymeric PINEAU
18
18
  applicationTemplate: https://github.com/intlayer-org/benchmark-i18n-vue-template
19
19
  history:
20
+ - version: 8.9.8
21
+ date: 2026-05-18
22
+ changes: "Додати порівняння зірок GitHub"
20
23
  - version: 8.7.12
21
24
  date: 2026-01-06
22
25
  changes: "Ініціалізація бенчмарку"
23
26
  ---
24
27
 
25
- # Бібліотеки i18n для Vue Звіт про бенчмарк 2026
28
+ # Бібліотеки i18n для Vue - Звіт про бенчмарк 2026
26
29
 
27
30
  Ця сторінка є звітом про бенчмарк рішень i18n на Vue.
28
31
 
@@ -97,7 +100,7 @@ style="border:none;"
97
100
  - `vue-i18n` (v11.4.0)
98
101
  - `fluent-vue` (v3.8.2)
99
102
 
100
- Фреймворк `Vue` з багатомовним додатком із **10 сторінок** і **10 мов**.
103
+ Фреймворк - `Vue` з багатомовним додатком із **10 сторінок** і **10 мов**.
101
104
 
102
105
  Ми порівняли **чотири стратегії завантаження**:
103
106
 
@@ -117,17 +120,17 @@ style="border:none;"
117
120
 
118
121
  Я запустив той самий багатомовний додаток у реальному браузері для кожного стека, а потім записав, що насправді пройшло мережею і скільки часу це зайняло. Розміри вказані **після звичайного веб-стиснення**, оскільки це ближче до того, що люди насправді завантажують, ніж необроблена кількість рядків вихідного коду.
119
122
 
120
- - **Розмір бібліотеки інтернаціоналізації**: Після бандлінгу, tree-shaking та мініфікації розмір бібліотеки i18n це розмір коду провайдерів + composables у порожньому компоненті. Він не включає завантаження файлів перекладу. Це відповідає на питання, наскільки "дорогою" є бібліотека до того, як ваш контент з'явиться в кадрі.
123
+ - **Розмір бібліотеки інтернаціоналізації**: Після бандлінгу, tree-shaking та мініфікації розмір бібліотеки i18n - це розмір коду провайдерів + composables у порожньому компоненті. Він не включає завантаження файлів перекладу. Це відповідає на питання, наскільки "дорогою" є бібліотека до того, як ваш контент з'явиться в кадрі.
121
124
 
122
- - **JavaScript на сторінку**: Для кожного маршруту бенчмарку, скільки скриптів завантажує браузер для цього відвідування, усереднено за сторінками в наборі (і за локалями). Важкі сторінки це повільні сторінки.
125
+ - **JavaScript на сторінку**: Для кожного маршруту бенчмарку, скільки скриптів завантажує браузер для цього відвідування, усереднено за сторінками в наборі (і за локалями). Важкі сторінки - це повільні сторінки.
123
126
 
124
127
  - **Витік з інших локалей (Leakage)**: Це контент тієї ж сторінки, але іншою мовою, який помилково завантажується на сторінці, що перевіряється. Цей контент є непотрібним і його слід уникати (наприклад: контент сторінки `/fr/about` у бандлі сторінки `/en/about`).
125
128
 
126
129
  - **Витік з інших маршрутів**: Та ж ідея для **інших екранів** у додатку: чи додається їхній текст, коли ви відкрили лише одну сторінку (наприклад: контент сторінки `/en/about` у бандлі сторінки `/en/contact`). Високий бал вказує на слабкий поділ або занадто широкі бандли.
127
130
 
128
- - **Середній розмір бандла компонента**: Загальні елементи інтерфейсу вимірюються **по одному**, замість того щоб ховатися всередині одного гігантського числа додатка. Це показує, чи інтернаціоналізація непомітно роздуває повсякденні компоненти. Наприклад, якщо ваш компонент перерендерюється, він завантажуватиме всі ці дані з пам'яті. Прикріплення гігантського JSON до будь-якого компонента це як підключення великого сховища невикористовуваних даних, що сповільнить продуктивність ваших компонентів.
131
+ - **Середній розмір бандла компонента**: Загальні елементи інтерфейсу вимірюються **по одному**, замість того щоб ховатися всередині одного гігантського числа додатка. Це показує, чи інтернаціоналізація непомітно роздуває повсякденні компоненти. Наприклад, якщо ваш компонент перерендерюється, він завантажуватиме всі ці дані з пам'яті. Прикріплення гігантського JSON до будь-якого компонента - це як підключення великого сховища невикористовуваних даних, що сповільнить продуктивність ваших компонентів.
129
132
 
130
- - **Швидкість реакції на зміну мови**: Я змінюю мову за допомогою власного контролера додатка і вимірюю час, поки сторінка чітко не зміниться те, що помітить відвідувач.
133
+ - **Швидкість реакції на зміну мови**: Я змінюю мову за допомогою власного контролера додатка і вимірюю час, поки сторінка чітко не зміниться - те, що помітить відвідувач.
131
134
 
132
135
  - **Робота рендерингу після зміни мови**: Більш точне спостереження: скільки зусиль доклав інтерфейс для перемальовування для нової мови після початку зміни. Корисно, коли "відчутний" час і витрати фреймворку розходяться.
133
136
 
@@ -135,13 +138,19 @@ style="border:none;"
135
138
 
136
139
  - **Час гідратації (Hydration)**: Час, який клієнт витрачає на перетворення серверного HTML на інтерактивний інтерфейс. Тире в таблицях означає, що ця реалізація не надала надійного показника гідратації в цьому бенчмарку.
137
140
 
141
+ ## Зірки на GitHub
142
+
143
+ Зірки на GitHub є потужним індикатором популярності проекту, довіри спільноти та довгострокової актуальності. Хоча вони не є прямим показником технічної якості, вони відображають, скільки розробників вважають проект корисним, стежать за його розвитком і, ймовірно, впровадять його. Для оцінки цінності проекту зірки допомагають порівняти інтерес до альтернатив і дають уявлення про зростання екосистеми.
144
+
145
+ [![Star History Chart](https://api.star-history.com/chart?repos=intlify%2Fvue-i18n%2Cfluent-vue%2Ffluent-vue%2Caymericzip%2Fintlayer&type=date&legend=top-left)](https://www.star-history.com/#intlify/vue-i18n&fluent-vue/fluent-vue&aymericzip/intlayer)
146
+
138
147
  ## Результати детально
139
148
 
140
- ### 1 Рішення, яких слід уникати
149
+ ### 1 - Рішення, яких слід уникати
141
150
 
142
151
  > В екосистемі Vue немає очевидних рішень, яких слід уникати.
143
152
 
144
- ### 2 Прийнятні рішення
153
+ ### 2 - Прийнятні рішення
145
154
 
146
155
  **(vue-i18n)** (`vue-i18n@11.4.0`):
147
156
 
@@ -153,7 +162,7 @@ style="border:none;"
153
162
 
154
163
  - **fluent-vue** пропонує спробу інновації через формат .ftl. Організація повідомлень чудова, легше почати роботу. Але на практиці відсутність безпеки типів підвищує ризик помилок і налагодження може швидко стати трудомістким. Більше того, це рішення завантажує повідомлення за допомогою плагіна vite, який змушує завантажувати весь контент усіма мовами на кожну сторінку. Крім того, це надзвичайно важке рішення (~92.7kb, що приблизно в 34 рази більше за `vue-intlayer`).
155
164
 
156
- ### 3 Рекомендації
165
+ ### 3 - Рекомендації
157
166
 
158
167
  **(Intlayer)** (`vue-intlayer@8.7.12`):
159
168
 
@@ -35,7 +35,7 @@ history:
35
35
 
36
36
  ## Сканування бандла
37
37
 
38
- Аналіз бандла це перший крок до виявлення "важких" JSON-файлів та можливостей розділення коду. Ці інструменти генерують візуальну деревоподібну карту (treemap) скомпільованого коду вашого застосунку, дозволяючи вам точно побачити, які бібліотеки займають найбільше місця.
38
+ Аналіз бандла - це перший крок до виявлення "важких" JSON-файлів та можливостей розділення коду. Ці інструменти генерують візуальну деревоподібну карту (treemap) скомпільованого коду вашого застосунку, дозволяючи вам точно побачити, які бібліотеки займають найбільше місця.
39
39
 
40
40
  <Tabs>
41
41
  <Tab value="vite">