@amplitude/wizard 1.0.0-beta.2 → 1.0.0-beta.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (391) hide show
  1. package/README.md +171 -74
  2. package/dist/bin.js +338 -222
  3. package/dist/src/lib/agent-interface.js +64 -9
  4. package/dist/src/lib/agent-runner.js +1 -10
  5. package/dist/src/lib/api.d.ts +22 -4
  6. package/dist/src/lib/api.js +114 -12
  7. package/dist/src/lib/commandments.js +14 -1
  8. package/dist/src/lib/constants.d.ts +5 -4
  9. package/dist/src/lib/constants.js +9 -11
  10. package/dist/src/lib/credential-resolution.d.ts +45 -0
  11. package/dist/src/lib/credential-resolution.js +311 -0
  12. package/dist/src/lib/exit-codes.d.ts +10 -0
  13. package/dist/src/lib/exit-codes.js +12 -0
  14. package/dist/src/lib/health-checks/statuspage.d.ts +1 -0
  15. package/dist/src/lib/health-checks/statuspage.js +5 -1
  16. package/dist/src/lib/mode-config.d.ts +14 -0
  17. package/dist/src/lib/mode-config.js +14 -0
  18. package/dist/src/lib/session-checkpoint.d.ts +27 -0
  19. package/dist/src/lib/session-checkpoint.js +134 -0
  20. package/dist/src/lib/wizard-session.d.ts +44 -1
  21. package/dist/src/lib/wizard-session.js +70 -14
  22. package/dist/src/lib/wizard-tools.js +19 -4
  23. package/dist/src/steps/add-mcp-server-to-clients/clients/claude.d.ts +3 -0
  24. package/dist/src/steps/add-mcp-server-to-clients/clients/claude.js +6 -0
  25. package/dist/src/steps/add-mcp-server-to-clients/clients/cursor.js +3 -1
  26. package/dist/src/ui/agent-ui.d.ts +91 -0
  27. package/dist/src/ui/agent-ui.js +277 -0
  28. package/dist/src/ui/logging-ui.js +1 -1
  29. package/dist/src/ui/tui/App.d.ts +12 -0
  30. package/dist/src/ui/tui/App.js +29 -18
  31. package/dist/src/ui/tui/components/AmplitudeLogo.js +16 -17
  32. package/dist/src/ui/tui/components/AmplitudeTextLogo.d.ts +0 -2
  33. package/dist/src/ui/tui/components/AmplitudeTextLogo.js +53 -18
  34. package/dist/src/ui/tui/components/BrailleSpinner.d.ts +8 -0
  35. package/dist/src/ui/tui/components/BrailleSpinner.js +15 -0
  36. package/dist/src/ui/tui/components/ConsoleView.d.ts +8 -11
  37. package/dist/src/ui/tui/components/ConsoleView.js +51 -34
  38. package/dist/src/ui/tui/components/HeaderBar.d.ts +12 -0
  39. package/dist/src/ui/tui/components/HeaderBar.js +17 -0
  40. package/dist/src/ui/tui/components/JourneyStepper.d.ts +16 -0
  41. package/dist/src/ui/tui/components/JourneyStepper.js +83 -0
  42. package/dist/src/ui/tui/components/KeyHintBar.d.ts +19 -0
  43. package/dist/src/ui/tui/components/KeyHintBar.js +20 -0
  44. package/dist/src/ui/tui/console-commands.d.ts +1 -2
  45. package/dist/src/ui/tui/console-commands.js +48 -7
  46. package/dist/src/ui/tui/flows.d.ts +1 -1
  47. package/dist/src/ui/tui/flows.js +1 -1
  48. package/dist/src/ui/tui/hooks/useAsyncEffect.d.ts +15 -0
  49. package/dist/src/ui/tui/hooks/useAsyncEffect.js +35 -0
  50. package/dist/src/ui/tui/hooks/useWizardStore.d.ts +9 -0
  51. package/dist/src/ui/tui/hooks/useWizardStore.js +11 -0
  52. package/dist/src/ui/tui/ink-ui.js +1 -1
  53. package/dist/src/ui/tui/primitives/DissolveTransition.js +4 -5
  54. package/dist/src/ui/tui/primitives/EventPlanViewer.d.ts +3 -1
  55. package/dist/src/ui/tui/primitives/EventPlanViewer.js +8 -3
  56. package/dist/src/ui/tui/primitives/ProgressList.js +1 -1
  57. package/dist/src/ui/tui/primitives/SlashCommandInput.js +19 -4
  58. package/dist/src/ui/tui/primitives/SplitView.d.ts +2 -1
  59. package/dist/src/ui/tui/primitives/SplitView.js +10 -2
  60. package/dist/src/ui/tui/primitives/TabContainer.js +10 -2
  61. package/dist/src/ui/tui/primitives/index.d.ts +0 -1
  62. package/dist/src/ui/tui/primitives/index.js +0 -1
  63. package/dist/src/ui/tui/router.js +1 -1
  64. package/dist/src/ui/tui/screen-registry.d.ts +0 -7
  65. package/dist/src/ui/tui/screen-registry.js +13 -4
  66. package/dist/src/ui/tui/screens/ActivationOptionsScreen.d.ts +2 -2
  67. package/dist/src/ui/tui/screens/ActivationOptionsScreen.js +8 -8
  68. package/dist/src/ui/tui/screens/AuthScreen.js +57 -27
  69. package/dist/src/ui/tui/screens/ChecklistScreen.d.ts +2 -12
  70. package/dist/src/ui/tui/screens/ChecklistScreen.js +22 -33
  71. package/dist/src/ui/tui/screens/DataIngestionCheckScreen.d.ts +3 -12
  72. package/dist/src/ui/tui/screens/DataIngestionCheckScreen.js +109 -39
  73. package/dist/src/ui/tui/screens/DataSetupScreen.d.ts +3 -3
  74. package/dist/src/ui/tui/screens/DataSetupScreen.js +17 -10
  75. package/dist/src/ui/tui/screens/IntroScreen.d.ts +5 -3
  76. package/dist/src/ui/tui/screens/IntroScreen.js +132 -41
  77. package/dist/src/ui/tui/screens/LoginScreen.d.ts +1 -1
  78. package/dist/src/ui/tui/screens/LoginScreen.js +4 -4
  79. package/dist/src/ui/tui/screens/LogoutScreen.d.ts +4 -2
  80. package/dist/src/ui/tui/screens/LogoutScreen.js +17 -5
  81. package/dist/src/ui/tui/screens/McpScreen.d.ts +4 -4
  82. package/dist/src/ui/tui/screens/McpScreen.js +25 -17
  83. package/dist/src/ui/tui/screens/OutageScreen.d.ts +1 -1
  84. package/dist/src/ui/tui/screens/OutageScreen.js +5 -5
  85. package/dist/src/ui/tui/screens/OutroScreen.d.ts +5 -0
  86. package/dist/src/ui/tui/screens/OutroScreen.js +21 -14
  87. package/dist/src/ui/tui/screens/RegionSelectScreen.js +15 -13
  88. package/dist/src/ui/tui/screens/RunScreen.d.ts +7 -5
  89. package/dist/src/ui/tui/screens/RunScreen.js +102 -157
  90. package/dist/src/ui/tui/screens/SettingsOverrideScreen.d.ts +1 -1
  91. package/dist/src/ui/tui/screens/SettingsOverrideScreen.js +6 -5
  92. package/dist/src/ui/tui/screens/SetupScreen.d.ts +1 -1
  93. package/dist/src/ui/tui/screens/SetupScreen.js +7 -7
  94. package/dist/src/ui/tui/screens/SlackScreen.d.ts +2 -2
  95. package/dist/src/ui/tui/screens/SlackScreen.js +60 -35
  96. package/dist/src/ui/tui/session-constants.d.ts +41 -0
  97. package/dist/src/ui/tui/session-constants.js +38 -0
  98. package/dist/src/ui/tui/start-tui.d.ts +3 -1
  99. package/dist/src/ui/tui/start-tui.js +14 -10
  100. package/dist/src/ui/tui/store.d.ts +2 -1
  101. package/dist/src/ui/tui/store.js +33 -7
  102. package/dist/src/ui/tui/styles.d.ts +75 -19
  103. package/dist/src/ui/tui/styles.js +101 -19
  104. package/dist/src/ui/tui/utils/classify-error.d.ts +14 -0
  105. package/dist/src/ui/tui/utils/classify-error.js +90 -0
  106. package/dist/src/ui/tui/utils/diagnostics.d.ts +21 -0
  107. package/dist/src/ui/tui/utils/diagnostics.js +72 -0
  108. package/dist/src/ui/tui/utils/with-retry.d.ts +12 -0
  109. package/dist/src/ui/tui/utils/with-retry.js +32 -0
  110. package/dist/src/ui/tui/utils/with-timeout.d.ts +10 -0
  111. package/dist/src/ui/tui/utils/with-timeout.js +24 -0
  112. package/dist/src/utils/ampli-settings.d.ts +1 -1
  113. package/dist/src/utils/ampli-settings.js +15 -5
  114. package/dist/src/utils/api-key-store.js +5 -5
  115. package/dist/src/utils/atomic-write.d.ts +15 -0
  116. package/dist/src/utils/atomic-write.js +34 -0
  117. package/dist/src/utils/setup-utils.js +2 -2
  118. package/dist/src/utils/token-refresh.d.ts +22 -0
  119. package/dist/src/utils/token-refresh.js +79 -0
  120. package/dist/src/utils/wizard-abort.js +6 -1
  121. package/package.json +5 -5
  122. package/skills/instrumentation/add-analytics-instrumentation/SKILL.md +142 -0
  123. package/skills/instrumentation/diff-intake/SKILL.md +128 -0
  124. package/skills/instrumentation/discover-analytics-patterns/SKILL.md +185 -0
  125. package/skills/instrumentation/discover-event-surfaces/SKILL.md +322 -0
  126. package/skills/instrumentation/discover-event-surfaces/references/best-practices.md +563 -0
  127. package/skills/instrumentation/instrument-events/SKILL.md +169 -0
  128. package/skills/instrumentation/instrument-events/references/best-practices.md +563 -0
  129. package/skills/integration/integration-android/SKILL.md +49 -0
  130. package/skills/integration/integration-android/references/EXAMPLE.md +1977 -0
  131. package/skills/integration/integration-android/references/amplitude-quickstart.md +1845 -0
  132. package/skills/integration/integration-android/references/analytics.md +1778 -0
  133. package/skills/integration/integration-android/references/basic-integration-1.0-begin.md +43 -0
  134. package/skills/integration/integration-android/references/basic-integration-1.1-edit.md +35 -0
  135. package/skills/integration/integration-android/references/basic-integration-1.2-revise.md +23 -0
  136. package/skills/integration/integration-android/references/basic-integration-1.3-conclude.md +57 -0
  137. package/skills/integration/integration-angular/SKILL.md +49 -0
  138. package/skills/integration/integration-angular/references/EXAMPLE.md +899 -0
  139. package/skills/integration/integration-angular/references/amplitude-quickstart.md +1845 -0
  140. package/skills/integration/integration-angular/references/basic-integration-1.0-begin.md +43 -0
  141. package/skills/integration/integration-angular/references/basic-integration-1.1-edit.md +35 -0
  142. package/skills/integration/integration-angular/references/basic-integration-1.2-revise.md +23 -0
  143. package/skills/integration/integration-angular/references/basic-integration-1.3-conclude.md +57 -0
  144. package/skills/integration/integration-angular/references/browser-sdk-2.md +4680 -0
  145. package/skills/integration/integration-astro-hybrid/SKILL.md +56 -0
  146. package/skills/integration/integration-astro-hybrid/references/EXAMPLE.md +1095 -0
  147. package/skills/integration/integration-astro-hybrid/references/amplitude-quickstart.md +1845 -0
  148. package/skills/integration/integration-astro-hybrid/references/basic-integration-1.0-begin.md +43 -0
  149. package/skills/integration/integration-astro-hybrid/references/basic-integration-1.1-edit.md +35 -0
  150. package/skills/integration/integration-astro-hybrid/references/basic-integration-1.2-revise.md +23 -0
  151. package/skills/integration/integration-astro-hybrid/references/basic-integration-1.3-conclude.md +57 -0
  152. package/skills/integration/integration-astro-hybrid/references/browser-sdk-2.md +4680 -0
  153. package/skills/integration/integration-astro-ssr/SKILL.md +52 -0
  154. package/skills/integration/integration-astro-ssr/references/EXAMPLE.md +1106 -0
  155. package/skills/integration/integration-astro-ssr/references/amplitude-quickstart.md +1845 -0
  156. package/skills/integration/integration-astro-ssr/references/basic-integration-1.0-begin.md +43 -0
  157. package/skills/integration/integration-astro-ssr/references/basic-integration-1.1-edit.md +35 -0
  158. package/skills/integration/integration-astro-ssr/references/basic-integration-1.2-revise.md +23 -0
  159. package/skills/integration/integration-astro-ssr/references/basic-integration-1.3-conclude.md +57 -0
  160. package/skills/integration/integration-astro-ssr/references/browser-sdk-2.md +4680 -0
  161. package/skills/integration/integration-astro-static/SKILL.md +49 -0
  162. package/skills/integration/integration-astro-static/references/EXAMPLE.md +910 -0
  163. package/skills/integration/integration-astro-static/references/amplitude-quickstart.md +1845 -0
  164. package/skills/integration/integration-astro-static/references/basic-integration-1.0-begin.md +43 -0
  165. package/skills/integration/integration-astro-static/references/basic-integration-1.1-edit.md +35 -0
  166. package/skills/integration/integration-astro-static/references/basic-integration-1.2-revise.md +23 -0
  167. package/skills/integration/integration-astro-static/references/basic-integration-1.3-conclude.md +57 -0
  168. package/skills/integration/integration-astro-static/references/browser-sdk-2.md +4680 -0
  169. package/skills/integration/integration-astro-view-transitions/SKILL.md +51 -0
  170. package/skills/integration/integration-astro-view-transitions/references/EXAMPLE.md +979 -0
  171. package/skills/integration/integration-astro-view-transitions/references/amplitude-quickstart.md +1845 -0
  172. package/skills/integration/integration-astro-view-transitions/references/basic-integration-1.0-begin.md +43 -0
  173. package/skills/integration/integration-astro-view-transitions/references/basic-integration-1.1-edit.md +35 -0
  174. package/skills/integration/integration-astro-view-transitions/references/basic-integration-1.2-revise.md +23 -0
  175. package/skills/integration/integration-astro-view-transitions/references/basic-integration-1.3-conclude.md +57 -0
  176. package/skills/integration/integration-astro-view-transitions/references/browser-sdk-2.md +4680 -0
  177. package/skills/integration/integration-django/SKILL.md +57 -0
  178. package/skills/integration/integration-django/references/EXAMPLE.md +1005 -0
  179. package/skills/integration/integration-django/references/amplitude-quickstart.md +1845 -0
  180. package/skills/integration/integration-django/references/basic-integration-1.0-begin.md +43 -0
  181. package/skills/integration/integration-django/references/basic-integration-1.1-edit.md +35 -0
  182. package/skills/integration/integration-django/references/basic-integration-1.2-revise.md +23 -0
  183. package/skills/integration/integration-django/references/basic-integration-1.3-conclude.md +57 -0
  184. package/skills/integration/integration-django/references/python.md +1424 -0
  185. package/skills/integration/integration-expo/SKILL.md +53 -0
  186. package/skills/integration/integration-expo/references/EXAMPLE.md +1291 -0
  187. package/skills/integration/integration-expo/references/amplitude-quickstart.md +1845 -0
  188. package/skills/integration/integration-expo/references/basic-integration-1.0-begin.md +43 -0
  189. package/skills/integration/integration-expo/references/basic-integration-1.1-edit.md +35 -0
  190. package/skills/integration/integration-expo/references/basic-integration-1.2-revise.md +23 -0
  191. package/skills/integration/integration-expo/references/basic-integration-1.3-conclude.md +57 -0
  192. package/skills/integration/integration-expo/references/react-native-sdk.md +2819 -0
  193. package/skills/integration/integration-fastapi/SKILL.md +57 -0
  194. package/skills/integration/integration-fastapi/references/EXAMPLE.md +1389 -0
  195. package/skills/integration/integration-fastapi/references/amplitude-quickstart.md +1845 -0
  196. package/skills/integration/integration-fastapi/references/basic-integration-1.0-begin.md +43 -0
  197. package/skills/integration/integration-fastapi/references/basic-integration-1.1-edit.md +35 -0
  198. package/skills/integration/integration-fastapi/references/basic-integration-1.2-revise.md +23 -0
  199. package/skills/integration/integration-fastapi/references/basic-integration-1.3-conclude.md +57 -0
  200. package/skills/integration/integration-fastapi/references/python.md +1424 -0
  201. package/skills/integration/integration-flask/SKILL.md +56 -0
  202. package/skills/integration/integration-flask/references/EXAMPLE.md +1130 -0
  203. package/skills/integration/integration-flask/references/amplitude-quickstart.md +1845 -0
  204. package/skills/integration/integration-flask/references/basic-integration-1.0-begin.md +43 -0
  205. package/skills/integration/integration-flask/references/basic-integration-1.1-edit.md +35 -0
  206. package/skills/integration/integration-flask/references/basic-integration-1.2-revise.md +23 -0
  207. package/skills/integration/integration-flask/references/basic-integration-1.3-conclude.md +57 -0
  208. package/skills/integration/integration-flask/references/python.md +1424 -0
  209. package/skills/integration/integration-javascript_node/SKILL.md +54 -0
  210. package/skills/integration/integration-javascript_node/references/EXAMPLE.md +365 -0
  211. package/skills/integration/integration-javascript_node/references/amplitude-quickstart.md +1845 -0
  212. package/skills/integration/integration-javascript_node/references/analytics.md +1778 -0
  213. package/skills/integration/integration-javascript_node/references/basic-integration-1.0-begin.md +43 -0
  214. package/skills/integration/integration-javascript_node/references/basic-integration-1.1-edit.md +35 -0
  215. package/skills/integration/integration-javascript_node/references/basic-integration-1.2-revise.md +23 -0
  216. package/skills/integration/integration-javascript_node/references/basic-integration-1.3-conclude.md +57 -0
  217. package/skills/integration/integration-javascript_web/SKILL.md +58 -0
  218. package/skills/integration/integration-javascript_web/references/EXAMPLE.md +451 -0
  219. package/skills/integration/integration-javascript_web/references/amplitude-quickstart.md +1845 -0
  220. package/skills/integration/integration-javascript_web/references/basic-integration-1.0-begin.md +43 -0
  221. package/skills/integration/integration-javascript_web/references/basic-integration-1.1-edit.md +35 -0
  222. package/skills/integration/integration-javascript_web/references/basic-integration-1.2-revise.md +23 -0
  223. package/skills/integration/integration-javascript_web/references/basic-integration-1.3-conclude.md +57 -0
  224. package/skills/integration/integration-javascript_web/references/browser-sdk-2.md +4680 -0
  225. package/skills/integration/integration-laravel/SKILL.md +52 -0
  226. package/skills/integration/integration-laravel/references/EXAMPLE.md +2039 -0
  227. package/skills/integration/integration-laravel/references/amplitude-quickstart.md +1845 -0
  228. package/skills/integration/integration-laravel/references/analytics.md +1778 -0
  229. package/skills/integration/integration-laravel/references/basic-integration-1.0-begin.md +43 -0
  230. package/skills/integration/integration-laravel/references/basic-integration-1.1-edit.md +35 -0
  231. package/skills/integration/integration-laravel/references/basic-integration-1.2-revise.md +23 -0
  232. package/skills/integration/integration-laravel/references/basic-integration-1.3-conclude.md +57 -0
  233. package/skills/integration/integration-nextjs-app-router/SKILL.md +54 -0
  234. package/skills/integration/integration-nextjs-app-router/references/EXAMPLE.md +673 -0
  235. package/skills/integration/integration-nextjs-app-router/references/amplitude-quickstart.md +1845 -0
  236. package/skills/integration/integration-nextjs-app-router/references/basic-integration-1.0-begin.md +43 -0
  237. package/skills/integration/integration-nextjs-app-router/references/basic-integration-1.1-edit.md +35 -0
  238. package/skills/integration/integration-nextjs-app-router/references/basic-integration-1.2-revise.md +23 -0
  239. package/skills/integration/integration-nextjs-app-router/references/basic-integration-1.3-conclude.md +57 -0
  240. package/skills/integration/integration-nextjs-app-router/references/browser-sdk-2.md +4680 -0
  241. package/skills/integration/integration-nextjs-pages-router/SKILL.md +54 -0
  242. package/skills/integration/integration-nextjs-pages-router/references/EXAMPLE.md +735 -0
  243. package/skills/integration/integration-nextjs-pages-router/references/amplitude-quickstart.md +1845 -0
  244. package/skills/integration/integration-nextjs-pages-router/references/basic-integration-1.0-begin.md +43 -0
  245. package/skills/integration/integration-nextjs-pages-router/references/basic-integration-1.1-edit.md +35 -0
  246. package/skills/integration/integration-nextjs-pages-router/references/basic-integration-1.2-revise.md +23 -0
  247. package/skills/integration/integration-nextjs-pages-router/references/basic-integration-1.3-conclude.md +57 -0
  248. package/skills/integration/integration-nextjs-pages-router/references/browser-sdk-2.md +4680 -0
  249. package/skills/integration/integration-nuxt-3.6/SKILL.md +46 -0
  250. package/skills/integration/integration-nuxt-3.6/references/EXAMPLE.md +8422 -0
  251. package/skills/integration/integration-nuxt-3.6/references/amplitude-quickstart.md +1845 -0
  252. package/skills/integration/integration-nuxt-3.6/references/basic-integration-1.0-begin.md +43 -0
  253. package/skills/integration/integration-nuxt-3.6/references/basic-integration-1.1-edit.md +35 -0
  254. package/skills/integration/integration-nuxt-3.6/references/basic-integration-1.2-revise.md +23 -0
  255. package/skills/integration/integration-nuxt-3.6/references/basic-integration-1.3-conclude.md +57 -0
  256. package/skills/integration/integration-nuxt-3.6/references/browser-sdk-2.md +4680 -0
  257. package/skills/integration/integration-nuxt-4/SKILL.md +46 -0
  258. package/skills/integration/integration-nuxt-4/references/EXAMPLE.md +8670 -0
  259. package/skills/integration/integration-nuxt-4/references/amplitude-quickstart.md +1845 -0
  260. package/skills/integration/integration-nuxt-4/references/basic-integration-1.0-begin.md +43 -0
  261. package/skills/integration/integration-nuxt-4/references/basic-integration-1.1-edit.md +35 -0
  262. package/skills/integration/integration-nuxt-4/references/basic-integration-1.2-revise.md +23 -0
  263. package/skills/integration/integration-nuxt-4/references/basic-integration-1.3-conclude.md +57 -0
  264. package/skills/integration/integration-nuxt-4/references/browser-sdk-2.md +4680 -0
  265. package/skills/integration/integration-python/SKILL.md +53 -0
  266. package/skills/integration/integration-python/references/EXAMPLE.md +445 -0
  267. package/skills/integration/integration-python/references/amplitude-quickstart.md +1845 -0
  268. package/skills/integration/integration-python/references/basic-integration-1.0-begin.md +43 -0
  269. package/skills/integration/integration-python/references/basic-integration-1.1-edit.md +35 -0
  270. package/skills/integration/integration-python/references/basic-integration-1.2-revise.md +23 -0
  271. package/skills/integration/integration-python/references/basic-integration-1.3-conclude.md +57 -0
  272. package/skills/integration/integration-python/references/python.md +1424 -0
  273. package/skills/integration/integration-react-native/SKILL.md +49 -0
  274. package/skills/integration/integration-react-native/references/EXAMPLE.md +2253 -0
  275. package/skills/integration/integration-react-native/references/amplitude-quickstart.md +1845 -0
  276. package/skills/integration/integration-react-native/references/basic-integration-1.0-begin.md +43 -0
  277. package/skills/integration/integration-react-native/references/basic-integration-1.1-edit.md +35 -0
  278. package/skills/integration/integration-react-native/references/basic-integration-1.2-revise.md +23 -0
  279. package/skills/integration/integration-react-native/references/basic-integration-1.3-conclude.md +57 -0
  280. package/skills/integration/integration-react-native/references/react-native-sdk.md +2819 -0
  281. package/skills/integration/integration-react-react-router-6/SKILL.md +53 -0
  282. package/skills/integration/integration-react-react-router-6/references/EXAMPLE.md +570 -0
  283. package/skills/integration/integration-react-react-router-6/references/amplitude-quickstart.md +1845 -0
  284. package/skills/integration/integration-react-react-router-6/references/basic-integration-1.0-begin.md +43 -0
  285. package/skills/integration/integration-react-react-router-6/references/basic-integration-1.1-edit.md +35 -0
  286. package/skills/integration/integration-react-react-router-6/references/basic-integration-1.2-revise.md +23 -0
  287. package/skills/integration/integration-react-react-router-6/references/basic-integration-1.3-conclude.md +57 -0
  288. package/skills/integration/integration-react-react-router-6/references/browser-sdk-2.md +4680 -0
  289. package/skills/integration/integration-react-react-router-7-data/SKILL.md +53 -0
  290. package/skills/integration/integration-react-react-router-7-data/references/EXAMPLE.md +830 -0
  291. package/skills/integration/integration-react-react-router-7-data/references/amplitude-quickstart.md +1845 -0
  292. package/skills/integration/integration-react-react-router-7-data/references/basic-integration-1.0-begin.md +43 -0
  293. package/skills/integration/integration-react-react-router-7-data/references/basic-integration-1.1-edit.md +35 -0
  294. package/skills/integration/integration-react-react-router-7-data/references/basic-integration-1.2-revise.md +23 -0
  295. package/skills/integration/integration-react-react-router-7-data/references/basic-integration-1.3-conclude.md +57 -0
  296. package/skills/integration/integration-react-react-router-7-data/references/browser-sdk-2.md +4680 -0
  297. package/skills/integration/integration-react-react-router-7-declarative/SKILL.md +53 -0
  298. package/skills/integration/integration-react-react-router-7-declarative/references/EXAMPLE.md +609 -0
  299. package/skills/integration/integration-react-react-router-7-declarative/references/amplitude-quickstart.md +1845 -0
  300. package/skills/integration/integration-react-react-router-7-declarative/references/basic-integration-1.0-begin.md +43 -0
  301. package/skills/integration/integration-react-react-router-7-declarative/references/basic-integration-1.1-edit.md +35 -0
  302. package/skills/integration/integration-react-react-router-7-declarative/references/basic-integration-1.2-revise.md +23 -0
  303. package/skills/integration/integration-react-react-router-7-declarative/references/basic-integration-1.3-conclude.md +57 -0
  304. package/skills/integration/integration-react-react-router-7-declarative/references/browser-sdk-2.md +4680 -0
  305. package/skills/integration/integration-react-react-router-7-framework/SKILL.md +53 -0
  306. package/skills/integration/integration-react-react-router-7-framework/references/EXAMPLE.md +1081 -0
  307. package/skills/integration/integration-react-react-router-7-framework/references/amplitude-quickstart.md +1845 -0
  308. package/skills/integration/integration-react-react-router-7-framework/references/basic-integration-1.0-begin.md +43 -0
  309. package/skills/integration/integration-react-react-router-7-framework/references/basic-integration-1.1-edit.md +35 -0
  310. package/skills/integration/integration-react-react-router-7-framework/references/basic-integration-1.2-revise.md +23 -0
  311. package/skills/integration/integration-react-react-router-7-framework/references/basic-integration-1.3-conclude.md +57 -0
  312. package/skills/integration/integration-react-react-router-7-framework/references/browser-sdk-2.md +4680 -0
  313. package/skills/integration/integration-react-tanstack-router-code-based/SKILL.md +57 -0
  314. package/skills/integration/integration-react-tanstack-router-code-based/references/EXAMPLE.md +659 -0
  315. package/skills/integration/integration-react-tanstack-router-code-based/references/amplitude-quickstart.md +1845 -0
  316. package/skills/integration/integration-react-tanstack-router-code-based/references/basic-integration-1.0-begin.md +43 -0
  317. package/skills/integration/integration-react-tanstack-router-code-based/references/basic-integration-1.1-edit.md +35 -0
  318. package/skills/integration/integration-react-tanstack-router-code-based/references/basic-integration-1.2-revise.md +23 -0
  319. package/skills/integration/integration-react-tanstack-router-code-based/references/basic-integration-1.3-conclude.md +57 -0
  320. package/skills/integration/integration-react-tanstack-router-code-based/references/browser-sdk-2.md +4680 -0
  321. package/skills/integration/integration-react-tanstack-router-file-based/SKILL.md +57 -0
  322. package/skills/integration/integration-react-tanstack-router-file-based/references/EXAMPLE.md +777 -0
  323. package/skills/integration/integration-react-tanstack-router-file-based/references/amplitude-quickstart.md +1845 -0
  324. package/skills/integration/integration-react-tanstack-router-file-based/references/basic-integration-1.0-begin.md +43 -0
  325. package/skills/integration/integration-react-tanstack-router-file-based/references/basic-integration-1.1-edit.md +35 -0
  326. package/skills/integration/integration-react-tanstack-router-file-based/references/basic-integration-1.2-revise.md +23 -0
  327. package/skills/integration/integration-react-tanstack-router-file-based/references/basic-integration-1.3-conclude.md +57 -0
  328. package/skills/integration/integration-react-tanstack-router-file-based/references/browser-sdk-2.md +4680 -0
  329. package/skills/integration/integration-react-vite/SKILL.md +53 -0
  330. package/skills/integration/integration-react-vite/references/EXAMPLE.md +542 -0
  331. package/skills/integration/integration-react-vite/references/amplitude-quickstart.md +1845 -0
  332. package/skills/integration/integration-react-vite/references/basic-integration-1.0-begin.md +43 -0
  333. package/skills/integration/integration-react-vite/references/basic-integration-1.1-edit.md +35 -0
  334. package/skills/integration/integration-react-vite/references/basic-integration-1.2-revise.md +23 -0
  335. package/skills/integration/integration-react-vite/references/basic-integration-1.3-conclude.md +57 -0
  336. package/skills/integration/integration-react-vite/references/browser-sdk-2.md +4680 -0
  337. package/skills/integration/integration-ruby/SKILL.md +50 -0
  338. package/skills/integration/integration-ruby/references/EXAMPLE.md +420 -0
  339. package/skills/integration/integration-ruby/references/amplitude-quickstart.md +1845 -0
  340. package/skills/integration/integration-ruby/references/analytics.md +1778 -0
  341. package/skills/integration/integration-ruby/references/basic-integration-1.0-begin.md +43 -0
  342. package/skills/integration/integration-ruby/references/basic-integration-1.1-edit.md +35 -0
  343. package/skills/integration/integration-ruby/references/basic-integration-1.2-revise.md +23 -0
  344. package/skills/integration/integration-ruby/references/basic-integration-1.3-conclude.md +57 -0
  345. package/skills/integration/integration-ruby-on-rails/SKILL.md +55 -0
  346. package/skills/integration/integration-ruby-on-rails/references/EXAMPLE.md +1013 -0
  347. package/skills/integration/integration-ruby-on-rails/references/amplitude-quickstart.md +1845 -0
  348. package/skills/integration/integration-ruby-on-rails/references/analytics.md +1778 -0
  349. package/skills/integration/integration-ruby-on-rails/references/basic-integration-1.0-begin.md +43 -0
  350. package/skills/integration/integration-ruby-on-rails/references/basic-integration-1.1-edit.md +35 -0
  351. package/skills/integration/integration-ruby-on-rails/references/basic-integration-1.2-revise.md +23 -0
  352. package/skills/integration/integration-ruby-on-rails/references/basic-integration-1.3-conclude.md +57 -0
  353. package/skills/integration/integration-sveltekit/SKILL.md +47 -0
  354. package/skills/integration/integration-sveltekit/references/EXAMPLE.md +14121 -0
  355. package/skills/integration/integration-sveltekit/references/amplitude-quickstart.md +1845 -0
  356. package/skills/integration/integration-sveltekit/references/basic-integration-1.0-begin.md +43 -0
  357. package/skills/integration/integration-sveltekit/references/basic-integration-1.1-edit.md +35 -0
  358. package/skills/integration/integration-sveltekit/references/basic-integration-1.2-revise.md +23 -0
  359. package/skills/integration/integration-sveltekit/references/basic-integration-1.3-conclude.md +57 -0
  360. package/skills/integration/integration-sveltekit/references/browser-sdk-2.md +4680 -0
  361. package/skills/integration/integration-swift/SKILL.md +49 -0
  362. package/skills/integration/integration-swift/references/EXAMPLE.md +660 -0
  363. package/skills/integration/integration-swift/references/amplitude-quickstart.md +1845 -0
  364. package/skills/integration/integration-swift/references/analytics.md +1778 -0
  365. package/skills/integration/integration-swift/references/basic-integration-1.0-begin.md +43 -0
  366. package/skills/integration/integration-swift/references/basic-integration-1.1-edit.md +35 -0
  367. package/skills/integration/integration-swift/references/basic-integration-1.2-revise.md +23 -0
  368. package/skills/integration/integration-swift/references/basic-integration-1.3-conclude.md +57 -0
  369. package/skills/integration/integration-tanstack-start/SKILL.md +58 -0
  370. package/skills/integration/integration-tanstack-start/references/EXAMPLE.md +998 -0
  371. package/skills/integration/integration-tanstack-start/references/amplitude-quickstart.md +1845 -0
  372. package/skills/integration/integration-tanstack-start/references/basic-integration-1.0-begin.md +43 -0
  373. package/skills/integration/integration-tanstack-start/references/basic-integration-1.1-edit.md +35 -0
  374. package/skills/integration/integration-tanstack-start/references/basic-integration-1.2-revise.md +23 -0
  375. package/skills/integration/integration-tanstack-start/references/basic-integration-1.3-conclude.md +57 -0
  376. package/skills/integration/integration-tanstack-start/references/browser-sdk-2.md +4680 -0
  377. package/skills/integration/integration-vue-3/SKILL.md +46 -0
  378. package/skills/integration/integration-vue-3/references/EXAMPLE.md +846 -0
  379. package/skills/integration/integration-vue-3/references/amplitude-quickstart.md +1845 -0
  380. package/skills/integration/integration-vue-3/references/basic-integration-1.0-begin.md +43 -0
  381. package/skills/integration/integration-vue-3/references/basic-integration-1.1-edit.md +35 -0
  382. package/skills/integration/integration-vue-3/references/basic-integration-1.2-revise.md +23 -0
  383. package/skills/integration/integration-vue-3/references/basic-integration-1.3-conclude.md +57 -0
  384. package/skills/integration/integration-vue-3/references/browser-sdk-2.md +4680 -0
  385. package/skills/taxonomy/amplitude-quickstart-taxonomy-agent/SKILL.md +228 -0
  386. package/dist/src/ui/tui/components/TitleBar.d.ts +0 -8
  387. package/dist/src/ui/tui/components/TitleBar.js +0 -27
  388. package/dist/src/ui/tui/primitives/KagiSmallWebViewer.d.ts +0 -7
  389. package/dist/src/ui/tui/primitives/KagiSmallWebViewer.js +0 -101
  390. package/dist/src/utils/anthropic-status.d.ts +0 -17
  391. package/dist/src/utils/anthropic-status.js +0 -51
@@ -0,0 +1,673 @@
1
+ # Amplitude Next.js App Router Example Project
2
+
3
+ Repository: https://github.com/amplitude/context-hub
4
+ Path: basics/next-app-router
5
+
6
+ ---
7
+
8
+ ## README.md
9
+
10
+ # Amplitude Next.js App Router Example
11
+
12
+ This is a [Next.js](https://nextjs.org) App Router example demonstrating Amplitude integration with product analytics and event tracking.
13
+
14
+ ### Amplitude SDKs
15
+
16
+ On the client, this example follows the [Browser Unified SDK (npm)](https://amplitude.com/docs/sdks/analytics/browser/browser-unified-sdk#unified-sdk-npm). Add [`@amplitude/unified`](https://www.npmjs.com/package/@amplitude/unified) and call `initAll` once. [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. Here `initAll` runs from [instrumentation-client.ts](instrumentation-client.ts). Optional arguments cover `serverZone`, `instanceName`, and product blocks for `analytics`, `sessionReplay`, `experiment`, and `engagement` ([configuration](https://amplitude.com/docs/sdks/analytics/browser/browser-unified-sdk#configuration)). Analytics settings match [Browser SDK 2](https://amplitude.com/docs/sdks/analytics/browser/browser-sdk-2#initialize-the-sdk).
17
+
18
+ The `experiment` config is for **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 **CDN** script, not the Unified **npm** package.
19
+
20
+ On the server, use [`@amplitude/analytics-node`](https://www.npmjs.com/package/@amplitude/analytics-node) from `src/lib/amplitude-server.ts`. Keep `@amplitude/unified` on the client only.
21
+
22
+ ## Features
23
+
24
+ - **Product analytics**: Track user events and behaviors
25
+ - **User authentication**: Demo login system with Amplitude user identification
26
+ - **Server-side & Client-side tracking**: Examples of both tracking methods
27
+
28
+ ## Getting started
29
+
30
+ ### 1. Install dependencies
31
+
32
+ ```bash
33
+ npm install
34
+ # or
35
+ pnpm install
36
+ ```
37
+
38
+ ### 2. Configure environment variables
39
+
40
+ Create a `.env.local` file in the root directory:
41
+
42
+ ```bash
43
+ NEXT_PUBLIC_AMPLITUDE_API_KEY=your_amplitude_api_key
44
+ ```
45
+
46
+ Get your Amplitude API key from your [Amplitude project settings](https://app.amplitude.com).
47
+
48
+ ### 3. Run the development server
49
+
50
+ ```bash
51
+ npm run dev
52
+ # or
53
+ pnpm dev
54
+ ```
55
+
56
+ Open [http://localhost:3000](http://localhost:3000) with your browser to see the app.
57
+
58
+ ## Project structure
59
+
60
+ ```
61
+ src/
62
+ ├── app/
63
+ │ ├── api/
64
+ │ │ └── auth/
65
+ │ │ └── login/
66
+ │ │ └── route.ts # Login API with server-side tracking
67
+ │ ├── burrito/
68
+ │ │ └── page.tsx # Demo feature page with event tracking
69
+ │ ├── profile/
70
+ │ │ └── page.tsx # User profile page
71
+ │ ├── layout.tsx # Root layout with providers
72
+ │ ├── page.tsx # Home/Login page
73
+ │ └── globals.css # Global styles
74
+ ├── components/
75
+ │ └── Header.tsx # Navigation header with auth state
76
+ ├── contexts/
77
+ │ └── AuthContext.tsx # Authentication context with Amplitude integration
78
+ └── lib/
79
+ └── amplitude-server.ts # Server-side Amplitude client
80
+
81
+ instrumentation-client.ts # Client-side Amplitude initialization
82
+ ```
83
+
84
+ ## Key integration points
85
+
86
+ ### Client-side initialization (instrumentation-client.ts)
87
+
88
+ ```typescript
89
+ import * as amplitude from "@amplitude/unified";
90
+
91
+ void amplitude.initAll(process.env.NEXT_PUBLIC_AMPLITUDE_API_KEY!, {
92
+ analytics: {
93
+ logLevel:
94
+ process.env.NODE_ENV === "development"
95
+ ? amplitude.Types.LogLevel.Debug
96
+ : amplitude.Types.LogLevel.None,
97
+ },
98
+ });
99
+ ```
100
+
101
+ ### User identification (AuthContext.tsx)
102
+
103
+ ```typescript
104
+ amplitude.setUserId(username);
105
+ const identifyObj = new Identify();
106
+ identifyObj.set('username', username);
107
+ amplitude.identify(identifyObj);
108
+ ```
109
+
110
+ ### Event tracking (burrito/page.tsx)
111
+
112
+ ```typescript
113
+ amplitude.track('Burrito Considered', {
114
+ total_considerations: count,
115
+ username: username,
116
+ });
117
+ ```
118
+
119
+ ### Server-side tracking (app/api/auth/login/route.ts)
120
+
121
+ ```typescript
122
+ const amplitude = getAmplitudeClient();
123
+ amplitude.track('Server Login Completed', { username }, { user_id: username });
124
+ ```
125
+
126
+ ## App router differences from pages router
127
+
128
+ This example uses Next.js App Router instead of Pages Router. Key differences:
129
+
130
+ 1. **File-based routing**: Pages in `src/app/` instead of `src/pages/`
131
+ 2. **layout.tsx**: Root layout component wraps all pages
132
+ 3. **API Routes**: Located in `src/app/api/` with `route.ts` files
133
+ 4. **'use client'**: Client components need explicit directive
134
+ 5. **useRouter**: From `next/navigation` instead of `next/router`
135
+ 6. **Metadata**: Exported from layout/page instead of Head component
136
+ 7. **Server Components**: Components are server-side by default
137
+
138
+ ## Learn more
139
+
140
+ - [Amplitude Documentation](https://amplitude.com/docs)
141
+ - [Next.js App Router Documentation](https://nextjs.org/docs/app)
142
+
143
+ ## Deploy on Vercel
144
+
145
+ The easiest way to deploy your Next.js app is to use the [Vercel Platform](https://vercel.com/new).
146
+
147
+ Check out the [Next.js deployment documentation](https://nextjs.org/docs/app/building-your-application/deploying) for more details.
148
+
149
+ ---
150
+
151
+ ## .env.example
152
+
153
+ ```example
154
+ # Amplitude Configuration
155
+ NEXT_PUBLIC_AMPLITUDE_API_KEY=your_amplitude_api_key_here
156
+
157
+ ```
158
+
159
+ ---
160
+
161
+ ## instrumentation-client.ts
162
+
163
+ ```ts
164
+ import * as amplitude from "@amplitude/unified";
165
+
166
+ void amplitude.initAll(process.env.NEXT_PUBLIC_AMPLITUDE_API_KEY!, {
167
+ analytics: {
168
+ logLevel:
169
+ process.env.NODE_ENV === "development"
170
+ ? amplitude.Types.LogLevel.Debug
171
+ : amplitude.Types.LogLevel.None,
172
+ },
173
+ });
174
+
175
+ ```
176
+
177
+ ---
178
+
179
+ ## next-env.d.ts
180
+
181
+ ```ts
182
+ /// <reference types="next" />
183
+ /// <reference types="next/image-types/global" />
184
+ /// <reference path="./.next/types/routes.d.ts" />
185
+
186
+ // NOTE: This file should not be edited
187
+ // see https://nextjs.org/docs/app/api-reference/config/typescript for more information.
188
+
189
+ ```
190
+
191
+ ---
192
+
193
+ ## next.config.ts
194
+
195
+ ```ts
196
+ import type { NextConfig } from "next";
197
+
198
+ const nextConfig: NextConfig = {
199
+ /* config options here */
200
+ };
201
+
202
+ export default nextConfig;
203
+
204
+ ```
205
+
206
+ ---
207
+
208
+ ## src/app/api/auth/login/route.ts
209
+
210
+ ```ts
211
+ import { NextResponse } from 'next/server';
212
+ import { getAmplitudeClient } from '@/lib/amplitude-server';
213
+
214
+ const users = new Map<string, { username: string; burritoConsiderations: number }>();
215
+
216
+ export async function POST(request: Request) {
217
+ const { username, password } = await request.json();
218
+
219
+ if (!username || !password) {
220
+ return NextResponse.json({ error: 'Username and password required' }, { status: 400 });
221
+ }
222
+
223
+ let user = users.get(username);
224
+ const isNewUser = !user;
225
+
226
+ if (!user) {
227
+ user = { username, burritoConsiderations: 0 };
228
+ users.set(username, user);
229
+ }
230
+
231
+ // Capture server-side login event with Amplitude
232
+ const amplitude = getAmplitudeClient();
233
+ if (amplitude) {
234
+ amplitude.track('Server Login Completed', {
235
+ username: username,
236
+ isNewUser: isNewUser,
237
+ source: 'api',
238
+ }, { user_id: username });
239
+ }
240
+
241
+ return NextResponse.json({ success: true, user });
242
+ }
243
+
244
+ ```
245
+
246
+ ---
247
+
248
+ ## src/app/burrito/page.tsx
249
+
250
+ ```tsx
251
+ 'use client';
252
+
253
+ import { useState } from 'react';
254
+ import { useAuth } from '@/contexts/AuthContext';
255
+ import { useRouter } from 'next/navigation';
256
+ import * as amplitude from '@amplitude/unified';
257
+
258
+ export default function BurritoPage() {
259
+ const { user, incrementBurritoConsiderations } = useAuth();
260
+ const router = useRouter();
261
+ const [hasConsidered, setHasConsidered] = useState(false);
262
+
263
+ // Redirect to home if not logged in
264
+ if (!user) {
265
+ router.push('/');
266
+ return null;
267
+ }
268
+
269
+ const handleConsideration = () => {
270
+ incrementBurritoConsiderations();
271
+ setHasConsidered(true);
272
+ setTimeout(() => setHasConsidered(false), 2000);
273
+
274
+ // Track burrito consideration event with Amplitude
275
+ amplitude.track('Burrito Considered', {
276
+ total_considerations: user.burritoConsiderations + 1,
277
+ username: user.username,
278
+ });
279
+ };
280
+
281
+ return (
282
+ <div className="container">
283
+ <h1>Burrito consideration zone</h1>
284
+ <p>Take a moment to truly consider the potential of burritos.</p>
285
+
286
+ <div style={{ textAlign: 'center' }}>
287
+ <button
288
+ onClick={handleConsideration}
289
+ className="btn-burrito"
290
+ >
291
+ I have considered the burrito potential
292
+ </button>
293
+
294
+ {hasConsidered && (
295
+ <p className="success">
296
+ Thank you for your consideration! Count: {user.burritoConsiderations}
297
+ </p>
298
+ )}
299
+ </div>
300
+
301
+ <div className="stats">
302
+ <h3>Consideration stats</h3>
303
+ <p>Total considerations: {user.burritoConsiderations}</p>
304
+ </div>
305
+ </div>
306
+ );
307
+ }
308
+
309
+ ```
310
+
311
+ ---
312
+
313
+ ## src/app/layout.tsx
314
+
315
+ ```tsx
316
+ import type { Metadata } from "next";
317
+ import "./globals.css";
318
+ import { AuthProvider } from "@/contexts/AuthContext";
319
+ import Header from "@/components/Header";
320
+
321
+ export const metadata: Metadata = {
322
+ title: "Burrito Consideration App",
323
+ description: "Consider the potential of burritos",
324
+ };
325
+
326
+ export default function RootLayout({
327
+ children,
328
+ }: Readonly<{
329
+ children: React.ReactNode;
330
+ }>) {
331
+ return (
332
+ <html lang="en">
333
+ <body>
334
+ <AuthProvider>
335
+ <Header />
336
+ <main>{children}</main>
337
+ </AuthProvider>
338
+ </body>
339
+ </html>
340
+ );
341
+ }
342
+
343
+ ```
344
+
345
+ ---
346
+
347
+ ## src/app/page.tsx
348
+
349
+ ```tsx
350
+ 'use client';
351
+
352
+ import { useState } from 'react';
353
+ import { useAuth } from '@/contexts/AuthContext';
354
+
355
+ export default function Home() {
356
+ const { user, login } = useAuth();
357
+ const [username, setUsername] = useState('');
358
+ const [password, setPassword] = useState('');
359
+ const [error, setError] = useState('');
360
+
361
+ const handleSubmit = async (e: React.FormEvent) => {
362
+ e.preventDefault();
363
+ setError('');
364
+
365
+ try {
366
+ const success = await login(username, password);
367
+ if (success) {
368
+ setUsername('');
369
+ setPassword('');
370
+ } else {
371
+ setError('Please provide both username and password');
372
+ }
373
+ } catch (err) {
374
+ console.error('Login failed:', err);
375
+ setError('An error occurred during login');
376
+ }
377
+ };
378
+
379
+ if (user) {
380
+ return (
381
+ <div className="container">
382
+ <h1>Welcome back, {user.username}!</h1>
383
+ <p>You are now logged in. Feel free to explore:</p>
384
+ <ul>
385
+ <li>Consider the potential of burritos</li>
386
+ <li>View your profile and statistics</li>
387
+ </ul>
388
+ </div>
389
+ );
390
+ }
391
+
392
+ return (
393
+ <div className="container">
394
+ <h1>Welcome to Burrito Consideration App</h1>
395
+ <p>Please sign in to begin your burrito journey</p>
396
+
397
+ <form onSubmit={handleSubmit} className="form">
398
+ <div className="form-group">
399
+ <label htmlFor="username">Username:</label>
400
+ <input
401
+ type="text"
402
+ id="username"
403
+ value={username}
404
+ onChange={(e) => setUsername(e.target.value)}
405
+ placeholder="Enter any username"
406
+ />
407
+ </div>
408
+
409
+ <div className="form-group">
410
+ <label htmlFor="password">Password:</label>
411
+ <input
412
+ type="password"
413
+ id="password"
414
+ value={password}
415
+ onChange={(e) => setPassword(e.target.value)}
416
+ placeholder="Enter any password"
417
+ />
418
+ </div>
419
+
420
+ {error && <p className="error">{error}</p>}
421
+
422
+ <button type="submit" className="btn-primary">Sign In</button>
423
+ </form>
424
+
425
+ <p className="note">
426
+ Note: This is a demo app. Use any username and password to sign in.
427
+ </p>
428
+ </div>
429
+ );
430
+ }
431
+ ```
432
+
433
+ ---
434
+
435
+ ## src/app/profile/page.tsx
436
+
437
+ ```tsx
438
+ 'use client';
439
+
440
+ import { useAuth } from '@/contexts/AuthContext';
441
+ import { useRouter } from 'next/navigation';
442
+
443
+ export default function ProfilePage() {
444
+ const { user } = useAuth();
445
+ const router = useRouter();
446
+
447
+ // Redirect to home if not logged in
448
+ if (!user) {
449
+ router.push('/');
450
+ return null;
451
+ }
452
+
453
+ return (
454
+ <div className="container">
455
+ <h1>User Profile</h1>
456
+
457
+ <div className="stats">
458
+ <h2>Your Information</h2>
459
+ <p><strong>Username:</strong> {user.username}</p>
460
+ <p><strong>Burrito Considerations:</strong> {user.burritoConsiderations}</p>
461
+ </div>
462
+
463
+ <div style={{ marginTop: '2rem' }}>
464
+ <h3>Your Burrito Journey</h3>
465
+ {user.burritoConsiderations === 0 ? (
466
+ <p>You haven&apos;t considered any burritos yet. Visit the Burrito Consideration page to start!</p>
467
+ ) : user.burritoConsiderations === 1 ? (
468
+ <p>You&apos;ve considered the burrito potential once. Keep going!</p>
469
+ ) : user.burritoConsiderations < 5 ? (
470
+ <p>You&apos;re getting the hang of burrito consideration!</p>
471
+ ) : user.burritoConsiderations < 10 ? (
472
+ <p>You&apos;re becoming a burrito consideration expert!</p>
473
+ ) : (
474
+ <p>You are a true burrito consideration master!</p>
475
+ )}
476
+ </div>
477
+ </div>
478
+ );
479
+ }
480
+
481
+ ```
482
+
483
+ ---
484
+
485
+ ## src/components/Header.tsx
486
+
487
+ ```tsx
488
+ 'use client';
489
+
490
+ import Link from 'next/link';
491
+ import { useAuth } from '@/contexts/AuthContext';
492
+
493
+ export default function Header() {
494
+ const { user, logout } = useAuth();
495
+
496
+ return (
497
+ <header className="header">
498
+ <div className="header-container">
499
+ <nav>
500
+ <Link href="/">Home</Link>
501
+ {user && (
502
+ <>
503
+ <Link href="/burrito">Burrito Consideration</Link>
504
+ <Link href="/profile">Profile</Link>
505
+ </>
506
+ )}
507
+ </nav>
508
+ <div className="user-section">
509
+ {user ? (
510
+ <>
511
+ <span>Welcome, {user.username}!</span>
512
+ <button onClick={logout} className="btn-logout">
513
+ Logout
514
+ </button>
515
+ </>
516
+ ) : (
517
+ <span>Not logged in</span>
518
+ )}
519
+ </div>
520
+ </div>
521
+ </header>
522
+ );
523
+ }
524
+ ```
525
+
526
+ ---
527
+
528
+ ## src/contexts/AuthContext.tsx
529
+
530
+ ```tsx
531
+ 'use client';
532
+
533
+ import { createContext, useContext, useState, ReactNode } from 'react';
534
+ import * as amplitude from '@amplitude/unified';
535
+ import { Identify } from '@amplitude/unified';
536
+
537
+ interface User {
538
+ username: string;
539
+ burritoConsiderations: number;
540
+ }
541
+
542
+ interface AuthContextType {
543
+ user: User | null;
544
+ login: (username: string, password: string) => Promise<boolean>;
545
+ logout: () => void;
546
+ incrementBurritoConsiderations: () => void;
547
+ }
548
+
549
+ const AuthContext = createContext<AuthContextType | undefined>(undefined);
550
+
551
+ const users: Map<string, User> = new Map();
552
+
553
+ export function AuthProvider({ children }: { children: ReactNode }) {
554
+ // Use lazy initializer to read from localStorage only once on mount
555
+ const [user, setUser] = useState<User | null>(() => {
556
+ if (typeof window === 'undefined') return null;
557
+
558
+ const storedUsername = localStorage.getItem('currentUser');
559
+ if (storedUsername) {
560
+ const existingUser = users.get(storedUsername);
561
+ if (existingUser) {
562
+ return existingUser;
563
+ }
564
+ }
565
+ return null;
566
+ });
567
+
568
+ const login = async (username: string, password: string): Promise<boolean> => {
569
+ try {
570
+ const response = await fetch('/api/auth/login', {
571
+ method: 'POST',
572
+ headers: { 'Content-Type': 'application/json' },
573
+ body: JSON.stringify({ username, password }),
574
+ });
575
+
576
+ if (response.ok) {
577
+ const { user: userData } = await response.json();
578
+
579
+ let localUser = users.get(username);
580
+ if (!localUser) {
581
+ localUser = userData as User;
582
+ users.set(username, localUser);
583
+ }
584
+
585
+ setUser(localUser);
586
+ localStorage.setItem('currentUser', username);
587
+
588
+ // Identify user in Amplitude using username as user ID
589
+ amplitude.setUserId(username);
590
+ const identifyObj = new Identify();
591
+ identifyObj.set('username', username);
592
+ amplitude.identify(identifyObj);
593
+
594
+ // Capture login event
595
+ amplitude.track('User Logged In', {
596
+ username: username,
597
+ });
598
+
599
+ return true;
600
+ }
601
+ return false;
602
+ } catch (error) {
603
+ console.error('Login error:', error);
604
+ return false;
605
+ }
606
+ };
607
+
608
+ const logout = () => {
609
+ // Capture logout event before resetting
610
+ amplitude.track('User Logged Out');
611
+ amplitude.reset();
612
+
613
+ setUser(null);
614
+ localStorage.removeItem('currentUser');
615
+ };
616
+
617
+ const incrementBurritoConsiderations = () => {
618
+ if (user) {
619
+ user.burritoConsiderations++;
620
+ users.set(user.username, user);
621
+ setUser({ ...user });
622
+ }
623
+ };
624
+
625
+ return (
626
+ <AuthContext.Provider value={{ user, login, logout, incrementBurritoConsiderations }}>
627
+ {children}
628
+ </AuthContext.Provider>
629
+ );
630
+ }
631
+
632
+ export function useAuth() {
633
+ const context = useContext(AuthContext);
634
+ if (context === undefined) {
635
+ throw new Error('useAuth must be used within an AuthProvider');
636
+ }
637
+ return context;
638
+ }
639
+
640
+ ```
641
+
642
+ ---
643
+
644
+ ## src/lib/amplitude-server.ts
645
+
646
+ ```ts
647
+ import { createInstance } from '@amplitude/analytics-node';
648
+
649
+ type AmplitudeNodeClient = ReturnType<typeof createInstance>;
650
+
651
+ let amplitudeClient: AmplitudeNodeClient | null = null;
652
+
653
+ export function getAmplitudeClient(): AmplitudeNodeClient | null {
654
+ const apiKey = process.env.NEXT_PUBLIC_AMPLITUDE_API_KEY;
655
+ if (!apiKey) return null;
656
+
657
+ if (!amplitudeClient) {
658
+ amplitudeClient = createInstance();
659
+ amplitudeClient.init(apiKey);
660
+ }
661
+ return amplitudeClient;
662
+ }
663
+
664
+ export async function flushAmplitude() {
665
+ if (amplitudeClient) {
666
+ await amplitudeClient.flush();
667
+ }
668
+ }
669
+
670
+ ```
671
+
672
+ ---
673
+