@posthog/wizard 1.36.0 → 2.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (487) hide show
  1. package/README.md +80 -3
  2. package/dist/bin.js +200 -24
  3. package/dist/bin.js.map +1 -1
  4. package/dist/src/__tests__/cli.test.js +10 -74
  5. package/dist/src/__tests__/cli.test.js.map +1 -1
  6. package/dist/src/__tests__/run.test.js +50 -5
  7. package/dist/src/__tests__/run.test.js.map +1 -1
  8. package/dist/src/__tests__/wizard-abort.test.js +127 -0
  9. package/dist/src/__tests__/wizard-abort.test.js.map +1 -0
  10. package/dist/src/{android → frameworks/android}/android-wizard-agent.d.ts +1 -1
  11. package/dist/src/{android → frameworks/android}/android-wizard-agent.js +2 -2
  12. package/dist/src/frameworks/android/android-wizard-agent.js.map +1 -0
  13. package/dist/src/{android → frameworks/android}/utils.d.ts +1 -1
  14. package/dist/src/{android → frameworks/android}/utils.js +1 -1
  15. package/dist/src/frameworks/android/utils.js.map +1 -0
  16. package/dist/src/{angular → frameworks/angular}/angular-wizard-agent.d.ts +1 -1
  17. package/dist/src/{angular → frameworks/angular}/angular-wizard-agent.js +9 -7
  18. package/dist/src/frameworks/angular/angular-wizard-agent.js.map +1 -0
  19. package/dist/src/{angular → frameworks/angular}/utils.js +1 -1
  20. package/dist/src/frameworks/angular/utils.js.map +1 -0
  21. package/dist/src/{astro → frameworks/astro}/astro-wizard-agent.d.ts +1 -1
  22. package/dist/src/{astro → frameworks/astro}/astro-wizard-agent.js +9 -7
  23. package/dist/src/frameworks/astro/astro-wizard-agent.js.map +1 -0
  24. package/dist/src/{astro → frameworks/astro}/utils.d.ts +2 -5
  25. package/dist/src/{astro → frameworks/astro}/utils.js +3 -52
  26. package/dist/src/frameworks/astro/utils.js.map +1 -0
  27. package/dist/src/{django → frameworks/django}/django-wizard-agent.d.ts +1 -1
  28. package/dist/src/{django → frameworks/django}/django-wizard-agent.js +3 -3
  29. package/dist/src/frameworks/django/django-wizard-agent.js.map +1 -0
  30. package/dist/src/{django → frameworks/django}/utils.d.ts +1 -1
  31. package/dist/src/{django → frameworks/django}/utils.js +6 -6
  32. package/dist/src/frameworks/django/utils.js.map +1 -0
  33. package/dist/src/frameworks/fastapi/fastapi-wizard-agent.d.ts +5 -0
  34. package/dist/src/{fastapi → frameworks/fastapi}/fastapi-wizard-agent.js +3 -32
  35. package/dist/src/frameworks/fastapi/fastapi-wizard-agent.js.map +1 -0
  36. package/dist/src/{fastapi → frameworks/fastapi}/utils.d.ts +1 -1
  37. package/dist/src/{fastapi → frameworks/fastapi}/utils.js +4 -4
  38. package/dist/src/frameworks/fastapi/utils.js.map +1 -0
  39. package/dist/src/{flask → frameworks/flask}/flask-wizard-agent.d.ts +1 -1
  40. package/dist/src/{flask → frameworks/flask}/flask-wizard-agent.js +3 -3
  41. package/dist/src/frameworks/flask/flask-wizard-agent.js.map +1 -0
  42. package/dist/src/{flask → frameworks/flask}/utils.d.ts +1 -1
  43. package/dist/src/{flask → frameworks/flask}/utils.js +7 -7
  44. package/dist/src/frameworks/flask/utils.js.map +1 -0
  45. package/dist/src/{javascript-node → frameworks/javascript-node}/javascript-node-wizard-agent.d.ts +1 -1
  46. package/dist/src/{javascript-node → frameworks/javascript-node}/javascript-node-wizard-agent.js +4 -4
  47. package/dist/src/frameworks/javascript-node/javascript-node-wizard-agent.js.map +1 -0
  48. package/dist/src/{javascript-web → frameworks/javascript-web}/javascript-web-wizard-agent.d.ts +1 -1
  49. package/dist/src/{javascript-web → frameworks/javascript-web}/javascript-web-wizard-agent.js +16 -14
  50. package/dist/src/frameworks/javascript-web/javascript-web-wizard-agent.js.map +1 -0
  51. package/dist/src/{javascript-web → frameworks/javascript-web}/utils.d.ts +6 -1
  52. package/dist/src/{javascript-web → frameworks/javascript-web}/utils.js +49 -1
  53. package/dist/src/frameworks/javascript-web/utils.js.map +1 -0
  54. package/dist/src/{laravel → frameworks/laravel}/laravel-wizard-agent.d.ts +1 -1
  55. package/dist/src/{laravel → frameworks/laravel}/laravel-wizard-agent.js +2 -2
  56. package/dist/src/frameworks/laravel/laravel-wizard-agent.js.map +1 -0
  57. package/dist/src/{laravel → frameworks/laravel}/utils.d.ts +1 -1
  58. package/dist/src/{laravel → frameworks/laravel}/utils.js +5 -5
  59. package/dist/src/frameworks/laravel/utils.js.map +1 -0
  60. package/dist/src/{nextjs → frameworks/nextjs}/nextjs-wizard-agent.d.ts +1 -1
  61. package/dist/src/{nextjs → frameworks/nextjs}/nextjs-wizard-agent.js +30 -8
  62. package/dist/src/frameworks/nextjs/nextjs-wizard-agent.js.map +1 -0
  63. package/dist/src/{nextjs → frameworks/nextjs}/utils.d.ts +5 -2
  64. package/dist/src/{nextjs → frameworks/nextjs}/utils.js +6 -20
  65. package/dist/src/frameworks/nextjs/utils.js.map +1 -0
  66. package/dist/src/{nuxt → frameworks/nuxt}/nuxt-wizard-agent.d.ts +1 -1
  67. package/dist/src/{nuxt → frameworks/nuxt}/nuxt-wizard-agent.js +11 -9
  68. package/dist/src/frameworks/nuxt/nuxt-wizard-agent.js.map +1 -0
  69. package/dist/src/{python → frameworks/python}/python-wizard-agent.d.ts +1 -1
  70. package/dist/src/{python → frameworks/python}/python-wizard-agent.js +3 -3
  71. package/dist/src/frameworks/python/python-wizard-agent.js.map +1 -0
  72. package/dist/src/{python → frameworks/python}/utils.d.ts +1 -1
  73. package/dist/src/frameworks/python/utils.js.map +1 -0
  74. package/dist/src/{rails → frameworks/rails}/rails-wizard-agent.d.ts +1 -1
  75. package/dist/src/{rails → frameworks/rails}/rails-wizard-agent.js +2 -2
  76. package/dist/src/frameworks/rails/rails-wizard-agent.js.map +1 -0
  77. package/dist/src/{rails → frameworks/rails}/utils.d.ts +1 -1
  78. package/dist/src/{rails → frameworks/rails}/utils.js +4 -4
  79. package/dist/src/frameworks/rails/utils.js.map +1 -0
  80. package/dist/src/{react-native → frameworks/react-native}/react-native-wizard-agent.d.ts +1 -1
  81. package/dist/src/{react-native → frameworks/react-native}/react-native-wizard-agent.js +9 -7
  82. package/dist/src/frameworks/react-native/react-native-wizard-agent.js.map +1 -0
  83. package/dist/src/{react-native → frameworks/react-native}/utils.d.ts +1 -1
  84. package/dist/src/{react-native → frameworks/react-native}/utils.js +7 -10
  85. package/dist/src/frameworks/react-native/utils.js.map +1 -0
  86. package/dist/src/{react-router → frameworks/react-router}/react-router-wizard-agent.d.ts +1 -1
  87. package/dist/src/{react-router → frameworks/react-router}/react-router-wizard-agent.js +15 -8
  88. package/dist/src/frameworks/react-router/react-router-wizard-agent.js.map +1 -0
  89. package/dist/src/frameworks/react-router/utils.d.ts +13 -0
  90. package/dist/src/{react-router → frameworks/react-router}/utils.js +14 -111
  91. package/dist/src/frameworks/react-router/utils.js.map +1 -0
  92. package/dist/src/{ruby → frameworks/ruby}/ruby-wizard-agent.d.ts +1 -1
  93. package/dist/src/{ruby → frameworks/ruby}/ruby-wizard-agent.js +2 -2
  94. package/dist/src/frameworks/ruby/ruby-wizard-agent.js.map +1 -0
  95. package/dist/src/{ruby → frameworks/ruby}/utils.d.ts +1 -1
  96. package/dist/src/{ruby → frameworks/ruby}/utils.js +1 -1
  97. package/dist/src/frameworks/ruby/utils.js.map +1 -0
  98. package/dist/src/{svelte → frameworks/svelte}/svelte-wizard-agent.d.ts +1 -1
  99. package/dist/src/{svelte → frameworks/svelte}/svelte-wizard-agent.js +5 -5
  100. package/dist/src/frameworks/svelte/svelte-wizard-agent.js.map +1 -0
  101. package/dist/src/{swift → frameworks/swift}/swift-wizard-agent.d.ts +1 -1
  102. package/dist/src/{swift → frameworks/swift}/swift-wizard-agent.js +2 -2
  103. package/dist/src/frameworks/swift/swift-wizard-agent.js.map +1 -0
  104. package/dist/src/{swift → frameworks/swift}/utils.d.ts +1 -1
  105. package/dist/src/frameworks/swift/utils.js.map +1 -0
  106. package/dist/src/{tanstack-router → frameworks/tanstack-router}/tanstack-router-wizard-agent.d.ts +1 -1
  107. package/dist/src/{tanstack-router → frameworks/tanstack-router}/tanstack-router-wizard-agent.js +15 -8
  108. package/dist/src/frameworks/tanstack-router/tanstack-router-wizard-agent.js.map +1 -0
  109. package/dist/src/frameworks/tanstack-router/utils.d.ts +11 -0
  110. package/dist/src/{tanstack-router → frameworks/tanstack-router}/utils.js +4 -47
  111. package/dist/src/frameworks/tanstack-router/utils.js.map +1 -0
  112. package/dist/src/{tanstack-start → frameworks/tanstack-start}/tanstack-start-wizard-agent.d.ts +1 -1
  113. package/dist/src/{tanstack-start → frameworks/tanstack-start}/tanstack-start-wizard-agent.js +9 -7
  114. package/dist/src/frameworks/tanstack-start/tanstack-start-wizard-agent.js.map +1 -0
  115. package/dist/src/{tanstack-start → frameworks/tanstack-start}/utils.js +1 -1
  116. package/dist/src/frameworks/tanstack-start/utils.js.map +1 -0
  117. package/dist/src/{vue → frameworks/vue}/vue-wizard-agent.d.ts +1 -1
  118. package/dist/src/{vue → frameworks/vue}/vue-wizard-agent.js +8 -8
  119. package/dist/src/frameworks/vue/vue-wizard-agent.js.map +1 -0
  120. package/dist/src/lib/__tests__/agent-interface.test.js +91 -19
  121. package/dist/src/lib/__tests__/agent-interface.test.js.map +1 -1
  122. package/dist/src/lib/agent-interface.d.ts +49 -2
  123. package/dist/src/lib/agent-interface.js +254 -40
  124. package/dist/src/lib/agent-interface.js.map +1 -1
  125. package/dist/src/lib/agent-runner.d.ts +4 -2
  126. package/dist/src/lib/agent-runner.js +131 -136
  127. package/dist/src/lib/agent-runner.js.map +1 -1
  128. package/dist/src/lib/api.d.ts +4 -4
  129. package/dist/src/lib/commandments.js +1 -0
  130. package/dist/src/lib/commandments.js.map +1 -1
  131. package/dist/src/lib/constants.d.ts +23 -8
  132. package/dist/src/lib/constants.js +36 -8
  133. package/dist/src/lib/constants.js.map +1 -1
  134. package/dist/src/lib/framework-config.d.ts +26 -0
  135. package/dist/src/lib/framework-config.js.map +1 -1
  136. package/dist/src/lib/health-checks/__tests__/health-checks.test.d.ts +18 -0
  137. package/dist/src/lib/health-checks/__tests__/health-checks.test.js +752 -0
  138. package/dist/src/lib/health-checks/__tests__/health-checks.test.js.map +1 -0
  139. package/dist/src/lib/health-checks/endpoints.d.ts +3 -0
  140. package/dist/src/lib/health-checks/endpoints.js +46 -0
  141. package/dist/src/lib/health-checks/endpoints.js.map +1 -0
  142. package/dist/src/lib/health-checks/index.d.ts +4 -0
  143. package/dist/src/lib/health-checks/index.js +23 -0
  144. package/dist/src/lib/health-checks/index.js.map +1 -0
  145. package/dist/src/lib/health-checks/readiness.d.ts +24 -0
  146. package/dist/src/lib/health-checks/readiness.js +119 -0
  147. package/dist/src/lib/health-checks/readiness.js.map +1 -0
  148. package/dist/src/lib/health-checks/statuspage.d.ts +9 -0
  149. package/dist/src/lib/health-checks/statuspage.js +105 -0
  150. package/dist/src/lib/health-checks/statuspage.js.map +1 -0
  151. package/dist/src/lib/health-checks/types.d.ts +31 -0
  152. package/dist/src/lib/health-checks/types.js +10 -0
  153. package/dist/src/lib/health-checks/types.js.map +1 -0
  154. package/dist/src/lib/middleware/benchmark.d.ts +2 -2
  155. package/dist/src/lib/middleware/benchmark.js +3 -3
  156. package/dist/src/lib/middleware/benchmark.js.map +1 -1
  157. package/dist/src/lib/middleware/benchmarks/json-writer.js +2 -2
  158. package/dist/src/lib/middleware/benchmarks/json-writer.js.map +1 -1
  159. package/dist/src/lib/middleware/benchmarks/summary.d.ts +2 -2
  160. package/dist/src/lib/middleware/benchmarks/summary.js +9 -9
  161. package/dist/src/lib/middleware/benchmarks/summary.js.map +1 -1
  162. package/dist/src/lib/middleware/types.d.ts +2 -2
  163. package/dist/src/lib/middleware/types.js.map +1 -1
  164. package/dist/src/lib/package-manager-detection.js +1 -1
  165. package/dist/src/lib/package-manager-detection.js.map +1 -1
  166. package/dist/src/lib/registry.js +21 -21
  167. package/dist/src/lib/registry.js.map +1 -1
  168. package/dist/src/lib/version.d.ts +1 -1
  169. package/dist/src/lib/version.js +1 -1
  170. package/dist/src/lib/version.js.map +1 -1
  171. package/dist/src/lib/wizard-session.d.ts +115 -0
  172. package/dist/src/lib/wizard-session.js +104 -0
  173. package/dist/src/lib/wizard-session.js.map +1 -0
  174. package/dist/src/lib/wizard-tools.js +13 -0
  175. package/dist/src/lib/wizard-tools.js.map +1 -1
  176. package/dist/src/run.d.ts +3 -3
  177. package/dist/src/run.js +73 -56
  178. package/dist/src/run.js.map +1 -1
  179. package/dist/src/steps/add-mcp-server-to-clients/MCPClient.d.ts +4 -5
  180. package/dist/src/steps/add-mcp-server-to-clients/MCPClient.js +6 -6
  181. package/dist/src/steps/add-mcp-server-to-clients/MCPClient.js.map +1 -1
  182. package/dist/src/steps/add-mcp-server-to-clients/__tests__/defaults.test.js +1 -21
  183. package/dist/src/steps/add-mcp-server-to-clients/__tests__/defaults.test.js.map +1 -1
  184. package/dist/src/steps/add-mcp-server-to-clients/clients/__tests__/claude.test.js +2 -7
  185. package/dist/src/steps/add-mcp-server-to-clients/clients/__tests__/claude.test.js.map +1 -1
  186. package/dist/src/steps/add-mcp-server-to-clients/clients/__tests__/codex.test.js +18 -22
  187. package/dist/src/steps/add-mcp-server-to-clients/clients/__tests__/codex.test.js.map +1 -1
  188. package/dist/src/steps/add-mcp-server-to-clients/clients/claude-code.d.ts +7 -8
  189. package/dist/src/steps/add-mcp-server-to-clients/clients/claude-code.js +2 -2
  190. package/dist/src/steps/add-mcp-server-to-clients/clients/claude-code.js.map +1 -1
  191. package/dist/src/steps/add-mcp-server-to-clients/clients/claude.d.ts +6 -6
  192. package/dist/src/steps/add-mcp-server-to-clients/clients/codex.d.ts +7 -8
  193. package/dist/src/steps/add-mcp-server-to-clients/clients/codex.js +9 -10
  194. package/dist/src/steps/add-mcp-server-to-clients/clients/codex.js.map +1 -1
  195. package/dist/src/steps/add-mcp-server-to-clients/clients/cursor.d.ts +8 -9
  196. package/dist/src/steps/add-mcp-server-to-clients/clients/cursor.js +4 -4
  197. package/dist/src/steps/add-mcp-server-to-clients/clients/cursor.js.map +1 -1
  198. package/dist/src/steps/add-mcp-server-to-clients/clients/visual-studio-code.d.ts +8 -9
  199. package/dist/src/steps/add-mcp-server-to-clients/clients/visual-studio-code.js +4 -4
  200. package/dist/src/steps/add-mcp-server-to-clients/clients/visual-studio-code.js.map +1 -1
  201. package/dist/src/steps/add-mcp-server-to-clients/clients/zed.d.ts +8 -9
  202. package/dist/src/steps/add-mcp-server-to-clients/clients/zed.js +4 -4
  203. package/dist/src/steps/add-mcp-server-to-clients/clients/zed.js.map +1 -1
  204. package/dist/src/steps/add-mcp-server-to-clients/defaults.d.ts +9 -10
  205. package/dist/src/steps/add-mcp-server-to-clients/defaults.js +6 -13
  206. package/dist/src/steps/add-mcp-server-to-clients/defaults.js.map +1 -1
  207. package/dist/src/steps/add-mcp-server-to-clients/index.d.ts +6 -5
  208. package/dist/src/steps/add-mcp-server-to-clients/index.js +26 -110
  209. package/dist/src/steps/add-mcp-server-to-clients/index.js.map +1 -1
  210. package/dist/src/steps/add-or-update-environment-variables.js +15 -20
  211. package/dist/src/steps/add-or-update-environment-variables.js.map +1 -1
  212. package/dist/src/steps/index.d.ts +0 -1
  213. package/dist/src/steps/index.js +0 -1
  214. package/dist/src/steps/index.js.map +1 -1
  215. package/dist/src/steps/run-prettier.js +9 -11
  216. package/dist/src/steps/run-prettier.js.map +1 -1
  217. package/dist/src/steps/upload-environment-variables/EnvironmentProvider.d.ts +6 -3
  218. package/dist/src/steps/upload-environment-variables/EnvironmentProvider.js.map +1 -1
  219. package/dist/src/steps/upload-environment-variables/index.d.ts +3 -3
  220. package/dist/src/steps/upload-environment-variables/index.js +7 -35
  221. package/dist/src/steps/upload-environment-variables/index.js.map +1 -1
  222. package/dist/src/steps/upload-environment-variables/providers/vercel.d.ts +3 -2
  223. package/dist/src/steps/upload-environment-variables/providers/vercel.js +2 -2
  224. package/dist/src/steps/upload-environment-variables/providers/vercel.js.map +1 -1
  225. package/dist/src/ui/index.d.ts +8 -0
  226. package/dist/src/ui/index.js +17 -0
  227. package/dist/src/ui/index.js.map +1 -0
  228. package/dist/src/ui/logging-ui.d.ts +44 -0
  229. package/dist/src/ui/logging-ui.js +103 -0
  230. package/dist/src/ui/logging-ui.js.map +1 -0
  231. package/dist/src/ui/tui/App.d.ts +6 -0
  232. package/dist/src/ui/tui/App.js +10 -0
  233. package/dist/src/ui/tui/App.js.map +1 -0
  234. package/dist/src/ui/tui/__tests__/layout-helpers.test.js +68 -0
  235. package/dist/src/ui/tui/__tests__/layout-helpers.test.js.map +1 -0
  236. package/dist/src/ui/tui/__tests__/store.test.d.ts +1 -0
  237. package/dist/src/ui/tui/__tests__/store.test.js +723 -0
  238. package/dist/src/ui/tui/__tests__/store.test.js.map +1 -0
  239. package/dist/src/ui/tui/components/LearnCard.d.ts +10 -0
  240. package/dist/src/ui/tui/components/LearnCard.js +217 -0
  241. package/dist/src/ui/tui/components/LearnCard.js.map +1 -0
  242. package/dist/src/ui/tui/components/TipsCard.d.ts +9 -0
  243. package/dist/src/ui/tui/components/TipsCard.js +55 -0
  244. package/dist/src/ui/tui/components/TipsCard.js.map +1 -0
  245. package/dist/src/ui/tui/components/TitleBar.d.ts +6 -0
  246. package/dist/src/ui/tui/components/TitleBar.js +17 -0
  247. package/dist/src/ui/tui/components/TitleBar.js.map +1 -0
  248. package/dist/src/ui/tui/flows.d.ts +38 -0
  249. package/dist/src/ui/tui/flows.js +82 -0
  250. package/dist/src/ui/tui/flows.js.map +1 -0
  251. package/dist/src/ui/tui/hooks/useStdoutDimensions.d.ts +9 -0
  252. package/dist/src/ui/tui/hooks/useStdoutDimensions.js +37 -0
  253. package/dist/src/ui/tui/hooks/useStdoutDimensions.js.map +1 -0
  254. package/dist/src/ui/tui/ink-ui.d.ts +50 -0
  255. package/dist/src/ui/tui/ink-ui.js +108 -0
  256. package/dist/src/ui/tui/ink-ui.js.map +1 -0
  257. package/dist/src/ui/tui/package.json +1 -0
  258. package/dist/src/ui/tui/playground/PlaygroundApp.d.ts +12 -0
  259. package/dist/src/ui/tui/playground/PlaygroundApp.js +32 -0
  260. package/dist/src/ui/tui/playground/PlaygroundApp.js.map +1 -0
  261. package/dist/src/ui/tui/playground/demos/InputDemo.d.ts +4 -0
  262. package/dist/src/ui/tui/playground/demos/InputDemo.js +53 -0
  263. package/dist/src/ui/tui/playground/demos/InputDemo.js.map +1 -0
  264. package/dist/src/ui/tui/playground/demos/LayoutDemo.d.ts +5 -0
  265. package/dist/src/ui/tui/playground/demos/LayoutDemo.js +25 -0
  266. package/dist/src/ui/tui/playground/demos/LayoutDemo.js.map +1 -0
  267. package/dist/src/ui/tui/playground/demos/LogDemo.d.ts +5 -0
  268. package/dist/src/ui/tui/playground/demos/LogDemo.js +53 -0
  269. package/dist/src/ui/tui/playground/demos/LogDemo.js.map +1 -0
  270. package/dist/src/ui/tui/playground/demos/ProgressDemo.d.ts +5 -0
  271. package/dist/src/ui/tui/playground/demos/ProgressDemo.js +58 -0
  272. package/dist/src/ui/tui/playground/demos/ProgressDemo.js.map +1 -0
  273. package/dist/src/ui/tui/playground/demos/RunScreenDemo.d.ts +11 -0
  274. package/dist/src/ui/tui/playground/demos/RunScreenDemo.js +159 -0
  275. package/dist/src/ui/tui/playground/demos/RunScreenDemo.js.map +1 -0
  276. package/dist/src/ui/tui/playground/demos/WelcomeDemo.d.ts +9 -0
  277. package/dist/src/ui/tui/playground/demos/WelcomeDemo.js +15 -0
  278. package/dist/src/ui/tui/playground/demos/WelcomeDemo.js.map +1 -0
  279. package/dist/src/ui/tui/playground/start-playground.d.ts +4 -0
  280. package/dist/src/ui/tui/playground/start-playground.js +24 -0
  281. package/dist/src/ui/tui/playground/start-playground.js.map +1 -0
  282. package/dist/src/ui/tui/primitives/CardLayout.d.ts +12 -0
  283. package/dist/src/ui/tui/primitives/CardLayout.js +10 -0
  284. package/dist/src/ui/tui/primitives/CardLayout.js.map +1 -0
  285. package/dist/src/ui/tui/primitives/ConfirmationInput.d.ts +13 -0
  286. package/dist/src/ui/tui/primitives/ConfirmationInput.js +35 -0
  287. package/dist/src/ui/tui/primitives/ConfirmationInput.js.map +1 -0
  288. package/dist/src/ui/tui/primitives/ContentSequencer.d.ts +42 -0
  289. package/dist/src/ui/tui/primitives/ContentSequencer.js +137 -0
  290. package/dist/src/ui/tui/primitives/ContentSequencer.js.map +1 -0
  291. package/dist/src/ui/tui/primitives/DissolveTransition.d.ts +21 -0
  292. package/dist/src/ui/tui/primitives/DissolveTransition.js +149 -0
  293. package/dist/src/ui/tui/primitives/DissolveTransition.js.map +1 -0
  294. package/dist/src/ui/tui/primitives/EventPlanViewer.d.ts +9 -0
  295. package/dist/src/ui/tui/primitives/EventPlanViewer.js +9 -0
  296. package/dist/src/ui/tui/primitives/EventPlanViewer.js.map +1 -0
  297. package/dist/src/ui/tui/primitives/HNViewer.d.ts +7 -0
  298. package/dist/src/ui/tui/primitives/HNViewer.js +63 -0
  299. package/dist/src/ui/tui/primitives/HNViewer.js.map +1 -0
  300. package/dist/src/ui/tui/primitives/LinesBlock.d.ts +16 -0
  301. package/dist/src/ui/tui/primitives/LinesBlock.js +37 -0
  302. package/dist/src/ui/tui/primitives/LinesBlock.js.map +1 -0
  303. package/dist/src/ui/tui/primitives/LoadingBox.d.ts +8 -0
  304. package/dist/src/ui/tui/primitives/LoadingBox.js +10 -0
  305. package/dist/src/ui/tui/primitives/LoadingBox.js.map +1 -0
  306. package/dist/src/ui/tui/primitives/LogViewer.d.ts +11 -0
  307. package/dist/src/ui/tui/primitives/LogViewer.js +55 -0
  308. package/dist/src/ui/tui/primitives/LogViewer.js.map +1 -0
  309. package/dist/src/ui/tui/primitives/NodeBlock.d.ts +13 -0
  310. package/dist/src/ui/tui/primitives/NodeBlock.js +17 -0
  311. package/dist/src/ui/tui/primitives/NodeBlock.js.map +1 -0
  312. package/dist/src/ui/tui/primitives/PickerMenu.d.ts +20 -0
  313. package/dist/src/ui/tui/primitives/PickerMenu.js +134 -0
  314. package/dist/src/ui/tui/primitives/PickerMenu.js.map +1 -0
  315. package/dist/src/ui/tui/primitives/ProgressList.d.ts +15 -0
  316. package/dist/src/ui/tui/primitives/ProgressList.js +30 -0
  317. package/dist/src/ui/tui/primitives/ProgressList.js.map +1 -0
  318. package/dist/src/ui/tui/primitives/PromptLabel.d.ts +11 -0
  319. package/dist/src/ui/tui/primitives/PromptLabel.js +13 -0
  320. package/dist/src/ui/tui/primitives/PromptLabel.js.map +1 -0
  321. package/dist/src/ui/tui/primitives/ScreenContainer.d.ts +16 -0
  322. package/dist/src/ui/tui/primitives/ScreenContainer.js +36 -0
  323. package/dist/src/ui/tui/primitives/ScreenContainer.js.map +1 -0
  324. package/dist/src/ui/tui/primitives/ScreenErrorBoundary.d.ts +22 -0
  325. package/dist/src/ui/tui/primitives/ScreenErrorBoundary.js +35 -0
  326. package/dist/src/ui/tui/primitives/ScreenErrorBoundary.js.map +1 -0
  327. package/dist/src/ui/tui/primitives/SplitView.d.ts +11 -0
  328. package/dist/src/ui/tui/primitives/SplitView.js +9 -0
  329. package/dist/src/ui/tui/primitives/SplitView.js.map +1 -0
  330. package/dist/src/ui/tui/primitives/TabContainer.d.ts +23 -0
  331. package/dist/src/ui/tui/primitives/TabContainer.js +45 -0
  332. package/dist/src/ui/tui/primitives/TabContainer.js.map +1 -0
  333. package/dist/src/ui/tui/primitives/TextBlock.d.ts +41 -0
  334. package/dist/src/ui/tui/primitives/TextBlock.js +144 -0
  335. package/dist/src/ui/tui/primitives/TextBlock.js.map +1 -0
  336. package/dist/src/ui/tui/primitives/content-types.d.ts +37 -0
  337. package/dist/src/ui/tui/primitives/content-types.js +19 -0
  338. package/dist/src/ui/tui/primitives/content-types.js.map +1 -0
  339. package/dist/src/ui/tui/primitives/index.d.ts +24 -0
  340. package/dist/src/ui/tui/primitives/index.js +21 -0
  341. package/dist/src/ui/tui/primitives/index.js.map +1 -0
  342. package/dist/src/ui/tui/primitives/layout-helpers.d.ts +36 -0
  343. package/dist/src/ui/tui/primitives/layout-helpers.js +95 -0
  344. package/dist/src/ui/tui/primitives/layout-helpers.js.map +1 -0
  345. package/dist/src/ui/tui/primitives/text-helpers.d.ts +10 -0
  346. package/dist/src/ui/tui/primitives/text-helpers.js +43 -0
  347. package/dist/src/ui/tui/primitives/text-helpers.js.map +1 -0
  348. package/dist/src/ui/tui/router.d.ts +56 -0
  349. package/dist/src/ui/tui/router.js +94 -0
  350. package/dist/src/ui/tui/router.js.map +1 -0
  351. package/dist/src/ui/tui/screen-registry.d.ts +19 -0
  352. package/dist/src/ui/tui/screen-registry.js +34 -0
  353. package/dist/src/ui/tui/screen-registry.js.map +1 -0
  354. package/dist/src/ui/tui/screens/AuthScreen.d.ts +13 -0
  355. package/dist/src/ui/tui/screens/AuthScreen.js +20 -0
  356. package/dist/src/ui/tui/screens/AuthScreen.js.map +1 -0
  357. package/dist/src/ui/tui/screens/IntroScreen.d.ts +16 -0
  358. package/dist/src/ui/tui/screens/IntroScreen.js +63 -0
  359. package/dist/src/ui/tui/screens/IntroScreen.js.map +1 -0
  360. package/dist/src/ui/tui/screens/McpScreen.d.ts +24 -0
  361. package/dist/src/ui/tui/screens/McpScreen.js +112 -0
  362. package/dist/src/ui/tui/screens/McpScreen.js.map +1 -0
  363. package/dist/src/ui/tui/screens/OutageScreen.d.ts +10 -0
  364. package/dist/src/ui/tui/screens/OutageScreen.js +17 -0
  365. package/dist/src/ui/tui/screens/OutageScreen.js.map +1 -0
  366. package/dist/src/ui/tui/screens/OutroScreen.d.ts +11 -0
  367. package/dist/src/ui/tui/screens/OutroScreen.js +22 -0
  368. package/dist/src/ui/tui/screens/OutroScreen.js.map +1 -0
  369. package/dist/src/ui/tui/screens/RunScreen.d.ts +16 -0
  370. package/dist/src/ui/tui/screens/RunScreen.js +73 -0
  371. package/dist/src/ui/tui/screens/RunScreen.js.map +1 -0
  372. package/dist/src/ui/tui/screens/SettingsOverrideScreen.d.ts +10 -0
  373. package/dist/src/ui/tui/screens/SettingsOverrideScreen.js +24 -0
  374. package/dist/src/ui/tui/screens/SettingsOverrideScreen.js.map +1 -0
  375. package/dist/src/ui/tui/screens/SetupScreen.d.ts +13 -0
  376. package/dist/src/ui/tui/screens/SetupScreen.js +74 -0
  377. package/dist/src/ui/tui/screens/SetupScreen.js.map +1 -0
  378. package/dist/src/ui/tui/services/mcp-installer.d.ts +21 -0
  379. package/dist/src/ui/tui/services/mcp-installer.js +58 -0
  380. package/dist/src/ui/tui/services/mcp-installer.js.map +1 -0
  381. package/dist/src/ui/tui/start-tui.d.ts +9 -0
  382. package/dist/src/ui/tui/start-tui.js +41 -0
  383. package/dist/src/ui/tui/start-tui.js.map +1 -0
  384. package/dist/src/ui/tui/store.d.ts +132 -0
  385. package/dist/src/ui/tui/store.js +320 -0
  386. package/dist/src/ui/tui/store.js.map +1 -0
  387. package/dist/src/ui/tui/styles.d.ts +31 -0
  388. package/dist/src/ui/tui/styles.js +34 -0
  389. package/dist/src/ui/tui/styles.js.map +1 -0
  390. package/dist/src/ui/wizard-ui.d.ts +64 -0
  391. package/dist/src/ui/wizard-ui.js +19 -0
  392. package/dist/src/ui/wizard-ui.js.map +1 -0
  393. package/dist/src/utils/__tests__/setup-utils.test.d.ts +1 -0
  394. package/dist/src/utils/__tests__/{clack-utils.test.js → setup-utils.test.js} +31 -22
  395. package/dist/src/utils/__tests__/setup-utils.test.js.map +1 -0
  396. package/dist/src/utils/analytics.d.ts +18 -0
  397. package/dist/src/utils/analytics.js +53 -0
  398. package/dist/src/utils/analytics.js.map +1 -1
  399. package/dist/src/utils/anthropic-status.d.ts +1 -12
  400. package/dist/src/utils/anthropic-status.js +4 -56
  401. package/dist/src/utils/anthropic-status.js.map +1 -1
  402. package/dist/src/utils/custom-headers.d.ts +9 -0
  403. package/dist/src/utils/custom-headers.js +24 -0
  404. package/dist/src/utils/custom-headers.js.map +1 -0
  405. package/dist/src/utils/debug.js +2 -2
  406. package/dist/src/utils/debug.js.map +1 -1
  407. package/dist/src/utils/environment.js +4 -2
  408. package/dist/src/utils/environment.js.map +1 -1
  409. package/dist/src/utils/oauth.d.ts +0 -2
  410. package/dist/src/utils/oauth.js +18 -21
  411. package/dist/src/utils/oauth.js.map +1 -1
  412. package/dist/src/utils/package-manager.js +13 -13
  413. package/dist/src/utils/package-manager.js.map +1 -1
  414. package/dist/src/utils/setup-utils.d.ts +76 -0
  415. package/dist/src/utils/setup-utils.js +364 -0
  416. package/dist/src/utils/setup-utils.js.map +1 -0
  417. package/dist/src/utils/types.d.ts +0 -4
  418. package/dist/src/utils/types.js.map +1 -1
  419. package/dist/src/utils/urls.d.ts +1 -1
  420. package/dist/src/utils/urls.js +22 -9
  421. package/dist/src/utils/urls.js.map +1 -1
  422. package/dist/src/utils/wizard-abort.d.ts +13 -0
  423. package/dist/src/utils/wizard-abort.js +57 -0
  424. package/dist/src/utils/wizard-abort.js.map +1 -0
  425. package/package.json +19 -7
  426. package/dist/src/android/android-wizard-agent.js.map +0 -1
  427. package/dist/src/android/utils.js.map +0 -1
  428. package/dist/src/angular/angular-wizard-agent.js.map +0 -1
  429. package/dist/src/angular/utils.js.map +0 -1
  430. package/dist/src/astro/astro-wizard-agent.js.map +0 -1
  431. package/dist/src/astro/utils.js.map +0 -1
  432. package/dist/src/django/django-wizard-agent.js.map +0 -1
  433. package/dist/src/django/utils.js.map +0 -1
  434. package/dist/src/fastapi/fastapi-wizard-agent.d.ts +0 -7
  435. package/dist/src/fastapi/fastapi-wizard-agent.js.map +0 -1
  436. package/dist/src/fastapi/utils.js.map +0 -1
  437. package/dist/src/flask/flask-wizard-agent.js.map +0 -1
  438. package/dist/src/flask/utils.js.map +0 -1
  439. package/dist/src/javascript-node/javascript-node-wizard-agent.js.map +0 -1
  440. package/dist/src/javascript-web/javascript-web-wizard-agent.js.map +0 -1
  441. package/dist/src/javascript-web/utils.js.map +0 -1
  442. package/dist/src/laravel/laravel-wizard-agent.js.map +0 -1
  443. package/dist/src/laravel/utils.js.map +0 -1
  444. package/dist/src/mcp.d.ts +0 -10
  445. package/dist/src/mcp.js +0 -45
  446. package/dist/src/mcp.js.map +0 -1
  447. package/dist/src/nextjs/nextjs-wizard-agent.js.map +0 -1
  448. package/dist/src/nextjs/utils.js.map +0 -1
  449. package/dist/src/nuxt/nuxt-wizard-agent.js.map +0 -1
  450. package/dist/src/python/python-wizard-agent.js.map +0 -1
  451. package/dist/src/python/utils.js.map +0 -1
  452. package/dist/src/rails/rails-wizard-agent.js.map +0 -1
  453. package/dist/src/rails/utils.js.map +0 -1
  454. package/dist/src/react-native/react-native-wizard-agent.js.map +0 -1
  455. package/dist/src/react-native/utils.js.map +0 -1
  456. package/dist/src/react-router/react-router-wizard-agent.js.map +0 -1
  457. package/dist/src/react-router/utils.d.ts +0 -19
  458. package/dist/src/react-router/utils.js.map +0 -1
  459. package/dist/src/ruby/ruby-wizard-agent.js.map +0 -1
  460. package/dist/src/ruby/utils.js.map +0 -1
  461. package/dist/src/steps/__tests__/add-editor-rules.test.js +0 -208
  462. package/dist/src/steps/__tests__/add-editor-rules.test.js.map +0 -1
  463. package/dist/src/steps/add-editor-rules.d.ts +0 -8
  464. package/dist/src/steps/add-editor-rules.js +0 -71
  465. package/dist/src/steps/add-editor-rules.js.map +0 -1
  466. package/dist/src/svelte/svelte-wizard-agent.js.map +0 -1
  467. package/dist/src/swift/swift-wizard-agent.js.map +0 -1
  468. package/dist/src/swift/utils.js.map +0 -1
  469. package/dist/src/tanstack-router/tanstack-router-wizard-agent.js.map +0 -1
  470. package/dist/src/tanstack-router/utils.d.ts +0 -17
  471. package/dist/src/tanstack-router/utils.js.map +0 -1
  472. package/dist/src/tanstack-start/tanstack-start-wizard-agent.js.map +0 -1
  473. package/dist/src/tanstack-start/utils.js.map +0 -1
  474. package/dist/src/utils/__tests__/clack-utils.test.js.map +0 -1
  475. package/dist/src/utils/clack-utils.d.ts +0 -190
  476. package/dist/src/utils/clack-utils.js +0 -728
  477. package/dist/src/utils/clack-utils.js.map +0 -1
  478. package/dist/src/utils/clack.d.ts +0 -2
  479. package/dist/src/utils/clack.js +0 -9
  480. package/dist/src/utils/clack.js.map +0 -1
  481. package/dist/src/vue/vue-wizard-agent.js.map +0 -1
  482. /package/dist/src/{steps/__tests__/add-editor-rules.test.d.ts → __tests__/wizard-abort.test.d.ts} +0 -0
  483. /package/dist/src/{angular → frameworks/angular}/utils.d.ts +0 -0
  484. /package/dist/src/{python → frameworks/python}/utils.js +0 -0
  485. /package/dist/src/{swift → frameworks/swift}/utils.js +0 -0
  486. /package/dist/src/{tanstack-start → frameworks/tanstack-start}/utils.d.ts +0 -0
  487. /package/dist/src/{utils/__tests__/clack-utils.test.d.ts → ui/tui/__tests__/layout-helpers.test.d.ts} +0 -0
@@ -1,208 +0,0 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
- Object.defineProperty(o, "default", { enumerable: true, value: v });
15
- }) : function(o, v) {
16
- o["default"] = v;
17
- });
18
- var __importStar = (this && this.__importStar) || (function () {
19
- var ownKeys = function(o) {
20
- ownKeys = Object.getOwnPropertyNames || function (o) {
21
- var ar = [];
22
- for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
- return ar;
24
- };
25
- return ownKeys(o);
26
- };
27
- return function (mod) {
28
- if (mod && mod.__esModule) return mod;
29
- var result = {};
30
- if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
- __setModuleDefault(result, mod);
32
- return result;
33
- };
34
- })();
35
- var __importDefault = (this && this.__importDefault) || function (mod) {
36
- return (mod && mod.__esModule) ? mod : { "default": mod };
37
- };
38
- Object.defineProperty(exports, "__esModule", { value: true });
39
- const fs = __importStar(require("fs"));
40
- const path_1 = __importDefault(require("path"));
41
- const add_editor_rules_1 = require("../add-editor-rules");
42
- const analytics_1 = require("../../utils/analytics");
43
- const clack_1 = __importDefault(require("../../utils/clack"));
44
- const chalk_1 = __importDefault(require("chalk"));
45
- // Mock dependencies
46
- jest.mock('fs', () => ({
47
- promises: {
48
- mkdir: jest.fn(),
49
- readFile: jest.fn(),
50
- writeFile: jest.fn(),
51
- },
52
- }));
53
- jest.mock('../../utils/analytics', () => ({
54
- analytics: {
55
- capture: jest.fn(),
56
- setTag: jest.fn(),
57
- shutdown: jest.fn().mockResolvedValue(undefined),
58
- },
59
- }));
60
- jest.mock('../../utils/clack', () => ({
61
- log: {
62
- info: jest.fn(),
63
- },
64
- select: jest.fn().mockResolvedValue(true),
65
- isCancel: jest.fn((value) => false),
66
- cancel: jest.fn(),
67
- }));
68
- describe('addEditorRules', () => {
69
- const mockOptions = {
70
- installDir: '/test/dir',
71
- rulesName: 'react-rules.md',
72
- integration: 'react',
73
- };
74
- const originalEnv = process.env;
75
- const mkdirMock = fs.promises.mkdir;
76
- const readFileMock = fs.promises.readFile;
77
- const writeFileMock = fs.promises.writeFile;
78
- // eslint-disable-next-line @typescript-eslint/unbound-method
79
- const captureMock = analytics_1.analytics.capture;
80
- const infoMock = clack_1.default.log.info;
81
- const selectMock = clack_1.default.select;
82
- const isCancelMock = clack_1.default.isCancel;
83
- const cancelMock = clack_1.default.cancel;
84
- beforeEach(() => {
85
- // Reset all mocks before each test
86
- jest.clearAllMocks();
87
- // Clear mock implementations
88
- fs.promises.mkdir.mockReset();
89
- fs.promises.readFile.mockReset();
90
- fs.promises.writeFile.mockReset();
91
- selectMock.mockReset();
92
- selectMock.mockResolvedValue(true); // Default to "Yes" for the prompt
93
- isCancelMock.mockReset();
94
- isCancelMock.mockReturnValue(false);
95
- cancelMock.mockReset();
96
- process.env = { ...originalEnv };
97
- });
98
- afterAll(() => {
99
- process.env = originalEnv;
100
- });
101
- it('should not install rules when CURSOR_TRACE_ID is not set', async () => {
102
- delete process.env.CURSOR_TRACE_ID;
103
- await (0, add_editor_rules_1.addEditorRulesStep)(mockOptions);
104
- expect(mkdirMock).not.toHaveBeenCalled();
105
- expect(readFileMock).not.toHaveBeenCalled();
106
- expect(writeFileMock).not.toHaveBeenCalled();
107
- expect(captureMock).not.toHaveBeenCalled();
108
- expect(infoMock).not.toHaveBeenCalled();
109
- });
110
- it('should install rules when CURSOR_TRACE_ID is set', async () => {
111
- process.env.CURSOR_TRACE_ID = 'test-trace-id';
112
- const mockFrameworkRules = 'framework rules {universal} content';
113
- const mockUniversalRules = 'universal rules content';
114
- const expectedCombinedRules = 'framework rules universal rules content content';
115
- fs.promises.readFile
116
- .mockImplementationOnce(() => Promise.resolve(mockFrameworkRules))
117
- .mockImplementationOnce(() => Promise.resolve(mockUniversalRules));
118
- await (0, add_editor_rules_1.addEditorRulesStep)(mockOptions);
119
- // Check if directory was created
120
- expect(mkdirMock).toHaveBeenCalledWith(path_1.default.join('/test/dir', '.cursor', 'rules'), { recursive: true });
121
- // Check if correct files were read
122
- expect(readFileMock).toHaveBeenCalledTimes(2);
123
- expect(readFileMock).toHaveBeenNthCalledWith(1, expect.stringMatching(/react-rules\.md$/), 'utf8');
124
- expect(readFileMock).toHaveBeenNthCalledWith(2, expect.stringMatching(/universal\.md$/), 'utf8');
125
- // Check if combined rules were written correctly
126
- expect(writeFileMock).toHaveBeenCalledWith(path_1.default.join('/test/dir', '.cursor', 'rules', 'posthog-integration.mdc'), expectedCombinedRules, 'utf8');
127
- // Check if analytics were captured
128
- expect(captureMock).toHaveBeenCalledWith('wizard interaction', {
129
- action: 'added editor rules',
130
- integration: mockOptions.integration,
131
- });
132
- // Check if success message was logged
133
- expect(infoMock).toHaveBeenCalledWith(`Added Cursor rules to ${chalk_1.default.bold.cyan('.cursor/rules/posthog-integration.mdc')}`);
134
- });
135
- it('should handle file system errors gracefully', async () => {
136
- process.env.CURSOR_TRACE_ID = 'test-trace-id';
137
- const mockError = new Error('File not found');
138
- // Mock readFile to throw an error
139
- fs.promises.readFile.mockRejectedValue(mockError);
140
- await expect((0, add_editor_rules_1.addEditorRulesStep)(mockOptions)).rejects.toThrow(mockError);
141
- expect(writeFileMock).not.toHaveBeenCalled();
142
- expect(captureMock).not.toHaveBeenCalled();
143
- expect(infoMock).not.toHaveBeenCalled();
144
- });
145
- it('should handle missing rules files gracefully', async () => {
146
- process.env.CURSOR_TRACE_ID = 'test-trace-id';
147
- const mockError = new Error('File system error');
148
- // Mock mkdir to throw an error
149
- fs.promises.mkdir.mockRejectedValue(mockError);
150
- await expect((0, add_editor_rules_1.addEditorRulesStep)(mockOptions)).rejects.toThrow(mockError);
151
- expect(writeFileMock).not.toHaveBeenCalled();
152
- expect(captureMock).not.toHaveBeenCalled();
153
- expect(infoMock).not.toHaveBeenCalled();
154
- });
155
- it('should correctly substitute universal rules with realistic content', async () => {
156
- process.env.CURSOR_TRACE_ID = 'test-trace-id';
157
- const mockFrameworkRules = `---
158
- description: apply when interacting with PostHog/analytics tasks
159
- globs:
160
- alwaysApply: true
161
- ---
162
-
163
- {universal}
164
-
165
- # Framework-specific rules
166
- - Rule 1
167
- - Rule 2`;
168
- const mockUniversalRules = `Never hallucinate an API key. Instead, always use the API key populated in the .env file.
169
-
170
- # Feature flags
171
-
172
- A given feature flag should be used in as few places as possible. Do not increase the risk of undefined behavior by scattering the same feature flag across multiple areas of code.`;
173
- const expectedCombinedRules = `---
174
- description: apply when interacting with PostHog/analytics tasks
175
- globs:
176
- alwaysApply: true
177
- ---
178
-
179
- Never hallucinate an API key. Instead, always use the API key populated in the .env file.
180
-
181
- # Feature flags
182
-
183
- A given feature flag should be used in as few places as possible. Do not increase the risk of undefined behavior by scattering the same feature flag across multiple areas of code.
184
-
185
- # Framework-specific rules
186
- - Rule 1
187
- - Rule 2`;
188
- fs.promises.readFile
189
- .mockImplementationOnce(() => Promise.resolve(mockFrameworkRules))
190
- .mockImplementationOnce(() => Promise.resolve(mockUniversalRules));
191
- await (0, add_editor_rules_1.addEditorRulesStep)(mockOptions);
192
- // Check if directory was created
193
- expect(mkdirMock).toHaveBeenCalledWith(path_1.default.join('/test/dir', '.cursor', 'rules'), { recursive: true });
194
- // Check if correct files were read
195
- expect(readFileMock).toHaveBeenCalledWith(expect.stringMatching(/react-rules\.md$/), 'utf8');
196
- expect(readFileMock).toHaveBeenCalledWith(expect.stringMatching(/universal\.md$/), 'utf8');
197
- // Check if combined rules were written correctly
198
- expect(writeFileMock).toHaveBeenCalledWith(path_1.default.join('/test/dir', '.cursor', 'rules', 'posthog-integration.mdc'), expectedCombinedRules, 'utf8');
199
- // Check if analytics were captured
200
- expect(captureMock).toHaveBeenCalledWith('wizard interaction', {
201
- action: 'added editor rules',
202
- integration: mockOptions.integration,
203
- });
204
- // Check if success message was logged
205
- expect(infoMock).toHaveBeenCalledWith(`Added Cursor rules to ${chalk_1.default.bold.cyan('.cursor/rules/posthog-integration.mdc')}`);
206
- });
207
- });
208
- //# sourceMappingURL=add-editor-rules.test.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"add-editor-rules.test.js","sourceRoot":"","sources":["../../../../src/steps/__tests__/add-editor-rules.test.ts"],"names":[],"mappings":"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","sourcesContent":["import * as fs from 'fs';\nimport path from 'path';\nimport { addEditorRulesStep } from '../add-editor-rules';\nimport { analytics } from '../../utils/analytics';\nimport clack from '../../utils/clack';\nimport { Integration } from '../../lib/constants';\nimport chalk from 'chalk';\n\n// Mock dependencies\njest.mock('fs', () => ({\n promises: {\n mkdir: jest.fn(),\n readFile: jest.fn(),\n writeFile: jest.fn(),\n },\n}));\n\njest.mock('../../utils/analytics', () => ({\n analytics: {\n capture: jest.fn(),\n setTag: jest.fn(),\n shutdown: jest.fn().mockResolvedValue(undefined),\n },\n}));\n\njest.mock('../../utils/clack', () => ({\n log: {\n info: jest.fn(),\n },\n select: jest.fn().mockResolvedValue(true),\n isCancel: jest.fn((value: unknown): value is symbol => false),\n cancel: jest.fn(),\n}));\n\ndescribe('addEditorRules', () => {\n const mockOptions = {\n installDir: '/test/dir',\n rulesName: 'react-rules.md',\n integration: 'react' as Integration,\n };\n\n const originalEnv = process.env;\n const mkdirMock = fs.promises.mkdir as jest.Mock;\n const readFileMock = fs.promises.readFile as jest.Mock;\n const writeFileMock = fs.promises.writeFile as jest.Mock;\n // eslint-disable-next-line @typescript-eslint/unbound-method\n const captureMock = analytics.capture as jest.Mock;\n const infoMock = clack.log.info as jest.Mock;\n const selectMock = clack.select as jest.Mock;\n const isCancelMock = clack.isCancel as unknown as jest.Mock;\n const cancelMock = clack.cancel as jest.Mock;\n\n beforeEach(() => {\n // Reset all mocks before each test\n jest.clearAllMocks();\n // Clear mock implementations\n (fs.promises.mkdir as jest.Mock).mockReset();\n (fs.promises.readFile as jest.Mock).mockReset();\n (fs.promises.writeFile as jest.Mock).mockReset();\n selectMock.mockReset();\n selectMock.mockResolvedValue(true); // Default to \"Yes\" for the prompt\n isCancelMock.mockReset();\n isCancelMock.mockReturnValue(false);\n cancelMock.mockReset();\n process.env = { ...originalEnv };\n });\n\n afterAll(() => {\n process.env = originalEnv;\n });\n\n it('should not install rules when CURSOR_TRACE_ID is not set', async () => {\n delete process.env.CURSOR_TRACE_ID;\n\n await addEditorRulesStep(mockOptions);\n\n expect(mkdirMock).not.toHaveBeenCalled();\n expect(readFileMock).not.toHaveBeenCalled();\n expect(writeFileMock).not.toHaveBeenCalled();\n expect(captureMock).not.toHaveBeenCalled();\n expect(infoMock).not.toHaveBeenCalled();\n });\n\n it('should install rules when CURSOR_TRACE_ID is set', async () => {\n process.env.CURSOR_TRACE_ID = 'test-trace-id';\n\n const mockFrameworkRules = 'framework rules {universal} content';\n const mockUniversalRules = 'universal rules content';\n const expectedCombinedRules =\n 'framework rules universal rules content content';\n\n (fs.promises.readFile as jest.Mock)\n .mockImplementationOnce(() => Promise.resolve(mockFrameworkRules))\n .mockImplementationOnce(() => Promise.resolve(mockUniversalRules));\n\n await addEditorRulesStep(mockOptions);\n\n // Check if directory was created\n expect(mkdirMock).toHaveBeenCalledWith(\n path.join('/test/dir', '.cursor', 'rules'),\n { recursive: true },\n );\n\n // Check if correct files were read\n expect(readFileMock).toHaveBeenCalledTimes(2);\n expect(readFileMock).toHaveBeenNthCalledWith(\n 1,\n expect.stringMatching(/react-rules\\.md$/),\n 'utf8',\n );\n expect(readFileMock).toHaveBeenNthCalledWith(\n 2,\n expect.stringMatching(/universal\\.md$/),\n 'utf8',\n );\n\n // Check if combined rules were written correctly\n expect(writeFileMock).toHaveBeenCalledWith(\n path.join('/test/dir', '.cursor', 'rules', 'posthog-integration.mdc'),\n expectedCombinedRules,\n 'utf8',\n );\n\n // Check if analytics were captured\n expect(captureMock).toHaveBeenCalledWith('wizard interaction', {\n action: 'added editor rules',\n integration: mockOptions.integration,\n });\n\n // Check if success message was logged\n expect(infoMock).toHaveBeenCalledWith(\n `Added Cursor rules to ${chalk.bold.cyan(\n '.cursor/rules/posthog-integration.mdc',\n )}`,\n );\n });\n\n it('should handle file system errors gracefully', async () => {\n process.env.CURSOR_TRACE_ID = 'test-trace-id';\n const mockError = new Error('File not found');\n\n // Mock readFile to throw an error\n (fs.promises.readFile as jest.Mock).mockRejectedValue(mockError);\n\n await expect(addEditorRulesStep(mockOptions)).rejects.toThrow(mockError);\n\n expect(writeFileMock).not.toHaveBeenCalled();\n expect(captureMock).not.toHaveBeenCalled();\n expect(infoMock).not.toHaveBeenCalled();\n });\n\n it('should handle missing rules files gracefully', async () => {\n process.env.CURSOR_TRACE_ID = 'test-trace-id';\n const mockError = new Error('File system error');\n\n // Mock mkdir to throw an error\n (fs.promises.mkdir as jest.Mock).mockRejectedValue(mockError);\n\n await expect(addEditorRulesStep(mockOptions)).rejects.toThrow(mockError);\n\n expect(writeFileMock).not.toHaveBeenCalled();\n expect(captureMock).not.toHaveBeenCalled();\n expect(infoMock).not.toHaveBeenCalled();\n });\n\n it('should correctly substitute universal rules with realistic content', async () => {\n process.env.CURSOR_TRACE_ID = 'test-trace-id';\n\n const mockFrameworkRules = `---\ndescription: apply when interacting with PostHog/analytics tasks\nglobs: \nalwaysApply: true\n---\n\n{universal}\n\n# Framework-specific rules\n- Rule 1\n- Rule 2`;\n\n const mockUniversalRules = `Never hallucinate an API key. Instead, always use the API key populated in the .env file.\n\n# Feature flags\n\nA given feature flag should be used in as few places as possible. Do not increase the risk of undefined behavior by scattering the same feature flag across multiple areas of code.`;\n\n const expectedCombinedRules = `---\ndescription: apply when interacting with PostHog/analytics tasks\nglobs: \nalwaysApply: true\n---\n\nNever hallucinate an API key. Instead, always use the API key populated in the .env file.\n\n# Feature flags\n\nA given feature flag should be used in as few places as possible. Do not increase the risk of undefined behavior by scattering the same feature flag across multiple areas of code.\n\n# Framework-specific rules\n- Rule 1\n- Rule 2`;\n\n (fs.promises.readFile as jest.Mock)\n .mockImplementationOnce(() => Promise.resolve(mockFrameworkRules))\n .mockImplementationOnce(() => Promise.resolve(mockUniversalRules));\n\n await addEditorRulesStep(mockOptions);\n\n // Check if directory was created\n expect(mkdirMock).toHaveBeenCalledWith(\n path.join('/test/dir', '.cursor', 'rules'),\n { recursive: true },\n );\n\n // Check if correct files were read\n expect(readFileMock).toHaveBeenCalledWith(\n expect.stringMatching(/react-rules\\.md$/),\n 'utf8',\n );\n expect(readFileMock).toHaveBeenCalledWith(\n expect.stringMatching(/universal\\.md$/),\n 'utf8',\n );\n\n // Check if combined rules were written correctly\n expect(writeFileMock).toHaveBeenCalledWith(\n path.join('/test/dir', '.cursor', 'rules', 'posthog-integration.mdc'),\n expectedCombinedRules,\n 'utf8',\n );\n\n // Check if analytics were captured\n expect(captureMock).toHaveBeenCalledWith('wizard interaction', {\n action: 'added editor rules',\n integration: mockOptions.integration,\n });\n\n // Check if success message was logged\n expect(infoMock).toHaveBeenCalledWith(\n `Added Cursor rules to ${chalk.bold.cyan(\n '.cursor/rules/posthog-integration.mdc',\n )}`,\n );\n });\n});\n"]}
@@ -1,8 +0,0 @@
1
- import { Integration } from '../lib/constants';
2
- type AddEditorRulesStepOptions = {
3
- installDir: string;
4
- rulesName: string;
5
- integration: Integration;
6
- };
7
- export declare const addEditorRulesStep: ({ installDir, rulesName, integration, }: AddEditorRulesStepOptions) => Promise<boolean>;
8
- export {};
@@ -1,71 +0,0 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = k;
4
- var desc = Object.getOwnPropertyDescriptor(m, k);
5
- if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
- desc = { enumerable: true, get: function() { return m[k]; } };
7
- }
8
- Object.defineProperty(o, k2, desc);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
- Object.defineProperty(o, "default", { enumerable: true, value: v });
15
- }) : function(o, v) {
16
- o["default"] = v;
17
- });
18
- var __importStar = (this && this.__importStar) || (function () {
19
- var ownKeys = function(o) {
20
- ownKeys = Object.getOwnPropertyNames || function (o) {
21
- var ar = [];
22
- for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
- return ar;
24
- };
25
- return ownKeys(o);
26
- };
27
- return function (mod) {
28
- if (mod && mod.__esModule) return mod;
29
- var result = {};
30
- if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
- __setModuleDefault(result, mod);
32
- return result;
33
- };
34
- })();
35
- var __importDefault = (this && this.__importDefault) || function (mod) {
36
- return (mod && mod.__esModule) ? mod : { "default": mod };
37
- };
38
- Object.defineProperty(exports, "__esModule", { value: true });
39
- exports.addEditorRulesStep = void 0;
40
- const fs = __importStar(require("fs"));
41
- const chalk_1 = __importDefault(require("chalk"));
42
- const path_1 = __importDefault(require("path"));
43
- const analytics_1 = require("../utils/analytics");
44
- const clack_1 = __importDefault(require("../utils/clack"));
45
- const telemetry_1 = require("../telemetry");
46
- const addEditorRulesStep = async ({ installDir, rulesName, integration, }) => {
47
- // Add rules file if in Cursor environment
48
- if (process.env.CURSOR_TRACE_ID) {
49
- return (0, telemetry_1.traceStep)('add-editor-rules', async () => {
50
- const docsDir = path_1.default.join(installDir, '.cursor', 'rules');
51
- await fs.promises.mkdir(docsDir, { recursive: true });
52
- const frameworkRules = await fs.promises.readFile(path_1.default.join(__dirname, '..', 'utils', 'rules', rulesName), 'utf8');
53
- const universalRulesPath = path_1.default.join(__dirname, '..', 'utils', 'rules', 'universal.md');
54
- const universalRules = await fs.promises.readFile(universalRulesPath, 'utf8');
55
- // Replace {universal} placeholder with universal rules content
56
- const combinedRules = frameworkRules.replace('{universal}', universalRules);
57
- const targetPath = path_1.default.join(docsDir, 'posthog-integration.mdc');
58
- // Write the combined rules
59
- await fs.promises.writeFile(targetPath, combinedRules, 'utf8');
60
- analytics_1.analytics.capture('wizard interaction', {
61
- action: 'added editor rules',
62
- integration,
63
- });
64
- clack_1.default.log.info(`Added Cursor rules to ${chalk_1.default.bold.cyan(`.cursor/rules/posthog-integration.mdc`)}`);
65
- return true;
66
- });
67
- }
68
- return false;
69
- };
70
- exports.addEditorRulesStep = addEditorRulesStep;
71
- //# sourceMappingURL=add-editor-rules.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"add-editor-rules.js","sourceRoot":"","sources":["../../../src/steps/add-editor-rules.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,uCAAyB;AACzB,kDAA0B;AAC1B,gDAAwB;AAExB,kDAA+C;AAC/C,2DAAmC;AACnC,4CAAyC;AAQlC,MAAM,kBAAkB,GAAG,KAAK,EAAE,EACvC,UAAU,EACV,SAAS,EACT,WAAW,GACe,EAAoB,EAAE;IAChD,0CAA0C;IAC1C,IAAI,OAAO,CAAC,GAAG,CAAC,eAAe,EAAE,CAAC;QAChC,OAAO,IAAA,qBAAS,EAAC,kBAAkB,EAAE,KAAK,IAAI,EAAE;YAC9C,MAAM,OAAO,GAAG,cAAI,CAAC,IAAI,CAAC,UAAU,EAAE,SAAS,EAAE,OAAO,CAAC,CAAC;YAE1D,MAAM,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC,OAAO,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;YAEtD,MAAM,cAAc,GAAG,MAAM,EAAE,CAAC,QAAQ,CAAC,QAAQ,CAC/C,cAAI,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,SAAS,CAAC,EACvD,MAAM,CACP,CAAC;YACF,MAAM,kBAAkB,GAAG,cAAI,CAAC,IAAI,CAClC,SAAS,EACT,IAAI,EACJ,OAAO,EACP,OAAO,EACP,cAAc,CACf,CAAC;YAEF,MAAM,cAAc,GAAG,MAAM,EAAE,CAAC,QAAQ,CAAC,QAAQ,CAC/C,kBAAkB,EAClB,MAAM,CACP,CAAC;YAEF,+DAA+D;YAC/D,MAAM,aAAa,GAAG,cAAc,CAAC,OAAO,CAC1C,aAAa,EACb,cAAc,CACf,CAAC;YACF,MAAM,UAAU,GAAG,cAAI,CAAC,IAAI,CAAC,OAAO,EAAE,yBAAyB,CAAC,CAAC;YAEjE,2BAA2B;YAC3B,MAAM,EAAE,CAAC,QAAQ,CAAC,SAAS,CAAC,UAAU,EAAE,aAAa,EAAE,MAAM,CAAC,CAAC;YAE/D,qBAAS,CAAC,OAAO,CAAC,oBAAoB,EAAE;gBACtC,MAAM,EAAE,oBAAoB;gBAC5B,WAAW;aACZ,CAAC,CAAC;YAEH,eAAK,CAAC,GAAG,CAAC,IAAI,CACZ,yBAAyB,eAAK,CAAC,IAAI,CAAC,IAAI,CACtC,uCAAuC,CACxC,EAAE,CACJ,CAAC;YAEF,OAAO,IAAI,CAAC;QACd,CAAC,CAAC,CAAC;IACL,CAAC;IAED,OAAO,KAAK,CAAC;AACf,CAAC,CAAC;AAvDW,QAAA,kBAAkB,sBAuD7B","sourcesContent":["import * as fs from 'fs';\nimport chalk from 'chalk';\nimport path from 'path';\nimport { Integration } from '../lib/constants';\nimport { analytics } from '../utils/analytics';\nimport clack from '../utils/clack';\nimport { traceStep } from '../telemetry';\n\ntype AddEditorRulesStepOptions = {\n installDir: string;\n rulesName: string;\n integration: Integration;\n};\n\nexport const addEditorRulesStep = async ({\n installDir,\n rulesName,\n integration,\n}: AddEditorRulesStepOptions): Promise<boolean> => {\n // Add rules file if in Cursor environment\n if (process.env.CURSOR_TRACE_ID) {\n return traceStep('add-editor-rules', async () => {\n const docsDir = path.join(installDir, '.cursor', 'rules');\n\n await fs.promises.mkdir(docsDir, { recursive: true });\n\n const frameworkRules = await fs.promises.readFile(\n path.join(__dirname, '..', 'utils', 'rules', rulesName),\n 'utf8',\n );\n const universalRulesPath = path.join(\n __dirname,\n '..',\n 'utils',\n 'rules',\n 'universal.md',\n );\n\n const universalRules = await fs.promises.readFile(\n universalRulesPath,\n 'utf8',\n );\n\n // Replace {universal} placeholder with universal rules content\n const combinedRules = frameworkRules.replace(\n '{universal}',\n universalRules,\n );\n const targetPath = path.join(docsDir, 'posthog-integration.mdc');\n\n // Write the combined rules\n await fs.promises.writeFile(targetPath, combinedRules, 'utf8');\n\n analytics.capture('wizard interaction', {\n action: 'added editor rules',\n integration,\n });\n\n clack.log.info(\n `Added Cursor rules to ${chalk.bold.cyan(\n `.cursor/rules/posthog-integration.mdc`,\n )}`,\n );\n\n return true;\n });\n }\n\n return false;\n};\n"]}
@@ -1 +0,0 @@
1
- {"version":3,"file":"svelte-wizard-agent.js","sourceRoot":"","sources":["../../../src/svelte/svelte-wizard-agent.ts"],"names":[],"mappings":";;;AAEA,gFAA6E;AAC7E,gDAA+C;AAC/C,wDAI+B;AAC/B,sDAAyD;AAI5C,QAAA,sBAAsB,GAAsC;IACvE,QAAQ,EAAE;QACR,IAAI,EAAE,WAAW;QACjB,WAAW,EAAE,uBAAW,CAAC,SAAS;QAClC,OAAO,EAAE,2CAA2C;QACpD,IAAI,EAAE,IAAI;QACV,oBAAoB,EAAE;YACpB,MAAM,EAAE,EAAE,GAAG,EAAE,4BAA4B,EAAE;SAC9C;KACF;IAED,SAAS,EAAE;QACT,WAAW,EAAE,eAAe;QAC5B,kBAAkB,EAAE,WAAW;QAC/B,UAAU,EAAE,CAAC,WAAoB,EAAE,EAAE,CACnC,IAAA,gCAAiB,EAAC,eAAe,EAAE,WAA6B,CAAC;QACnE,MAAM,EAAE,KAAK,EAAE,OAAO,EAAE,EAAE;YACxB,MAAM,WAAW,GAAG,MAAM,IAAA,+BAAiB,EAAC,OAAO,CAAC,CAAC;YACrD,OAAO,WAAW;gBAChB,CAAC,CAAC,IAAA,kCAAmB,EAAC,eAAe,EAAE,WAAW,CAAC;gBACnD,CAAC,CAAC,KAAK,CAAC;QACZ,CAAC;QACD,cAAc,EAAE,OAAO;QACvB,oBAAoB,EAAE,qDAAyB;KAChD;IAED,WAAW,EAAE;QACX,eAAe,EAAE,IAAI;QACrB,UAAU,EAAE,CAAC,MAAc,EAAE,IAAY,EAAE,EAAE,CAAC,CAAC;YAC7C,kBAAkB,EAAE,MAAM;YAC1B,mBAAmB,EAAE,IAAI;SAC1B,CAAC;KACH;IAED,SAAS,EAAE;QACT,OAAO,EAAE,GAAG,EAAE,CAAC,CAAC,EAAE,CAAC;KACpB;IAED,OAAO,EAAE;QACP,oBAAoB,EAClB,uLAAuL;QACzL,yBAAyB,EAAE,GAAG,EAAE,CAAC;YAC/B,0FAA0F;SAC3F;KACF;IAED,EAAE,EAAE;QACF,cAAc,EAAE,8BAA8B;QAC9C,wBAAwB,EAAE,CAAC;QAC3B,eAAe,EAAE,GAAG,EAAE,CAAC;YACrB,2CAA2C;YAC3C,6CAA6C;YAC7C,0CAA0C;SAC3C;QACD,iBAAiB,EAAE,GAAG,EAAE,CAAC;YACvB,wDAAwD;YACxD,qDAAqD;SACtD;KACF;CACF,CAAC","sourcesContent":["/* SvelteKit wizard using posthog-agent with PostHog MCP */\nimport type { FrameworkConfig } from '../lib/framework-config';\nimport { detectNodePackageManagers } from '../lib/package-manager-detection';\nimport { Integration } from '../lib/constants';\nimport {\n getPackageVersion,\n hasPackageInstalled,\n type PackageDotJson,\n} from '../utils/package-json';\nimport { tryGetPackageJson } from '../utils/clack-utils';\n\ntype SvelteKitContext = Record<string, unknown>;\n\nexport const SVELTEKIT_AGENT_CONFIG: FrameworkConfig<SvelteKitContext> = {\n metadata: {\n name: 'SvelteKit',\n integration: Integration.sveltekit,\n docsUrl: 'https://posthog.com/docs/libraries/svelte',\n beta: true,\n additionalMcpServers: {\n svelte: { url: 'https://mcp.svelte.dev/mcp' },\n },\n },\n\n detection: {\n packageName: '@sveltejs/kit',\n packageDisplayName: 'SvelteKit',\n getVersion: (packageJson: unknown) =>\n getPackageVersion('@sveltejs/kit', packageJson as PackageDotJson),\n detect: async (options) => {\n const packageJson = await tryGetPackageJson(options);\n return packageJson\n ? hasPackageInstalled('@sveltejs/kit', packageJson)\n : false;\n },\n minimumVersion: '2.0.0',\n detectPackageManager: detectNodePackageManagers,\n },\n\n environment: {\n uploadToHosting: true,\n getEnvVars: (apiKey: string, host: string) => ({\n PUBLIC_POSTHOG_KEY: apiKey,\n PUBLIC_POSTHOG_HOST: host,\n }),\n },\n\n analytics: {\n getTags: () => ({}),\n },\n\n prompts: {\n projectTypeDetection:\n 'This is a JavaScript/TypeScript project using SvelteKit. Look for package.json, svelte.config.js, and lockfiles (package-lock.json, yarn.lock, pnpm-lock.yaml, bun.lockb) to confirm.',\n getAdditionalContextLines: () => [\n 'Framework docs ID: sveltekit (use posthog://docs/frameworks/sveltekit for documentation)',\n ],\n },\n\n ui: {\n successMessage: 'PostHog integration complete',\n estimatedDurationMinutes: 8,\n getOutroChanges: () => [\n 'Analyzed your SvelteKit project structure',\n 'Created and configured PostHog initializers',\n 'Integrated PostHog into your application',\n ],\n getOutroNextSteps: () => [\n 'Start your development server to see PostHog in action',\n 'Visit your PostHog dashboard to see incoming events',\n ],\n },\n};\n"]}
@@ -1 +0,0 @@
1
- {"version":3,"file":"swift-wizard-agent.js","sourceRoot":"","sources":["../../../src/swift/swift-wizard-agent.ts"],"names":[],"mappings":"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","sourcesContent":["/* Swift wizard using posthog-agent with PostHog MCP */\nimport type { WizardOptions } from '../utils/types';\nimport type { FrameworkConfig } from '../lib/framework-config';\nimport { swiftPackageManager } from '../lib/package-manager-detection';\nimport { Integration } from '../lib/constants';\nimport fg from 'fast-glob';\nimport * as fs from 'node:fs';\nimport * as path from 'node:path';\nimport {\n detectSwiftProjectType,\n getSwiftProjectTypeName,\n SwiftProjectType,\n} from './utils';\n\ntype SwiftContext = {\n projectType?: SwiftProjectType;\n};\n\nexport const SWIFT_AGENT_CONFIG: FrameworkConfig<SwiftContext> = {\n metadata: {\n name: 'Swift (iOS/macOS)',\n integration: Integration.swift,\n beta: true,\n docsUrl: 'https://posthog.com/docs/libraries/ios',\n preRunNotice:\n 'Please close the Xcode project before proceeding. Xcode may overwrite changes the wizard makes to project files.',\n gatherContext: async (options: WizardOptions) => {\n const projectType = await detectSwiftProjectType(options);\n return { projectType };\n },\n },\n\n detection: {\n packageName: 'posthog-ios',\n packageDisplayName: 'Swift',\n usesPackageJson: false,\n getVersion: () => undefined,\n detect: async (options) => {\n const { installDir } = options;\n\n // Check for Xcode project\n const xcodeProjects = await fg('*.xcodeproj', {\n cwd: installDir,\n onlyDirectories: true,\n });\n\n if (xcodeProjects.length > 0) {\n // Verify it contains Swift source files\n const swiftFiles = await fg('**/*.swift', {\n cwd: installDir,\n ignore: [\n '**/.build/**',\n '**/DerivedData/**',\n '**/build/**',\n '**/*.xcodeproj/**',\n '**/Pods/**',\n ],\n });\n if (swiftFiles.length > 0) {\n return true;\n }\n }\n\n // Check for Swift Package Manager project\n const packageSwiftPath = path.join(installDir, 'Package.swift');\n if (fs.existsSync(packageSwiftPath)) {\n return true;\n }\n\n return false;\n },\n detectPackageManager: swiftPackageManager,\n },\n\n environment: {\n uploadToHosting: false,\n getEnvVars: (apiKey: string, host: string) => ({\n POSTHOG_API_KEY: apiKey,\n POSTHOG_HOST: host,\n }),\n },\n\n analytics: {\n getTags: (context) => ({\n projectType: context.projectType || 'unknown',\n }),\n },\n\n prompts: {\n projectTypeDetection:\n 'This is a Swift project. Look for .xcodeproj directories, Package.swift, and .swift source files to confirm. Check for SwiftUI or UIKit imports to determine the UI framework.',\n packageInstallation:\n 'Add the posthog-ios package via Swift Package Manager. For Xcode projects, add XCRemoteSwiftPackageReference and XCSwiftPackageProductDependency to the .pbxproj file. For Swift packages, add the dependency to Package.swift.',\n getAdditionalContextLines: (context) => {\n const projectTypeName = context.projectType\n ? getSwiftProjectTypeName(context.projectType)\n : 'unknown';\n\n const lines = [\n `Project type: ${projectTypeName}`,\n `Framework docs ID: swift (use posthog://docs/frameworks/swift for documentation)`,\n ];\n\n return lines;\n },\n },\n\n ui: {\n successMessage: 'PostHog integration complete',\n estimatedDurationMinutes: 5,\n getOutroChanges: (context) => {\n const projectTypeName = context.projectType\n ? getSwiftProjectTypeName(context.projectType)\n : 'Swift';\n\n const changes = [\n `Analyzed your ${projectTypeName} project structure`,\n `Added the PostHog iOS SDK via Swift Package Manager`,\n `Configured PostHog initialization in your app entry point`,\n `Added event capture and user identification`,\n ];\n\n return changes;\n },\n getOutroNextSteps: () => [\n 'Set POSTHOG_API_KEY and POSTHOG_HOST in your Xcode scheme environment variables',\n 'Build and run your app to see PostHog in action',\n 'Visit your PostHog dashboard to see incoming events',\n ],\n },\n};\n"]}
@@ -1 +0,0 @@
1
- {"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../src/swift/utils.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAWA,0DASC;AAED,wDAiDC;AAtED,0DAA2B;AAC3B,4CAA8B;AAC9B,gDAAkC;AAElC,IAAY,gBAIX;AAJD,WAAY,gBAAgB;IAC1B,uCAAmB,CAAA;IACnB,mCAAe,CAAA;IACf,+BAAW,CAAA;AACb,CAAC,EAJW,gBAAgB,gCAAhB,gBAAgB,QAI3B;AAED,SAAgB,uBAAuB,CAAC,WAA6B;IACnE,QAAQ,WAAW,EAAE,CAAC;QACpB,KAAK,gBAAgB,CAAC,OAAO;YAC3B,OAAO,SAAS,CAAC;QACnB,KAAK,gBAAgB,CAAC,KAAK;YACzB,OAAO,OAAO,CAAC;QACjB,KAAK,gBAAgB,CAAC,GAAG;YACvB,OAAO,eAAe,CAAC;IAC3B,CAAC;AACH,CAAC;AAEM,KAAK,UAAU,sBAAsB,CAC1C,OAAsB;IAEtB,MAAM,EAAE,UAAU,EAAE,GAAG,OAAO,CAAC;IAE/B,yEAAyE;IACzE,MAAM,eAAe,GAAG,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,eAAe,CAAC,CAAC,CAAC;IAC9E,MAAM,aAAa,GAAG,MAAM,IAAA,mBAAE,EAAC,aAAa,EAAE;QAC5C,GAAG,EAAE,UAAU;QACf,eAAe,EAAE,IAAI;KACtB,CAAC,CAAC;IAEH,IAAI,eAAe,IAAI,aAAa,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAClD,OAAO,gBAAgB,CAAC,GAAG,CAAC;IAC9B,CAAC;IAED,wDAAwD;IACxD,MAAM,UAAU,GAAG,MAAM,IAAA,mBAAE,EAAC,YAAY,EAAE;QACxC,GAAG,EAAE,UAAU;QACf,MAAM,EAAE;YACN,cAAc;YACd,mBAAmB;YACnB,aAAa;YACb,mBAAmB;YACnB,YAAY;SACb;KACF,CAAC,CAAC;IAEH,IAAI,UAAU,GAAG,KAAK,CAAC;IACvB,IAAI,QAAQ,GAAG,KAAK,CAAC;IAErB,KAAK,MAAM,IAAI,IAAI,UAAU,EAAE,CAAC;QAC9B,IAAI,CAAC;YACH,MAAM,OAAO,GAAG,EAAE,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,EAAE,OAAO,CAAC,CAAC;YACtE,IAAI,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAC,EAAE,CAAC;gBACvC,UAAU,GAAG,IAAI,CAAC;YACpB,CAAC;YACD,IAAI,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAC,EAAE,CAAC;gBACrC,QAAQ,GAAG,IAAI,CAAC;YAClB,CAAC;QACH,CAAC;QAAC,MAAM,CAAC;YACP,SAAS;QACX,CAAC;IACH,CAAC;IAED,IAAI,UAAU;QAAE,OAAO,gBAAgB,CAAC,OAAO,CAAC;IAChD,IAAI,QAAQ;QAAE,OAAO,gBAAgB,CAAC,KAAK,CAAC;IAE5C,OAAO,SAAS,CAAC;AACnB,CAAC","sourcesContent":["import type { WizardOptions } from '../utils/types';\nimport fg from 'fast-glob';\nimport * as fs from 'node:fs';\nimport * as path from 'node:path';\n\nexport enum SwiftProjectType {\n SWIFTUI = 'swiftui',\n UIKIT = 'uikit',\n SPM = 'spm',\n}\n\nexport function getSwiftProjectTypeName(projectType: SwiftProjectType): string {\n switch (projectType) {\n case SwiftProjectType.SWIFTUI:\n return 'SwiftUI';\n case SwiftProjectType.UIKIT:\n return 'UIKit';\n case SwiftProjectType.SPM:\n return 'Swift Package';\n }\n}\n\nexport async function detectSwiftProjectType(\n options: WizardOptions,\n): Promise<SwiftProjectType | undefined> {\n const { installDir } = options;\n\n // Check if this is a pure SPM package (Package.swift without .xcodeproj)\n const hasPackageSwift = fs.existsSync(path.join(installDir, 'Package.swift'));\n const xcodeProjects = await fg('*.xcodeproj', {\n cwd: installDir,\n onlyDirectories: true,\n });\n\n if (hasPackageSwift && xcodeProjects.length === 0) {\n return SwiftProjectType.SPM;\n }\n\n // Check Swift source files for SwiftUI vs UIKit imports\n const swiftFiles = await fg('**/*.swift', {\n cwd: installDir,\n ignore: [\n '**/.build/**',\n '**/DerivedData/**',\n '**/build/**',\n '**/*.xcodeproj/**',\n '**/Pods/**',\n ],\n });\n\n let hasSwiftUI = false;\n let hasUIKit = false;\n\n for (const file of swiftFiles) {\n try {\n const content = fs.readFileSync(path.join(installDir, file), 'utf-8');\n if (content.includes('import SwiftUI')) {\n hasSwiftUI = true;\n }\n if (content.includes('import UIKit')) {\n hasUIKit = true;\n }\n } catch {\n continue;\n }\n }\n\n if (hasSwiftUI) return SwiftProjectType.SWIFTUI;\n if (hasUIKit) return SwiftProjectType.UIKIT;\n\n return undefined;\n}\n"]}
@@ -1 +0,0 @@
1
- {"version":3,"file":"tanstack-router-wizard-agent.js","sourceRoot":"","sources":["../../../src/tanstack-router/tanstack-router-wizard-agent.ts"],"names":[],"mappings":"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","sourcesContent":["/* TanStack Router wizard using posthog-agent with PostHog MCP */\nimport type { WizardOptions } from '../utils/types';\nimport type { FrameworkConfig } from '../lib/framework-config';\nimport { detectNodePackageManagers } from '../lib/package-manager-detection';\nimport { Integration } from '../lib/constants';\nimport {\n getPackageVersion,\n hasPackageInstalled,\n type PackageDotJson,\n} from '../utils/package-json';\nimport { getPackageDotJson, tryGetPackageJson } from '../utils/clack-utils';\nimport {\n getTanStackRouterMode,\n getTanStackRouterModeName,\n getTanStackRouterVersionBucket,\n TanStackRouterMode,\n} from './utils';\n\ntype TanStackRouterContext = {\n routerMode?: TanStackRouterMode;\n};\n\nexport const TANSTACK_ROUTER_AGENT_CONFIG: FrameworkConfig<TanStackRouterContext> =\n {\n metadata: {\n name: 'React (TanStack Router)',\n integration: Integration.tanstackRouter,\n docsUrl: 'https://posthog.com/docs/libraries/react',\n gatherContext: async (options: WizardOptions) => {\n const routerMode = await getTanStackRouterMode(options);\n return { routerMode };\n },\n },\n\n detection: {\n packageName: '@tanstack/react-router',\n packageDisplayName: 'TanStack Router',\n getVersion: (packageJson: unknown) =>\n getPackageVersion(\n '@tanstack/react-router',\n packageJson as PackageDotJson,\n ),\n getVersionBucket: getTanStackRouterVersionBucket,\n minimumVersion: '1.0.0',\n getInstalledVersion: async (options: WizardOptions) => {\n const packageJson = await getPackageDotJson(options);\n return getPackageVersion('@tanstack/react-router', packageJson);\n },\n detect: async (options) => {\n const packageJson = await tryGetPackageJson(options);\n if (!packageJson) {\n return false;\n }\n // Exclude TanStack Start projects (they have their own integration)\n if (hasPackageInstalled('@tanstack/react-start', packageJson)) {\n return false;\n }\n return hasPackageInstalled('@tanstack/react-router', packageJson);\n },\n detectPackageManager: detectNodePackageManagers,\n },\n\n environment: {\n uploadToHosting: false,\n getEnvVars: (apiKey: string, host: string) => ({\n VITE_PUBLIC_POSTHOG_KEY: apiKey,\n VITE_PUBLIC_POSTHOG_HOST: host,\n }),\n },\n\n analytics: {\n getTags: (context) => ({\n routerMode: context.routerMode || 'unknown',\n }),\n },\n\n prompts: {\n projectTypeDetection:\n 'This is a JavaScript/TypeScript project. Look for package.json and lockfiles (package-lock.json, yarn.lock, pnpm-lock.yaml, bun.lockb) to confirm.',\n getAdditionalContextLines: (context) => {\n const routerMode = context.routerMode;\n const modeName = routerMode\n ? getTanStackRouterModeName(routerMode)\n : 'unknown';\n\n // Map router mode to framework ID for MCP docs resource\n const frameworkIdMap: Record<TanStackRouterMode, string> = {\n [TanStackRouterMode.FILE_BASED]: 'react-tanstack-router-file-based',\n [TanStackRouterMode.CODE_BASED]: 'react-tanstack-router-code-based',\n };\n\n const frameworkId = routerMode\n ? frameworkIdMap[routerMode]\n : 'react-tanstack-router-file-based';\n\n return [\n `Router mode: ${modeName}`,\n `Framework docs ID: ${frameworkId} (use posthog://docs/frameworks/${frameworkId} for documentation)`,\n ];\n },\n },\n\n ui: {\n successMessage: 'PostHog integration complete',\n estimatedDurationMinutes: 8,\n getOutroChanges: (context) => {\n const modeName = context.routerMode\n ? getTanStackRouterModeName(context.routerMode)\n : 'TanStack Router';\n return [\n `Analyzed your React (TanStack Router) project structure (${modeName})`,\n `Created and configured PostHog initializers`,\n `Integrated PostHog into your application`,\n ];\n },\n getOutroNextSteps: () => [\n 'Start your development server to see PostHog in action',\n 'Visit your PostHog dashboard to see incoming events',\n ],\n },\n };\n"]}
@@ -1,17 +0,0 @@
1
- import type { WizardOptions } from '../utils/types';
2
- export declare enum TanStackRouterMode {
3
- FILE_BASED = "file-based",// Uses @tanstack/router-plugin with file-based route generation
4
- CODE_BASED = "code-based"
5
- }
6
- /**
7
- * Get TanStack Router version bucket for analytics
8
- */
9
- export declare const getTanStackRouterVersionBucket: (version: string | undefined) => string;
10
- /**
11
- * Detect TanStack Router mode (file-based vs code-based routing)
12
- */
13
- export declare function getTanStackRouterMode(options: WizardOptions): Promise<TanStackRouterMode>;
14
- /**
15
- * Get human-readable name for TanStack Router mode
16
- */
17
- export declare function getTanStackRouterModeName(mode: TanStackRouterMode): string;
@@ -1 +0,0 @@
1
- {"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../src/tanstack-router/utils.ts"],"names":[],"mappings":"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","sourcesContent":["import fg from 'fast-glob';\nimport { abortIfCancelled } from '../utils/clack-utils';\nimport clack from '../utils/clack';\nimport type { WizardOptions } from '../utils/types';\nimport { Integration } from '../lib/constants';\nimport { hasPackageInstalled } from '../utils/package-json';\nimport { createVersionBucket } from '../utils/semver';\nimport * as fs from 'node:fs';\nimport * as path from 'node:path';\n\nexport enum TanStackRouterMode {\n FILE_BASED = 'file-based', // Uses @tanstack/router-plugin with file-based route generation\n CODE_BASED = 'code-based', // Manually defines routes with createRoute/createRootRoute\n}\n\nconst IGNORE_PATTERNS = [\n '**/node_modules/**',\n '**/dist/**',\n '**/build/**',\n '**/public/**',\n '**/.vinxi/**',\n '**/.output/**',\n];\n\n/**\n * Get TanStack Router version bucket for analytics\n */\nexport const getTanStackRouterVersionBucket = createVersionBucket();\n\n/**\n * Check if the project uses file-based routing.\n *\n * Detection signals (in order of reliability):\n * 1. Generated route tree file exists (routeTree.gen.ts) - definitive\n * 2. Router plugin in package.json (@tanstack/router-plugin or @tanstack/router-vite-plugin)\n * 3. createFileRoute usage in source files\n */\nasync function hasFileBasedRouting({\n installDir,\n}: Pick<WizardOptions, 'installDir'>): Promise<boolean> {\n // 1. Check for generated route tree file (most definitive signal)\n const generatedFiles = await fg('**/routeTree.gen.@(ts|tsx|js|jsx)', {\n dot: true,\n cwd: installDir,\n ignore: IGNORE_PATTERNS,\n });\n\n if (generatedFiles.length > 0) {\n return true;\n }\n\n // 2. Check package.json for the router plugin\n try {\n const packageJsonPath = path.join(installDir, 'package.json');\n const content = fs.readFileSync(packageJsonPath, 'utf-8');\n const packageJson = JSON.parse(content) as Record<string, unknown>;\n\n if (\n hasPackageInstalled('@tanstack/router-plugin', packageJson) ||\n hasPackageInstalled('@tanstack/router-vite-plugin', packageJson)\n ) {\n return true;\n }\n } catch {\n // package.json not found or unreadable\n }\n\n // 3. Check for createFileRoute usage in source files\n const sourceFiles = await fg('**/*.@(ts|tsx|js|jsx)', {\n dot: true,\n cwd: installDir,\n ignore: IGNORE_PATTERNS,\n });\n\n for (const file of sourceFiles) {\n try {\n const filePath = path.join(installDir, file);\n const content = fs.readFileSync(filePath, 'utf-8');\n if (content.includes('createFileRoute')) {\n return true;\n }\n } catch {\n continue;\n }\n }\n\n return false;\n}\n\n/**\n * Check if the project uses code-based routing.\n *\n * Code-based routing uses createRoute() to manually define routes,\n * as opposed to file-based routing which uses createFileRoute().\n */\nasync function hasCodeBasedRouting({\n installDir,\n}: Pick<WizardOptions, 'installDir'>): Promise<boolean> {\n const sourceFiles = await fg('**/*.@(ts|tsx|js|jsx)', {\n dot: true,\n cwd: installDir,\n ignore: IGNORE_PATTERNS,\n });\n\n let hasCreateRoute = false;\n let hasCreateFileRoute = false;\n\n for (const file of sourceFiles) {\n try {\n const filePath = path.join(installDir, file);\n const content = fs.readFileSync(filePath, 'utf-8');\n\n if (content.includes('createRoute(')) {\n hasCreateRoute = true;\n }\n if (content.includes('createFileRoute')) {\n hasCreateFileRoute = true;\n }\n } catch {\n continue;\n }\n }\n\n // Code-based if createRoute is used without createFileRoute\n return hasCreateRoute && !hasCreateFileRoute;\n}\n\n/**\n * Detect TanStack Router mode (file-based vs code-based routing)\n */\nexport async function getTanStackRouterMode(\n options: WizardOptions,\n): Promise<TanStackRouterMode> {\n const { installDir } = options;\n\n const isFileBased = await hasFileBasedRouting({ installDir });\n if (isFileBased) {\n clack.log.info('Detected TanStack Router file-based routing');\n return TanStackRouterMode.FILE_BASED;\n }\n\n const isCodeBased = await hasCodeBasedRouting({ installDir });\n if (isCodeBased) {\n clack.log.info('Detected TanStack Router code-based routing');\n return TanStackRouterMode.CODE_BASED;\n }\n\n // If we can't detect, ask the user\n const result: TanStackRouterMode = await abortIfCancelled(\n clack.select({\n message: 'What TanStack Router routing mode are you using?',\n options: [\n {\n label: 'File-based routing',\n value: TanStackRouterMode.FILE_BASED,\n },\n {\n label: 'Code-based routing',\n value: TanStackRouterMode.CODE_BASED,\n },\n ],\n }),\n Integration.tanstackRouter,\n );\n return result;\n}\n\n/**\n * Get human-readable name for TanStack Router mode\n */\nexport function getTanStackRouterModeName(mode: TanStackRouterMode): string {\n switch (mode) {\n case TanStackRouterMode.FILE_BASED:\n return 'File-based routing';\n case TanStackRouterMode.CODE_BASED:\n return 'Code-based routing';\n }\n}\n"]}
@@ -1 +0,0 @@
1
- {"version":3,"file":"tanstack-start-wizard-agent.js","sourceRoot":"","sources":["../../../src/tanstack-start/tanstack-start-wizard-agent.ts"],"names":[],"mappings":";;;AAGA,gFAA6E;AAC7E,gDAA+C;AAC/C,wDAI+B;AAC/B,sDAA4E;AAC5E,mCAAwD;AAI3C,QAAA,2BAA2B,GACtC;IACE,QAAQ,EAAE;QACR,IAAI,EAAE,gBAAgB;QACtB,WAAW,EAAE,uBAAW,CAAC,aAAa;QACtC,OAAO,EAAE,0CAA0C;KACpD;IAED,SAAS,EAAE;QACT,WAAW,EAAE,uBAAuB;QACpC,kBAAkB,EAAE,gBAAgB;QACpC,UAAU,EAAE,CAAC,WAAoB,EAAE,EAAE,CACnC,IAAA,gCAAiB,EACf,uBAAuB,EACvB,WAA6B,CAC9B;QACH,gBAAgB,EAAE,qCAA6B;QAC/C,cAAc,EAAE,OAAO;QACvB,mBAAmB,EAAE,KAAK,EAAE,OAAsB,EAAE,EAAE;YACpD,MAAM,WAAW,GAAG,MAAM,IAAA,+BAAiB,EAAC,OAAO,CAAC,CAAC;YACrD,OAAO,IAAA,gCAAiB,EAAC,uBAAuB,EAAE,WAAW,CAAC,CAAC;QACjE,CAAC;QACD,MAAM,EAAE,KAAK,EAAE,OAAO,EAAE,EAAE;YACxB,MAAM,WAAW,GAAG,MAAM,IAAA,+BAAiB,EAAC,OAAO,CAAC,CAAC;YACrD,OAAO,WAAW;gBAChB,CAAC,CAAC,IAAA,kCAAmB,EAAC,uBAAuB,EAAE,WAAW,CAAC;gBAC3D,CAAC,CAAC,KAAK,CAAC;QACZ,CAAC;QACD,oBAAoB,EAAE,qDAAyB;KAChD;IAED,WAAW,EAAE;QACX,eAAe,EAAE,KAAK;QACtB,UAAU,EAAE,CAAC,MAAc,EAAE,IAAY,EAAE,EAAE,CAAC,CAAC;YAC7C,uBAAuB,EAAE,MAAM;YAC/B,wBAAwB,EAAE,IAAI;SAC/B,CAAC;KACH;IAED,SAAS,EAAE;QACT,OAAO,EAAE,GAAG,EAAE,CAAC,CAAC,EAAE,CAAC;KACpB;IAED,OAAO,EAAE;QACP,oBAAoB,EAClB,oJAAoJ;QACtJ,yBAAyB,EAAE,GAAG,EAAE;YAC9B,uGAAuG;YACvG,MAAM,WAAW,GAAG,sBAAsB,CAAC;YAE3C,OAAO;gBACL,sBAAsB,WAAW,mCAAmC,WAAW,qBAAqB;aACrG,CAAC;QACJ,CAAC;KACF;IAED,EAAE,EAAE;QACF,cAAc,EAAE,8BAA8B;QAC9C,wBAAwB,EAAE,CAAC;QAC3B,eAAe,EAAE,GAAG,EAAE,CAAC;YACrB,gDAAgD;YAChD,6CAA6C;YAC7C,0CAA0C;SAC3C;QACD,iBAAiB,EAAE,GAAG,EAAE,CAAC;YACvB,wDAAwD;YACxD,qDAAqD;SACtD;KACF;CACF,CAAC","sourcesContent":["/* TanStack Start wizard using posthog-agent with PostHog MCP */\nimport type { WizardOptions } from '../utils/types';\nimport type { FrameworkConfig } from '../lib/framework-config';\nimport { detectNodePackageManagers } from '../lib/package-manager-detection';\nimport { Integration } from '../lib/constants';\nimport {\n getPackageVersion,\n hasPackageInstalled,\n type PackageDotJson,\n} from '../utils/package-json';\nimport { getPackageDotJson, tryGetPackageJson } from '../utils/clack-utils';\nimport { getTanStackStartVersionBucket } from './utils';\n\ntype TanStackStartContext = Record<string, unknown>;\n\nexport const TANSTACK_START_AGENT_CONFIG: FrameworkConfig<TanStackStartContext> =\n {\n metadata: {\n name: 'TanStack Start',\n integration: Integration.tanstackStart,\n docsUrl: 'https://posthog.com/docs/libraries/react',\n },\n\n detection: {\n packageName: '@tanstack/react-start',\n packageDisplayName: 'TanStack Start',\n getVersion: (packageJson: unknown) =>\n getPackageVersion(\n '@tanstack/react-start',\n packageJson as PackageDotJson,\n ),\n getVersionBucket: getTanStackStartVersionBucket,\n minimumVersion: '1.0.0',\n getInstalledVersion: async (options: WizardOptions) => {\n const packageJson = await getPackageDotJson(options);\n return getPackageVersion('@tanstack/react-start', packageJson);\n },\n detect: async (options) => {\n const packageJson = await tryGetPackageJson(options);\n return packageJson\n ? hasPackageInstalled('@tanstack/react-start', packageJson)\n : false;\n },\n detectPackageManager: detectNodePackageManagers,\n },\n\n environment: {\n uploadToHosting: false,\n getEnvVars: (apiKey: string, host: string) => ({\n VITE_PUBLIC_POSTHOG_KEY: apiKey,\n VITE_PUBLIC_POSTHOG_HOST: host,\n }),\n },\n\n analytics: {\n getTags: () => ({}),\n },\n\n prompts: {\n projectTypeDetection:\n 'This is a JavaScript/TypeScript project. Look for package.json and lockfiles (package-lock.json, yarn.lock, pnpm-lock.yaml, bun.lockb) to confirm.',\n getAdditionalContextLines: () => {\n // TanStack Start always uses file-based routing (it's a full-stack framework built on TanStack Router)\n const frameworkId = 'react-tanstack-start';\n\n return [\n `Framework docs ID: ${frameworkId} (use posthog://docs/frameworks/${frameworkId} for documentation)`,\n ];\n },\n },\n\n ui: {\n successMessage: 'PostHog integration complete',\n estimatedDurationMinutes: 8,\n getOutroChanges: () => [\n `Analyzed your TanStack Start project structure`,\n `Created and configured PostHog initializers`,\n `Integrated PostHog into your application`,\n ],\n getOutroNextSteps: () => [\n 'Start your development server to see PostHog in action',\n 'Visit your PostHog dashboard to see incoming events',\n ],\n },\n };\n"]}
@@ -1 +0,0 @@
1
- {"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../src/tanstack-start/utils.ts"],"names":[],"mappings":";;;AAAA,4CAAsD;AAEtD;;GAEG;AACU,QAAA,6BAA6B,GAAG,IAAA,4BAAmB,GAAE,CAAC","sourcesContent":["import { createVersionBucket } from '../utils/semver';\n\n/**\n * Get TanStack Start version bucket for analytics\n */\nexport const getTanStackStartVersionBucket = createVersionBucket();\n"]}
@@ -1 +0,0 @@
1
- {"version":3,"file":"clack-utils.test.js","sourceRoot":"","sources":["../../../../src/utils/__tests__/clack-utils.test.ts"],"names":[],"mappings":"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","sourcesContent":["import { installPackage } from '../clack-utils';\n\nimport * as ChildProcess from 'node:child_process';\nimport type { PackageManager } from '../package-manager';\n\njest.mock('node:child_process', () => ({\n __esModule: true,\n ...jest.requireActual('node:child_process'),\n}));\n\njest.mock('@clack/prompts', () => ({\n log: {\n info: jest.fn(),\n success: jest.fn(),\n warn: jest.fn(),\n error: jest.fn(),\n },\n text: jest.fn(),\n confirm: jest.fn(),\n cancel: jest.fn(),\n outro: jest.fn(),\n // passthrough for abortIfCancelled\n isCancel: jest.fn().mockReturnValue(false),\n spinner: jest\n .fn()\n .mockImplementation(() => ({ start: jest.fn(), stop: jest.fn() })),\n}));\n\ndescribe.skip('installPackage', () => {\n afterEach(() => {\n jest.clearAllMocks();\n });\n\n it('force-installs a package if the forceInstall flag is set', async () => {\n const packageManagerMock: PackageManager = {\n name: 'npm',\n label: 'NPM',\n installCommand: 'npm install',\n buildCommand: 'npm run build',\n runScriptCommand: 'npm run',\n flags: '',\n forceInstallFlag: '--force',\n detect: jest.fn(),\n addOverride: jest.fn(),\n };\n\n const execSpy = jest\n .spyOn(ChildProcess, 'exec')\n // @ts-expect-error - don't care about the return value\n .mockImplementationOnce((cmd, cb) => {\n if (cb) {\n // @ts-expect-error - don't care about the options value\n cb(null, '', '');\n }\n });\n\n await installPackage({\n alreadyInstalled: false,\n packageName: 'posthog-js',\n packageNameDisplayLabel: 'posthog-js',\n forceInstall: true,\n askBeforeUpdating: false,\n packageManager: packageManagerMock,\n installDir: process.cwd(),\n });\n\n expect(execSpy).toHaveBeenCalledWith(\n 'npm install posthog-js --force',\n expect.any(Function),\n );\n });\n\n it.each([false, undefined])(\n \"doesn't force-install a package if the forceInstall flag is %s\",\n async (flag) => {\n const packageManagerMock: PackageManager = {\n name: 'npm',\n label: 'NPM',\n installCommand: 'npm install',\n buildCommand: 'npm run build',\n runScriptCommand: 'npm run',\n flags: '',\n forceInstallFlag: '--force',\n detect: jest.fn(),\n addOverride: jest.fn(),\n };\n\n const execSpy = jest\n .spyOn(ChildProcess, 'exec')\n // @ts-expect-error - don't care about the return value\n .mockImplementationOnce((cmd, cb) => {\n if (cb) {\n // @ts-expect-error - don't care about the options value\n cb(null, '', '');\n }\n });\n\n await installPackage({\n alreadyInstalled: false,\n packageName: 'posthog-js',\n packageNameDisplayLabel: 'posthog-js',\n forceInstall: flag,\n askBeforeUpdating: false,\n packageManager: packageManagerMock,\n installDir: process.cwd(),\n });\n\n expect(execSpy).toHaveBeenCalledWith(\n 'npm install posthog-js ',\n expect.any(Function),\n );\n },\n );\n});\n"]}