@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,136 @@
1
+ import { createFileRoute } from '@tanstack/react-router'
2
+ import { chat } from '@tanstack/ai'
3
+ import { openaiText } from '@tanstack/ai-openai'
4
+ import { z } from 'zod'
5
+
6
+ // Schema for structured recipe output
7
+ const RecipeSchema = z.object({
8
+ name: z.string().describe('The name of the recipe'),
9
+ description: z.string().describe('A brief description of the dish'),
10
+ prepTime: z.string().describe('Preparation time (e.g., "15 minutes")'),
11
+ cookTime: z.string().describe('Cooking time (e.g., "30 minutes")'),
12
+ servings: z.number().describe('Number of servings'),
13
+ difficulty: z.enum(['easy', 'medium', 'hard']).describe('Difficulty level'),
14
+ ingredients: z
15
+ .array(
16
+ z.object({
17
+ item: z.string().describe('Ingredient name'),
18
+ amount: z.string().describe('Amount needed (e.g., "2 cups")'),
19
+ notes: z.string().optional().describe('Optional preparation notes'),
20
+ }),
21
+ )
22
+ .describe('List of ingredients'),
23
+ instructions: z
24
+ .array(z.string())
25
+ .describe('Step-by-step cooking instructions'),
26
+ tips: z.array(z.string()).optional().describe('Optional cooking tips'),
27
+ nutritionPerServing: z
28
+ .object({
29
+ calories: z.number().optional(),
30
+ protein: z.string().optional(),
31
+ carbs: z.string().optional(),
32
+ fat: z.string().optional(),
33
+ })
34
+ .optional()
35
+ .describe('Nutritional information per serving'),
36
+ })
37
+
38
+ export type Recipe = z.infer<typeof RecipeSchema>
39
+
40
+ export const Route = createFileRoute('/demo/api/ai/structured')({
41
+ server: {
42
+ handlers: {
43
+ POST: async ({ request }) => {
44
+ const body = await request.json()
45
+ const { recipeName, mode = 'structured' } = body
46
+
47
+ if (!recipeName || recipeName.trim().length === 0) {
48
+ return new Response(
49
+ JSON.stringify({
50
+ error: 'Recipe name is required',
51
+ }),
52
+ {
53
+ status: 400,
54
+ headers: { 'Content-Type': 'application/json' },
55
+ },
56
+ )
57
+ }
58
+
59
+ try {
60
+ if (mode === 'structured') {
61
+ // Structured output mode - returns validated object
62
+ const result = await chat({
63
+ adapter: openaiText('gpt-4o'),
64
+ messages: [
65
+ {
66
+ role: 'user',
67
+ content: `Generate a complete recipe for: ${recipeName}. Include all ingredients with amounts, step-by-step instructions, prep/cook times, and difficulty level.`,
68
+ },
69
+ ],
70
+ outputSchema: RecipeSchema,
71
+ } as any)
72
+
73
+ return new Response(
74
+ JSON.stringify({
75
+ mode: 'structured',
76
+ recipe: result,
77
+ provider: 'openai',
78
+ model: 'gpt-4o',
79
+ }),
80
+ {
81
+ status: 200,
82
+ headers: { 'Content-Type': 'application/json' },
83
+ },
84
+ )
85
+ } else {
86
+ // One-shot markdown mode - returns text
87
+ const markdown = await chat({
88
+ adapter: openaiText('gpt-4o'),
89
+ stream: false,
90
+ messages: [
91
+ {
92
+ role: 'user',
93
+ content: `Generate a complete recipe for: ${recipeName}.
94
+
95
+ Format the recipe in beautiful markdown with:
96
+ - A title with the recipe name
97
+ - A brief description
98
+ - Prep time, cook time, and servings
99
+ - Ingredients list with amounts
100
+ - Numbered step-by-step instructions
101
+ - Optional tips section
102
+ - Nutritional info if applicable
103
+
104
+ Make it detailed and easy to follow.`,
105
+ },
106
+ ],
107
+ } as any)
108
+
109
+ return new Response(
110
+ JSON.stringify({
111
+ mode: 'oneshot',
112
+ markdown,
113
+ provider: 'openai',
114
+ model: 'gpt-4o',
115
+ }),
116
+ {
117
+ status: 200,
118
+ headers: { 'Content-Type': 'application/json' },
119
+ },
120
+ )
121
+ }
122
+ } catch (error: any) {
123
+ return new Response(
124
+ JSON.stringify({
125
+ error: error.message || 'An error occurred',
126
+ }),
127
+ {
128
+ status: 500,
129
+ headers: { 'Content-Type': 'application/json' },
130
+ },
131
+ )
132
+ }
133
+ },
134
+ },
135
+ },
136
+ })
@@ -0,0 +1,89 @@
1
+ import { createFileRoute } from '@tanstack/react-router'
2
+ import { generateTranscription } from '@tanstack/ai'
3
+ import { openaiTranscription } from '@tanstack/ai-openai'
4
+
5
+ export const Route = createFileRoute('/demo/api/ai/transcription')({
6
+ server: {
7
+ handlers: {
8
+ POST: async ({ request }) => {
9
+ const formData = await request.formData()
10
+ const audioFile = formData.get('audio') as File | null
11
+ const audioBase64 = formData.get('audioBase64') as string | null
12
+ const model = (formData.get('model') as string) || 'whisper-1'
13
+ const language = formData.get('language') as string | null
14
+ const responseFormat = formData.get('responseFormat') as string | null
15
+
16
+ if (!audioFile && !audioBase64) {
17
+ return new Response(
18
+ JSON.stringify({
19
+ error: 'Audio file or base64 data is required',
20
+ }),
21
+ {
22
+ status: 400,
23
+ headers: { 'Content-Type': 'application/json' },
24
+ },
25
+ )
26
+ }
27
+
28
+ if (!process.env.OPENAI_API_KEY) {
29
+ return new Response(
30
+ JSON.stringify({
31
+ error: 'OPENAI_API_KEY is not configured',
32
+ }),
33
+ {
34
+ status: 500,
35
+ headers: { 'Content-Type': 'application/json' },
36
+ },
37
+ )
38
+ }
39
+
40
+ try {
41
+ const adapter = openaiTranscription(model as any)
42
+
43
+ // Prepare audio data
44
+ let audioData: string | File
45
+ if (audioFile) {
46
+ audioData = audioFile
47
+ } else if (audioBase64) {
48
+ audioData = audioBase64
49
+ } else {
50
+ throw new Error('No audio data provided')
51
+ }
52
+
53
+ const result = await generateTranscription({
54
+ adapter,
55
+ audio: audioData,
56
+ language: language || undefined,
57
+ responseFormat: (responseFormat as any) || 'verbose_json',
58
+ })
59
+
60
+ return new Response(
61
+ JSON.stringify({
62
+ id: result.id,
63
+ model: result.model,
64
+ text: result.text,
65
+ language: result.language,
66
+ duration: result.duration,
67
+ segments: result.segments,
68
+ words: result.words,
69
+ }),
70
+ {
71
+ status: 200,
72
+ headers: { 'Content-Type': 'application/json' },
73
+ },
74
+ )
75
+ } catch (error: any) {
76
+ return new Response(
77
+ JSON.stringify({
78
+ error: error.message || 'An error occurred',
79
+ }),
80
+ {
81
+ status: 500,
82
+ headers: { 'Content-Type': 'application/json' },
83
+ },
84
+ )
85
+ }
86
+ },
87
+ },
88
+ },
89
+ })
@@ -0,0 +1,81 @@
1
+ import { createFileRoute } from '@tanstack/react-router'
2
+ import { generateSpeech } from '@tanstack/ai'
3
+ import { openaiSpeech } from '@tanstack/ai-openai'
4
+
5
+ export const Route = createFileRoute('/demo/api/ai/tts')({
6
+ server: {
7
+ handlers: {
8
+ POST: async ({ request }) => {
9
+ const body = await request.json()
10
+ const {
11
+ text,
12
+ voice = 'alloy',
13
+ model = 'tts-1',
14
+ format = 'mp3',
15
+ speed = 1.0,
16
+ } = body
17
+
18
+ if (!text || text.trim().length === 0) {
19
+ return new Response(
20
+ JSON.stringify({
21
+ error: 'Text is required',
22
+ }),
23
+ {
24
+ status: 400,
25
+ headers: { 'Content-Type': 'application/json' },
26
+ },
27
+ )
28
+ }
29
+
30
+ if (!process.env.OPENAI_API_KEY) {
31
+ return new Response(
32
+ JSON.stringify({
33
+ error: 'OPENAI_API_KEY is not configured',
34
+ }),
35
+ {
36
+ status: 500,
37
+ headers: { 'Content-Type': 'application/json' },
38
+ },
39
+ )
40
+ }
41
+
42
+ try {
43
+ const adapter = openaiSpeech(model)
44
+
45
+ const result = await generateSpeech({
46
+ adapter,
47
+ text,
48
+ voice,
49
+ format,
50
+ speed,
51
+ })
52
+
53
+ return new Response(
54
+ JSON.stringify({
55
+ id: result.id,
56
+ model: result.model,
57
+ audio: result.audio,
58
+ format: result.format,
59
+ contentType: result.contentType,
60
+ duration: result.duration,
61
+ }),
62
+ {
63
+ status: 200,
64
+ headers: { 'Content-Type': 'application/json' },
65
+ },
66
+ )
67
+ } catch (error: any) {
68
+ return new Response(
69
+ JSON.stringify({
70
+ error: error.message || 'An error occurred',
71
+ }),
72
+ {
73
+ status: 500,
74
+ headers: { 'Content-Type': 'application/json' },
75
+ },
76
+ )
77
+ }
78
+ },
79
+ },
80
+ },
81
+ })
@@ -43,6 +43,6 @@
43
43
  "jsName": "AiDevtools"
44
44
  }
45
45
  ],
46
- "dependsOn": ["start", "store"],
46
+ "dependsOn": ["store"],
47
47
  "variables": []
48
48
  }
@@ -8,7 +8,7 @@
8
8
  "color": "#311C87",
9
9
  "priority": 15,
10
10
  "link": "https://github.com/apollographql/apollo-client-integrations/tree/main/packages/tanstack-start",
11
- "dependsOn": ["start"],
11
+
12
12
  "routes": [
13
13
  {
14
14
  "icon": "Network",
@@ -0,0 +1,3 @@
1
+ import { createAuthClient } from 'better-auth/react'
2
+
3
+ export const authClient = createAuthClient()
@@ -0,0 +1,9 @@
1
+ import { betterAuth } from 'better-auth'
2
+ import { tanstackStartCookies } from 'better-auth/tanstack-start'
3
+
4
+ export const auth = betterAuth({
5
+ emailAndPassword: {
6
+ enabled: true,
7
+ },
8
+ plugins: [tanstackStartCookies()],
9
+ })
@@ -0,0 +1,11 @@
1
+ import { createFileRoute } from '@tanstack/react-router'
2
+ import { auth } from '@/lib/auth'
3
+
4
+ export const Route = createFileRoute('/api/auth/$')({
5
+ server: {
6
+ handlers: {
7
+ GET: ({ request }) => auth.handler(request),
8
+ POST: ({ request }) => auth.handler(request),
9
+ },
10
+ },
11
+ })
@@ -9,8 +9,6 @@
9
9
  "priority": 26,
10
10
  "link": "https://www.better-auth.com",
11
11
  "modes": ["file-router"],
12
- "tailwind": true,
13
- "dependsOn": ["start"],
14
12
  "routes": [
15
13
  {
16
14
  "url": "/demo/better-auth",
@@ -9,7 +9,6 @@
9
9
  "color": "#6C47FF",
10
10
  "priority": 150,
11
11
  "link": "https://clerk.com",
12
- "tailwind": true,
13
12
  "routes": [
14
13
  {
15
14
  "url": "/demo/clerk",
@@ -0,0 +1,14 @@
1
+ import { defineSchema, defineTable } from 'convex/server'
2
+ import { v } from 'convex/values'
3
+
4
+ export default defineSchema({
5
+ products: defineTable({
6
+ title: v.string(),
7
+ imageId: v.string(),
8
+ price: v.number(),
9
+ }),
10
+ todos: defineTable({
11
+ text: v.string(),
12
+ completed: v.boolean(),
13
+ }),
14
+ })
@@ -0,0 +1,43 @@
1
+ import { mutation, query } from './_generated/server'
2
+ import { v } from 'convex/values'
3
+
4
+ export const list = query({
5
+ args: {},
6
+ handler: async (ctx) => {
7
+ return await ctx.db
8
+ .query('todos')
9
+ .withIndex('by_creation_time')
10
+ .order('desc')
11
+ .collect()
12
+ },
13
+ })
14
+
15
+ export const add = mutation({
16
+ args: { text: v.string() },
17
+ handler: async (ctx, args) => {
18
+ return await ctx.db.insert('todos', {
19
+ text: args.text,
20
+ completed: false,
21
+ })
22
+ },
23
+ })
24
+
25
+ export const toggle = mutation({
26
+ args: { id: v.id('todos') },
27
+ handler: async (ctx, args) => {
28
+ const todo = await ctx.db.get(args.id)
29
+ if (!todo) {
30
+ throw new Error('Todo not found')
31
+ }
32
+ return await ctx.db.patch(args.id, {
33
+ completed: !todo.completed,
34
+ })
35
+ },
36
+ })
37
+
38
+ export const remove = mutation({
39
+ args: { id: v.id('todos') },
40
+ handler: async (ctx, args) => {
41
+ return await ctx.db.delete(args.id)
42
+ },
43
+ })
@@ -0,0 +1,20 @@
1
+ import {
2
+ createCollection,
3
+ localOnlyCollectionOptions,
4
+ } from "@tanstack/react-db";
5
+ import { z } from "zod";
6
+
7
+ const MessageSchema = z.object({
8
+ id: z.number(),
9
+ text: z.string(),
10
+ user: z.string(),
11
+ });
12
+
13
+ export type Message = z.infer<typeof MessageSchema>;
14
+
15
+ export const messagesCollection = createCollection(
16
+ localOnlyCollectionOptions({
17
+ getKey: (message) => message.id,
18
+ schema: MessageSchema,
19
+ })
20
+ );
@@ -0,0 +1,62 @@
1
+ import { useEffect, useRef } from 'react'
2
+ import { useLiveQuery } from '@tanstack/react-db'
3
+
4
+ import { messagesCollection, type Message } from '@/db-collections'
5
+
6
+ import type { Collection } from '@tanstack/react-db'
7
+
8
+ function useStreamConnection(
9
+ url: string,
10
+ collection: Collection<any, any, any>,
11
+ ) {
12
+ const loadedRef = useRef(false)
13
+
14
+ useEffect(() => {
15
+ const fetchData = async () => {
16
+ if (loadedRef.current) return
17
+ loadedRef.current = true
18
+
19
+ const response = await fetch(url)
20
+ const reader = response.body?.getReader()
21
+ if (!reader) {
22
+ return
23
+ }
24
+
25
+ const decoder = new TextDecoder()
26
+ while (true) {
27
+ const { done, value } = await reader.read()
28
+ if (done) break
29
+ for (const chunk of decoder
30
+ .decode(value, { stream: true })
31
+ .split('\n')
32
+ .filter((chunk) => chunk.length > 0)) {
33
+ collection.insert(JSON.parse(chunk))
34
+ }
35
+ }
36
+ }
37
+ fetchData()
38
+ }, [])
39
+ }
40
+
41
+ export function useChat() {
42
+ useStreamConnection('/demo/db-chat-api', messagesCollection)
43
+
44
+ const sendMessage = (message: string, user: string) => {
45
+ fetch('/demo/db-chat-api', {
46
+ method: 'POST',
47
+ body: JSON.stringify({ text: message.trim(), user: user.trim() }),
48
+ })
49
+ }
50
+
51
+ return { sendMessage }
52
+ }
53
+
54
+ export function useMessages() {
55
+ const { data: messages } = useLiveQuery((q) =>
56
+ q.from({ message: messagesCollection }).select(({ message }) => ({
57
+ ...message,
58
+ })),
59
+ )
60
+
61
+ return messages as Message[]
62
+ }
@@ -0,0 +1,83 @@
1
+ import { createFileRoute } from '@tanstack/react-router'
2
+ import { json } from '@tanstack/react-start'
3
+
4
+ import {
5
+ createCollection,
6
+ localOnlyCollectionOptions,
7
+ } from '@tanstack/react-db'
8
+ import { z } from 'zod'
9
+
10
+ const IncomingMessageSchema = z.object({
11
+ user: z.string(),
12
+ text: z.string(),
13
+ })
14
+
15
+ const MessageSchema = IncomingMessageSchema.extend({
16
+ id: z.number(),
17
+ })
18
+
19
+ export type Message = z.infer<typeof MessageSchema>
20
+
21
+ export const serverMessagesCollection = createCollection(
22
+ localOnlyCollectionOptions({
23
+ getKey: (message) => message.id,
24
+ schema: MessageSchema,
25
+ }),
26
+ )
27
+
28
+ let id = 0
29
+ serverMessagesCollection.insert({
30
+ id: id++,
31
+ user: 'Alice',
32
+ text: 'Hello, how are you?',
33
+ })
34
+ serverMessagesCollection.insert({
35
+ id: id++,
36
+ user: 'Bob',
37
+ text: "I'm fine, thank you!",
38
+ })
39
+
40
+ const sendMessage = (message: { user: string; text: string }) => {
41
+ serverMessagesCollection.insert({
42
+ id: id++,
43
+ user: message.user,
44
+ text: message.text,
45
+ })
46
+ }
47
+
48
+ export const Route = createFileRoute('/demo/db-chat-api')({
49
+ server: {
50
+ handlers: {
51
+ GET: () => {
52
+ const stream = new ReadableStream({
53
+ start(controller) {
54
+ for (const [_id, message] of serverMessagesCollection.state) {
55
+ controller.enqueue(JSON.stringify(message) + '\n')
56
+ }
57
+ serverMessagesCollection.subscribeChanges((changes) => {
58
+ for (const change of changes) {
59
+ if (change.type === 'insert') {
60
+ controller.enqueue(JSON.stringify(change.value) + '\n')
61
+ }
62
+ }
63
+ })
64
+ },
65
+ })
66
+
67
+ return new Response(stream, {
68
+ headers: {
69
+ 'Content-Type': 'application/x-ndjson',
70
+ },
71
+ })
72
+ },
73
+ POST: async ({ request }) => {
74
+ const message = IncomingMessageSchema.safeParse(await request.json())
75
+ if (!message.success) {
76
+ return new Response(message.error.message, { status: 400 })
77
+ }
78
+ sendMessage(message.data)
79
+ return json(message.data)
80
+ },
81
+ },
82
+ },
83
+ })
@@ -8,7 +8,7 @@
8
8
  "priority": 48,
9
9
  "modes": ["file-router"],
10
10
  "link": "https://tanstack.com/db/latest",
11
- "dependsOn": ["tanstack-query", "start"],
11
+ "dependsOn": ["tanstack-query"],
12
12
  "routes": [
13
13
  {
14
14
  "icon": "Database",
@@ -9,7 +9,7 @@
9
9
  "priority": 46,
10
10
  "link": "https://orm.drizzle.team/",
11
11
  "modes": ["file-router"],
12
- "dependsOn": ["start"],
12
+
13
13
  "options": {
14
14
  "database": {
15
15
  "type": "select",
@@ -18,5 +18,9 @@
18
18
  "db:push": "drizzle-kit push",
19
19
  "db:pull": "drizzle-kit pull",
20
20
  "db:studio": "drizzle-kit studio"
21
+ }<% if (addOnOption.drizzle.database === 'sqlite') { %>,
22
+ "pnpm": {
23
+ "onlyBuiltDependencies": ["better-sqlite3"]
21
24
  }
25
+ <% } %>
22
26
  }
@@ -0,0 +1,4 @@
1
+ import { createFormHookContexts } from '@tanstack/react-form'
2
+
3
+ export const { fieldContext, useFieldContext, formContext, useFormContext } =
4
+ createFormHookContexts()
@@ -0,0 +1,22 @@
1
+ import { createFormHook } from '@tanstack/react-form'
2
+
3
+ import {
4
+ Select,
5
+ SubscribeButton,
6
+ TextArea,
7
+ TextField,
8
+ } from '../components/demo.FormComponents'
9
+ import { fieldContext, formContext } from './demo.form-context'
10
+
11
+ export const { useAppForm } = createFormHook({
12
+ fieldComponents: {
13
+ TextField,
14
+ Select,
15
+ TextArea,
16
+ },
17
+ formComponents: {
18
+ SubscribeButton,
19
+ },
20
+ fieldContext,
21
+ formContext,
22
+ })