@tanstack/create 0.49.2 → 0.59.4

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 (294) hide show
  1. package/CHANGELOG.md +603 -0
  2. package/dist/add-ons.js +42 -2
  3. package/dist/add-to-app.js +36 -7
  4. package/dist/custom-add-ons/add-on.js +2 -26
  5. package/dist/custom-add-ons/starter.js +1 -2
  6. package/dist/file-helpers.js +11 -10
  7. package/dist/frameworks/react/add-ons/ai/assets/src/data/demo-guitars.ts +93 -0
  8. package/dist/frameworks/react/add-ons/ai/assets/src/hooks/demo-useAudioRecorder.ts +85 -0
  9. package/dist/frameworks/react/add-ons/ai/assets/src/hooks/demo-useTTS.ts +78 -0
  10. package/dist/frameworks/react/add-ons/ai/assets/src/lib/demo-ai-hook.ts +22 -0
  11. package/dist/frameworks/react/add-ons/ai/assets/src/lib/demo-guitar-tools.ts +40 -0
  12. package/dist/frameworks/react/add-ons/ai/assets/src/routes/demo/api.ai.chat.ts +99 -0
  13. package/dist/frameworks/react/add-ons/ai/assets/src/routes/demo/api.ai.image.ts +72 -0
  14. package/dist/frameworks/react/add-ons/ai/assets/src/routes/demo/api.ai.structured.ts +136 -0
  15. package/dist/frameworks/react/add-ons/ai/assets/src/routes/demo/api.ai.transcription.ts +89 -0
  16. package/dist/frameworks/react/add-ons/ai/assets/src/routes/demo/api.ai.tts.ts +81 -0
  17. package/dist/frameworks/react/add-ons/ai/info.json +1 -1
  18. package/dist/frameworks/react/add-ons/apollo-client/info.json +1 -1
  19. package/dist/frameworks/react/add-ons/better-auth/assets/src/lib/auth-client.ts +3 -0
  20. package/dist/frameworks/react/add-ons/better-auth/assets/src/lib/auth.ts +9 -0
  21. package/dist/frameworks/react/add-ons/better-auth/assets/src/routes/api/auth/$.ts +11 -0
  22. package/dist/frameworks/react/add-ons/better-auth/info.json +0 -2
  23. package/dist/frameworks/react/add-ons/clerk/info.json +0 -1
  24. package/dist/frameworks/react/add-ons/convex/assets/convex/schema.ts +14 -0
  25. package/dist/frameworks/react/add-ons/convex/assets/convex/todos.ts +43 -0
  26. package/dist/frameworks/react/add-ons/db/assets/src/db-collections/index.ts +20 -0
  27. package/dist/frameworks/react/add-ons/db/assets/src/hooks/demo.useChat.ts +62 -0
  28. package/dist/frameworks/react/add-ons/db/assets/src/routes/demo/db-chat-api.ts +83 -0
  29. package/dist/frameworks/react/add-ons/db/info.json +1 -1
  30. package/dist/frameworks/react/add-ons/drizzle/info.json +1 -1
  31. package/dist/frameworks/react/add-ons/drizzle/package.json.ejs +4 -0
  32. package/dist/frameworks/react/add-ons/form/assets/src/hooks/demo.form-context.ts +4 -0
  33. package/dist/frameworks/react/add-ons/form/assets/src/hooks/demo.form.ts +22 -0
  34. package/dist/frameworks/react/add-ons/mcp/assets/src/mcp-todos.ts +51 -0
  35. package/dist/frameworks/react/add-ons/mcp/assets/src/routes/demo/api.mcp-todos.ts +37 -0
  36. package/dist/frameworks/react/add-ons/mcp/assets/src/routes/mcp.ts +53 -0
  37. package/dist/frameworks/react/add-ons/mcp/assets/src/utils/mcp-handler.ts +61 -0
  38. package/dist/frameworks/react/add-ons/mcp/info.json +1 -2
  39. package/dist/frameworks/react/add-ons/neon/assets/neon-vite-plugin.ts +10 -0
  40. package/dist/frameworks/react/add-ons/neon/assets/src/db.ts +13 -0
  41. package/dist/frameworks/react/add-ons/neon/info.json +1 -2
  42. package/dist/frameworks/react/add-ons/oRPC/assets/src/orpc/client.ts +29 -0
  43. package/dist/frameworks/react/add-ons/oRPC/assets/src/orpc/router/index.ts +6 -0
  44. package/dist/frameworks/react/add-ons/oRPC/assets/src/orpc/router/todos.ts +20 -0
  45. package/dist/frameworks/react/add-ons/oRPC/assets/src/orpc/schema.ts +6 -0
  46. package/dist/frameworks/react/add-ons/oRPC/assets/src/polyfill.ts +21 -0
  47. package/dist/frameworks/react/add-ons/oRPC/assets/src/routes/api.$.ts +77 -0
  48. package/dist/frameworks/react/add-ons/oRPC/assets/src/routes/api.rpc.$.ts +29 -0
  49. package/dist/frameworks/react/add-ons/oRPC/info.json +1 -1
  50. package/dist/frameworks/react/add-ons/paraglide/info.json +1 -1
  51. package/dist/frameworks/react/add-ons/prisma/info.json +1 -1
  52. package/dist/frameworks/react/add-ons/prisma/package.json.ejs +4 -0
  53. package/dist/frameworks/react/add-ons/sentry/info.json +1 -2
  54. package/dist/frameworks/react/add-ons/shadcn/assets/src/lib/utils.ts +6 -0
  55. package/dist/frameworks/react/add-ons/store/assets/src/lib/demo-store.ts +13 -0
  56. package/dist/frameworks/react/add-ons/storybook/assets/_dot_storybook/main.ts +17 -0
  57. package/dist/frameworks/react/add-ons/storybook/assets/_dot_storybook/preview.ts +15 -0
  58. package/dist/frameworks/react/add-ons/storybook/assets/src/components/storybook/button.stories.ts +67 -0
  59. package/dist/frameworks/react/add-ons/storybook/assets/src/components/storybook/index.ts +14 -0
  60. package/dist/frameworks/react/add-ons/storybook/assets/src/components/storybook/input.stories.ts +43 -0
  61. package/dist/frameworks/react/add-ons/storybook/assets/src/components/storybook/radio-group.stories.ts +53 -0
  62. package/dist/frameworks/react/add-ons/storybook/assets/src/components/storybook/slider.stories.ts +55 -0
  63. package/dist/frameworks/react/add-ons/strapi/assets/src/lib/strapiClient.ts +7 -0
  64. package/dist/frameworks/react/add-ons/t3env/assets/src/env.ts +39 -0
  65. package/dist/frameworks/react/add-ons/tRPC/assets/src/integrations/trpc/init.ts +9 -0
  66. package/dist/frameworks/react/add-ons/tRPC/assets/src/integrations/trpc/react.ts +4 -0
  67. package/dist/frameworks/react/add-ons/tRPC/assets/src/integrations/trpc/router.ts +27 -0
  68. package/dist/frameworks/react/add-ons/tRPC/info.json +1 -1
  69. package/dist/frameworks/react/add-ons/table/assets/src/data/demo-table-data.ts +50 -0
  70. package/dist/frameworks/react/add-ons/tanstack-query/assets/src/integrations/tanstack-query/root-provider.tsx.ejs +1 -29
  71. package/dist/frameworks/react/add-ons/workos/info.json +0 -1
  72. package/dist/frameworks/react/examples/events/assets/content-collections.ts +56 -0
  73. package/dist/frameworks/react/examples/events/assets/src/lib/conference-ai-hook.ts +26 -0
  74. package/dist/frameworks/react/examples/events/assets/src/lib/conference-tools.ts +210 -0
  75. package/dist/frameworks/react/examples/events/assets/src/lib/utils.ts +6 -0
  76. package/dist/frameworks/react/examples/events/assets/src/routes/api.remy-chat.ts +121 -0
  77. package/dist/frameworks/react/examples/resume/assets/content-collections.ts +36 -0
  78. package/dist/frameworks/react/examples/resume/assets/src/lib/resume-ai-hook.ts +21 -0
  79. package/dist/frameworks/react/examples/resume/assets/src/lib/resume-tools.ts +165 -0
  80. package/dist/frameworks/react/examples/resume/assets/src/lib/utils.ts +6 -0
  81. package/dist/frameworks/react/examples/resume/assets/src/routes/api.resume-chat.ts +110 -0
  82. package/dist/frameworks/react/hosts/cloudflare/info.json +0 -1
  83. package/dist/frameworks/react/hosts/netlify/info.json +0 -1
  84. package/dist/frameworks/react/hosts/nitro/info.json +0 -1
  85. package/dist/frameworks/react/hosts/railway/info.json +0 -1
  86. package/dist/frameworks/react/index.js +1 -6
  87. package/dist/frameworks/react/project/base/README.md.ejs +86 -436
  88. package/dist/frameworks/react/project/base/_dot_gitignore +4 -0
  89. package/dist/frameworks/react/project/base/package.json +8 -5
  90. package/dist/frameworks/react/project/base/src/components/Header.tsx.ejs +2 -32
  91. package/dist/frameworks/react/project/base/src/routes/__root.tsx.ejs +4 -44
  92. package/dist/frameworks/react/project/base/src/routes/index.tsx.ejs +99 -61
  93. package/dist/frameworks/react/project/base/src/styles.css.ejs +3 -3
  94. package/dist/frameworks/react/project/base/tsconfig.json.ejs +1 -1
  95. package/dist/frameworks/react/project/base/vite.config.ts.ejs +33 -27
  96. package/dist/frameworks/react/project/packages.json +2 -2
  97. package/dist/frameworks/solid/add-ons/better-auth/assets/src/lib/auth-client.ts +3 -0
  98. package/dist/frameworks/solid/add-ons/better-auth/assets/src/lib/auth.ts +9 -0
  99. package/dist/frameworks/solid/add-ons/better-auth/assets/src/routes/api/auth/$.ts +11 -0
  100. package/dist/frameworks/solid/add-ons/better-auth/info.json +1 -1
  101. package/dist/frameworks/solid/add-ons/convex/assets/convex/schema.ts +14 -0
  102. package/dist/frameworks/solid/add-ons/convex/assets/convex/todos.ts +43 -0
  103. package/dist/frameworks/solid/add-ons/solid-ui/assets/src/lib/utils.ts +6 -0
  104. package/dist/frameworks/solid/add-ons/store/assets/src/lib/demo-store.ts +13 -0
  105. package/dist/frameworks/solid/add-ons/strapi/assets/src/lib/strapiClient.ts +7 -0
  106. package/dist/frameworks/solid/add-ons/t3env/assets/src/env.ts +39 -0
  107. package/dist/frameworks/solid/examples/tanchat/assets/ai-streaming-server/src/index.ts +102 -0
  108. package/dist/frameworks/solid/examples/tanchat/assets/src/lib/demo-store.ts +13 -0
  109. package/dist/frameworks/solid/examples/tanchat/assets/src/store/demo.hooks.ts +17 -0
  110. package/dist/frameworks/solid/examples/tanchat/assets/src/store/demo.store.ts +133 -0
  111. package/dist/frameworks/solid/hosts/cloudflare/info.json +0 -1
  112. package/dist/frameworks/solid/hosts/netlify/info.json +0 -1
  113. package/dist/frameworks/solid/hosts/nitro/info.json +0 -1
  114. package/dist/frameworks/solid/hosts/railway/info.json +0 -1
  115. package/dist/frameworks/solid/index.js +1 -6
  116. package/dist/frameworks/solid/project/base/README.md.ejs +43 -117
  117. package/dist/frameworks/solid/project/base/_dot_gitignore +4 -0
  118. package/dist/frameworks/solid/project/base/package.json +8 -3
  119. package/dist/frameworks/solid/project/base/src/components/Header.tsx.ejs +2 -25
  120. package/dist/frameworks/solid/project/base/src/routes/__root.tsx.ejs +3 -30
  121. package/dist/frameworks/solid/project/base/src/routes/index.tsx.ejs +97 -35
  122. package/dist/frameworks/solid/project/base/tsconfig.json.ejs +1 -1
  123. package/dist/frameworks/solid/project/base/vite.config.ts.ejs +15 -20
  124. package/dist/frameworks/solid/project/packages.json +2 -2
  125. package/dist/frameworks.js +0 -1
  126. package/dist/package-json.js +6 -10
  127. package/dist/template-file.js +21 -7
  128. package/dist/types/custom-add-ons/add-on.d.ts +1 -1
  129. package/dist/types/file-helpers.d.ts +0 -1
  130. package/dist/types/types.d.ts +12 -12
  131. package/dist/types.js +1 -2
  132. package/package.json +2 -2
  133. package/src/add-ons.ts +54 -2
  134. package/src/add-to-app.ts +42 -7
  135. package/src/custom-add-ons/add-on.ts +2 -33
  136. package/src/custom-add-ons/starter.ts +1 -2
  137. package/src/file-helpers.ts +11 -10
  138. package/src/frameworks/react/add-ons/ai/info.json +1 -1
  139. package/src/frameworks/react/add-ons/apollo-client/info.json +1 -1
  140. package/src/frameworks/react/add-ons/better-auth/info.json +0 -2
  141. package/src/frameworks/react/add-ons/clerk/info.json +0 -1
  142. package/src/frameworks/react/add-ons/db/info.json +1 -1
  143. package/src/frameworks/react/add-ons/drizzle/info.json +1 -1
  144. package/src/frameworks/react/add-ons/drizzle/package.json.ejs +4 -0
  145. package/src/frameworks/react/add-ons/mcp/info.json +1 -2
  146. package/src/frameworks/react/add-ons/neon/assets/neon-vite-plugin.ts +1 -1
  147. package/src/frameworks/react/add-ons/neon/info.json +1 -2
  148. package/src/frameworks/react/add-ons/oRPC/info.json +1 -1
  149. package/src/frameworks/react/add-ons/paraglide/info.json +1 -1
  150. package/src/frameworks/react/add-ons/prisma/info.json +1 -1
  151. package/src/frameworks/react/add-ons/prisma/package.json.ejs +4 -0
  152. package/src/frameworks/react/add-ons/sentry/info.json +1 -2
  153. package/src/frameworks/react/add-ons/tRPC/info.json +1 -1
  154. package/src/frameworks/react/add-ons/tanstack-query/assets/src/integrations/tanstack-query/root-provider.tsx.ejs +1 -29
  155. package/src/frameworks/react/add-ons/workos/info.json +0 -1
  156. package/src/frameworks/react/hosts/cloudflare/info.json +0 -1
  157. package/src/frameworks/react/hosts/netlify/info.json +0 -1
  158. package/src/frameworks/react/hosts/nitro/info.json +0 -1
  159. package/src/frameworks/react/hosts/railway/info.json +0 -1
  160. package/src/frameworks/react/index.ts +1 -6
  161. package/src/frameworks/react/project/base/README.md.ejs +86 -436
  162. package/src/frameworks/react/project/base/_dot_gitignore +4 -0
  163. package/src/frameworks/react/project/base/package.json +8 -5
  164. package/src/frameworks/react/project/base/src/components/Header.tsx.ejs +2 -32
  165. package/src/frameworks/react/project/base/src/routes/__root.tsx.ejs +4 -44
  166. package/src/frameworks/react/project/base/src/routes/index.tsx.ejs +99 -61
  167. package/src/frameworks/react/project/base/src/styles.css.ejs +3 -3
  168. package/src/frameworks/react/project/base/tsconfig.json.ejs +1 -1
  169. package/src/frameworks/react/project/base/vite.config.ts.ejs +33 -27
  170. package/src/frameworks/react/project/packages.json +2 -2
  171. package/src/frameworks/solid/add-ons/better-auth/info.json +1 -1
  172. package/src/frameworks/solid/hosts/cloudflare/info.json +0 -1
  173. package/src/frameworks/solid/hosts/netlify/info.json +0 -1
  174. package/src/frameworks/solid/hosts/nitro/info.json +0 -1
  175. package/src/frameworks/solid/hosts/railway/info.json +0 -1
  176. package/src/frameworks/solid/index.ts +1 -6
  177. package/src/frameworks/solid/project/base/README.md.ejs +43 -117
  178. package/src/frameworks/solid/project/base/_dot_gitignore +4 -0
  179. package/src/frameworks/solid/project/base/package.json +8 -3
  180. package/src/frameworks/solid/project/base/src/components/Header.tsx.ejs +2 -25
  181. package/src/frameworks/solid/project/base/src/routes/__root.tsx.ejs +3 -30
  182. package/src/frameworks/solid/project/base/src/routes/index.tsx.ejs +97 -35
  183. package/src/frameworks/solid/project/base/tsconfig.json.ejs +1 -1
  184. package/src/frameworks/solid/project/base/vite.config.ts.ejs +15 -20
  185. package/src/frameworks/solid/project/packages.json +2 -2
  186. package/src/frameworks.ts +0 -1
  187. package/src/package-json.ts +6 -10
  188. package/src/template-file.ts +27 -8
  189. package/src/types.ts +1 -2
  190. package/tests/add-to-app.test.ts +37 -0
  191. package/tests/copy-assets.test.ts +53 -0
  192. package/tests/file-helper.test.ts +23 -2
  193. package/tests/package-json.test.ts +32 -0
  194. package/tests/template-file.test.ts +28 -0
  195. package/dist/frameworks/react/add-ons/module-federation/assets/module-federation.config.js.ejs +0 -31
  196. package/dist/frameworks/react/add-ons/module-federation/assets/src/demo-mf-component.tsx +0 -3
  197. package/dist/frameworks/react/add-ons/module-federation/assets/src/demo-mf-self-contained.tsx +0 -11
  198. package/dist/frameworks/react/add-ons/module-federation/info.json +0 -11
  199. package/dist/frameworks/react/add-ons/module-federation/package.json +0 -5
  200. package/dist/frameworks/react/add-ons/module-federation/small-logo.svg +0 -87
  201. package/dist/frameworks/react/add-ons/start/assets/_dot_gitignore.append +0 -3
  202. package/dist/frameworks/react/add-ons/start/assets/src/router.tsx.ejs +0 -77
  203. package/dist/frameworks/react/add-ons/start/assets/src/routes/demo/api.tq-todos.ts.ejs +0 -35
  204. package/dist/frameworks/react/add-ons/start/assets/src/routes/demo/start.api-request.tsx.ejs +0 -68
  205. package/dist/frameworks/react/add-ons/start/assets/src/routes/demo/start.css.ejs +0 -43
  206. package/dist/frameworks/react/add-ons/start/assets/src/routes/demo/start.server-funcs.tsx.ejs +0 -183
  207. package/dist/frameworks/react/add-ons/start/assets/src/routes/demo/start.ssr.data-only.tsx.ejs +0 -55
  208. package/dist/frameworks/react/add-ons/start/assets/src/routes/demo/start.ssr.full-ssr.tsx.ejs +0 -55
  209. package/dist/frameworks/react/add-ons/start/assets/src/routes/demo/start.ssr.index.tsx.ejs +0 -62
  210. package/dist/frameworks/react/add-ons/start/assets/src/routes/demo/start.ssr.spa-mode.tsx.ejs +0 -62
  211. package/dist/frameworks/react/add-ons/start/assets/src/routes/index.tsx.ejs +0 -142
  212. package/dist/frameworks/react/add-ons/start/assets/src/server.ts.ejs +0 -9
  213. package/dist/frameworks/react/add-ons/start/assets/vite.config.ts.ejs +0 -40
  214. package/dist/frameworks/react/add-ons/start/info.json +0 -61
  215. package/dist/frameworks/react/add-ons/start/package.json +0 -12
  216. package/dist/frameworks/react/add-ons/start/small-logo.svg +0 -1
  217. package/dist/frameworks/react/project/base/index.html.ejs +0 -20
  218. package/dist/frameworks/react/project/base/src/App.css.ejs +0 -38
  219. package/dist/frameworks/react/project/base/src/App.tsx.ejs +0 -63
  220. package/dist/frameworks/react/project/base/src/components/Header.css.ejs +0 -18
  221. package/dist/frameworks/react/project/base/src/logo.svg +0 -12
  222. package/dist/frameworks/react/project/base/src/main.tsx.ejs +0 -166
  223. package/dist/frameworks/react/project/base/src/reportWebVitals.ts.ejs +0 -28
  224. package/dist/frameworks/solid/add-ons/module-federation/assets/module-federation.config.js.ejs +0 -27
  225. package/dist/frameworks/solid/add-ons/module-federation/assets/src/demo-mf-component.tsx +0 -3
  226. package/dist/frameworks/solid/add-ons/module-federation/assets/src/demo-mf-self-contained.tsx +0 -9
  227. package/dist/frameworks/solid/add-ons/module-federation/info.json +0 -10
  228. package/dist/frameworks/solid/add-ons/module-federation/package.json +0 -5
  229. package/dist/frameworks/solid/add-ons/module-federation/small-logo.svg +0 -87
  230. package/dist/frameworks/solid/add-ons/start/assets/public/tanstack-circle-logo.png +0 -0
  231. package/dist/frameworks/solid/add-ons/start/assets/public/tanstack-word-logo-white.svg +0 -1
  232. package/dist/frameworks/solid/add-ons/start/assets/src/router.tsx.ejs +0 -30
  233. package/dist/frameworks/solid/add-ons/start/assets/src/routes/demo.start.server-funcs.tsx +0 -49
  234. package/dist/frameworks/solid/add-ons/start/assets/src/routes/index.tsx.ejs +0 -138
  235. package/dist/frameworks/solid/add-ons/start/assets/vite.config.ts.ejs +0 -22
  236. package/dist/frameworks/solid/add-ons/start/info.json +0 -18
  237. package/dist/frameworks/solid/add-ons/start/package.json +0 -15
  238. package/dist/frameworks/solid/add-ons/start/small-logo.svg +0 -1
  239. package/dist/frameworks/solid/project/base/index.html.ejs +0 -20
  240. package/dist/frameworks/solid/project/base/src/App.css.ejs +0 -38
  241. package/dist/frameworks/solid/project/base/src/App.tsx.ejs +0 -34
  242. package/dist/frameworks/solid/project/base/src/logo.svg +0 -120
  243. package/dist/frameworks/solid/project/base/src/main.tsx.ejs +0 -126
  244. package/src/frameworks/react/add-ons/module-federation/assets/module-federation.config.js.ejs +0 -31
  245. package/src/frameworks/react/add-ons/module-federation/assets/src/demo-mf-component.tsx +0 -3
  246. package/src/frameworks/react/add-ons/module-federation/assets/src/demo-mf-self-contained.tsx +0 -11
  247. package/src/frameworks/react/add-ons/module-federation/info.json +0 -11
  248. package/src/frameworks/react/add-ons/module-federation/package.json +0 -5
  249. package/src/frameworks/react/add-ons/module-federation/small-logo.svg +0 -87
  250. package/src/frameworks/react/add-ons/start/assets/_dot_gitignore.append +0 -3
  251. package/src/frameworks/react/add-ons/start/assets/src/data/demo.punk-songs.ts +0 -13
  252. package/src/frameworks/react/add-ons/start/assets/src/router.tsx.ejs +0 -77
  253. package/src/frameworks/react/add-ons/start/assets/src/routes/demo/api.names.ts +0 -10
  254. package/src/frameworks/react/add-ons/start/assets/src/routes/demo/api.tq-todos.ts.ejs +0 -35
  255. package/src/frameworks/react/add-ons/start/assets/src/routes/demo/start.api-request.tsx.ejs +0 -68
  256. package/src/frameworks/react/add-ons/start/assets/src/routes/demo/start.css.ejs +0 -43
  257. package/src/frameworks/react/add-ons/start/assets/src/routes/demo/start.server-funcs.tsx.ejs +0 -183
  258. package/src/frameworks/react/add-ons/start/assets/src/routes/demo/start.ssr.data-only.tsx.ejs +0 -55
  259. package/src/frameworks/react/add-ons/start/assets/src/routes/demo/start.ssr.full-ssr.tsx.ejs +0 -55
  260. package/src/frameworks/react/add-ons/start/assets/src/routes/demo/start.ssr.index.tsx.ejs +0 -62
  261. package/src/frameworks/react/add-ons/start/assets/src/routes/demo/start.ssr.spa-mode.tsx.ejs +0 -62
  262. package/src/frameworks/react/add-ons/start/assets/src/routes/index.tsx.ejs +0 -142
  263. package/src/frameworks/react/add-ons/start/assets/src/server.ts.ejs +0 -9
  264. package/src/frameworks/react/add-ons/start/assets/vite.config.ts.ejs +0 -40
  265. package/src/frameworks/react/add-ons/start/info.json +0 -61
  266. package/src/frameworks/react/add-ons/start/package.json +0 -12
  267. package/src/frameworks/react/add-ons/start/small-logo.svg +0 -1
  268. package/src/frameworks/react/project/base/index.html.ejs +0 -20
  269. package/src/frameworks/react/project/base/src/App.css.ejs +0 -38
  270. package/src/frameworks/react/project/base/src/App.tsx.ejs +0 -63
  271. package/src/frameworks/react/project/base/src/components/Header.css.ejs +0 -18
  272. package/src/frameworks/react/project/base/src/logo.svg +0 -12
  273. package/src/frameworks/react/project/base/src/main.tsx.ejs +0 -166
  274. package/src/frameworks/react/project/base/src/reportWebVitals.ts.ejs +0 -28
  275. package/src/frameworks/solid/add-ons/module-federation/assets/module-federation.config.js.ejs +0 -27
  276. package/src/frameworks/solid/add-ons/module-federation/assets/src/demo-mf-component.tsx +0 -3
  277. package/src/frameworks/solid/add-ons/module-federation/assets/src/demo-mf-self-contained.tsx +0 -9
  278. package/src/frameworks/solid/add-ons/module-federation/info.json +0 -10
  279. package/src/frameworks/solid/add-ons/module-federation/package.json +0 -5
  280. package/src/frameworks/solid/add-ons/module-federation/small-logo.svg +0 -87
  281. package/src/frameworks/solid/add-ons/start/assets/public/tanstack-circle-logo.png +0 -0
  282. package/src/frameworks/solid/add-ons/start/assets/public/tanstack-word-logo-white.svg +0 -1
  283. package/src/frameworks/solid/add-ons/start/assets/src/router.tsx.ejs +0 -30
  284. package/src/frameworks/solid/add-ons/start/assets/src/routes/demo.start.server-funcs.tsx +0 -49
  285. package/src/frameworks/solid/add-ons/start/assets/src/routes/index.tsx.ejs +0 -138
  286. package/src/frameworks/solid/add-ons/start/assets/vite.config.ts.ejs +0 -22
  287. package/src/frameworks/solid/add-ons/start/info.json +0 -18
  288. package/src/frameworks/solid/add-ons/start/package.json +0 -15
  289. package/src/frameworks/solid/add-ons/start/small-logo.svg +0 -1
  290. package/src/frameworks/solid/project/base/index.html.ejs +0 -20
  291. package/src/frameworks/solid/project/base/src/App.css.ejs +0 -38
  292. package/src/frameworks/solid/project/base/src/App.tsx.ejs +0 -34
  293. package/src/frameworks/solid/project/base/src/logo.svg +0 -120
  294. package/src/frameworks/solid/project/base/src/main.tsx.ejs +0 -126
@@ -0,0 +1,51 @@
1
+ import fs from 'node:fs'
2
+
3
+ const todosPath = './mcp-todos.json'
4
+
5
+ // In-memory todos storage
6
+ const todos = fs.existsSync(todosPath)
7
+ ? JSON.parse(fs.readFileSync(todosPath, 'utf8'))
8
+ : [
9
+ {
10
+ id: 1,
11
+ title: 'Buy groceries',
12
+ },
13
+ ]
14
+
15
+ // Subscription callbacks per userID
16
+ let subscribers: ((todos: Todo[]) => void)[] = []
17
+
18
+ export type Todo = {
19
+ id: number
20
+ title: string
21
+ }
22
+
23
+ // Get the todos for a user
24
+ export function getTodos(): Todo[] {
25
+ return todos
26
+ }
27
+
28
+ // Add an item to the todos
29
+ export function addTodo(title: string) {
30
+ todos.push({ id: todos.length + 1, title })
31
+ fs.writeFileSync(todosPath, JSON.stringify(todos, null, 2))
32
+ notifySubscribers()
33
+ }
34
+
35
+ // Subscribe to cart changes for a user
36
+ export function subscribeToTodos(callback: (todos: Todo[]) => void) {
37
+ subscribers.push(callback)
38
+ callback(todos)
39
+ return () => {
40
+ subscribers = subscribers.filter((cb) => cb !== callback)
41
+ }
42
+ }
43
+
44
+ // Notify all subscribers of a user's cart
45
+ function notifySubscribers() {
46
+ for (const cb of subscribers) {
47
+ try {
48
+ cb(todos)
49
+ } catch {}
50
+ }
51
+ }
@@ -0,0 +1,37 @@
1
+ import { createFileRoute } from '@tanstack/react-router'
2
+
3
+ import { addTodo, getTodos, subscribeToTodos } from '@/mcp-todos'
4
+
5
+ export const Route = createFileRoute('/api/mcp-todos')({
6
+ server: {
7
+ handlers: {
8
+ GET: () => {
9
+ const stream = new ReadableStream({
10
+ start(controller) {
11
+ function ping() {
12
+ try {
13
+ controller.enqueue(`event: ping\n\n`)
14
+ setTimeout(ping, 1000)
15
+ } catch {}
16
+ }
17
+ ping()
18
+ const unsubscribe = subscribeToTodos((todos) => {
19
+ controller.enqueue(`data: ${JSON.stringify(todos)}\n\n`)
20
+ })
21
+ const todos = getTodos()
22
+ controller.enqueue(`data: ${JSON.stringify(todos)}\n\n`)
23
+ return () => unsubscribe()
24
+ },
25
+ })
26
+ return new Response(stream, {
27
+ headers: { 'Content-Type': 'text/event-stream' },
28
+ })
29
+ },
30
+ POST: async ({ request }) => {
31
+ const { title } = await request.json()
32
+ addTodo(title)
33
+ return Response.json(getTodos())
34
+ },
35
+ },
36
+ },
37
+ })
@@ -0,0 +1,53 @@
1
+ import { McpServer } from '@modelcontextprotocol/sdk/server/mcp.js'
2
+ import { createFileRoute } from '@tanstack/react-router'
3
+ import z from 'zod'
4
+
5
+ import { handleMcpRequest } from '@/utils/mcp-handler'
6
+
7
+ import { addTodo } from '@/mcp-todos'
8
+
9
+ const server = new McpServer({
10
+ name: 'start-server',
11
+ version: '1.0.0',
12
+ })
13
+
14
+ server.registerTool(
15
+ 'addTodo',
16
+ {
17
+ title: 'Tool to add a todo to a list of todos',
18
+ description: 'Add a todo to a list of todos',
19
+ inputSchema: {
20
+ title: z.string().describe('The title of the todo'),
21
+ },
22
+ },
23
+ ({ title }) => ({
24
+ content: [{ type: 'text', text: String(addTodo(title)) }],
25
+ }),
26
+ )
27
+
28
+ // server.registerResource(
29
+ // "counter-value",
30
+ // "count://",
31
+ // {
32
+ // title: "Counter Resource",
33
+ // description: "Returns the current value of the counter",
34
+ // },
35
+ // async (uri) => {
36
+ // return {
37
+ // contents: [
38
+ // {
39
+ // uri: uri.href,
40
+ // text: `The counter is at 20!`,
41
+ // },
42
+ // ],
43
+ // };
44
+ // }
45
+ // );
46
+
47
+ export const Route = createFileRoute('/mcp')({
48
+ server: {
49
+ handlers: {
50
+ POST: async ({ request }) => handleMcpRequest(request, server),
51
+ },
52
+ },
53
+ })
@@ -0,0 +1,61 @@
1
+ import { InMemoryTransport } from '@modelcontextprotocol/sdk/inMemory.js'
2
+
3
+ import type { McpServer } from '@modelcontextprotocol/sdk/server/mcp.js'
4
+ import type { JSONRPCMessage } from '@modelcontextprotocol/sdk/types.js'
5
+
6
+ export async function handleMcpRequest(
7
+ request: Request,
8
+ server: McpServer,
9
+ ): Promise<Response> {
10
+ try {
11
+ const jsonRpcRequest = (await request.json()) as JSONRPCMessage
12
+
13
+ const [clientTransport, serverTransport] =
14
+ InMemoryTransport.createLinkedPair()
15
+
16
+ let responseData: JSONRPCMessage | null = null
17
+
18
+ clientTransport.onmessage = (message: JSONRPCMessage) => {
19
+ responseData = message
20
+ }
21
+
22
+ await server.connect(serverTransport)
23
+
24
+ await clientTransport.start()
25
+ await serverTransport.start()
26
+
27
+ await clientTransport.send(jsonRpcRequest)
28
+
29
+ await new Promise((resolve) => setTimeout(resolve, 10))
30
+
31
+ await clientTransport.close()
32
+ await serverTransport.close()
33
+
34
+ return Response.json(responseData, {
35
+ headers: {
36
+ 'Content-Type': 'application/json',
37
+ },
38
+ })
39
+ } catch (error) {
40
+ console.error('MCP handler error:', error)
41
+
42
+ // Return a JSON-RPC error response
43
+ return Response.json(
44
+ {
45
+ jsonrpc: '2.0',
46
+ error: {
47
+ code: -32603,
48
+ message: 'Internal server error',
49
+ data: error instanceof Error ? error.message : String(error),
50
+ },
51
+ id: null,
52
+ },
53
+ {
54
+ status: 500,
55
+ headers: {
56
+ 'Content-Type': 'application/json',
57
+ },
58
+ },
59
+ )
60
+ }
61
+ }
@@ -17,6 +17,5 @@
17
17
  "path": "src/routes/demo.mcp-todos.tsx",
18
18
  "jsName": "MCPTodosDemo"
19
19
  }
20
- ],
21
- "dependsOn": ["start"]
20
+ ]
22
21
  }
@@ -0,0 +1,10 @@
1
+ import { postgresPlugin } from '@neondatabase/vite-plugin-postgres'
2
+
3
+ export default postgresPlugin({
4
+ seed: {
5
+ type: 'sql-script',
6
+ path: 'db/init.sql',
7
+ },
8
+ referrer: 'create-tanstack',
9
+ dotEnvKey: 'VITE_DATABASE_URL',
10
+ })
@@ -0,0 +1,13 @@
1
+ import { neon } from '@neondatabase/serverless'
2
+
3
+ let client: ReturnType<typeof neon>
4
+
5
+ export async function getClient() {
6
+ if (!process.env.VITE_DATABASE_URL) {
7
+ return undefined
8
+ }
9
+ if (!client) {
10
+ client = await neon(process.env.VITE_DATABASE_URL!)
11
+ }
12
+ return client
13
+ }
@@ -24,6 +24,5 @@
24
24
  "jsName": "neon",
25
25
  "path": "neon-vite-plugin.ts"
26
26
  }
27
- ],
28
- "dependsOn": ["start"]
27
+ ]
29
28
  }
@@ -0,0 +1,29 @@
1
+ import { createRouterClient } from '@orpc/server'
2
+ import { createORPCClient } from '@orpc/client'
3
+ import { RPCLink } from '@orpc/client/fetch'
4
+ import { createTanstackQueryUtils } from '@orpc/tanstack-query'
5
+ import { getRequestHeaders } from '@tanstack/react-start/server'
6
+ import { createIsomorphicFn } from '@tanstack/react-start'
7
+
8
+ import type { RouterClient } from '@orpc/server'
9
+
10
+ import router from '@/orpc/router'
11
+
12
+ const getORPCClient = createIsomorphicFn()
13
+ .server(() =>
14
+ createRouterClient(router, {
15
+ context: () => ({
16
+ headers: getRequestHeaders(),
17
+ }),
18
+ }),
19
+ )
20
+ .client((): RouterClient<typeof router> => {
21
+ const link = new RPCLink({
22
+ url: `${window.location.origin}/api/rpc`,
23
+ })
24
+ return createORPCClient(link)
25
+ })
26
+
27
+ export const client: RouterClient<typeof router> = getORPCClient()
28
+
29
+ export const orpc = createTanstackQueryUtils(client)
@@ -0,0 +1,6 @@
1
+ import { addTodo, listTodos } from './todos'
2
+
3
+ export default {
4
+ listTodos,
5
+ addTodo,
6
+ }
@@ -0,0 +1,20 @@
1
+ import { os } from '@orpc/server'
2
+ import * as z from 'zod'
3
+
4
+ const todos = [
5
+ { id: 1, name: 'Get groceries' },
6
+ { id: 2, name: 'Buy a new phone' },
7
+ { id: 3, name: 'Finish the project' },
8
+ ]
9
+
10
+ export const listTodos = os.input(z.object({})).handler(() => {
11
+ return todos
12
+ })
13
+
14
+ export const addTodo = os
15
+ .input(z.object({ name: z.string() }))
16
+ .handler(({ input }) => {
17
+ const newTodo = { id: todos.length + 1, name: input.name }
18
+ todos.push(newTodo)
19
+ return newTodo
20
+ })
@@ -0,0 +1,6 @@
1
+ import { z } from 'zod'
2
+
3
+ export const TodoSchema = z.object({
4
+ id: z.number().int().min(1),
5
+ name: z.string(),
6
+ })
@@ -0,0 +1,21 @@
1
+ import { File } from "node:buffer";
2
+
3
+ /**
4
+ * This file aims to polyfill missing APIs in Node.js 18 that oRPC depends on.
5
+ *
6
+ * Since Stackblitz runs on Node.js 18, these polyfills ensure oRPC works in that environment.
7
+ * If you're running oRPC locally, please use Node.js 20 or later for full compatibility.
8
+ */
9
+
10
+ /**
11
+ * Note: Stackblitz provides an emulated Node.js environment with inherent limitations.
12
+ * If you encounter issues, please test on a local setup with Node.js 20 or later before reporting them.
13
+ */
14
+
15
+ /**
16
+ * The `oz.file()` schema depends on the `File` API.
17
+ * If you're not using `oz.file()`, you can safely remove this polyfill.
18
+ */
19
+ if (typeof globalThis.File === "undefined") {
20
+ globalThis.File = File as any;
21
+ }
@@ -0,0 +1,77 @@
1
+ import '@/polyfill'
2
+
3
+ import { OpenAPIHandler } from '@orpc/openapi/fetch'
4
+ import { ZodToJsonSchemaConverter } from '@orpc/zod/zod4'
5
+ import { SmartCoercionPlugin } from '@orpc/json-schema'
6
+ import { createFileRoute } from '@tanstack/react-router'
7
+ import { onError } from '@orpc/server'
8
+ import { OpenAPIReferencePlugin } from '@orpc/openapi/plugins'
9
+
10
+ import { TodoSchema } from '@/orpc/schema'
11
+ import router from '@/orpc/router'
12
+
13
+ const handler = new OpenAPIHandler(router, {
14
+ interceptors: [
15
+ onError((error) => {
16
+ console.error(error)
17
+ }),
18
+ ],
19
+ plugins: [
20
+ new SmartCoercionPlugin({
21
+ schemaConverters: [new ZodToJsonSchemaConverter()],
22
+ }),
23
+ new OpenAPIReferencePlugin({
24
+ schemaConverters: [new ZodToJsonSchemaConverter()],
25
+ specGenerateOptions: {
26
+ info: {
27
+ title: 'TanStack ORPC Playground',
28
+ version: '1.0.0',
29
+ },
30
+ commonSchemas: {
31
+ Todo: { schema: TodoSchema },
32
+ UndefinedError: { error: 'UndefinedError' },
33
+ },
34
+ security: [{ bearerAuth: [] }],
35
+ components: {
36
+ securitySchemes: {
37
+ bearerAuth: {
38
+ type: 'http',
39
+ scheme: 'bearer',
40
+ },
41
+ },
42
+ },
43
+ },
44
+ docsConfig: {
45
+ authentication: {
46
+ securitySchemes: {
47
+ bearerAuth: {
48
+ token: 'default-token',
49
+ },
50
+ },
51
+ },
52
+ },
53
+ }),
54
+ ],
55
+ })
56
+
57
+ async function handle({ request }: { request: Request }) {
58
+ const { response } = await handler.handle(request, {
59
+ prefix: '/api',
60
+ context: {},
61
+ })
62
+
63
+ return response ?? new Response('Not Found', { status: 404 })
64
+ }
65
+
66
+ export const Route = createFileRoute('/api/$')({
67
+ server: {
68
+ handlers: {
69
+ HEAD: handle,
70
+ GET: handle,
71
+ POST: handle,
72
+ PUT: handle,
73
+ PATCH: handle,
74
+ DELETE: handle,
75
+ },
76
+ },
77
+ })
@@ -0,0 +1,29 @@
1
+ import '@/polyfill'
2
+
3
+ import { RPCHandler } from '@orpc/server/fetch'
4
+ import { createFileRoute } from '@tanstack/react-router'
5
+ import router from '@/orpc/router'
6
+
7
+ const handler = new RPCHandler(router)
8
+
9
+ async function handle({ request }: { request: Request }) {
10
+ const { response } = await handler.handle(request, {
11
+ prefix: '/api/rpc',
12
+ context: {},
13
+ })
14
+
15
+ return response ?? new Response('Not Found', { status: 404 })
16
+ }
17
+
18
+ export const Route = createFileRoute('/api/rpc/$')({
19
+ server: {
20
+ handlers: {
21
+ HEAD: handle,
22
+ GET: handle,
23
+ POST: handle,
24
+ PUT: handle,
25
+ PATCH: handle,
26
+ DELETE: handle,
27
+ },
28
+ },
29
+ })
@@ -4,7 +4,7 @@
4
4
  "phase": "add-on",
5
5
  "modes": ["file-router"],
6
6
  "link": "https://orpc.unnoq.com/",
7
- "dependsOn": ["tanstack-query", "start"],
7
+ "dependsOn": ["tanstack-query"],
8
8
  "type": "add-on",
9
9
  "category": "api",
10
10
  "color": "#FF6B6B",
@@ -7,7 +7,7 @@
7
7
  "category": "i18n",
8
8
  "color": "#14B8A6",
9
9
  "priority": 30,
10
- "link": "https://github.com/paraglidejs/paraglide-js",
10
+ "link": "https://github.com/opral/paraglide-js",
11
11
  "routes": [
12
12
  {
13
13
  "icon": "Languages",
@@ -9,7 +9,7 @@
9
9
  "priority": 120,
10
10
  "link": "https://www.prisma.io/",
11
11
  "modes": ["file-router"],
12
- "dependsOn": ["start"],
12
+
13
13
  "postInitSpecialSteps": ["post-init-script"],
14
14
  "options": {
15
15
  "database": {
@@ -17,5 +17,9 @@
17
17
  "db:migrate": "dotenv -e .env.local -- prisma migrate dev",
18
18
  "db:studio": "dotenv -e .env.local -- prisma studio",
19
19
  "db:seed": "dotenv -e .env.local -- prisma db seed"
20
+ }<% if (addOnOption.prisma.database === 'sqlite') { %>,
21
+ "pnpm": {
22
+ "onlyBuiltDependencies": ["better-sqlite3"]
20
23
  }
24
+ <% } %>
21
25
  }
@@ -15,6 +15,5 @@
15
15
  "path": "src/routes/demo.sentry.testing.tsx",
16
16
  "jsName": "SentryDemo"
17
17
  }
18
- ],
19
- "dependsOn": ["start"]
18
+ ]
20
19
  }
@@ -0,0 +1,6 @@
1
+ import { clsx, type ClassValue } from "clsx"
2
+ import { twMerge } from "tailwind-merge"
3
+
4
+ export function cn(...inputs: ClassValue[]) {
5
+ return twMerge(clsx(inputs))
6
+ }
@@ -0,0 +1,13 @@
1
+ import { Derived, Store } from '@tanstack/store'
2
+
3
+ export const store = new Store({
4
+ firstName: 'Jane',
5
+ lastName: 'Smith',
6
+ })
7
+
8
+ export const fullName = new Derived({
9
+ fn: () => `${store.state.firstName} ${store.state.lastName}`,
10
+ deps: [store],
11
+ })
12
+
13
+ fullName.mount()
@@ -0,0 +1,17 @@
1
+ import type { StorybookConfig } from "@storybook/react-vite";
2
+
3
+ const config: StorybookConfig = {
4
+ stories: ["../src/**/*.stories.@(js|jsx|mjs|ts|tsx)"],
5
+ addons: [],
6
+ framework: {
7
+ name: "@storybook/react-vite",
8
+ options: {},
9
+ },
10
+ async viteFinal(config) {
11
+ const { default: tailwindcss } = await import("@tailwindcss/vite");
12
+ config.plugins = config.plugins || [];
13
+ config.plugins.push(tailwindcss());
14
+ return config;
15
+ },
16
+ };
17
+ export default config;
@@ -0,0 +1,15 @@
1
+ import type { Preview } from "@storybook/react-vite";
2
+ import "../src/styles.css";
3
+
4
+ const preview: Preview = {
5
+ parameters: {
6
+ controls: {
7
+ matchers: {
8
+ color: /(background|color)$/i,
9
+ date: /Date$/i,
10
+ },
11
+ },
12
+ },
13
+ };
14
+
15
+ export default preview;
@@ -0,0 +1,67 @@
1
+ import type { Meta, StoryObj } from "@storybook/react-vite";
2
+ import { fn } from "storybook/test";
3
+
4
+ import { Button } from "./button";
5
+
6
+ const meta = {
7
+ title: "Form/Button",
8
+ component: Button,
9
+ parameters: {
10
+ layout: "centered",
11
+ },
12
+ tags: ["autodocs"],
13
+ args: { onClick: fn() },
14
+ } satisfies Meta<typeof Button>;
15
+
16
+ export default meta;
17
+ type Story = StoryObj<typeof meta>;
18
+
19
+ export const Primary: Story = {
20
+ args: {
21
+ variant: "primary",
22
+ children: "Primary Button",
23
+ },
24
+ };
25
+
26
+ export const Secondary: Story = {
27
+ args: {
28
+ variant: "secondary",
29
+ children: "Secondary Button",
30
+ },
31
+ };
32
+
33
+ export const Danger: Story = {
34
+ args: {
35
+ variant: "danger",
36
+ children: "Delete Account",
37
+ },
38
+ };
39
+
40
+ export const Small: Story = {
41
+ args: {
42
+ size: "small",
43
+ children: "Small Button",
44
+ },
45
+ };
46
+
47
+ export const Medium: Story = {
48
+ args: {
49
+ size: "medium",
50
+ children: "Medium Button",
51
+ },
52
+ };
53
+
54
+ export const Large: Story = {
55
+ args: {
56
+ size: "large",
57
+ children: "Large Button",
58
+ },
59
+ };
60
+
61
+ export const Disabled: Story = {
62
+ args: {
63
+ variant: "primary",
64
+ children: "Disabled Button",
65
+ disabled: true,
66
+ },
67
+ };
@@ -0,0 +1,14 @@
1
+ export { Input } from "./input";
2
+ export type { InputProps } from "./input";
3
+
4
+ export { RadioGroup } from "./radio-group";
5
+ export type { RadioGroupProps, RadioOption } from "./radio-group";
6
+
7
+ export { Slider } from "./slider";
8
+ export type { SliderProps } from "./slider";
9
+
10
+ export { Dialog } from "./dialog";
11
+ export type { DialogProps } from "./dialog";
12
+
13
+ export { Button } from "./button";
14
+ export type { ButtonProps } from "./button";
@@ -0,0 +1,43 @@
1
+ import type { Meta, StoryObj } from "@storybook/react-vite";
2
+ import { fn } from "storybook/test";
3
+
4
+ import { Input } from "./input";
5
+
6
+ const meta = {
7
+ title: "Form/Input",
8
+ component: Input,
9
+ parameters: {
10
+ layout: "centered",
11
+ },
12
+ tags: ["autodocs"],
13
+ args: { onChange: fn() },
14
+ } satisfies Meta<typeof Input>;
15
+
16
+ export default meta;
17
+ type Story = StoryObj<typeof meta>;
18
+
19
+ export const Default: Story = {
20
+ args: {
21
+ label: "Email Address",
22
+ id: "email",
23
+ placeholder: "Enter your email",
24
+ },
25
+ };
26
+
27
+ export const Required: Story = {
28
+ args: {
29
+ label: "First Name",
30
+ id: "firstName",
31
+ placeholder: "John",
32
+ required: true,
33
+ },
34
+ };
35
+
36
+ export const WithValue: Story = {
37
+ args: {
38
+ label: "Last Name",
39
+ id: "lastName",
40
+ value: "Doe",
41
+ placeholder: "Enter last name",
42
+ },
43
+ };