@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,322 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: discover-event-surfaces
|
|
3
|
+
description: >
|
|
4
|
+
Given a change_brief YAML (output from diff-intake), generates an exhaustive
|
|
5
|
+
list of candidate analytics events to instrument. Takes the perspective of an
|
|
6
|
+
engineer with a PM mindset — surfaces everything worth considering so a PM can
|
|
7
|
+
decide what actually matters. Use this as step 2 of the analytics
|
|
8
|
+
instrumentation workflow, immediately after diff-intake produces a
|
|
9
|
+
change_brief. Trigger whenever a user has a change_brief YAML and wants to
|
|
10
|
+
know what analytics events to add, or asks "what should I track for this PR",
|
|
11
|
+
"what events should I instrument", "generate event candidates", or any
|
|
12
|
+
request to surface analytics coverage gaps for a code change.
|
|
13
|
+
---
|
|
14
|
+
|
|
15
|
+
# discover-event-surfaces
|
|
16
|
+
|
|
17
|
+
You are step 2 of the analytics instrumentation workflow. Read a `change_brief`
|
|
18
|
+
YAML and produce an exhaustive candidate list of analytics events — named well,
|
|
19
|
+
organized by category, and ready for PM review.
|
|
20
|
+
|
|
21
|
+
Think like an engineer who ships the feature AND cares about whether it
|
|
22
|
+
succeeds. Generate events that answer product/business questions, not events
|
|
23
|
+
that mirror implementation details. Aim for **breadth and quality** — a
|
|
24
|
+
downstream skill will narrow the list.
|
|
25
|
+
|
|
26
|
+
Read the `taxonomy` skill at `../../taxonomy/amplitude-quickstart-taxonomy-agent/SKILL.md` to understand core
|
|
27
|
+
analytics philosophy and naming standards.
|
|
28
|
+
|
|
29
|
+
---
|
|
30
|
+
|
|
31
|
+
## 1. Parse the change_brief
|
|
32
|
+
|
|
33
|
+
- `classification.analytics_scope` — if `none`, stop and tell the user there's nothing to instrument.
|
|
34
|
+
- `summary` — one-line description of the change.
|
|
35
|
+
- `user_facing_changes` — primary signal. Each entry = something a user can now do or see differently.
|
|
36
|
+
- `surfaces.components` — modified UI components; where interactions happen.
|
|
37
|
+
- `file_summary_map` — read summaries for files in `surfaces` or touching user-facing logic. Skip tests/config/tooling.
|
|
38
|
+
|
|
39
|
+
## 2. Scan the codebase and map user flows
|
|
40
|
+
|
|
41
|
+
Before generating any events, build a concrete understanding of how users move
|
|
42
|
+
through the feature. The change_brief gives you file paths and summaries — now
|
|
43
|
+
read the actual code to trace the full journey.
|
|
44
|
+
|
|
45
|
+
### What to read
|
|
46
|
+
|
|
47
|
+
- Every file listed in `surfaces.components` — read them fully.
|
|
48
|
+
- Files from `file_summary_map` that touch user-facing logic (skip tests, config,
|
|
49
|
+
tooling).
|
|
50
|
+
- Follow imports and references one level out: if a component calls a hook, API
|
|
51
|
+
function, or navigates to another route, read that target file too. This is how
|
|
52
|
+
you discover steps the diff didn't touch but that are part of the same flow.
|
|
53
|
+
|
|
54
|
+
### What to look for
|
|
55
|
+
|
|
56
|
+
Trace the path a user takes from entry to outcome:
|
|
57
|
+
|
|
58
|
+
- **Entry points** — how does the user arrive? Route definitions, navigation
|
|
59
|
+
calls, menu items, links, feature flag gates.
|
|
60
|
+
- **Interaction sequence** — what does the user do step by step? Form fills,
|
|
61
|
+
selections, confirmations, uploads. Look at handler wiring (`onClick`,
|
|
62
|
+
`onSubmit`, `onChange`) and what state they mutate.
|
|
63
|
+
- **Async boundaries** — API calls, mutations, server actions. These are where
|
|
64
|
+
"attempted" becomes "succeeded" or "failed."
|
|
65
|
+
- **Terminal states** — success confirmations, error handling, redirects,
|
|
66
|
+
completion screens.
|
|
67
|
+
- **Branching paths** — conditionals that route users to different outcomes
|
|
68
|
+
(e.g., free vs paid, first-time vs returning).
|
|
69
|
+
|
|
70
|
+
### Produce a funnel hypothesis
|
|
71
|
+
|
|
72
|
+
Synthesize what you found into one or more funnels — ordered sequences of user
|
|
73
|
+
steps from entry to outcome. Each funnel should have:
|
|
74
|
+
|
|
75
|
+
- A descriptive name (e.g., "Property extraction flow", "Onboarding wizard")
|
|
76
|
+
- The ordered steps, each with the file and function/handler where it happens
|
|
77
|
+
- Which step is the **start** and which is the **end**
|
|
78
|
+
|
|
79
|
+
Not every change has a funnel. Single-action features (a toggle, a one-click
|
|
80
|
+
export) don't need one — just note that there's no multi-step flow. But when a
|
|
81
|
+
flow exists, mapping it here is what allows you to confidently assign funnel
|
|
82
|
+
start/end as critical later.
|
|
83
|
+
|
|
84
|
+
Keep the hypothesis grounded in code you actually read. Don't invent steps you
|
|
85
|
+
didn't see evidence for.
|
|
86
|
+
|
|
87
|
+
## 3. Determine naming conventions and fetch existing events
|
|
88
|
+
|
|
89
|
+
Invoke `discover-analytics-patterns` and use its
|
|
90
|
+
`event_naming_convention` and `property_naming_convention` outputs. That skill
|
|
91
|
+
owns the naming-resolution procedure and precedence order. Do not redefine it
|
|
92
|
+
here.
|
|
93
|
+
|
|
94
|
+
Before generating candidates, pull the project's existing event taxonomy so you can
|
|
95
|
+
avoid duplicates and match the naming convention already in use.
|
|
96
|
+
|
|
97
|
+
### Resolve the project
|
|
98
|
+
|
|
99
|
+
If the change_brief includes an Amplitude `projectId`, use it directly. Otherwise,
|
|
100
|
+
call `get_context` to resolve the project name or ask the user which project to
|
|
101
|
+
target. You need a `projectId` for the next call.
|
|
102
|
+
|
|
103
|
+
### Pull existing events
|
|
104
|
+
|
|
105
|
+
Call `get_events` with the resolved `projectId` (no cursor needed — just the first
|
|
106
|
+
page is enough for pattern detection). This returns event objects with fields like
|
|
107
|
+
`eventType`, `category`, `description`, etc.
|
|
108
|
+
|
|
109
|
+
### Build naming references and an existing event index
|
|
110
|
+
|
|
111
|
+
1. **Existing event index** — Collect all `eventType` values into a set. You'll
|
|
112
|
+
check candidates against this set in step 4 to avoid proposing events that are
|
|
113
|
+
already tracked. An event is a duplicate if its semantic meaning matches an
|
|
114
|
+
existing `eventType`, not just its exact string — e.g., if `Subscription Upgraded`
|
|
115
|
+
exists, don't propose `Plan Upgraded` for the same action.
|
|
116
|
+
|
|
117
|
+
## 4. Generate candidate events
|
|
118
|
+
|
|
119
|
+
Start from the funnel hypothesis. If you identified funnels in step 2, generate
|
|
120
|
+
events for the funnel start and end first — these are your anchors. Then fill in
|
|
121
|
+
candidates for intermediate steps and non-funnel surfaces.
|
|
122
|
+
|
|
123
|
+
For each `user_facing_change`, ask: *"If a user does this — what outcomes would a PM want to know about?"*
|
|
124
|
+
|
|
125
|
+
Generate from four categories (ordered by priority):
|
|
126
|
+
|
|
127
|
+
| Category | What it captures | When to include |
|
|
128
|
+
| -------------------- | ------------------------------------------------------------------------------------------------- | ---------------------------------------------------- |
|
|
129
|
+
| **business_outcome** | Revenue, retention, growth actions (purchases, subscription changes, conversion gates) | Change touches monetization or retention surface |
|
|
130
|
+
| **user_journey** | Meaningful state transitions (workflow completed, feature activated, onboarding finished) | Change introduces or alters a user journey step |
|
|
131
|
+
| **feature_success** | The "it worked" moment — confirmed outcome, not button click (document created, report generated) | Any new or materially changed feature |
|
|
132
|
+
| **friction_failure** | Where users fail, get stuck, or give up (errors, empty states, abandonment) | Complex multi-step interactions or error-prone flows |
|
|
133
|
+
|
|
134
|
+
### Deduplicate against existing events
|
|
135
|
+
|
|
136
|
+
After generating candidates, check each one against the **existing event index**
|
|
137
|
+
you built in step 3. For each candidate:
|
|
138
|
+
|
|
139
|
+
- **Exact match** — the `eventType` already exists verbatim. Drop the candidate.
|
|
140
|
+
- **Semantic match** — a different name tracks the same user action or outcome
|
|
141
|
+
(e.g., you proposed `Plan Upgraded` but `Subscription Upgraded` already exists
|
|
142
|
+
for the same action). Drop the candidate.
|
|
143
|
+
- **Partial overlap** — an existing event covers a broader action that subsumes
|
|
144
|
+
your candidate (e.g., `Checkout Completed` already exists and your candidate
|
|
145
|
+
`Payment Submitted` fires at the same moment). Drop unless the candidate captures
|
|
146
|
+
meaningfully different information.
|
|
147
|
+
|
|
148
|
+
If you drop a candidate because it already exists, note it in a
|
|
149
|
+
`already_tracked` list in the output so the user can see what's covered.
|
|
150
|
+
|
|
151
|
+
## 5. Quality filter
|
|
152
|
+
|
|
153
|
+
Every candidate must pass all three:
|
|
154
|
+
|
|
155
|
+
1. **Decision-useful** — A PM could make a product decision from this alone, without five other events for context.
|
|
156
|
+
2. **Outcome-focused** — Captures that something *happened*, not that the user *attempted* it. `Property Extracted` > `Extract Button Clicked`. Prefer confirmed outcomes; form submissions are acceptable when no server confirmation exists.
|
|
157
|
+
3. **Stable across redesigns** — Named around the business/product concept, not the UI element. If renaming a modal would make the event name stale, it's too coupled.
|
|
158
|
+
|
|
159
|
+
**Cut:** raw clicks/hovers without outcomes, internal technical actions (API callbacks, state updates), UI-versioned names (`modal_v2_submit`), sub-step-level granularity.
|
|
160
|
+
|
|
161
|
+
## 6. Name events
|
|
162
|
+
|
|
163
|
+
Use the naming conventions returned by `discover-analytics-patterns`.
|
|
164
|
+
New events should look like they belong with the rest of the instrumentation:
|
|
165
|
+
same casing, same word order, same delimiters, same prefix patterns, and the
|
|
166
|
+
same level of specificity.
|
|
167
|
+
|
|
168
|
+
If you later need to suggest property names in rationale or instrumentation
|
|
169
|
+
hints, use the `property_naming_convention` returned by
|
|
170
|
+
`discover-analytics-patterns`.
|
|
171
|
+
|
|
172
|
+
In all cases, use product-domain subjects (Property, User, Document), not code
|
|
173
|
+
names (PropertyItem, ActionStore).
|
|
174
|
+
|
|
175
|
+
| Good (Title Case convention) | Bad |
|
|
176
|
+
| ---------------------------- | -------------------------- |
|
|
177
|
+
| `Property Extracted` | `extract_property_clicked` |
|
|
178
|
+
| `Extract Type Configured` | `type_dropdown_changed` |
|
|
179
|
+
| `Property Creation Failed` | `500_error_new_property` |
|
|
180
|
+
|
|
181
|
+
## 7. Determine file and instrumentation point
|
|
182
|
+
|
|
183
|
+
For each candidate, use `file_summary_map` and `surfaces.components` to identify:
|
|
184
|
+
|
|
185
|
+
- **`file`** — the source file where the tracking call belongs. Prefer the file closest to where the outcome is confirmed (not where the user initiates the action). Usually a component file from `surfaces.components` or a hook where an async operation resolves.
|
|
186
|
+
- **`instrumentation`** — 1-2 sentences: *when* it fires (after what condition/callback/state transition) and *how* it's wired (which function/handler to place it in). Reference actual function names from file summaries so an engineer can find the right line.
|
|
187
|
+
|
|
188
|
+
## 8. Deepen understanding, then prioritize
|
|
189
|
+
|
|
190
|
+
For each candidate, first work through these two fields — they force you to think concretely about the event's value before scoring it:
|
|
191
|
+
|
|
192
|
+
- **`analysis_recipe`** — Describe the specific chart, funnel, or query an analyst would build with this event. Be concrete: mention the visualization type, segmentation dimensions, and any other events to combine with. e.g., *"Weekly funnel: Panel Opened → Extract Type Selected → Property Extracted, segmented by extractType. Alert if completion rate drops below 50%."*
|
|
193
|
+
- **`stakeholder_narrative`** — Write a sentence that a PM could drop into a quarterly review or board deck, using this event's data. Imagine the metric already exists and write the story it tells. e.g., *"68% of users who try extraction complete it on the first attempt, up from 45% last quarter."* If you can't imagine a compelling slide sentence, the event probably isn't worth instrumenting.
|
|
194
|
+
|
|
195
|
+
Now, with that context fresh, assign a **priority**:
|
|
196
|
+
|
|
197
|
+
| Priority | Meaning | Guidance |
|
|
198
|
+
| ---------------- | ------------------------------------------------------------------------------------------------------------------ | -------------------------------------------------------------------------------------------------------------------------------- |
|
|
199
|
+
| **3** (critical) | You would block a release if this event were missing. It answers a question the team *will* ask in the first week. | Reserve for events that directly measure whether the feature succeeded or failed. Most changes produce only 1-2 critical events. |
|
|
200
|
+
| **2** (useful) | Adds real analytical value but the feature can ship without it. Worth adding if instrumentation cost is low. | Segmentation dimensions, secondary workflows, configuration choices. |
|
|
201
|
+
| **1** (optional) | Nice-to-have. Only instrument if the team has bandwidth and a specific hypothesis to test. | Edge-case failures, exploratory engagement signals, discoverability metrics. |
|
|
202
|
+
|
|
203
|
+
**Funnel events deserve special attention.** When a change introduces or modifies a multi-step process (checkout flow, onboarding wizard, data import pipeline), the PM's first question will be "where are users dropping off?" A gap between funnel start and funnel end with no visibility in between is a blind spot that can hide serious product problems — if engagement craters at step 2 of 5, the team needs to know, not guess.
|
|
204
|
+
|
|
205
|
+
**Funnel start and funnel end events are always critical (priority 3).** Without the bookends, you can't measure conversion rate — the single most important metric for any funnel. These two events are non-negotiable regardless of funnel length or complexity.
|
|
206
|
+
|
|
207
|
+
To decide how many *intermediate* funnel events to mark critical, gauge the length and complexity of the funnel:
|
|
208
|
+
|
|
209
|
+
- **Short process (2-3 steps, single page):** The start and end events are enough. Don't instrument every micro-step in a simple flow.
|
|
210
|
+
- **Medium process (3-5 steps, possibly spanning pages):** Add one intermediate event at the most likely drop-off point — typically where the user commits effort (fills a form, makes a key selection, uploads a file).
|
|
211
|
+
- **Long process (5+ steps, multi-page or wizard-style):** 2-3 intermediate events at natural phase boundaries. Think "started → configured → submitted → confirmed" rather than tracking every field interaction.
|
|
212
|
+
|
|
213
|
+
Be selective with intermediate events. Every funnel event you mark critical is one more thing an engineer must implement and a PM must monitor. If you're unsure whether an intermediate step is worth tracking, it probably isn't — the start and end events will reveal whether there's a problem, and the team can always add granularity later once they see where drop-off is high.
|
|
214
|
+
|
|
215
|
+
Less is more. A focused set of critical events that actually get dashboarded beats a sprawling list nobody looks at. When in doubt, downgrade — it's easier to add an event later than to remove one that's already in dashboards.
|
|
216
|
+
|
|
217
|
+
## 9. Emit YAML output
|
|
218
|
+
|
|
219
|
+
Output only the YAML block — no surrounding prose.
|
|
220
|
+
|
|
221
|
+
```yaml
|
|
222
|
+
event_candidates:
|
|
223
|
+
source_summary: "<from change_brief.summary>"
|
|
224
|
+
analytics_scope: "<from change_brief.classification.analytics_scope>"
|
|
225
|
+
event_naming_convention: "<from MCP if clear, otherwise codebase instrumentation, otherwise taxonomy skill>"
|
|
226
|
+
property_naming_convention: "<from MCP if clear, otherwise codebase instrumentation, otherwise taxonomy skill>"
|
|
227
|
+
|
|
228
|
+
already_tracked: # omit if no duplicates found
|
|
229
|
+
- existing_event: "Subscription Upgraded"
|
|
230
|
+
candidate_dropped: "Plan Upgraded"
|
|
231
|
+
reason: "Same action — existing event already tracks plan/subscription upgrades."
|
|
232
|
+
|
|
233
|
+
funnels: # omit if no multi-step flows found
|
|
234
|
+
- name: "Descriptive funnel name"
|
|
235
|
+
steps:
|
|
236
|
+
- step: "Step description"
|
|
237
|
+
file: "src/components/Foo.tsx"
|
|
238
|
+
function: "handleOpen"
|
|
239
|
+
role: start # start | intermediate | end
|
|
240
|
+
- step: "Next step"
|
|
241
|
+
file: "src/components/Bar.tsx"
|
|
242
|
+
function: "onSubmit"
|
|
243
|
+
role: intermediate
|
|
244
|
+
- step: "Final step"
|
|
245
|
+
file: "src/hooks/useSave.ts"
|
|
246
|
+
function: "onSuccess"
|
|
247
|
+
role: end
|
|
248
|
+
|
|
249
|
+
candidates:
|
|
250
|
+
- name: "Event Name Here"
|
|
251
|
+
category: feature_success # business_outcome | user_journey | feature_success | friction_failure
|
|
252
|
+
rationale: "What PM question this answers."
|
|
253
|
+
analysis_recipe: "Weekly trend of completions; funnel from Panel Opened → Extract Type Selected → Event Name, segmented by extract type."
|
|
254
|
+
stakeholder_narrative: "Feature X adoption reached 40% of active users within two weeks of launch, exceeding our 25% target."
|
|
255
|
+
priority: 3 # 3 = critical, 2 = useful, 1 = optional
|
|
256
|
+
funnel: "Funnel name" # which funnel this belongs to, if any
|
|
257
|
+
funnel_role: start # start | intermediate | end — omit if not part of a funnel
|
|
258
|
+
surface: "ComponentName" # from surfaces.components
|
|
259
|
+
file: "src/components/Foo/Bar.tsx"
|
|
260
|
+
instrumentation: "Fire after the async save resolves, inside onSuccess of useExtract(). Pass result status."
|
|
261
|
+
|
|
262
|
+
- name: "Another Event"
|
|
263
|
+
category: user_journey
|
|
264
|
+
rationale: "..."
|
|
265
|
+
analysis_recipe: "..."
|
|
266
|
+
stakeholder_narrative: "..."
|
|
267
|
+
priority: 2
|
|
268
|
+
surface: "..."
|
|
269
|
+
file: "..."
|
|
270
|
+
instrumentation: "..."
|
|
271
|
+
```
|
|
272
|
+
|
|
273
|
+
Order: higher categories first, most impactful within each category first.
|
|
274
|
+
|
|
275
|
+
---
|
|
276
|
+
|
|
277
|
+
## Example
|
|
278
|
+
|
|
279
|
+
**Input excerpt:**
|
|
280
|
+
```yaml
|
|
281
|
+
user_facing_changes:
|
|
282
|
+
- "Users can now select Extract Type (Text or Attribute) in the PropertyItem panel"
|
|
283
|
+
surfaces:
|
|
284
|
+
components:
|
|
285
|
+
- name: PropertyItem
|
|
286
|
+
change: modified
|
|
287
|
+
```
|
|
288
|
+
|
|
289
|
+
**Good candidates:**
|
|
290
|
+
```yaml
|
|
291
|
+
- name: "Property Extracted"
|
|
292
|
+
category: feature_success
|
|
293
|
+
rationale: "Core adoption signal — tells PMs whether the extract workflow completes."
|
|
294
|
+
analysis_recipe: "Weekly funnel: Panel Opened → Extract Type Selected → Property Extracted, segmented by extractType. Alert if completion rate drops below 50%."
|
|
295
|
+
stakeholder_narrative: "72% of users who open a property panel complete an extraction, up from 0% before this release — validating the new extract workflow."
|
|
296
|
+
priority: 3
|
|
297
|
+
surface: "PropertyItem"
|
|
298
|
+
file: "src/components/PropertiesPanel/PropertyItem.tsx"
|
|
299
|
+
instrumentation: "Fire after extract resolves successfully in onSuccess handler. Include extractType (TEXT or ATTRIBUTE)."
|
|
300
|
+
|
|
301
|
+
- name: "Extract Type Selected"
|
|
302
|
+
category: feature_success
|
|
303
|
+
rationale: "Shows which mode users prefer — informs investment in Attribute mode."
|
|
304
|
+
analysis_recipe: "Pie chart of Text vs Attribute selections over 30 days. Combine with Property Extracted to get per-mode completion rate."
|
|
305
|
+
stakeholder_narrative: "85% of extractions use Text mode vs 15% Attribute — we should double down on Text UX before expanding Attribute capabilities."
|
|
306
|
+
priority: 2
|
|
307
|
+
surface: "PropertyItem"
|
|
308
|
+
file: "src/components/PropertiesPanel/PropertyItem.tsx"
|
|
309
|
+
instrumentation: "Fire in onChange of Extract Type select, passing new value."
|
|
310
|
+
|
|
311
|
+
- name: "Property Extraction Failed"
|
|
312
|
+
category: friction_failure
|
|
313
|
+
rationale: "Surfaces where the extract workflow breaks for reliability prioritization."
|
|
314
|
+
analysis_recipe: "Error rate chart: Property Extraction Failed / (Property Extracted + Property Extraction Failed), grouped by error reason. Alert on spikes."
|
|
315
|
+
stakeholder_narrative: "Extraction failure rate dropped from 12% to 3% after the v2 error-handling patch — users are hitting fewer dead ends."
|
|
316
|
+
priority: 2
|
|
317
|
+
surface: "PropertyItem"
|
|
318
|
+
file: "src/components/PropertiesPanel/PropertyItem.tsx"
|
|
319
|
+
instrumentation: "Fire in catch/onError of extract call. Include error reason if available."
|
|
320
|
+
```
|
|
321
|
+
|
|
322
|
+
**Do NOT include:** `Extract Type Dropdown Opened` (click, no outcome), `PropertyItem State Updated` (internal), `Attribute Input Focused` (too granular).
|