@tanstack/cta-engine 0.10.0-alpha.14 → 0.10.0-alpha.16

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 (291) hide show
  1. package/dist/add-ons.js +8 -73
  2. package/dist/{add.js → add-to-app.js} +19 -19
  3. package/dist/config-file.js +6 -3
  4. package/dist/constants.js +0 -2
  5. package/dist/create-app.js +76 -460
  6. package/dist/environment.js +11 -26
  7. package/dist/file-helpers.js +59 -0
  8. package/dist/frameworks.js +78 -0
  9. package/dist/index.js +10 -1
  10. package/dist/integrations/git.js +4 -0
  11. package/dist/integrations/shadcn.js +27 -0
  12. package/dist/package-json.js +46 -0
  13. package/dist/package-manager.js +51 -6
  14. package/dist/template-file.js +108 -0
  15. package/dist/types/add-ons.d.ts +2 -6
  16. package/dist/types/add-to-app.d.ts +4 -0
  17. package/dist/types/config-file.d.ts +3 -2
  18. package/dist/types/constants.d.ts +0 -3
  19. package/dist/types/file-helpers.d.ts +5 -0
  20. package/dist/types/frameworks.d.ts +5 -0
  21. package/dist/types/index.d.ts +13 -1
  22. package/dist/types/integrations/git.d.ts +2 -0
  23. package/dist/types/integrations/shadcn.d.ts +2 -0
  24. package/dist/types/package-json.d.ts +2 -0
  25. package/dist/types/package-manager.d.ts +14 -1
  26. package/dist/types/template-file.d.ts +2 -0
  27. package/dist/types/types.d.ts +86 -64
  28. package/dist/types/utils.d.ts +5 -0
  29. package/dist/utils.js +9 -0
  30. package/package.json +3 -13
  31. package/src/add-ons.ts +11 -104
  32. package/src/{add.ts → add-to-app.ts} +29 -35
  33. package/src/config-file.ts +12 -6
  34. package/src/constants.ts +0 -5
  35. package/src/create-app.ts +126 -727
  36. package/src/environment.ts +12 -27
  37. package/src/file-helpers.ts +73 -0
  38. package/src/frameworks.ts +114 -0
  39. package/src/index.ts +42 -1
  40. package/src/integrations/git.ts +7 -0
  41. package/src/integrations/shadcn.ts +44 -0
  42. package/src/package-json.ts +62 -0
  43. package/src/package-manager.ts +80 -9
  44. package/src/template-file.ts +146 -0
  45. package/src/types.ts +101 -70
  46. package/src/utils.ts +17 -0
  47. package/tests/file-helper.test.ts +37 -0
  48. package/tests/package-manager.test.ts +154 -0
  49. package/dist/cli.js +0 -126
  50. package/dist/custom-add-on.js +0 -254
  51. package/dist/file-helper.js +0 -18
  52. package/dist/mcp.js +0 -229
  53. package/dist/options.js +0 -328
  54. package/dist/templates.js +0 -6
  55. package/dist/toolchain.js +0 -6
  56. package/dist/types/add.d.ts +0 -3
  57. package/dist/types/cli.d.ts +0 -6
  58. package/dist/types/custom-add-on.d.ts +0 -3
  59. package/dist/types/file-helper.d.ts +0 -2
  60. package/dist/types/mcp.d.ts +0 -7
  61. package/dist/types/options.d.ts +0 -6
  62. package/dist/types/templates.d.ts +0 -1
  63. package/dist/types/toolchain.d.ts +0 -3
  64. package/src/cli.ts +0 -189
  65. package/src/custom-add-on.ts +0 -325
  66. package/src/file-helper.ts +0 -20
  67. package/src/mcp.ts +0 -302
  68. package/src/options.ts +0 -399
  69. package/src/templates.ts +0 -7
  70. package/src/toolchain.ts +0 -7
  71. package/templates/react/add-on/clerk/README.md +0 -3
  72. package/templates/react/add-on/clerk/assets/_dot_env.local.append +0 -2
  73. package/templates/react/add-on/clerk/assets/src/integrations/clerk/header-user.tsx +0 -19
  74. package/templates/react/add-on/clerk/assets/src/integrations/clerk/provider.tsx +0 -18
  75. package/templates/react/add-on/clerk/assets/src/routes/demo.clerk.tsx +0 -20
  76. package/templates/react/add-on/clerk/info.json +0 -13
  77. package/templates/react/add-on/clerk/package.json +0 -5
  78. package/templates/react/add-on/convex/README.md +0 -4
  79. package/templates/react/add-on/convex/assets/_dot_cursorrules.append +0 -93
  80. package/templates/react/add-on/convex/assets/_dot_env.local.append +0 -3
  81. package/templates/react/add-on/convex/assets/convex/products.ts +0 -8
  82. package/templates/react/add-on/convex/assets/convex/schema.ts +0 -10
  83. package/templates/react/add-on/convex/assets/src/integrations/convex/provider.tsx +0 -20
  84. package/templates/react/add-on/convex/assets/src/routes/demo.convex.tsx +0 -33
  85. package/templates/react/add-on/convex/info.json +0 -13
  86. package/templates/react/add-on/convex/package.json +0 -6
  87. package/templates/react/add-on/form/assets/src/components/demo.FormComponents.tsx.ejs +0 -300
  88. package/templates/react/add-on/form/assets/src/hooks/demo.form-context.ts +0 -4
  89. package/templates/react/add-on/form/assets/src/hooks/demo.form.ts +0 -22
  90. package/templates/react/add-on/form/assets/src/routes/demo.form.address.tsx.ejs +0 -213
  91. package/templates/react/add-on/form/assets/src/routes/demo.form.simple.tsx.ejs +0 -77
  92. package/templates/react/add-on/form/info.json +0 -26
  93. package/templates/react/add-on/form/package.json +0 -6
  94. package/templates/react/add-on/module-federation/assets/module-federation.config.js.ejs +0 -31
  95. package/templates/react/add-on/module-federation/assets/src/demo-mf-component.tsx +0 -3
  96. package/templates/react/add-on/module-federation/assets/src/demo-mf-self-contained.tsx +0 -11
  97. package/templates/react/add-on/module-federation/info.json +0 -7
  98. package/templates/react/add-on/module-federation/package.json +0 -5
  99. package/templates/react/add-on/netlify/README.md +0 -11
  100. package/templates/react/add-on/netlify/info.json +0 -7
  101. package/templates/react/add-on/sentry/assets/_dot_cursorrules.append +0 -22
  102. package/templates/react/add-on/sentry/assets/_dot_env.local.append +0 -2
  103. package/templates/react/add-on/sentry/assets/src/app/global-middleware.ts +0 -25
  104. package/templates/react/add-on/sentry/assets/src/routes/demo.sentry.testing.tsx +0 -480
  105. package/templates/react/add-on/sentry/info.json +0 -14
  106. package/templates/react/add-on/sentry/package.json +0 -7
  107. package/templates/react/add-on/shadcn/README.md +0 -7
  108. package/templates/react/add-on/shadcn/assets/_dot_cursorrules.append +0 -7
  109. package/templates/react/add-on/shadcn/assets/components.json +0 -21
  110. package/templates/react/add-on/shadcn/assets/src/lib/utils.ts +0 -6
  111. package/templates/react/add-on/shadcn/assets/src/styles.css +0 -138
  112. package/templates/react/add-on/shadcn/info.json +0 -7
  113. package/templates/react/add-on/shadcn/package.json +0 -9
  114. package/templates/react/add-on/start/assets/_dot_gitignore.append +0 -2
  115. package/templates/react/add-on/start/assets/app.config.ts.ejs +0 -19
  116. package/templates/react/add-on/start/assets/src/api.ts +0 -6
  117. package/templates/react/add-on/start/assets/src/client.tsx +0 -8
  118. package/templates/react/add-on/start/assets/src/router.tsx.ejs +0 -77
  119. package/templates/react/add-on/start/assets/src/routes/api.demo-names.ts +0 -11
  120. package/templates/react/add-on/start/assets/src/routes/demo.start.api-request.tsx.ejs +0 -33
  121. package/templates/react/add-on/start/assets/src/routes/demo.start.server-funcs.tsx +0 -50
  122. package/templates/react/add-on/start/assets/src/ssr.tsx +0 -12
  123. package/templates/react/add-on/start/info.json +0 -18
  124. package/templates/react/add-on/start/package.json +0 -13
  125. package/templates/react/add-on/store/assets/src/lib/demo-store.ts +0 -13
  126. package/templates/react/add-on/store/assets/src/routes/demo.store.tsx.ejs +0 -75
  127. package/templates/react/add-on/store/info.json +0 -13
  128. package/templates/react/add-on/store/package.json +0 -6
  129. package/templates/react/add-on/tRPC/assets/src/integrations/trpc/init.ts +0 -9
  130. package/templates/react/add-on/tRPC/assets/src/integrations/trpc/react.ts +0 -4
  131. package/templates/react/add-on/tRPC/assets/src/integrations/trpc/router.ts +0 -18
  132. package/templates/react/add-on/tRPC/assets/src/routes/api.trpc.$.tsx +0 -16
  133. package/templates/react/add-on/tRPC/info.json +0 -9
  134. package/templates/react/add-on/tRPC/package.json +0 -9
  135. package/templates/react/add-on/table/assets/src/data/demo-table-data.ts +0 -50
  136. package/templates/react/add-on/table/assets/src/routes/demo.table.tsx.ejs +0 -373
  137. package/templates/react/add-on/table/info.json +0 -13
  138. package/templates/react/add-on/table/package.json +0 -7
  139. package/templates/react/add-on/tanstack-query/assets/src/integrations/tanstack-query/layout.tsx +0 -5
  140. package/templates/react/add-on/tanstack-query/assets/src/integrations/tanstack-query/root-provider.tsx.ejs +0 -70
  141. package/templates/react/add-on/tanstack-query/assets/src/routes/demo.tanstack-query.tsx.ejs +0 -53
  142. package/templates/react/add-on/tanstack-query/info.json +0 -13
  143. package/templates/react/add-on/tanstack-query/package.json +0 -6
  144. package/templates/react/base/README.md.ejs +0 -558
  145. package/templates/react/base/_dot_gitignore +0 -5
  146. package/templates/react/base/_dot_vscode/settings.biome.json +0 -38
  147. package/templates/react/base/_dot_vscode/settings.json +0 -11
  148. package/templates/react/base/index.html.ejs +0 -20
  149. package/templates/react/base/package.biome.json +0 -10
  150. package/templates/react/base/package.eslintprettier.json +0 -11
  151. package/templates/react/base/package.json +0 -29
  152. package/templates/react/base/package.ts.json +0 -7
  153. package/templates/react/base/package.tw.json +0 -6
  154. package/templates/react/base/public/favicon.ico +0 -0
  155. package/templates/react/base/public/logo192.png +0 -0
  156. package/templates/react/base/public/logo512.png +0 -0
  157. package/templates/react/base/public/manifest.json +0 -25
  158. package/templates/react/base/public/robots.txt +0 -3
  159. package/templates/react/base/src/App.css +0 -38
  160. package/templates/react/base/src/App.test.tsx.ejs +0 -10
  161. package/templates/react/base/src/App.tsx.ejs +0 -74
  162. package/templates/react/base/src/components/Header.tsx.ejs +0 -27
  163. package/templates/react/base/src/logo.svg +0 -44
  164. package/templates/react/base/src/reportWebVitals.ts.ejs +0 -28
  165. package/templates/react/base/src/styles.css.ejs +0 -15
  166. package/templates/react/base/toolchain/.prettierignore +0 -3
  167. package/templates/react/base/toolchain/biome.json +0 -31
  168. package/templates/react/base/toolchain/eslint.config.js +0 -5
  169. package/templates/react/base/toolchain/prettier.config.js +0 -10
  170. package/templates/react/base/tsconfig.json.ejs +0 -29
  171. package/templates/react/base/vite.config.js.ejs +0 -23
  172. package/templates/react/code-router/src/main.tsx.ejs +0 -92
  173. package/templates/react/example/tanchat/README.md +0 -37
  174. package/templates/react/example/tanchat/assets/_dot_env.local.append +0 -2
  175. package/templates/react/example/tanchat/assets/public/example-guitar-flowers.jpg +0 -0
  176. package/templates/react/example/tanchat/assets/public/example-guitar-motherboard.jpg +0 -0
  177. package/templates/react/example/tanchat/assets/public/example-guitar-racing.jpg +0 -0
  178. package/templates/react/example/tanchat/assets/public/example-guitar-steamer-trunk.jpg +0 -0
  179. package/templates/react/example/tanchat/assets/public/example-guitar-superhero.jpg +0 -0
  180. package/templates/react/example/tanchat/assets/public/example-guitar-traveling.jpg +0 -0
  181. package/templates/react/example/tanchat/assets/public/example-guitar-video-games.jpg +0 -0
  182. package/templates/react/example/tanchat/assets/src/components/example-AIAssistant.tsx +0 -173
  183. package/templates/react/example/tanchat/assets/src/components/example-GuitarRecommendation.tsx +0 -47
  184. package/templates/react/example/tanchat/assets/src/data/example-guitars.ts +0 -83
  185. package/templates/react/example/tanchat/assets/src/demo.index.css +0 -220
  186. package/templates/react/example/tanchat/assets/src/integrations/tanchat/header-user.tsx +0 -5
  187. package/templates/react/example/tanchat/assets/src/routes/example.chat.tsx +0 -159
  188. package/templates/react/example/tanchat/assets/src/routes/example.guitars/$guitarId.tsx +0 -50
  189. package/templates/react/example/tanchat/assets/src/routes/example.guitars/index.tsx +0 -54
  190. package/templates/react/example/tanchat/assets/src/store/example-assistant.ts +0 -3
  191. package/templates/react/example/tanchat/assets/src/utils/demo.ai.ts +0 -62
  192. package/templates/react/example/tanchat/assets/src/utils/demo.tools.ts +0 -47
  193. package/templates/react/example/tanchat/info.json +0 -19
  194. package/templates/react/example/tanchat/package.json +0 -15
  195. package/templates/react/file-router/package.fr.json +0 -5
  196. package/templates/react/file-router/src/main.tsx.ejs +0 -55
  197. package/templates/react/file-router/src/routes/__root.tsx.ejs +0 -82
  198. package/templates/solid/add-on/form/assets/src/routes/demo.form.tsx.ejs +0 -352
  199. package/templates/solid/add-on/form/info.json +0 -13
  200. package/templates/solid/add-on/form/package.json +0 -5
  201. package/templates/solid/add-on/module-federation/assets/module-federation.config.js.ejs +0 -27
  202. package/templates/solid/add-on/module-federation/assets/src/demo-mf-component.tsx +0 -3
  203. package/templates/solid/add-on/module-federation/assets/src/demo-mf-self-contained.tsx +0 -9
  204. package/templates/solid/add-on/module-federation/info.json +0 -7
  205. package/templates/solid/add-on/module-federation/package.json +0 -5
  206. package/templates/solid/add-on/sentry/assets/_dot_cursorrules.append +0 -22
  207. package/templates/solid/add-on/sentry/assets/_dot_env.local.append +0 -2
  208. package/templates/solid/add-on/sentry/assets/src/routes/demo.sentry.bad-event-handler.tsx +0 -20
  209. package/templates/solid/add-on/sentry/info.json +0 -13
  210. package/templates/solid/add-on/sentry/package.json +0 -5
  211. package/templates/solid/add-on/solid-ui/README.md +0 -9
  212. package/templates/solid/add-on/solid-ui/assets/src/lib/utils.ts +0 -6
  213. package/templates/solid/add-on/solid-ui/assets/src/styles.css +0 -138
  214. package/templates/solid/add-on/solid-ui/assets/ui.config.json +0 -13
  215. package/templates/solid/add-on/solid-ui/info.json +0 -11
  216. package/templates/solid/add-on/solid-ui/package.json +0 -9
  217. package/templates/solid/add-on/start/assets/app.config.ts +0 -16
  218. package/templates/solid/add-on/start/assets/src/api.ts +0 -6
  219. package/templates/solid/add-on/start/assets/src/client.tsx +0 -7
  220. package/templates/solid/add-on/start/assets/src/router.tsx.ejs +0 -24
  221. package/templates/solid/add-on/start/assets/src/routes/demo.start.server-funcs.tsx +0 -49
  222. package/templates/solid/add-on/start/assets/src/ssr.tsx +0 -12
  223. package/templates/solid/add-on/start/info.json +0 -14
  224. package/templates/solid/add-on/start/package.json +0 -12
  225. package/templates/solid/add-on/store/assets/src/lib/demo-store.ts +0 -13
  226. package/templates/solid/add-on/store/assets/src/routes/demo.store.tsx.ejs +0 -77
  227. package/templates/solid/add-on/store/info.json +0 -13
  228. package/templates/solid/add-on/store/package.json +0 -6
  229. package/templates/solid/add-on/tanstack-query/assets/src/integrations/tanstack-query/header-user.tsx +0 -5
  230. package/templates/solid/add-on/tanstack-query/assets/src/integrations/tanstack-query/provider.tsx +0 -15
  231. package/templates/solid/add-on/tanstack-query/assets/src/routes/demo.tanstack-query.tsx +0 -30
  232. package/templates/solid/add-on/tanstack-query/info.json +0 -13
  233. package/templates/solid/add-on/tanstack-query/package.json +0 -6
  234. package/templates/solid/base/README.md.ejs +0 -215
  235. package/templates/solid/base/_dot_cursorrules.append +0 -35
  236. package/templates/solid/base/_dot_gitignore +0 -5
  237. package/templates/solid/base/_dot_vscode/settings.biome.json +0 -38
  238. package/templates/solid/base/_dot_vscode/settings.json +0 -11
  239. package/templates/solid/base/index.html.ejs +0 -20
  240. package/templates/solid/base/package.biome.json +0 -10
  241. package/templates/solid/base/package.eslintprettier.json +0 -11
  242. package/templates/solid/base/package.json +0 -22
  243. package/templates/solid/base/package.ts.json +0 -5
  244. package/templates/solid/base/package.tw.json +0 -6
  245. package/templates/solid/base/public/favicon.ico +0 -0
  246. package/templates/solid/base/public/logo192.png +0 -0
  247. package/templates/solid/base/public/logo512.png +0 -0
  248. package/templates/solid/base/public/manifest.json +0 -25
  249. package/templates/solid/base/public/robots.txt +0 -3
  250. package/templates/solid/base/src/App.css +0 -0
  251. package/templates/solid/base/src/App.tsx.ejs +0 -47
  252. package/templates/solid/base/src/components/Header.tsx.ejs +0 -26
  253. package/templates/solid/base/src/logo.svg +0 -120
  254. package/templates/solid/base/src/styles.css.ejs +0 -15
  255. package/templates/solid/base/toolchain/.prettierignore +0 -3
  256. package/templates/solid/base/toolchain/biome.json +0 -31
  257. package/templates/solid/base/toolchain/eslint.config.js +0 -5
  258. package/templates/solid/base/toolchain/prettier.config.js +0 -10
  259. package/templates/solid/base/tsconfig.json.ejs +0 -31
  260. package/templates/solid/base/vite.config.js.ejs +0 -22
  261. package/templates/solid/code-router/src/main.tsx.ejs +0 -71
  262. package/templates/solid/example/tanchat/README.md +0 -52
  263. package/templates/solid/example/tanchat/assets/ai-streaming-server/README.md +0 -110
  264. package/templates/solid/example/tanchat/assets/ai-streaming-server/_dot_env.example +0 -1
  265. package/templates/solid/example/tanchat/assets/ai-streaming-server/package.json +0 -26
  266. package/templates/solid/example/tanchat/assets/ai-streaming-server/src/index.ts +0 -102
  267. package/templates/solid/example/tanchat/assets/ai-streaming-server/tsconfig.json +0 -15
  268. package/templates/solid/example/tanchat/assets/src/components/demo.SettingsDialog.tsx +0 -149
  269. package/templates/solid/example/tanchat/assets/src/demo.index.css +0 -227
  270. package/templates/solid/example/tanchat/assets/src/lib/demo-store.ts +0 -13
  271. package/templates/solid/example/tanchat/assets/src/routes/example.chat.tsx +0 -435
  272. package/templates/solid/example/tanchat/assets/src/store/demo.hooks.ts +0 -17
  273. package/templates/solid/example/tanchat/assets/src/store/demo.store.ts +0 -133
  274. package/templates/solid/example/tanchat/info.json +0 -14
  275. package/templates/solid/example/tanchat/package.json +0 -7
  276. package/templates/solid/file-router/package.fr.json +0 -5
  277. package/templates/solid/file-router/src/main.tsx.ejs +0 -47
  278. package/templates/solid/file-router/src/routes/__root.tsx.ejs +0 -41
  279. package/templates/solid/file-router/src/routes/index.tsx +0 -43
  280. package/tests/cra.test.ts +0 -293
  281. package/tests/snapshots/cra/cr-js-npm.json +0 -33
  282. package/tests/snapshots/cra/cr-ts-npm.json +0 -34
  283. package/tests/snapshots/cra/cr-ts-start-npm.json +0 -38
  284. package/tests/snapshots/cra/fr-ts-npm.json +0 -34
  285. package/tests/snapshots/cra/fr-ts-tw-npm.json +0 -33
  286. package/tests/snapshots/cra/solid-cr-js-npm.json +0 -31
  287. package/tests/snapshots/cra/solid-cr-ts-npm.json +0 -32
  288. package/tests/snapshots/cra/solid-cr-ts-start-npm.json +0 -36
  289. package/tests/snapshots/cra/solid-fr-ts-npm.json +0 -33
  290. package/tests/snapshots/cra/solid-fr-ts-tw-npm.json +0 -32
  291. package/tests/test-utilities.ts +0 -87
@@ -1,325 +0,0 @@
1
- import { readFile, readdir } from 'node:fs/promises'
2
- import { existsSync, mkdirSync, writeFileSync } from 'node:fs'
3
- import { basename, dirname, resolve } from 'node:path'
4
- import chalk from 'chalk'
5
-
6
- import { createMemoryEnvironment } from './environment.js'
7
- import { createApp } from './create-app.js'
8
- import { readConfigFile } from './config-file.js'
9
- import { finalizeAddOns } from './add-ons.js'
10
- import { readFileHelper } from './file-helper.js'
11
-
12
- import type { Framework, Options } from './types.js'
13
- import type { PersistedOptions } from './config-file.js'
14
-
15
- type AddOnMode = 'add-on' | 'overlay'
16
-
17
- const INFO_FILE: Record<AddOnMode, string> = {
18
- 'add-on': '.add-on/info.json',
19
- overlay: 'overlay-info.json',
20
- }
21
- const COMPILED_FILE: Record<AddOnMode, string> = {
22
- 'add-on': 'add-on.json',
23
- overlay: 'overlay.json',
24
- }
25
-
26
- const ADD_ON_DIR = '.add-on'
27
- const ASSETS_DIR = 'assets'
28
-
29
- const IGNORE_FILES = [
30
- ADD_ON_DIR,
31
- 'node_modules',
32
- 'dist',
33
- 'build',
34
- '.git',
35
- 'pnpm-lock.yaml',
36
- 'package-lock.json',
37
- 'yarn.lock',
38
- 'bun.lockb',
39
- 'bun.lock',
40
- 'deno.lock',
41
- 'add-on.json',
42
- 'add-on-info.json',
43
- 'package.json',
44
- ]
45
-
46
- const ADD_ON_IGNORE_FILES: Array<string> = [
47
- 'main.jsx',
48
- 'App.jsx',
49
- 'main.tsx',
50
- 'App.tsx',
51
- 'routeTree.gen.ts',
52
- ]
53
-
54
- function templatize(routeCode: string, routeFile: string) {
55
- let code = routeCode
56
-
57
- // Replace the import
58
- code = code.replace(
59
- /import { createFileRoute } from '@tanstack\/react-router'/g,
60
- `import { <% if (fileRouter) { %>createFileRoute<% } else { %>createRoute<% } %> } from '@tanstack/react-router'`,
61
- )
62
-
63
- // Extract route path and definition, then transform the route declaration
64
- const routeMatch = code.match(
65
- /export\s+const\s+Route\s*=\s*createFileRoute\(['"]([^'"]+)['"]\)\s*\(\{([^}]+)\}\)/,
66
- )
67
-
68
- let path = ''
69
-
70
- if (routeMatch) {
71
- const fullMatch = routeMatch[0]
72
- path = routeMatch[1]
73
- const routeDefinition = routeMatch[2]
74
- code = code.replace(
75
- fullMatch,
76
- `<% if (codeRouter) { %>
77
- import type { RootRoute } from '@tanstack/react-router'
78
- <% } else { %>
79
- export const Route = createFileRoute('${path}')({${routeDefinition}})
80
- <% } %>`,
81
- )
82
-
83
- code += `
84
- <% if (codeRouter) { %>
85
- export default (parentRoute: RootRoute) => createRoute({
86
- path: '${path}',
87
- ${routeDefinition}
88
- getParentRoute: () => parentRoute,
89
- })
90
- <% } %>
91
- `
92
- } else {
93
- console.error(`No route found in the file: ${routeFile}`)
94
- }
95
-
96
- const name = basename(path)
97
- .replace('.tsx', '')
98
- .replace(/^demo/, '')
99
- .replace('.', ' ')
100
- .trim()
101
-
102
- return { url: path, code, name }
103
- }
104
-
105
- async function createOptions(
106
- json: PersistedOptions,
107
- ): Promise<Required<Options>> {
108
- return {
109
- ...json,
110
- chosenAddOns: await finalizeAddOns(
111
- json.framework as Framework,
112
- json.mode as string,
113
- [...json.existingAddOns],
114
- ),
115
- } as Required<Options>
116
- }
117
-
118
- async function runCreateApp(options: Required<Options>) {
119
- const { environment, output } = createMemoryEnvironment()
120
- await createApp(options, {
121
- silent: true,
122
- environment,
123
- cwd: process.cwd(),
124
- name: 'create-tsrouter-app',
125
- })
126
- return output
127
- }
128
-
129
- async function recursivelyGatherFiles(
130
- path: string,
131
- files: Record<string, string>,
132
- ) {
133
- const dirFiles = await readdir(path, { withFileTypes: true })
134
- for (const file of dirFiles) {
135
- if (file.isDirectory()) {
136
- await recursivelyGatherFiles(resolve(path, file.name), files)
137
- } else {
138
- files[resolve(path, file.name)] = readFileHelper(resolve(path, file.name))
139
- }
140
- }
141
- }
142
-
143
- async function compareFiles(
144
- path: string,
145
- ignore: Array<string>,
146
- original: Record<string, string>,
147
- changedFiles: Record<string, string>,
148
- ) {
149
- const files = await readdir(path, { withFileTypes: true })
150
- for (const file of files) {
151
- const filePath = `${path}/${file.name}`
152
- if (!ignore.includes(file.name)) {
153
- if (file.isDirectory()) {
154
- await compareFiles(filePath, ignore, original, changedFiles)
155
- } else {
156
- const contents = (await readFile(filePath)).toString()
157
- const absolutePath = resolve(process.cwd(), filePath)
158
- if (!original[absolutePath] || original[absolutePath] !== contents) {
159
- changedFiles[filePath] = contents
160
- }
161
- }
162
- }
163
- }
164
- }
165
-
166
- export async function initAddOn(mode: AddOnMode) {
167
- const persistedOptions = await readConfigFile(process.cwd())
168
- if (!persistedOptions) {
169
- console.error(`${chalk.red('There is no .cta.json file in your project.')}
170
-
171
- This is probably because this was created with an older version of create-tsrouter-app.`)
172
- return
173
- }
174
-
175
- if (mode === 'add-on') {
176
- if (persistedOptions.mode !== 'file-router') {
177
- console.error(`${chalk.red('This project is not using file-router mode.')}
178
-
179
- To create an add-on, the project must be created with the file-router mode.`)
180
- return
181
- }
182
- if (!persistedOptions.tailwind) {
183
- console.error(`${chalk.red('This project is not using Tailwind CSS.')}
184
-
185
- To create an add-on, the project must be created with Tailwind CSS.`)
186
- return
187
- }
188
- if (!persistedOptions.typescript) {
189
- console.error(`${chalk.red('This project is not using TypeScript.')}
190
-
191
- To create an add-on, the project must be created with TypeScript.`)
192
- return
193
- }
194
- }
195
-
196
- const info = existsSync(INFO_FILE[mode])
197
- ? JSON.parse((await readFile(INFO_FILE[mode])).toString())
198
- : {
199
- name: `${persistedOptions.projectName}-${mode}`,
200
- version: '0.0.1',
201
- description: mode === 'add-on' ? 'Add-on' : 'Project overlay',
202
- author: 'Jane Smith <jane.smith@example.com>',
203
- license: 'MIT',
204
- link: `https://github.com/jane-smith/${persistedOptions.projectName}-${mode}`,
205
- command: {},
206
- shadcnComponents: [],
207
- templates: [persistedOptions.mode],
208
- routes: [],
209
- warning: '',
210
- variables: {},
211
- phase: 'add-on',
212
- type: mode,
213
- packageAdditions: {
214
- scripts: {},
215
- dependencies: {},
216
- devDependencies: {},
217
- },
218
- }
219
-
220
- const compiledInfo = JSON.parse(JSON.stringify(info))
221
-
222
- const originalOutput = await runCreateApp(
223
- await createOptions(persistedOptions),
224
- )
225
-
226
- const originalPackageJson = JSON.parse(
227
- originalOutput.files[resolve(process.cwd(), 'package.json')],
228
- )
229
- const currentPackageJson = JSON.parse(
230
- (await readFile('package.json')).toString(),
231
- )
232
-
233
- for (const script of Object.keys(currentPackageJson.scripts)) {
234
- if (
235
- originalPackageJson.scripts[script] !== currentPackageJson.scripts[script]
236
- ) {
237
- info.packageAdditions.scripts[script] = currentPackageJson.scripts[script]
238
- }
239
- }
240
-
241
- const dependencies: Record<string, string> = {}
242
- for (const dependency of Object.keys(currentPackageJson.dependencies)) {
243
- if (
244
- originalPackageJson.dependencies[dependency] !==
245
- currentPackageJson.dependencies[dependency]
246
- ) {
247
- dependencies[dependency] = currentPackageJson.dependencies[dependency]
248
- }
249
- }
250
- info.packageAdditions.dependencies = dependencies
251
-
252
- const devDependencies: Record<string, string> = {}
253
- for (const dependency of Object.keys(currentPackageJson.devDependencies)) {
254
- if (
255
- originalPackageJson.devDependencies[dependency] !==
256
- currentPackageJson.devDependencies[dependency]
257
- ) {
258
- devDependencies[dependency] =
259
- currentPackageJson.devDependencies[dependency]
260
- }
261
- }
262
- info.packageAdditions.devDependencies = devDependencies
263
-
264
- // Find altered files
265
- const changedFiles: Record<string, string> = {}
266
- await compareFiles('.', IGNORE_FILES, originalOutput.files, changedFiles)
267
- if (mode === 'overlay') {
268
- compiledInfo.files = changedFiles
269
- } else {
270
- const assetsDir = resolve(ADD_ON_DIR, ASSETS_DIR)
271
- if (!existsSync(assetsDir)) {
272
- await compareFiles('.', IGNORE_FILES, originalOutput.files, changedFiles)
273
- for (const file of Object.keys(changedFiles).filter(
274
- (file) => !ADD_ON_IGNORE_FILES.includes(basename(file)),
275
- )) {
276
- mkdirSync(dirname(resolve(assetsDir, file)), {
277
- recursive: true,
278
- })
279
- if (file.includes('/routes/')) {
280
- const { url, code, name } = templatize(changedFiles[file], file)
281
- info.routes.push({
282
- url,
283
- name,
284
- })
285
- writeFileSync(resolve(assetsDir, `${file}.ejs`), code)
286
- } else {
287
- writeFileSync(resolve(assetsDir, file), changedFiles[file])
288
- }
289
- }
290
- }
291
- const addOnFiles: Record<string, string> = {}
292
- await recursivelyGatherFiles(assetsDir, addOnFiles)
293
- compiledInfo.files = Object.keys(addOnFiles).reduce(
294
- (acc, file) => {
295
- acc[file.replace(assetsDir, '.')] = addOnFiles[file]
296
- return acc
297
- },
298
- {} as Record<string, string>,
299
- )
300
- }
301
-
302
- compiledInfo.routes = info.routes
303
- compiledInfo.framework = persistedOptions.framework
304
- compiledInfo.addDependencies = persistedOptions.existingAddOns
305
-
306
- if (mode === 'overlay') {
307
- compiledInfo.mode = persistedOptions.mode
308
- compiledInfo.typescript = persistedOptions.typescript
309
- compiledInfo.tailwind = persistedOptions.tailwind
310
-
311
- compiledInfo.deletedFiles = []
312
- for (const file of Object.keys(originalOutput.files)) {
313
- if (!existsSync(file)) {
314
- compiledInfo.deletedFiles.push(file.replace(process.cwd(), '.'))
315
- }
316
- }
317
- }
318
-
319
- if (!existsSync(resolve(INFO_FILE[mode]))) {
320
- mkdirSync(resolve(dirname(INFO_FILE[mode])), { recursive: true })
321
- writeFileSync(INFO_FILE[mode], JSON.stringify(info, null, 2))
322
- }
323
-
324
- writeFileSync(COMPILED_FILE[mode], JSON.stringify(compiledInfo, null, 2))
325
- }
@@ -1,20 +0,0 @@
1
- import { readFileSync } from 'node:fs'
2
- import { extname } from 'node:path'
3
-
4
- const BINARY_EXTENSIONS = ['.png', '.jpg', '.jpeg', '.gif', '.svg', '.ico']
5
-
6
- export function readFileHelper(path: string): string {
7
- if (BINARY_EXTENSIONS.includes(extname(path))) {
8
- return `base64::${readFileSync(path).toString('base64')}`
9
- } else {
10
- return readFileSync(path, 'utf-8').toString()
11
- }
12
- }
13
-
14
- export function getBinaryFile(content: string): string | null {
15
- if (content.startsWith('base64::')) {
16
- const binaryContent = Buffer.from(content.replace('base64::', ''), 'base64')
17
- return binaryContent as unknown as string
18
- }
19
- return null
20
- }
package/src/mcp.ts DELETED
@@ -1,302 +0,0 @@
1
- import { McpServer } from '@modelcontextprotocol/sdk/server/mcp.js'
2
- import { SSEServerTransport } from '@modelcontextprotocol/sdk/server/sse.js'
3
- import { StdioServerTransport } from '@modelcontextprotocol/sdk/server/stdio.js'
4
- import express from 'express'
5
- import { z } from 'zod'
6
-
7
- import { createApp } from './create-app.js'
8
- import { finalizeAddOns } from './add-ons.js'
9
- import { createDefaultEnvironment } from './environment.js'
10
-
11
- import type { TemplateOptions } from './types.js'
12
-
13
- const tanStackReactAddOns = [
14
- {
15
- id: 'clerk',
16
- description: 'Enable authentication with Clerk',
17
- },
18
- {
19
- id: 'convex',
20
- description: 'Enable a database using Convex',
21
- },
22
- {
23
- id: 'form',
24
- description: 'Form handling library',
25
- },
26
- {
27
- id: 'netlify',
28
- description: 'Enable deployments to Netlify',
29
- },
30
- {
31
- id: 'sentry',
32
- description: 'Enable Sentry error tracking',
33
- },
34
- {
35
- id: 'shadcn',
36
- description: 'Enable integration of the Shadcn UI component library',
37
- },
38
- {
39
- id: 'start',
40
- description:
41
- 'Set this if you want a TanStack Start application that supports server functions or APIs',
42
- },
43
- {
44
- id: 'tanstack-query',
45
- description: 'Enable TanStack Query for data fetching',
46
- },
47
- {
48
- id: 'store',
49
- description: 'Enable the TanStack Store state management library',
50
- },
51
- {
52
- id: 'tanchat',
53
- description: 'Add an AI chatbot example to the application',
54
- },
55
- ]
56
-
57
- const tanStackSolidAddOns = [
58
- {
59
- id: 'solid-ui',
60
- description: 'Enable integration of the Solid UI component library',
61
- },
62
- {
63
- id: 'form',
64
- description: 'Form handling library',
65
- },
66
- {
67
- id: 'sentry',
68
- description: 'Enable Sentry error tracking',
69
- },
70
- {
71
- id: 'store',
72
- description: 'Enable the TanStack Store state management library',
73
- },
74
- {
75
- id: 'start',
76
- description:
77
- 'Set this if you want a TanStack Start application that supports server functions or APIs',
78
- },
79
- {
80
- id: 'tanstack-query',
81
- description: 'Enable TanStack Query for data fetching',
82
- },
83
- {
84
- id: 'tanchat',
85
- description: 'Add an AI chatbot example to the application',
86
- },
87
- ]
88
-
89
- function createServer({
90
- appName,
91
- forcedAddOns = [],
92
- name,
93
- }: {
94
- appName?: string
95
- forcedAddOns?: Array<string>
96
- name?: string
97
- }) {
98
- const server = new McpServer({
99
- name: `${appName} Application Builder`,
100
- version: '1.0.0',
101
- })
102
-
103
- server.tool('listTanStackReactAddOns', {}, () => {
104
- return {
105
- content: [{ type: 'text', text: JSON.stringify(tanStackReactAddOns) }],
106
- }
107
- })
108
-
109
- server.tool(
110
- 'createTanStackReactApplication',
111
- {
112
- projectName: z
113
- .string()
114
- .describe(
115
- 'The package.json module name of the application (will also be the directory name)',
116
- ),
117
- cwd: z.string().describe('The directory to create the application in'),
118
- addOns: z
119
- .array(
120
- z.enum([
121
- 'clerk',
122
- 'convex',
123
- 'form',
124
- 'netlify',
125
- 'sentry',
126
- 'shadcn',
127
- 'start',
128
- 'store',
129
- 'tanstack-query',
130
- 'tanchat',
131
- ]),
132
- )
133
- .describe('The IDs of the add-ons to install'),
134
- targetDir: z
135
- .string()
136
- .describe(
137
- 'The directory to create the application in. Use the absolute path of the directory you want the application to be created in',
138
- ),
139
- },
140
- async ({ projectName, addOns, cwd, targetDir }) => {
141
- try {
142
- process.chdir(cwd)
143
- const chosenAddOns = await finalizeAddOns(
144
- 'react',
145
- 'file-router',
146
- Array.from(
147
- new Set([...(addOns as unknown as Array<string>), ...forcedAddOns]),
148
- ),
149
- )
150
- await createApp(
151
- {
152
- projectName: projectName.replace(/^\//, './'),
153
- framework: 'react',
154
- typescript: true,
155
- tailwind: true,
156
- packageManager: 'pnpm',
157
- toolchain: 'none',
158
- mode: 'file-router',
159
- addOns: true,
160
- chosenAddOns,
161
- git: true,
162
- variableValues: {},
163
- },
164
- {
165
- silent: true,
166
- environment: createDefaultEnvironment(),
167
- name,
168
- cwd: targetDir,
169
- },
170
- )
171
- return {
172
- content: [{ type: 'text', text: 'Application created successfully' }],
173
- }
174
- } catch (error) {
175
- return {
176
- content: [
177
- { type: 'text', text: `Error creating application: ${error}` },
178
- ],
179
- }
180
- }
181
- },
182
- )
183
-
184
- server.tool('listTanStackSolidAddOns', {}, () => {
185
- return {
186
- content: [{ type: 'text', text: JSON.stringify(tanStackSolidAddOns) }],
187
- }
188
- })
189
-
190
- server.tool(
191
- 'createTanStackSolidApplication',
192
- {
193
- projectName: z
194
- .string()
195
- .describe(
196
- 'The package.json module name of the application (will also be the directory name)',
197
- ),
198
- cwd: z.string().describe('The directory to create the application in'),
199
- addOns: z
200
- .array(
201
- z.enum([
202
- 'solid-ui',
203
- 'form',
204
- 'sentry',
205
- 'store',
206
- 'tanstack-query',
207
- 'tanchat',
208
- ]),
209
- )
210
- .describe('The IDs of the add-ons to install'),
211
- targetDir: z
212
- .string()
213
- .describe(
214
- 'The directory to create the application in. Use the absolute path of the directory you want the application to be created in',
215
- ),
216
- },
217
- async ({ projectName, addOns, cwd, targetDir }) => {
218
- try {
219
- process.chdir(cwd)
220
- const chosenAddOns = await finalizeAddOns(
221
- 'solid',
222
- 'file-router',
223
- Array.from(
224
- new Set([...(addOns as unknown as Array<string>), ...forcedAddOns]),
225
- ),
226
- )
227
- await createApp(
228
- {
229
- projectName: projectName.replace(/^\//, './'),
230
- framework: 'solid',
231
- typescript: true,
232
- tailwind: true,
233
- packageManager: 'pnpm',
234
- toolchain: 'none',
235
- mode: 'file-router',
236
- addOns: true,
237
- chosenAddOns,
238
- git: true,
239
- variableValues: {},
240
- },
241
- {
242
- silent: true,
243
- environment: createDefaultEnvironment(),
244
- name,
245
- cwd: targetDir,
246
- },
247
- )
248
- return {
249
- content: [{ type: 'text', text: 'Application created successfully' }],
250
- }
251
- } catch (error) {
252
- return {
253
- content: [
254
- { type: 'text', text: `Error creating application: ${error}` },
255
- ],
256
- }
257
- }
258
- },
259
- )
260
-
261
- return server
262
- }
263
-
264
- export default async function runServer(
265
- sse: boolean,
266
- {
267
- forcedAddOns,
268
- appName,
269
- name,
270
- }: {
271
- forcedMode?: TemplateOptions
272
- forcedAddOns?: Array<string>
273
- appName?: string
274
- name?: string
275
- },
276
- ) {
277
- let transport: SSEServerTransport | null = null
278
-
279
- const server = createServer({ appName, forcedAddOns, name })
280
- if (sse) {
281
- const app = express()
282
-
283
- app.get('/sse', (req, res) => {
284
- transport = new SSEServerTransport('/messages', res)
285
- server.connect(transport)
286
- })
287
-
288
- app.post('/messages', (req, res) => {
289
- if (transport) {
290
- transport.handlePostMessage(req, res)
291
- }
292
- })
293
-
294
- const port = process.env.PORT || 8080
295
- app.listen(port, () => {
296
- console.log(`Server is running on port http://localhost:${port}/sse`)
297
- })
298
- } else {
299
- const transport = new StdioServerTransport()
300
- await server.connect(transport)
301
- }
302
- }