@amplitude/wizard 1.0.0-beta.2 → 1.0.0-beta.6
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/LICENSE +25 -1
- 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,53 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: integration-react-react-router-7-declarative
|
|
3
|
+
description: Amplitude integration for React Router v7 - Declarative mode applications
|
|
4
|
+
metadata:
|
|
5
|
+
author: Amplitude
|
|
6
|
+
version: dev
|
|
7
|
+
---
|
|
8
|
+
|
|
9
|
+
# Amplitude integration for React Router v7 - Declarative mode
|
|
10
|
+
|
|
11
|
+
This skill helps you add Amplitude analytics to React Router v7 - Declarative mode applications.
|
|
12
|
+
|
|
13
|
+
## Workflow
|
|
14
|
+
|
|
15
|
+
Follow these steps in order to complete the integration:
|
|
16
|
+
|
|
17
|
+
1. `basic-integration-1.0-begin.md` - Amplitude Setup - Begin ← **Start here**
|
|
18
|
+
2. `basic-integration-1.1-edit.md` - Amplitude Setup - Edit
|
|
19
|
+
3. `basic-integration-1.2-revise.md` - Amplitude Setup - Revise
|
|
20
|
+
4. `basic-integration-1.3-conclude.md` - Amplitude Setup - Conclusion
|
|
21
|
+
|
|
22
|
+
## Reference files
|
|
23
|
+
|
|
24
|
+
- `references/EXAMPLE.md` - React Router v7 - Declarative mode example project code
|
|
25
|
+
- `references/browser-sdk-2.md` - Or install unified SDK to get access to all Amplitude products
|
|
26
|
+
- `references/amplitude-quickstart.md` - Amplitude documentation for Amplitude Quickstart
|
|
27
|
+
- `references/basic-integration-1.0-begin.md` - Amplitude setup - begin
|
|
28
|
+
- `references/basic-integration-1.1-edit.md` - Amplitude setup - edit
|
|
29
|
+
- `references/basic-integration-1.2-revise.md` - Amplitude setup - revise
|
|
30
|
+
- `references/basic-integration-1.3-conclude.md` - Amplitude setup - conclusion
|
|
31
|
+
|
|
32
|
+
The example project shows the target implementation pattern. Consult the documentation for API details.
|
|
33
|
+
|
|
34
|
+
## Key principles
|
|
35
|
+
|
|
36
|
+
- **Environment variables**: Always use environment variables for Amplitude keys. Never hardcode them.
|
|
37
|
+
- **Minimal changes**: Add Amplitude code alongside existing integrations. Don't replace or restructure existing code.
|
|
38
|
+
- **Match the example**: Your implementation should follow the example project's patterns as closely as possible.
|
|
39
|
+
|
|
40
|
+
## Framework guidelines
|
|
41
|
+
|
|
42
|
+
- For feature flags, use the Amplitude Experiment React SDK hooks (useVariantValue, useExperiment) — they handle loading states and async fetch automatically
|
|
43
|
+
- Add analytics track calls in event handlers where user actions occur, NOT in useEffect reacting to state changes
|
|
44
|
+
- Do NOT use useEffect for data transformation - calculate derived values during render instead
|
|
45
|
+
- Do NOT use useEffect to respond to user events - put that logic in the event handler itself
|
|
46
|
+
- Do NOT use useEffect to chain state updates - calculate all related updates together in the event handler
|
|
47
|
+
- Do NOT use useEffect to notify parent components - call the parent callback alongside setState in the event handler
|
|
48
|
+
- To reset component state when a prop changes, pass the prop as the component's key instead of using useEffect
|
|
49
|
+
- useEffect is ONLY for synchronizing with external systems (non-React widgets, browser APIs, network subscriptions)
|
|
50
|
+
|
|
51
|
+
## Identifying users
|
|
52
|
+
|
|
53
|
+
Identify users during login and signup events. Refer to the example code and documentation for the correct identify pattern for this framework. Call `amplitude.setUserId(userId)` to associate events with a known user, and use `amplitude.identify()` with an `Identify` object to set user properties. If both frontend and backend code exist, pass a consistent user/device ID via custom request headers to maintain event correlation.
|
|
@@ -0,0 +1,609 @@
|
|
|
1
|
+
# Amplitude React Router v7 - Declarative mode Example Project
|
|
2
|
+
|
|
3
|
+
Repository: https://github.com/amplitude/context-hub
|
|
4
|
+
Path: basics/react-react-router-7-declarative
|
|
5
|
+
|
|
6
|
+
---
|
|
7
|
+
|
|
8
|
+
## README.md
|
|
9
|
+
|
|
10
|
+
# Amplitude React Router 7 Declarative example
|
|
11
|
+
|
|
12
|
+
This is a [React Router 7](https://reactrouter.com) Declarative example demonstrating Amplitude integration with product analytics and event tracking.
|
|
13
|
+
|
|
14
|
+
### Amplitude SDKs
|
|
15
|
+
|
|
16
|
+
The client uses the [Browser Unified SDK (npm)](https://amplitude.com/docs/sdks/analytics/browser/browser-unified-sdk#unified-sdk-npm): [`@amplitude/unified`](https://www.npmjs.com/package/@amplitude/unified) with a single `initAll` call. [Initialize the Unified SDK](https://amplitude.com/docs/sdks/analytics/browser/browser-unified-sdk#initialize-the-unified-sdk) documents that call as initializing every product bundled with Unified npm. See [configuration](https://amplitude.com/docs/sdks/analytics/browser/browser-unified-sdk#configuration) and [Browser SDK 2](https://amplitude.com/docs/sdks/analytics/browser/browser-sdk-2#initialize-the-sdk) for `analytics` options. The `experiment` block is **Feature Experiment** (`@amplitude/experiment-js-client`); Amplitude’s [product support table](https://amplitude.com/docs/sdks/analytics/browser/browser-unified-sdk#product-support-by-installation-method) lists **Web Experiment** (`@amplitude/experiment-tag`, including the visual editor) for the [Unified script (CDN)](https://amplitude.com/docs/sdks/analytics/browser/browser-unified-sdk#unified-script-cdn), not Unified **npm**.
|
|
17
|
+
|
|
18
|
+
If you add backend events, use [`@amplitude/analytics-node`](https://www.npmjs.com/package/@amplitude/analytics-node).
|
|
19
|
+
|
|
20
|
+
## Features
|
|
21
|
+
|
|
22
|
+
- **Product Analytics**: Track user events and behaviors
|
|
23
|
+
- **User Authentication**: Demo login system with Amplitude user identification
|
|
24
|
+
- **Client-side Tracking**: Examples of client-side tracking methods
|
|
25
|
+
|
|
26
|
+
## Getting Started
|
|
27
|
+
|
|
28
|
+
### 1. Install Dependencies
|
|
29
|
+
|
|
30
|
+
```bash
|
|
31
|
+
npm install
|
|
32
|
+
# or
|
|
33
|
+
pnpm install
|
|
34
|
+
```
|
|
35
|
+
|
|
36
|
+
### 2. Configure Environment Variables
|
|
37
|
+
|
|
38
|
+
Create a `.env` file in the root directory:
|
|
39
|
+
|
|
40
|
+
```bash
|
|
41
|
+
VITE_PUBLIC_AMPLITUDE_API_KEY=your_amplitude_api_key
|
|
42
|
+
```
|
|
43
|
+
|
|
44
|
+
Get your Amplitude API key from your [Amplitude project settings](https://app.amplitude.com).
|
|
45
|
+
|
|
46
|
+
### 3. Run the Development Server
|
|
47
|
+
|
|
48
|
+
```bash
|
|
49
|
+
npm run dev
|
|
50
|
+
# or
|
|
51
|
+
pnpm dev
|
|
52
|
+
```
|
|
53
|
+
|
|
54
|
+
Open [http://localhost:5173](http://localhost:5173) with your browser to see the app.
|
|
55
|
+
|
|
56
|
+
## Project Structure
|
|
57
|
+
|
|
58
|
+
```
|
|
59
|
+
src/
|
|
60
|
+
├── components/
|
|
61
|
+
│ └── Header.tsx # Navigation header with auth state
|
|
62
|
+
├── contexts/
|
|
63
|
+
│ └── AuthContext.tsx # Authentication context with Amplitude integration
|
|
64
|
+
├── routes/
|
|
65
|
+
│ ├── Root.tsx # Root route component
|
|
66
|
+
│ ├── Home.tsx # Home/Login page
|
|
67
|
+
│ ├── Burrito.tsx # Demo feature page with event tracking
|
|
68
|
+
│ └── Profile.tsx # User profile page
|
|
69
|
+
└── main.tsx # App entry point with Amplitude initialization
|
|
70
|
+
```
|
|
71
|
+
|
|
72
|
+
## Key Integration Points
|
|
73
|
+
|
|
74
|
+
### Client-side initialization (main.tsx)
|
|
75
|
+
|
|
76
|
+
```typescript
|
|
77
|
+
import * as amplitude from '@amplitude/unified';
|
|
78
|
+
|
|
79
|
+
void amplitude.initAll(import.meta.env.VITE_PUBLIC_AMPLITUDE_API_KEY);
|
|
80
|
+
```
|
|
81
|
+
|
|
82
|
+
### User identification (contexts/AuthContext.tsx)
|
|
83
|
+
|
|
84
|
+
```typescript
|
|
85
|
+
import * as amplitude from '@amplitude/unified';
|
|
86
|
+
import { Identify } from '@amplitude/unified';
|
|
87
|
+
|
|
88
|
+
amplitude.setUserId(username);
|
|
89
|
+
const identifyObj = new Identify();
|
|
90
|
+
identifyObj.set('username', username);
|
|
91
|
+
amplitude.identify(identifyObj);
|
|
92
|
+
amplitude.track('User Logged In', { username });
|
|
93
|
+
```
|
|
94
|
+
|
|
95
|
+
## Learn More
|
|
96
|
+
|
|
97
|
+
- [Amplitude Documentation](https://amplitude.com/docs)
|
|
98
|
+
- [React Router 7 Documentation](https://reactrouter.com/home)
|
|
99
|
+
- [Amplitude Browser SDK](https://amplitude.com/docs/sdks/analytics/browser/browser-sdk-2)
|
|
100
|
+
|
|
101
|
+
---
|
|
102
|
+
|
|
103
|
+
## .env.example
|
|
104
|
+
|
|
105
|
+
```example
|
|
106
|
+
VITE_PUBLIC_AMPLITUDE_API_KEY=
|
|
107
|
+
|
|
108
|
+
```
|
|
109
|
+
|
|
110
|
+
---
|
|
111
|
+
|
|
112
|
+
## index.html
|
|
113
|
+
|
|
114
|
+
```html
|
|
115
|
+
<!doctype html>
|
|
116
|
+
<html lang="en">
|
|
117
|
+
<head>
|
|
118
|
+
<meta charset="UTF-8" />
|
|
119
|
+
<link rel="icon" type="image/svg+xml" href="/vite.svg" />
|
|
120
|
+
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
|
121
|
+
<title>react-react-router-7-declarative</title>
|
|
122
|
+
</head>
|
|
123
|
+
<body>
|
|
124
|
+
<div id="root"></div>
|
|
125
|
+
<script type="module" src="/src/main.tsx"></script>
|
|
126
|
+
</body>
|
|
127
|
+
</html>
|
|
128
|
+
|
|
129
|
+
```
|
|
130
|
+
|
|
131
|
+
---
|
|
132
|
+
|
|
133
|
+
## src/App.tsx
|
|
134
|
+
|
|
135
|
+
```tsx
|
|
136
|
+
import { useState } from 'react'
|
|
137
|
+
import reactLogo from './assets/react.svg'
|
|
138
|
+
import viteLogo from '/vite.svg'
|
|
139
|
+
import './App.css'
|
|
140
|
+
|
|
141
|
+
function App() {
|
|
142
|
+
const [count, setCount] = useState(0)
|
|
143
|
+
|
|
144
|
+
return (
|
|
145
|
+
<>
|
|
146
|
+
<div>
|
|
147
|
+
<a href="https://vite.dev" target="_blank">
|
|
148
|
+
<img src={viteLogo} className="logo" alt="Vite logo" />
|
|
149
|
+
</a>
|
|
150
|
+
<a href="https://react.dev" target="_blank">
|
|
151
|
+
<img src={reactLogo} className="logo react" alt="React logo" />
|
|
152
|
+
</a>
|
|
153
|
+
</div>
|
|
154
|
+
<h1>Vite + React</h1>
|
|
155
|
+
<div className="card">
|
|
156
|
+
<button onClick={() => setCount((count) => count + 1)}>
|
|
157
|
+
count is {count}
|
|
158
|
+
</button>
|
|
159
|
+
<p>
|
|
160
|
+
Edit <code>src/App.tsx</code> and save to test HMR
|
|
161
|
+
</p>
|
|
162
|
+
</div>
|
|
163
|
+
<p className="read-the-docs">
|
|
164
|
+
Click on the Vite and React logos to learn more
|
|
165
|
+
</p>
|
|
166
|
+
</>
|
|
167
|
+
)
|
|
168
|
+
}
|
|
169
|
+
|
|
170
|
+
export default App
|
|
171
|
+
|
|
172
|
+
```
|
|
173
|
+
|
|
174
|
+
---
|
|
175
|
+
|
|
176
|
+
## src/components/Header.tsx
|
|
177
|
+
|
|
178
|
+
```tsx
|
|
179
|
+
import { Link } from 'react-router';
|
|
180
|
+
import { useAuth } from '../contexts/AuthContext';
|
|
181
|
+
import * as amplitude from '@amplitude/unified';
|
|
182
|
+
|
|
183
|
+
export default function Header() {
|
|
184
|
+
const { user, logout } = useAuth();
|
|
185
|
+
|
|
186
|
+
const handleLogout = () => {
|
|
187
|
+
amplitude.track('User Logged Out');
|
|
188
|
+
amplitude.reset();
|
|
189
|
+
logout();
|
|
190
|
+
};
|
|
191
|
+
|
|
192
|
+
return (
|
|
193
|
+
<header className="header">
|
|
194
|
+
<div className="header-container">
|
|
195
|
+
<nav>
|
|
196
|
+
<Link to="/">Home</Link>
|
|
197
|
+
{user && (
|
|
198
|
+
<>
|
|
199
|
+
<Link to="/burrito">Burrito Consideration</Link>
|
|
200
|
+
<Link to="/profile">Profile</Link>
|
|
201
|
+
</>
|
|
202
|
+
)}
|
|
203
|
+
</nav>
|
|
204
|
+
<div className="user-section">
|
|
205
|
+
{user ? (
|
|
206
|
+
<>
|
|
207
|
+
<span>Welcome, {user.username}!</span>
|
|
208
|
+
<button onClick={handleLogout} className="btn-logout">
|
|
209
|
+
Logout
|
|
210
|
+
</button>
|
|
211
|
+
</>
|
|
212
|
+
) : (
|
|
213
|
+
<span>Not logged in</span>
|
|
214
|
+
)}
|
|
215
|
+
</div>
|
|
216
|
+
</div>
|
|
217
|
+
</header>
|
|
218
|
+
);
|
|
219
|
+
}
|
|
220
|
+
|
|
221
|
+
```
|
|
222
|
+
|
|
223
|
+
---
|
|
224
|
+
|
|
225
|
+
## src/contexts/AuthContext.tsx
|
|
226
|
+
|
|
227
|
+
```tsx
|
|
228
|
+
import * as amplitude from '@amplitude/unified';
|
|
229
|
+
import { Identify } from '@amplitude/unified';
|
|
230
|
+
import { createContext, useContext, useState, type ReactNode } from 'react';
|
|
231
|
+
|
|
232
|
+
interface User {
|
|
233
|
+
username: string;
|
|
234
|
+
burritoConsiderations: number;
|
|
235
|
+
}
|
|
236
|
+
|
|
237
|
+
interface AuthContextType {
|
|
238
|
+
user: User | null;
|
|
239
|
+
login: (username: string, password: string) => Promise<boolean>;
|
|
240
|
+
logout: () => void;
|
|
241
|
+
setUser: (user: User) => void;
|
|
242
|
+
}
|
|
243
|
+
|
|
244
|
+
const AuthContext = createContext<AuthContextType | undefined>(undefined);
|
|
245
|
+
|
|
246
|
+
const users: Map<string, User> = new Map();
|
|
247
|
+
|
|
248
|
+
export function AuthProvider({ children }: { children: ReactNode }) {
|
|
249
|
+
const [user, setUser] = useState<User | null>(() => {
|
|
250
|
+
if (typeof window === 'undefined') return null;
|
|
251
|
+
|
|
252
|
+
const storedUsername = localStorage.getItem('currentUser');
|
|
253
|
+
if (storedUsername) {
|
|
254
|
+
const existingUser = users.get(storedUsername);
|
|
255
|
+
if (existingUser) {
|
|
256
|
+
return existingUser;
|
|
257
|
+
}
|
|
258
|
+
}
|
|
259
|
+
return null;
|
|
260
|
+
});
|
|
261
|
+
|
|
262
|
+
const login = async (username: string, password: string): Promise<boolean> => {
|
|
263
|
+
// Client-side only fake auth - no server calls
|
|
264
|
+
if (!username || !password) {
|
|
265
|
+
return false;
|
|
266
|
+
}
|
|
267
|
+
|
|
268
|
+
let localUser = users.get(username);
|
|
269
|
+
if (!localUser) {
|
|
270
|
+
localUser = {
|
|
271
|
+
username,
|
|
272
|
+
burritoConsiderations: 0
|
|
273
|
+
};
|
|
274
|
+
users.set(username, localUser);
|
|
275
|
+
}
|
|
276
|
+
|
|
277
|
+
setUser(localUser);
|
|
278
|
+
localStorage.setItem('currentUser', username);
|
|
279
|
+
|
|
280
|
+
// Identify user in Amplitude using username as user ID
|
|
281
|
+
amplitude.setUserId(username);
|
|
282
|
+
const identifyObj = new Identify();
|
|
283
|
+
identifyObj.set('username', username);
|
|
284
|
+
amplitude.identify(identifyObj);
|
|
285
|
+
amplitude.track('User Logged In', { username });
|
|
286
|
+
|
|
287
|
+
return true;
|
|
288
|
+
};
|
|
289
|
+
|
|
290
|
+
const logout = () => {
|
|
291
|
+
setUser(null);
|
|
292
|
+
localStorage.removeItem('currentUser');
|
|
293
|
+
};
|
|
294
|
+
|
|
295
|
+
const setUserState = (newUser: User) => {
|
|
296
|
+
setUser(newUser);
|
|
297
|
+
users.set(newUser.username, newUser);
|
|
298
|
+
};
|
|
299
|
+
|
|
300
|
+
return (
|
|
301
|
+
<AuthContext.Provider value={{ user, login, logout, setUser: setUserState }}>
|
|
302
|
+
{children}
|
|
303
|
+
</AuthContext.Provider>
|
|
304
|
+
);
|
|
305
|
+
}
|
|
306
|
+
|
|
307
|
+
// eslint-disable-next-line react-refresh/only-export-components -- useAuth is the companion hook for AuthProvider
|
|
308
|
+
export function useAuth() {
|
|
309
|
+
const context = useContext(AuthContext);
|
|
310
|
+
if (context === undefined) {
|
|
311
|
+
throw new Error('useAuth must be used within an AuthProvider');
|
|
312
|
+
}
|
|
313
|
+
return context;
|
|
314
|
+
}
|
|
315
|
+
|
|
316
|
+
```
|
|
317
|
+
|
|
318
|
+
---
|
|
319
|
+
|
|
320
|
+
## src/main.tsx
|
|
321
|
+
|
|
322
|
+
```tsx
|
|
323
|
+
import './globals.css'
|
|
324
|
+
|
|
325
|
+
import { StrictMode } from "react";
|
|
326
|
+
import ReactDOM from "react-dom/client";
|
|
327
|
+
import { BrowserRouter, Routes, Route } from "react-router";
|
|
328
|
+
import Root from './routes/Root';
|
|
329
|
+
import Home from './routes/Home';
|
|
330
|
+
import Burrito from './routes/Burrito';
|
|
331
|
+
import Profile from './routes/Profile';
|
|
332
|
+
|
|
333
|
+
import * as amplitude from '@amplitude/unified';
|
|
334
|
+
|
|
335
|
+
void amplitude.initAll(import.meta.env.VITE_PUBLIC_AMPLITUDE_API_KEY);
|
|
336
|
+
|
|
337
|
+
const root = document.getElementById("root");
|
|
338
|
+
if (!root) throw new Error("Root element not found");
|
|
339
|
+
|
|
340
|
+
ReactDOM.createRoot(root).render(
|
|
341
|
+
<StrictMode>
|
|
342
|
+
<BrowserRouter>
|
|
343
|
+
<Routes>
|
|
344
|
+
<Route path="/" element={<Root />}>
|
|
345
|
+
<Route index element={<Home />} />
|
|
346
|
+
<Route path="burrito" element={<Burrito />} />
|
|
347
|
+
<Route path="profile" element={<Profile />} />
|
|
348
|
+
</Route>
|
|
349
|
+
</Routes>
|
|
350
|
+
</BrowserRouter>
|
|
351
|
+
</StrictMode>,
|
|
352
|
+
);
|
|
353
|
+
|
|
354
|
+
```
|
|
355
|
+
|
|
356
|
+
---
|
|
357
|
+
|
|
358
|
+
## src/routes/Burrito.tsx
|
|
359
|
+
|
|
360
|
+
```tsx
|
|
361
|
+
import { useState, useEffect } from 'react';
|
|
362
|
+
import { useNavigate } from 'react-router';
|
|
363
|
+
import { useAuth } from '../contexts/AuthContext';
|
|
364
|
+
|
|
365
|
+
export default function BurritoPage() {
|
|
366
|
+
const { user, setUser } = useAuth();
|
|
367
|
+
const navigate = useNavigate();
|
|
368
|
+
const [hasConsidered, setHasConsidered] = useState(false);
|
|
369
|
+
|
|
370
|
+
useEffect(() => {
|
|
371
|
+
if (!user) {
|
|
372
|
+
navigate('/');
|
|
373
|
+
}
|
|
374
|
+
}, [user, navigate]);
|
|
375
|
+
|
|
376
|
+
if (!user) {
|
|
377
|
+
return null;
|
|
378
|
+
}
|
|
379
|
+
|
|
380
|
+
const handleConsideration = () => {
|
|
381
|
+
// Client-side only - no server calls
|
|
382
|
+
const updatedUser = {
|
|
383
|
+
...user,
|
|
384
|
+
burritoConsiderations: user.burritoConsiderations + 1
|
|
385
|
+
};
|
|
386
|
+
setUser(updatedUser);
|
|
387
|
+
setHasConsidered(true);
|
|
388
|
+
setTimeout(() => setHasConsidered(false), 2000);
|
|
389
|
+
};
|
|
390
|
+
|
|
391
|
+
return (
|
|
392
|
+
<div className="container">
|
|
393
|
+
<h1>Burrito consideration zone</h1>
|
|
394
|
+
<p>Take a moment to truly consider the potential of burritos.</p>
|
|
395
|
+
|
|
396
|
+
<div style={{ textAlign: 'center' }}>
|
|
397
|
+
<button
|
|
398
|
+
onClick={handleConsideration}
|
|
399
|
+
className="btn-burrito"
|
|
400
|
+
>
|
|
401
|
+
I have considered the burrito potential
|
|
402
|
+
</button>
|
|
403
|
+
|
|
404
|
+
{hasConsidered && (
|
|
405
|
+
<p className="success">
|
|
406
|
+
Thank you for your consideration! Count: {user.burritoConsiderations}
|
|
407
|
+
</p>
|
|
408
|
+
)}
|
|
409
|
+
</div>
|
|
410
|
+
|
|
411
|
+
<div className="stats">
|
|
412
|
+
<h3>Consideration stats</h3>
|
|
413
|
+
<p>Total considerations: {user.burritoConsiderations}</p>
|
|
414
|
+
</div>
|
|
415
|
+
</div>
|
|
416
|
+
);
|
|
417
|
+
}
|
|
418
|
+
|
|
419
|
+
|
|
420
|
+
```
|
|
421
|
+
|
|
422
|
+
---
|
|
423
|
+
|
|
424
|
+
## src/routes/Home.tsx
|
|
425
|
+
|
|
426
|
+
```tsx
|
|
427
|
+
import { useState } from 'react';
|
|
428
|
+
import { useAuth } from '../contexts/AuthContext';
|
|
429
|
+
|
|
430
|
+
export default function Home() {
|
|
431
|
+
const { user, login } = useAuth();
|
|
432
|
+
const [username, setUsername] = useState('');
|
|
433
|
+
const [password, setPassword] = useState('');
|
|
434
|
+
const [error, setError] = useState('');
|
|
435
|
+
|
|
436
|
+
const handleSubmit = async (e: React.FormEvent) => {
|
|
437
|
+
e.preventDefault();
|
|
438
|
+
setError('');
|
|
439
|
+
|
|
440
|
+
const success = await login(username, password);
|
|
441
|
+
if (success) {
|
|
442
|
+
setUsername('');
|
|
443
|
+
setPassword('');
|
|
444
|
+
} else {
|
|
445
|
+
setError('Please provide both username and password');
|
|
446
|
+
}
|
|
447
|
+
};
|
|
448
|
+
|
|
449
|
+
if (user) {
|
|
450
|
+
return (
|
|
451
|
+
<div className="container">
|
|
452
|
+
<h1>Welcome back, {user.username}!</h1>
|
|
453
|
+
<p>You are now logged in. Feel free to explore:</p>
|
|
454
|
+
<ul>
|
|
455
|
+
<li>Consider the potential of burritos</li>
|
|
456
|
+
<li>View your profile and statistics</li>
|
|
457
|
+
</ul>
|
|
458
|
+
</div>
|
|
459
|
+
);
|
|
460
|
+
}
|
|
461
|
+
|
|
462
|
+
return (
|
|
463
|
+
<div className="container">
|
|
464
|
+
<h1>Welcome to Burrito Consideration App</h1>
|
|
465
|
+
<p>Please sign in to begin your burrito journey</p>
|
|
466
|
+
|
|
467
|
+
<form onSubmit={handleSubmit} className="form">
|
|
468
|
+
<div className="form-group">
|
|
469
|
+
<label htmlFor="username">Username:</label>
|
|
470
|
+
<input
|
|
471
|
+
type="text"
|
|
472
|
+
id="username"
|
|
473
|
+
value={username}
|
|
474
|
+
onChange={(e) => setUsername(e.target.value)}
|
|
475
|
+
placeholder="Enter any username"
|
|
476
|
+
/>
|
|
477
|
+
</div>
|
|
478
|
+
|
|
479
|
+
<div className="form-group">
|
|
480
|
+
<label htmlFor="password">Password:</label>
|
|
481
|
+
<input
|
|
482
|
+
type="password"
|
|
483
|
+
id="password"
|
|
484
|
+
value={password}
|
|
485
|
+
onChange={(e) => setPassword(e.target.value)}
|
|
486
|
+
placeholder="Enter any password"
|
|
487
|
+
/>
|
|
488
|
+
</div>
|
|
489
|
+
|
|
490
|
+
{error && <p className="error">{error}</p>}
|
|
491
|
+
|
|
492
|
+
<button type="submit" className="btn-primary">Sign In</button>
|
|
493
|
+
</form>
|
|
494
|
+
|
|
495
|
+
<p className="note">
|
|
496
|
+
Note: This is a demo app. Use any username and password to sign in.
|
|
497
|
+
</p>
|
|
498
|
+
</div>
|
|
499
|
+
);
|
|
500
|
+
}
|
|
501
|
+
|
|
502
|
+
|
|
503
|
+
```
|
|
504
|
+
|
|
505
|
+
---
|
|
506
|
+
|
|
507
|
+
## src/routes/Profile.tsx
|
|
508
|
+
|
|
509
|
+
```tsx
|
|
510
|
+
import { useEffect } from 'react';
|
|
511
|
+
import { useNavigate } from 'react-router';
|
|
512
|
+
import { useAuth } from '../contexts/AuthContext';
|
|
513
|
+
|
|
514
|
+
export default function ProfilePage() {
|
|
515
|
+
const { user } = useAuth();
|
|
516
|
+
const navigate = useNavigate();
|
|
517
|
+
|
|
518
|
+
useEffect(() => {
|
|
519
|
+
if (!user) {
|
|
520
|
+
navigate('/');
|
|
521
|
+
}
|
|
522
|
+
}, [user, navigate]);
|
|
523
|
+
|
|
524
|
+
if (!user) {
|
|
525
|
+
return null;
|
|
526
|
+
}
|
|
527
|
+
|
|
528
|
+
return (
|
|
529
|
+
<div className="container">
|
|
530
|
+
<h1>User Profile</h1>
|
|
531
|
+
|
|
532
|
+
<div className="stats">
|
|
533
|
+
<h2>Your Information</h2>
|
|
534
|
+
<p><strong>Username:</strong> {user.username}</p>
|
|
535
|
+
<p><strong>Burrito Considerations:</strong> {user.burritoConsiderations}</p>
|
|
536
|
+
</div>
|
|
537
|
+
|
|
538
|
+
<div style={{ marginTop: '2rem' }}>
|
|
539
|
+
<h3>Your Burrito Journey</h3>
|
|
540
|
+
{user.burritoConsiderations === 0 ? (
|
|
541
|
+
<p>You haven't considered any burritos yet. Visit the Burrito Consideration page to start!</p>
|
|
542
|
+
) : user.burritoConsiderations === 1 ? (
|
|
543
|
+
<p>You've considered the burrito potential once. Keep going!</p>
|
|
544
|
+
) : user.burritoConsiderations < 5 ? (
|
|
545
|
+
<p>You're getting the hang of burrito consideration!</p>
|
|
546
|
+
) : user.burritoConsiderations < 10 ? (
|
|
547
|
+
<p>You're becoming a burrito consideration expert!</p>
|
|
548
|
+
) : (
|
|
549
|
+
<p>You are a true burrito consideration master! 🌯</p>
|
|
550
|
+
)}
|
|
551
|
+
</div>
|
|
552
|
+
</div>
|
|
553
|
+
);
|
|
554
|
+
}
|
|
555
|
+
|
|
556
|
+
|
|
557
|
+
```
|
|
558
|
+
|
|
559
|
+
---
|
|
560
|
+
|
|
561
|
+
## src/routes/Root.tsx
|
|
562
|
+
|
|
563
|
+
```tsx
|
|
564
|
+
import { Outlet } from "react-router";
|
|
565
|
+
import Header from "../components/Header";
|
|
566
|
+
import { AuthProvider } from "../contexts/AuthContext";
|
|
567
|
+
|
|
568
|
+
export default function Root() {
|
|
569
|
+
return (
|
|
570
|
+
<AuthProvider>
|
|
571
|
+
<Header />
|
|
572
|
+
<main>
|
|
573
|
+
<Outlet />
|
|
574
|
+
</main>
|
|
575
|
+
</AuthProvider>
|
|
576
|
+
);
|
|
577
|
+
}
|
|
578
|
+
```
|
|
579
|
+
|
|
580
|
+
---
|
|
581
|
+
|
|
582
|
+
## src/vite-env.d.ts
|
|
583
|
+
|
|
584
|
+
```ts
|
|
585
|
+
/// <reference types="vite/client" />
|
|
586
|
+
|
|
587
|
+
|
|
588
|
+
```
|
|
589
|
+
|
|
590
|
+
---
|
|
591
|
+
|
|
592
|
+
## vite.config.ts
|
|
593
|
+
|
|
594
|
+
```ts
|
|
595
|
+
import { defineConfig } from 'vite'
|
|
596
|
+
import react from '@vitejs/plugin-react'
|
|
597
|
+
|
|
598
|
+
// https://vite.dev/config/
|
|
599
|
+
export default defineConfig({
|
|
600
|
+
plugins: [react()],
|
|
601
|
+
resolve: {
|
|
602
|
+
dedupe: ['react', 'react-dom'],
|
|
603
|
+
},
|
|
604
|
+
})
|
|
605
|
+
|
|
606
|
+
```
|
|
607
|
+
|
|
608
|
+
---
|
|
609
|
+
|