@amplitude/wizard 1.0.0-beta.2 → 1.0.0

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