@stackframe/tanstack-start 0.0.1 → 2.8.92

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 (1037) hide show
  1. package/LICENSE +7 -0
  2. package/README.md +26 -0
  3. package/dist/chunk-BE-pF4vm.js +34 -0
  4. package/dist/components/api-key-dialogs.d.ts +28 -0
  5. package/dist/components/api-key-dialogs.d.ts.map +1 -0
  6. package/dist/components/api-key-dialogs.js +163 -0
  7. package/dist/components/api-key-dialogs.js.map +1 -0
  8. package/dist/components/api-key-table.d.ts +10 -0
  9. package/dist/components/api-key-table.d.ts.map +1 -0
  10. package/dist/components/api-key-table.js +144 -0
  11. package/dist/components/api-key-table.js.map +1 -0
  12. package/dist/components/credential-sign-in.d.ts +7 -0
  13. package/dist/components/credential-sign-in.d.ts.map +1 -0
  14. package/dist/components/credential-sign-in.js +87 -0
  15. package/dist/components/credential-sign-in.js.map +1 -0
  16. package/dist/components/credential-sign-up.d.ts +9 -0
  17. package/dist/components/credential-sign-up.d.ts.map +1 -0
  18. package/dist/components/credential-sign-up.js +121 -0
  19. package/dist/components/credential-sign-up.js.map +1 -0
  20. package/dist/components/elements/form-warning.d.ts +11 -0
  21. package/dist/components/elements/form-warning.d.ts.map +1 -0
  22. package/dist/components/elements/form-warning.js +18 -0
  23. package/dist/components/elements/form-warning.js.map +1 -0
  24. package/dist/components/elements/maybe-full-page.d.ts +16 -0
  25. package/dist/components/elements/maybe-full-page.d.ts.map +1 -0
  26. package/dist/components/elements/maybe-full-page.js +41 -0
  27. package/dist/components/elements/maybe-full-page.js.map +1 -0
  28. package/dist/components/elements/separator-with-text.d.ts +11 -0
  29. package/dist/components/elements/separator-with-text.d.ts.map +1 -0
  30. package/dist/components/elements/separator-with-text.js +31 -0
  31. package/dist/components/elements/separator-with-text.js.map +1 -0
  32. package/dist/components/elements/sidebar-layout.d.ts +21 -0
  33. package/dist/components/elements/sidebar-layout.d.ts.map +1 -0
  34. package/dist/components/elements/sidebar-layout.js +135 -0
  35. package/dist/components/elements/sidebar-layout.js.map +1 -0
  36. package/dist/components/elements/ssr-layout-effect.d.ts +10 -0
  37. package/dist/components/elements/ssr-layout-effect.d.ts.map +1 -0
  38. package/dist/components/elements/ssr-layout-effect.js +22 -0
  39. package/dist/components/elements/ssr-layout-effect.js.map +1 -0
  40. package/dist/components/elements/user-avatar.d.ts +15 -0
  41. package/dist/components/elements/user-avatar.d.ts.map +1 -0
  42. package/dist/components/elements/user-avatar.js +30 -0
  43. package/dist/components/elements/user-avatar.js.map +1 -0
  44. package/dist/components/link.d.ts +16 -0
  45. package/dist/components/link.d.ts.map +1 -0
  46. package/dist/components/link.js +29 -0
  47. package/dist/components/link.js.map +1 -0
  48. package/dist/components/magic-link-sign-in.d.ts +7 -0
  49. package/dist/components/magic-link-sign-in.d.ts.map +1 -0
  50. package/dist/components/magic-link-sign-in.js +138 -0
  51. package/dist/components/magic-link-sign-in.js.map +1 -0
  52. package/dist/components/message-cards/known-error-message-card.d.ts +14 -0
  53. package/dist/components/message-cards/known-error-message-card.d.ts.map +1 -0
  54. package/dist/components/message-cards/known-error-message-card.js +24 -0
  55. package/dist/components/message-cards/known-error-message-card.js.map +1 -0
  56. package/dist/components/message-cards/message-card.d.ts +19 -0
  57. package/dist/components/message-cards/message-card.d.ts.map +1 -0
  58. package/dist/components/message-cards/message-card.js +46 -0
  59. package/dist/components/message-cards/message-card.js.map +1 -0
  60. package/dist/components/message-cards/predefined-message-card.d.ts +13 -0
  61. package/dist/components/message-cards/predefined-message-card.d.ts.map +1 -0
  62. package/dist/components/message-cards/predefined-message-card.js +73 -0
  63. package/dist/components/message-cards/predefined-message-card.js.map +1 -0
  64. package/dist/components/oauth-button-group.d.ts +19 -0
  65. package/dist/components/oauth-button-group.d.ts.map +1 -0
  66. package/dist/components/oauth-button-group.js +24 -0
  67. package/dist/components/oauth-button-group.js.map +1 -0
  68. package/dist/components/oauth-button.d.ts +17 -0
  69. package/dist/components/oauth-button.d.ts.map +1 -0
  70. package/dist/components/oauth-button.js +173 -0
  71. package/dist/components/oauth-button.js.map +1 -0
  72. package/dist/components/passkey-button.d.ts +11 -0
  73. package/dist/components/passkey-button.d.ts.map +1 -0
  74. package/dist/components/passkey-button.js +33 -0
  75. package/dist/components/passkey-button.js.map +1 -0
  76. package/dist/components/profile-image-editor.d.ts +15 -0
  77. package/dist/components/profile-image-editor.d.ts.map +1 -0
  78. package/dist/components/profile-image-editor.js +171 -0
  79. package/dist/components/profile-image-editor.js.map +1 -0
  80. package/dist/components/selected-team-switcher.d.ts +31 -0
  81. package/dist/components/selected-team-switcher.d.ts.map +1 -0
  82. package/dist/components/selected-team-switcher.js +59 -0
  83. package/dist/components/selected-team-switcher.js.map +1 -0
  84. package/dist/components/team-icon.d.ts +10 -0
  85. package/dist/components/team-icon.d.ts.map +1 -0
  86. package/dist/components/team-icon.js +31 -0
  87. package/dist/components/team-icon.js.map +1 -0
  88. package/dist/components/team-switcher.d.ts +31 -0
  89. package/dist/components/team-switcher.d.ts.map +1 -0
  90. package/dist/components/team-switcher.js +123 -0
  91. package/dist/components/team-switcher.js.map +1 -0
  92. package/dist/components/use-in-iframe.d.ts +5 -0
  93. package/dist/components/use-in-iframe.d.ts.map +1 -0
  94. package/dist/components/use-in-iframe.js +18 -0
  95. package/dist/components/use-in-iframe.js.map +1 -0
  96. package/dist/components/user-button.d.ts +22 -0
  97. package/dist/components/user-button.d.ts.map +1 -0
  98. package/dist/components/user-button.js +134 -0
  99. package/dist/components/user-button.js.map +1 -0
  100. package/dist/components-page/account-settings/active-sessions/active-sessions-page.d.ts +20 -0
  101. package/dist/components-page/account-settings/active-sessions/active-sessions-page.d.ts.map +1 -0
  102. package/dist/components-page/account-settings/active-sessions/active-sessions-page.js +208 -0
  103. package/dist/components-page/account-settings/active-sessions/active-sessions-page.js.map +1 -0
  104. package/dist/components-page/account-settings/api-keys/api-keys-page.d.ts +16 -0
  105. package/dist/components-page/account-settings/api-keys/api-keys-page.d.ts.map +1 -0
  106. package/dist/components-page/account-settings/api-keys/api-keys-page.js +115 -0
  107. package/dist/components-page/account-settings/api-keys/api-keys-page.js.map +1 -0
  108. package/dist/components-page/account-settings/editable-text.d.ts +10 -0
  109. package/dist/components-page/account-settings/editable-text.d.ts.map +1 -0
  110. package/dist/components-page/account-settings/editable-text.js +49 -0
  111. package/dist/components-page/account-settings/editable-text.js.map +1 -0
  112. package/dist/components-page/account-settings/email-and-auth/email-and-auth-page.d.ts +9 -0
  113. package/dist/components-page/account-settings/email-and-auth/email-and-auth-page.d.ts.map +1 -0
  114. package/dist/components-page/account-settings/email-and-auth/email-and-auth-page.js +24 -0
  115. package/dist/components-page/account-settings/email-and-auth/email-and-auth-page.js.map +1 -0
  116. package/dist/components-page/account-settings/email-and-auth/emails-section.d.ts +9 -0
  117. package/dist/components-page/account-settings/email-and-auth/emails-section.d.ts.map +1 -0
  118. package/dist/components-page/account-settings/email-and-auth/emails-section.js +181 -0
  119. package/dist/components-page/account-settings/email-and-auth/emails-section.js.map +1 -0
  120. package/dist/components-page/account-settings/email-and-auth/mfa-section.d.ts +9 -0
  121. package/dist/components-page/account-settings/email-and-auth/mfa-section.d.ts.map +1 -0
  122. package/dist/components-page/account-settings/email-and-auth/mfa-section.js +121 -0
  123. package/dist/components-page/account-settings/email-and-auth/mfa-section.js.map +1 -0
  124. package/dist/components-page/account-settings/email-and-auth/otp-section.d.ts +9 -0
  125. package/dist/components-page/account-settings/email-and-auth/otp-section.d.ts.map +1 -0
  126. package/dist/components-page/account-settings/email-and-auth/otp-section.js +80 -0
  127. package/dist/components-page/account-settings/email-and-auth/otp-section.js.map +1 -0
  128. package/dist/components-page/account-settings/email-and-auth/passkey-section.d.ts +9 -0
  129. package/dist/components-page/account-settings/email-and-auth/passkey-section.d.ts.map +1 -0
  130. package/dist/components-page/account-settings/email-and-auth/passkey-section.js +89 -0
  131. package/dist/components-page/account-settings/email-and-auth/passkey-section.js.map +1 -0
  132. package/dist/components-page/account-settings/email-and-auth/password-section.d.ts +9 -0
  133. package/dist/components-page/account-settings/email-and-auth/password-section.d.ts.map +1 -0
  134. package/dist/components-page/account-settings/email-and-auth/password-section.js +161 -0
  135. package/dist/components-page/account-settings/email-and-auth/password-section.js.map +1 -0
  136. package/dist/components-page/account-settings/notifications/notifications-page.d.ts +7 -0
  137. package/dist/components-page/account-settings/notifications/notifications-page.d.ts.map +1 -0
  138. package/dist/components-page/account-settings/notifications/notifications-page.js +42 -0
  139. package/dist/components-page/account-settings/notifications/notifications-page.js.map +1 -0
  140. package/dist/components-page/account-settings/page-layout.d.ts +9 -0
  141. package/dist/components-page/account-settings/page-layout.d.ts.map +1 -0
  142. package/dist/components-page/account-settings/page-layout.js +15 -0
  143. package/dist/components-page/account-settings/page-layout.js.map +1 -0
  144. package/dist/components-page/account-settings/payments/payments-page.d.ts +12 -0
  145. package/dist/components-page/account-settings/payments/payments-page.d.ts.map +1 -0
  146. package/dist/components-page/account-settings/payments/payments-page.js +55 -0
  147. package/dist/components-page/account-settings/payments/payments-page.js.map +1 -0
  148. package/dist/components-page/account-settings/payments/payments-panel.d.ts +61 -0
  149. package/dist/components-page/account-settings/payments/payments-panel.d.ts.map +1 -0
  150. package/dist/components-page/account-settings/payments/payments-panel.js +466 -0
  151. package/dist/components-page/account-settings/payments/payments-panel.js.map +1 -0
  152. package/dist/components-page/account-settings/profile-page/profile-page.d.ts +12 -0
  153. package/dist/components-page/account-settings/profile-page/profile-page.d.ts.map +1 -0
  154. package/dist/components-page/account-settings/profile-page/profile-page.js +46 -0
  155. package/dist/components-page/account-settings/profile-page/profile-page.js.map +1 -0
  156. package/dist/components-page/account-settings/section.d.ts +11 -0
  157. package/dist/components-page/account-settings/section.d.ts.map +1 -0
  158. package/dist/components-page/account-settings/section.js +29 -0
  159. package/dist/components-page/account-settings/section.js.map +1 -0
  160. package/dist/components-page/account-settings/settings/delete-account-section.d.ts +9 -0
  161. package/dist/components-page/account-settings/settings/delete-account-section.d.ts.map +1 -0
  162. package/dist/components-page/account-settings/settings/delete-account-section.js +70 -0
  163. package/dist/components-page/account-settings/settings/delete-account-section.js.map +1 -0
  164. package/dist/components-page/account-settings/settings/settings-page.d.ts +9 -0
  165. package/dist/components-page/account-settings/settings/settings-page.d.ts.map +1 -0
  166. package/dist/components-page/account-settings/settings/settings-page.js +15 -0
  167. package/dist/components-page/account-settings/settings/settings-page.js.map +1 -0
  168. package/dist/components-page/account-settings/settings/sign-out-section.d.ts +9 -0
  169. package/dist/components-page/account-settings/settings/sign-out-section.d.ts.map +1 -0
  170. package/dist/components-page/account-settings/settings/sign-out-section.js +33 -0
  171. package/dist/components-page/account-settings/settings/sign-out-section.js.map +1 -0
  172. package/dist/components-page/account-settings/teams/leave-team-section.d.ts +10 -0
  173. package/dist/components-page/account-settings/teams/leave-team-section.d.ts.map +1 -0
  174. package/dist/components-page/account-settings/teams/leave-team-section.js +48 -0
  175. package/dist/components-page/account-settings/teams/leave-team-section.js.map +1 -0
  176. package/dist/components-page/account-settings/teams/team-api-keys-section.d.ts +10 -0
  177. package/dist/components-page/account-settings/teams/team-api-keys-section.d.ts.map +1 -0
  178. package/dist/components-page/account-settings/teams/team-api-keys-section.js +57 -0
  179. package/dist/components-page/account-settings/teams/team-api-keys-section.js.map +1 -0
  180. package/dist/components-page/account-settings/teams/team-creation-page.d.ts +9 -0
  181. package/dist/components-page/account-settings/teams/team-creation-page.d.ts.map +1 -0
  182. package/dist/components-page/account-settings/teams/team-creation-page.js +67 -0
  183. package/dist/components-page/account-settings/teams/team-creation-page.js.map +1 -0
  184. package/dist/components-page/account-settings/teams/team-display-name-section.d.ts +10 -0
  185. package/dist/components-page/account-settings/teams/team-display-name-section.d.ts.map +1 -0
  186. package/dist/components-page/account-settings/teams/team-display-name-section.js +25 -0
  187. package/dist/components-page/account-settings/teams/team-display-name-section.js.map +1 -0
  188. package/dist/components-page/account-settings/teams/team-member-invitation-section.d.ts +10 -0
  189. package/dist/components-page/account-settings/teams/team-member-invitation-section.d.ts.map +1 -0
  190. package/dist/components-page/account-settings/teams/team-member-invitation-section.js +114 -0
  191. package/dist/components-page/account-settings/teams/team-member-invitation-section.js.map +1 -0
  192. package/dist/components-page/account-settings/teams/team-member-list-section.d.ts +10 -0
  193. package/dist/components-page/account-settings/teams/team-member-list-section.d.ts.map +1 -0
  194. package/dist/components-page/account-settings/teams/team-member-list-section.js +40 -0
  195. package/dist/components-page/account-settings/teams/team-member-list-section.js.map +1 -0
  196. package/dist/components-page/account-settings/teams/team-page.d.ts +10 -0
  197. package/dist/components-page/account-settings/teams/team-page.d.ts.map +1 -0
  198. package/dist/components-page/account-settings/teams/team-page.js +28 -0
  199. package/dist/components-page/account-settings/teams/team-page.js.map +1 -0
  200. package/dist/components-page/account-settings/teams/team-profile-image-section.d.ts +10 -0
  201. package/dist/components-page/account-settings/teams/team-profile-image-section.d.ts.map +1 -0
  202. package/dist/components-page/account-settings/teams/team-profile-image-section.js +27 -0
  203. package/dist/components-page/account-settings/teams/team-profile-image-section.js.map +1 -0
  204. package/dist/components-page/account-settings/teams/team-profile-user-section.d.ts +10 -0
  205. package/dist/components-page/account-settings/teams/team-profile-user-section.d.ts.map +1 -0
  206. package/dist/components-page/account-settings/teams/team-profile-user-section.js +27 -0
  207. package/dist/components-page/account-settings/teams/team-profile-user-section.js.map +1 -0
  208. package/dist/components-page/account-settings.d.ts +58 -0
  209. package/dist/components-page/account-settings.d.ts.map +1 -0
  210. package/dist/components-page/account-settings.js +267 -0
  211. package/dist/components-page/account-settings.js.map +1 -0
  212. package/dist/components-page/auth-page.d.ts +26 -0
  213. package/dist/components-page/auth-page.d.ts.map +1 -0
  214. package/dist/components-page/auth-page.js +163 -0
  215. package/dist/components-page/auth-page.js.map +1 -0
  216. package/dist/components-page/cli-auth-confirm.d.ts +21 -0
  217. package/dist/components-page/cli-auth-confirm.d.ts.map +1 -0
  218. package/dist/components-page/cli-auth-confirm.js +216 -0
  219. package/dist/components-page/cli-auth-confirm.js.map +1 -0
  220. package/dist/components-page/cli-auth-confirm.test.d.ts +1 -0
  221. package/dist/components-page/cli-auth-confirm.test.js +176 -0
  222. package/dist/components-page/cli-auth-confirm.test.js.map +1 -0
  223. package/dist/components-page/email-verification.d.ts +10 -0
  224. package/dist/components-page/email-verification.d.ts.map +1 -0
  225. package/dist/components-page/email-verification.js +60 -0
  226. package/dist/components-page/email-verification.js.map +1 -0
  227. package/dist/components-page/error-page.d.ts +10 -0
  228. package/dist/components-page/error-page.d.ts.map +1 -0
  229. package/dist/components-page/error-page.js +77 -0
  230. package/dist/components-page/error-page.js.map +1 -0
  231. package/dist/components-page/forgot-password.d.ts +14 -0
  232. package/dist/components-page/forgot-password.d.ts.map +1 -0
  233. package/dist/components-page/forgot-password.js +103 -0
  234. package/dist/components-page/forgot-password.js.map +1 -0
  235. package/dist/components-page/magic-link-callback.d.ts +10 -0
  236. package/dist/components-page/magic-link-callback.d.ts.map +1 -0
  237. package/dist/components-page/magic-link-callback.js +75 -0
  238. package/dist/components-page/magic-link-callback.js.map +1 -0
  239. package/dist/components-page/mfa.d.ts +11 -0
  240. package/dist/components-page/mfa.d.ts.map +1 -0
  241. package/dist/components-page/mfa.js +166 -0
  242. package/dist/components-page/mfa.js.map +1 -0
  243. package/dist/components-page/oauth-callback.d.ts +11 -0
  244. package/dist/components-page/oauth-callback.d.ts.map +1 -0
  245. package/dist/components-page/oauth-callback.js +72 -0
  246. package/dist/components-page/oauth-callback.js.map +1 -0
  247. package/dist/components-page/onboarding.d.ts +9 -0
  248. package/dist/components-page/onboarding.d.ts.map +1 -0
  249. package/dist/components-page/onboarding.js +140 -0
  250. package/dist/components-page/onboarding.js.map +1 -0
  251. package/dist/components-page/password-reset.d.ts +17 -0
  252. package/dist/components-page/password-reset.d.ts.map +1 -0
  253. package/dist/components-page/password-reset.js +161 -0
  254. package/dist/components-page/password-reset.js.map +1 -0
  255. package/dist/components-page/section.d.ts +1 -0
  256. package/dist/components-page/section.js +2 -0
  257. package/dist/components-page/sign-in.d.ts +23 -0
  258. package/dist/components-page/sign-in.d.ts.map +1 -0
  259. package/dist/components-page/sign-in.js +20 -0
  260. package/dist/components-page/sign-in.js.map +1 -0
  261. package/dist/components-page/sign-out.d.ts +9 -0
  262. package/dist/components-page/sign-out.d.ts.map +1 -0
  263. package/dist/components-page/sign-out.js +26 -0
  264. package/dist/components-page/sign-out.js.map +1 -0
  265. package/dist/components-page/sign-up.d.ts +13 -0
  266. package/dist/components-page/sign-up.d.ts.map +1 -0
  267. package/dist/components-page/sign-up.js +22 -0
  268. package/dist/components-page/sign-up.js.map +1 -0
  269. package/dist/components-page/stack-handler-client.d.ts +50 -0
  270. package/dist/components-page/stack-handler-client.d.ts.map +1 -0
  271. package/dist/components-page/stack-handler-client.js +235 -0
  272. package/dist/components-page/stack-handler-client.js.map +1 -0
  273. package/dist/components-page/stack-handler.d.ts +32 -0
  274. package/dist/components-page/stack-handler.d.ts.map +1 -0
  275. package/dist/components-page/stack-handler.js +12 -0
  276. package/dist/components-page/stack-handler.js.map +1 -0
  277. package/dist/components-page/team-creation.d.ts +9 -0
  278. package/dist/components-page/team-creation.d.ts.map +1 -0
  279. package/dist/components-page/team-creation.js +80 -0
  280. package/dist/components-page/team-creation.js.map +1 -0
  281. package/dist/components-page/team-invitation.d.ts +13 -0
  282. package/dist/components-page/team-invitation.d.ts.map +1 -0
  283. package/dist/components-page/team-invitation.js +109 -0
  284. package/dist/components-page/team-invitation.js.map +1 -0
  285. package/dist/dev-tool/dev-tool-core.d.ts +7 -0
  286. package/dist/dev-tool/dev-tool-core.d.ts.map +1 -0
  287. package/dist/dev-tool/dev-tool-core.js +2107 -0
  288. package/dist/dev-tool/dev-tool-core.js.map +1 -0
  289. package/dist/dev-tool/dev-tool-styles.d.ts +5 -0
  290. package/dist/dev-tool/dev-tool-styles.d.ts.map +1 -0
  291. package/dist/dev-tool/dev-tool-styles.js +2757 -0
  292. package/dist/dev-tool/dev-tool-styles.js.map +1 -0
  293. package/dist/dev-tool/dev-tool-trigger-position.d.ts +36 -0
  294. package/dist/dev-tool/dev-tool-trigger-position.d.ts.map +1 -0
  295. package/dist/dev-tool/dev-tool-trigger-position.js +70 -0
  296. package/dist/dev-tool/dev-tool-trigger-position.js.map +1 -0
  297. package/dist/dev-tool/dev-tool-trigger-position.test.d.ts +1 -0
  298. package/dist/dev-tool/dev-tool-trigger-position.test.js +155 -0
  299. package/dist/dev-tool/dev-tool-trigger-position.test.js.map +1 -0
  300. package/dist/dev-tool/index.d.ts +19 -0
  301. package/dist/dev-tool/index.d.ts.map +1 -0
  302. package/dist/dev-tool/index.js +119 -0
  303. package/dist/dev-tool/index.js.map +1 -0
  304. package/dist/esm/components/api-key-dialogs.d.ts +28 -0
  305. package/dist/esm/components/api-key-dialogs.d.ts.map +1 -0
  306. package/dist/esm/components/api-key-dialogs.js +158 -0
  307. package/dist/esm/components/api-key-dialogs.js.map +1 -0
  308. package/dist/esm/components/api-key-table.d.ts +10 -0
  309. package/dist/esm/components/api-key-table.d.ts.map +1 -0
  310. package/dist/esm/components/api-key-table.js +142 -0
  311. package/dist/esm/components/api-key-table.js.map +1 -0
  312. package/dist/esm/components/credential-sign-in.d.ts +7 -0
  313. package/dist/esm/components/credential-sign-in.d.ts.map +1 -0
  314. package/dist/esm/components/credential-sign-in.js +85 -0
  315. package/dist/esm/components/credential-sign-in.js.map +1 -0
  316. package/dist/esm/components/credential-sign-up.d.ts +9 -0
  317. package/dist/esm/components/credential-sign-up.d.ts.map +1 -0
  318. package/dist/esm/components/credential-sign-up.js +117 -0
  319. package/dist/esm/components/credential-sign-up.js.map +1 -0
  320. package/dist/esm/components/elements/form-warning.d.ts +11 -0
  321. package/dist/esm/components/elements/form-warning.d.ts.map +1 -0
  322. package/dist/esm/components/elements/form-warning.js +16 -0
  323. package/dist/esm/components/elements/form-warning.js.map +1 -0
  324. package/dist/esm/components/elements/maybe-full-page.d.ts +16 -0
  325. package/dist/esm/components/elements/maybe-full-page.d.ts.map +1 -0
  326. package/dist/esm/components/elements/maybe-full-page.js +38 -0
  327. package/dist/esm/components/elements/maybe-full-page.js.map +1 -0
  328. package/dist/esm/components/elements/separator-with-text.d.ts +11 -0
  329. package/dist/esm/components/elements/separator-with-text.d.ts.map +1 -0
  330. package/dist/esm/components/elements/separator-with-text.js +29 -0
  331. package/dist/esm/components/elements/separator-with-text.js.map +1 -0
  332. package/dist/esm/components/elements/sidebar-layout.d.ts +21 -0
  333. package/dist/esm/components/elements/sidebar-layout.d.ts.map +1 -0
  334. package/dist/esm/components/elements/sidebar-layout.js +132 -0
  335. package/dist/esm/components/elements/sidebar-layout.js.map +1 -0
  336. package/dist/esm/components/elements/ssr-layout-effect.d.ts +10 -0
  337. package/dist/esm/components/elements/ssr-layout-effect.d.ts.map +1 -0
  338. package/dist/esm/components/elements/ssr-layout-effect.js +20 -0
  339. package/dist/esm/components/elements/ssr-layout-effect.js.map +1 -0
  340. package/dist/esm/components/elements/user-avatar.d.ts +15 -0
  341. package/dist/esm/components/elements/user-avatar.d.ts.map +1 -0
  342. package/dist/esm/components/elements/user-avatar.js +28 -0
  343. package/dist/esm/components/elements/user-avatar.js.map +1 -0
  344. package/dist/esm/components/link.d.ts +16 -0
  345. package/dist/esm/components/link.d.ts.map +1 -0
  346. package/dist/esm/components/link.js +26 -0
  347. package/dist/esm/components/link.js.map +1 -0
  348. package/dist/esm/components/magic-link-sign-in.d.ts +7 -0
  349. package/dist/esm/components/magic-link-sign-in.d.ts.map +1 -0
  350. package/dist/esm/components/magic-link-sign-in.js +136 -0
  351. package/dist/esm/components/magic-link-sign-in.js.map +1 -0
  352. package/dist/esm/components/message-cards/known-error-message-card.d.ts +14 -0
  353. package/dist/esm/components/message-cards/known-error-message-card.d.ts.map +1 -0
  354. package/dist/esm/components/message-cards/known-error-message-card.js +22 -0
  355. package/dist/esm/components/message-cards/known-error-message-card.js.map +1 -0
  356. package/dist/esm/components/message-cards/message-card.d.ts +19 -0
  357. package/dist/esm/components/message-cards/message-card.d.ts.map +1 -0
  358. package/dist/esm/components/message-cards/message-card.js +43 -0
  359. package/dist/esm/components/message-cards/message-card.js.map +1 -0
  360. package/dist/esm/components/message-cards/predefined-message-card.d.ts +13 -0
  361. package/dist/esm/components/message-cards/predefined-message-card.d.ts.map +1 -0
  362. package/dist/esm/components/message-cards/predefined-message-card.js +71 -0
  363. package/dist/esm/components/message-cards/predefined-message-card.js.map +1 -0
  364. package/dist/esm/components/oauth-button-group.d.ts +19 -0
  365. package/dist/esm/components/oauth-button-group.d.ts.map +1 -0
  366. package/dist/esm/components/oauth-button-group.js +22 -0
  367. package/dist/esm/components/oauth-button-group.js.map +1 -0
  368. package/dist/esm/components/oauth-button.d.ts +17 -0
  369. package/dist/esm/components/oauth-button.d.ts.map +1 -0
  370. package/dist/esm/components/oauth-button.js +170 -0
  371. package/dist/esm/components/oauth-button.js.map +1 -0
  372. package/dist/esm/components/passkey-button.d.ts +11 -0
  373. package/dist/esm/components/passkey-button.d.ts.map +1 -0
  374. package/dist/esm/components/passkey-button.js +31 -0
  375. package/dist/esm/components/passkey-button.js.map +1 -0
  376. package/dist/esm/components/profile-image-editor.d.ts +15 -0
  377. package/dist/esm/components/profile-image-editor.d.ts.map +1 -0
  378. package/dist/esm/components/profile-image-editor.js +165 -0
  379. package/dist/esm/components/profile-image-editor.js.map +1 -0
  380. package/dist/esm/components/selected-team-switcher.d.ts +31 -0
  381. package/dist/esm/components/selected-team-switcher.d.ts.map +1 -0
  382. package/dist/esm/components/selected-team-switcher.js +57 -0
  383. package/dist/esm/components/selected-team-switcher.js.map +1 -0
  384. package/dist/esm/components/team-icon.d.ts +10 -0
  385. package/dist/esm/components/team-icon.d.ts.map +1 -0
  386. package/dist/esm/components/team-icon.js +29 -0
  387. package/dist/esm/components/team-icon.js.map +1 -0
  388. package/dist/esm/components/team-switcher.d.ts +31 -0
  389. package/dist/esm/components/team-switcher.d.ts.map +1 -0
  390. package/dist/esm/components/team-switcher.js +121 -0
  391. package/dist/esm/components/team-switcher.js.map +1 -0
  392. package/dist/esm/components/use-in-iframe.d.ts +5 -0
  393. package/dist/esm/components/use-in-iframe.d.ts.map +1 -0
  394. package/dist/esm/components/use-in-iframe.js +16 -0
  395. package/dist/esm/components/use-in-iframe.js.map +1 -0
  396. package/dist/esm/components/user-button.d.ts +22 -0
  397. package/dist/esm/components/user-button.d.ts.map +1 -0
  398. package/dist/esm/components/user-button.js +131 -0
  399. package/dist/esm/components/user-button.js.map +1 -0
  400. package/dist/esm/components-page/account-settings/active-sessions/active-sessions-page.d.ts +20 -0
  401. package/dist/esm/components-page/account-settings/active-sessions/active-sessions-page.d.ts.map +1 -0
  402. package/dist/esm/components-page/account-settings/active-sessions/active-sessions-page.js +206 -0
  403. package/dist/esm/components-page/account-settings/active-sessions/active-sessions-page.js.map +1 -0
  404. package/dist/esm/components-page/account-settings/api-keys/api-keys-page.d.ts +16 -0
  405. package/dist/esm/components-page/account-settings/api-keys/api-keys-page.d.ts.map +1 -0
  406. package/dist/esm/components-page/account-settings/api-keys/api-keys-page.js +113 -0
  407. package/dist/esm/components-page/account-settings/api-keys/api-keys-page.js.map +1 -0
  408. package/dist/esm/components-page/account-settings/editable-text.d.ts +10 -0
  409. package/dist/esm/components-page/account-settings/editable-text.d.ts.map +1 -0
  410. package/dist/esm/components-page/account-settings/editable-text.js +47 -0
  411. package/dist/esm/components-page/account-settings/editable-text.js.map +1 -0
  412. package/dist/esm/components-page/account-settings/email-and-auth/email-and-auth-page.d.ts +9 -0
  413. package/dist/esm/components-page/account-settings/email-and-auth/email-and-auth-page.d.ts.map +1 -0
  414. package/dist/esm/components-page/account-settings/email-and-auth/email-and-auth-page.js +22 -0
  415. package/dist/esm/components-page/account-settings/email-and-auth/email-and-auth-page.js.map +1 -0
  416. package/dist/esm/components-page/account-settings/email-and-auth/emails-section.d.ts +9 -0
  417. package/dist/esm/components-page/account-settings/email-and-auth/emails-section.d.ts.map +1 -0
  418. package/dist/esm/components-page/account-settings/email-and-auth/emails-section.js +179 -0
  419. package/dist/esm/components-page/account-settings/email-and-auth/emails-section.js.map +1 -0
  420. package/dist/esm/components-page/account-settings/email-and-auth/mfa-section.d.ts +9 -0
  421. package/dist/esm/components-page/account-settings/email-and-auth/mfa-section.d.ts.map +1 -0
  422. package/dist/esm/components-page/account-settings/email-and-auth/mfa-section.js +118 -0
  423. package/dist/esm/components-page/account-settings/email-and-auth/mfa-section.js.map +1 -0
  424. package/dist/esm/components-page/account-settings/email-and-auth/otp-section.d.ts +9 -0
  425. package/dist/esm/components-page/account-settings/email-and-auth/otp-section.d.ts.map +1 -0
  426. package/dist/esm/components-page/account-settings/email-and-auth/otp-section.js +78 -0
  427. package/dist/esm/components-page/account-settings/email-and-auth/otp-section.js.map +1 -0
  428. package/dist/esm/components-page/account-settings/email-and-auth/passkey-section.d.ts +9 -0
  429. package/dist/esm/components-page/account-settings/email-and-auth/passkey-section.d.ts.map +1 -0
  430. package/dist/esm/components-page/account-settings/email-and-auth/passkey-section.js +87 -0
  431. package/dist/esm/components-page/account-settings/email-and-auth/passkey-section.js.map +1 -0
  432. package/dist/esm/components-page/account-settings/email-and-auth/password-section.d.ts +9 -0
  433. package/dist/esm/components-page/account-settings/email-and-auth/password-section.d.ts.map +1 -0
  434. package/dist/esm/components-page/account-settings/email-and-auth/password-section.js +158 -0
  435. package/dist/esm/components-page/account-settings/email-and-auth/password-section.js.map +1 -0
  436. package/dist/esm/components-page/account-settings/notifications/notifications-page.d.ts +7 -0
  437. package/dist/esm/components-page/account-settings/notifications/notifications-page.d.ts.map +1 -0
  438. package/dist/esm/components-page/account-settings/notifications/notifications-page.js +40 -0
  439. package/dist/esm/components-page/account-settings/notifications/notifications-page.js.map +1 -0
  440. package/dist/esm/components-page/account-settings/page-layout.d.ts +9 -0
  441. package/dist/esm/components-page/account-settings/page-layout.d.ts.map +1 -0
  442. package/dist/esm/components-page/account-settings/page-layout.js +13 -0
  443. package/dist/esm/components-page/account-settings/page-layout.js.map +1 -0
  444. package/dist/esm/components-page/account-settings/payments/payments-page.d.ts +12 -0
  445. package/dist/esm/components-page/account-settings/payments/payments-page.d.ts.map +1 -0
  446. package/dist/esm/components-page/account-settings/payments/payments-page.js +53 -0
  447. package/dist/esm/components-page/account-settings/payments/payments-page.js.map +1 -0
  448. package/dist/esm/components-page/account-settings/payments/payments-panel.d.ts +61 -0
  449. package/dist/esm/components-page/account-settings/payments/payments-panel.d.ts.map +1 -0
  450. package/dist/esm/components-page/account-settings/payments/payments-panel.js +464 -0
  451. package/dist/esm/components-page/account-settings/payments/payments-panel.js.map +1 -0
  452. package/dist/esm/components-page/account-settings/profile-page/profile-page.d.ts +12 -0
  453. package/dist/esm/components-page/account-settings/profile-page/profile-page.d.ts.map +1 -0
  454. package/dist/esm/components-page/account-settings/profile-page/profile-page.js +44 -0
  455. package/dist/esm/components-page/account-settings/profile-page/profile-page.js.map +1 -0
  456. package/dist/esm/components-page/account-settings/section.d.ts +11 -0
  457. package/dist/esm/components-page/account-settings/section.d.ts.map +1 -0
  458. package/dist/esm/components-page/account-settings/section.js +27 -0
  459. package/dist/esm/components-page/account-settings/section.js.map +1 -0
  460. package/dist/esm/components-page/account-settings/settings/delete-account-section.d.ts +9 -0
  461. package/dist/esm/components-page/account-settings/settings/delete-account-section.d.ts.map +1 -0
  462. package/dist/esm/components-page/account-settings/settings/delete-account-section.js +68 -0
  463. package/dist/esm/components-page/account-settings/settings/delete-account-section.js.map +1 -0
  464. package/dist/esm/components-page/account-settings/settings/settings-page.d.ts +9 -0
  465. package/dist/esm/components-page/account-settings/settings/settings-page.d.ts.map +1 -0
  466. package/dist/esm/components-page/account-settings/settings/settings-page.js +13 -0
  467. package/dist/esm/components-page/account-settings/settings/settings-page.js.map +1 -0
  468. package/dist/esm/components-page/account-settings/settings/sign-out-section.d.ts +9 -0
  469. package/dist/esm/components-page/account-settings/settings/sign-out-section.d.ts.map +1 -0
  470. package/dist/esm/components-page/account-settings/settings/sign-out-section.js +31 -0
  471. package/dist/esm/components-page/account-settings/settings/sign-out-section.js.map +1 -0
  472. package/dist/esm/components-page/account-settings/teams/leave-team-section.d.ts +10 -0
  473. package/dist/esm/components-page/account-settings/teams/leave-team-section.d.ts.map +1 -0
  474. package/dist/esm/components-page/account-settings/teams/leave-team-section.js +46 -0
  475. package/dist/esm/components-page/account-settings/teams/leave-team-section.js.map +1 -0
  476. package/dist/esm/components-page/account-settings/teams/team-api-keys-section.d.ts +10 -0
  477. package/dist/esm/components-page/account-settings/teams/team-api-keys-section.d.ts.map +1 -0
  478. package/dist/esm/components-page/account-settings/teams/team-api-keys-section.js +55 -0
  479. package/dist/esm/components-page/account-settings/teams/team-api-keys-section.js.map +1 -0
  480. package/dist/esm/components-page/account-settings/teams/team-creation-page.d.ts +9 -0
  481. package/dist/esm/components-page/account-settings/teams/team-creation-page.d.ts.map +1 -0
  482. package/dist/esm/components-page/account-settings/teams/team-creation-page.js +65 -0
  483. package/dist/esm/components-page/account-settings/teams/team-creation-page.js.map +1 -0
  484. package/dist/esm/components-page/account-settings/teams/team-display-name-section.d.ts +10 -0
  485. package/dist/esm/components-page/account-settings/teams/team-display-name-section.d.ts.map +1 -0
  486. package/dist/esm/components-page/account-settings/teams/team-display-name-section.js +23 -0
  487. package/dist/esm/components-page/account-settings/teams/team-display-name-section.js.map +1 -0
  488. package/dist/esm/components-page/account-settings/teams/team-member-invitation-section.d.ts +10 -0
  489. package/dist/esm/components-page/account-settings/teams/team-member-invitation-section.d.ts.map +1 -0
  490. package/dist/esm/components-page/account-settings/teams/team-member-invitation-section.js +112 -0
  491. package/dist/esm/components-page/account-settings/teams/team-member-invitation-section.js.map +1 -0
  492. package/dist/esm/components-page/account-settings/teams/team-member-list-section.d.ts +10 -0
  493. package/dist/esm/components-page/account-settings/teams/team-member-list-section.d.ts.map +1 -0
  494. package/dist/esm/components-page/account-settings/teams/team-member-list-section.js +38 -0
  495. package/dist/esm/components-page/account-settings/teams/team-member-list-section.js.map +1 -0
  496. package/dist/esm/components-page/account-settings/teams/team-page.d.ts +10 -0
  497. package/dist/esm/components-page/account-settings/teams/team-page.d.ts.map +1 -0
  498. package/dist/esm/components-page/account-settings/teams/team-page.js +26 -0
  499. package/dist/esm/components-page/account-settings/teams/team-page.js.map +1 -0
  500. package/dist/esm/components-page/account-settings/teams/team-profile-image-section.d.ts +10 -0
  501. package/dist/esm/components-page/account-settings/teams/team-profile-image-section.d.ts.map +1 -0
  502. package/dist/esm/components-page/account-settings/teams/team-profile-image-section.js +25 -0
  503. package/dist/esm/components-page/account-settings/teams/team-profile-image-section.js.map +1 -0
  504. package/dist/esm/components-page/account-settings/teams/team-profile-user-section.d.ts +10 -0
  505. package/dist/esm/components-page/account-settings/teams/team-profile-user-section.d.ts.map +1 -0
  506. package/dist/esm/components-page/account-settings/teams/team-profile-user-section.js +25 -0
  507. package/dist/esm/components-page/account-settings/teams/team-profile-user-section.js.map +1 -0
  508. package/dist/esm/components-page/account-settings.d.ts +58 -0
  509. package/dist/esm/components-page/account-settings.d.ts.map +1 -0
  510. package/dist/esm/components-page/account-settings.js +264 -0
  511. package/dist/esm/components-page/account-settings.js.map +1 -0
  512. package/dist/esm/components-page/auth-page.d.ts +26 -0
  513. package/dist/esm/components-page/auth-page.d.ts.map +1 -0
  514. package/dist/esm/components-page/auth-page.js +161 -0
  515. package/dist/esm/components-page/auth-page.js.map +1 -0
  516. package/dist/esm/components-page/cli-auth-confirm.d.ts +21 -0
  517. package/dist/esm/components-page/cli-auth-confirm.d.ts.map +1 -0
  518. package/dist/esm/components-page/cli-auth-confirm.js +213 -0
  519. package/dist/esm/components-page/cli-auth-confirm.js.map +1 -0
  520. package/dist/esm/components-page/cli-auth-confirm.test.d.ts +1 -0
  521. package/dist/esm/components-page/cli-auth-confirm.test.js +175 -0
  522. package/dist/esm/components-page/cli-auth-confirm.test.js.map +1 -0
  523. package/dist/esm/components-page/email-verification.d.ts +10 -0
  524. package/dist/esm/components-page/email-verification.d.ts.map +1 -0
  525. package/dist/esm/components-page/email-verification.js +57 -0
  526. package/dist/esm/components-page/email-verification.js.map +1 -0
  527. package/dist/esm/components-page/error-page.d.ts +10 -0
  528. package/dist/esm/components-page/error-page.d.ts.map +1 -0
  529. package/dist/esm/components-page/error-page.js +75 -0
  530. package/dist/esm/components-page/error-page.js.map +1 -0
  531. package/dist/esm/components-page/forgot-password.d.ts +14 -0
  532. package/dist/esm/components-page/forgot-password.d.ts.map +1 -0
  533. package/dist/esm/components-page/forgot-password.js +100 -0
  534. package/dist/esm/components-page/forgot-password.js.map +1 -0
  535. package/dist/esm/components-page/magic-link-callback.d.ts +10 -0
  536. package/dist/esm/components-page/magic-link-callback.d.ts.map +1 -0
  537. package/dist/esm/components-page/magic-link-callback.js +72 -0
  538. package/dist/esm/components-page/magic-link-callback.js.map +1 -0
  539. package/dist/esm/components-page/mfa.d.ts +11 -0
  540. package/dist/esm/components-page/mfa.d.ts.map +1 -0
  541. package/dist/esm/components-page/mfa.js +164 -0
  542. package/dist/esm/components-page/mfa.js.map +1 -0
  543. package/dist/esm/components-page/oauth-callback.d.ts +11 -0
  544. package/dist/esm/components-page/oauth-callback.d.ts.map +1 -0
  545. package/dist/esm/components-page/oauth-callback.js +70 -0
  546. package/dist/esm/components-page/oauth-callback.js.map +1 -0
  547. package/dist/esm/components-page/onboarding.d.ts +9 -0
  548. package/dist/esm/components-page/onboarding.d.ts.map +1 -0
  549. package/dist/esm/components-page/onboarding.js +138 -0
  550. package/dist/esm/components-page/onboarding.js.map +1 -0
  551. package/dist/esm/components-page/password-reset.d.ts +17 -0
  552. package/dist/esm/components-page/password-reset.d.ts.map +1 -0
  553. package/dist/esm/components-page/password-reset.js +157 -0
  554. package/dist/esm/components-page/password-reset.js.map +1 -0
  555. package/dist/esm/components-page/section.d.ts +1 -0
  556. package/dist/esm/components-page/section.js +4 -0
  557. package/dist/esm/components-page/sign-in.d.ts +23 -0
  558. package/dist/esm/components-page/sign-in.d.ts.map +1 -0
  559. package/dist/esm/components-page/sign-in.js +18 -0
  560. package/dist/esm/components-page/sign-in.js.map +1 -0
  561. package/dist/esm/components-page/sign-out.d.ts +9 -0
  562. package/dist/esm/components-page/sign-out.d.ts.map +1 -0
  563. package/dist/esm/components-page/sign-out.js +24 -0
  564. package/dist/esm/components-page/sign-out.js.map +1 -0
  565. package/dist/esm/components-page/sign-up.d.ts +13 -0
  566. package/dist/esm/components-page/sign-up.d.ts.map +1 -0
  567. package/dist/esm/components-page/sign-up.js +20 -0
  568. package/dist/esm/components-page/sign-up.js.map +1 -0
  569. package/dist/esm/components-page/stack-handler-client.d.ts +49 -0
  570. package/dist/esm/components-page/stack-handler-client.d.ts.map +1 -0
  571. package/dist/esm/components-page/stack-handler-client.js +233 -0
  572. package/dist/esm/components-page/stack-handler-client.js.map +1 -0
  573. package/dist/esm/components-page/stack-handler.d.ts +33 -0
  574. package/dist/esm/components-page/stack-handler.d.ts.map +1 -0
  575. package/dist/esm/components-page/stack-handler.js +11 -0
  576. package/dist/esm/components-page/stack-handler.js.map +1 -0
  577. package/dist/esm/components-page/team-creation.d.ts +9 -0
  578. package/dist/esm/components-page/team-creation.d.ts.map +1 -0
  579. package/dist/esm/components-page/team-creation.js +78 -0
  580. package/dist/esm/components-page/team-creation.js.map +1 -0
  581. package/dist/esm/components-page/team-invitation.d.ts +13 -0
  582. package/dist/esm/components-page/team-invitation.d.ts.map +1 -0
  583. package/dist/esm/components-page/team-invitation.js +106 -0
  584. package/dist/esm/components-page/team-invitation.js.map +1 -0
  585. package/dist/esm/dev-tool/dev-tool-core.d.ts +7 -0
  586. package/dist/esm/dev-tool/dev-tool-core.d.ts.map +1 -0
  587. package/dist/esm/dev-tool/dev-tool-core.js +2105 -0
  588. package/dist/esm/dev-tool/dev-tool-core.js.map +1 -0
  589. package/dist/esm/dev-tool/dev-tool-styles.d.ts +5 -0
  590. package/dist/esm/dev-tool/dev-tool-styles.d.ts.map +1 -0
  591. package/dist/esm/dev-tool/dev-tool-styles.js +2755 -0
  592. package/dist/esm/dev-tool/dev-tool-styles.js.map +1 -0
  593. package/dist/esm/dev-tool/dev-tool-trigger-position.d.ts +36 -0
  594. package/dist/esm/dev-tool/dev-tool-trigger-position.d.ts.map +1 -0
  595. package/dist/esm/dev-tool/dev-tool-trigger-position.js +65 -0
  596. package/dist/esm/dev-tool/dev-tool-trigger-position.js.map +1 -0
  597. package/dist/esm/dev-tool/dev-tool-trigger-position.test.d.ts +1 -0
  598. package/dist/esm/dev-tool/dev-tool-trigger-position.test.js +155 -0
  599. package/dist/esm/dev-tool/dev-tool-trigger-position.test.js.map +1 -0
  600. package/dist/esm/dev-tool/index.d.ts +19 -0
  601. package/dist/esm/dev-tool/index.d.ts.map +1 -0
  602. package/dist/esm/dev-tool/index.js +117 -0
  603. package/dist/esm/dev-tool/index.js.map +1 -0
  604. package/dist/esm/generated/global-css.d.ts +5 -0
  605. package/dist/esm/generated/global-css.d.ts.map +1 -0
  606. package/dist/esm/generated/global-css.js +6 -0
  607. package/dist/esm/generated/global-css.js.map +1 -0
  608. package/dist/esm/generated/quetzal-translations.d.ts +6 -0
  609. package/dist/esm/generated/quetzal-translations.d.ts.map +1 -0
  610. package/dist/esm/generated/quetzal-translations.js +4307 -0
  611. package/dist/esm/generated/quetzal-translations.js.map +1 -0
  612. package/dist/esm/global.d.ts +1 -0
  613. package/dist/esm/index.d.ts +27 -0
  614. package/dist/esm/index.js +28 -0
  615. package/dist/esm/integrations/convex/component/convex.config.d.ts +7 -0
  616. package/dist/esm/integrations/convex/component/convex.config.d.ts.map +1 -0
  617. package/dist/esm/integrations/convex/component/convex.config.js +8 -0
  618. package/dist/esm/integrations/convex/component/convex.config.js.map +1 -0
  619. package/dist/esm/integrations/convex.d.ts +13 -0
  620. package/dist/esm/integrations/convex.d.ts.map +1 -0
  621. package/dist/esm/integrations/convex.js +23 -0
  622. package/dist/esm/integrations/convex.js.map +1 -0
  623. package/dist/esm/lib/auth.d.ts +29 -0
  624. package/dist/esm/lib/auth.d.ts.map +1 -0
  625. package/dist/esm/lib/auth.js +108 -0
  626. package/dist/esm/lib/auth.js.map +1 -0
  627. package/dist/esm/lib/auth.test.d.ts +1 -0
  628. package/dist/esm/lib/auth.test.js +60 -0
  629. package/dist/esm/lib/auth.test.js.map +1 -0
  630. package/dist/esm/lib/cookie.d.ts +50 -0
  631. package/dist/esm/lib/cookie.d.ts.map +1 -0
  632. package/dist/esm/lib/cookie.js +347 -0
  633. package/dist/esm/lib/cookie.js.map +1 -0
  634. package/dist/esm/lib/env.d.ts +37 -0
  635. package/dist/esm/lib/env.d.ts.map +1 -0
  636. package/dist/esm/lib/env.js +88 -0
  637. package/dist/esm/lib/env.js.map +1 -0
  638. package/dist/esm/lib/hooks.d.ts +33 -0
  639. package/dist/esm/lib/hooks.d.ts.map +1 -0
  640. package/dist/esm/lib/hooks.js +27 -0
  641. package/dist/esm/lib/hooks.js.map +1 -0
  642. package/dist/esm/lib/stack-app/api-keys/index.d.ts +53 -0
  643. package/dist/esm/lib/stack-app/api-keys/index.d.ts.map +1 -0
  644. package/dist/esm/lib/stack-app/api-keys/index.js +22 -0
  645. package/dist/esm/lib/stack-app/api-keys/index.js.map +1 -0
  646. package/dist/esm/lib/stack-app/apps/implementations/admin-app-impl.d.ts +423 -0
  647. package/dist/esm/lib/stack-app/apps/implementations/admin-app-impl.d.ts.map +1 -0
  648. package/dist/esm/lib/stack-app/apps/implementations/admin-app-impl.js +1041 -0
  649. package/dist/esm/lib/stack-app/apps/implementations/admin-app-impl.js.map +1 -0
  650. package/dist/esm/lib/stack-app/apps/implementations/client-app-impl.d.ts +562 -0
  651. package/dist/esm/lib/stack-app/apps/implementations/client-app-impl.d.ts.map +1 -0
  652. package/dist/esm/lib/stack-app/apps/implementations/client-app-impl.js +2631 -0
  653. package/dist/esm/lib/stack-app/apps/implementations/client-app-impl.js.map +1 -0
  654. package/dist/esm/lib/stack-app/apps/implementations/client-app-impl.oauth-prefetch.test.d.ts +1 -0
  655. package/dist/esm/lib/stack-app/apps/implementations/client-app-impl.oauth-prefetch.test.js +32 -0
  656. package/dist/esm/lib/stack-app/apps/implementations/client-app-impl.oauth-prefetch.test.js.map +1 -0
  657. package/dist/esm/lib/stack-app/apps/implementations/common.d.ts +66 -0
  658. package/dist/esm/lib/stack-app/apps/implementations/common.d.ts.map +1 -0
  659. package/dist/esm/lib/stack-app/apps/implementations/common.js +167 -0
  660. package/dist/esm/lib/stack-app/apps/implementations/common.js.map +1 -0
  661. package/dist/esm/lib/stack-app/apps/implementations/event-tracker.d.ts +42 -0
  662. package/dist/esm/lib/stack-app/apps/implementations/event-tracker.d.ts.map +1 -0
  663. package/dist/esm/lib/stack-app/apps/implementations/event-tracker.js +211 -0
  664. package/dist/esm/lib/stack-app/apps/implementations/event-tracker.js.map +1 -0
  665. package/dist/esm/lib/stack-app/apps/implementations/event-tracker.test.d.ts +1 -0
  666. package/dist/esm/lib/stack-app/apps/implementations/event-tracker.test.js +87 -0
  667. package/dist/esm/lib/stack-app/apps/implementations/event-tracker.test.js.map +1 -0
  668. package/dist/esm/lib/stack-app/apps/implementations/index.d.ts +9 -0
  669. package/dist/esm/lib/stack-app/apps/implementations/index.d.ts.map +1 -0
  670. package/dist/esm/lib/stack-app/apps/implementations/index.js +27 -0
  671. package/dist/esm/lib/stack-app/apps/implementations/index.js.map +1 -0
  672. package/dist/esm/lib/stack-app/apps/implementations/redirect-page-urls.d.ts +35 -0
  673. package/dist/esm/lib/stack-app/apps/implementations/redirect-page-urls.d.ts.map +1 -0
  674. package/dist/esm/lib/stack-app/apps/implementations/redirect-page-urls.js +187 -0
  675. package/dist/esm/lib/stack-app/apps/implementations/redirect-page-urls.js.map +1 -0
  676. package/dist/esm/lib/stack-app/apps/implementations/server-app-impl.d.ts +260 -0
  677. package/dist/esm/lib/stack-app/apps/implementations/server-app-impl.d.ts.map +1 -0
  678. package/dist/esm/lib/stack-app/apps/implementations/server-app-impl.js +1383 -0
  679. package/dist/esm/lib/stack-app/apps/implementations/server-app-impl.js.map +1 -0
  680. package/dist/esm/lib/stack-app/apps/implementations/session-refresh-subscription.d.ts +28 -0
  681. package/dist/esm/lib/stack-app/apps/implementations/session-refresh-subscription.d.ts.map +1 -0
  682. package/dist/esm/lib/stack-app/apps/implementations/session-refresh-subscription.js +31 -0
  683. package/dist/esm/lib/stack-app/apps/implementations/session-refresh-subscription.js.map +1 -0
  684. package/dist/esm/lib/stack-app/apps/implementations/session-refresh-subscription.test.d.ts +1 -0
  685. package/dist/esm/lib/stack-app/apps/implementations/session-refresh-subscription.test.js +82 -0
  686. package/dist/esm/lib/stack-app/apps/implementations/session-refresh-subscription.test.js.map +1 -0
  687. package/dist/esm/lib/stack-app/apps/implementations/session-replay.d.ts +108 -0
  688. package/dist/esm/lib/stack-app/apps/implementations/session-replay.d.ts.map +1 -0
  689. package/dist/esm/lib/stack-app/apps/implementations/session-replay.js +234 -0
  690. package/dist/esm/lib/stack-app/apps/implementations/session-replay.js.map +1 -0
  691. package/dist/esm/lib/stack-app/apps/implementations/session-replay.test.d.ts +1 -0
  692. package/dist/esm/lib/stack-app/apps/implementations/session-replay.test.js +29 -0
  693. package/dist/esm/lib/stack-app/apps/implementations/session-replay.test.js.map +1 -0
  694. package/dist/esm/lib/stack-app/apps/index.d.ts +4 -0
  695. package/dist/esm/lib/stack-app/apps/index.js +5 -0
  696. package/dist/esm/lib/stack-app/apps/interfaces/admin-app.d.ts +252 -0
  697. package/dist/esm/lib/stack-app/apps/interfaces/admin-app.d.ts.map +1 -0
  698. package/dist/esm/lib/stack-app/apps/interfaces/admin-app.js +8 -0
  699. package/dist/esm/lib/stack-app/apps/interfaces/admin-app.js.map +1 -0
  700. package/dist/esm/lib/stack-app/apps/interfaces/client-app.d.ts +220 -0
  701. package/dist/esm/lib/stack-app/apps/interfaces/client-app.d.ts.map +1 -0
  702. package/dist/esm/lib/stack-app/apps/interfaces/client-app.js +8 -0
  703. package/dist/esm/lib/stack-app/apps/interfaces/client-app.js.map +1 -0
  704. package/dist/esm/lib/stack-app/apps/interfaces/server-app.d.ts +153 -0
  705. package/dist/esm/lib/stack-app/apps/interfaces/server-app.d.ts.map +1 -0
  706. package/dist/esm/lib/stack-app/apps/interfaces/server-app.js +8 -0
  707. package/dist/esm/lib/stack-app/apps/interfaces/server-app.js.map +1 -0
  708. package/dist/esm/lib/stack-app/common.d.ts +183 -0
  709. package/dist/esm/lib/stack-app/common.d.ts.map +1 -0
  710. package/dist/esm/lib/stack-app/common.js +7 -0
  711. package/dist/esm/lib/stack-app/common.js.map +1 -0
  712. package/dist/esm/lib/stack-app/connected-accounts/index.d.ts +57 -0
  713. package/dist/esm/lib/stack-app/connected-accounts/index.d.ts.map +1 -0
  714. package/dist/esm/lib/stack-app/connected-accounts/index.js +1 -0
  715. package/dist/esm/lib/stack-app/contact-channels/index.d.ts +43 -0
  716. package/dist/esm/lib/stack-app/contact-channels/index.d.ts.map +1 -0
  717. package/dist/esm/lib/stack-app/contact-channels/index.js +39 -0
  718. package/dist/esm/lib/stack-app/contact-channels/index.js.map +1 -0
  719. package/dist/esm/lib/stack-app/customers/index.d.ts +129 -0
  720. package/dist/esm/lib/stack-app/customers/index.d.ts.map +1 -0
  721. package/dist/esm/lib/stack-app/customers/index.js +1 -0
  722. package/dist/esm/lib/stack-app/data-vault/index.d.ts +14 -0
  723. package/dist/esm/lib/stack-app/data-vault/index.d.ts.map +1 -0
  724. package/dist/esm/lib/stack-app/data-vault/index.js +1 -0
  725. package/dist/esm/lib/stack-app/email/index.d.ts +204 -0
  726. package/dist/esm/lib/stack-app/email/index.d.ts.map +1 -0
  727. package/dist/esm/lib/stack-app/email/index.js +1 -0
  728. package/dist/esm/lib/stack-app/email-templates/index.d.ts +17 -0
  729. package/dist/esm/lib/stack-app/email-templates/index.d.ts.map +1 -0
  730. package/dist/esm/lib/stack-app/email-templates/index.js +11 -0
  731. package/dist/esm/lib/stack-app/email-templates/index.js.map +1 -0
  732. package/dist/esm/lib/stack-app/index.d.ts +14 -0
  733. package/dist/esm/lib/stack-app/index.js +5 -0
  734. package/dist/esm/lib/stack-app/internal-api-keys/index.d.ts +42 -0
  735. package/dist/esm/lib/stack-app/internal-api-keys/index.d.ts.map +1 -0
  736. package/dist/esm/lib/stack-app/internal-api-keys/index.js +14 -0
  737. package/dist/esm/lib/stack-app/internal-api-keys/index.js.map +1 -0
  738. package/dist/esm/lib/stack-app/notification-categories/index.d.ts +11 -0
  739. package/dist/esm/lib/stack-app/notification-categories/index.d.ts.map +1 -0
  740. package/dist/esm/lib/stack-app/notification-categories/index.js +1 -0
  741. package/dist/esm/lib/stack-app/permissions/index.d.ts +43 -0
  742. package/dist/esm/lib/stack-app/permissions/index.d.ts.map +1 -0
  743. package/dist/esm/lib/stack-app/permissions/index.js +31 -0
  744. package/dist/esm/lib/stack-app/permissions/index.js.map +1 -0
  745. package/dist/esm/lib/stack-app/project-configs/index.d.ts +99 -0
  746. package/dist/esm/lib/stack-app/project-configs/index.d.ts.map +1 -0
  747. package/dist/esm/lib/stack-app/project-configs/index.js +1 -0
  748. package/dist/esm/lib/stack-app/projects/index.d.ts +147 -0
  749. package/dist/esm/lib/stack-app/projects/index.d.ts.map +1 -0
  750. package/dist/esm/lib/stack-app/projects/index.js +66 -0
  751. package/dist/esm/lib/stack-app/projects/index.js.map +1 -0
  752. package/dist/esm/lib/stack-app/session-replays/index.d.ts +66 -0
  753. package/dist/esm/lib/stack-app/session-replays/index.d.ts.map +1 -0
  754. package/dist/esm/lib/stack-app/session-replays/index.js +1 -0
  755. package/dist/esm/lib/stack-app/teams/index.d.ts +163 -0
  756. package/dist/esm/lib/stack-app/teams/index.d.ts.map +1 -0
  757. package/dist/esm/lib/stack-app/teams/index.js +35 -0
  758. package/dist/esm/lib/stack-app/teams/index.js.map +1 -0
  759. package/dist/esm/lib/stack-app/url-targets.d.ts +40 -0
  760. package/dist/esm/lib/stack-app/url-targets.d.ts.map +1 -0
  761. package/dist/esm/lib/stack-app/url-targets.js +280 -0
  762. package/dist/esm/lib/stack-app/url-targets.js.map +1 -0
  763. package/dist/esm/lib/stack-app/url-targets.test.d.ts +1 -0
  764. package/dist/esm/lib/stack-app/url-targets.test.js +169 -0
  765. package/dist/esm/lib/stack-app/url-targets.test.js.map +1 -0
  766. package/dist/esm/lib/stack-app/users/index.d.ts +400 -0
  767. package/dist/esm/lib/stack-app/users/index.d.ts.map +1 -0
  768. package/dist/esm/lib/stack-app/users/index.js +71 -0
  769. package/dist/esm/lib/stack-app/users/index.js.map +1 -0
  770. package/dist/esm/lib/translations.d.ts +7 -0
  771. package/dist/esm/lib/translations.d.ts.map +1 -0
  772. package/dist/esm/lib/translations.js +18 -0
  773. package/dist/esm/lib/translations.js.map +1 -0
  774. package/dist/esm/providers/stack-context.d.ts +10 -0
  775. package/dist/esm/providers/stack-context.d.ts.map +1 -0
  776. package/dist/esm/providers/stack-context.js +10 -0
  777. package/dist/esm/providers/stack-context.js.map +1 -0
  778. package/dist/esm/providers/stack-provider-client.d.ts +17 -0
  779. package/dist/esm/providers/stack-provider-client.d.ts.map +1 -0
  780. package/dist/esm/providers/stack-provider-client.js +30 -0
  781. package/dist/esm/providers/stack-provider-client.js.map +1 -0
  782. package/dist/esm/providers/stack-provider.d.ts +26 -0
  783. package/dist/esm/providers/stack-provider.d.ts.map +1 -0
  784. package/dist/esm/providers/stack-provider.js +24 -0
  785. package/dist/esm/providers/stack-provider.js.map +1 -0
  786. package/dist/esm/providers/theme-provider.d.ts +46 -0
  787. package/dist/esm/providers/theme-provider.d.ts.map +1 -0
  788. package/dist/esm/providers/theme-provider.js +68 -0
  789. package/dist/esm/providers/theme-provider.js.map +1 -0
  790. package/dist/esm/providers/translation-provider-client.d.ts +16 -0
  791. package/dist/esm/providers/translation-provider-client.d.ts.map +1 -0
  792. package/dist/esm/providers/translation-provider-client.js +20 -0
  793. package/dist/esm/providers/translation-provider-client.js.map +1 -0
  794. package/dist/esm/providers/translation-provider.d.ts +16 -0
  795. package/dist/esm/providers/translation-provider.d.ts.map +1 -0
  796. package/dist/esm/providers/translation-provider.js +23 -0
  797. package/dist/esm/providers/translation-provider.js.map +1 -0
  798. package/dist/esm/tanstack-start-server-context.combined.d.ts +12 -0
  799. package/dist/esm/tanstack-start-server-context.combined.d.ts.map +1 -0
  800. package/dist/esm/tanstack-start-server-context.combined.js +1 -0
  801. package/dist/esm/tanstack-start-server-context.default.d.ts +9 -0
  802. package/dist/esm/tanstack-start-server-context.default.d.ts.map +1 -0
  803. package/dist/esm/tanstack-start-server-context.default.js +10 -0
  804. package/dist/esm/tanstack-start-server-context.default.js.map +1 -0
  805. package/dist/esm/tanstack-start-server-context.server.d.ts +2 -0
  806. package/dist/esm/tanstack-start-server-context.server.js +3 -0
  807. package/dist/esm/utils/browser-script.d.ts +9 -0
  808. package/dist/esm/utils/browser-script.d.ts.map +1 -0
  809. package/dist/esm/utils/browser-script.js +105 -0
  810. package/dist/esm/utils/browser-script.js.map +1 -0
  811. package/dist/esm/utils/constants.d.ts +81 -0
  812. package/dist/esm/utils/constants.d.ts.map +1 -0
  813. package/dist/esm/utils/constants.js +82 -0
  814. package/dist/esm/utils/constants.js.map +1 -0
  815. package/dist/esm/utils/url.d.ts +5 -0
  816. package/dist/esm/utils/url.d.ts.map +1 -0
  817. package/dist/esm/utils/url.js +16 -0
  818. package/dist/esm/utils/url.js.map +1 -0
  819. package/dist/generated/global-css.d.ts +5 -0
  820. package/dist/generated/global-css.d.ts.map +1 -0
  821. package/dist/generated/global-css.js +8 -0
  822. package/dist/generated/global-css.js.map +1 -0
  823. package/dist/generated/quetzal-translations.d.ts +6 -0
  824. package/dist/generated/quetzal-translations.d.ts.map +1 -0
  825. package/dist/generated/quetzal-translations.js +4310 -0
  826. package/dist/generated/quetzal-translations.js.map +1 -0
  827. package/dist/global.d.d.ts +0 -0
  828. package/dist/global.d.ts +1 -0
  829. package/dist/index.d.ts +40 -0
  830. package/dist/index.js +192 -0
  831. package/dist/integrations/convex/component/convex.config.d.ts +61 -0
  832. package/dist/integrations/convex/component/convex.config.d.ts.map +1 -0
  833. package/dist/integrations/convex/component/convex.config.js +9 -0
  834. package/dist/integrations/convex/component/convex.config.js.map +1 -0
  835. package/dist/integrations/convex.d.ts +13 -0
  836. package/dist/integrations/convex.d.ts.map +1 -0
  837. package/dist/integrations/convex.js +25 -0
  838. package/dist/integrations/convex.js.map +1 -0
  839. package/dist/lib/auth.d.ts +29 -0
  840. package/dist/lib/auth.d.ts.map +1 -0
  841. package/dist/lib/auth.js +111 -0
  842. package/dist/lib/auth.js.map +1 -0
  843. package/dist/lib/auth.test.d.ts +1 -0
  844. package/dist/lib/auth.test.js +60 -0
  845. package/dist/lib/auth.test.js.map +1 -0
  846. package/dist/lib/cookie.d.ts +50 -0
  847. package/dist/lib/cookie.d.ts.map +1 -0
  848. package/dist/lib/cookie.js +366 -0
  849. package/dist/lib/cookie.js.map +1 -0
  850. package/dist/lib/env.d.ts +37 -0
  851. package/dist/lib/env.d.ts.map +1 -0
  852. package/dist/lib/env.js +90 -0
  853. package/dist/lib/env.js.map +1 -0
  854. package/dist/lib/hooks.d.ts +35 -0
  855. package/dist/lib/hooks.d.ts.map +1 -0
  856. package/dist/lib/hooks.js +30 -0
  857. package/dist/lib/hooks.js.map +1 -0
  858. package/dist/lib/stack-app/api-keys/index.d.ts +53 -0
  859. package/dist/lib/stack-app/api-keys/index.d.ts.map +1 -0
  860. package/dist/lib/stack-app/api-keys/index.js +25 -0
  861. package/dist/lib/stack-app/api-keys/index.js.map +1 -0
  862. package/dist/lib/stack-app/apps/implementations/admin-app-impl.d.ts +421 -0
  863. package/dist/lib/stack-app/apps/implementations/admin-app-impl.d.ts.map +1 -0
  864. package/dist/lib/stack-app/apps/implementations/admin-app-impl.js +1043 -0
  865. package/dist/lib/stack-app/apps/implementations/admin-app-impl.js.map +1 -0
  866. package/dist/lib/stack-app/apps/implementations/client-app-impl.d.ts +561 -0
  867. package/dist/lib/stack-app/apps/implementations/client-app-impl.d.ts.map +1 -0
  868. package/dist/lib/stack-app/apps/implementations/client-app-impl.js +2637 -0
  869. package/dist/lib/stack-app/apps/implementations/client-app-impl.js.map +1 -0
  870. package/dist/lib/stack-app/apps/implementations/client-app-impl.oauth-prefetch.test.d.ts +1 -0
  871. package/dist/lib/stack-app/apps/implementations/client-app-impl.oauth-prefetch.test.js +32 -0
  872. package/dist/lib/stack-app/apps/implementations/client-app-impl.oauth-prefetch.test.js.map +1 -0
  873. package/dist/lib/stack-app/apps/implementations/common.d.ts +66 -0
  874. package/dist/lib/stack-app/apps/implementations/common.d.ts.map +1 -0
  875. package/dist/lib/stack-app/apps/implementations/common.js +186 -0
  876. package/dist/lib/stack-app/apps/implementations/common.js.map +1 -0
  877. package/dist/lib/stack-app/apps/implementations/event-tracker.d.ts +42 -0
  878. package/dist/lib/stack-app/apps/implementations/event-tracker.d.ts.map +1 -0
  879. package/dist/lib/stack-app/apps/implementations/event-tracker.js +213 -0
  880. package/dist/lib/stack-app/apps/implementations/event-tracker.js.map +1 -0
  881. package/dist/lib/stack-app/apps/implementations/event-tracker.test.d.ts +1 -0
  882. package/dist/lib/stack-app/apps/implementations/event-tracker.test.js +87 -0
  883. package/dist/lib/stack-app/apps/implementations/event-tracker.test.js.map +1 -0
  884. package/dist/lib/stack-app/apps/implementations/index.d.ts +9 -0
  885. package/dist/lib/stack-app/apps/implementations/index.d.ts.map +1 -0
  886. package/dist/lib/stack-app/apps/implementations/index.js +31 -0
  887. package/dist/lib/stack-app/apps/implementations/index.js.map +1 -0
  888. package/dist/lib/stack-app/apps/implementations/redirect-page-urls.d.ts +35 -0
  889. package/dist/lib/stack-app/apps/implementations/redirect-page-urls.d.ts.map +1 -0
  890. package/dist/lib/stack-app/apps/implementations/redirect-page-urls.js +191 -0
  891. package/dist/lib/stack-app/apps/implementations/redirect-page-urls.js.map +1 -0
  892. package/dist/lib/stack-app/apps/implementations/server-app-impl.d.ts +260 -0
  893. package/dist/lib/stack-app/apps/implementations/server-app-impl.d.ts.map +1 -0
  894. package/dist/lib/stack-app/apps/implementations/server-app-impl.js +1385 -0
  895. package/dist/lib/stack-app/apps/implementations/server-app-impl.js.map +1 -0
  896. package/dist/lib/stack-app/apps/implementations/session-refresh-subscription.d.ts +28 -0
  897. package/dist/lib/stack-app/apps/implementations/session-refresh-subscription.d.ts.map +1 -0
  898. package/dist/lib/stack-app/apps/implementations/session-refresh-subscription.js +33 -0
  899. package/dist/lib/stack-app/apps/implementations/session-refresh-subscription.js.map +1 -0
  900. package/dist/lib/stack-app/apps/implementations/session-refresh-subscription.test.d.ts +1 -0
  901. package/dist/lib/stack-app/apps/implementations/session-refresh-subscription.test.js +82 -0
  902. package/dist/lib/stack-app/apps/implementations/session-refresh-subscription.test.js.map +1 -0
  903. package/dist/lib/stack-app/apps/implementations/session-replay.d.ts +108 -0
  904. package/dist/lib/stack-app/apps/implementations/session-replay.d.ts.map +1 -0
  905. package/dist/lib/stack-app/apps/implementations/session-replay.js +242 -0
  906. package/dist/lib/stack-app/apps/implementations/session-replay.js.map +1 -0
  907. package/dist/lib/stack-app/apps/implementations/session-replay.test.d.ts +1 -0
  908. package/dist/lib/stack-app/apps/implementations/session-replay.test.js +29 -0
  909. package/dist/lib/stack-app/apps/implementations/session-replay.test.js.map +1 -0
  910. package/dist/lib/stack-app/apps/index.d.ts +4 -0
  911. package/dist/lib/stack-app/apps/index.js +24 -0
  912. package/dist/lib/stack-app/apps/interfaces/admin-app.d.ts +252 -0
  913. package/dist/lib/stack-app/apps/interfaces/admin-app.d.ts.map +1 -0
  914. package/dist/lib/stack-app/apps/interfaces/admin-app.js +10 -0
  915. package/dist/lib/stack-app/apps/interfaces/admin-app.js.map +1 -0
  916. package/dist/lib/stack-app/apps/interfaces/client-app.d.ts +220 -0
  917. package/dist/lib/stack-app/apps/interfaces/client-app.d.ts.map +1 -0
  918. package/dist/lib/stack-app/apps/interfaces/client-app.js +10 -0
  919. package/dist/lib/stack-app/apps/interfaces/client-app.js.map +1 -0
  920. package/dist/lib/stack-app/apps/interfaces/server-app.d.ts +153 -0
  921. package/dist/lib/stack-app/apps/interfaces/server-app.d.ts.map +1 -0
  922. package/dist/lib/stack-app/apps/interfaces/server-app.js +10 -0
  923. package/dist/lib/stack-app/apps/interfaces/server-app.js.map +1 -0
  924. package/dist/lib/stack-app/common.d.ts +183 -0
  925. package/dist/lib/stack-app/common.d.ts.map +1 -0
  926. package/dist/lib/stack-app/common.js +9 -0
  927. package/dist/lib/stack-app/common.js.map +1 -0
  928. package/dist/lib/stack-app/connected-accounts/index.d.ts +57 -0
  929. package/dist/lib/stack-app/connected-accounts/index.d.ts.map +1 -0
  930. package/dist/lib/stack-app/connected-accounts/index.js +0 -0
  931. package/dist/lib/stack-app/contact-channels/index.d.ts +43 -0
  932. package/dist/lib/stack-app/contact-channels/index.d.ts.map +1 -0
  933. package/dist/lib/stack-app/contact-channels/index.js +44 -0
  934. package/dist/lib/stack-app/contact-channels/index.js.map +1 -0
  935. package/dist/lib/stack-app/customers/index.d.ts +129 -0
  936. package/dist/lib/stack-app/customers/index.d.ts.map +1 -0
  937. package/dist/lib/stack-app/customers/index.js +0 -0
  938. package/dist/lib/stack-app/data-vault/index.d.ts +14 -0
  939. package/dist/lib/stack-app/data-vault/index.d.ts.map +1 -0
  940. package/dist/lib/stack-app/data-vault/index.js +0 -0
  941. package/dist/lib/stack-app/email/index.d.ts +204 -0
  942. package/dist/lib/stack-app/email/index.d.ts.map +1 -0
  943. package/dist/lib/stack-app/email/index.js +0 -0
  944. package/dist/lib/stack-app/email-templates/index.d.ts +17 -0
  945. package/dist/lib/stack-app/email-templates/index.d.ts.map +1 -0
  946. package/dist/lib/stack-app/email-templates/index.js +13 -0
  947. package/dist/lib/stack-app/email-templates/index.js.map +1 -0
  948. package/dist/lib/stack-app/index.d.ts +15 -0
  949. package/dist/lib/stack-app/index.js +36 -0
  950. package/dist/lib/stack-app/internal-api-keys/index.d.ts +42 -0
  951. package/dist/lib/stack-app/internal-api-keys/index.d.ts.map +1 -0
  952. package/dist/lib/stack-app/internal-api-keys/index.js +16 -0
  953. package/dist/lib/stack-app/internal-api-keys/index.js.map +1 -0
  954. package/dist/lib/stack-app/notification-categories/index.d.ts +11 -0
  955. package/dist/lib/stack-app/notification-categories/index.d.ts.map +1 -0
  956. package/dist/lib/stack-app/notification-categories/index.js +0 -0
  957. package/dist/lib/stack-app/permissions/index.d.ts +43 -0
  958. package/dist/lib/stack-app/permissions/index.d.ts.map +1 -0
  959. package/dist/lib/stack-app/permissions/index.js +36 -0
  960. package/dist/lib/stack-app/permissions/index.js.map +1 -0
  961. package/dist/lib/stack-app/project-configs/index.d.ts +99 -0
  962. package/dist/lib/stack-app/project-configs/index.d.ts.map +1 -0
  963. package/dist/lib/stack-app/project-configs/index.js +0 -0
  964. package/dist/lib/stack-app/projects/index.d.ts +147 -0
  965. package/dist/lib/stack-app/projects/index.d.ts.map +1 -0
  966. package/dist/lib/stack-app/projects/index.js +69 -0
  967. package/dist/lib/stack-app/projects/index.js.map +1 -0
  968. package/dist/lib/stack-app/session-replays/index.d.ts +66 -0
  969. package/dist/lib/stack-app/session-replays/index.d.ts.map +1 -0
  970. package/dist/lib/stack-app/session-replays/index.js +0 -0
  971. package/dist/lib/stack-app/teams/index.d.ts +163 -0
  972. package/dist/lib/stack-app/teams/index.d.ts.map +1 -0
  973. package/dist/lib/stack-app/teams/index.js +40 -0
  974. package/dist/lib/stack-app/teams/index.js.map +1 -0
  975. package/dist/lib/stack-app/url-targets.d.ts +40 -0
  976. package/dist/lib/stack-app/url-targets.d.ts.map +1 -0
  977. package/dist/lib/stack-app/url-targets.js +289 -0
  978. package/dist/lib/stack-app/url-targets.js.map +1 -0
  979. package/dist/lib/stack-app/url-targets.test.d.ts +1 -0
  980. package/dist/lib/stack-app/url-targets.test.js +169 -0
  981. package/dist/lib/stack-app/url-targets.test.js.map +1 -0
  982. package/dist/lib/stack-app/users/index.d.ts +400 -0
  983. package/dist/lib/stack-app/users/index.d.ts.map +1 -0
  984. package/dist/lib/stack-app/users/index.js +76 -0
  985. package/dist/lib/stack-app/users/index.js.map +1 -0
  986. package/dist/lib/translations.d.ts +7 -0
  987. package/dist/lib/translations.d.ts.map +1 -0
  988. package/dist/lib/translations.js +21 -0
  989. package/dist/lib/translations.js.map +1 -0
  990. package/dist/providers/stack-context.d.ts +10 -0
  991. package/dist/providers/stack-context.d.ts.map +1 -0
  992. package/dist/providers/stack-context.js +13 -0
  993. package/dist/providers/stack-context.js.map +1 -0
  994. package/dist/providers/stack-provider-client.d.ts +17 -0
  995. package/dist/providers/stack-provider-client.d.ts.map +1 -0
  996. package/dist/providers/stack-provider-client.js +34 -0
  997. package/dist/providers/stack-provider-client.js.map +1 -0
  998. package/dist/providers/stack-provider.d.ts +25 -0
  999. package/dist/providers/stack-provider.d.ts.map +1 -0
  1000. package/dist/providers/stack-provider.js +26 -0
  1001. package/dist/providers/stack-provider.js.map +1 -0
  1002. package/dist/providers/theme-provider.d.ts +46 -0
  1003. package/dist/providers/theme-provider.d.ts.map +1 -0
  1004. package/dist/providers/theme-provider.js +72 -0
  1005. package/dist/providers/theme-provider.js.map +1 -0
  1006. package/dist/providers/translation-provider-client.d.ts +16 -0
  1007. package/dist/providers/translation-provider-client.d.ts.map +1 -0
  1008. package/dist/providers/translation-provider-client.js +23 -0
  1009. package/dist/providers/translation-provider-client.js.map +1 -0
  1010. package/dist/providers/translation-provider.d.ts +16 -0
  1011. package/dist/providers/translation-provider.d.ts.map +1 -0
  1012. package/dist/providers/translation-provider.js +25 -0
  1013. package/dist/providers/translation-provider.js.map +1 -0
  1014. package/dist/storage-CKzvsBxG.d.ts +1912 -0
  1015. package/dist/storage-CKzvsBxG.d.ts.map +1 -0
  1016. package/dist/tanstack-start-server-context.combined.d.ts +12 -0
  1017. package/dist/tanstack-start-server-context.combined.d.ts.map +1 -0
  1018. package/dist/tanstack-start-server-context.combined.js +0 -0
  1019. package/dist/tanstack-start-server-context.default.d.ts +9 -0
  1020. package/dist/tanstack-start-server-context.default.d.ts.map +1 -0
  1021. package/dist/tanstack-start-server-context.default.js +16 -0
  1022. package/dist/tanstack-start-server-context.default.js.map +1 -0
  1023. package/dist/tanstack-start-server-context.server.d.ts +2 -0
  1024. package/dist/tanstack-start-server-context.server.js +34 -0
  1025. package/dist/utils/browser-script.d.ts +9 -0
  1026. package/dist/utils/browser-script.d.ts.map +1 -0
  1027. package/dist/utils/browser-script.js +107 -0
  1028. package/dist/utils/browser-script.js.map +1 -0
  1029. package/dist/utils/constants.d.ts +81 -0
  1030. package/dist/utils/constants.d.ts.map +1 -0
  1031. package/dist/utils/constants.js +92 -0
  1032. package/dist/utils/constants.js.map +1 -0
  1033. package/dist/utils/url.d.ts +5 -0
  1034. package/dist/utils/url.d.ts.map +1 -0
  1035. package/dist/utils/url.js +18 -0
  1036. package/dist/utils/url.js.map +1 -0
  1037. package/package.json +129 -6
@@ -0,0 +1 @@
1
+ {"version":3,"file":"email-and-auth-page.d.ts","names":[],"sources":["../../../../../src/components-page/account-settings/email-and-auth/email-and-auth-page.tsx"],"mappings":";;;iBAWgB,iBAAA,CAAkB,KAAA;EAChC,QAAA;AAAA,IACD,kBAAA,CAAA,GAAA,CAAA,OAAA"}
@@ -0,0 +1,22 @@
1
+ import { jsx, jsxs } from "react/jsx-runtime";
2
+ import { PageLayout } from "../page-layout.js";
3
+ import { EmailsSection } from "./emails-section.js";
4
+ import { MfaSection } from "./mfa-section.js";
5
+ import { OtpSection } from "./otp-section.js";
6
+ import { PasskeySection } from "./passkey-section.js";
7
+ import { PasswordSection } from "./password-section.js";
8
+
9
+ //#region src/components-page/account-settings/email-and-auth/email-and-auth-page.tsx
10
+ function EmailsAndAuthPage(props) {
11
+ return /* @__PURE__ */ jsxs(PageLayout, { children: [
12
+ /* @__PURE__ */ jsx(EmailsSection, { mockMode: props?.mockMode }),
13
+ /* @__PURE__ */ jsx(PasswordSection, { mockMode: props?.mockMode }),
14
+ /* @__PURE__ */ jsx(PasskeySection, { mockMode: props?.mockMode }),
15
+ /* @__PURE__ */ jsx(OtpSection, { mockMode: props?.mockMode }),
16
+ /* @__PURE__ */ jsx(MfaSection, { mockMode: props?.mockMode })
17
+ ] });
18
+ }
19
+
20
+ //#endregion
21
+ export { EmailsAndAuthPage };
22
+ //# sourceMappingURL=email-and-auth-page.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"email-and-auth-page.js","names":[],"sources":["../../../../../src/components-page/account-settings/email-and-auth/email-and-auth-page.tsx"],"sourcesContent":["\n//===========================================\n// THIS FILE IS AUTO-GENERATED FROM TEMPLATE. DO NOT EDIT IT DIRECTLY, INSTEAD EDIT THE CORRESPONDING FILE IN packages/template\n//===========================================\nimport { PageLayout } from \"../page-layout\";\nimport { EmailsSection } from \"./emails-section\";\nimport { MfaSection } from \"./mfa-section\";\nimport { OtpSection } from \"./otp-section\";\nimport { PasskeySection } from \"./passkey-section\";\nimport { PasswordSection } from \"./password-section\";\n\nexport function EmailsAndAuthPage(props?: {\n mockMode?: boolean,\n}) {\n return (\n <PageLayout>\n <EmailsSection mockMode={props?.mockMode}/>\n <PasswordSection mockMode={props?.mockMode} />\n <PasskeySection mockMode={props?.mockMode} />\n <OtpSection mockMode={props?.mockMode} />\n <MfaSection mockMode={props?.mockMode} />\n </PageLayout>\n );\n}\n"],"mappings":";;;;;;;;;AAWA,SAAgB,kBAAkB,OAE/B;AACD,QACE,qBAAC;EACC,oBAAC,iBAAc,UAAU,OAAO,WAAW;EAC3C,oBAAC,mBAAgB,UAAU,OAAO,WAAY;EAC9C,oBAAC,kBAAe,UAAU,OAAO,WAAY;EAC7C,oBAAC,cAAW,UAAU,OAAO,WAAY;EACzC,oBAAC,cAAW,UAAU,OAAO,WAAY;KAC9B"}
@@ -0,0 +1,9 @@
1
+ import * as react_jsx_runtime0 from "react/jsx-runtime";
2
+
3
+ //#region src/components-page/account-settings/email-and-auth/emails-section.d.ts
4
+ declare function EmailsSection(props?: {
5
+ mockMode?: boolean;
6
+ }): react_jsx_runtime0.JSX.Element | null;
7
+ //#endregion
8
+ export { EmailsSection };
9
+ //# sourceMappingURL=emails-section.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"emails-section.d.ts","names":[],"sources":["../../../../../src/components-page/account-settings/email-and-auth/emails-section.tsx"],"mappings":";;;iBAgBgB,aAAA,CAAc,KAAA;EAC5B,QAAA;AAAA,IACD,kBAAA,CAAA,GAAA,CAAA,OAAA"}
@@ -0,0 +1,179 @@
1
+ import { yupResolver } from "@hookform/resolvers/yup";
2
+ import { strictEmailSchema, yupObject } from "@stackframe/stack-shared/dist/schema-fields";
3
+ import { runAsynchronously } from "@stackframe/stack-shared/dist/utils/promises";
4
+ import { ActionCell, Badge, Button, Input, Table, TableBody, TableCell, TableRow, Typography } from "@stackframe/stack-ui";
5
+ import { useEffect, useState } from "react";
6
+ import { useForm } from "react-hook-form";
7
+ import { jsx, jsxs } from "react/jsx-runtime";
8
+ import { useUser } from "../../../lib/hooks.js";
9
+ import { useTranslation } from "../../../lib/translations.js";
10
+ import { KnownErrors } from "@stackframe/stack-shared/dist/known-errors";
11
+ import { FormWarningText } from "../../../components/elements/form-warning.js";
12
+
13
+ //#region src/components-page/account-settings/email-and-auth/emails-section.tsx
14
+ function EmailsSection(props) {
15
+ const { t } = useTranslation();
16
+ const user = useUser({ or: props?.mockMode ? "return-null" : "redirect" });
17
+ if (props?.mockMode && !user) return /* @__PURE__ */ jsxs("div", { children: [/* @__PURE__ */ jsx("div", {
18
+ className: "flex flex-col md:flex-row justify-between mb-4 gap-4",
19
+ children: /* @__PURE__ */ jsx(Typography, {
20
+ className: "font-medium",
21
+ children: t("Emails")
22
+ })
23
+ }), /* @__PURE__ */ jsx(Typography, {
24
+ variant: "secondary",
25
+ children: t("Email management is not available in demo mode.")
26
+ })] });
27
+ if (!user) return null;
28
+ const contactChannels = user.useContactChannels();
29
+ const [addingEmail, setAddingEmail] = useState(contactChannels.length === 0);
30
+ const [addingEmailLoading, setAddingEmailLoading] = useState(false);
31
+ const [addedEmail, setAddedEmail] = useState(null);
32
+ const isLastEmailUsedForAuth = contactChannels.filter((x) => x.usedForAuth && x.type === "email").length === 1;
33
+ useEffect(() => {
34
+ if (addedEmail) runAsynchronously(async () => {
35
+ const cc = contactChannels.find((x) => x.value === addedEmail);
36
+ if (cc && !cc.isVerified) await cc.sendVerificationEmail();
37
+ setAddedEmail(null);
38
+ });
39
+ }, [contactChannels, addedEmail]);
40
+ const { register, handleSubmit, formState: { errors }, reset } = useForm({ resolver: yupResolver(yupObject({ email: strictEmailSchema(t("Please enter a valid email address")).notOneOf(contactChannels.map((x) => x.value), t("Email already exists")).defined().nonEmpty(t("Email is required")) })) });
41
+ const onSubmit = async (data) => {
42
+ setAddingEmailLoading(true);
43
+ try {
44
+ await user.createContactChannel({
45
+ type: "email",
46
+ value: data.email,
47
+ usedForAuth: false
48
+ });
49
+ setAddedEmail(data.email);
50
+ } finally {
51
+ setAddingEmailLoading(false);
52
+ }
53
+ setAddingEmail(false);
54
+ reset();
55
+ };
56
+ return /* @__PURE__ */ jsxs("div", { children: [/* @__PURE__ */ jsxs("div", {
57
+ className: "flex flex-col md:flex-row justify-between mb-4 gap-4",
58
+ children: [/* @__PURE__ */ jsx(Typography, {
59
+ className: "font-medium",
60
+ children: t("Emails")
61
+ }), addingEmail ? /* @__PURE__ */ jsxs("form", {
62
+ onSubmit: (e) => {
63
+ e.preventDefault();
64
+ runAsynchronously(handleSubmit(onSubmit));
65
+ },
66
+ className: "flex flex-col",
67
+ children: [/* @__PURE__ */ jsxs("div", {
68
+ className: "flex gap-2",
69
+ children: [
70
+ /* @__PURE__ */ jsx(Input, {
71
+ ...register("email"),
72
+ placeholder: t("Enter email")
73
+ }),
74
+ /* @__PURE__ */ jsx(Button, {
75
+ type: "submit",
76
+ loading: addingEmailLoading,
77
+ children: t("Add")
78
+ }),
79
+ /* @__PURE__ */ jsx(Button, {
80
+ variant: "secondary",
81
+ onClick: () => {
82
+ setAddingEmail(false);
83
+ reset();
84
+ },
85
+ children: t("Cancel")
86
+ })
87
+ ]
88
+ }), errors.email && /* @__PURE__ */ jsx(FormWarningText, { text: errors.email.message })]
89
+ }) : /* @__PURE__ */ jsx("div", {
90
+ className: "flex md:justify-end",
91
+ children: /* @__PURE__ */ jsx(Button, {
92
+ variant: "secondary",
93
+ onClick: () => setAddingEmail(true),
94
+ children: t("Add an email")
95
+ })
96
+ })]
97
+ }), contactChannels.length > 0 ? /* @__PURE__ */ jsx("div", {
98
+ className: "border rounded-md",
99
+ children: /* @__PURE__ */ jsx(Table, { children: /* @__PURE__ */ jsx(TableBody, { children: contactChannels.filter((x) => x.type === "email").sort((a, b) => {
100
+ if (a.isPrimary !== b.isPrimary) return a.isPrimary ? -1 : 1;
101
+ if (a.isVerified !== b.isVerified) return a.isVerified ? -1 : 1;
102
+ return 0;
103
+ }).map((x) => /* @__PURE__ */ jsxs(TableRow, { children: [/* @__PURE__ */ jsx(TableCell, { children: /* @__PURE__ */ jsxs("div", {
104
+ className: "flex flex-col md:flex-row gap-2 md:gap-4",
105
+ children: [x.value, /* @__PURE__ */ jsxs("div", {
106
+ className: "flex gap-2",
107
+ children: [
108
+ x.isPrimary ? /* @__PURE__ */ jsx(Badge, { children: t("Primary") }) : null,
109
+ !x.isVerified ? /* @__PURE__ */ jsx(Badge, {
110
+ variant: "destructive",
111
+ children: t("Unverified")
112
+ }) : null,
113
+ x.usedForAuth ? /* @__PURE__ */ jsx(Badge, {
114
+ variant: "outline",
115
+ children: t("Used for sign-in")
116
+ }) : null
117
+ ]
118
+ })]
119
+ }) }), /* @__PURE__ */ jsx(TableCell, {
120
+ className: "flex justify-end",
121
+ children: /* @__PURE__ */ jsx(ActionCell, { items: [
122
+ ...!x.isVerified ? [{
123
+ item: t("Send verification email"),
124
+ onClick: async () => {
125
+ await x.sendVerificationEmail();
126
+ }
127
+ }] : [],
128
+ ...!x.isPrimary && x.isVerified ? [{
129
+ item: t("Set as primary"),
130
+ onClick: async () => {
131
+ await x.update({ isPrimary: true });
132
+ }
133
+ }] : !x.isPrimary ? [{
134
+ item: t("Set as primary"),
135
+ onClick: async () => {},
136
+ disabled: true,
137
+ disabledTooltip: t("Please verify your email first")
138
+ }] : [],
139
+ ...!x.usedForAuth && x.isVerified ? [{
140
+ item: t("Use for sign-in"),
141
+ onClick: async () => {
142
+ try {
143
+ await x.update({ usedForAuth: true });
144
+ } catch (e) {
145
+ if (KnownErrors.ContactChannelAlreadyUsedForAuthBySomeoneElse.isInstance(e)) alert(t("This email is already used for sign-in by another user."));
146
+ }
147
+ }
148
+ }] : [],
149
+ ...x.usedForAuth && !isLastEmailUsedForAuth ? [{
150
+ item: t("Stop using for sign-in"),
151
+ onClick: async () => {
152
+ await x.update({ usedForAuth: false });
153
+ }
154
+ }] : x.usedForAuth ? [{
155
+ item: t("Stop using for sign-in"),
156
+ onClick: async () => {},
157
+ disabled: true,
158
+ disabledTooltip: t("You can not remove your last sign-in email")
159
+ }] : [],
160
+ ...!isLastEmailUsedForAuth || !x.usedForAuth ? [{
161
+ item: t("Remove"),
162
+ onClick: async () => {
163
+ await x.delete();
164
+ },
165
+ danger: true
166
+ }] : [{
167
+ item: t("Remove"),
168
+ onClick: async () => {},
169
+ disabled: true,
170
+ disabledTooltip: t("You can not remove your last sign-in email")
171
+ }]
172
+ ] })
173
+ })] }, x.id)) }) })
174
+ }) : null] });
175
+ }
176
+
177
+ //#endregion
178
+ export { EmailsSection };
179
+ //# sourceMappingURL=emails-section.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"emails-section.js","names":[],"sources":["../../../../../src/components-page/account-settings/email-and-auth/emails-section.tsx"],"sourcesContent":["\n//===========================================\n// THIS FILE IS AUTO-GENERATED FROM TEMPLATE. DO NOT EDIT IT DIRECTLY, INSTEAD EDIT THE CORRESPONDING FILE IN packages/template\n//===========================================\nimport { yupResolver } from \"@hookform/resolvers/yup\";\nimport { KnownErrors } from \"@stackframe/stack-shared/dist/known-errors\";\nimport { strictEmailSchema, yupObject } from \"@stackframe/stack-shared/dist/schema-fields\";\nimport { runAsynchronously } from \"@stackframe/stack-shared/dist/utils/promises\";\nimport { ActionCell, Badge, Button, Input, Table, TableBody, TableCell, TableRow, Typography } from \"@stackframe/stack-ui\";\nimport { useEffect, useState } from \"react\";\nimport { useForm } from \"react-hook-form\";\nimport * as yup from \"yup\";\nimport { FormWarningText } from \"../../../components/elements/form-warning\";\nimport { useUser } from \"../../../lib/hooks\";\nimport { useTranslation } from \"../../../lib/translations\";\n\nexport function EmailsSection(props?: {\n mockMode?: boolean,\n}) {\n const { t } = useTranslation();\n const user = useUser({ or: props?.mockMode ? 'return-null' : 'redirect' });\n\n // In mock mode, show a placeholder message\n if (props?.mockMode && !user) {\n return (\n <div>\n <div className='flex flex-col md:flex-row justify-between mb-4 gap-4'>\n <Typography className='font-medium'>{t(\"Emails\")}</Typography>\n </div>\n <Typography variant='secondary'>{t(\"Email management is not available in demo mode.\")}</Typography>\n </div>\n );\n }\n\n if (!user) {\n return null; // This shouldn't happen in non-mock mode due to redirect\n }\n\n const contactChannels = user.useContactChannels();\n const [addingEmail, setAddingEmail] = useState(contactChannels.length === 0);\n const [addingEmailLoading, setAddingEmailLoading] = useState(false);\n const [addedEmail, setAddedEmail] = useState<string | null>(null);\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n const isLastEmailUsedForAuth = contactChannels.filter(x => x.usedForAuth && x.type === 'email').length === 1;\n\n useEffect(() => {\n if (addedEmail) {\n runAsynchronously(async () => {\n const cc = contactChannels.find(x => x.value === addedEmail);\n if (cc && !cc.isVerified) {\n await cc.sendVerificationEmail();\n }\n setAddedEmail(null);\n });\n }\n }, [contactChannels, addedEmail]);\n\n const emailSchema = yupObject({\n email: strictEmailSchema(t('Please enter a valid email address'))\n .notOneOf(contactChannels.map(x => x.value), t('Email already exists'))\n .defined()\n .nonEmpty(t('Email is required')),\n });\n\n const { register, handleSubmit, formState: { errors }, reset } = useForm({\n resolver: yupResolver(emailSchema)\n });\n\n const onSubmit = async (data: yup.InferType<typeof emailSchema>) => {\n setAddingEmailLoading(true);\n try {\n await user.createContactChannel({ type: 'email', value: data.email, usedForAuth: false });\n setAddedEmail(data.email);\n } finally {\n setAddingEmailLoading(false);\n }\n setAddingEmail(false);\n reset();\n };\n\n return (\n <div>\n <div className='flex flex-col md:flex-row justify-between mb-4 gap-4'>\n <Typography className='font-medium'>{t(\"Emails\")}</Typography>\n {addingEmail ? (\n <form\n onSubmit={(e) => {\n e.preventDefault();\n runAsynchronously(handleSubmit(onSubmit));\n }}\n className='flex flex-col'\n >\n <div className='flex gap-2'>\n <Input\n {...register(\"email\")}\n placeholder={t(\"Enter email\")}\n />\n <Button type=\"submit\" loading={addingEmailLoading}>\n {t(\"Add\")}\n </Button>\n <Button\n variant='secondary'\n onClick={() => {\n setAddingEmail(false);\n reset();\n }}\n >\n {t(\"Cancel\")}\n </Button>\n </div>\n {errors.email && <FormWarningText text={errors.email.message} />}\n </form>\n ) : (\n <div className='flex md:justify-end'>\n <Button variant='secondary' onClick={() => setAddingEmail(true)}>{t(\"Add an email\")}</Button>\n </div>\n )}\n </div>\n\n {contactChannels.length > 0 ? (\n <div className='border rounded-md'>\n <Table>\n <TableBody>\n {/*eslint-disable-next-line @typescript-eslint/no-unnecessary-condition*/}\n {contactChannels.filter(x => x.type === 'email')\n .sort((a, b) => {\n if (a.isPrimary !== b.isPrimary) return a.isPrimary ? -1 : 1;\n if (a.isVerified !== b.isVerified) return a.isVerified ? -1 : 1;\n return 0;\n })\n .map(x => (\n <TableRow key={x.id}>\n <TableCell>\n <div className='flex flex-col md:flex-row gap-2 md:gap-4'>\n {x.value}\n <div className='flex gap-2'>\n {x.isPrimary ? <Badge>{t(\"Primary\")}</Badge> : null}\n {!x.isVerified ? <Badge variant='destructive'>{t(\"Unverified\")}</Badge> : null}\n {x.usedForAuth ? <Badge variant='outline'>{t(\"Used for sign-in\")}</Badge> : null}\n </div>\n </div>\n </TableCell>\n <TableCell className=\"flex justify-end\">\n <ActionCell items={[\n ...(!x.isVerified ? [{\n item: t(\"Send verification email\"),\n onClick: async () => { await x.sendVerificationEmail(); },\n }] : []),\n ...(!x.isPrimary && x.isVerified ? [{\n item: t(\"Set as primary\"),\n onClick: async () => { await x.update({ isPrimary: true }); },\n }] :\n !x.isPrimary ? [{\n item: t(\"Set as primary\"),\n onClick: async () => {},\n disabled: true,\n disabledTooltip: t(\"Please verify your email first\"),\n }] : []),\n ...(!x.usedForAuth && x.isVerified ? [{\n item: t(\"Use for sign-in\"),\n onClick: async () => {\n try {\n await x.update({ usedForAuth: true });\n } catch (e) {\n if (KnownErrors.ContactChannelAlreadyUsedForAuthBySomeoneElse.isInstance(e)) {\n alert(t(\"This email is already used for sign-in by another user.\"));\n }\n }\n }\n }] : []),\n ...(x.usedForAuth && !isLastEmailUsedForAuth ? [{\n item: t(\"Stop using for sign-in\"),\n onClick: async () => { await x.update({ usedForAuth: false }); },\n }] : x.usedForAuth ? [{\n item: t(\"Stop using for sign-in\"),\n onClick: async () => {},\n disabled: true,\n disabledTooltip: t(\"You can not remove your last sign-in email\"),\n }] : []),\n // Determine if this email can be removed\n ...(!isLastEmailUsedForAuth || !x.usedForAuth ? [{\n item: t(\"Remove\"),\n onClick: async () => { await x.delete(); },\n danger: true,\n }] : [{\n item: t(\"Remove\"),\n onClick: async () => {},\n disabled: true,\n disabledTooltip: t(\"You can not remove your last sign-in email\"),\n }]),\n ]}/>\n </TableCell>\n </TableRow>\n ))}\n </TableBody>\n </Table>\n </div>\n ) : null}\n </div>\n );\n}\n"],"mappings":";;;;;;;;;;;;;AAgBA,SAAgB,cAAc,OAE3B;CACD,MAAM,EAAE,MAAM,gBAAgB;CAC9B,MAAM,OAAO,QAAQ,EAAE,IAAI,OAAO,WAAW,gBAAgB,YAAY,CAAC;AAG1E,KAAI,OAAO,YAAY,CAAC,KACtB,QACE,qBAAC,oBACC,oBAAC;EAAI,WAAU;YACb,oBAAC;GAAW,WAAU;aAAe,EAAE,SAAS;IAAc;GAC1D,EACN,oBAAC;EAAW,SAAQ;YAAa,EAAE,kDAAkD;GAAc,IAC/F;AAIV,KAAI,CAAC,KACH,QAAO;CAGT,MAAM,kBAAkB,KAAK,oBAAoB;CACjD,MAAM,CAAC,aAAa,kBAAkB,SAAS,gBAAgB,WAAW,EAAE;CAC5E,MAAM,CAAC,oBAAoB,yBAAyB,SAAS,MAAM;CACnE,MAAM,CAAC,YAAY,iBAAiB,SAAwB,KAAK;CAEjE,MAAM,yBAAyB,gBAAgB,QAAO,MAAK,EAAE,eAAe,EAAE,SAAS,QAAQ,CAAC,WAAW;AAE3G,iBAAgB;AACd,MAAI,WACF,mBAAkB,YAAY;GAC5B,MAAM,KAAK,gBAAgB,MAAK,MAAK,EAAE,UAAU,WAAW;AAC5D,OAAI,MAAM,CAAC,GAAG,WACZ,OAAM,GAAG,uBAAuB;AAElC,iBAAc,KAAK;IACnB;IAEH,CAAC,iBAAiB,WAAW,CAAC;CASjC,MAAM,EAAE,UAAU,cAAc,WAAW,EAAE,UAAU,UAAU,QAAQ,EACvE,UAAU,YARQ,UAAU,EAC5B,OAAO,kBAAkB,EAAE,qCAAqC,CAAC,CAC9D,SAAS,gBAAgB,KAAI,MAAK,EAAE,MAAM,EAAE,EAAE,uBAAuB,CAAC,CACtE,SAAS,CACT,SAAS,EAAE,oBAAoB,CAAC,EACpC,CAAC,CAGkC,EACnC,CAAC;CAEF,MAAM,WAAW,OAAO,SAA4C;AAClE,wBAAsB,KAAK;AAC3B,MAAI;AACF,SAAM,KAAK,qBAAqB;IAAE,MAAM;IAAS,OAAO,KAAK;IAAO,aAAa;IAAO,CAAC;AACzF,iBAAc,KAAK,MAAM;YACjB;AACR,yBAAsB,MAAM;;AAE9B,iBAAe,MAAM;AACrB,SAAO;;AAGT,QACE,qBAAC,oBACC,qBAAC;EAAI,WAAU;aACb,oBAAC;GAAW,WAAU;aAAe,EAAE,SAAS;IAAc,EAC7D,cACC,qBAAC;GACC,WAAW,MAAM;AACf,MAAE,gBAAgB;AAClB,sBAAkB,aAAa,SAAS,CAAC;;GAE3C,WAAU;cAEV,qBAAC;IAAI,WAAU;;KACb,oBAAC;MACC,GAAI,SAAS,QAAQ;MACrB,aAAa,EAAE,cAAc;OAC7B;KACF,oBAAC;MAAO,MAAK;MAAS,SAAS;gBAC5B,EAAE,MAAM;OACF;KACT,oBAAC;MACC,SAAQ;MACR,eAAe;AACb,sBAAe,MAAM;AACrB,cAAO;;gBAGR,EAAE,SAAS;OACL;;KACL,EACL,OAAO,SAAS,oBAAC,mBAAgB,MAAM,OAAO,MAAM,UAAW;IAC3D,GAEP,oBAAC;GAAI,WAAU;aACb,oBAAC;IAAO,SAAQ;IAAY,eAAe,eAAe,KAAK;cAAG,EAAE,eAAe;KAAU;IACzF;GAEJ,EAEL,gBAAgB,SAAS,IACxB,oBAAC;EAAI,WAAU;YACb,oBAAC,mBACC,oBAAC,uBAEE,gBAAgB,QAAO,MAAK,EAAE,SAAS,QAAQ,CAC7C,MAAM,GAAG,MAAM;AACd,OAAI,EAAE,cAAc,EAAE,UAAW,QAAO,EAAE,YAAY,KAAK;AAC3D,OAAI,EAAE,eAAe,EAAE,WAAY,QAAO,EAAE,aAAa,KAAK;AAC9D,UAAO;IACP,CACD,KAAI,MACH,qBAAC,uBACC,oBAAC,uBACC,qBAAC;GAAI,WAAU;cACZ,EAAE,OACH,qBAAC;IAAI,WAAU;;KACZ,EAAE,YAAY,oBAAC,mBAAO,EAAE,UAAU,GAAS,GAAG;KAC9C,CAAC,EAAE,aAAa,oBAAC;MAAM,SAAQ;gBAAe,EAAE,aAAa;OAAS,GAAG;KACzE,EAAE,cAAc,oBAAC;MAAM,SAAQ;gBAAW,EAAE,mBAAmB;OAAS,GAAG;;KACxE;IACF,GACI,EACZ,oBAAC;GAAU,WAAU;aACnB,oBAAC,cAAW,OAAO;IACjB,GAAI,CAAC,EAAE,aAAa,CAAC;KACnB,MAAM,EAAE,0BAA0B;KAClC,SAAS,YAAY;AAAE,YAAM,EAAE,uBAAuB;;KACvD,CAAC,GAAG,EAAE;IACP,GAAI,CAAC,EAAE,aAAa,EAAE,aAAa,CAAC;KAClC,MAAM,EAAE,iBAAiB;KACzB,SAAS,YAAY;AAAE,YAAM,EAAE,OAAO,EAAE,WAAW,MAAM,CAAC;;KAC3D,CAAC,GACA,CAAC,EAAE,YAAY,CAAC;KACd,MAAM,EAAE,iBAAiB;KACzB,SAAS,YAAY;KACrB,UAAU;KACV,iBAAiB,EAAE,iCAAiC;KACrD,CAAC,GAAG,EAAE;IACT,GAAI,CAAC,EAAE,eAAe,EAAE,aAAa,CAAC;KACpC,MAAM,EAAE,kBAAkB;KAC1B,SAAS,YAAY;AACnB,UAAI;AACF,aAAM,EAAE,OAAO,EAAE,aAAa,MAAM,CAAC;eAC9B,GAAG;AACV,WAAI,YAAY,8CAA8C,WAAW,EAAE,CACzE,OAAM,EAAE,0DAA0D,CAAC;;;KAI1E,CAAC,GAAG,EAAE;IACP,GAAI,EAAE,eAAe,CAAC,yBAAyB,CAAC;KAC9C,MAAM,EAAE,yBAAyB;KACjC,SAAS,YAAY;AAAE,YAAM,EAAE,OAAO,EAAE,aAAa,OAAO,CAAC;;KAC9D,CAAC,GAAG,EAAE,cAAc,CAAC;KACpB,MAAM,EAAE,yBAAyB;KACjC,SAAS,YAAY;KACrB,UAAU;KACV,iBAAiB,EAAE,6CAA6C;KACjE,CAAC,GAAG,EAAE;IAEP,GAAI,CAAC,0BAA0B,CAAC,EAAE,cAAc,CAAC;KAC/C,MAAM,EAAE,SAAS;KACjB,SAAS,YAAY;AAAE,YAAM,EAAE,QAAQ;;KACvC,QAAQ;KACT,CAAC,GAAG,CAAC;KACJ,MAAM,EAAE,SAAS;KACjB,SAAS,YAAY;KACrB,UAAU;KACV,iBAAiB,EAAE,6CAA6C;KACjE,CAAC;IACH,GAAG;IACM,KA5DC,EAAE,GA6DN,CACX,GACM,GACN;GACJ,GACJ,QACA"}
@@ -0,0 +1,9 @@
1
+ import * as react_jsx_runtime0 from "react/jsx-runtime";
2
+
3
+ //#region src/components-page/account-settings/email-and-auth/mfa-section.d.ts
4
+ declare function MfaSection(props?: {
5
+ mockMode?: boolean;
6
+ }): react_jsx_runtime0.JSX.Element | null;
7
+ //#endregion
8
+ export { MfaSection };
9
+ //# sourceMappingURL=mfa-section.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mfa-section.d.ts","names":[],"sources":["../../../../../src/components-page/account-settings/email-and-auth/mfa-section.tsx"],"mappings":";;;iBAiBgB,UAAA,CAAW,KAAA;EACzB,QAAA;AAAA,IACD,kBAAA,CAAA,GAAA,CAAA,OAAA"}
@@ -0,0 +1,118 @@
1
+ import { throwErr } from "@stackframe/stack-shared/dist/utils/errors";
2
+ import { runAsynchronouslyWithAlert } from "@stackframe/stack-shared/dist/utils/promises";
3
+ import { Button, Input, Typography } from "@stackframe/stack-ui";
4
+ import { useEffect, useState } from "react";
5
+ import { Fragment, jsx, jsxs } from "react/jsx-runtime";
6
+ import { useStackApp, useUser } from "../../../lib/hooks.js";
7
+ import { useTranslation } from "../../../lib/translations.js";
8
+ import { createTOTPKeyURI, verifyTOTP } from "@oslojs/otp";
9
+ import { useAsyncCallback } from "@stackframe/stack-shared/dist/hooks/use-async-callback";
10
+ import { generateRandomValues } from "@stackframe/stack-shared/dist/utils/crypto";
11
+ import * as QRCode from "qrcode";
12
+ import { Section } from "../section.js";
13
+
14
+ //#region src/components-page/account-settings/email-and-auth/mfa-section.tsx
15
+ function MfaSection(props) {
16
+ const { t } = useTranslation();
17
+ const project = useStackApp().useProject();
18
+ const user = useUser({ or: props?.mockMode ? "return-null" : "throw" });
19
+ if (props?.mockMode && !user) return /* @__PURE__ */ jsx(Section, {
20
+ title: t("Multi-factor authentication"),
21
+ description: t("MFA management is not available in demo mode."),
22
+ children: /* @__PURE__ */ jsx(Typography, {
23
+ variant: "secondary",
24
+ children: t("MFA management is not available in demo mode.")
25
+ })
26
+ });
27
+ if (!user) return null;
28
+ const [generatedSecret, setGeneratedSecret] = useState(null);
29
+ const [qrCodeUrl, setQrCodeUrl] = useState(null);
30
+ const [mfaCode, setMfaCode] = useState("");
31
+ const [isMaybeWrong, setIsMaybeWrong] = useState(false);
32
+ const isEnabled = user.isMultiFactorRequired;
33
+ const [handleSubmit, isLoading] = useAsyncCallback(async () => {
34
+ await user.update({ totpMultiFactorSecret: generatedSecret });
35
+ setGeneratedSecret(null);
36
+ setQrCodeUrl(null);
37
+ setMfaCode("");
38
+ }, [generatedSecret, user]);
39
+ useEffect(() => {
40
+ setIsMaybeWrong(false);
41
+ runAsynchronouslyWithAlert(async () => {
42
+ if (generatedSecret && verifyTOTP(generatedSecret, 30, 6, mfaCode)) await handleSubmit();
43
+ setIsMaybeWrong(true);
44
+ });
45
+ }, [
46
+ mfaCode,
47
+ generatedSecret,
48
+ handleSubmit
49
+ ]);
50
+ return /* @__PURE__ */ jsx(Section, {
51
+ title: t("Multi-factor authentication"),
52
+ description: isEnabled ? t("Multi-factor authentication is currently enabled.") : t("Multi-factor authentication is currently disabled."),
53
+ children: /* @__PURE__ */ jsxs("div", {
54
+ className: "flex flex-col gap-4",
55
+ children: [!isEnabled && generatedSecret && /* @__PURE__ */ jsxs(Fragment, { children: [
56
+ /* @__PURE__ */ jsx(Typography, { children: t("Scan this QR code with your authenticator app:") }),
57
+ /* @__PURE__ */ jsx("img", {
58
+ width: 200,
59
+ height: 200,
60
+ src: qrCodeUrl ?? throwErr("TOTP QR code failed to generate"),
61
+ alt: t("TOTP multi-factor authentication QR code")
62
+ }),
63
+ /* @__PURE__ */ jsx(Typography, { children: t("Then, enter your six-digit MFA code:") }),
64
+ /* @__PURE__ */ jsx(Input, {
65
+ value: mfaCode,
66
+ onChange: (e) => {
67
+ setIsMaybeWrong(false);
68
+ setMfaCode(e.target.value);
69
+ },
70
+ placeholder: "123456",
71
+ maxLength: 6,
72
+ disabled: isLoading
73
+ }),
74
+ isMaybeWrong && mfaCode.length === 6 && /* @__PURE__ */ jsx(Typography, {
75
+ variant: "destructive",
76
+ children: t("Incorrect code. Please try again.")
77
+ }),
78
+ /* @__PURE__ */ jsx("div", {
79
+ className: "flex",
80
+ children: /* @__PURE__ */ jsx(Button, {
81
+ variant: "secondary",
82
+ onClick: () => {
83
+ setGeneratedSecret(null);
84
+ setQrCodeUrl(null);
85
+ setMfaCode("");
86
+ },
87
+ children: t("Cancel")
88
+ })
89
+ })
90
+ ] }), /* @__PURE__ */ jsx("div", {
91
+ className: "flex gap-2",
92
+ children: isEnabled ? /* @__PURE__ */ jsx(Button, {
93
+ variant: "secondary",
94
+ onClick: async () => {
95
+ await user.update({ totpMultiFactorSecret: null });
96
+ },
97
+ children: t("Disable MFA")
98
+ }) : !generatedSecret && /* @__PURE__ */ jsx(Button, {
99
+ variant: "secondary",
100
+ onClick: async () => {
101
+ const secret = generateRandomValues(new Uint8Array(20));
102
+ setQrCodeUrl(await generateTotpQrCode(project, user, secret));
103
+ setGeneratedSecret(secret);
104
+ },
105
+ children: t("Enable MFA")
106
+ })
107
+ })]
108
+ })
109
+ });
110
+ }
111
+ async function generateTotpQrCode(project, user, secret) {
112
+ const uri = createTOTPKeyURI(project.displayName, user.primaryEmail ?? user.id, secret, 30, 6);
113
+ return await QRCode.toDataURL(uri);
114
+ }
115
+
116
+ //#endregion
117
+ export { MfaSection };
118
+ //# sourceMappingURL=mfa-section.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mfa-section.js","names":[],"sources":["../../../../../src/components-page/account-settings/email-and-auth/mfa-section.tsx"],"sourcesContent":["\n//===========================================\n// THIS FILE IS AUTO-GENERATED FROM TEMPLATE. DO NOT EDIT IT DIRECTLY, INSTEAD EDIT THE CORRESPONDING FILE IN packages/template\n//===========================================\nimport { createTOTPKeyURI, verifyTOTP } from \"@oslojs/otp\";\nimport { useAsyncCallback } from '@stackframe/stack-shared/dist/hooks/use-async-callback';\nimport { generateRandomValues } from '@stackframe/stack-shared/dist/utils/crypto';\nimport { throwErr } from \"@stackframe/stack-shared/dist/utils/errors\";\nimport { runAsynchronouslyWithAlert } from \"@stackframe/stack-shared/dist/utils/promises\";\nimport { Button, Input, Typography } from \"@stackframe/stack-ui\";\nimport * as QRCode from 'qrcode';\nimport { useEffect, useState } from \"react\";\nimport { CurrentUser, Project } from '../../..';\nimport { useStackApp, useUser } from \"../../../lib/hooks\";\nimport { useTranslation } from \"../../../lib/translations\";\nimport { Section } from \"../section\";\n\nexport function MfaSection(props?: {\n mockMode?: boolean,\n}) {\n const { t } = useTranslation();\n const project = useStackApp().useProject();\n const user = useUser({ or: props?.mockMode ? 'return-null' : \"throw\" });\n\n // In mock mode, show a placeholder message\n if (props?.mockMode && !user) {\n return (\n <Section\n title={t(\"Multi-factor authentication\")}\n description={t(\"MFA management is not available in demo mode.\")}\n >\n <Typography variant='secondary'>{t(\"MFA management is not available in demo mode.\")}</Typography>\n </Section>\n );\n }\n\n if (!user) {\n return null; // This shouldn't happen in non-mock mode due to throw\n }\n const [generatedSecret, setGeneratedSecret] = useState<Uint8Array | null>(null);\n const [qrCodeUrl, setQrCodeUrl] = useState<string | null>(null);\n const [mfaCode, setMfaCode] = useState<string>(\"\");\n const [isMaybeWrong, setIsMaybeWrong] = useState(false);\n const isEnabled = user.isMultiFactorRequired;\n\n const [handleSubmit, isLoading] = useAsyncCallback(async () => {\n await user.update({\n totpMultiFactorSecret: generatedSecret,\n });\n setGeneratedSecret(null);\n setQrCodeUrl(null);\n setMfaCode(\"\");\n }, [generatedSecret, user]);\n\n useEffect(() => {\n setIsMaybeWrong(false);\n runAsynchronouslyWithAlert(async () => {\n if (generatedSecret && verifyTOTP(generatedSecret, 30, 6, mfaCode)) {\n await handleSubmit();\n }\n setIsMaybeWrong(true);\n });\n }, [mfaCode, generatedSecret, handleSubmit]);\n\n return (\n <Section\n title={t(\"Multi-factor authentication\")}\n description={isEnabled\n ? t(\"Multi-factor authentication is currently enabled.\")\n : t(\"Multi-factor authentication is currently disabled.\")}\n >\n <div className='flex flex-col gap-4'>\n {!isEnabled && generatedSecret && (\n <>\n <Typography>{t(\"Scan this QR code with your authenticator app:\")}</Typography>\n <img width={200} height={200} src={qrCodeUrl ?? throwErr(\"TOTP QR code failed to generate\")} alt={t(\"TOTP multi-factor authentication QR code\")} />\n <Typography>{t(\"Then, enter your six-digit MFA code:\")}</Typography>\n <Input\n value={mfaCode}\n onChange={(e) => {\n setIsMaybeWrong(false);\n setMfaCode(e.target.value);\n }}\n placeholder=\"123456\"\n maxLength={6}\n disabled={isLoading}\n />\n {isMaybeWrong && mfaCode.length === 6 && (\n <Typography variant=\"destructive\">{t(\"Incorrect code. Please try again.\")}</Typography>\n )}\n <div className='flex'>\n <Button\n variant='secondary'\n onClick={() => {\n setGeneratedSecret(null);\n setQrCodeUrl(null);\n setMfaCode(\"\");\n }}\n >\n {t(\"Cancel\")}\n </Button>\n </div>\n </>\n )}\n <div className='flex gap-2'>\n {isEnabled ? (\n <Button\n variant='secondary'\n onClick={async () => {\n await user.update({\n totpMultiFactorSecret: null,\n });\n }}\n >\n {t(\"Disable MFA\")}\n </Button>\n ) : !generatedSecret && (\n <Button\n variant='secondary'\n onClick={async () => {\n const secret = generateRandomValues(new Uint8Array(20));\n setQrCodeUrl(await generateTotpQrCode(project, user, secret));\n setGeneratedSecret(secret);\n }}\n >\n {t(\"Enable MFA\")}\n </Button>\n )}\n </div>\n </div>\n </Section>\n );\n}\n\n\nasync function generateTotpQrCode(project: Project, user: CurrentUser, secret: Uint8Array) {\n const uri = createTOTPKeyURI(project.displayName, user.primaryEmail ?? user.id, secret, 30, 6);\n return await QRCode.toDataURL(uri) as any;\n}\n"],"mappings":";;;;;;;;;;;;;;AAiBA,SAAgB,WAAW,OAExB;CACD,MAAM,EAAE,MAAM,gBAAgB;CAC9B,MAAM,UAAU,aAAa,CAAC,YAAY;CAC1C,MAAM,OAAO,QAAQ,EAAE,IAAI,OAAO,WAAW,gBAAgB,SAAS,CAAC;AAGvE,KAAI,OAAO,YAAY,CAAC,KACtB,QACE,oBAAC;EACC,OAAO,EAAE,8BAA8B;EACvC,aAAa,EAAE,gDAAgD;YAE/D,oBAAC;GAAW,SAAQ;aAAa,EAAE,gDAAgD;IAAc;GACzF;AAId,KAAI,CAAC,KACH,QAAO;CAET,MAAM,CAAC,iBAAiB,sBAAsB,SAA4B,KAAK;CAC/E,MAAM,CAAC,WAAW,gBAAgB,SAAwB,KAAK;CAC/D,MAAM,CAAC,SAAS,cAAc,SAAiB,GAAG;CAClD,MAAM,CAAC,cAAc,mBAAmB,SAAS,MAAM;CACvD,MAAM,YAAY,KAAK;CAEvB,MAAM,CAAC,cAAc,aAAa,iBAAiB,YAAY;AAC7D,QAAM,KAAK,OAAO,EAChB,uBAAuB,iBACxB,CAAC;AACF,qBAAmB,KAAK;AACxB,eAAa,KAAK;AAClB,aAAW,GAAG;IACb,CAAC,iBAAiB,KAAK,CAAC;AAE3B,iBAAgB;AACd,kBAAgB,MAAM;AACtB,6BAA2B,YAAY;AACrC,OAAI,mBAAmB,WAAW,iBAAiB,IAAI,GAAG,QAAQ,CAChE,OAAM,cAAc;AAEtB,mBAAgB,KAAK;IACrB;IACD;EAAC;EAAS;EAAiB;EAAa,CAAC;AAE5C,QACE,oBAAC;EACC,OAAO,EAAE,8BAA8B;EACvC,aAAa,YACT,EAAE,oDAAoD,GACtD,EAAE,qDAAqD;YAE3D,qBAAC;GAAI,WAAU;cACZ,CAAC,aAAa,mBACb;IACE,oBAAC,wBAAY,EAAE,iDAAiD,GAAc;IAC9E,oBAAC;KAAI,OAAO;KAAK,QAAQ;KAAK,KAAK,aAAa,SAAS,kCAAkC;KAAE,KAAK,EAAE,2CAA2C;MAAI;IACnJ,oBAAC,wBAAY,EAAE,uCAAuC,GAAc;IACpE,oBAAC;KACC,OAAO;KACP,WAAW,MAAM;AACf,sBAAgB,MAAM;AACtB,iBAAW,EAAE,OAAO,MAAM;;KAE5B,aAAY;KACZ,WAAW;KACX,UAAU;MACV;IACD,gBAAgB,QAAQ,WAAW,KAClC,oBAAC;KAAW,SAAQ;eAAe,EAAE,oCAAoC;MAAc;IAEzF,oBAAC;KAAI,WAAU;eACb,oBAAC;MACC,SAAQ;MACR,eAAe;AACb,0BAAmB,KAAK;AACxB,oBAAa,KAAK;AAClB,kBAAW,GAAG;;gBAGf,EAAE,SAAS;OACL;MACL;OACL,EAEL,oBAAC;IAAI,WAAU;cACZ,YACC,oBAAC;KACC,SAAQ;KACR,SAAS,YAAY;AACnB,YAAM,KAAK,OAAO,EAChB,uBAAuB,MACxB,CAAC;;eAGH,EAAE,cAAc;MACV,GACP,CAAC,mBACH,oBAAC;KACC,SAAQ;KACR,SAAS,YAAY;MACnB,MAAM,SAAS,qBAAqB,IAAI,WAAW,GAAG,CAAC;AACvD,mBAAa,MAAM,mBAAmB,SAAS,MAAM,OAAO,CAAC;AAC7D,yBAAmB,OAAO;;eAG3B,EAAE,aAAa;MACT;KAEP;IACF;GACE;;AAKd,eAAe,mBAAmB,SAAkB,MAAmB,QAAoB;CACzF,MAAM,MAAM,iBAAiB,QAAQ,aAAa,KAAK,gBAAgB,KAAK,IAAI,QAAQ,IAAI,EAAE;AAC9F,QAAO,MAAM,OAAO,UAAU,IAAI"}
@@ -0,0 +1,9 @@
1
+ import * as react_jsx_runtime0 from "react/jsx-runtime";
2
+
3
+ //#region src/components-page/account-settings/email-and-auth/otp-section.d.ts
4
+ declare function OtpSection(props?: {
5
+ mockMode?: boolean;
6
+ }): react_jsx_runtime0.JSX.Element | null;
7
+ //#endregion
8
+ export { OtpSection };
9
+ //# sourceMappingURL=otp-section.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"otp-section.d.ts","names":[],"sources":["../../../../../src/components-page/account-settings/email-and-auth/otp-section.tsx"],"mappings":";;;iBAUgB,UAAA,CAAW,KAAA;EACzB,QAAA;AAAA,IACD,kBAAA,CAAA,GAAA,CAAA,OAAA"}
@@ -0,0 +1,78 @@
1
+ import { Button, Typography } from "@stackframe/stack-ui";
2
+ import { useState } from "react";
3
+ import { jsx, jsxs } from "react/jsx-runtime";
4
+ import { useStackApp, useUser } from "../../../lib/hooks.js";
5
+ import { useTranslation } from "../../../lib/translations.js";
6
+ import { Section } from "../section.js";
7
+
8
+ //#region src/components-page/account-settings/email-and-auth/otp-section.tsx
9
+ function OtpSection(props) {
10
+ const { t } = useTranslation();
11
+ const user = useUser({ or: props?.mockMode ? "return-null" : "throw" });
12
+ if (props?.mockMode && !user) return /* @__PURE__ */ jsx(Section, {
13
+ title: t("One-Time Password"),
14
+ description: t("OTP management is not available in demo mode."),
15
+ children: /* @__PURE__ */ jsx(Typography, {
16
+ variant: "secondary",
17
+ children: t("OTP management is not available in demo mode.")
18
+ })
19
+ });
20
+ if (!user) return null;
21
+ const project = useStackApp().useProject();
22
+ const contactChannels = user.useContactChannels();
23
+ const isLastAuth = user.otpAuthEnabled && !user.hasPassword && user.oauthProviders.length === 0 && !user.passkeyAuthEnabled;
24
+ const [disabling, setDisabling] = useState(false);
25
+ const hasValidEmail = contactChannels.filter((x) => x.type === "email" && x.isVerified && x.usedForAuth).length > 0;
26
+ if (!project.config.magicLinkEnabled) return null;
27
+ const handleDisableOTP = async () => {
28
+ await user.update({ otpAuthEnabled: false });
29
+ setDisabling(false);
30
+ };
31
+ return /* @__PURE__ */ jsx(Section, {
32
+ title: t("OTP sign-in"),
33
+ description: user.otpAuthEnabled ? t("OTP/magic link sign-in is currently enabled.") : t("Enable sign-in via magic link or OTP sent to your sign-in emails."),
34
+ children: /* @__PURE__ */ jsx("div", {
35
+ className: "flex md:justify-end",
36
+ children: hasValidEmail ? user.otpAuthEnabled ? !isLastAuth ? !disabling ? /* @__PURE__ */ jsx(Button, {
37
+ variant: "secondary",
38
+ onClick: () => setDisabling(true),
39
+ children: t("Disable OTP")
40
+ }) : /* @__PURE__ */ jsxs("div", {
41
+ className: "flex flex-col gap-2",
42
+ children: [/* @__PURE__ */ jsx(Typography, {
43
+ variant: "destructive",
44
+ children: t("Are you sure you want to disable OTP sign-in? You will not be able to sign in with only emails anymore.")
45
+ }), /* @__PURE__ */ jsxs("div", {
46
+ className: "flex gap-2",
47
+ children: [/* @__PURE__ */ jsx(Button, {
48
+ variant: "destructive",
49
+ onClick: handleDisableOTP,
50
+ children: t("Disable")
51
+ }), /* @__PURE__ */ jsx(Button, {
52
+ variant: "secondary",
53
+ onClick: () => setDisabling(false),
54
+ children: t("Cancel")
55
+ })]
56
+ })]
57
+ }) : /* @__PURE__ */ jsx(Typography, {
58
+ variant: "secondary",
59
+ type: "label",
60
+ children: t("OTP sign-in is enabled and cannot be disabled as it is currently the only sign-in method")
61
+ }) : /* @__PURE__ */ jsx(Button, {
62
+ variant: "secondary",
63
+ onClick: async () => {
64
+ await user.update({ otpAuthEnabled: true });
65
+ },
66
+ children: t("Enable OTP")
67
+ }) : /* @__PURE__ */ jsx(Typography, {
68
+ variant: "secondary",
69
+ type: "label",
70
+ children: t("To enable OTP sign-in, please add a verified sign-in email.")
71
+ })
72
+ })
73
+ });
74
+ }
75
+
76
+ //#endregion
77
+ export { OtpSection };
78
+ //# sourceMappingURL=otp-section.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"otp-section.js","names":[],"sources":["../../../../../src/components-page/account-settings/email-and-auth/otp-section.tsx"],"sourcesContent":["\n//===========================================\n// THIS FILE IS AUTO-GENERATED FROM TEMPLATE. DO NOT EDIT IT DIRECTLY, INSTEAD EDIT THE CORRESPONDING FILE IN packages/template\n//===========================================\nimport { Button, Typography } from \"@stackframe/stack-ui\";\nimport { useState } from \"react\";\nimport { useStackApp, useUser } from \"../../../lib/hooks\";\nimport { useTranslation } from \"../../../lib/translations\";\nimport { Section } from \"../section\";\n\nexport function OtpSection(props?: {\n mockMode?: boolean,\n}) {\n const { t } = useTranslation();\n const user = useUser({ or: props?.mockMode ? 'return-null' : \"throw\" });\n\n // In mock mode, show a placeholder message\n if (props?.mockMode && !user) {\n return (\n <Section\n title={t(\"One-Time Password\")}\n description={t(\"OTP management is not available in demo mode.\")}\n >\n <Typography variant='secondary'>{t(\"OTP management is not available in demo mode.\")}</Typography>\n </Section>\n );\n }\n\n if (!user) {\n return null; // This shouldn't happen in non-mock mode due to throw\n }\n const project = useStackApp().useProject();\n const contactChannels = user.useContactChannels();\n const isLastAuth = user.otpAuthEnabled && !user.hasPassword && user.oauthProviders.length === 0 && !user.passkeyAuthEnabled;\n const [disabling, setDisabling] = useState(false);\n\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n const hasValidEmail = contactChannels.filter(x => x.type === 'email' && x.isVerified && x.usedForAuth).length > 0;\n\n if (!project.config.magicLinkEnabled) {\n return null;\n }\n\n const handleDisableOTP = async () => {\n await user.update({ otpAuthEnabled: false });\n setDisabling(false);\n };\n\n return (\n <Section title={t(\"OTP sign-in\")} description={user.otpAuthEnabled ? t(\"OTP/magic link sign-in is currently enabled.\") : t(\"Enable sign-in via magic link or OTP sent to your sign-in emails.\")}>\n <div className='flex md:justify-end'>\n {hasValidEmail ? (\n user.otpAuthEnabled ? (\n !isLastAuth ? (\n !disabling ? (\n <Button\n variant='secondary'\n onClick={() => setDisabling(true)}\n >\n {t(\"Disable OTP\")}\n </Button>\n ) : (\n <div className='flex flex-col gap-2'>\n <Typography variant='destructive'>\n {t(\"Are you sure you want to disable OTP sign-in? You will not be able to sign in with only emails anymore.\")}\n </Typography>\n <div className='flex gap-2'>\n <Button\n variant='destructive'\n onClick={handleDisableOTP}\n >\n {t(\"Disable\")}\n </Button>\n <Button\n variant='secondary'\n onClick={() => setDisabling(false)}\n >\n {t(\"Cancel\")}\n </Button>\n </div>\n </div>\n )\n ) : (\n <Typography variant='secondary' type='label'>{t(\"OTP sign-in is enabled and cannot be disabled as it is currently the only sign-in method\")}</Typography>\n )\n ) : (\n <Button\n variant='secondary'\n onClick={async () => {\n await user.update({ otpAuthEnabled: true });\n }}\n >\n {t(\"Enable OTP\")}\n </Button>\n )\n ) : (\n <Typography variant='secondary' type='label'>{t(\"To enable OTP sign-in, please add a verified sign-in email.\")}</Typography>\n )}\n </div>\n </Section>\n );\n}\n"],"mappings":";;;;;;;;AAUA,SAAgB,WAAW,OAExB;CACD,MAAM,EAAE,MAAM,gBAAgB;CAC9B,MAAM,OAAO,QAAQ,EAAE,IAAI,OAAO,WAAW,gBAAgB,SAAS,CAAC;AAGvE,KAAI,OAAO,YAAY,CAAC,KACtB,QACE,oBAAC;EACC,OAAO,EAAE,oBAAoB;EAC7B,aAAa,EAAE,gDAAgD;YAE/D,oBAAC;GAAW,SAAQ;aAAa,EAAE,gDAAgD;IAAc;GACzF;AAId,KAAI,CAAC,KACH,QAAO;CAET,MAAM,UAAU,aAAa,CAAC,YAAY;CAC1C,MAAM,kBAAkB,KAAK,oBAAoB;CACjD,MAAM,aAAa,KAAK,kBAAkB,CAAC,KAAK,eAAe,KAAK,eAAe,WAAW,KAAK,CAAC,KAAK;CACzG,MAAM,CAAC,WAAW,gBAAgB,SAAS,MAAM;CAGjD,MAAM,gBAAgB,gBAAgB,QAAO,MAAK,EAAE,SAAS,WAAW,EAAE,cAAc,EAAE,YAAY,CAAC,SAAS;AAEhH,KAAI,CAAC,QAAQ,OAAO,iBAClB,QAAO;CAGT,MAAM,mBAAmB,YAAY;AACnC,QAAM,KAAK,OAAO,EAAE,gBAAgB,OAAO,CAAC;AAC5C,eAAa,MAAM;;AAGrB,QACE,oBAAC;EAAQ,OAAO,EAAE,cAAc;EAAE,aAAa,KAAK,iBAAiB,EAAE,+CAA+C,GAAG,EAAE,oEAAoE;YAC7L,oBAAC;GAAI,WAAU;aACZ,gBACC,KAAK,iBACH,CAAC,aACC,CAAC,YACC,oBAAC;IACC,SAAQ;IACR,eAAe,aAAa,KAAK;cAEhC,EAAE,cAAc;KACV,GAET,qBAAC;IAAI,WAAU;eACb,oBAAC;KAAW,SAAQ;eACjB,EAAE,0GAA0G;MAClG,EACb,qBAAC;KAAI,WAAU;gBACb,oBAAC;MACC,SAAQ;MACR,SAAS;gBAER,EAAE,UAAU;OACN,EACT,oBAAC;MACC,SAAQ;MACR,eAAe,aAAa,MAAM;gBAEjC,EAAE,SAAS;OACL;MACL;KACF,GAGR,oBAAC;IAAW,SAAQ;IAAY,MAAK;cAAS,EAAE,2FAA2F;KAAc,GAG3J,oBAAC;IACC,SAAQ;IACR,SAAS,YAAY;AACnB,WAAM,KAAK,OAAO,EAAE,gBAAgB,MAAM,CAAC;;cAG5C,EAAE,aAAa;KACT,GAGX,oBAAC;IAAW,SAAQ;IAAY,MAAK;cAAS,EAAE,8DAA8D;KAAc;IAE1H;GACE"}
@@ -0,0 +1,9 @@
1
+ import * as react_jsx_runtime0 from "react/jsx-runtime";
2
+
3
+ //#region src/components-page/account-settings/email-and-auth/passkey-section.d.ts
4
+ declare function PasskeySection(props?: {
5
+ mockMode?: boolean;
6
+ }): react_jsx_runtime0.JSX.Element | null;
7
+ //#endregion
8
+ export { PasskeySection };
9
+ //# sourceMappingURL=passkey-section.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"passkey-section.d.ts","names":[],"sources":["../../../../../src/components-page/account-settings/email-and-auth/passkey-section.tsx"],"mappings":";;;iBAWgB,cAAA,CAAe,KAAA;EAC7B,QAAA;AAAA,IACD,kBAAA,CAAA,GAAA,CAAA,OAAA"}
@@ -0,0 +1,87 @@
1
+ import { Button, Typography } from "@stackframe/stack-ui";
2
+ import { useState } from "react";
3
+ import { Fragment, jsx, jsxs } from "react/jsx-runtime";
4
+ import { useUser } from "../../../lib/hooks.js";
5
+ import { useTranslation } from "../../../lib/translations.js";
6
+ import { Section } from "../section.js";
7
+ import { useStackApp as useStackApp$1 } from "../../../index.js";
8
+
9
+ //#region src/components-page/account-settings/email-and-auth/passkey-section.tsx
10
+ function PasskeySection(props) {
11
+ const { t } = useTranslation();
12
+ const user = useUser({ or: props?.mockMode ? "return-null" : "throw" });
13
+ if (props?.mockMode && !user) return /* @__PURE__ */ jsx(Section, {
14
+ title: t("Passkey"),
15
+ description: t("Passkey management is not available in demo mode."),
16
+ children: /* @__PURE__ */ jsx(Typography, {
17
+ variant: "secondary",
18
+ children: t("Passkey management is not available in demo mode.")
19
+ })
20
+ });
21
+ if (!user) return null;
22
+ const project = useStackApp$1().useProject();
23
+ const contactChannels = user.useContactChannels();
24
+ const hasPasskey = user.passkeyAuthEnabled;
25
+ const isLastAuth = user.passkeyAuthEnabled && !user.hasPassword && user.oauthProviders.length === 0 && !user.otpAuthEnabled;
26
+ const [showConfirmationModal, setShowConfirmationModal] = useState(false);
27
+ const hasValidEmail = contactChannels.filter((x) => x.type === "email" && x.isVerified && x.usedForAuth).length > 0;
28
+ if (!project.config.passkeyEnabled) return null;
29
+ const handleDeletePasskey = async () => {
30
+ await user.update({ passkeyAuthEnabled: false });
31
+ setShowConfirmationModal(false);
32
+ };
33
+ const handleAddNewPasskey = async () => {
34
+ await user.registerPasskey();
35
+ };
36
+ return /* @__PURE__ */ jsx(Fragment, { children: /* @__PURE__ */ jsx(Section, {
37
+ title: t("Passkey"),
38
+ description: hasPasskey ? t("Passkey registered") : t("Register a passkey"),
39
+ children: /* @__PURE__ */ jsxs("div", {
40
+ className: "flex md:justify-end gap-2",
41
+ children: [
42
+ !hasValidEmail && /* @__PURE__ */ jsx(Typography, {
43
+ variant: "secondary",
44
+ type: "label",
45
+ children: t("To enable Passkey sign-in, please add a verified sign-in email.")
46
+ }),
47
+ hasValidEmail && hasPasskey && isLastAuth && /* @__PURE__ */ jsx(Typography, {
48
+ variant: "secondary",
49
+ type: "label",
50
+ children: t("Passkey sign-in is enabled and cannot be disabled as it is currently the only sign-in method")
51
+ }),
52
+ !hasPasskey && hasValidEmail && /* @__PURE__ */ jsx("div", { children: /* @__PURE__ */ jsx(Button, {
53
+ onClick: handleAddNewPasskey,
54
+ variant: "secondary",
55
+ children: t("Add new passkey")
56
+ }) }),
57
+ hasValidEmail && hasPasskey && !isLastAuth && !showConfirmationModal && /* @__PURE__ */ jsx(Button, {
58
+ variant: "secondary",
59
+ onClick: () => setShowConfirmationModal(true),
60
+ children: t("Delete Passkey")
61
+ }),
62
+ hasValidEmail && hasPasskey && !isLastAuth && showConfirmationModal && /* @__PURE__ */ jsxs("div", {
63
+ className: "flex flex-col gap-2",
64
+ children: [/* @__PURE__ */ jsx(Typography, {
65
+ variant: "destructive",
66
+ children: t("Are you sure you want to disable Passkey sign-in? You will not be able to sign in with your passkey anymore.")
67
+ }), /* @__PURE__ */ jsxs("div", {
68
+ className: "flex gap-2",
69
+ children: [/* @__PURE__ */ jsx(Button, {
70
+ variant: "destructive",
71
+ onClick: handleDeletePasskey,
72
+ children: t("Disable")
73
+ }), /* @__PURE__ */ jsx(Button, {
74
+ variant: "secondary",
75
+ onClick: () => setShowConfirmationModal(false),
76
+ children: t("Cancel")
77
+ })]
78
+ })]
79
+ })
80
+ ]
81
+ })
82
+ }) });
83
+ }
84
+
85
+ //#endregion
86
+ export { PasskeySection };
87
+ //# sourceMappingURL=passkey-section.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"passkey-section.js","names":["useStackApp"],"sources":["../../../../../src/components-page/account-settings/email-and-auth/passkey-section.tsx"],"sourcesContent":["\n//===========================================\n// THIS FILE IS AUTO-GENERATED FROM TEMPLATE. DO NOT EDIT IT DIRECTLY, INSTEAD EDIT THE CORRESPONDING FILE IN packages/template\n//===========================================\nimport { Button, Typography } from \"@stackframe/stack-ui\";\nimport { useState } from \"react\";\nimport { useStackApp } from \"../../..\";\nimport { useUser } from \"../../../lib/hooks\";\nimport { useTranslation } from \"../../../lib/translations\";\nimport { Section } from \"../section\";\n\nexport function PasskeySection(props?: {\n mockMode?: boolean,\n}) {\n const { t } = useTranslation();\n const user = useUser({ or: props?.mockMode ? 'return-null' : \"throw\" });\n\n // In mock mode, show a placeholder message\n if (props?.mockMode && !user) {\n return (\n <Section\n title={t(\"Passkey\")}\n description={t(\"Passkey management is not available in demo mode.\")}\n >\n <Typography variant='secondary'>{t(\"Passkey management is not available in demo mode.\")}</Typography>\n </Section>\n );\n }\n\n if (!user) {\n return null; // This shouldn't happen in non-mock mode due to throw\n }\n const stackApp = useStackApp();\n const project = stackApp.useProject();\n const contactChannels = user.useContactChannels();\n\n\n // passkey is enabled if there is a passkey\n const hasPasskey = user.passkeyAuthEnabled;\n\n const isLastAuth = user.passkeyAuthEnabled && !user.hasPassword && user.oauthProviders.length === 0 && !user.otpAuthEnabled;\n const [showConfirmationModal, setShowConfirmationModal] = useState(false);\n\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n const hasValidEmail = contactChannels.filter(x => x.type === 'email' && x.isVerified && x.usedForAuth).length > 0;\n\n if (!project.config.passkeyEnabled) {\n return null;\n }\n\n const handleDeletePasskey = async () => {\n await user.update({ passkeyAuthEnabled: false });\n setShowConfirmationModal(false);\n };\n\n\n const handleAddNewPasskey = async () => {\n await user.registerPasskey();\n };\n\n return (\n <>\n <Section title={t(\"Passkey\")} description={hasPasskey ? t(\"Passkey registered\") : t(\"Register a passkey\")}>\n <div className='flex md:justify-end gap-2'>\n {!hasValidEmail && (\n <Typography variant='secondary' type='label'>{t(\"To enable Passkey sign-in, please add a verified sign-in email.\")}</Typography>\n )}\n {hasValidEmail && hasPasskey && isLastAuth && (\n <Typography variant='secondary' type='label'>{t(\"Passkey sign-in is enabled and cannot be disabled as it is currently the only sign-in method\")}</Typography>\n )}\n {!hasPasskey && hasValidEmail && (\n <div>\n <Button onClick={handleAddNewPasskey} variant='secondary'>{t(\"Add new passkey\")}</Button>\n </div>\n )}\n {hasValidEmail && hasPasskey && !isLastAuth && !showConfirmationModal && (\n <Button\n variant='secondary'\n onClick={() => setShowConfirmationModal(true)}\n >\n {t(\"Delete Passkey\")}\n </Button>\n )}\n {hasValidEmail && hasPasskey && !isLastAuth && showConfirmationModal && (\n <div className='flex flex-col gap-2'>\n <Typography variant='destructive'>\n {t(\"Are you sure you want to disable Passkey sign-in? You will not be able to sign in with your passkey anymore.\")}\n </Typography>\n <div className='flex gap-2'>\n <Button\n variant='destructive'\n onClick={handleDeletePasskey}\n >\n {t(\"Disable\")}\n </Button>\n <Button\n variant='secondary'\n onClick={() => setShowConfirmationModal(false)}\n >\n {t(\"Cancel\")}\n </Button>\n </div>\n </div>\n )}\n </div>\n </Section>\n\n\n </>\n\n );\n}\n"],"mappings":";;;;;;;;;AAWA,SAAgB,eAAe,OAE5B;CACD,MAAM,EAAE,MAAM,gBAAgB;CAC9B,MAAM,OAAO,QAAQ,EAAE,IAAI,OAAO,WAAW,gBAAgB,SAAS,CAAC;AAGvE,KAAI,OAAO,YAAY,CAAC,KACtB,QACE,oBAAC;EACC,OAAO,EAAE,UAAU;EACnB,aAAa,EAAE,oDAAoD;YAEnE,oBAAC;GAAW,SAAQ;aAAa,EAAE,oDAAoD;IAAc;GAC7F;AAId,KAAI,CAAC,KACH,QAAO;CAGT,MAAM,UADWA,eAAa,CACL,YAAY;CACrC,MAAM,kBAAkB,KAAK,oBAAoB;CAIjD,MAAM,aAAa,KAAK;CAExB,MAAM,aAAa,KAAK,sBAAsB,CAAC,KAAK,eAAe,KAAK,eAAe,WAAW,KAAK,CAAC,KAAK;CAC7G,MAAM,CAAC,uBAAuB,4BAA4B,SAAS,MAAM;CAGzE,MAAM,gBAAgB,gBAAgB,QAAO,MAAK,EAAE,SAAS,WAAW,EAAE,cAAc,EAAE,YAAY,CAAC,SAAS;AAEhH,KAAI,CAAC,QAAQ,OAAO,eAClB,QAAO;CAGT,MAAM,sBAAsB,YAAY;AACtC,QAAM,KAAK,OAAO,EAAE,oBAAoB,OAAO,CAAC;AAChD,2BAAyB,MAAM;;CAIjC,MAAM,sBAAsB,YAAY;AACtC,QAAM,KAAK,iBAAiB;;AAG9B,QACE,0CACE,oBAAC;EAAQ,OAAO,EAAE,UAAU;EAAE,aAAa,aAAa,EAAE,qBAAqB,GAAG,EAAE,qBAAqB;YACvG,qBAAC;GAAI,WAAU;;IACZ,CAAC,iBACA,oBAAC;KAAW,SAAQ;KAAY,MAAK;eAAS,EAAE,kEAAkE;MAAc;IAEjI,iBAAiB,cAAc,cAC9B,oBAAC;KAAW,SAAQ;KAAY,MAAK;eAAS,EAAE,+FAA+F;MAAc;IAE9J,CAAC,cAAc,iBACd,oBAAC,mBACC,oBAAC;KAAO,SAAS;KAAqB,SAAQ;eAAa,EAAE,kBAAkB;MAAU,GACrF;IAEP,iBAAiB,cAAc,CAAC,cAAc,CAAC,yBAC9C,oBAAC;KACC,SAAQ;KACR,eAAe,yBAAyB,KAAK;eAE5C,EAAE,iBAAiB;MACb;IAEV,iBAAiB,cAAc,CAAC,cAAc,yBAC7C,qBAAC;KAAI,WAAU;gBACb,oBAAC;MAAW,SAAQ;gBACjB,EAAE,+GAA+G;OACvG,EACb,qBAAC;MAAI,WAAU;iBACb,oBAAC;OACC,SAAQ;OACR,SAAS;iBAER,EAAE,UAAU;QACN,EACT,oBAAC;OACC,SAAQ;OACR,eAAe,yBAAyB,MAAM;iBAE7C,EAAE,SAAS;QACL;OACL;MACF;;IAEJ;GACE,GAGT"}