@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.
- package/README.md +171 -74
- package/dist/bin.js +338 -222
- package/dist/src/lib/agent-interface.js +64 -9
- package/dist/src/lib/agent-runner.js +1 -10
- package/dist/src/lib/api.d.ts +22 -4
- package/dist/src/lib/api.js +114 -12
- package/dist/src/lib/commandments.js +14 -1
- package/dist/src/lib/constants.d.ts +6 -5
- package/dist/src/lib/constants.js +13 -13
- package/dist/src/lib/credential-resolution.d.ts +45 -0
- package/dist/src/lib/credential-resolution.js +311 -0
- package/dist/src/lib/exit-codes.d.ts +10 -0
- package/dist/src/lib/exit-codes.js +12 -0
- package/dist/src/lib/health-checks/statuspage.d.ts +1 -0
- package/dist/src/lib/health-checks/statuspage.js +5 -1
- package/dist/src/lib/mode-config.d.ts +14 -0
- package/dist/src/lib/mode-config.js +14 -0
- package/dist/src/lib/session-checkpoint.d.ts +27 -0
- package/dist/src/lib/session-checkpoint.js +134 -0
- package/dist/src/lib/wizard-session.d.ts +44 -1
- package/dist/src/lib/wizard-session.js +70 -14
- package/dist/src/lib/wizard-tools.js +19 -4
- package/dist/src/steps/add-mcp-server-to-clients/clients/claude.d.ts +3 -0
- package/dist/src/steps/add-mcp-server-to-clients/clients/claude.js +6 -0
- package/dist/src/steps/add-mcp-server-to-clients/clients/cursor.js +3 -1
- package/dist/src/ui/agent-ui.d.ts +91 -0
- package/dist/src/ui/agent-ui.js +277 -0
- package/dist/src/ui/logging-ui.js +1 -1
- package/dist/src/ui/tui/App.d.ts +12 -0
- package/dist/src/ui/tui/App.js +29 -18
- package/dist/src/ui/tui/components/AmplitudeLogo.js +16 -17
- package/dist/src/ui/tui/components/AmplitudeTextLogo.d.ts +0 -2
- package/dist/src/ui/tui/components/AmplitudeTextLogo.js +53 -18
- package/dist/src/ui/tui/components/BrailleSpinner.d.ts +8 -0
- package/dist/src/ui/tui/components/BrailleSpinner.js +15 -0
- package/dist/src/ui/tui/components/ConsoleView.d.ts +8 -11
- package/dist/src/ui/tui/components/ConsoleView.js +51 -34
- package/dist/src/ui/tui/components/HeaderBar.d.ts +12 -0
- package/dist/src/ui/tui/components/HeaderBar.js +17 -0
- package/dist/src/ui/tui/components/JourneyStepper.d.ts +16 -0
- package/dist/src/ui/tui/components/JourneyStepper.js +83 -0
- package/dist/src/ui/tui/components/KeyHintBar.d.ts +19 -0
- package/dist/src/ui/tui/components/KeyHintBar.js +20 -0
- package/dist/src/ui/tui/console-commands.d.ts +1 -2
- package/dist/src/ui/tui/console-commands.js +48 -7
- package/dist/src/ui/tui/flows.d.ts +1 -1
- package/dist/src/ui/tui/flows.js +1 -1
- package/dist/src/ui/tui/hooks/useAsyncEffect.d.ts +15 -0
- package/dist/src/ui/tui/hooks/useAsyncEffect.js +35 -0
- package/dist/src/ui/tui/hooks/useWizardStore.d.ts +9 -0
- package/dist/src/ui/tui/hooks/useWizardStore.js +11 -0
- package/dist/src/ui/tui/ink-ui.js +1 -1
- package/dist/src/ui/tui/primitives/DissolveTransition.js +4 -5
- package/dist/src/ui/tui/primitives/EventPlanViewer.d.ts +3 -1
- package/dist/src/ui/tui/primitives/EventPlanViewer.js +8 -3
- package/dist/src/ui/tui/primitives/ProgressList.js +1 -1
- package/dist/src/ui/tui/primitives/SlashCommandInput.js +19 -4
- package/dist/src/ui/tui/primitives/SplitView.d.ts +2 -1
- package/dist/src/ui/tui/primitives/SplitView.js +10 -2
- package/dist/src/ui/tui/primitives/TabContainer.js +10 -2
- package/dist/src/ui/tui/primitives/index.d.ts +0 -1
- package/dist/src/ui/tui/primitives/index.js +0 -1
- package/dist/src/ui/tui/router.js +1 -1
- package/dist/src/ui/tui/screen-registry.d.ts +0 -7
- package/dist/src/ui/tui/screen-registry.js +13 -4
- package/dist/src/ui/tui/screens/ActivationOptionsScreen.d.ts +2 -2
- package/dist/src/ui/tui/screens/ActivationOptionsScreen.js +8 -8
- package/dist/src/ui/tui/screens/AuthScreen.js +57 -27
- package/dist/src/ui/tui/screens/ChecklistScreen.d.ts +2 -12
- package/dist/src/ui/tui/screens/ChecklistScreen.js +22 -33
- package/dist/src/ui/tui/screens/DataIngestionCheckScreen.d.ts +3 -12
- package/dist/src/ui/tui/screens/DataIngestionCheckScreen.js +109 -39
- package/dist/src/ui/tui/screens/DataSetupScreen.d.ts +3 -3
- package/dist/src/ui/tui/screens/DataSetupScreen.js +17 -10
- package/dist/src/ui/tui/screens/IntroScreen.d.ts +5 -3
- package/dist/src/ui/tui/screens/IntroScreen.js +132 -41
- package/dist/src/ui/tui/screens/LoginScreen.d.ts +1 -1
- package/dist/src/ui/tui/screens/LoginScreen.js +4 -4
- package/dist/src/ui/tui/screens/LogoutScreen.d.ts +4 -2
- package/dist/src/ui/tui/screens/LogoutScreen.js +17 -5
- package/dist/src/ui/tui/screens/McpScreen.d.ts +4 -4
- package/dist/src/ui/tui/screens/McpScreen.js +25 -17
- package/dist/src/ui/tui/screens/OutageScreen.d.ts +1 -1
- package/dist/src/ui/tui/screens/OutageScreen.js +5 -5
- package/dist/src/ui/tui/screens/OutroScreen.d.ts +5 -0
- package/dist/src/ui/tui/screens/OutroScreen.js +21 -14
- package/dist/src/ui/tui/screens/RegionSelectScreen.js +15 -13
- package/dist/src/ui/tui/screens/RunScreen.d.ts +7 -5
- package/dist/src/ui/tui/screens/RunScreen.js +102 -157
- package/dist/src/ui/tui/screens/SettingsOverrideScreen.d.ts +1 -1
- package/dist/src/ui/tui/screens/SettingsOverrideScreen.js +6 -5
- package/dist/src/ui/tui/screens/SetupScreen.d.ts +1 -1
- package/dist/src/ui/tui/screens/SetupScreen.js +7 -7
- package/dist/src/ui/tui/screens/SlackScreen.d.ts +2 -2
- package/dist/src/ui/tui/screens/SlackScreen.js +60 -35
- package/dist/src/ui/tui/session-constants.d.ts +41 -0
- package/dist/src/ui/tui/session-constants.js +38 -0
- package/dist/src/ui/tui/start-tui.d.ts +3 -1
- package/dist/src/ui/tui/start-tui.js +14 -10
- package/dist/src/ui/tui/store.d.ts +2 -1
- package/dist/src/ui/tui/store.js +33 -7
- package/dist/src/ui/tui/styles.d.ts +75 -19
- package/dist/src/ui/tui/styles.js +101 -19
- package/dist/src/ui/tui/utils/classify-error.d.ts +14 -0
- package/dist/src/ui/tui/utils/classify-error.js +90 -0
- package/dist/src/ui/tui/utils/diagnostics.d.ts +21 -0
- package/dist/src/ui/tui/utils/diagnostics.js +72 -0
- package/dist/src/ui/tui/utils/with-retry.d.ts +12 -0
- package/dist/src/ui/tui/utils/with-retry.js +32 -0
- package/dist/src/ui/tui/utils/with-timeout.d.ts +10 -0
- package/dist/src/ui/tui/utils/with-timeout.js +24 -0
- package/dist/src/utils/ampli-settings.d.ts +1 -1
- package/dist/src/utils/ampli-settings.js +15 -5
- package/dist/src/utils/api-key-store.js +5 -5
- package/dist/src/utils/atomic-write.d.ts +15 -0
- package/dist/src/utils/atomic-write.js +34 -0
- package/dist/src/utils/setup-utils.js +2 -2
- package/dist/src/utils/token-refresh.d.ts +22 -0
- package/dist/src/utils/token-refresh.js +79 -0
- package/dist/src/utils/wizard-abort.js +6 -1
- package/package.json +6 -6
- package/skills/instrumentation/add-analytics-instrumentation/SKILL.md +142 -0
- package/skills/instrumentation/diff-intake/SKILL.md +128 -0
- package/skills/instrumentation/discover-analytics-patterns/SKILL.md +185 -0
- package/skills/instrumentation/discover-event-surfaces/SKILL.md +322 -0
- package/skills/instrumentation/discover-event-surfaces/references/best-practices.md +563 -0
- package/skills/instrumentation/instrument-events/SKILL.md +169 -0
- package/skills/instrumentation/instrument-events/references/best-practices.md +563 -0
- package/skills/integration/integration-android/SKILL.md +49 -0
- package/skills/integration/integration-android/references/EXAMPLE.md +1977 -0
- package/skills/integration/integration-android/references/amplitude-quickstart.md +1845 -0
- package/skills/integration/integration-android/references/analytics.md +1778 -0
- package/skills/integration/integration-android/references/basic-integration-1.0-begin.md +43 -0
- package/skills/integration/integration-android/references/basic-integration-1.1-edit.md +35 -0
- package/skills/integration/integration-android/references/basic-integration-1.2-revise.md +23 -0
- package/skills/integration/integration-android/references/basic-integration-1.3-conclude.md +57 -0
- package/skills/integration/integration-angular/SKILL.md +49 -0
- package/skills/integration/integration-angular/references/EXAMPLE.md +899 -0
- package/skills/integration/integration-angular/references/amplitude-quickstart.md +1845 -0
- package/skills/integration/integration-angular/references/basic-integration-1.0-begin.md +43 -0
- package/skills/integration/integration-angular/references/basic-integration-1.1-edit.md +35 -0
- package/skills/integration/integration-angular/references/basic-integration-1.2-revise.md +23 -0
- package/skills/integration/integration-angular/references/basic-integration-1.3-conclude.md +57 -0
- package/skills/integration/integration-angular/references/browser-sdk-2.md +4680 -0
- package/skills/integration/integration-astro-hybrid/SKILL.md +56 -0
- package/skills/integration/integration-astro-hybrid/references/EXAMPLE.md +1095 -0
- package/skills/integration/integration-astro-hybrid/references/amplitude-quickstart.md +1845 -0
- package/skills/integration/integration-astro-hybrid/references/basic-integration-1.0-begin.md +43 -0
- package/skills/integration/integration-astro-hybrid/references/basic-integration-1.1-edit.md +35 -0
- package/skills/integration/integration-astro-hybrid/references/basic-integration-1.2-revise.md +23 -0
- package/skills/integration/integration-astro-hybrid/references/basic-integration-1.3-conclude.md +57 -0
- package/skills/integration/integration-astro-hybrid/references/browser-sdk-2.md +4680 -0
- package/skills/integration/integration-astro-ssr/SKILL.md +52 -0
- package/skills/integration/integration-astro-ssr/references/EXAMPLE.md +1106 -0
- package/skills/integration/integration-astro-ssr/references/amplitude-quickstart.md +1845 -0
- package/skills/integration/integration-astro-ssr/references/basic-integration-1.0-begin.md +43 -0
- package/skills/integration/integration-astro-ssr/references/basic-integration-1.1-edit.md +35 -0
- package/skills/integration/integration-astro-ssr/references/basic-integration-1.2-revise.md +23 -0
- package/skills/integration/integration-astro-ssr/references/basic-integration-1.3-conclude.md +57 -0
- package/skills/integration/integration-astro-ssr/references/browser-sdk-2.md +4680 -0
- package/skills/integration/integration-astro-static/SKILL.md +49 -0
- package/skills/integration/integration-astro-static/references/EXAMPLE.md +910 -0
- package/skills/integration/integration-astro-static/references/amplitude-quickstart.md +1845 -0
- package/skills/integration/integration-astro-static/references/basic-integration-1.0-begin.md +43 -0
- package/skills/integration/integration-astro-static/references/basic-integration-1.1-edit.md +35 -0
- package/skills/integration/integration-astro-static/references/basic-integration-1.2-revise.md +23 -0
- package/skills/integration/integration-astro-static/references/basic-integration-1.3-conclude.md +57 -0
- package/skills/integration/integration-astro-static/references/browser-sdk-2.md +4680 -0
- package/skills/integration/integration-astro-view-transitions/SKILL.md +51 -0
- package/skills/integration/integration-astro-view-transitions/references/EXAMPLE.md +979 -0
- package/skills/integration/integration-astro-view-transitions/references/amplitude-quickstart.md +1845 -0
- package/skills/integration/integration-astro-view-transitions/references/basic-integration-1.0-begin.md +43 -0
- package/skills/integration/integration-astro-view-transitions/references/basic-integration-1.1-edit.md +35 -0
- package/skills/integration/integration-astro-view-transitions/references/basic-integration-1.2-revise.md +23 -0
- package/skills/integration/integration-astro-view-transitions/references/basic-integration-1.3-conclude.md +57 -0
- package/skills/integration/integration-astro-view-transitions/references/browser-sdk-2.md +4680 -0
- package/skills/integration/integration-django/SKILL.md +57 -0
- package/skills/integration/integration-django/references/EXAMPLE.md +1005 -0
- package/skills/integration/integration-django/references/amplitude-quickstart.md +1845 -0
- package/skills/integration/integration-django/references/basic-integration-1.0-begin.md +43 -0
- package/skills/integration/integration-django/references/basic-integration-1.1-edit.md +35 -0
- package/skills/integration/integration-django/references/basic-integration-1.2-revise.md +23 -0
- package/skills/integration/integration-django/references/basic-integration-1.3-conclude.md +57 -0
- package/skills/integration/integration-django/references/python.md +1424 -0
- package/skills/integration/integration-expo/SKILL.md +53 -0
- package/skills/integration/integration-expo/references/EXAMPLE.md +1291 -0
- package/skills/integration/integration-expo/references/amplitude-quickstart.md +1845 -0
- package/skills/integration/integration-expo/references/basic-integration-1.0-begin.md +43 -0
- package/skills/integration/integration-expo/references/basic-integration-1.1-edit.md +35 -0
- package/skills/integration/integration-expo/references/basic-integration-1.2-revise.md +23 -0
- package/skills/integration/integration-expo/references/basic-integration-1.3-conclude.md +57 -0
- package/skills/integration/integration-expo/references/react-native-sdk.md +2819 -0
- package/skills/integration/integration-fastapi/SKILL.md +57 -0
- package/skills/integration/integration-fastapi/references/EXAMPLE.md +1389 -0
- package/skills/integration/integration-fastapi/references/amplitude-quickstart.md +1845 -0
- package/skills/integration/integration-fastapi/references/basic-integration-1.0-begin.md +43 -0
- package/skills/integration/integration-fastapi/references/basic-integration-1.1-edit.md +35 -0
- package/skills/integration/integration-fastapi/references/basic-integration-1.2-revise.md +23 -0
- package/skills/integration/integration-fastapi/references/basic-integration-1.3-conclude.md +57 -0
- package/skills/integration/integration-fastapi/references/python.md +1424 -0
- package/skills/integration/integration-flask/SKILL.md +56 -0
- package/skills/integration/integration-flask/references/EXAMPLE.md +1130 -0
- package/skills/integration/integration-flask/references/amplitude-quickstart.md +1845 -0
- package/skills/integration/integration-flask/references/basic-integration-1.0-begin.md +43 -0
- package/skills/integration/integration-flask/references/basic-integration-1.1-edit.md +35 -0
- package/skills/integration/integration-flask/references/basic-integration-1.2-revise.md +23 -0
- package/skills/integration/integration-flask/references/basic-integration-1.3-conclude.md +57 -0
- package/skills/integration/integration-flask/references/python.md +1424 -0
- package/skills/integration/integration-javascript_node/SKILL.md +54 -0
- package/skills/integration/integration-javascript_node/references/EXAMPLE.md +365 -0
- package/skills/integration/integration-javascript_node/references/amplitude-quickstart.md +1845 -0
- package/skills/integration/integration-javascript_node/references/analytics.md +1778 -0
- package/skills/integration/integration-javascript_node/references/basic-integration-1.0-begin.md +43 -0
- package/skills/integration/integration-javascript_node/references/basic-integration-1.1-edit.md +35 -0
- package/skills/integration/integration-javascript_node/references/basic-integration-1.2-revise.md +23 -0
- package/skills/integration/integration-javascript_node/references/basic-integration-1.3-conclude.md +57 -0
- package/skills/integration/integration-javascript_web/SKILL.md +58 -0
- package/skills/integration/integration-javascript_web/references/EXAMPLE.md +451 -0
- package/skills/integration/integration-javascript_web/references/amplitude-quickstart.md +1845 -0
- package/skills/integration/integration-javascript_web/references/basic-integration-1.0-begin.md +43 -0
- package/skills/integration/integration-javascript_web/references/basic-integration-1.1-edit.md +35 -0
- package/skills/integration/integration-javascript_web/references/basic-integration-1.2-revise.md +23 -0
- package/skills/integration/integration-javascript_web/references/basic-integration-1.3-conclude.md +57 -0
- package/skills/integration/integration-javascript_web/references/browser-sdk-2.md +4680 -0
- package/skills/integration/integration-laravel/SKILL.md +52 -0
- package/skills/integration/integration-laravel/references/EXAMPLE.md +2039 -0
- package/skills/integration/integration-laravel/references/amplitude-quickstart.md +1845 -0
- package/skills/integration/integration-laravel/references/analytics.md +1778 -0
- package/skills/integration/integration-laravel/references/basic-integration-1.0-begin.md +43 -0
- package/skills/integration/integration-laravel/references/basic-integration-1.1-edit.md +35 -0
- package/skills/integration/integration-laravel/references/basic-integration-1.2-revise.md +23 -0
- package/skills/integration/integration-laravel/references/basic-integration-1.3-conclude.md +57 -0
- package/skills/integration/integration-nextjs-app-router/SKILL.md +54 -0
- package/skills/integration/integration-nextjs-app-router/references/EXAMPLE.md +673 -0
- package/skills/integration/integration-nextjs-app-router/references/amplitude-quickstart.md +1845 -0
- package/skills/integration/integration-nextjs-app-router/references/basic-integration-1.0-begin.md +43 -0
- package/skills/integration/integration-nextjs-app-router/references/basic-integration-1.1-edit.md +35 -0
- package/skills/integration/integration-nextjs-app-router/references/basic-integration-1.2-revise.md +23 -0
- package/skills/integration/integration-nextjs-app-router/references/basic-integration-1.3-conclude.md +57 -0
- package/skills/integration/integration-nextjs-app-router/references/browser-sdk-2.md +4680 -0
- package/skills/integration/integration-nextjs-pages-router/SKILL.md +54 -0
- package/skills/integration/integration-nextjs-pages-router/references/EXAMPLE.md +735 -0
- package/skills/integration/integration-nextjs-pages-router/references/amplitude-quickstart.md +1845 -0
- package/skills/integration/integration-nextjs-pages-router/references/basic-integration-1.0-begin.md +43 -0
- package/skills/integration/integration-nextjs-pages-router/references/basic-integration-1.1-edit.md +35 -0
- package/skills/integration/integration-nextjs-pages-router/references/basic-integration-1.2-revise.md +23 -0
- package/skills/integration/integration-nextjs-pages-router/references/basic-integration-1.3-conclude.md +57 -0
- package/skills/integration/integration-nextjs-pages-router/references/browser-sdk-2.md +4680 -0
- package/skills/integration/integration-nuxt-3.6/SKILL.md +46 -0
- package/skills/integration/integration-nuxt-3.6/references/EXAMPLE.md +8422 -0
- package/skills/integration/integration-nuxt-3.6/references/amplitude-quickstart.md +1845 -0
- package/skills/integration/integration-nuxt-3.6/references/basic-integration-1.0-begin.md +43 -0
- package/skills/integration/integration-nuxt-3.6/references/basic-integration-1.1-edit.md +35 -0
- package/skills/integration/integration-nuxt-3.6/references/basic-integration-1.2-revise.md +23 -0
- package/skills/integration/integration-nuxt-3.6/references/basic-integration-1.3-conclude.md +57 -0
- package/skills/integration/integration-nuxt-3.6/references/browser-sdk-2.md +4680 -0
- package/skills/integration/integration-nuxt-4/SKILL.md +46 -0
- package/skills/integration/integration-nuxt-4/references/EXAMPLE.md +8670 -0
- package/skills/integration/integration-nuxt-4/references/amplitude-quickstart.md +1845 -0
- package/skills/integration/integration-nuxt-4/references/basic-integration-1.0-begin.md +43 -0
- package/skills/integration/integration-nuxt-4/references/basic-integration-1.1-edit.md +35 -0
- package/skills/integration/integration-nuxt-4/references/basic-integration-1.2-revise.md +23 -0
- package/skills/integration/integration-nuxt-4/references/basic-integration-1.3-conclude.md +57 -0
- package/skills/integration/integration-nuxt-4/references/browser-sdk-2.md +4680 -0
- package/skills/integration/integration-python/SKILL.md +53 -0
- package/skills/integration/integration-python/references/EXAMPLE.md +445 -0
- package/skills/integration/integration-python/references/amplitude-quickstart.md +1845 -0
- package/skills/integration/integration-python/references/basic-integration-1.0-begin.md +43 -0
- package/skills/integration/integration-python/references/basic-integration-1.1-edit.md +35 -0
- package/skills/integration/integration-python/references/basic-integration-1.2-revise.md +23 -0
- package/skills/integration/integration-python/references/basic-integration-1.3-conclude.md +57 -0
- package/skills/integration/integration-python/references/python.md +1424 -0
- package/skills/integration/integration-react-native/SKILL.md +49 -0
- package/skills/integration/integration-react-native/references/EXAMPLE.md +2253 -0
- package/skills/integration/integration-react-native/references/amplitude-quickstart.md +1845 -0
- package/skills/integration/integration-react-native/references/basic-integration-1.0-begin.md +43 -0
- package/skills/integration/integration-react-native/references/basic-integration-1.1-edit.md +35 -0
- package/skills/integration/integration-react-native/references/basic-integration-1.2-revise.md +23 -0
- package/skills/integration/integration-react-native/references/basic-integration-1.3-conclude.md +57 -0
- package/skills/integration/integration-react-native/references/react-native-sdk.md +2819 -0
- package/skills/integration/integration-react-react-router-6/SKILL.md +53 -0
- package/skills/integration/integration-react-react-router-6/references/EXAMPLE.md +570 -0
- package/skills/integration/integration-react-react-router-6/references/amplitude-quickstart.md +1845 -0
- package/skills/integration/integration-react-react-router-6/references/basic-integration-1.0-begin.md +43 -0
- package/skills/integration/integration-react-react-router-6/references/basic-integration-1.1-edit.md +35 -0
- package/skills/integration/integration-react-react-router-6/references/basic-integration-1.2-revise.md +23 -0
- package/skills/integration/integration-react-react-router-6/references/basic-integration-1.3-conclude.md +57 -0
- package/skills/integration/integration-react-react-router-6/references/browser-sdk-2.md +4680 -0
- package/skills/integration/integration-react-react-router-7-data/SKILL.md +53 -0
- package/skills/integration/integration-react-react-router-7-data/references/EXAMPLE.md +830 -0
- package/skills/integration/integration-react-react-router-7-data/references/amplitude-quickstart.md +1845 -0
- package/skills/integration/integration-react-react-router-7-data/references/basic-integration-1.0-begin.md +43 -0
- package/skills/integration/integration-react-react-router-7-data/references/basic-integration-1.1-edit.md +35 -0
- package/skills/integration/integration-react-react-router-7-data/references/basic-integration-1.2-revise.md +23 -0
- package/skills/integration/integration-react-react-router-7-data/references/basic-integration-1.3-conclude.md +57 -0
- package/skills/integration/integration-react-react-router-7-data/references/browser-sdk-2.md +4680 -0
- package/skills/integration/integration-react-react-router-7-declarative/SKILL.md +53 -0
- package/skills/integration/integration-react-react-router-7-declarative/references/EXAMPLE.md +609 -0
- package/skills/integration/integration-react-react-router-7-declarative/references/amplitude-quickstart.md +1845 -0
- package/skills/integration/integration-react-react-router-7-declarative/references/basic-integration-1.0-begin.md +43 -0
- package/skills/integration/integration-react-react-router-7-declarative/references/basic-integration-1.1-edit.md +35 -0
- package/skills/integration/integration-react-react-router-7-declarative/references/basic-integration-1.2-revise.md +23 -0
- package/skills/integration/integration-react-react-router-7-declarative/references/basic-integration-1.3-conclude.md +57 -0
- package/skills/integration/integration-react-react-router-7-declarative/references/browser-sdk-2.md +4680 -0
- package/skills/integration/integration-react-react-router-7-framework/SKILL.md +53 -0
- package/skills/integration/integration-react-react-router-7-framework/references/EXAMPLE.md +1081 -0
- package/skills/integration/integration-react-react-router-7-framework/references/amplitude-quickstart.md +1845 -0
- package/skills/integration/integration-react-react-router-7-framework/references/basic-integration-1.0-begin.md +43 -0
- package/skills/integration/integration-react-react-router-7-framework/references/basic-integration-1.1-edit.md +35 -0
- package/skills/integration/integration-react-react-router-7-framework/references/basic-integration-1.2-revise.md +23 -0
- package/skills/integration/integration-react-react-router-7-framework/references/basic-integration-1.3-conclude.md +57 -0
- package/skills/integration/integration-react-react-router-7-framework/references/browser-sdk-2.md +4680 -0
- package/skills/integration/integration-react-tanstack-router-code-based/SKILL.md +57 -0
- package/skills/integration/integration-react-tanstack-router-code-based/references/EXAMPLE.md +659 -0
- package/skills/integration/integration-react-tanstack-router-code-based/references/amplitude-quickstart.md +1845 -0
- package/skills/integration/integration-react-tanstack-router-code-based/references/basic-integration-1.0-begin.md +43 -0
- package/skills/integration/integration-react-tanstack-router-code-based/references/basic-integration-1.1-edit.md +35 -0
- package/skills/integration/integration-react-tanstack-router-code-based/references/basic-integration-1.2-revise.md +23 -0
- package/skills/integration/integration-react-tanstack-router-code-based/references/basic-integration-1.3-conclude.md +57 -0
- package/skills/integration/integration-react-tanstack-router-code-based/references/browser-sdk-2.md +4680 -0
- package/skills/integration/integration-react-tanstack-router-file-based/SKILL.md +57 -0
- package/skills/integration/integration-react-tanstack-router-file-based/references/EXAMPLE.md +777 -0
- package/skills/integration/integration-react-tanstack-router-file-based/references/amplitude-quickstart.md +1845 -0
- package/skills/integration/integration-react-tanstack-router-file-based/references/basic-integration-1.0-begin.md +43 -0
- package/skills/integration/integration-react-tanstack-router-file-based/references/basic-integration-1.1-edit.md +35 -0
- package/skills/integration/integration-react-tanstack-router-file-based/references/basic-integration-1.2-revise.md +23 -0
- package/skills/integration/integration-react-tanstack-router-file-based/references/basic-integration-1.3-conclude.md +57 -0
- package/skills/integration/integration-react-tanstack-router-file-based/references/browser-sdk-2.md +4680 -0
- package/skills/integration/integration-react-vite/SKILL.md +53 -0
- package/skills/integration/integration-react-vite/references/EXAMPLE.md +542 -0
- package/skills/integration/integration-react-vite/references/amplitude-quickstart.md +1845 -0
- package/skills/integration/integration-react-vite/references/basic-integration-1.0-begin.md +43 -0
- package/skills/integration/integration-react-vite/references/basic-integration-1.1-edit.md +35 -0
- package/skills/integration/integration-react-vite/references/basic-integration-1.2-revise.md +23 -0
- package/skills/integration/integration-react-vite/references/basic-integration-1.3-conclude.md +57 -0
- package/skills/integration/integration-react-vite/references/browser-sdk-2.md +4680 -0
- package/skills/integration/integration-ruby/SKILL.md +50 -0
- package/skills/integration/integration-ruby/references/EXAMPLE.md +420 -0
- package/skills/integration/integration-ruby/references/amplitude-quickstart.md +1845 -0
- package/skills/integration/integration-ruby/references/analytics.md +1778 -0
- package/skills/integration/integration-ruby/references/basic-integration-1.0-begin.md +43 -0
- package/skills/integration/integration-ruby/references/basic-integration-1.1-edit.md +35 -0
- package/skills/integration/integration-ruby/references/basic-integration-1.2-revise.md +23 -0
- package/skills/integration/integration-ruby/references/basic-integration-1.3-conclude.md +57 -0
- package/skills/integration/integration-ruby-on-rails/SKILL.md +55 -0
- package/skills/integration/integration-ruby-on-rails/references/EXAMPLE.md +1013 -0
- package/skills/integration/integration-ruby-on-rails/references/amplitude-quickstart.md +1845 -0
- package/skills/integration/integration-ruby-on-rails/references/analytics.md +1778 -0
- package/skills/integration/integration-ruby-on-rails/references/basic-integration-1.0-begin.md +43 -0
- package/skills/integration/integration-ruby-on-rails/references/basic-integration-1.1-edit.md +35 -0
- package/skills/integration/integration-ruby-on-rails/references/basic-integration-1.2-revise.md +23 -0
- package/skills/integration/integration-ruby-on-rails/references/basic-integration-1.3-conclude.md +57 -0
- package/skills/integration/integration-sveltekit/SKILL.md +47 -0
- package/skills/integration/integration-sveltekit/references/EXAMPLE.md +14121 -0
- package/skills/integration/integration-sveltekit/references/amplitude-quickstart.md +1845 -0
- package/skills/integration/integration-sveltekit/references/basic-integration-1.0-begin.md +43 -0
- package/skills/integration/integration-sveltekit/references/basic-integration-1.1-edit.md +35 -0
- package/skills/integration/integration-sveltekit/references/basic-integration-1.2-revise.md +23 -0
- package/skills/integration/integration-sveltekit/references/basic-integration-1.3-conclude.md +57 -0
- package/skills/integration/integration-sveltekit/references/browser-sdk-2.md +4680 -0
- package/skills/integration/integration-swift/SKILL.md +49 -0
- package/skills/integration/integration-swift/references/EXAMPLE.md +660 -0
- package/skills/integration/integration-swift/references/amplitude-quickstart.md +1845 -0
- package/skills/integration/integration-swift/references/analytics.md +1778 -0
- package/skills/integration/integration-swift/references/basic-integration-1.0-begin.md +43 -0
- package/skills/integration/integration-swift/references/basic-integration-1.1-edit.md +35 -0
- package/skills/integration/integration-swift/references/basic-integration-1.2-revise.md +23 -0
- package/skills/integration/integration-swift/references/basic-integration-1.3-conclude.md +57 -0
- package/skills/integration/integration-tanstack-start/SKILL.md +58 -0
- package/skills/integration/integration-tanstack-start/references/EXAMPLE.md +998 -0
- package/skills/integration/integration-tanstack-start/references/amplitude-quickstart.md +1845 -0
- package/skills/integration/integration-tanstack-start/references/basic-integration-1.0-begin.md +43 -0
- package/skills/integration/integration-tanstack-start/references/basic-integration-1.1-edit.md +35 -0
- package/skills/integration/integration-tanstack-start/references/basic-integration-1.2-revise.md +23 -0
- package/skills/integration/integration-tanstack-start/references/basic-integration-1.3-conclude.md +57 -0
- package/skills/integration/integration-tanstack-start/references/browser-sdk-2.md +4680 -0
- package/skills/integration/integration-vue-3/SKILL.md +46 -0
- package/skills/integration/integration-vue-3/references/EXAMPLE.md +846 -0
- package/skills/integration/integration-vue-3/references/amplitude-quickstart.md +1845 -0
- package/skills/integration/integration-vue-3/references/basic-integration-1.0-begin.md +43 -0
- package/skills/integration/integration-vue-3/references/basic-integration-1.1-edit.md +35 -0
- package/skills/integration/integration-vue-3/references/basic-integration-1.2-revise.md +23 -0
- package/skills/integration/integration-vue-3/references/basic-integration-1.3-conclude.md +57 -0
- package/skills/integration/integration-vue-3/references/browser-sdk-2.md +4680 -0
- package/skills/taxonomy/amplitude-quickstart-taxonomy-agent/SKILL.md +228 -0
- package/dist/src/ui/tui/components/TitleBar.d.ts +0 -8
- package/dist/src/ui/tui/components/TitleBar.js +0 -27
- package/dist/src/ui/tui/primitives/KagiSmallWebViewer.d.ts +0 -7
- package/dist/src/ui/tui/primitives/KagiSmallWebViewer.js +0 -101
- package/dist/src/utils/anthropic-status.d.ts +0 -17
- 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.
|