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