@amplitude/wizard 1.0.0-beta.2 → 1.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 (391) hide show
  1. package/README.md +171 -74
  2. package/dist/bin.js +338 -222
  3. package/dist/src/lib/agent-interface.js +64 -9
  4. package/dist/src/lib/agent-runner.js +1 -10
  5. package/dist/src/lib/api.d.ts +22 -4
  6. package/dist/src/lib/api.js +114 -12
  7. package/dist/src/lib/commandments.js +14 -1
  8. package/dist/src/lib/constants.d.ts +6 -5
  9. package/dist/src/lib/constants.js +13 -13
  10. package/dist/src/lib/credential-resolution.d.ts +45 -0
  11. package/dist/src/lib/credential-resolution.js +311 -0
  12. package/dist/src/lib/exit-codes.d.ts +10 -0
  13. package/dist/src/lib/exit-codes.js +12 -0
  14. package/dist/src/lib/health-checks/statuspage.d.ts +1 -0
  15. package/dist/src/lib/health-checks/statuspage.js +5 -1
  16. package/dist/src/lib/mode-config.d.ts +14 -0
  17. package/dist/src/lib/mode-config.js +14 -0
  18. package/dist/src/lib/session-checkpoint.d.ts +27 -0
  19. package/dist/src/lib/session-checkpoint.js +134 -0
  20. package/dist/src/lib/wizard-session.d.ts +44 -1
  21. package/dist/src/lib/wizard-session.js +70 -14
  22. package/dist/src/lib/wizard-tools.js +19 -4
  23. package/dist/src/steps/add-mcp-server-to-clients/clients/claude.d.ts +3 -0
  24. package/dist/src/steps/add-mcp-server-to-clients/clients/claude.js +6 -0
  25. package/dist/src/steps/add-mcp-server-to-clients/clients/cursor.js +3 -1
  26. package/dist/src/ui/agent-ui.d.ts +91 -0
  27. package/dist/src/ui/agent-ui.js +277 -0
  28. package/dist/src/ui/logging-ui.js +1 -1
  29. package/dist/src/ui/tui/App.d.ts +12 -0
  30. package/dist/src/ui/tui/App.js +29 -18
  31. package/dist/src/ui/tui/components/AmplitudeLogo.js +16 -17
  32. package/dist/src/ui/tui/components/AmplitudeTextLogo.d.ts +0 -2
  33. package/dist/src/ui/tui/components/AmplitudeTextLogo.js +53 -18
  34. package/dist/src/ui/tui/components/BrailleSpinner.d.ts +8 -0
  35. package/dist/src/ui/tui/components/BrailleSpinner.js +15 -0
  36. package/dist/src/ui/tui/components/ConsoleView.d.ts +8 -11
  37. package/dist/src/ui/tui/components/ConsoleView.js +51 -34
  38. package/dist/src/ui/tui/components/HeaderBar.d.ts +12 -0
  39. package/dist/src/ui/tui/components/HeaderBar.js +17 -0
  40. package/dist/src/ui/tui/components/JourneyStepper.d.ts +16 -0
  41. package/dist/src/ui/tui/components/JourneyStepper.js +83 -0
  42. package/dist/src/ui/tui/components/KeyHintBar.d.ts +19 -0
  43. package/dist/src/ui/tui/components/KeyHintBar.js +20 -0
  44. package/dist/src/ui/tui/console-commands.d.ts +1 -2
  45. package/dist/src/ui/tui/console-commands.js +48 -7
  46. package/dist/src/ui/tui/flows.d.ts +1 -1
  47. package/dist/src/ui/tui/flows.js +1 -1
  48. package/dist/src/ui/tui/hooks/useAsyncEffect.d.ts +15 -0
  49. package/dist/src/ui/tui/hooks/useAsyncEffect.js +35 -0
  50. package/dist/src/ui/tui/hooks/useWizardStore.d.ts +9 -0
  51. package/dist/src/ui/tui/hooks/useWizardStore.js +11 -0
  52. package/dist/src/ui/tui/ink-ui.js +1 -1
  53. package/dist/src/ui/tui/primitives/DissolveTransition.js +4 -5
  54. package/dist/src/ui/tui/primitives/EventPlanViewer.d.ts +3 -1
  55. package/dist/src/ui/tui/primitives/EventPlanViewer.js +8 -3
  56. package/dist/src/ui/tui/primitives/ProgressList.js +1 -1
  57. package/dist/src/ui/tui/primitives/SlashCommandInput.js +19 -4
  58. package/dist/src/ui/tui/primitives/SplitView.d.ts +2 -1
  59. package/dist/src/ui/tui/primitives/SplitView.js +10 -2
  60. package/dist/src/ui/tui/primitives/TabContainer.js +10 -2
  61. package/dist/src/ui/tui/primitives/index.d.ts +0 -1
  62. package/dist/src/ui/tui/primitives/index.js +0 -1
  63. package/dist/src/ui/tui/router.js +1 -1
  64. package/dist/src/ui/tui/screen-registry.d.ts +0 -7
  65. package/dist/src/ui/tui/screen-registry.js +13 -4
  66. package/dist/src/ui/tui/screens/ActivationOptionsScreen.d.ts +2 -2
  67. package/dist/src/ui/tui/screens/ActivationOptionsScreen.js +8 -8
  68. package/dist/src/ui/tui/screens/AuthScreen.js +57 -27
  69. package/dist/src/ui/tui/screens/ChecklistScreen.d.ts +2 -12
  70. package/dist/src/ui/tui/screens/ChecklistScreen.js +22 -33
  71. package/dist/src/ui/tui/screens/DataIngestionCheckScreen.d.ts +3 -12
  72. package/dist/src/ui/tui/screens/DataIngestionCheckScreen.js +109 -39
  73. package/dist/src/ui/tui/screens/DataSetupScreen.d.ts +3 -3
  74. package/dist/src/ui/tui/screens/DataSetupScreen.js +17 -10
  75. package/dist/src/ui/tui/screens/IntroScreen.d.ts +5 -3
  76. package/dist/src/ui/tui/screens/IntroScreen.js +132 -41
  77. package/dist/src/ui/tui/screens/LoginScreen.d.ts +1 -1
  78. package/dist/src/ui/tui/screens/LoginScreen.js +4 -4
  79. package/dist/src/ui/tui/screens/LogoutScreen.d.ts +4 -2
  80. package/dist/src/ui/tui/screens/LogoutScreen.js +17 -5
  81. package/dist/src/ui/tui/screens/McpScreen.d.ts +4 -4
  82. package/dist/src/ui/tui/screens/McpScreen.js +25 -17
  83. package/dist/src/ui/tui/screens/OutageScreen.d.ts +1 -1
  84. package/dist/src/ui/tui/screens/OutageScreen.js +5 -5
  85. package/dist/src/ui/tui/screens/OutroScreen.d.ts +5 -0
  86. package/dist/src/ui/tui/screens/OutroScreen.js +21 -14
  87. package/dist/src/ui/tui/screens/RegionSelectScreen.js +15 -13
  88. package/dist/src/ui/tui/screens/RunScreen.d.ts +7 -5
  89. package/dist/src/ui/tui/screens/RunScreen.js +102 -157
  90. package/dist/src/ui/tui/screens/SettingsOverrideScreen.d.ts +1 -1
  91. package/dist/src/ui/tui/screens/SettingsOverrideScreen.js +6 -5
  92. package/dist/src/ui/tui/screens/SetupScreen.d.ts +1 -1
  93. package/dist/src/ui/tui/screens/SetupScreen.js +7 -7
  94. package/dist/src/ui/tui/screens/SlackScreen.d.ts +2 -2
  95. package/dist/src/ui/tui/screens/SlackScreen.js +60 -35
  96. package/dist/src/ui/tui/session-constants.d.ts +41 -0
  97. package/dist/src/ui/tui/session-constants.js +38 -0
  98. package/dist/src/ui/tui/start-tui.d.ts +3 -1
  99. package/dist/src/ui/tui/start-tui.js +14 -10
  100. package/dist/src/ui/tui/store.d.ts +2 -1
  101. package/dist/src/ui/tui/store.js +33 -7
  102. package/dist/src/ui/tui/styles.d.ts +75 -19
  103. package/dist/src/ui/tui/styles.js +101 -19
  104. package/dist/src/ui/tui/utils/classify-error.d.ts +14 -0
  105. package/dist/src/ui/tui/utils/classify-error.js +90 -0
  106. package/dist/src/ui/tui/utils/diagnostics.d.ts +21 -0
  107. package/dist/src/ui/tui/utils/diagnostics.js +72 -0
  108. package/dist/src/ui/tui/utils/with-retry.d.ts +12 -0
  109. package/dist/src/ui/tui/utils/with-retry.js +32 -0
  110. package/dist/src/ui/tui/utils/with-timeout.d.ts +10 -0
  111. package/dist/src/ui/tui/utils/with-timeout.js +24 -0
  112. package/dist/src/utils/ampli-settings.d.ts +1 -1
  113. package/dist/src/utils/ampli-settings.js +15 -5
  114. package/dist/src/utils/api-key-store.js +5 -5
  115. package/dist/src/utils/atomic-write.d.ts +15 -0
  116. package/dist/src/utils/atomic-write.js +34 -0
  117. package/dist/src/utils/setup-utils.js +2 -2
  118. package/dist/src/utils/token-refresh.d.ts +22 -0
  119. package/dist/src/utils/token-refresh.js +79 -0
  120. package/dist/src/utils/wizard-abort.js +6 -1
  121. package/package.json +6 -6
  122. package/skills/instrumentation/add-analytics-instrumentation/SKILL.md +142 -0
  123. package/skills/instrumentation/diff-intake/SKILL.md +128 -0
  124. package/skills/instrumentation/discover-analytics-patterns/SKILL.md +185 -0
  125. package/skills/instrumentation/discover-event-surfaces/SKILL.md +322 -0
  126. package/skills/instrumentation/discover-event-surfaces/references/best-practices.md +563 -0
  127. package/skills/instrumentation/instrument-events/SKILL.md +169 -0
  128. package/skills/instrumentation/instrument-events/references/best-practices.md +563 -0
  129. package/skills/integration/integration-android/SKILL.md +49 -0
  130. package/skills/integration/integration-android/references/EXAMPLE.md +1977 -0
  131. package/skills/integration/integration-android/references/amplitude-quickstart.md +1845 -0
  132. package/skills/integration/integration-android/references/analytics.md +1778 -0
  133. package/skills/integration/integration-android/references/basic-integration-1.0-begin.md +43 -0
  134. package/skills/integration/integration-android/references/basic-integration-1.1-edit.md +35 -0
  135. package/skills/integration/integration-android/references/basic-integration-1.2-revise.md +23 -0
  136. package/skills/integration/integration-android/references/basic-integration-1.3-conclude.md +57 -0
  137. package/skills/integration/integration-angular/SKILL.md +49 -0
  138. package/skills/integration/integration-angular/references/EXAMPLE.md +899 -0
  139. package/skills/integration/integration-angular/references/amplitude-quickstart.md +1845 -0
  140. package/skills/integration/integration-angular/references/basic-integration-1.0-begin.md +43 -0
  141. package/skills/integration/integration-angular/references/basic-integration-1.1-edit.md +35 -0
  142. package/skills/integration/integration-angular/references/basic-integration-1.2-revise.md +23 -0
  143. package/skills/integration/integration-angular/references/basic-integration-1.3-conclude.md +57 -0
  144. package/skills/integration/integration-angular/references/browser-sdk-2.md +4680 -0
  145. package/skills/integration/integration-astro-hybrid/SKILL.md +56 -0
  146. package/skills/integration/integration-astro-hybrid/references/EXAMPLE.md +1095 -0
  147. package/skills/integration/integration-astro-hybrid/references/amplitude-quickstart.md +1845 -0
  148. package/skills/integration/integration-astro-hybrid/references/basic-integration-1.0-begin.md +43 -0
  149. package/skills/integration/integration-astro-hybrid/references/basic-integration-1.1-edit.md +35 -0
  150. package/skills/integration/integration-astro-hybrid/references/basic-integration-1.2-revise.md +23 -0
  151. package/skills/integration/integration-astro-hybrid/references/basic-integration-1.3-conclude.md +57 -0
  152. package/skills/integration/integration-astro-hybrid/references/browser-sdk-2.md +4680 -0
  153. package/skills/integration/integration-astro-ssr/SKILL.md +52 -0
  154. package/skills/integration/integration-astro-ssr/references/EXAMPLE.md +1106 -0
  155. package/skills/integration/integration-astro-ssr/references/amplitude-quickstart.md +1845 -0
  156. package/skills/integration/integration-astro-ssr/references/basic-integration-1.0-begin.md +43 -0
  157. package/skills/integration/integration-astro-ssr/references/basic-integration-1.1-edit.md +35 -0
  158. package/skills/integration/integration-astro-ssr/references/basic-integration-1.2-revise.md +23 -0
  159. package/skills/integration/integration-astro-ssr/references/basic-integration-1.3-conclude.md +57 -0
  160. package/skills/integration/integration-astro-ssr/references/browser-sdk-2.md +4680 -0
  161. package/skills/integration/integration-astro-static/SKILL.md +49 -0
  162. package/skills/integration/integration-astro-static/references/EXAMPLE.md +910 -0
  163. package/skills/integration/integration-astro-static/references/amplitude-quickstart.md +1845 -0
  164. package/skills/integration/integration-astro-static/references/basic-integration-1.0-begin.md +43 -0
  165. package/skills/integration/integration-astro-static/references/basic-integration-1.1-edit.md +35 -0
  166. package/skills/integration/integration-astro-static/references/basic-integration-1.2-revise.md +23 -0
  167. package/skills/integration/integration-astro-static/references/basic-integration-1.3-conclude.md +57 -0
  168. package/skills/integration/integration-astro-static/references/browser-sdk-2.md +4680 -0
  169. package/skills/integration/integration-astro-view-transitions/SKILL.md +51 -0
  170. package/skills/integration/integration-astro-view-transitions/references/EXAMPLE.md +979 -0
  171. package/skills/integration/integration-astro-view-transitions/references/amplitude-quickstart.md +1845 -0
  172. package/skills/integration/integration-astro-view-transitions/references/basic-integration-1.0-begin.md +43 -0
  173. package/skills/integration/integration-astro-view-transitions/references/basic-integration-1.1-edit.md +35 -0
  174. package/skills/integration/integration-astro-view-transitions/references/basic-integration-1.2-revise.md +23 -0
  175. package/skills/integration/integration-astro-view-transitions/references/basic-integration-1.3-conclude.md +57 -0
  176. package/skills/integration/integration-astro-view-transitions/references/browser-sdk-2.md +4680 -0
  177. package/skills/integration/integration-django/SKILL.md +57 -0
  178. package/skills/integration/integration-django/references/EXAMPLE.md +1005 -0
  179. package/skills/integration/integration-django/references/amplitude-quickstart.md +1845 -0
  180. package/skills/integration/integration-django/references/basic-integration-1.0-begin.md +43 -0
  181. package/skills/integration/integration-django/references/basic-integration-1.1-edit.md +35 -0
  182. package/skills/integration/integration-django/references/basic-integration-1.2-revise.md +23 -0
  183. package/skills/integration/integration-django/references/basic-integration-1.3-conclude.md +57 -0
  184. package/skills/integration/integration-django/references/python.md +1424 -0
  185. package/skills/integration/integration-expo/SKILL.md +53 -0
  186. package/skills/integration/integration-expo/references/EXAMPLE.md +1291 -0
  187. package/skills/integration/integration-expo/references/amplitude-quickstart.md +1845 -0
  188. package/skills/integration/integration-expo/references/basic-integration-1.0-begin.md +43 -0
  189. package/skills/integration/integration-expo/references/basic-integration-1.1-edit.md +35 -0
  190. package/skills/integration/integration-expo/references/basic-integration-1.2-revise.md +23 -0
  191. package/skills/integration/integration-expo/references/basic-integration-1.3-conclude.md +57 -0
  192. package/skills/integration/integration-expo/references/react-native-sdk.md +2819 -0
  193. package/skills/integration/integration-fastapi/SKILL.md +57 -0
  194. package/skills/integration/integration-fastapi/references/EXAMPLE.md +1389 -0
  195. package/skills/integration/integration-fastapi/references/amplitude-quickstart.md +1845 -0
  196. package/skills/integration/integration-fastapi/references/basic-integration-1.0-begin.md +43 -0
  197. package/skills/integration/integration-fastapi/references/basic-integration-1.1-edit.md +35 -0
  198. package/skills/integration/integration-fastapi/references/basic-integration-1.2-revise.md +23 -0
  199. package/skills/integration/integration-fastapi/references/basic-integration-1.3-conclude.md +57 -0
  200. package/skills/integration/integration-fastapi/references/python.md +1424 -0
  201. package/skills/integration/integration-flask/SKILL.md +56 -0
  202. package/skills/integration/integration-flask/references/EXAMPLE.md +1130 -0
  203. package/skills/integration/integration-flask/references/amplitude-quickstart.md +1845 -0
  204. package/skills/integration/integration-flask/references/basic-integration-1.0-begin.md +43 -0
  205. package/skills/integration/integration-flask/references/basic-integration-1.1-edit.md +35 -0
  206. package/skills/integration/integration-flask/references/basic-integration-1.2-revise.md +23 -0
  207. package/skills/integration/integration-flask/references/basic-integration-1.3-conclude.md +57 -0
  208. package/skills/integration/integration-flask/references/python.md +1424 -0
  209. package/skills/integration/integration-javascript_node/SKILL.md +54 -0
  210. package/skills/integration/integration-javascript_node/references/EXAMPLE.md +365 -0
  211. package/skills/integration/integration-javascript_node/references/amplitude-quickstart.md +1845 -0
  212. package/skills/integration/integration-javascript_node/references/analytics.md +1778 -0
  213. package/skills/integration/integration-javascript_node/references/basic-integration-1.0-begin.md +43 -0
  214. package/skills/integration/integration-javascript_node/references/basic-integration-1.1-edit.md +35 -0
  215. package/skills/integration/integration-javascript_node/references/basic-integration-1.2-revise.md +23 -0
  216. package/skills/integration/integration-javascript_node/references/basic-integration-1.3-conclude.md +57 -0
  217. package/skills/integration/integration-javascript_web/SKILL.md +58 -0
  218. package/skills/integration/integration-javascript_web/references/EXAMPLE.md +451 -0
  219. package/skills/integration/integration-javascript_web/references/amplitude-quickstart.md +1845 -0
  220. package/skills/integration/integration-javascript_web/references/basic-integration-1.0-begin.md +43 -0
  221. package/skills/integration/integration-javascript_web/references/basic-integration-1.1-edit.md +35 -0
  222. package/skills/integration/integration-javascript_web/references/basic-integration-1.2-revise.md +23 -0
  223. package/skills/integration/integration-javascript_web/references/basic-integration-1.3-conclude.md +57 -0
  224. package/skills/integration/integration-javascript_web/references/browser-sdk-2.md +4680 -0
  225. package/skills/integration/integration-laravel/SKILL.md +52 -0
  226. package/skills/integration/integration-laravel/references/EXAMPLE.md +2039 -0
  227. package/skills/integration/integration-laravel/references/amplitude-quickstart.md +1845 -0
  228. package/skills/integration/integration-laravel/references/analytics.md +1778 -0
  229. package/skills/integration/integration-laravel/references/basic-integration-1.0-begin.md +43 -0
  230. package/skills/integration/integration-laravel/references/basic-integration-1.1-edit.md +35 -0
  231. package/skills/integration/integration-laravel/references/basic-integration-1.2-revise.md +23 -0
  232. package/skills/integration/integration-laravel/references/basic-integration-1.3-conclude.md +57 -0
  233. package/skills/integration/integration-nextjs-app-router/SKILL.md +54 -0
  234. package/skills/integration/integration-nextjs-app-router/references/EXAMPLE.md +673 -0
  235. package/skills/integration/integration-nextjs-app-router/references/amplitude-quickstart.md +1845 -0
  236. package/skills/integration/integration-nextjs-app-router/references/basic-integration-1.0-begin.md +43 -0
  237. package/skills/integration/integration-nextjs-app-router/references/basic-integration-1.1-edit.md +35 -0
  238. package/skills/integration/integration-nextjs-app-router/references/basic-integration-1.2-revise.md +23 -0
  239. package/skills/integration/integration-nextjs-app-router/references/basic-integration-1.3-conclude.md +57 -0
  240. package/skills/integration/integration-nextjs-app-router/references/browser-sdk-2.md +4680 -0
  241. package/skills/integration/integration-nextjs-pages-router/SKILL.md +54 -0
  242. package/skills/integration/integration-nextjs-pages-router/references/EXAMPLE.md +735 -0
  243. package/skills/integration/integration-nextjs-pages-router/references/amplitude-quickstart.md +1845 -0
  244. package/skills/integration/integration-nextjs-pages-router/references/basic-integration-1.0-begin.md +43 -0
  245. package/skills/integration/integration-nextjs-pages-router/references/basic-integration-1.1-edit.md +35 -0
  246. package/skills/integration/integration-nextjs-pages-router/references/basic-integration-1.2-revise.md +23 -0
  247. package/skills/integration/integration-nextjs-pages-router/references/basic-integration-1.3-conclude.md +57 -0
  248. package/skills/integration/integration-nextjs-pages-router/references/browser-sdk-2.md +4680 -0
  249. package/skills/integration/integration-nuxt-3.6/SKILL.md +46 -0
  250. package/skills/integration/integration-nuxt-3.6/references/EXAMPLE.md +8422 -0
  251. package/skills/integration/integration-nuxt-3.6/references/amplitude-quickstart.md +1845 -0
  252. package/skills/integration/integration-nuxt-3.6/references/basic-integration-1.0-begin.md +43 -0
  253. package/skills/integration/integration-nuxt-3.6/references/basic-integration-1.1-edit.md +35 -0
  254. package/skills/integration/integration-nuxt-3.6/references/basic-integration-1.2-revise.md +23 -0
  255. package/skills/integration/integration-nuxt-3.6/references/basic-integration-1.3-conclude.md +57 -0
  256. package/skills/integration/integration-nuxt-3.6/references/browser-sdk-2.md +4680 -0
  257. package/skills/integration/integration-nuxt-4/SKILL.md +46 -0
  258. package/skills/integration/integration-nuxt-4/references/EXAMPLE.md +8670 -0
  259. package/skills/integration/integration-nuxt-4/references/amplitude-quickstart.md +1845 -0
  260. package/skills/integration/integration-nuxt-4/references/basic-integration-1.0-begin.md +43 -0
  261. package/skills/integration/integration-nuxt-4/references/basic-integration-1.1-edit.md +35 -0
  262. package/skills/integration/integration-nuxt-4/references/basic-integration-1.2-revise.md +23 -0
  263. package/skills/integration/integration-nuxt-4/references/basic-integration-1.3-conclude.md +57 -0
  264. package/skills/integration/integration-nuxt-4/references/browser-sdk-2.md +4680 -0
  265. package/skills/integration/integration-python/SKILL.md +53 -0
  266. package/skills/integration/integration-python/references/EXAMPLE.md +445 -0
  267. package/skills/integration/integration-python/references/amplitude-quickstart.md +1845 -0
  268. package/skills/integration/integration-python/references/basic-integration-1.0-begin.md +43 -0
  269. package/skills/integration/integration-python/references/basic-integration-1.1-edit.md +35 -0
  270. package/skills/integration/integration-python/references/basic-integration-1.2-revise.md +23 -0
  271. package/skills/integration/integration-python/references/basic-integration-1.3-conclude.md +57 -0
  272. package/skills/integration/integration-python/references/python.md +1424 -0
  273. package/skills/integration/integration-react-native/SKILL.md +49 -0
  274. package/skills/integration/integration-react-native/references/EXAMPLE.md +2253 -0
  275. package/skills/integration/integration-react-native/references/amplitude-quickstart.md +1845 -0
  276. package/skills/integration/integration-react-native/references/basic-integration-1.0-begin.md +43 -0
  277. package/skills/integration/integration-react-native/references/basic-integration-1.1-edit.md +35 -0
  278. package/skills/integration/integration-react-native/references/basic-integration-1.2-revise.md +23 -0
  279. package/skills/integration/integration-react-native/references/basic-integration-1.3-conclude.md +57 -0
  280. package/skills/integration/integration-react-native/references/react-native-sdk.md +2819 -0
  281. package/skills/integration/integration-react-react-router-6/SKILL.md +53 -0
  282. package/skills/integration/integration-react-react-router-6/references/EXAMPLE.md +570 -0
  283. package/skills/integration/integration-react-react-router-6/references/amplitude-quickstart.md +1845 -0
  284. package/skills/integration/integration-react-react-router-6/references/basic-integration-1.0-begin.md +43 -0
  285. package/skills/integration/integration-react-react-router-6/references/basic-integration-1.1-edit.md +35 -0
  286. package/skills/integration/integration-react-react-router-6/references/basic-integration-1.2-revise.md +23 -0
  287. package/skills/integration/integration-react-react-router-6/references/basic-integration-1.3-conclude.md +57 -0
  288. package/skills/integration/integration-react-react-router-6/references/browser-sdk-2.md +4680 -0
  289. package/skills/integration/integration-react-react-router-7-data/SKILL.md +53 -0
  290. package/skills/integration/integration-react-react-router-7-data/references/EXAMPLE.md +830 -0
  291. package/skills/integration/integration-react-react-router-7-data/references/amplitude-quickstart.md +1845 -0
  292. package/skills/integration/integration-react-react-router-7-data/references/basic-integration-1.0-begin.md +43 -0
  293. package/skills/integration/integration-react-react-router-7-data/references/basic-integration-1.1-edit.md +35 -0
  294. package/skills/integration/integration-react-react-router-7-data/references/basic-integration-1.2-revise.md +23 -0
  295. package/skills/integration/integration-react-react-router-7-data/references/basic-integration-1.3-conclude.md +57 -0
  296. package/skills/integration/integration-react-react-router-7-data/references/browser-sdk-2.md +4680 -0
  297. package/skills/integration/integration-react-react-router-7-declarative/SKILL.md +53 -0
  298. package/skills/integration/integration-react-react-router-7-declarative/references/EXAMPLE.md +609 -0
  299. package/skills/integration/integration-react-react-router-7-declarative/references/amplitude-quickstart.md +1845 -0
  300. package/skills/integration/integration-react-react-router-7-declarative/references/basic-integration-1.0-begin.md +43 -0
  301. package/skills/integration/integration-react-react-router-7-declarative/references/basic-integration-1.1-edit.md +35 -0
  302. package/skills/integration/integration-react-react-router-7-declarative/references/basic-integration-1.2-revise.md +23 -0
  303. package/skills/integration/integration-react-react-router-7-declarative/references/basic-integration-1.3-conclude.md +57 -0
  304. package/skills/integration/integration-react-react-router-7-declarative/references/browser-sdk-2.md +4680 -0
  305. package/skills/integration/integration-react-react-router-7-framework/SKILL.md +53 -0
  306. package/skills/integration/integration-react-react-router-7-framework/references/EXAMPLE.md +1081 -0
  307. package/skills/integration/integration-react-react-router-7-framework/references/amplitude-quickstart.md +1845 -0
  308. package/skills/integration/integration-react-react-router-7-framework/references/basic-integration-1.0-begin.md +43 -0
  309. package/skills/integration/integration-react-react-router-7-framework/references/basic-integration-1.1-edit.md +35 -0
  310. package/skills/integration/integration-react-react-router-7-framework/references/basic-integration-1.2-revise.md +23 -0
  311. package/skills/integration/integration-react-react-router-7-framework/references/basic-integration-1.3-conclude.md +57 -0
  312. package/skills/integration/integration-react-react-router-7-framework/references/browser-sdk-2.md +4680 -0
  313. package/skills/integration/integration-react-tanstack-router-code-based/SKILL.md +57 -0
  314. package/skills/integration/integration-react-tanstack-router-code-based/references/EXAMPLE.md +659 -0
  315. package/skills/integration/integration-react-tanstack-router-code-based/references/amplitude-quickstart.md +1845 -0
  316. package/skills/integration/integration-react-tanstack-router-code-based/references/basic-integration-1.0-begin.md +43 -0
  317. package/skills/integration/integration-react-tanstack-router-code-based/references/basic-integration-1.1-edit.md +35 -0
  318. package/skills/integration/integration-react-tanstack-router-code-based/references/basic-integration-1.2-revise.md +23 -0
  319. package/skills/integration/integration-react-tanstack-router-code-based/references/basic-integration-1.3-conclude.md +57 -0
  320. package/skills/integration/integration-react-tanstack-router-code-based/references/browser-sdk-2.md +4680 -0
  321. package/skills/integration/integration-react-tanstack-router-file-based/SKILL.md +57 -0
  322. package/skills/integration/integration-react-tanstack-router-file-based/references/EXAMPLE.md +777 -0
  323. package/skills/integration/integration-react-tanstack-router-file-based/references/amplitude-quickstart.md +1845 -0
  324. package/skills/integration/integration-react-tanstack-router-file-based/references/basic-integration-1.0-begin.md +43 -0
  325. package/skills/integration/integration-react-tanstack-router-file-based/references/basic-integration-1.1-edit.md +35 -0
  326. package/skills/integration/integration-react-tanstack-router-file-based/references/basic-integration-1.2-revise.md +23 -0
  327. package/skills/integration/integration-react-tanstack-router-file-based/references/basic-integration-1.3-conclude.md +57 -0
  328. package/skills/integration/integration-react-tanstack-router-file-based/references/browser-sdk-2.md +4680 -0
  329. package/skills/integration/integration-react-vite/SKILL.md +53 -0
  330. package/skills/integration/integration-react-vite/references/EXAMPLE.md +542 -0
  331. package/skills/integration/integration-react-vite/references/amplitude-quickstart.md +1845 -0
  332. package/skills/integration/integration-react-vite/references/basic-integration-1.0-begin.md +43 -0
  333. package/skills/integration/integration-react-vite/references/basic-integration-1.1-edit.md +35 -0
  334. package/skills/integration/integration-react-vite/references/basic-integration-1.2-revise.md +23 -0
  335. package/skills/integration/integration-react-vite/references/basic-integration-1.3-conclude.md +57 -0
  336. package/skills/integration/integration-react-vite/references/browser-sdk-2.md +4680 -0
  337. package/skills/integration/integration-ruby/SKILL.md +50 -0
  338. package/skills/integration/integration-ruby/references/EXAMPLE.md +420 -0
  339. package/skills/integration/integration-ruby/references/amplitude-quickstart.md +1845 -0
  340. package/skills/integration/integration-ruby/references/analytics.md +1778 -0
  341. package/skills/integration/integration-ruby/references/basic-integration-1.0-begin.md +43 -0
  342. package/skills/integration/integration-ruby/references/basic-integration-1.1-edit.md +35 -0
  343. package/skills/integration/integration-ruby/references/basic-integration-1.2-revise.md +23 -0
  344. package/skills/integration/integration-ruby/references/basic-integration-1.3-conclude.md +57 -0
  345. package/skills/integration/integration-ruby-on-rails/SKILL.md +55 -0
  346. package/skills/integration/integration-ruby-on-rails/references/EXAMPLE.md +1013 -0
  347. package/skills/integration/integration-ruby-on-rails/references/amplitude-quickstart.md +1845 -0
  348. package/skills/integration/integration-ruby-on-rails/references/analytics.md +1778 -0
  349. package/skills/integration/integration-ruby-on-rails/references/basic-integration-1.0-begin.md +43 -0
  350. package/skills/integration/integration-ruby-on-rails/references/basic-integration-1.1-edit.md +35 -0
  351. package/skills/integration/integration-ruby-on-rails/references/basic-integration-1.2-revise.md +23 -0
  352. package/skills/integration/integration-ruby-on-rails/references/basic-integration-1.3-conclude.md +57 -0
  353. package/skills/integration/integration-sveltekit/SKILL.md +47 -0
  354. package/skills/integration/integration-sveltekit/references/EXAMPLE.md +14121 -0
  355. package/skills/integration/integration-sveltekit/references/amplitude-quickstart.md +1845 -0
  356. package/skills/integration/integration-sveltekit/references/basic-integration-1.0-begin.md +43 -0
  357. package/skills/integration/integration-sveltekit/references/basic-integration-1.1-edit.md +35 -0
  358. package/skills/integration/integration-sveltekit/references/basic-integration-1.2-revise.md +23 -0
  359. package/skills/integration/integration-sveltekit/references/basic-integration-1.3-conclude.md +57 -0
  360. package/skills/integration/integration-sveltekit/references/browser-sdk-2.md +4680 -0
  361. package/skills/integration/integration-swift/SKILL.md +49 -0
  362. package/skills/integration/integration-swift/references/EXAMPLE.md +660 -0
  363. package/skills/integration/integration-swift/references/amplitude-quickstart.md +1845 -0
  364. package/skills/integration/integration-swift/references/analytics.md +1778 -0
  365. package/skills/integration/integration-swift/references/basic-integration-1.0-begin.md +43 -0
  366. package/skills/integration/integration-swift/references/basic-integration-1.1-edit.md +35 -0
  367. package/skills/integration/integration-swift/references/basic-integration-1.2-revise.md +23 -0
  368. package/skills/integration/integration-swift/references/basic-integration-1.3-conclude.md +57 -0
  369. package/skills/integration/integration-tanstack-start/SKILL.md +58 -0
  370. package/skills/integration/integration-tanstack-start/references/EXAMPLE.md +998 -0
  371. package/skills/integration/integration-tanstack-start/references/amplitude-quickstart.md +1845 -0
  372. package/skills/integration/integration-tanstack-start/references/basic-integration-1.0-begin.md +43 -0
  373. package/skills/integration/integration-tanstack-start/references/basic-integration-1.1-edit.md +35 -0
  374. package/skills/integration/integration-tanstack-start/references/basic-integration-1.2-revise.md +23 -0
  375. package/skills/integration/integration-tanstack-start/references/basic-integration-1.3-conclude.md +57 -0
  376. package/skills/integration/integration-tanstack-start/references/browser-sdk-2.md +4680 -0
  377. package/skills/integration/integration-vue-3/SKILL.md +46 -0
  378. package/skills/integration/integration-vue-3/references/EXAMPLE.md +846 -0
  379. package/skills/integration/integration-vue-3/references/amplitude-quickstart.md +1845 -0
  380. package/skills/integration/integration-vue-3/references/basic-integration-1.0-begin.md +43 -0
  381. package/skills/integration/integration-vue-3/references/basic-integration-1.1-edit.md +35 -0
  382. package/skills/integration/integration-vue-3/references/basic-integration-1.2-revise.md +23 -0
  383. package/skills/integration/integration-vue-3/references/basic-integration-1.3-conclude.md +57 -0
  384. package/skills/integration/integration-vue-3/references/browser-sdk-2.md +4680 -0
  385. package/skills/taxonomy/amplitude-quickstart-taxonomy-agent/SKILL.md +228 -0
  386. package/dist/src/ui/tui/components/TitleBar.d.ts +0 -8
  387. package/dist/src/ui/tui/components/TitleBar.js +0 -27
  388. package/dist/src/ui/tui/primitives/KagiSmallWebViewer.d.ts +0 -7
  389. package/dist/src/ui/tui/primitives/KagiSmallWebViewer.js +0 -101
  390. package/dist/src/utils/anthropic-status.d.ts +0 -17
  391. package/dist/src/utils/anthropic-status.js +0 -51
@@ -0,0 +1,142 @@
1
+ ---
2
+ name: add-analytics-instrumentation
3
+ description: >
4
+ End-to-end analytics instrumentation workflow for a PR, branch, file,
5
+ directory, or feature. Reads the code, discovers what events should be
6
+ tracked, and produces a concrete instrumentation plan — all in one shot. Use
7
+ this skill whenever a user wants to add analytics to a PR, asks "instrument
8
+ this PR", "add tracking to this branch", "what analytics does this file need",
9
+ "instrument the checkout flow", "run the full instrumentation workflow", or any
10
+ request that implies going from code changes to a tracking plan. Also trigger
11
+ when the user gives you a PR link, branch name, file path, or feature
12
+ description and mentions analytics, events, or instrumentation. This is the
13
+ main entry point for the analytics workflow — prefer it over calling the
14
+ individual steps (diff-intake, discover-event-surfaces, instrument-events)
15
+ separately.
16
+ ---
17
+
18
+ # add-analytics-instrumentation
19
+
20
+ You are the orchestrator for the analytics instrumentation pipeline. Your job is
21
+ to figure out what the user wants to instrument, gather the relevant code, and
22
+ run the pipeline to produce a tracking plan.
23
+
24
+ ## Pipeline
25
+
26
+ ### Step 0: Capture intent
27
+
28
+ Before running anything, determine **what** the user wants to instrument. There
29
+ are four input types — infer the type from what the user has already provided in
30
+ the conversation. Only ask if it's genuinely ambiguous.
31
+
32
+ | Input type | How to recognize it | Example |
33
+ | -------------------- | ------------------------------------------------------------------------------ | --------------------------------------------------------------------------- |
34
+ | **PR** | A PR URL, PR number, or phrases like "this PR", "my PR" | `instrument PR #42`, `https://github.com/org/repo/pull/42` |
35
+ | **Branch** | A branch name or "this branch", "my branch", "current branch" | `instrument feature/checkout`, `add tracking to this branch` |
36
+ | **File / Directory** | A file path, directory path, or glob pattern | `instrument src/components/Checkout.tsx`, `add analytics to src/payments/` |
37
+ | **Feature** | A natural-language description of functionality, not a specific code reference | `instrument the onboarding flow`, `add tracking to the checkout experience` |
38
+
39
+ **Inference rules:**
40
+ - If the user provided a URL or `#number` → **PR**
41
+ - If the user provided something that looks like a branch name (contains `/`, no file extension, matches a git branch) → **Branch**
42
+ - If the user provided a path that exists on disk (file or directory) → **File / Directory**
43
+ - If none of the above match and the input is descriptive → **Feature**
44
+ - If the conversation already contains a PR link, branch name, or file path from earlier messages, use that instead of asking again
45
+
46
+ **If ambiguous**, ask the user:
47
+
48
+ > What would you like to instrument?
49
+ > 1. A specific file or directory
50
+ > 2. A PR
51
+ > 3. A branch
52
+ > 4. A feature (describe it and I'll find the relevant code)
53
+
54
+ Once you know the input type, proceed to the appropriate step:
55
+
56
+ - **PR or Branch** → go to Step 1 (diff-intake)
57
+ - **File / Directory** → go to Step 1a (direct file read)
58
+ - **Feature** → go to Step 1b (feature search)
59
+
60
+ ### Step 1: diff-intake skill (PR or Branch)
61
+
62
+ Invoke the `diff-intake` skill with the user's PR or branch reference.
63
+
64
+ It produces a `change_brief` YAML block.
65
+
66
+ Capture the full YAML output — step 2 consumes it verbatim. Skip to Step 2.
67
+
68
+ ### Step 1a: Direct file read (File / Directory)
69
+
70
+ Skip diff-intake entirely — there's no diff to analyze. Instead, build the
71
+ `change_brief` YAML yourself by reading the files directly.
72
+
73
+ 1. **Resolve the input.** If a directory, find all source files in it (skip
74
+ tests, config, lock files, generated code). If a single file, just use that.
75
+ 2. **Read each file** and summarize what it does — focus on user-facing behavior,
76
+ not implementation details.
77
+ 3. **Scan for existing instrumentation** using the same patterns as diff-intake:
78
+ `track(`, `trackEvent(`, `logEvent(`, `amplitude.track(`, `ampli.`, and
79
+ analytics-related imports.
80
+ 4. **Build the `change_brief` YAML** with `analytics_scope: high` (the user
81
+ explicitly asked to instrument these files, so assume they want tracking).
82
+ Set `primary: feat` and `classification.types: [feat]`. Populate
83
+ `file_summary_map` with each file's summary, layer, and existing
84
+ instrumentation.
85
+
86
+ Proceed to Step 2 with the YAML you built.
87
+
88
+ ### Step 1b: Feature search (Feature)
89
+
90
+ The user described a feature in natural language. Your job is to find the
91
+ relevant code, then build a `change_brief`.
92
+
93
+ 1. **Search git commit history** to find related commits. Use `git log --all --grep="<patterns>"`. This will find relevant commits. Then read the git commit body to understand the feature and relevant files. If the results are good, then proceed to generating the `change_brief` YAML
94
+ 2. **Search the codebase** for files related to the described feature. Use a
95
+ combination of:
96
+ - Grep for keywords from the feature description (component names, route
97
+ paths, function names, domain terms)
98
+ - Glob for likely file paths (e.g., `**/checkout/**`, `**/onboarding/**`)
99
+ - Read route definitions, navigation configs, or index files to find entry
100
+ points
101
+ 3. Build the `change_brief` YAML.
102
+
103
+ Proceed to Step 2 with the YAML you built.
104
+
105
+ ### Step 2: discover-event-surfaces
106
+
107
+ Invoke the `discover-event-surfaces` skill, passing the `change_brief` YAML
108
+ from step 1.
109
+
110
+ It produces an `event_candidates` YAML block. If there are zero candidates,
111
+ stop and tell the user the change has user-facing impact but no events worth
112
+ instrumenting were identified.
113
+
114
+ If event_candidates is empty, stop here and tell the user there's nothing to
115
+ instrument.
116
+
117
+ Capture the full YAML output — step 3 consumes it.
118
+
119
+ ### Step 3: instrument-events
120
+
121
+ Invoke the `instrument-events` skill, passing the `event_candidates` YAML from
122
+ step 2.
123
+
124
+ It produces a `trackingPlan` JSON with exact file locations, tracking code, and
125
+ property definitions for every critical (priority 3) event.
126
+
127
+ ## Presenting the result
128
+
129
+ After step 3 completes, present the tracking plan to the user. Walk through each
130
+ event briefly:
131
+
132
+ - What it tracks and why it matters
133
+ - Where the tracking call goes (file + function)
134
+ - What properties it sends
135
+
136
+ Then ask if they want to adjust anything or proceed to implementation.
137
+
138
+ ## Error handling
139
+
140
+ If any step fails (e.g., the PR doesn't exist, git commands error, no files to
141
+ analyze), surface the error clearly and stop. Don't try to continue with
142
+ incomplete data.
@@ -0,0 +1,128 @@
1
+ ---
2
+ name: diff-intake
3
+ description: >
4
+ Reads a PR or branch diff and produces a structured YAML change brief for
5
+ downstream analytics instrumentation skills. Use this as the first step
6
+ whenever a user shares a PR link, branch comparison, or raw diff and wants
7
+ to understand what changed, what needs tracking, or how to instrument a
8
+ feature. Trigger on phrases like "review this PR", "what changed in this
9
+ branch", "help me instrument this diff", "check analytics coverage for this
10
+ change", or any request to start the analytics review workflow.
11
+ ---
12
+
13
+ # diff-intake
14
+
15
+ Follow this skill step by step.
16
+ You are step 1 of the analytics instrumentation workflow. Produce a compact
17
+ YAML change brief that downstream skills (discover-event-surfaces,
18
+ instrument-events) will consume. Keep the output machine-readable and
19
+ precise — no prose around the YAML block.
20
+
21
+ ## Step 1: Gather changed files and categorize
22
+
23
+ Fetch the list of changed files from the source, then categorize each one.
24
+
25
+ ### Fetching changes
26
+ - **PR URL**
27
+ `gh pr view <number-or-url>`
28
+ `gh pr view <pr-number> --json files --jq '.files[] | "\(.path)\t+\(.additions) -\(.deletions)\t"'`
29
+ - **Branch comparison**
30
+ `git log <main|master>..<branch>`
31
+ `git diff --stat <main|master>..<branch>`
32
+ - **Ambiguous mention** (PR number, branch name): infer the right form and fetch without asking unless auth fails.
33
+
34
+ ### Categorize files
35
+ Assign each file to a category based on its path:
36
+ - **Core Logic**: application source (e.g. src/auth/login.py, database/models.ts)
37
+ - **Generated**: anything with `generated` in its path
38
+ - **Testing**: test files
39
+ - **Config / Dependencies**: package.json, docker-compose.yml, etc.
40
+ - **Documentation**: READMEs, docs/
41
+ - **Noise**: lock-files, .svg, auto-generated migrations
42
+
43
+ For each file, record: path, category, change type (Added / Modified / Deleted), and analytics likelihood (1–5).
44
+
45
+ ## Step 2: Build the file summary map
46
+ Read every single **Core Logic** file and create the file summary map.
47
+ Only process and include **Core Logic** files.
48
+
49
+ ### Fetching detailed diffs
50
+ - **PR**
51
+ `gh pr view <number-or-url> --json baseRefOid,headRefOid`
52
+ Using the response, get a detailed diff
53
+ `git diff <baseRefOid>...<headRefOid> -- <file1> <file2> <file_n>`
54
+ - **Branch comparison**
55
+ `git diff main..feature/foo -- <file1> <file2> <file_n>`
56
+
57
+ ### For each file, record
58
+ - `summary` — 2-line summary of what changed
59
+ - `stack` — frontend, backend, or shared
60
+
61
+ ### Also derive user-facing changes and touched surfaces
62
+
63
+ While reading the diff and the changed files, also produce the higher-level
64
+ signals that downstream event discovery needs:
65
+
66
+ - `user_facing_changes` — a flat list of concrete behavior changes that matter
67
+ to a user, PM, or analyst. Each item should describe what a user can now do,
68
+ see, or experience differently. Omit purely internal refactors.
69
+ - `surfaces.components` — the UI components, routes, pages, handlers, or other
70
+ interaction surfaces directly involved in those user-facing changes. Prefer
71
+ likely instrumentation points over low-level helpers.
72
+
73
+ For each surface, record:
74
+ - `name` — component, route, page, hook, or surface name
75
+ - `file` — repo-relative path
76
+ - `change` — `added`, `modified`, or `deleted`
77
+
78
+ If the change is backend-only or has no clear interactive surface, omit
79
+ `surfaces.components` rather than inventing one.
80
+
81
+ ## Step 3: Classify the overall change
82
+
83
+ Infer the change type and analytics scope:
84
+
85
+ | Type | Analytics implication |
86
+ | ---------------------------------------- | ------------------------------------------------- |
87
+ | feat | High — new surfaces likely need tracking |
88
+ | fix | Low–Medium — may affect existing event conditions |
89
+ | refactor | Low — tracking paths may move, regression risk |
90
+ | perf | Low — usually no tracking impact |
91
+ | revert | Medium — need to check what tracking was lost |
92
+ | style / docs / test / build / ci / chore | None — skip analytics analysis |
93
+
94
+ `analytics_scope` = highest implication present:
95
+ - `none` — only no-impact types
96
+ - `low` — only perf/refactor
97
+ - `medium` — fix
98
+ - `high` — any feature or capability addition
99
+
100
+ If `analytics_scope` is `none`, emit the brief and note that downstream skills are not needed.
101
+
102
+ ## Step 4: Emit the YAML brief
103
+ Output only the YAML block — no prose before or after. Follow the format exactly.
104
+ List each file individually in file_summary_map (no globs).
105
+
106
+ ```yaml
107
+ change_brief:
108
+ classification:
109
+ primary: feat # dominant conventional commit type
110
+ types: [feat, fix] # all types detected
111
+ analytics_scope: high # none | low | medium | high
112
+ stack: frontend # frontend | backend | fullstack
113
+ summary: "One sentence describing the overall change"
114
+ user_facing_changes:
115
+ - "Users can now upload an avatar with drag-and-drop and preview it before saving."
116
+ surfaces:
117
+ components:
118
+ - name: "AvatarUpload"
119
+ file: "src/components/AvatarUpload.tsx"
120
+ change: modified
121
+ file_summary_map: # each entry includes a layer field
122
+ - file: "src/components/AvatarUpload.tsx"
123
+ summary: "New component for avatar upload with drag-and-drop and preview"
124
+ layer: frontend # frontend | backend | shared
125
+ - file: "src/api/upload.ts"
126
+ summary: "Upload endpoint handler, validates file type and persists to S3"
127
+ layer: backend
128
+ ```
@@ -0,0 +1,185 @@
1
+ ---
2
+ name: discover-analytics-patterns
3
+ description: >
4
+ Discovers how analytics tracking calls are actually written in this codebase —
5
+ the concrete SDK calls, function signatures, and import patterns used to send
6
+ events. Use this skill whenever you need to understand the existing analytics
7
+ instrumentation patterns before adding new tracking, when someone asks "how do
8
+ we track events here?", "show me the analytics setup", "what's the analytics
9
+ pattern in this codebase?", or any time the instrument-events or
10
+ discover-event-surfaces skills are about to run and you need to know the
11
+ correct coding style to follow. Outputs a deduplicated list of patterns with
12
+ generalized examples and the file paths where each pattern appears, plus the
13
+ dominant event and property naming conventions inferred from those call sites.
14
+ Always use this skill before writing any analytics instrumentation code.
15
+ ---
16
+
17
+ # discover-analytics-patterns
18
+
19
+ Your goal is to find out **how** this codebase sends analytics events — not which
20
+ events exist, but the specific code patterns engineers use to fire a tracking
21
+ call. This output helps engineers add new events that look consistent with the
22
+ rest of the codebase. It should also tell downstream skills how event names and
23
+ property names are typically written in code here.
24
+
25
+ When determining naming conventions in this skill, use the following sources in strict order of preference:
26
+ 1. Events and properties observed from the Amplitude MCP server
27
+ 2. Real tracking call sites in the codebase
28
+ 3. The `taxonomy` skill at `../../taxonomy/amplitude-quickstart-taxonomy-agent/SKILL.md`
29
+
30
+ ---
31
+
32
+ ## Step 1: Find tracking calls
33
+
34
+ Use two approaches based on what's available.
35
+
36
+ ### If the Amplitude MCP is connected
37
+
38
+ Call `get_events` (or equivalent) to fetch a sample of event names from the
39
+ project. Use those results to choose a few representative non-system product
40
+ events, then call `get_event_properties` for those events to inspect real
41
+ property names. This is your primary naming reference.
42
+
43
+ Do not infer naming conventions from bracket-prefixed Amplitude system names
44
+ such as `[Amplitude], [Guides-Surveys], [Assistant], [Experiment]` for either events or properties. Exclude those from
45
+ pattern detection. If the MCP sample is dominated by Amplitude system names or otherwise does not provide enough evidence, fall back to codebase
46
+ inference for naming.
47
+
48
+ Then search the codebase for the sampled non-system event names using Grep to
49
+ locate the actual tracking call sites.
50
+
51
+ ### If the Amplitude MCP is not available (fallback)
52
+
53
+ Search the codebase for these signals using Grep. Cast a wide net — you can
54
+ narrow down after:
55
+
56
+ | What to search for | Why |
57
+ | -------------------------------------------------------- | ------------------------------------------------- |
58
+ | `\.track\(` | Generic `.track()` method calls |
59
+ | `ampli\.` | Ampli typed SDK calls (e.g. `ampli.myEvent(...)`) |
60
+ | `amplitude\.track\|amplitude\.logEvent` | Direct Amplitude SDK calls |
61
+ | `sendEvent` | Custom wrapper method names |
62
+ | `from.*amplitude\|import.*amplitude\|require.*amplitude` | Import statements |
63
+ | `https://api2\.amplitude\.com/2/httpapi` | HTTP API calls |
64
+
65
+ Also actively look for custom analytics wrappers — a codebase often wraps the
66
+ raw SDK in a utility like `trackEvent()`, `track()`, or a React hook like
67
+ `useAnalytics()` or `useTracking()`. Search for these by looking for functions
68
+ that call into Amplitude internally. **Treat each wrapper as its own pattern,
69
+ separate from the underlying SDK call**, even if it ultimately calls
70
+ `amplitude.track()` underneath. Engineers who encounter the wrapper will use
71
+ *it*, not the raw SDK — so it's the more important pattern to document.
72
+
73
+ To find wrappers: search for files that import the Amplitude SDK, then check
74
+ whether any of those files export a function or hook that other parts of the
75
+ codebase import and use for tracking.
76
+
77
+ Exclude test files (`.test.`, `.spec.`, `__tests__`) and mock files unless they
78
+ are the *only* place a pattern appears.
79
+
80
+ ---
81
+
82
+ ## Step 2: Group by pattern
83
+
84
+ Two call sites use the **same pattern** if they share the same:
85
+ - Library/SDK/function being called
86
+ - Method name
87
+ - Argument structure (even if the event name or properties differ)
88
+
89
+ For example, these are the **same** pattern:
90
+ ```ts
91
+ amplitude.track('Page Viewed', { page: '/home' })
92
+ amplitude.track('Button Clicked', { label: 'signup' })
93
+ ```
94
+
95
+ But these are **different** patterns — always keep them separate:
96
+ ```ts
97
+ amplitude.track('Page Viewed', { page: '/home' }) // direct SDK — one pattern
98
+ ampli.pageViewed({ page: '/home' }) // Ampli typed method — different pattern
99
+ trackEvent('Page Viewed', { page: '/home' }) // custom wrapper — also a separate pattern
100
+ ```
101
+
102
+ A custom wrapper is always its own pattern, even if it delegates to the SDK
103
+ underneath. When documenting a wrapper pattern, note what it wraps (e.g.,
104
+ "Custom hook wrapping `amplitude.track()`") so engineers understand the layering.
105
+
106
+ ---
107
+
108
+ ## Step 3: Resolve naming conventions
109
+
110
+ Resolve two conventions separately:
111
+
112
+ - `event_naming_convention` — casing, separators, word order, prefixes, and
113
+ tense used for event names in instrumentation code. Examples: `Title Case`,
114
+ `snake_case`, `[Prefix] Action`, object-first vs action-first.
115
+ - `property_naming_convention` — casing, separators, and common suffix/prefix
116
+ patterns used for event properties. Examples: `snake_case`, `camelCase`,
117
+ `*_id`, `is_*`, flat keys vs nested objects.
118
+
119
+ Use this precedence order:
120
+
121
+ 1. **Amplitude MCP first.** If the observed `eventType` values and
122
+ property names returned by `get_event_properties` for a few representative
123
+ non-system events show a clear dominant convention, use that. Do not use
124
+ bracket-prefixed Amplitude system names as naming evidence.
125
+ 2. **Codebase second.** If the MCP evidence is unavailable, sparse, or
126
+ inconsistent, infer the dominant convention from nearby, real tracking call
127
+ sites in the repository. If the codebase shows multiple conventions, call
128
+ out the dominant one and note meaningful local exceptions.
129
+ 3. **Taxonomy fallback last.** If neither MCP nor codebase evidence is
130
+ clear enough, fall back to the `taxonomy` skill at `../../taxonomy/amplitude-quickstart-taxonomy-agent/SKILL.md`.
131
+
132
+ Do not guess. If one or both conventions remain unclear even after checking
133
+ those sources, say so explicitly.
134
+
135
+ ---
136
+
137
+ ## Step 4: Output
138
+
139
+ Start with a short conventions section, then list each unique pattern.
140
+
141
+ ```yaml
142
+ event_naming_convention: "<from MCP if clear, otherwise codebase, otherwise taxonomy skill, or 'insufficient evidence'>"
143
+ property_naming_convention: "<from MCP if clear, otherwise codebase, otherwise taxonomy skill, or 'insufficient evidence'>"
144
+ ```
145
+
146
+ Then, for each unique pattern, output a section in this format:
147
+
148
+ ---
149
+
150
+ ### Pattern: `<short descriptive name>`
151
+
152
+ **Description**: What this pattern does and when it's typically used in this
153
+ codebase (e.g., "Used throughout the React frontend for user action tracking").
154
+
155
+ **Example** (generalized):
156
+ ```<language>
157
+ // show the import(s) needed
158
+ import { amplitude } from '@/lib/analytics'
159
+
160
+ // show a representative tracking call with placeholder names
161
+ amplitude.track('Event Name', {
162
+ propertyOne: value,
163
+ propertyTwo: value,
164
+ })
165
+ ```
166
+
167
+ **Relevant paths**:
168
+ - `src/path/to/file.ts`
169
+ - `src/another/file.tsx`
170
+
171
+ ---
172
+
173
+ List patterns from most common (most file paths) to least common.
174
+
175
+ If two patterns are always used together (e.g., an import + a call), show them
176
+ together in one example.
177
+
178
+ ---
179
+
180
+ ## Step 5: Handle no results
181
+
182
+ If no tracking calls are found with any search strategy, say so clearly. Suggest
183
+ that the user check whether Amplitude (or another analytics library) has been set
184
+ up in the project, and offer to search for other analytics libraries (Segment,
185
+ Mixpanel, PostHog, etc.) if relevant.