@intlayer/docs 8.5.1 → 8.6.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (727) hide show
  1. package/blog/ar/intlayer_with_i18next.md +1 -1
  2. package/blog/ar/intlayer_with_next-i18next.md +1 -1
  3. package/blog/ar/intlayer_with_next-intl.md +1 -1
  4. package/blog/ar/intlayer_with_react-i18next.md +1 -1
  5. package/blog/ar/intlayer_with_react-intl.md +1 -1
  6. package/blog/ar/intlayer_with_vue-i18n.md +1 -1
  7. package/blog/de/intlayer_with_i18next.md +1 -1
  8. package/blog/de/intlayer_with_next-i18next.md +1 -1
  9. package/blog/de/intlayer_with_next-intl.md +1 -1
  10. package/blog/de/intlayer_with_react-i18next.md +1 -1
  11. package/blog/de/intlayer_with_react-intl.md +1 -1
  12. package/blog/de/intlayer_with_vue-i18n.md +1 -1
  13. package/blog/en/intlayer_with_i18next.md +1 -1
  14. package/blog/en/intlayer_with_next-i18next.md +1 -1
  15. package/blog/en/intlayer_with_next-intl.md +1 -1
  16. package/blog/en/intlayer_with_react-i18next.md +1 -1
  17. package/blog/en/intlayer_with_react-intl.md +1 -1
  18. package/blog/en/intlayer_with_vue-i18n.md +1 -1
  19. package/blog/en-GB/intlayer_with_i18next.md +1 -1
  20. package/blog/en-GB/intlayer_with_next-i18next.md +1 -1
  21. package/blog/en-GB/intlayer_with_next-intl.md +1 -1
  22. package/blog/en-GB/intlayer_with_react-i18next.md +1 -1
  23. package/blog/en-GB/intlayer_with_react-intl.md +1 -1
  24. package/blog/en-GB/intlayer_with_vue-i18n.md +1 -1
  25. package/blog/es/intlayer_with_i18next.md +1 -1
  26. package/blog/es/intlayer_with_next-i18next.md +1 -1
  27. package/blog/es/intlayer_with_next-intl.md +1 -1
  28. package/blog/es/intlayer_with_react-i18next.md +1 -1
  29. package/blog/es/intlayer_with_react-intl.md +1 -1
  30. package/blog/es/intlayer_with_vue-i18n.md +1 -1
  31. package/blog/fr/intlayer_with_i18next.md +1 -1
  32. package/blog/fr/intlayer_with_next-i18next.md +1 -1
  33. package/blog/fr/intlayer_with_next-intl.md +1 -1
  34. package/blog/fr/intlayer_with_react-i18next.md +1 -1
  35. package/blog/fr/intlayer_with_react-intl.md +1 -1
  36. package/blog/fr/intlayer_with_vue-i18n.md +1 -1
  37. package/blog/hi/intlayer_with_i18next.md +1 -1
  38. package/blog/hi/intlayer_with_next-i18next.md +1 -1
  39. package/blog/hi/intlayer_with_next-intl.md +1 -1
  40. package/blog/hi/intlayer_with_react-i18next.md +1 -1
  41. package/blog/hi/intlayer_with_react-intl.md +1 -1
  42. package/blog/hi/intlayer_with_vue-i18n.md +1 -1
  43. package/blog/id/intlayer_with_i18next.md +1 -1
  44. package/blog/id/intlayer_with_next-i18next.md +1 -1
  45. package/blog/id/intlayer_with_next-intl.md +1 -1
  46. package/blog/id/intlayer_with_react-i18next.md +1 -1
  47. package/blog/id/intlayer_with_react-intl.md +1 -1
  48. package/blog/id/intlayer_with_vue-i18n.md +1 -1
  49. package/blog/it/intlayer_with_i18next.md +1 -1
  50. package/blog/it/intlayer_with_next-i18next.md +1 -1
  51. package/blog/it/intlayer_with_next-intl.md +1 -1
  52. package/blog/it/intlayer_with_react-i18next.md +1 -1
  53. package/blog/it/intlayer_with_react-intl.md +1 -1
  54. package/blog/it/intlayer_with_vue-i18n.md +1 -1
  55. package/blog/ja/intlayer_with_i18next.md +1 -1
  56. package/blog/ja/intlayer_with_next-i18next.md +1 -1
  57. package/blog/ja/intlayer_with_next-intl.md +1 -1
  58. package/blog/ja/intlayer_with_react-i18next.md +1 -1
  59. package/blog/ja/intlayer_with_react-intl.md +1 -1
  60. package/blog/ja/intlayer_with_vue-i18n.md +1 -1
  61. package/blog/ko/intlayer_with_i18next.md +1 -1
  62. package/blog/ko/intlayer_with_next-i18next.md +1 -1
  63. package/blog/ko/intlayer_with_next-intl.md +1 -1
  64. package/blog/ko/intlayer_with_react-i18next.md +1 -1
  65. package/blog/ko/intlayer_with_react-intl.md +1 -1
  66. package/blog/ko/intlayer_with_vue-i18n.md +1 -1
  67. package/blog/pl/intlayer_with_i18next.md +1 -1
  68. package/blog/pl/intlayer_with_next-i18next.md +1 -1
  69. package/blog/pl/intlayer_with_next-intl.md +1 -1
  70. package/blog/pl/intlayer_with_react-i18next.md +1 -1
  71. package/blog/pl/intlayer_with_react-intl.md +1 -1
  72. package/blog/pl/intlayer_with_vue-i18n.md +1 -1
  73. package/blog/pt/intlayer_with_i18next.md +1 -1
  74. package/blog/pt/intlayer_with_next-i18next.md +1 -1
  75. package/blog/pt/intlayer_with_next-intl.md +1 -1
  76. package/blog/pt/intlayer_with_react-i18next.md +1 -1
  77. package/blog/pt/intlayer_with_react-intl.md +1 -1
  78. package/blog/pt/intlayer_with_vue-i18n.md +1 -1
  79. package/blog/ru/intlayer_with_i18next.md +1 -1
  80. package/blog/ru/intlayer_with_next-i18next.md +1 -1
  81. package/blog/ru/intlayer_with_next-intl.md +1 -1
  82. package/blog/ru/intlayer_with_react-i18next.md +1 -1
  83. package/blog/ru/intlayer_with_react-intl.md +1 -1
  84. package/blog/ru/intlayer_with_vue-i18n.md +1 -1
  85. package/blog/tr/intlayer_with_i18next.md +1 -1
  86. package/blog/tr/intlayer_with_next-i18next.md +1 -1
  87. package/blog/tr/intlayer_with_next-intl.md +1 -1
  88. package/blog/tr/intlayer_with_react-i18next.md +1 -1
  89. package/blog/tr/intlayer_with_react-intl.md +1 -1
  90. package/blog/tr/intlayer_with_vue-i18n.md +1 -1
  91. package/blog/uk/intlayer_with_i18next.md +1 -1
  92. package/blog/uk/intlayer_with_next-i18next.md +1 -1
  93. package/blog/uk/intlayer_with_next-intl.md +1 -1
  94. package/blog/uk/intlayer_with_react-i18next.md +1 -1
  95. package/blog/uk/intlayer_with_react-intl.md +1 -1
  96. package/blog/uk/intlayer_with_vue-i18n.md +1 -1
  97. package/blog/vi/intlayer_with_i18next.md +1 -1
  98. package/blog/vi/intlayer_with_next-i18next.md +1 -1
  99. package/blog/vi/intlayer_with_next-intl.md +1 -1
  100. package/blog/vi/intlayer_with_react-i18next.md +1 -1
  101. package/blog/vi/intlayer_with_react-intl.md +1 -1
  102. package/blog/vi/intlayer_with_vue-i18n.md +1 -1
  103. package/blog/zh/intlayer_with_i18next.md +1 -1
  104. package/blog/zh/intlayer_with_next-i18next.md +1 -1
  105. package/blog/zh/intlayer_with_next-intl.md +1 -1
  106. package/blog/zh/intlayer_with_react-i18next.md +1 -1
  107. package/blog/zh/intlayer_with_react-intl.md +1 -1
  108. package/blog/zh/intlayer_with_vue-i18n.md +1 -1
  109. package/dist/cjs/generated/docs.entry.cjs +20 -0
  110. package/dist/cjs/generated/docs.entry.cjs.map +1 -1
  111. package/dist/esm/generated/docs.entry.mjs +20 -0
  112. package/dist/esm/generated/docs.entry.mjs.map +1 -1
  113. package/dist/types/generated/docs.entry.d.ts +1 -0
  114. package/dist/types/generated/docs.entry.d.ts.map +1 -1
  115. package/docs/ar/intlayer_CMS.md +1 -1
  116. package/docs/ar/intlayer_with_adonisjs.md +1 -1
  117. package/docs/ar/intlayer_with_analog.md +1 -1
  118. package/docs/ar/intlayer_with_angular.md +1 -1
  119. package/docs/ar/intlayer_with_create_react_app.md +1 -1
  120. package/docs/ar/intlayer_with_express.md +1 -1
  121. package/docs/ar/intlayer_with_fastify.md +1 -1
  122. package/docs/ar/intlayer_with_hono.md +1 -1
  123. package/docs/ar/intlayer_with_lynx+react.md +1 -1
  124. package/docs/ar/intlayer_with_nestjs.md +1 -1
  125. package/docs/ar/intlayer_with_next-i18next.md +1 -1
  126. package/docs/ar/intlayer_with_next-intl.md +1 -1
  127. package/docs/ar/intlayer_with_nextjs_14.md +1 -1
  128. package/docs/ar/intlayer_with_nextjs_15.md +1 -1
  129. package/docs/ar/intlayer_with_nextjs_16.md +2 -2
  130. package/docs/ar/intlayer_with_nextjs_compiler.md +2 -2
  131. package/docs/ar/intlayer_with_nextjs_no_locale_path.md +1 -1
  132. package/docs/ar/intlayer_with_nextjs_page_router.md +1 -1
  133. package/docs/ar/intlayer_with_nuxt.md +1 -1
  134. package/docs/ar/intlayer_with_react_native+expo.md +1 -1
  135. package/docs/ar/intlayer_with_react_router_v7.md +4 -6
  136. package/docs/ar/intlayer_with_react_router_v7_fs_routes.md +4 -6
  137. package/docs/ar/intlayer_with_svelte_kit.md +5 -5
  138. package/docs/ar/intlayer_with_tanstack+solid.md +894 -0
  139. package/docs/ar/intlayer_with_tanstack.md +2 -10
  140. package/docs/ar/intlayer_with_vite+lit.md +1 -2
  141. package/docs/ar/intlayer_with_vite+preact.md +2 -2
  142. package/docs/ar/intlayer_with_vite+react.md +2 -2
  143. package/docs/ar/intlayer_with_vite+react_compiler.md +1 -1
  144. package/docs/ar/intlayer_with_vite+solid.md +2 -3
  145. package/docs/ar/intlayer_with_vite+svelte.md +3 -3
  146. package/docs/ar/intlayer_with_vite+vanilla.md +2 -2
  147. package/docs/ar/intlayer_with_vite+vue.md +2 -2
  148. package/docs/bn/intlayer_with_fastify.md +1 -1
  149. package/docs/bn/intlayer_with_hono.md +1 -1
  150. package/docs/bn/intlayer_with_vite+lit.md +1 -2
  151. package/docs/bn/intlayer_with_vite+vanilla.md +2 -2
  152. package/docs/cs/intlayer_with_fastify.md +1 -1
  153. package/docs/cs/intlayer_with_hono.md +1 -1
  154. package/docs/cs/intlayer_with_vite+lit.md +1 -2
  155. package/docs/cs/intlayer_with_vite+vanilla.md +2 -2
  156. package/docs/de/intlayer_CMS.md +1 -1
  157. package/docs/de/intlayer_with_adonisjs.md +1 -1
  158. package/docs/de/intlayer_with_analog.md +1 -1
  159. package/docs/de/intlayer_with_angular.md +1 -1
  160. package/docs/de/intlayer_with_create_react_app.md +1 -1
  161. package/docs/de/intlayer_with_express.md +1 -1
  162. package/docs/de/intlayer_with_fastify.md +1 -1
  163. package/docs/de/intlayer_with_hono.md +1 -1
  164. package/docs/de/intlayer_with_lynx+react.md +1 -1
  165. package/docs/de/intlayer_with_nestjs.md +1 -1
  166. package/docs/de/intlayer_with_next-i18next.md +1 -1
  167. package/docs/de/intlayer_with_next-intl.md +1 -1
  168. package/docs/de/intlayer_with_nextjs_14.md +1 -1
  169. package/docs/de/intlayer_with_nextjs_15.md +1 -1
  170. package/docs/de/intlayer_with_nextjs_16.md +2 -2
  171. package/docs/de/intlayer_with_nextjs_compiler.md +1 -1
  172. package/docs/de/intlayer_with_nextjs_no_locale_path.md +1 -1
  173. package/docs/de/intlayer_with_nextjs_page_router.md +1 -1
  174. package/docs/de/intlayer_with_nuxt.md +1 -1
  175. package/docs/de/intlayer_with_react_router_v7.md +4 -6
  176. package/docs/de/intlayer_with_react_router_v7_fs_routes.md +2 -3
  177. package/docs/de/intlayer_with_svelte_kit.md +5 -5
  178. package/docs/de/intlayer_with_tanstack+solid.md +970 -0
  179. package/docs/de/intlayer_with_tanstack.md +98 -30
  180. package/docs/de/intlayer_with_vite+lit.md +1 -2
  181. package/docs/de/intlayer_with_vite+preact.md +2 -2
  182. package/docs/de/intlayer_with_vite+react.md +2 -2
  183. package/docs/de/intlayer_with_vite+react_compiler.md +1 -1
  184. package/docs/de/intlayer_with_vite+solid.md +2 -3
  185. package/docs/de/intlayer_with_vite+svelte.md +3 -3
  186. package/docs/de/intlayer_with_vite+vanilla.md +2 -2
  187. package/docs/de/intlayer_with_vite+vue.md +2 -2
  188. package/docs/en/intlayer_CMS.md +1 -1
  189. package/docs/en/intlayer_with_adonisjs.md +1 -1
  190. package/docs/en/intlayer_with_analog.md +1 -1
  191. package/docs/en/intlayer_with_angular.md +1 -1
  192. package/docs/en/intlayer_with_create_react_app.md +1 -1
  193. package/docs/en/intlayer_with_express.md +1 -1
  194. package/docs/en/intlayer_with_fastify.md +1 -1
  195. package/docs/en/intlayer_with_hono.md +1 -1
  196. package/docs/en/intlayer_with_lynx+react.md +1 -1
  197. package/docs/en/intlayer_with_nestjs.md +1 -1
  198. package/docs/en/intlayer_with_next-i18next.md +1 -1
  199. package/docs/en/intlayer_with_next-intl.md +1 -1
  200. package/docs/en/intlayer_with_nextjs_14.md +1 -1
  201. package/docs/en/intlayer_with_nextjs_15.md +1 -1
  202. package/docs/en/intlayer_with_nextjs_16.md +2 -2
  203. package/docs/en/intlayer_with_nextjs_compiler.md +2 -2
  204. package/docs/en/intlayer_with_nextjs_no_locale_path.md +1 -1
  205. package/docs/en/intlayer_with_nextjs_page_router.md +1 -1
  206. package/docs/en/intlayer_with_nuxt.md +1 -1
  207. package/docs/en/intlayer_with_react_native+expo.md +1 -1
  208. package/docs/en/intlayer_with_react_router_v7.md +3 -4
  209. package/docs/en/intlayer_with_react_router_v7_fs_routes.md +4 -6
  210. package/docs/en/intlayer_with_svelte_kit.md +4 -4
  211. package/docs/en/intlayer_with_tanstack+solid.md +973 -0
  212. package/docs/en/intlayer_with_tanstack.md +83 -12
  213. package/docs/en/intlayer_with_vite+lit.md +1 -2
  214. package/docs/en/intlayer_with_vite+preact.md +2 -2
  215. package/docs/en/intlayer_with_vite+react.md +2 -2
  216. package/docs/en/intlayer_with_vite+react_compiler.md +1 -1
  217. package/docs/en/intlayer_with_vite+solid.md +2 -3
  218. package/docs/en/intlayer_with_vite+svelte.md +7 -8
  219. package/docs/en/intlayer_with_vite+vanilla.md +2 -2
  220. package/docs/en/intlayer_with_vite+vue.md +2 -2
  221. package/docs/en-GB/intlayer_CMS.md +1 -1
  222. package/docs/en-GB/intlayer_with_adonisjs.md +1 -1
  223. package/docs/en-GB/intlayer_with_analog.md +1 -1
  224. package/docs/en-GB/intlayer_with_angular.md +1 -1
  225. package/docs/en-GB/intlayer_with_create_react_app.md +2 -2
  226. package/docs/en-GB/intlayer_with_express.md +1 -1
  227. package/docs/en-GB/intlayer_with_fastify.md +1 -1
  228. package/docs/en-GB/intlayer_with_hono.md +1 -1
  229. package/docs/en-GB/intlayer_with_lynx+react.md +2 -2
  230. package/docs/en-GB/intlayer_with_nestjs.md +1 -1
  231. package/docs/en-GB/intlayer_with_next-i18next.md +1 -1
  232. package/docs/en-GB/intlayer_with_next-intl.md +1 -1
  233. package/docs/en-GB/intlayer_with_nextjs_14.md +1 -1
  234. package/docs/en-GB/intlayer_with_nextjs_15.md +1 -1
  235. package/docs/en-GB/intlayer_with_nextjs_16.md +1 -1
  236. package/docs/en-GB/intlayer_with_nextjs_compiler.md +1 -1
  237. package/docs/en-GB/intlayer_with_nextjs_no_locale_path.md +1 -1
  238. package/docs/en-GB/intlayer_with_nextjs_page_router.md +1 -1
  239. package/docs/en-GB/intlayer_with_nuxt.md +1 -1
  240. package/docs/en-GB/intlayer_with_react_native+expo.md +1 -1
  241. package/docs/en-GB/intlayer_with_react_router_v7.md +3 -5
  242. package/docs/en-GB/intlayer_with_react_router_v7_fs_routes.md +3 -5
  243. package/docs/en-GB/intlayer_with_svelte_kit.md +4 -4
  244. package/docs/en-GB/intlayer_with_tanstack+solid.md +968 -0
  245. package/docs/en-GB/intlayer_with_tanstack.md +75 -10
  246. package/docs/en-GB/intlayer_with_vite+lit.md +1 -2
  247. package/docs/en-GB/intlayer_with_vite+preact.md +1 -1
  248. package/docs/en-GB/intlayer_with_vite+react.md +1 -1
  249. package/docs/en-GB/intlayer_with_vite+react_compiler.md +1 -1
  250. package/docs/en-GB/intlayer_with_vite+solid.md +1 -2
  251. package/docs/en-GB/intlayer_with_vite+svelte.md +2 -2
  252. package/docs/en-GB/intlayer_with_vite+vanilla.md +2 -2
  253. package/docs/en-GB/intlayer_with_vite+vue.md +1 -1
  254. package/docs/es/intlayer_CMS.md +1 -1
  255. package/docs/es/intlayer_with_adonisjs.md +1 -1
  256. package/docs/es/intlayer_with_analog.md +1 -1
  257. package/docs/es/intlayer_with_angular.md +1 -1
  258. package/docs/es/intlayer_with_create_react_app.md +1 -1
  259. package/docs/es/intlayer_with_express.md +1 -1
  260. package/docs/es/intlayer_with_fastify.md +1 -1
  261. package/docs/es/intlayer_with_hono.md +1 -1
  262. package/docs/es/intlayer_with_lynx+react.md +1 -1
  263. package/docs/es/intlayer_with_nestjs.md +1 -1
  264. package/docs/es/intlayer_with_next-i18next.md +1 -1
  265. package/docs/es/intlayer_with_next-intl.md +1 -1
  266. package/docs/es/intlayer_with_nextjs_14.md +1 -1
  267. package/docs/es/intlayer_with_nextjs_15.md +1 -1
  268. package/docs/es/intlayer_with_nextjs_16.md +2 -2
  269. package/docs/es/intlayer_with_nextjs_compiler.md +2 -2
  270. package/docs/es/intlayer_with_nextjs_no_locale_path.md +1 -1
  271. package/docs/es/intlayer_with_nextjs_page_router.md +1 -1
  272. package/docs/es/intlayer_with_nuxt.md +1 -1
  273. package/docs/es/intlayer_with_react_native+expo.md +1 -1
  274. package/docs/es/intlayer_with_react_router_v7.md +4 -6
  275. package/docs/es/intlayer_with_react_router_v7_fs_routes.md +4 -6
  276. package/docs/es/intlayer_with_svelte_kit.md +5 -5
  277. package/docs/es/intlayer_with_tanstack+solid.md +970 -0
  278. package/docs/es/intlayer_with_tanstack.md +98 -30
  279. package/docs/es/intlayer_with_vite+lit.md +1 -2
  280. package/docs/es/intlayer_with_vite+preact.md +2 -2
  281. package/docs/es/intlayer_with_vite+react.md +2 -2
  282. package/docs/es/intlayer_with_vite+react_compiler.md +1 -1
  283. package/docs/es/intlayer_with_vite+solid.md +2 -3
  284. package/docs/es/intlayer_with_vite+svelte.md +3 -3
  285. package/docs/es/intlayer_with_vite+vanilla.md +2 -2
  286. package/docs/es/intlayer_with_vite+vue.md +2 -2
  287. package/docs/es/packages/next-intlayer/index.md +1 -1
  288. package/docs/es/packages/react-intlayer/index.md +1 -1
  289. package/docs/fr/intlayer_CMS.md +1 -1
  290. package/docs/fr/intlayer_with_adonisjs.md +1 -1
  291. package/docs/fr/intlayer_with_analog.md +1 -1
  292. package/docs/fr/intlayer_with_angular.md +1 -1
  293. package/docs/fr/intlayer_with_create_react_app.md +1 -1
  294. package/docs/fr/intlayer_with_express.md +1 -1
  295. package/docs/fr/intlayer_with_fastify.md +1 -1
  296. package/docs/fr/intlayer_with_hono.md +1 -1
  297. package/docs/fr/intlayer_with_lynx+react.md +1 -1
  298. package/docs/fr/intlayer_with_nestjs.md +1 -1
  299. package/docs/fr/intlayer_with_next-i18next.md +1 -1
  300. package/docs/fr/intlayer_with_next-intl.md +1 -1
  301. package/docs/fr/intlayer_with_nextjs_14.md +1 -1
  302. package/docs/fr/intlayer_with_nextjs_15.md +1 -1
  303. package/docs/fr/intlayer_with_nextjs_16.md +2 -2
  304. package/docs/fr/intlayer_with_nextjs_compiler.md +2 -2
  305. package/docs/fr/intlayer_with_nextjs_no_locale_path.md +1 -1
  306. package/docs/fr/intlayer_with_nextjs_page_router.md +1 -1
  307. package/docs/fr/intlayer_with_nuxt.md +1 -1
  308. package/docs/fr/intlayer_with_react_router_v7.md +4 -6
  309. package/docs/fr/intlayer_with_react_router_v7_fs_routes.md +4 -6
  310. package/docs/fr/intlayer_with_svelte_kit.md +6 -6
  311. package/docs/fr/intlayer_with_tanstack+solid.md +970 -0
  312. package/docs/fr/intlayer_with_tanstack.md +98 -30
  313. package/docs/fr/intlayer_with_vite+lit.md +1 -2
  314. package/docs/fr/intlayer_with_vite+preact.md +2 -2
  315. package/docs/fr/intlayer_with_vite+react.md +2 -2
  316. package/docs/fr/intlayer_with_vite+react_compiler.md +1 -1
  317. package/docs/fr/intlayer_with_vite+solid.md +2 -3
  318. package/docs/fr/intlayer_with_vite+svelte.md +3 -3
  319. package/docs/fr/intlayer_with_vite+vanilla.md +2 -2
  320. package/docs/fr/intlayer_with_vite+vue.md +2 -2
  321. package/docs/fr/packages/react-intlayer/index.md +1 -1
  322. package/docs/hi/intlayer_CMS.md +1 -1
  323. package/docs/hi/intlayer_with_adonisjs.md +1 -1
  324. package/docs/hi/intlayer_with_analog.md +1 -1
  325. package/docs/hi/intlayer_with_angular.md +1 -1
  326. package/docs/hi/intlayer_with_create_react_app.md +1 -1
  327. package/docs/hi/intlayer_with_express.md +1 -1
  328. package/docs/hi/intlayer_with_fastify.md +1 -1
  329. package/docs/hi/intlayer_with_hono.md +1 -1
  330. package/docs/hi/intlayer_with_lynx+react.md +1 -1
  331. package/docs/hi/intlayer_with_nestjs.md +1 -1
  332. package/docs/hi/intlayer_with_next-i18next.md +1 -1
  333. package/docs/hi/intlayer_with_next-intl.md +1 -1
  334. package/docs/hi/intlayer_with_nextjs_14.md +1 -1
  335. package/docs/hi/intlayer_with_nextjs_15.md +1 -1
  336. package/docs/hi/intlayer_with_nextjs_16.md +2 -2
  337. package/docs/hi/intlayer_with_nextjs_compiler.md +2 -2
  338. package/docs/hi/intlayer_with_nextjs_no_locale_path.md +1 -1
  339. package/docs/hi/intlayer_with_nextjs_page_router.md +1 -1
  340. package/docs/hi/intlayer_with_nuxt.md +1 -1
  341. package/docs/hi/intlayer_with_react_router_v7.md +4 -6
  342. package/docs/hi/intlayer_with_react_router_v7_fs_routes.md +4 -6
  343. package/docs/hi/intlayer_with_svelte_kit.md +5 -5
  344. package/docs/hi/intlayer_with_tanstack+solid.md +894 -0
  345. package/docs/hi/intlayer_with_tanstack.md +2 -10
  346. package/docs/hi/intlayer_with_vite+lit.md +1 -2
  347. package/docs/hi/intlayer_with_vite+preact.md +2 -2
  348. package/docs/hi/intlayer_with_vite+react.md +2 -2
  349. package/docs/hi/intlayer_with_vite+react_compiler.md +1 -1
  350. package/docs/hi/intlayer_with_vite+solid.md +2 -3
  351. package/docs/hi/intlayer_with_vite+svelte.md +3 -3
  352. package/docs/hi/intlayer_with_vite+vanilla.md +2 -2
  353. package/docs/hi/intlayer_with_vite+vue.md +2 -2
  354. package/docs/hi/packages/intlayer/index.md +1 -1
  355. package/docs/id/intlayer_CMS.md +1 -1
  356. package/docs/id/intlayer_with_adonisjs.md +1 -1
  357. package/docs/id/intlayer_with_analog.md +1 -1
  358. package/docs/id/intlayer_with_angular.md +1 -1
  359. package/docs/id/intlayer_with_create_react_app.md +1 -1
  360. package/docs/id/intlayer_with_express.md +1 -1
  361. package/docs/id/intlayer_with_fastify.md +1 -1
  362. package/docs/id/intlayer_with_hono.md +1 -1
  363. package/docs/id/intlayer_with_lynx+react.md +1 -1
  364. package/docs/id/intlayer_with_nestjs.md +1 -1
  365. package/docs/id/intlayer_with_next-i18next.md +1 -1
  366. package/docs/id/intlayer_with_next-intl.md +1 -1
  367. package/docs/id/intlayer_with_nextjs_14.md +1 -1
  368. package/docs/id/intlayer_with_nextjs_15.md +1 -1
  369. package/docs/id/intlayer_with_nextjs_16.md +2 -2
  370. package/docs/id/intlayer_with_nextjs_compiler.md +2 -2
  371. package/docs/id/intlayer_with_nextjs_no_locale_path.md +1 -1
  372. package/docs/id/intlayer_with_nextjs_page_router.md +1 -1
  373. package/docs/id/intlayer_with_nuxt.md +1 -1
  374. package/docs/id/intlayer_with_react_native+expo.md +1 -1
  375. package/docs/id/intlayer_with_react_router_v7.md +4 -6
  376. package/docs/id/intlayer_with_react_router_v7_fs_routes.md +4 -6
  377. package/docs/id/intlayer_with_svelte_kit.md +5 -5
  378. package/docs/id/intlayer_with_tanstack+solid.md +894 -0
  379. package/docs/id/intlayer_with_tanstack.md +2 -10
  380. package/docs/id/intlayer_with_vite+lit.md +1 -2
  381. package/docs/id/intlayer_with_vite+preact.md +2 -2
  382. package/docs/id/intlayer_with_vite+react.md +2 -2
  383. package/docs/id/intlayer_with_vite+react_compiler.md +1 -1
  384. package/docs/id/intlayer_with_vite+solid.md +2 -3
  385. package/docs/id/intlayer_with_vite+svelte.md +3 -3
  386. package/docs/id/intlayer_with_vite+vanilla.md +2 -2
  387. package/docs/id/intlayer_with_vite+vue.md +2 -2
  388. package/docs/it/intlayer_CMS.md +1 -1
  389. package/docs/it/intlayer_with_adonisjs.md +1 -1
  390. package/docs/it/intlayer_with_analog.md +1 -1
  391. package/docs/it/intlayer_with_angular.md +1 -1
  392. package/docs/it/intlayer_with_create_react_app.md +1 -1
  393. package/docs/it/intlayer_with_express.md +1 -1
  394. package/docs/it/intlayer_with_fastify.md +1 -1
  395. package/docs/it/intlayer_with_hono.md +1 -1
  396. package/docs/it/intlayer_with_lynx+react.md +1 -1
  397. package/docs/it/intlayer_with_nestjs.md +1 -1
  398. package/docs/it/intlayer_with_next-i18next.md +1 -1
  399. package/docs/it/intlayer_with_next-intl.md +1 -1
  400. package/docs/it/intlayer_with_nextjs_14.md +1 -1
  401. package/docs/it/intlayer_with_nextjs_15.md +1 -1
  402. package/docs/it/intlayer_with_nextjs_16.md +2 -2
  403. package/docs/it/intlayer_with_nextjs_compiler.md +2 -2
  404. package/docs/it/intlayer_with_nextjs_no_locale_path.md +1 -1
  405. package/docs/it/intlayer_with_nextjs_page_router.md +1 -1
  406. package/docs/it/intlayer_with_nuxt.md +1 -1
  407. package/docs/it/intlayer_with_react_native+expo.md +1 -1
  408. package/docs/it/intlayer_with_react_router_v7.md +4 -6
  409. package/docs/it/intlayer_with_react_router_v7_fs_routes.md +4 -6
  410. package/docs/it/intlayer_with_svelte_kit.md +6 -6
  411. package/docs/it/intlayer_with_tanstack+solid.md +970 -0
  412. package/docs/it/intlayer_with_tanstack.md +98 -32
  413. package/docs/it/intlayer_with_vite+lit.md +1 -2
  414. package/docs/it/intlayer_with_vite+preact.md +2 -2
  415. package/docs/it/intlayer_with_vite+react.md +2 -2
  416. package/docs/it/intlayer_with_vite+react_compiler.md +1 -1
  417. package/docs/it/intlayer_with_vite+solid.md +2 -3
  418. package/docs/it/intlayer_with_vite+svelte.md +3 -3
  419. package/docs/it/intlayer_with_vite+vanilla.md +2 -2
  420. package/docs/it/intlayer_with_vite+vue.md +2 -2
  421. package/docs/ja/intlayer_CMS.md +1 -1
  422. package/docs/ja/intlayer_with_adonisjs.md +1 -1
  423. package/docs/ja/intlayer_with_analog.md +1 -1
  424. package/docs/ja/intlayer_with_angular.md +1 -1
  425. package/docs/ja/intlayer_with_create_react_app.md +1 -1
  426. package/docs/ja/intlayer_with_express.md +1 -1
  427. package/docs/ja/intlayer_with_fastify.md +1 -1
  428. package/docs/ja/intlayer_with_hono.md +1 -1
  429. package/docs/ja/intlayer_with_lynx+react.md +1 -1
  430. package/docs/ja/intlayer_with_nestjs.md +1 -1
  431. package/docs/ja/intlayer_with_next-i18next.md +1 -1
  432. package/docs/ja/intlayer_with_next-intl.md +1 -1
  433. package/docs/ja/intlayer_with_nextjs_14.md +1 -1
  434. package/docs/ja/intlayer_with_nextjs_15.md +1 -1
  435. package/docs/ja/intlayer_with_nextjs_16.md +2 -2
  436. package/docs/ja/intlayer_with_nextjs_compiler.md +2 -2
  437. package/docs/ja/intlayer_with_nextjs_no_locale_path.md +1 -1
  438. package/docs/ja/intlayer_with_nextjs_page_router.md +1 -1
  439. package/docs/ja/intlayer_with_nuxt.md +1 -1
  440. package/docs/ja/intlayer_with_react_router_v7.md +2 -3
  441. package/docs/ja/intlayer_with_react_router_v7_fs_routes.md +4 -6
  442. package/docs/ja/intlayer_with_svelte_kit.md +1 -1
  443. package/docs/ja/intlayer_with_tanstack+solid.md +972 -0
  444. package/docs/ja/intlayer_with_tanstack.md +780 -94
  445. package/docs/ja/intlayer_with_vite+lit.md +1 -2
  446. package/docs/ja/intlayer_with_vite+preact.md +1 -1
  447. package/docs/ja/intlayer_with_vite+react.md +1 -1
  448. package/docs/ja/intlayer_with_vite+react_compiler.md +1 -1
  449. package/docs/ja/intlayer_with_vite+solid.md +2 -3
  450. package/docs/ja/intlayer_with_vite+svelte.md +3 -3
  451. package/docs/ja/intlayer_with_vite+vanilla.md +2 -2
  452. package/docs/ja/intlayer_with_vite+vue.md +2 -2
  453. package/docs/ko/intlayer_CMS.md +1 -1
  454. package/docs/ko/intlayer_with_adonisjs.md +1 -1
  455. package/docs/ko/intlayer_with_analog.md +1 -1
  456. package/docs/ko/intlayer_with_angular.md +1 -1
  457. package/docs/ko/intlayer_with_create_react_app.md +1 -1
  458. package/docs/ko/intlayer_with_express.md +1 -1
  459. package/docs/ko/intlayer_with_fastify.md +1 -1
  460. package/docs/ko/intlayer_with_hono.md +1 -1
  461. package/docs/ko/intlayer_with_lynx+react.md +1 -1
  462. package/docs/ko/intlayer_with_nestjs.md +1 -1
  463. package/docs/ko/intlayer_with_next-i18next.md +1 -1
  464. package/docs/ko/intlayer_with_next-intl.md +1 -1
  465. package/docs/ko/intlayer_with_nextjs_14.md +1 -1
  466. package/docs/ko/intlayer_with_nextjs_15.md +1 -1
  467. package/docs/ko/intlayer_with_nextjs_16.md +2 -2
  468. package/docs/ko/intlayer_with_nextjs_compiler.md +2 -2
  469. package/docs/ko/intlayer_with_nextjs_no_locale_path.md +1 -1
  470. package/docs/ko/intlayer_with_nextjs_page_router.md +1 -1
  471. package/docs/ko/intlayer_with_nuxt.md +1 -1
  472. package/docs/ko/intlayer_with_react_native+expo.md +1 -1
  473. package/docs/ko/intlayer_with_react_router_v7.md +4 -6
  474. package/docs/ko/intlayer_with_react_router_v7_fs_routes.md +4 -6
  475. package/docs/ko/intlayer_with_svelte_kit.md +5 -5
  476. package/docs/ko/intlayer_with_tanstack+solid.md +970 -0
  477. package/docs/ko/intlayer_with_tanstack.md +97 -103
  478. package/docs/ko/intlayer_with_vite+lit.md +1 -2
  479. package/docs/ko/intlayer_with_vite+preact.md +2 -2
  480. package/docs/ko/intlayer_with_vite+react.md +2 -2
  481. package/docs/ko/intlayer_with_vite+react_compiler.md +1 -1
  482. package/docs/ko/intlayer_with_vite+solid.md +2 -3
  483. package/docs/ko/intlayer_with_vite+svelte.md +3 -3
  484. package/docs/ko/intlayer_with_vite+vanilla.md +2 -2
  485. package/docs/ko/intlayer_with_vite+vue.md +2 -2
  486. package/docs/nl/intlayer_with_fastify.md +1 -1
  487. package/docs/nl/intlayer_with_hono.md +1 -1
  488. package/docs/nl/intlayer_with_vite+lit.md +1 -2
  489. package/docs/nl/intlayer_with_vite+vanilla.md +2 -2
  490. package/docs/pl/intlayer_CMS.md +1 -1
  491. package/docs/pl/intlayer_with_adonisjs.md +1 -1
  492. package/docs/pl/intlayer_with_analog.md +1 -1
  493. package/docs/pl/intlayer_with_angular.md +1 -1
  494. package/docs/pl/intlayer_with_create_react_app.md +1 -1
  495. package/docs/pl/intlayer_with_express.md +1 -1
  496. package/docs/pl/intlayer_with_fastify.md +1 -1
  497. package/docs/pl/intlayer_with_hono.md +1 -1
  498. package/docs/pl/intlayer_with_lynx+react.md +1 -1
  499. package/docs/pl/intlayer_with_nestjs.md +1 -1
  500. package/docs/pl/intlayer_with_next-i18next.md +1 -1
  501. package/docs/pl/intlayer_with_next-intl.md +1 -1
  502. package/docs/pl/intlayer_with_nextjs_14.md +1 -1
  503. package/docs/pl/intlayer_with_nextjs_15.md +1 -1
  504. package/docs/pl/intlayer_with_nextjs_16.md +2 -2
  505. package/docs/pl/intlayer_with_nextjs_compiler.md +2 -2
  506. package/docs/pl/intlayer_with_nextjs_no_locale_path.md +1 -1
  507. package/docs/pl/intlayer_with_nextjs_page_router.md +1 -1
  508. package/docs/pl/intlayer_with_nuxt.md +1 -1
  509. package/docs/pl/intlayer_with_react_native+expo.md +1 -1
  510. package/docs/pl/intlayer_with_react_router_v7.md +4 -6
  511. package/docs/pl/intlayer_with_react_router_v7_fs_routes.md +4 -6
  512. package/docs/pl/intlayer_with_svelte_kit.md +5 -5
  513. package/docs/pl/intlayer_with_tanstack+solid.md +894 -0
  514. package/docs/pl/intlayer_with_tanstack.md +2 -10
  515. package/docs/pl/intlayer_with_vite+lit.md +1 -2
  516. package/docs/pl/intlayer_with_vite+preact.md +2 -2
  517. package/docs/pl/intlayer_with_vite+react.md +2 -2
  518. package/docs/pl/intlayer_with_vite+react_compiler.md +1 -1
  519. package/docs/pl/intlayer_with_vite+solid.md +2 -3
  520. package/docs/pl/intlayer_with_vite+svelte.md +3 -3
  521. package/docs/pl/intlayer_with_vite+vanilla.md +2 -2
  522. package/docs/pl/intlayer_with_vite+vue.md +2 -2
  523. package/docs/pt/intlayer_CMS.md +1 -1
  524. package/docs/pt/intlayer_with_adonisjs.md +1 -1
  525. package/docs/pt/intlayer_with_analog.md +1 -1
  526. package/docs/pt/intlayer_with_angular.md +1 -1
  527. package/docs/pt/intlayer_with_create_react_app.md +1 -1
  528. package/docs/pt/intlayer_with_express.md +1 -1
  529. package/docs/pt/intlayer_with_fastify.md +1 -1
  530. package/docs/pt/intlayer_with_hono.md +1 -1
  531. package/docs/pt/intlayer_with_lynx+react.md +1 -1
  532. package/docs/pt/intlayer_with_nestjs.md +1 -1
  533. package/docs/pt/intlayer_with_next-i18next.md +1 -1
  534. package/docs/pt/intlayer_with_next-intl.md +1 -1
  535. package/docs/pt/intlayer_with_nextjs_14.md +1 -1
  536. package/docs/pt/intlayer_with_nextjs_15.md +1 -1
  537. package/docs/pt/intlayer_with_nextjs_16.md +2 -2
  538. package/docs/pt/intlayer_with_nextjs_compiler.md +2 -2
  539. package/docs/pt/intlayer_with_nextjs_no_locale_path.md +1 -1
  540. package/docs/pt/intlayer_with_nextjs_page_router.md +1 -1
  541. package/docs/pt/intlayer_with_nuxt.md +1 -1
  542. package/docs/pt/intlayer_with_react_native+expo.md +1 -1
  543. package/docs/pt/intlayer_with_react_router_v7.md +3 -4
  544. package/docs/pt/intlayer_with_react_router_v7_fs_routes.md +4 -6
  545. package/docs/pt/intlayer_with_svelte_kit.md +6 -6
  546. package/docs/pt/intlayer_with_tanstack+solid.md +970 -0
  547. package/docs/pt/intlayer_with_tanstack.md +98 -32
  548. package/docs/pt/intlayer_with_vite+lit.md +1 -2
  549. package/docs/pt/intlayer_with_vite+preact.md +2 -2
  550. package/docs/pt/intlayer_with_vite+react.md +2 -2
  551. package/docs/pt/intlayer_with_vite+react_compiler.md +1 -1
  552. package/docs/pt/intlayer_with_vite+solid.md +2 -3
  553. package/docs/pt/intlayer_with_vite+svelte.md +3 -3
  554. package/docs/pt/intlayer_with_vite+vanilla.md +2 -2
  555. package/docs/pt/intlayer_with_vite+vue.md +2 -2
  556. package/docs/ru/intlayer_CMS.md +1 -1
  557. package/docs/ru/intlayer_with_adonisjs.md +1 -1
  558. package/docs/ru/intlayer_with_analog.md +1 -1
  559. package/docs/ru/intlayer_with_angular.md +1 -1
  560. package/docs/ru/intlayer_with_create_react_app.md +1 -1
  561. package/docs/ru/intlayer_with_express.md +1 -1
  562. package/docs/ru/intlayer_with_fastify.md +1 -1
  563. package/docs/ru/intlayer_with_hono.md +1 -1
  564. package/docs/ru/intlayer_with_lynx+react.md +1 -1
  565. package/docs/ru/intlayer_with_nestjs.md +1 -1
  566. package/docs/ru/intlayer_with_next-i18next.md +1 -1
  567. package/docs/ru/intlayer_with_next-intl.md +1 -1
  568. package/docs/ru/intlayer_with_nextjs_14.md +1 -1
  569. package/docs/ru/intlayer_with_nextjs_15.md +1 -1
  570. package/docs/ru/intlayer_with_nextjs_16.md +2 -2
  571. package/docs/ru/intlayer_with_nextjs_compiler.md +2 -2
  572. package/docs/ru/intlayer_with_nextjs_no_locale_path.md +1 -1
  573. package/docs/ru/intlayer_with_nextjs_page_router.md +1 -1
  574. package/docs/ru/intlayer_with_nuxt.md +1 -1
  575. package/docs/ru/intlayer_with_react_native+expo.md +1 -1
  576. package/docs/ru/intlayer_with_react_router_v7.md +4 -6
  577. package/docs/ru/intlayer_with_react_router_v7_fs_routes.md +4 -6
  578. package/docs/ru/intlayer_with_svelte_kit.md +5 -5
  579. package/docs/ru/intlayer_with_tanstack+solid.md +970 -0
  580. package/docs/ru/intlayer_with_tanstack.md +101 -35
  581. package/docs/ru/intlayer_with_vite+lit.md +1 -2
  582. package/docs/ru/intlayer_with_vite+preact.md +2 -2
  583. package/docs/ru/intlayer_with_vite+react.md +2 -2
  584. package/docs/ru/intlayer_with_vite+react_compiler.md +1 -1
  585. package/docs/ru/intlayer_with_vite+solid.md +2 -3
  586. package/docs/ru/intlayer_with_vite+svelte.md +3 -3
  587. package/docs/ru/intlayer_with_vite+vanilla.md +2 -2
  588. package/docs/ru/intlayer_with_vite+vue.md +2 -2
  589. package/docs/tr/intlayer_CMS.md +1 -1
  590. package/docs/tr/intlayer_with_adonisjs.md +1 -1
  591. package/docs/tr/intlayer_with_analog.md +1 -1
  592. package/docs/tr/intlayer_with_angular.md +1 -1
  593. package/docs/tr/intlayer_with_create_react_app.md +1 -1
  594. package/docs/tr/intlayer_with_express.md +1 -1
  595. package/docs/tr/intlayer_with_fastify.md +1 -1
  596. package/docs/tr/intlayer_with_hono.md +1 -1
  597. package/docs/tr/intlayer_with_lynx+react.md +1 -1
  598. package/docs/tr/intlayer_with_nestjs.md +1 -1
  599. package/docs/tr/intlayer_with_next-i18next.md +1 -1
  600. package/docs/tr/intlayer_with_next-intl.md +1 -1
  601. package/docs/tr/intlayer_with_nextjs_14.md +1 -1
  602. package/docs/tr/intlayer_with_nextjs_15.md +1 -1
  603. package/docs/tr/intlayer_with_nextjs_16.md +2 -2
  604. package/docs/tr/intlayer_with_nextjs_compiler.md +2 -2
  605. package/docs/tr/intlayer_with_nextjs_no_locale_path.md +1 -1
  606. package/docs/tr/intlayer_with_nextjs_page_router.md +1 -1
  607. package/docs/tr/intlayer_with_nuxt.md +1 -1
  608. package/docs/tr/intlayer_with_react_native+expo.md +1 -1
  609. package/docs/tr/intlayer_with_react_router_v7.md +4 -6
  610. package/docs/tr/intlayer_with_react_router_v7_fs_routes.md +4 -6
  611. package/docs/tr/intlayer_with_svelte_kit.md +5 -5
  612. package/docs/tr/intlayer_with_tanstack+solid.md +895 -0
  613. package/docs/tr/intlayer_with_tanstack.md +2 -10
  614. package/docs/tr/intlayer_with_vite+lit.md +1 -2
  615. package/docs/tr/intlayer_with_vite+preact.md +2 -2
  616. package/docs/tr/intlayer_with_vite+react.md +2 -2
  617. package/docs/tr/intlayer_with_vite+react_compiler.md +1 -1
  618. package/docs/tr/intlayer_with_vite+solid.md +2 -3
  619. package/docs/tr/intlayer_with_vite+svelte.md +3 -3
  620. package/docs/tr/intlayer_with_vite+vanilla.md +2 -2
  621. package/docs/tr/intlayer_with_vite+vue.md +2 -2
  622. package/docs/uk/intlayer_CMS.md +1 -1
  623. package/docs/uk/intlayer_with_adonisjs.md +1 -1
  624. package/docs/uk/intlayer_with_analog.md +1 -1
  625. package/docs/uk/intlayer_with_angular.md +1 -1
  626. package/docs/uk/intlayer_with_create_react_app.md +1 -1
  627. package/docs/uk/intlayer_with_express.md +1 -1
  628. package/docs/uk/intlayer_with_fastify.md +1 -1
  629. package/docs/uk/intlayer_with_hono.md +1 -1
  630. package/docs/uk/intlayer_with_lynx+react.md +1 -1
  631. package/docs/uk/intlayer_with_nestjs.md +1 -1
  632. package/docs/uk/intlayer_with_next-i18next.md +1 -1
  633. package/docs/uk/intlayer_with_next-intl.md +1 -1
  634. package/docs/uk/intlayer_with_nextjs_14.md +1 -1
  635. package/docs/uk/intlayer_with_nextjs_15.md +1 -1
  636. package/docs/uk/intlayer_with_nextjs_16.md +2 -2
  637. package/docs/uk/intlayer_with_nextjs_compiler.md +2 -2
  638. package/docs/uk/intlayer_with_nextjs_no_locale_path.md +1 -1
  639. package/docs/uk/intlayer_with_nextjs_page_router.md +1 -1
  640. package/docs/uk/intlayer_with_nuxt.md +1 -1
  641. package/docs/uk/intlayer_with_react_native+expo.md +1 -1
  642. package/docs/uk/intlayer_with_react_router_v7.md +3 -4
  643. package/docs/uk/intlayer_with_react_router_v7_fs_routes.md +4 -6
  644. package/docs/uk/intlayer_with_svelte_kit.md +4 -4
  645. package/docs/uk/intlayer_with_tanstack+solid.md +894 -0
  646. package/docs/uk/intlayer_with_tanstack.md +2 -10
  647. package/docs/uk/intlayer_with_vite+lit.md +1 -2
  648. package/docs/uk/intlayer_with_vite+preact.md +2 -2
  649. package/docs/uk/intlayer_with_vite+react.md +2 -2
  650. package/docs/uk/intlayer_with_vite+react_compiler.md +1 -1
  651. package/docs/uk/intlayer_with_vite+solid.md +2 -3
  652. package/docs/uk/intlayer_with_vite+svelte.md +3 -3
  653. package/docs/uk/intlayer_with_vite+vanilla.md +2 -2
  654. package/docs/uk/intlayer_with_vite+vue.md +2 -2
  655. package/docs/ur/intlayer_with_fastify.md +1 -1
  656. package/docs/ur/intlayer_with_hono.md +1 -1
  657. package/docs/ur/intlayer_with_vite+lit.md +1 -2
  658. package/docs/ur/intlayer_with_vite+vanilla.md +1 -1
  659. package/docs/vi/cli/index.md +1 -1
  660. package/docs/vi/intlayer_CMS.md +1 -1
  661. package/docs/vi/intlayer_with_adonisjs.md +1 -1
  662. package/docs/vi/intlayer_with_analog.md +1 -1
  663. package/docs/vi/intlayer_with_angular.md +1 -1
  664. package/docs/vi/intlayer_with_create_react_app.md +1 -1
  665. package/docs/vi/intlayer_with_express.md +1 -1
  666. package/docs/vi/intlayer_with_fastify.md +1 -1
  667. package/docs/vi/intlayer_with_hono.md +1 -1
  668. package/docs/vi/intlayer_with_lynx+react.md +1 -1
  669. package/docs/vi/intlayer_with_nestjs.md +1 -1
  670. package/docs/vi/intlayer_with_next-i18next.md +1 -1
  671. package/docs/vi/intlayer_with_next-intl.md +1 -1
  672. package/docs/vi/intlayer_with_nextjs_14.md +1 -1
  673. package/docs/vi/intlayer_with_nextjs_15.md +1 -1
  674. package/docs/vi/intlayer_with_nextjs_16.md +2 -2
  675. package/docs/vi/intlayer_with_nextjs_compiler.md +2 -2
  676. package/docs/vi/intlayer_with_nextjs_no_locale_path.md +1 -1
  677. package/docs/vi/intlayer_with_nextjs_page_router.md +1 -1
  678. package/docs/vi/intlayer_with_nuxt.md +1 -1
  679. package/docs/vi/intlayer_with_react_native+expo.md +1 -1
  680. package/docs/vi/intlayer_with_react_router_v7.md +4 -6
  681. package/docs/vi/intlayer_with_react_router_v7_fs_routes.md +4 -6
  682. package/docs/vi/intlayer_with_svelte_kit.md +5 -5
  683. package/docs/vi/intlayer_with_tanstack+solid.md +894 -0
  684. package/docs/vi/intlayer_with_tanstack.md +2 -10
  685. package/docs/vi/intlayer_with_vite+lit.md +1 -2
  686. package/docs/vi/intlayer_with_vite+preact.md +2 -2
  687. package/docs/vi/intlayer_with_vite+react.md +2 -2
  688. package/docs/vi/intlayer_with_vite+react_compiler.md +1 -1
  689. package/docs/vi/intlayer_with_vite+solid.md +2 -3
  690. package/docs/vi/intlayer_with_vite+svelte.md +3 -3
  691. package/docs/vi/intlayer_with_vite+vanilla.md +2 -2
  692. package/docs/vi/intlayer_with_vite+vue.md +2 -2
  693. package/docs/zh/intlayer_CMS.md +1 -1
  694. package/docs/zh/intlayer_with_adonisjs.md +1 -1
  695. package/docs/zh/intlayer_with_analog.md +1 -1
  696. package/docs/zh/intlayer_with_angular.md +1 -1
  697. package/docs/zh/intlayer_with_create_react_app.md +1 -1
  698. package/docs/zh/intlayer_with_express.md +1 -1
  699. package/docs/zh/intlayer_with_fastify.md +1 -1
  700. package/docs/zh/intlayer_with_hono.md +1 -1
  701. package/docs/zh/intlayer_with_lynx+react.md +1 -1
  702. package/docs/zh/intlayer_with_nestjs.md +1 -1
  703. package/docs/zh/intlayer_with_next-i18next.md +1 -1
  704. package/docs/zh/intlayer_with_next-intl.md +1 -1
  705. package/docs/zh/intlayer_with_nextjs_14.md +1 -1
  706. package/docs/zh/intlayer_with_nextjs_15.md +1 -1
  707. package/docs/zh/intlayer_with_nextjs_16.md +2 -2
  708. package/docs/zh/intlayer_with_nextjs_compiler.md +2 -2
  709. package/docs/zh/intlayer_with_nextjs_no_locale_path.md +1 -1
  710. package/docs/zh/intlayer_with_nextjs_page_router.md +1 -1
  711. package/docs/zh/intlayer_with_nuxt.md +1 -1
  712. package/docs/zh/intlayer_with_react_native+expo.md +1 -1
  713. package/docs/zh/intlayer_with_react_router_v7.md +4 -6
  714. package/docs/zh/intlayer_with_react_router_v7_fs_routes.md +4 -6
  715. package/docs/zh/intlayer_with_svelte_kit.md +5 -5
  716. package/docs/zh/intlayer_with_tanstack+solid.md +970 -0
  717. package/docs/zh/intlayer_with_tanstack.md +98 -106
  718. package/docs/zh/intlayer_with_vite+lit.md +1 -2
  719. package/docs/zh/intlayer_with_vite+preact.md +2 -2
  720. package/docs/zh/intlayer_with_vite+react.md +2 -2
  721. package/docs/zh/intlayer_with_vite+react_compiler.md +1 -1
  722. package/docs/zh/intlayer_with_vite+solid.md +2 -3
  723. package/docs/zh/intlayer_with_vite+svelte.md +3 -3
  724. package/docs/zh/intlayer_with_vite+vanilla.md +2 -2
  725. package/docs/zh/intlayer_with_vite+vue.md +2 -2
  726. package/package.json +8 -8
  727. package/src/generated/docs.entry.ts +20 -0
@@ -0,0 +1,972 @@
1
+ ---
2
+ createdAt: 2025-03-25
3
+ updatedAt: 2026-03-29
4
+ title: Tanstack Start i18n - 2026年にSolid.jsを使用してTanstack Startアプリを翻訳する方法
5
+ description: IntlayerとSolid.jsを使用して、Tanstack Startアプリケーションに国際化(i18n)を追加する方法を学びます。この包括的なガイドに従って、ロケール対応ルーティングを備えた多言語アプリを作成してください。
6
+ keywords:
7
+ - 国際化
8
+ - ドキュメント
9
+ - Intlayer
10
+ - Tanstack Start
11
+ - Solid
12
+ - i18n
13
+ - TypeScript
14
+ - ロケールルーティング
15
+ - Sitemap
16
+ slugs:
17
+ - doc
18
+ - environment
19
+ - tanstack-start
20
+ applicationTemplate: https://github.com/aymericzip/intlayer-tanstack-start-solid-template
21
+ youtubeVideo: https://www.youtube.com/watch?v=_XTdKVWaeqg
22
+ history:
23
+ - version: 8.5.1
24
+ date: 2026-03-25
25
+ changes: "Tanstack Start Solid.js用に追加"
26
+ ---
27
+
28
+ # Intlayerを使用してTanstack Start + Solid.jsウェブサイトを翻訳する | 国際化 (i18n)
29
+
30
+ ## 目次
31
+
32
+ <TOC/>
33
+
34
+ このガイドでは、Solid.jsを使用したTanstack Startプロジェクトにおいて、Intlayerを統合してシームレスな国際化、ロケール対応ルーティング、TypeScriptサポート、および現代的な開発手法を実現する方法を説明します。
35
+
36
+ ## Intlayerとは?
37
+
38
+ **Intlayer**は、現代的なウェブアプリケーションにおける多言語サポートを簡素化するために設計された、革新的でオープンソースの国際化(i18n)ライブラリです。
39
+
40
+ Intlayerを使用すると、以下のことが可能になります:
41
+
42
+ - コンポーネントレベルで宣言的な辞書を使用して、**翻訳を簡単に管理**できます。
43
+ - メタデータ、ルート、コンテンツを**動的にローカライズ**できます。
44
+ - 自動生成された型により**TypeScriptサポートを確保**し、オートコンプリートとエラー検出を向上させます。
45
+ - 動的なロケール検出や切り替えなどの**高度な機能の恩恵**を受けられます。
46
+ - Tanstack Startのファイルベースルーティングシステムを使用して、**ロケール対応ルーティングを有効化**できます。
47
+
48
+ ---
49
+
50
+ ## Tanstack StartアプリケーションでIntlayerをセットアップするためのステップバイステップガイド
51
+
52
+ <Tabs defaultTab="video">
53
+ <Tab label="動画" value="video">
54
+
55
+ <iframe title="Tanstack Startに最適なi18nソリューションは?Intlayerを発見する" class="m-auto aspect-16/9 w-full overflow-hidden rounded-lg border-0" allow="autoplay; gyroscope;" loading="lazy" width="1080" height="auto" src="https://www.youtube.com/embed/_XTdKVWaeqg?autoplay=0&amp;origin=http://intlayer.org&amp;controls=0&amp;rel=1"/>
56
+
57
+ </Tab>
58
+ <Tab label="コード" value="code">
59
+
60
+ <iframe
61
+ src="https://stackblitz.com/github/aymericzip/intlayer-tanstack-start-solid-template?embed=1&ctl=1&file=intlayer.config.ts"
62
+ className="m-auto overflow-hidden rounded-lg border-0 max-md:size-full max-md:h-[700px] md:aspect-16/9 md:w-full"
63
+ title="デモ CodeSandbox - Intlayerを使用してアプリケーションを国際化する方法"
64
+ sandbox="allow-forms allow-modals allow-popups allow-presentation allow-same-origin allow-scripts"
65
+ loading="lazy"
66
+ />
67
+
68
+ </Tab>
69
+ </Tabs>
70
+
71
+ GitHubで[アプリケーションテンプレート](https://github.com/aymericzip/intlayer-tanstack-start-solid-template)を確認してください。
72
+
73
+ ### ステップ 1: プロジェクト作成
74
+
75
+ まず、TanStack Startウェブサイトの[新しいプロジェクトを開始](https://tanstack.com/start/latest/docs/framework/solid/quick-start)ガイドに従って、新しいTanStack Startプロジェクトを作成します。
76
+
77
+ ### ステップ 2: Intlayerパッケージのインストール
78
+
79
+ お好みのパッケージマネージャーを使用して、必要なパッケージをインストールします:
80
+
81
+ ```bash packageManager="npm"
82
+ npm install intlayer solid-intlayer
83
+ npm install vite-intlayer --save-dev
84
+ npx intlayer init
85
+ ```
86
+
87
+ ```bash packageManager="pnpm"
88
+ pnpm add intlayer solid-intlayer
89
+ pnpm add vite-intlayer --save-dev
90
+ pnpm intlayer init
91
+ ```
92
+
93
+ ```bash packageManager="yarn"
94
+ yarn add intlayer solid-intlayer
95
+ yarn add vite-intlayer --save-dev
96
+ yarn intlayer init
97
+ ```
98
+
99
+ ```bash packageManager="bun"
100
+ bun add intlayer solid-intlayer
101
+ bun add vite-intlayer --dev
102
+ bun x intlayer init
103
+ ```
104
+
105
+ - **intlayer**
106
+
107
+ 構成管理、翻訳、[コンテンツ宣言](https://github.com/aymericzip/intlayer/blob/main/docs/docs/ja/dictionary/content_file.md)、トランスパイル、および[CLIコマンド](https://github.com/aymericzip/intlayer/blob/main/docs/docs/ja/cli/index.md)のための国際化ツールを提供するコアパッケージ。
108
+
109
+ - **solid-intlayer**
110
+ IntlayerをSolidアプリケーションと統合するためのパッケージ。Solidの国際化のためのコンテキストプロバイダーとフックを提供します。
111
+
112
+ - **vite-intlayer**
113
+ Intlayerを[Viteバンドラー](https://vite.dev/guide/why.html#why-bundle-for-production)と統合するためのViteプラグイン、およびユーザーの優先ロケールの検出、Cookie管理、URLリダイレクトを処理するためのミドルウェアが含まれています。
114
+
115
+ ### ステップ 3: プロジェクトの構成
116
+
117
+ アプリケーションの言語を構成するための構成ファイルを作成します:
118
+
119
+ ```typescript fileName="intlayer.config.ts"
120
+ import type { IntlayerConfig } from "intlayer";
121
+
122
+ import { Locales } from "intlayer";
123
+
124
+ const config: IntlayerConfig = {
125
+ internationalization: {
126
+ defaultLocale: Locales.ENGLISH,
127
+ locales: [Locales.ENGLISH, Locales.FRENCH, Locales.SPANISH],
128
+ },
129
+ };
130
+
131
+ export default config;
132
+ ```
133
+
134
+ > この構成ファイルを通じて、ローカライズされたURL、ミドルウェアのリダイレクト、Cookie名、コンテンツ宣言の場所と拡張子、コンソールでのIntlayerログの無効化などを設定できます。利用可能なパラメータの完全なリストについては、[構成ドキュメント](https://github.com/aymericzip/intlayer/blob/main/docs/docs/ja/configuration.md)を参照してください。
135
+
136
+ ### ステップ 4: Vite構成にIntlayerを統合する
137
+
138
+ Vite構成にintlayerプラグインを追加します:
139
+
140
+ ```typescript fileName="vite.config.ts"
141
+ import { intlayer } from "vite-intlayer";
142
+ import { defineConfig } from "vite";
143
+ import { devtools } from "@tanstack/devtools-vite";
144
+ import { tanstackStart } from "@tanstack/solid-start/plugin/vite";
145
+ import solidPlugin from "vite-plugin-solid";
146
+
147
+ export default defineConfig({
148
+ plugins: [
149
+ devtools(),
150
+ tanstackStart({
151
+ router: {
152
+ routeFileIgnorePattern:
153
+ ".content.(ts|tsx|js|mjs|cjs|jsx|json|jsonc|json5)$",
154
+ },
155
+ }),
156
+ solidPlugin({ ssr: true }),
157
+ intlayer(),
158
+ ],
159
+ });
160
+ ```
161
+
162
+ > `intlayer()` Viteプラグインは、IntlayerをViteと統合するために使用されます。コンテンツ宣言ファイルの構築を確実にし、開発モードでそれらを監視します。Viteアプリケーション内でIntlayer環境変数を定義します。さらに、パフォーマンスを最適化するためのエイリアスを提供します。
163
+
164
+ ### ステップ 5: ルートレイアウトの作成
165
+
166
+ 現在選択されているロケールを検出するために `useMatches` を使用し、`html` タグに `lang` および `dir` 属性を設定することで、国際化をサポートするようにルートレイアウトを構成します。
167
+
168
+ ```tsx fileName="src/routes/__root.tsx"
169
+ import {
170
+ HeadContent,
171
+ Outlet,
172
+ Scripts,
173
+ createRootRouteWithContext,
174
+ useMatches,
175
+ } from "@tanstack/solid-router";
176
+ import { TanStackRouterDevtools } from "@tanstack/solid-router-devtools";
177
+ import { HydrationScript } from "solid-js/web";
178
+ import { Suspense } from "solid-js";
179
+ import { IntlayerProvider } from "solid-intlayer";
180
+ import { defaultLocale, getHTMLTextDir, type Locale } from "intlayer";
181
+
182
+ export const Route = createRootRouteWithContext()({
183
+ shellComponent: RootComponent,
184
+ });
185
+
186
+ type Params = {
187
+ locale: Locale;
188
+ };
189
+
190
+ function RootComponent() {
191
+ const matches = useMatches();
192
+
193
+ // アクティブなマッチのパラメータからロケールを見つけようとします
194
+ // これはルートツリーで動的セグメント "/{-$locale}" を使用していることを前提としています
195
+ const locale =
196
+ (
197
+ matches().find((match) => match.routeId === "/{-$locale}/")
198
+ ?.params as Params
199
+ )?.locale ?? defaultLocale;
200
+
201
+ return (
202
+ <html dir={getHTMLTextDir(locale)} lang={locale}>
203
+ <head>
204
+ <HydrationScript />
205
+ </head>
206
+ <body>
207
+ <HeadContent />
208
+ <IntlayerProvider locale={locale}>
209
+ <Suspense>
210
+ <Outlet />
211
+ <TanStackRouterDevtools />
212
+ </Suspense>
213
+ </IntlayerProvider>
214
+ <Scripts />
215
+ </body>
216
+ </html>
217
+ );
218
+ }
219
+ ```
220
+
221
+ ### ステップ 6: ロケールレイアウトの作成 (任意)
222
+
223
+ ロケールプレフィックスを処理し、検証を実行するレイアウトを作成します。このレイアウトにより、有効なロケールのみが処理されるようになります。
224
+
225
+ > ルートレベルでロケールプレフィックスを検証する必要がない場合、このステップは任意です。
226
+
227
+ ```tsx fileName="src/routes/{-$locale}/route.tsx"
228
+ import { createFileRoute, Outlet, redirect } from "@tanstack/solid-router";
229
+ import { validatePrefix } from "intlayer";
230
+
231
+ export const Route = createFileRoute("/{-$locale}")({
232
+ beforeLoad: ({ params }) => {
233
+ const localeParam = params.locale;
234
+
235
+ // ロケールプレフィックスを検証
236
+ const { isValid, localePrefix } = validatePrefix(localeParam);
237
+
238
+ if (!isValid) {
239
+ throw redirect({
240
+ to: "/{-$locale}/404",
241
+ params: { locale: localePrefix },
242
+ replace: true,
243
+ });
244
+ }
245
+ },
246
+ component: Outlet,
247
+ });
248
+ ```
249
+
250
+ > ここで、`{-$locale}` は現在のロケールに置き換えられる動的なルートパラメータです。この表記によりスロットがオプションになり、`'prefix-no-default'` などのルーティングモードで動作できるようになります。
251
+
252
+ > 同じルートで複数の動的セグメントを使用している場合 (例: `/{-$locale}/other-path/$anotherDynamicPath/...`)、このスロットが問題を引き起こす可能性があることに注意してください。
253
+ > `'prefix-all'` モードの場合、代わりにスロットを `$locale` に切り替えることをお勧めします。
254
+ > `'no-prefix'` または `'search-params'` モードの場合、スロットを完全に削除できます。
255
+
256
+ ### ステップ 7: コンテンツの宣言
257
+
258
+ 翻訳を保存するためのコンテンツ宣言を作成および管理します:
259
+
260
+ ```tsx fileName="src/contents/page.content.ts"
261
+ import type { Dictionary } from "intlayer";
262
+
263
+ import { t } from "intlayer";
264
+
265
+ const appContent = {
266
+ content: {
267
+ links: {
268
+ about: t({
269
+ en: "About",
270
+ es: "Acerca de",
271
+ fr: "À propos",
272
+ }),
273
+ home: t({
274
+ en: "Home",
275
+ es: "Inicio",
276
+ fr: "Accueil",
277
+ }),
278
+ },
279
+ meta: {
280
+ title: t({
281
+ en: "Welcome to Intlayer + TanStack Router",
282
+ es: "Bienvenido a Intlayer + TanStack Router",
283
+ fr: "Bienvenue à Intlayer + TanStack Router",
284
+ }),
285
+ description: t({
286
+ en: "This is an example of using Intlayer with TanStack Router",
287
+ es: "Este es un ejemplo de uso de Intlayer con TanStack Router",
288
+ fr: "Ceci est un exemple d'utilisation d'Intlayer avec TanStack Router",
289
+ }),
290
+ },
291
+ },
292
+ key: "app",
293
+ } satisfies Dictionary;
294
+
295
+ export default appContent;
296
+ ```
297
+
298
+ > コンテンツ宣言は、`contentDir` ディレクトリ (デフォルトは `./app`) に含まれていれば、アプリケーションのどこにでも定義できます。また、コンテンツ宣言ファイルの拡張子 (デフォルトは `.content.{json,ts,tsx,js,jsx,mjs,cjs}`) に一致する必要があります。
299
+
300
+ > 詳細については、[コンテンツ宣言のドキュメント](https://github.com/aymericzip/intlayer/blob/main/docs/docs/ja/dictionary/content_file.md)を参照してください。
301
+
302
+ ### ステップ 8: ロケール対応のコンポーネントとフックを利用する
303
+
304
+ ロケール対応のナビゲーションのために `LocalizedLink` コンポーネントを作成します:
305
+
306
+ ```tsx fileName="src/components/LocalizedLink.tsx"
307
+ import { Link, type LinkProps } from "@tanstack/solid-router";
308
+ import { getPrefix } from "intlayer";
309
+ import { useLocale } from "solid-intlayer";
310
+ import type { JSX } from "solid-js";
311
+
312
+ export const LOCALE_ROUTE = "{-$locale}" as const;
313
+
314
+ export type RemoveLocaleParam<TVal> = TVal extends string
315
+ ? RemoveLocaleFromString<TVal>
316
+ : TVal;
317
+
318
+ export type To = RemoveLocaleParam<LinkProps["to"]>;
319
+
320
+ type CollapseDoubleSlashes<TString extends string> =
321
+ TString extends `${infer THead}//${infer TTail}`
322
+ ? CollapseDoubleSlashes<`${THead}/${TTail}`>
323
+ : TString;
324
+
325
+ export type LocalizedLinkProps = Omit<LinkProps, "to"> & {
326
+ to?: To;
327
+ } & JSX.AnchorHTMLAttributes<HTMLAnchorElement>;
328
+
329
+ type RemoveAll<
330
+ TString extends string,
331
+ TSub extends string,
332
+ > = TString extends `${infer THead}${TSub}${infer TTail}`
333
+ ? RemoveAll<`${THead}${TTail}`, TSub>
334
+ : TString;
335
+
336
+ type RemoveLocaleFromString<TString extends string> = CollapseDoubleSlashes<
337
+ RemoveAll<TString, typeof LOCALE_ROUTE>
338
+ >;
339
+
340
+ export const LocalizedLink = (props: LocalizedLinkProps) => {
341
+ const { locale } = useLocale();
342
+
343
+ return (
344
+ <Link
345
+ {...props}
346
+ params={{
347
+ locale: getPrefix(locale()).localePrefix,
348
+ ...(typeof props.params === "object" ? props.params : {}),
349
+ }}
350
+ to={`/${LOCALE_ROUTE}${props.to ?? ""}` as LinkProps["to"]}
351
+ />
352
+ );
353
+ };
354
+ ```
355
+
356
+ このコンポーネントには2つの目的があります:
357
+
358
+ - URLから不要な `{-$locale}` プレフィックスを削除する。
359
+ - ユーザーがローカライズされたルートに直接リダイレクトされるように、URLにロケールパラメータを注入する。
360
+
361
+ 次に、プログラムによるナビゲーションのための `useLocalizedNavigate` フックを作成します:
362
+
363
+ ```tsx fileName="src/hooks/useLocalizedNavigate.tsx"
364
+ import { useNavigate } from "@tanstack/solid-router";
365
+ import { getLocalizedUrl } from "intlayer";
366
+ import { useLocale } from "solid-intlayer";
367
+
368
+ export const useLocalizedNavigate = () => {
369
+ const navigate = useNavigate();
370
+ const { locale } = useLocale();
371
+
372
+ const localizedNavigate = (to: string) => {
373
+ const localizedTo = getLocalizedUrl(to, locale());
374
+ return navigate({ to: localizedTo });
375
+ };
376
+
377
+ return localizedNavigate;
378
+ };
379
+ ```
380
+
381
+ ### ステップ 9: ページでIntlayerを活用する
382
+
383
+ アプリケーション全体でコンテンツ辞書にアクセスします:
384
+
385
+ #### ローカライズされたホームページ
386
+
387
+ ```tsx fileName="src/routes/{-$locale}/index.tsx"
388
+ import { createFileRoute } from "@tanstack/solid-router";
389
+ import { useIntlayer } from "solid-intlayer";
390
+ import { LocalizedLink } from "@/components/LocalizedLink";
391
+
392
+ export const Route = createFileRoute("/{-$locale}/")({
393
+ component: RouteComponent,
394
+ });
395
+
396
+ function RouteComponent() {
397
+ const content = useIntlayer("index-page");
398
+
399
+ return (
400
+ <main>
401
+ <h1>{content().heroTitle}</h1>
402
+ <p>{content().heroDesc}</p>
403
+ <div>
404
+ <LocalizedLink to="/">{content().navHome}</LocalizedLink>
405
+ <LocalizedLink to="/about">{content().navAbout}</LocalizedLink>
406
+ </div>
407
+ </main>
408
+ );
409
+ }
410
+ ```
411
+
412
+ > Solidでは、`useIntlayer` は **アクセサー** 関数 (例: `content()`) を返します。リアクティブなコンテンツにアクセスするには、この関数を呼び出す必要があります。
413
+ >
414
+ > `useIntlayer` フックの詳細については、[ドキュメント](https://github.com/aymericzip/intlayer/blob/main/docs/docs/ja/packages/solid-intlayer/useIntlayer.md)を参照してください。
415
+
416
+ ### ステップ 10: ロケール切り替えコンポーネントの作成
417
+
418
+ ユーザーが言語を変更できるようにするコンポーネントを作成します:
419
+
420
+ ```tsx fileName="src/components/LocaleSwitcher.tsx"
421
+ import { useLocation } from "@tanstack/solid-router";
422
+ import { getLocaleName, getPathWithoutLocale, getPrefix } from "intlayer";
423
+ import { For } from "solid-js";
424
+ import { useIntlayer, useLocale } from "solid-intlayer";
425
+ import { LocalizedLink, type To } from "./LocalizedLink";
426
+
427
+ export const LocaleSwitcher = () => {
428
+ const content = useIntlayer("locale-switcher");
429
+ const location = useLocation();
430
+
431
+ const { availableLocales, locale, setLocale } = useLocale();
432
+
433
+ const pathWithoutLocale = () => getPathWithoutLocale(location().pathname);
434
+
435
+ return (
436
+ <div class="flex flex-row gap-2">
437
+ <For each={availableLocales}>
438
+ {(localeEl) => (
439
+ <LocalizedLink
440
+ aria-current={localeEl === locale() ? "page" : undefined}
441
+ onClick={() => setLocale(localeEl)}
442
+ params={{ locale: getPrefix(localeEl).localePrefix }}
443
+ to={pathWithoutLocale() as To}
444
+ >
445
+ {getLocaleName(localeEl)}
446
+ </LocalizedLink>
447
+ )}
448
+ </For>
449
+ </div>
450
+ );
451
+ };
452
+
453
+ export default LocaleSwitcher;
454
+ ```
455
+
456
+ > Solidでは、`useLocale` からの `locale` は **シグナルアクセサー** です。現在の値をリアクティブに読み取るには、`locale()` (括弧付き) を使用します。
457
+ >
458
+ > `useLocale` フックの詳細については、[ドキュメント](https://github.com/aymericzip/intlayer/blob/main/docs/docs/ja/packages/solid-intlayer/useLocale.md)を参照してください。
459
+
460
+ ### ステップ 11: HTML属性の管理
461
+
462
+ ステップ 5 で見たように、ルートコンポーネントで `useMatches` を使用して `html` タグの `lang` および `dir` 属性を管理できます。これにより、サーバーとクライアントで正しい属性が設定されるようになります。
463
+
464
+ ```tsx fileName="src/routes/__root.tsx"
465
+ const RootComponent: ParentComponent = (props) => {
466
+ const matches = useMatches();
467
+
468
+ // アクティブなマッチのパラメータからロケールを見つけようとします
469
+ const locale =
470
+ (
471
+ matches().find((match) => match.routeId === "/{-$locale}/")
472
+ ?.params as Params
473
+ )?.locale ?? defaultLocale;
474
+
475
+ return (
476
+ <html dir={getHTMLTextDir(locale)} lang={locale}>
477
+ {/* ... */}
478
+ </html>
479
+ );
480
+ };
481
+ ```
482
+
483
+ ---
484
+
485
+ ### ステップ 12: ミドルウェアの追加 (任意)
486
+
487
+ `intlayerProxy` を使用して、アプリケーションにサーバーサイドのルーティングを追加することもできます。このプラグインはURLに基づいて現在のロケールを自動的に検出し、適切なロケールCookieを設定します。ロケールが指定されていない場合、プラグインはユーザーのブラウザ言語設定に基づいて最も適切なロケールを決定します。ロケールが検出されない場合は、デフォルトのロケールにリダイレクトします。
488
+
489
+ > 本番環境で `intlayerProxy` を使用するには、`vite-intlayer` パッケージを `devDependencies` から `dependencies` に切り替える必要があることに注意してください。
490
+
491
+ ```typescript {7,14-17} fileName="vite.config.ts"
492
+ import { tanstackStart } from "@tanstack/solid-start/plugin/vite";
493
+ import solid from "vite-plugin-solid";
494
+ import { nitro } from "nitro/vite";
495
+ import { defineConfig } from "vite";
496
+ import { intlayer, intlayerProxy } from "vite-intlayer";
497
+
498
+ export default defineConfig({
499
+ plugins: [
500
+ intlayerProxy(), // Nitroを使用する場合、プロキシはサーバーの前に配置する必要があります
501
+ nitro(),
502
+ intlayer(),
503
+ tanstackStart({
504
+ router: {
505
+ routeFileIgnorePattern:
506
+ ".content.(ts|tsx|js|mjs|cjs|jsx|json|jsonc|json5)$",
507
+ },
508
+ }),
509
+ solid(),
510
+ ],
511
+ });
512
+ ```
513
+
514
+ ---
515
+
516
+ ### ステップ 12: メタデータの国際化 (任意)
517
+
518
+ ロケール対応のメタデータのために、`head` ローダー内で `getIntlayer` 関数を使用してコンテンツ辞書にアクセスすることもできます:
519
+
520
+ ```tsx fileName="src/routes/{-$locale}/index.tsx"
521
+ import { createFileRoute } from "@tanstack/solid-router";
522
+ import { getIntlayer } from "intlayer";
523
+
524
+ export const Route = createFileRoute("/{-$locale}/")({
525
+ component: RouteComponent,
526
+ head: ({ params }) => {
527
+ const { locale } = params;
528
+ const metaContent = getIntlayer("page-metadata", locale);
529
+
530
+ return {
531
+ meta: [
532
+ { title: metaContent.title },
533
+ { content: metaContent.description, name: "description" },
534
+ ],
535
+ };
536
+ },
537
+ });
538
+ ```
539
+
540
+ ---
541
+
542
+ ### ステップ 13: サーバーアクションでロケールを取得する (任意)
543
+
544
+ サーバーアクションやAPIエンドポイント内から現在のロケールにアクセスしたい場合があります。
545
+ これを行うには、`intlayer` から `getLocale` ヘルパーを使用します。
546
+
547
+ TanStack Startのサーバー関数を使用した例を次に示します:
548
+
549
+ ```tsx fileName="src/routes/{-$locale}/index.tsx"
550
+ import { createServerFn } from "@tanstack/solid-start";
551
+ import {
552
+ getRequestHeader,
553
+ getRequestHeaders,
554
+ } from "@tanstack/solid-start/server";
555
+ import { getCookie, getIntlayer, getLocale } from "intlayer";
556
+
557
+ export const getLocaleServer = createServerFn().handler(async () => {
558
+ const locale = await getLocale({
559
+ // リクエストからCookieを取得する (デフォルト: 'INTLAYER_LOCALE')
560
+ getCookie: (name) => {
561
+ const cookieString = getRequestHeader("cookie");
562
+
563
+ return getCookie(name, cookieString);
564
+ },
565
+ // リクエストからヘッダーを取得する (デフォルト: 'x-intlayer-locale')
566
+ // Accept-Language ネゴシエーションを使用したフォールバック
567
+ getHeader: (name) => getRequestHeader(name),
568
+ });
569
+
570
+ // getIntlayer() を使用してコンテンツを取得する
571
+ const content = getIntlayer("app", locale);
572
+
573
+ return { locale, content };
574
+ });
575
+ ```
576
+
577
+ ---
578
+
579
+ ### ステップ 14: 404ページを管理する (任意)
580
+
581
+ ユーザーが存在しないページにアクセスしたときに、カスタム 404 ページを表示できます。ロケールプレフィックスは、404 ページがトリガーされる方法に影響を与える可能性があります。
582
+
583
+ #### TanStack Router のロケールプレフィックス付き 404 処理について
584
+
585
+ TanStack Router では、ローカライズされたルートでの 404 ページの処理に重層的なアプローチが必要です:
586
+
587
+ 1. **専用 404 ルート**: 404 UI を表示するための特定のルート。
588
+ 2. **ルートレベルの検証**: ロケールプレフィックスを検証し、無効な場合は 404 にリダイレクトします。
589
+ 3. **キャッチオールルート**: ロケールセグメント内のあらゆる一致しないパスをキャプチャします。
590
+
591
+ ```tsx fileName="src/routes/{-$locale}/404.tsx"
592
+ import { createFileRoute } from "@tanstack/solid-router";
593
+
594
+ // これにより専用の /[locale]/404 ルートが作成されます
595
+ // 直接のルートとして、また他のファイルでコンポーネントとしてインポートされて使用されます
596
+ export const Route = createFileRoute("/{-$locale}/404")({
597
+ component: NotFoundComponent,
598
+ });
599
+
600
+ // notFoundComponent やキャッチオールルートで再利用できるように別途エクスポート
601
+ export function NotFoundComponent() {
602
+ return (
603
+ <div>
604
+ <h1>404</h1>
605
+ </div>
606
+ );
607
+ }
608
+ ```
609
+
610
+ ```tsx fileName="src/routes/{-$locale}/route.tsx"
611
+ import { createFileRoute, Outlet, redirect } from "@tanstack/solid-router";
612
+ import { validatePrefix } from "intlayer";
613
+ import { NotFoundComponent } from "./404";
614
+
615
+ export const Route = createFileRoute("/{-$locale}")({
616
+ // beforeLoad はルートがレンダリングされる前に実行されます (サーバーとクライアントの両方)
617
+ // ここはロケールプレフィックスを検証するのに最適な場所です
618
+ beforeLoad: ({ params }) => {
619
+ const localeParam = params.locale;
620
+
621
+ // validatePrefix は intlayer 構成に従ってロケールが有効かどうかを確認します
622
+ const { isValid, localePrefix } = validatePrefix(localeParam);
623
+
624
+ if (!isValid) {
625
+ // 無効なロケールプレフィックス - 有効なロケールプレフィックスを使用して 404 ページにリダイレクト
626
+ throw redirect({
627
+ to: "/{-$locale}/404",
628
+ params: { locale: localePrefix },
629
+ });
630
+ }
631
+ },
632
+ component: Outlet,
633
+ // notFoundComponent は、子ルートが存在しないときに呼び出されます
634
+ // 例: /en/non-existent-page は /en レイアウト内でこれをトリガーします
635
+ notFoundComponent: NotFoundComponent,
636
+ });
637
+ ```
638
+
639
+ ```tsx fileName="src/routes/{-$locale}/$.tsx"
640
+ import { createFileRoute } from "@tanstack/solid-router";
641
+
642
+ import { NotFoundComponent } from "./404";
643
+
644
+ // $ (スプラット/キャッチオール) ルートは、他のルートに一致しないあらゆるパスに一致します
645
+ // 例: /en/some/deeply/nested/invalid/path
646
+ // これにより、ロケール内のすべての不一致パスが 404 ページを表示するようになります
647
+ // これがないと、一致しない深いパスは空白のページまたはエラーを表示する可能性があります
648
+ export const Route = createFileRoute("/{-$locale}/$")({
649
+ component: NotFoundComponent,
650
+ });
651
+ ```
652
+
653
+ ### (任意) ステップ 15: コンポーネントのコンテンツを抽出する
654
+
655
+ 既存のコードベースがある場合、数千ものファイルを変換するのは時間がかかる可能性があります。
656
+
657
+ このプロセスを容易にするために、Intlayerはコンポーネントを変換してコンテンツを抽出するための [コンパイラ](https://github.com/aymericzip/intlayer/blob/main/docs/docs/ja/compiler.md) / [エクストラクタ](https://github.com/aymericzip/intlayer/blob/main/docs/docs/ja/cli/extract.md) を提案しています。
658
+
659
+ セットアップするには、`intlayer.config.ts` ファイルに `compiler` セクションを追加します:
660
+
661
+ ```typescript fileName="intlayer.config.ts" codeFormat="typescript"
662
+ import { type IntlayerConfig } from "intlayer";
663
+
664
+ const config: IntlayerConfig = {
665
+ // ...構成の残り
666
+ compiler: {
667
+ /**
668
+ * コンパイラを有効にするかどうかを示します。
669
+ */
670
+ enabled: true,
671
+
672
+ /**
673
+ * 出力ファイルパスを定義します
674
+ */
675
+ output: ({ fileName, extension }) => `./${fileName}${extension}`,
676
+
677
+ /**
678
+ * 変換後にコンポーネントを保存するかどうかを示します。
679
+ *
680
+ * - `true` の場合、コンパイラはディスク上のコンポーネントファイルを書き換えます。そのため、変換は永続的になり、コンパイラは次のプロセスでの変換をスキップします。これにより、コンパイラはアプリを変換した後、削除できます。
681
+ *
682
+ * - `false` の場合、コンパイラはビルド出力のコードにのみ `useIntlayer()` 関数呼び出しを注入し、基本コードベースはそのまま維持します。変換はメモリ内でのみ行われます。
683
+ */
684
+ saveComponents: false,
685
+
686
+ /**
687
+ * 辞書キーのプレフィックス
688
+ */
689
+ dictionaryKeyPrefix: "",
690
+ },
691
+ };
692
+
693
+ export default config;
694
+ ```
695
+
696
+ ```javascript fileName="intlayer.config.mjs" codeFormat="esm"
697
+ /** @type {import('intlayer').IntlayerConfig} */
698
+ const config = {
699
+ // ...構成の残り
700
+ compiler: {
701
+ /**
702
+ * コンパイラを有効にするかどうかを示します。
703
+ */
704
+ enabled: true,
705
+
706
+ /**
707
+ * 出力ファイルパスを定義します
708
+ */
709
+ output: ({ fileName, extension }) => `./${fileName}${extension}`,
710
+
711
+ /**
712
+ * 変換後にコンポーネントを保存するかどうかを示します。
713
+ *
714
+ * - `true` の場合、コンパイラはディスク上のコンポーネントファイルを書き換えます。そのため、変換は永続的になり、コンパイラは次のプロセスでの変換をスキップします。これにより、コンパイラはアプリを変換した後、削除できます。
715
+ *
716
+ * - `false` の場合、コンパイラはビルド出力のコードにのみ `useIntlayer()` 関数呼び出しを注入し、基本コードベースはそのまま維持します。変換はメモリ内でのみ行われます。
717
+ */
718
+ saveComponents: false,
719
+
720
+ /**
721
+ * 辞書キーのプレフィックス
722
+ */
723
+ dictionaryKeyPrefix: "",
724
+ },
725
+ };
726
+
727
+ export default config;
728
+ ```
729
+
730
+ ```javascript fileName="intlayer.config.cjs" codeFormat="commonjs"
731
+ /** @type {import('intlayer').IntlayerConfig} */
732
+ const config = {
733
+ // ...構成の残り
734
+ compiler: {
735
+ /**
736
+ * コンパイラを有効にするかどうかを示します。
737
+ */
738
+ enabled: true,
739
+
740
+ /**
741
+ * 出力ファイルパスを定義します
742
+ */
743
+ output: ({ fileName, extension }) => `./${fileName}${extension}`,
744
+
745
+ /**
746
+ * 変換後にコンポーネントを保存するかどうかを示します。
747
+ *
748
+ * - `true` の場合、コンパイラはディスク上のコンポーネントファイルを書き換えます。そのため、変換は永続的になり、コンパイラは次のプロセスでの変換をスキップします。これにより、コンパイラはアプリを変換した後、削除できます。
749
+ *
750
+ * - `false` の場合、コンパイラはビルド出力のコードにのみ `useIntlayer()` 関数呼び出しを注入し、基本コードベースはそのまま維持します。変換はメモリ内でのみ行われます。
751
+ */
752
+ saveComponents: false,
753
+
754
+ /**
755
+ * 辞書キーのプレフィックス
756
+ */
757
+ dictionaryKeyPrefix: "",
758
+ },
759
+ };
760
+
761
+ module.exports = config;
762
+ ```
763
+
764
+ <Tabs>
765
+ <Tab value='Extract command'>
766
+
767
+ エクストラクタを実行して、コンポーネントを変換し、コンテンツを抽出します
768
+
769
+ ```bash packageManager="npm"
770
+ npx intlayer extract
771
+ ```
772
+
773
+ ```bash packageManager="pnpm"
774
+ pnpm intlayer extract
775
+ ```
776
+
777
+ ```bash packageManager="yarn"
778
+ yarn intlayer extract
779
+ ```
780
+
781
+ ```bash packageManager="bun"
782
+ bun x intlayer extract
783
+ ```
784
+
785
+ </Tab>
786
+ <Tab value='Babel compiler'>
787
+
788
+ `intlayerCompiler` プラグインを含めるように `vite.config.ts` を更新します:
789
+
790
+ ```ts fileName="vite.config.ts"
791
+ import { intlayer, intlayerCompiler } from "vite-intlayer";
792
+ import { defineConfig } from "vite";
793
+ import { devtools } from "@tanstack/devtools-vite";
794
+ import { tanstackStart } from "@tanstack/solid-start/plugin/vite";
795
+ import solidPlugin from "vite-plugin-solid";
796
+
797
+ export default defineConfig({
798
+ plugins: [
799
+ devtools(),
800
+ tanstackStart({
801
+ router: {
802
+ routeFileIgnorePattern:
803
+ ".content.(ts|tsx|js|mjs|cjs|jsx|json|jsonc|json5)$",
804
+ },
805
+ }),
806
+ solidPlugin({ ssr: true }),
807
+ intlayer(),
808
+ intlayerCompiler(),
809
+ ],
810
+ });
811
+ ```
812
+
813
+ ```bash packageManager="npm"
814
+ npm run build # または npm run dev
815
+ ```
816
+
817
+ ```bash packageManager="pnpm"
818
+ pnpm run build # または pnpm run dev
819
+ ```
820
+
821
+ ```bash packageManager="yarn"
822
+ yarn build # または yarn dev
823
+ ```
824
+
825
+ ```bash packageManager="bun"
826
+ bun run build # または bun run dev
827
+ ```
828
+
829
+ </Tab>
830
+ </Tabs>
831
+
832
+ ---
833
+
834
+ ### ステップ 16: サイトマップの生成 (オプション)
835
+
836
+ Intlayer には、アプリケーションのサイトマップを簡単に作成できるサイトマップ ジェネレーターが組み込まれています。ローカライズされたルートを処理し、検索エンジンに必要なメタデータを追加します。
837
+
838
+ > Intlayer によって生成されたサイトマップは、`xhtml:link` 名前空間 (Hreflang XML Extensions) をサポートしています。生の URL のみを表示するデフォルトのサイトマップ ジェネレーターとは異なり、Intlayer はページのすべての言語バージョン (例: `/about`、`/about?lang=fr`、`/about?lang=es`) 間に必要な双方向リンクを自動的に作成します。これにより、検索エンジンが正しい言語バージョンを正しい対象者に正しくインデックス付けして提供できるようになります。
839
+
840
+ > Intlayer によって生成されたサイトマップは、`xhtml:link` 名前空間 (Hreflang XML Extensions) をサポートしています。生の URL のみを表示するデフォルトのサイトマップ ジェネレーターとは異なり、Intlayer はページのすべての言語バージョン (例: `/about`、`/about?lang=fr`、`/about?lang=es`) 間に必要な双方向リンクを自動的に作成します。これにより、検索エンジンが正しい言語バージョンを正しい対象者に正しくインデックス付けして提供できるようになります。
841
+
842
+ これを使用するには、まず `vite.config.ts` を構成して、ローカライズされたルートのプリレンダリングを有効にし、デフォルトの TanStack Start サイトマップ生成を無効にする必要があります。
843
+
844
+ ```typescript fileName="vite.config.ts"
845
+ import { localeMap, localeFlatMap } from "intlayer";
846
+ // ... その他のインポート
847
+
848
+ export const pathList = ["", "/about", "/404"];
849
+
850
+ const localizedPages = localeFlatMap(({ urlPrefix }) =>
851
+ pathList.map((path) => ({
852
+ path: `${urlPrefix}${path}`,
853
+ prerender: {
854
+ enabled: true,
855
+ },
856
+ }))
857
+ );
858
+
859
+ export default defineConfig({
860
+ plugins: [
861
+ // ... その他のプラグイン
862
+ tanstackStart({
863
+ // ... その他の設定
864
+ sitemap: {
865
+ enabled: false,
866
+ },
867
+ prerender: {
868
+ enabled: true,
869
+ crawlLinks: false,
870
+ concurrency: 10,
871
+ },
872
+ pages: localizedPages,
873
+ }),
874
+ ],
875
+ });
876
+ ```
877
+
878
+ 次に、`generateSitemap` 関数を使用する `src/routes/sitemap[.]xml.ts` ルートを作成します。
879
+
880
+ ```typescript fileName="src/routes/sitemap[.]xml.ts"
881
+ import { createFileRoute } from "@tanstack/solid-router";
882
+ import { generateSitemap } from "intlayer";
883
+
884
+ const SITE_URL = (
885
+ import.meta.env.VITE_SITE_URL ?? "http://localhost:3000"
886
+ ).replace(/\/$/, "");
887
+
888
+ export const Route = createFileRoute("/sitemap.xml")({
889
+ server: {
890
+ handlers: {
891
+ GET: async () => {
892
+ const sitemap = generateSitemap(
893
+ [
894
+ { path: "/", changefreq: "daily", priority: 1.0 },
895
+ { path: "/about", changefreq: "monthly", priority: 0.8 },
896
+ ],
897
+ { siteUrl: SITE_URL }
898
+ );
899
+
900
+ return new Response(sitemap, {
901
+ headers: { "Content-Type": "application/xml" },
902
+ });
903
+ },
904
+ },
905
+ },
906
+ });
907
+ ```
908
+
909
+ ---
910
+
911
+ ### ステップ 17: TypeScriptの構成 (任意)
912
+
913
+ Intlayerは、TypeScriptの利点を活用し、コードベースをより強固にするために、モジュール拡張(module augmentation)を使用します。
914
+
915
+ TypeScript構成に自動生成された型が含まれていることを確認してください:
916
+
917
+ ```json5 fileName="tsconfig.json"
918
+ {
919
+ // ...既存の構成
920
+ include: [
921
+ // ...既存のインクルード
922
+ ".intlayer/**/*.ts", // 自動生成された型を含める
923
+ ],
924
+ }
925
+ ```
926
+
927
+ ---
928
+
929
+ ### Git構成
930
+
931
+ Intlayerによって生成されたファイルを無視することをお勧めします。これにより、それらをGitリポジトリにコミットすることを避けることができます。
932
+
933
+ これを行うには、`.gitignore` ファイルに次の指示を追加します:
934
+
935
+ ```plaintext fileName=".gitignore"
936
+ # Intlayerによって生成されたファイルを無視する
937
+ .intlayer
938
+ ```
939
+
940
+ ---
941
+
942
+ ## VS Code 拡張機能
943
+
944
+ Intlayerでの開発体験を向上させるために、公式の **Intlayer VS Code 拡張機能** をインストールできます。
945
+
946
+ [VS Code Marketplace からインストール](https://marketplace.visualstudio.com/items?itemName=intlayer.intlayer-vs-code-extension)
947
+
948
+ この拡張機能は以下を提供します:
949
+
950
+ - 翻訳キーの **オートコンプリート**。
951
+ - 不足している翻訳の **リアルタイムエラー検出**。
952
+ - 翻訳されたコンテンツの **インラインプレビュー**。
953
+ - 翻訳を簡単に作成および更新するための **クイックアクション**。
954
+
955
+ 拡張機能の使用方法の詳細については、[Intlayer VS Code 拡張機能ドキュメント](https://intlayer.org/doc/vs-code-extension) を参照してください。
956
+
957
+ ---
958
+
959
+ ## さらに進む
960
+
961
+ さらに進むには、[ビジュアルエディタ](https://github.com/aymericzip/intlayer/blob/main/docs/docs/ja/intlayer_visual_editor.md)を実装したり、[CMS](https://github.com/aymericzip/intlayer/blob/main/docs/docs/ja/intlayer_CMS.md)を使用してコンテンツを外部化したりできます。
962
+
963
+ ---
964
+
965
+ ## ドキュメント参照
966
+
967
+ - [Intlayer ドキュメント](https://intlayer.org)
968
+ - [Tanstack Start ドキュメント](https://tanstack.com/start/latest)
969
+ - [useIntlayer フック](https://github.com/aymericzip/intlayer/blob/main/docs/docs/ja/packages/solid-intlayer/useIntlayer.md)
970
+ - [useLocale フック](https://github.com/aymericzip/intlayer/blob/main/docs/docs/ja/packages/solid-intlayer/useLocale.md)
971
+ - [コンテンツ宣言](https://github.com/aymericzip/intlayer/blob/main/docs/docs/ja/dictionary/content_file.md)
972
+ - [構成](https://github.com/aymericzip/intlayer/blob/main/docs/docs/ja/configuration.md)