@stackframe/stack 2.8.11 → 2.8.16

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 (248) hide show
  1. package/CHANGELOG.md +48 -0
  2. package/dist/components/api-key-dialogs.js +5 -4
  3. package/dist/components/api-key-dialogs.js.map +1 -1
  4. package/dist/components/credential-sign-in.js +4 -4
  5. package/dist/components/credential-sign-up.js +3 -3
  6. package/dist/components/elements/maybe-full-page.js +1 -1
  7. package/dist/components/elements/sidebar-layout.js +1 -1
  8. package/dist/components/magic-link-sign-in.js +6 -6
  9. package/dist/components/magic-link-sign-in.js.map +1 -1
  10. package/dist/components/message-cards/known-error-message-card.js +2 -2
  11. package/dist/components/message-cards/message-card.js +1 -1
  12. package/dist/components/message-cards/predefined-message-card.js +3 -3
  13. package/dist/components/oauth-button-group.js +2 -2
  14. package/dist/components/oauth-button.js +27 -16
  15. package/dist/components/oauth-button.js.map +1 -1
  16. package/dist/components/passkey-button.js +2 -2
  17. package/dist/components/profile-image-editor.js +87 -34
  18. package/dist/components/profile-image-editor.js.map +1 -1
  19. package/dist/components/selected-team-switcher.js +41 -9
  20. package/dist/components/selected-team-switcher.js.map +1 -1
  21. package/dist/components/{iframe-preventer.js → use-in-iframe.js} +9 -19
  22. package/dist/components/use-in-iframe.js.map +1 -0
  23. package/dist/components/user-button.js +41 -8
  24. package/dist/components/user-button.js.map +1 -1
  25. package/dist/components-page/account-settings/active-sessions/active-sessions-page.js +57 -12
  26. package/dist/components-page/account-settings/active-sessions/active-sessions-page.js.map +1 -1
  27. package/dist/components-page/account-settings/api-keys/api-keys-page.js +100 -12
  28. package/dist/components-page/account-settings/api-keys/api-keys-page.js.map +1 -1
  29. package/dist/components-page/account-settings/editable-text.js +1 -1
  30. package/dist/components-page/account-settings/email-and-auth/email-and-auth-page.js +12 -12
  31. package/dist/components-page/account-settings/email-and-auth/email-and-auth-page.js.map +1 -1
  32. package/dist/components-page/account-settings/email-and-auth/emails-section.js +15 -6
  33. package/dist/components-page/account-settings/email-and-auth/emails-section.js.map +1 -1
  34. package/dist/components-page/account-settings/email-and-auth/mfa-section.js +18 -5
  35. package/dist/components-page/account-settings/email-and-auth/mfa-section.js.map +1 -1
  36. package/dist/components-page/account-settings/email-and-auth/otp-section.js +18 -5
  37. package/dist/components-page/account-settings/email-and-auth/otp-section.js.map +1 -1
  38. package/dist/components-page/account-settings/email-and-auth/passkey-section.js +19 -6
  39. package/dist/components-page/account-settings/email-and-auth/passkey-section.js.map +1 -1
  40. package/dist/components-page/account-settings/email-and-auth/password-section.js +20 -7
  41. package/dist/components-page/account-settings/email-and-auth/password-section.js.map +1 -1
  42. package/dist/components-page/account-settings/profile-page/profile-page.js +18 -8
  43. package/dist/components-page/account-settings/profile-page/profile-page.js.map +1 -1
  44. package/dist/components-page/account-settings/settings/delete-account-section.js +19 -10
  45. package/dist/components-page/account-settings/settings/delete-account-section.js.map +1 -1
  46. package/dist/components-page/account-settings/settings/settings-page.js +6 -6
  47. package/dist/components-page/account-settings/settings/settings-page.js.map +1 -1
  48. package/dist/components-page/account-settings/settings/sign-out-section.js +15 -6
  49. package/dist/components-page/account-settings/settings/sign-out-section.js.map +1 -1
  50. package/dist/components-page/account-settings/teams/leave-team-section.js +3 -3
  51. package/dist/components-page/account-settings/teams/team-api-keys-section.js +9 -6
  52. package/dist/components-page/account-settings/teams/team-api-keys-section.js.map +1 -1
  53. package/dist/components-page/account-settings/teams/team-creation-page.js +19 -10
  54. package/dist/components-page/account-settings/teams/team-creation-page.js.map +1 -1
  55. package/dist/components-page/account-settings/teams/team-display-name-section.js +4 -4
  56. package/dist/components-page/account-settings/teams/team-member-invitation-section.js +4 -4
  57. package/dist/components-page/account-settings/teams/team-member-list-section.js +7 -4
  58. package/dist/components-page/account-settings/teams/team-member-list-section.js.map +1 -1
  59. package/dist/components-page/account-settings/teams/team-page.js +8 -8
  60. package/dist/components-page/account-settings/teams/team-profile-image-section.js +4 -4
  61. package/dist/components-page/account-settings/teams/team-profile-user-section.js +4 -4
  62. package/dist/components-page/account-settings.js +29 -21
  63. package/dist/components-page/account-settings.js.map +1 -1
  64. package/dist/components-page/auth-page.js +16 -17
  65. package/dist/components-page/auth-page.js.map +1 -1
  66. package/dist/components-page/cli-auth-confirm.js +3 -3
  67. package/dist/components-page/email-verification.js +6 -6
  68. package/dist/components-page/email-verification.js.map +1 -1
  69. package/dist/components-page/error-page.js +9 -9
  70. package/dist/components-page/error-page.js.map +1 -1
  71. package/dist/components-page/forgot-password.js +6 -6
  72. package/dist/components-page/magic-link-callback.js +7 -7
  73. package/dist/components-page/magic-link-callback.js.map +1 -1
  74. package/dist/components-page/mfa.js +190 -0
  75. package/dist/components-page/mfa.js.map +1 -0
  76. package/dist/components-page/oauth-callback.js +4 -4
  77. package/dist/components-page/password-reset.js +9 -9
  78. package/dist/components-page/password-reset.js.map +1 -1
  79. package/dist/components-page/sign-in.js +3 -2
  80. package/dist/components-page/sign-in.js.map +1 -1
  81. package/dist/components-page/sign-out.js +2 -2
  82. package/dist/components-page/sign-up.js +1 -1
  83. package/dist/components-page/stack-handler.js +25 -14
  84. package/dist/components-page/stack-handler.js.map +1 -1
  85. package/dist/components-page/team-creation.js +4 -4
  86. package/dist/components-page/team-invitation.js +6 -6
  87. package/dist/components-page/team-invitation.js.map +1 -1
  88. package/dist/esm/components/api-key-dialogs.js +5 -4
  89. package/dist/esm/components/api-key-dialogs.js.map +1 -1
  90. package/dist/esm/components/credential-sign-in.js +4 -4
  91. package/dist/esm/components/credential-sign-up.js +3 -3
  92. package/dist/esm/components/elements/maybe-full-page.js +1 -1
  93. package/dist/esm/components/elements/sidebar-layout.js +1 -1
  94. package/dist/esm/components/magic-link-sign-in.js +6 -6
  95. package/dist/esm/components/magic-link-sign-in.js.map +1 -1
  96. package/dist/esm/components/message-cards/known-error-message-card.js +2 -2
  97. package/dist/esm/components/message-cards/message-card.js +1 -1
  98. package/dist/esm/components/message-cards/predefined-message-card.js +3 -3
  99. package/dist/esm/components/oauth-button-group.js +2 -2
  100. package/dist/esm/components/oauth-button.js +28 -17
  101. package/dist/esm/components/oauth-button.js.map +1 -1
  102. package/dist/esm/components/passkey-button.js +2 -2
  103. package/dist/esm/components/profile-image-editor.js +86 -34
  104. package/dist/esm/components/profile-image-editor.js.map +1 -1
  105. package/dist/esm/components/selected-team-switcher.js +41 -9
  106. package/dist/esm/components/selected-team-switcher.js.map +1 -1
  107. package/dist/esm/components/use-in-iframe.js +18 -0
  108. package/dist/esm/components/use-in-iframe.js.map +1 -0
  109. package/dist/esm/components/user-button.js +41 -8
  110. package/dist/esm/components/user-button.js.map +1 -1
  111. package/dist/esm/components-page/account-settings/active-sessions/active-sessions-page.js +57 -12
  112. package/dist/esm/components-page/account-settings/active-sessions/active-sessions-page.js.map +1 -1
  113. package/dist/esm/components-page/account-settings/api-keys/api-keys-page.js +100 -12
  114. package/dist/esm/components-page/account-settings/api-keys/api-keys-page.js.map +1 -1
  115. package/dist/esm/components-page/account-settings/editable-text.js +1 -1
  116. package/dist/esm/components-page/account-settings/email-and-auth/email-and-auth-page.js +12 -12
  117. package/dist/esm/components-page/account-settings/email-and-auth/email-and-auth-page.js.map +1 -1
  118. package/dist/esm/components-page/account-settings/email-and-auth/emails-section.js +15 -6
  119. package/dist/esm/components-page/account-settings/email-and-auth/emails-section.js.map +1 -1
  120. package/dist/esm/components-page/account-settings/email-and-auth/mfa-section.js +18 -5
  121. package/dist/esm/components-page/account-settings/email-and-auth/mfa-section.js.map +1 -1
  122. package/dist/esm/components-page/account-settings/email-and-auth/otp-section.js +18 -5
  123. package/dist/esm/components-page/account-settings/email-and-auth/otp-section.js.map +1 -1
  124. package/dist/esm/components-page/account-settings/email-and-auth/passkey-section.js +19 -6
  125. package/dist/esm/components-page/account-settings/email-and-auth/passkey-section.js.map +1 -1
  126. package/dist/esm/components-page/account-settings/email-and-auth/password-section.js +20 -7
  127. package/dist/esm/components-page/account-settings/email-and-auth/password-section.js.map +1 -1
  128. package/dist/esm/components-page/account-settings/profile-page/profile-page.js +18 -8
  129. package/dist/esm/components-page/account-settings/profile-page/profile-page.js.map +1 -1
  130. package/dist/esm/components-page/account-settings/settings/delete-account-section.js +19 -10
  131. package/dist/esm/components-page/account-settings/settings/delete-account-section.js.map +1 -1
  132. package/dist/esm/components-page/account-settings/settings/settings-page.js +6 -6
  133. package/dist/esm/components-page/account-settings/settings/settings-page.js.map +1 -1
  134. package/dist/esm/components-page/account-settings/settings/sign-out-section.js +15 -6
  135. package/dist/esm/components-page/account-settings/settings/sign-out-section.js.map +1 -1
  136. package/dist/esm/components-page/account-settings/teams/leave-team-section.js +3 -3
  137. package/dist/esm/components-page/account-settings/teams/team-api-keys-section.js +9 -6
  138. package/dist/esm/components-page/account-settings/teams/team-api-keys-section.js.map +1 -1
  139. package/dist/esm/components-page/account-settings/teams/team-creation-page.js +19 -10
  140. package/dist/esm/components-page/account-settings/teams/team-creation-page.js.map +1 -1
  141. package/dist/esm/components-page/account-settings/teams/team-display-name-section.js +4 -4
  142. package/dist/esm/components-page/account-settings/teams/team-member-invitation-section.js +4 -4
  143. package/dist/esm/components-page/account-settings/teams/team-member-list-section.js +7 -4
  144. package/dist/esm/components-page/account-settings/teams/team-member-list-section.js.map +1 -1
  145. package/dist/esm/components-page/account-settings/teams/team-page.js +8 -8
  146. package/dist/esm/components-page/account-settings/teams/team-profile-image-section.js +4 -4
  147. package/dist/esm/components-page/account-settings/teams/team-profile-user-section.js +4 -4
  148. package/dist/esm/components-page/account-settings.js +29 -21
  149. package/dist/esm/components-page/account-settings.js.map +1 -1
  150. package/dist/esm/components-page/auth-page.js +16 -17
  151. package/dist/esm/components-page/auth-page.js.map +1 -1
  152. package/dist/esm/components-page/cli-auth-confirm.js +3 -3
  153. package/dist/esm/components-page/email-verification.js +6 -6
  154. package/dist/esm/components-page/email-verification.js.map +1 -1
  155. package/dist/esm/components-page/error-page.js +9 -9
  156. package/dist/esm/components-page/error-page.js.map +1 -1
  157. package/dist/esm/components-page/forgot-password.js +6 -6
  158. package/dist/esm/components-page/magic-link-callback.js +7 -7
  159. package/dist/esm/components-page/magic-link-callback.js.map +1 -1
  160. package/dist/esm/components-page/mfa.js +174 -0
  161. package/dist/esm/components-page/mfa.js.map +1 -0
  162. package/dist/esm/components-page/oauth-callback.js +4 -4
  163. package/dist/esm/components-page/password-reset.js +9 -9
  164. package/dist/esm/components-page/password-reset.js.map +1 -1
  165. package/dist/esm/components-page/sign-in.js +3 -2
  166. package/dist/esm/components-page/sign-in.js.map +1 -1
  167. package/dist/esm/components-page/sign-out.js +2 -2
  168. package/dist/esm/components-page/sign-up.js +1 -1
  169. package/dist/esm/components-page/stack-handler.js +25 -14
  170. package/dist/esm/components-page/stack-handler.js.map +1 -1
  171. package/dist/esm/components-page/team-creation.js +4 -4
  172. package/dist/esm/components-page/team-invitation.js +6 -6
  173. package/dist/esm/components-page/team-invitation.js.map +1 -1
  174. package/dist/esm/generated/global-css.js +1 -1
  175. package/dist/esm/generated/global-css.js.map +1 -1
  176. package/dist/esm/generated/quetzal-translations.js +3574 -2364
  177. package/dist/esm/generated/quetzal-translations.js.map +1 -1
  178. package/dist/esm/index.js +22 -22
  179. package/dist/esm/lib/auth.js +3 -3
  180. package/dist/esm/lib/auth.js.map +1 -1
  181. package/dist/esm/lib/cookie.js +1 -129
  182. package/dist/esm/lib/cookie.js.map +1 -1
  183. package/dist/esm/lib/hooks.js +1 -1
  184. package/dist/esm/lib/stack-app/apps/implementations/admin-app-impl.js +8 -8
  185. package/dist/esm/lib/stack-app/apps/implementations/admin-app-impl.js.map +1 -1
  186. package/dist/esm/lib/stack-app/apps/implementations/client-app-impl.js +57 -26
  187. package/dist/esm/lib/stack-app/apps/implementations/client-app-impl.js.map +1 -1
  188. package/dist/esm/lib/stack-app/apps/implementations/common.js +2 -1
  189. package/dist/esm/lib/stack-app/apps/implementations/common.js.map +1 -1
  190. package/dist/esm/lib/stack-app/apps/implementations/index.js +3 -3
  191. package/dist/esm/lib/stack-app/apps/implementations/server-app-impl.js +35 -17
  192. package/dist/esm/lib/stack-app/apps/implementations/server-app-impl.js.map +1 -1
  193. package/dist/esm/lib/stack-app/apps/index.js +3 -3
  194. package/dist/esm/lib/stack-app/apps/interfaces/admin-app.js +1 -1
  195. package/dist/esm/lib/stack-app/apps/interfaces/client-app.js +1 -1
  196. package/dist/esm/lib/stack-app/apps/interfaces/client-app.js.map +1 -1
  197. package/dist/esm/lib/stack-app/apps/interfaces/server-app.js +1 -1
  198. package/dist/esm/lib/stack-app/common.js.map +1 -1
  199. package/dist/esm/lib/stack-app/index.js +2 -2
  200. package/dist/esm/lib/stack-app/internal-api-keys/index.js.map +1 -1
  201. package/dist/esm/lib/stack-app/users/index.js.map +1 -1
  202. package/dist/esm/lib/translations.js +1 -1
  203. package/dist/esm/providers/stack-provider-client.js +2 -2
  204. package/dist/esm/providers/stack-provider.js +3 -3
  205. package/dist/esm/providers/theme-provider.js +3 -3
  206. package/dist/esm/providers/translation-provider.js +2 -2
  207. package/dist/esm/utils/browser-script.js +1 -1
  208. package/dist/generated/global-css.js +1 -1
  209. package/dist/generated/global-css.js.map +1 -1
  210. package/dist/generated/quetzal-translations.js +3574 -2364
  211. package/dist/generated/quetzal-translations.js.map +1 -1
  212. package/dist/index.d.mts +73 -2
  213. package/dist/index.d.ts +73 -2
  214. package/dist/index.js +23 -23
  215. package/dist/index.js.map +1 -1
  216. package/dist/lib/auth.js +3 -3
  217. package/dist/lib/auth.js.map +1 -1
  218. package/dist/lib/cookie.js +4 -132
  219. package/dist/lib/cookie.js.map +1 -1
  220. package/dist/lib/hooks.js +1 -1
  221. package/dist/lib/stack-app/apps/implementations/admin-app-impl.js +8 -8
  222. package/dist/lib/stack-app/apps/implementations/admin-app-impl.js.map +1 -1
  223. package/dist/lib/stack-app/apps/implementations/client-app-impl.js +57 -26
  224. package/dist/lib/stack-app/apps/implementations/client-app-impl.js.map +1 -1
  225. package/dist/lib/stack-app/apps/implementations/common.js +2 -1
  226. package/dist/lib/stack-app/apps/implementations/common.js.map +1 -1
  227. package/dist/lib/stack-app/apps/implementations/index.js +3 -3
  228. package/dist/lib/stack-app/apps/implementations/server-app-impl.js +35 -17
  229. package/dist/lib/stack-app/apps/implementations/server-app-impl.js.map +1 -1
  230. package/dist/lib/stack-app/apps/index.js +3 -3
  231. package/dist/lib/stack-app/apps/interfaces/admin-app.js +1 -1
  232. package/dist/lib/stack-app/apps/interfaces/client-app.js +1 -1
  233. package/dist/lib/stack-app/apps/interfaces/client-app.js.map +1 -1
  234. package/dist/lib/stack-app/apps/interfaces/server-app.js +1 -1
  235. package/dist/lib/stack-app/common.js.map +1 -1
  236. package/dist/lib/stack-app/index.js +2 -2
  237. package/dist/lib/stack-app/internal-api-keys/index.js.map +1 -1
  238. package/dist/lib/stack-app/users/index.js.map +1 -1
  239. package/dist/lib/translations.js +1 -1
  240. package/dist/providers/stack-provider-client.js +2 -2
  241. package/dist/providers/stack-provider.js +3 -3
  242. package/dist/providers/theme-provider.js +3 -3
  243. package/dist/providers/translation-provider.js +2 -2
  244. package/dist/utils/browser-script.js +1 -1
  245. package/package.json +5 -5
  246. package/dist/components/iframe-preventer.js.map +0 -1
  247. package/dist/esm/components/iframe-preventer.js +0 -28
  248. package/dist/esm/components/iframe-preventer.js.map +0 -1
package/CHANGELOG.md CHANGED
@@ -1,5 +1,53 @@
1
1
  # @stackframe/stack
2
2
 
3
+ ## 2.8.16
4
+
5
+ ### Patch Changes
6
+
7
+ - Various changes
8
+ - Updated dependencies
9
+ - @stackframe/stack-shared@2.8.16
10
+ - @stackframe/stack-ui@2.8.16
11
+ - @stackframe/stack-sc@2.8.16
12
+
13
+ ## 2.8.15
14
+
15
+ ### Patch Changes
16
+
17
+ - @stackframe/stack-sc@2.8.15
18
+ - @stackframe/stack-shared@2.8.15
19
+ - @stackframe/stack-ui@2.8.15
20
+
21
+ ## 2.8.14
22
+
23
+ ### Patch Changes
24
+
25
+ - Various changes
26
+ - Updated dependencies
27
+ - @stackframe/stack-shared@2.8.14
28
+ - @stackframe/stack-ui@2.8.14
29
+ - @stackframe/stack-sc@2.8.14
30
+
31
+ ## 2.8.13
32
+
33
+ ### Patch Changes
34
+
35
+ - Various changes
36
+ - Updated dependencies
37
+ - @stackframe/stack-shared@2.8.13
38
+ - @stackframe/stack-sc@2.8.13
39
+ - @stackframe/stack-ui@2.8.13
40
+
41
+ ## 2.8.12
42
+
43
+ ### Patch Changes
44
+
45
+ - Various changes
46
+ - Updated dependencies
47
+ - @stackframe/stack-shared@2.8.12
48
+ - @stackframe/stack-ui@2.8.12
49
+ - @stackframe/stack-sc@2.8.12
50
+
3
51
  ## 2.8.11
4
52
 
5
53
  ### Patch Changes
@@ -35,9 +35,9 @@ var import_promises = require("@stackframe/stack-shared/dist/utils/promises");
35
35
  var import_stack_ui = require("@stackframe/stack-ui");
36
36
  var import_react = require("react");
37
37
  var import_react_hook_form = require("react-hook-form");
38
- var import__ = require("..");
39
- var import_form_warning = require("../components/elements/form-warning");
40
- var import_translations = require("../lib/translations");
38
+ var import__ = require("../index.js");
39
+ var import_form_warning = require("../components/elements/form-warning.js");
40
+ var import_translations = require("../lib/translations.js");
41
41
  var import_jsx_runtime = require("react/jsx-runtime");
42
42
  var neverInMs = 1e3 * 60 * 60 * 24 * 365 * 200;
43
43
  var expiresInOptions = {
@@ -50,7 +50,7 @@ var expiresInOptions = {
50
50
  };
51
51
  function CreateApiKeyDialog(props) {
52
52
  const { t } = (0, import_translations.useTranslation)();
53
- const user = (0, import__.useUser)({ or: "redirect" });
53
+ const user = (0, import__.useUser)({ or: props.mockMode ? "return-null" : "redirect" });
54
54
  const [loading, setLoading] = (0, import_react.useState)(false);
55
55
  const apiKeySchema = (0, import_schema_fields.yupObject)({
56
56
  description: (0, import_schema_fields.yupString)().defined().nonEmpty(t("Description is required")),
@@ -165,6 +165,7 @@ function ShowApiKeyDialog(props) {
165
165
  /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
166
166
  import_stack_ui.CopyField,
167
167
  {
168
+ type: "input",
168
169
  monospace: true,
169
170
  value: props.apiKey?.value ?? "",
170
171
  label: t("Secret API Key")
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/components/api-key-dialogs.tsx"],"sourcesContent":["'use client';\n\n\n//===========================================\n// THIS FILE IS AUTO-GENERATED FROM TEMPLATE. DO NOT EDIT IT DIRECTLY\n//===========================================\n\nimport { yupResolver } from \"@hookform/resolvers/yup\";\nimport { yupObject, yupString } from '@stackframe/stack-shared/dist/schema-fields';\nimport { captureError } from '@stackframe/stack-shared/dist/utils/errors';\nimport { runAsynchronously } from '@stackframe/stack-shared/dist/utils/promises';\nimport { ActionDialog, Button, CopyField, Input, Label, Typography } from '@stackframe/stack-ui';\nimport { useState } from \"react\";\nimport { useForm } from 'react-hook-form';\nimport * as yup from \"yup\";\nimport { useUser } from '..';\nimport { FormWarningText } from '../components/elements/form-warning';\nimport { ApiKey, ApiKeyCreationOptions, ApiKeyType } from \"../lib/stack-app/api-keys\";\nimport { useTranslation } from \"../lib/translations\";\n\n// Constants for expiration options\nexport const neverInMs = 1000 * 60 * 60 * 24 * 365 * 200;\nexport const expiresInOptions = {\n [1000 * 60 * 60 * 24 * 1]: \"1 day\",\n [1000 * 60 * 60 * 24 * 7]: \"7 days\",\n [1000 * 60 * 60 * 24 * 30]: \"30 days\",\n [1000 * 60 * 60 * 24 * 90]: \"90 days\",\n [1000 * 60 * 60 * 24 * 365]: \"1 year\",\n [neverInMs]: \"Never\",\n} as const;\n\n/**\n * Dialog for creating a new API key\n */\nexport function CreateApiKeyDialog<Type extends ApiKeyType = ApiKeyType>(props: {\n open: boolean,\n onOpenChange: (open: boolean) => void,\n onKeyCreated?: (key: ApiKey<Type, true>) => void,\n createApiKey: (data: ApiKeyCreationOptions<Type>) => Promise<ApiKey<Type, true>>,\n}) {\n const { t } = useTranslation();\n const user = useUser({ or: 'redirect' });\n const [loading, setLoading] = useState(false);\n\n const apiKeySchema = yupObject({\n description: yupString().defined().nonEmpty(t('Description is required')),\n expiresIn: yupString().defined(),\n });\n\n const { register, handleSubmit, formState: { errors }, reset } = useForm({\n resolver: yupResolver(apiKeySchema),\n defaultValues: {\n description: '',\n expiresIn: Object.keys(expiresInOptions)[2], // Default to 30 days\n }\n });\n\n const onSubmit = async (data: yup.InferType<typeof apiKeySchema>) => {\n setLoading(true);\n try {\n const expiresAt = new Date(Date.now() + parseInt(data.expiresIn));\n const apiKey = await props.createApiKey({\n description: data.description,\n expiresAt,\n });\n\n if (props.onKeyCreated) {\n props.onKeyCreated(apiKey);\n }\n\n reset();\n props.onOpenChange(false);\n } catch (error) {\n captureError(\"Failed to create API key\", { error });\n } finally {\n setLoading(false);\n }\n };\n\n return (\n <ActionDialog\n open={props.open}\n onOpenChange={props.onOpenChange}\n title={t('Create API Key')}\n description={t('API keys grant programmatic access to your account.')}\n >\n <form\n onSubmit={(e) => {\n e.preventDefault();\n runAsynchronously(handleSubmit(onSubmit));\n }}\n className=\"space-y-4\"\n >\n <div className=\"space-y-2\">\n <Label htmlFor=\"description\">{t('Description')}</Label>\n <Input\n id=\"description\"\n placeholder={t('e.g. Development, Production, CI/CD')}\n {...register('description')}\n />\n {errors.description && <FormWarningText text={errors.description.message} />}\n </div>\n\n <div className=\"space-y-2\">\n <Label htmlFor=\"expiresIn\">{t('Expires In')}</Label>\n <select\n id=\"expiresIn\"\n className=\"w-full p-2 border border-input rounded-md bg-background\"\n {...register('expiresIn')}\n >\n {Object.entries(expiresInOptions).map(([value, label]) => (\n <option key={value} value={value}>{t(label)}</option>\n ))}\n </select>\n {errors.expiresIn && <FormWarningText text={errors.expiresIn.message} />}\n </div>\n\n <div className=\"flex justify-end gap-2 pt-4\">\n <Button\n type=\"button\"\n variant=\"secondary\"\n onClick={() => {\n reset();\n props.onOpenChange(false);\n }}\n >\n {t('Cancel')}\n </Button>\n <Button type=\"submit\" loading={loading}>\n {t('Create')}\n </Button>\n </div>\n </form>\n </ActionDialog>\n );\n}\n\n/**\n * Dialog for showing the newly created API key\n */\nexport function ShowApiKeyDialog<Type extends ApiKeyType = ApiKeyType>(props: {\n apiKey: ApiKey<Type, true> | null,\n onClose?: () => void,\n}) {\n const { t } = useTranslation();\n\n return (\n <ActionDialog\n open={!!props.apiKey}\n title={t(\"API Key\")}\n okButton={{ label: t(\"Close\") }}\n onClose={props.onClose}\n preventClose\n confirmText={t(\"I understand that I will not be able to view this key again.\")}\n >\n <div className=\"flex flex-col gap-4\">\n <Typography>\n {t(\"Here is your API key.\")}{\" \"}\n <span className=\"font-bold\">\n {t(\"Copy it to a safe place. You will not be able to view it again.\")}\n </span>\n </Typography>\n <CopyField\n monospace\n value={props.apiKey?.value ?? ''}\n label={t(\"Secret API Key\")}\n />\n </div>\n </ActionDialog>\n );\n}\n"],"mappings":"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","names":[]}
1
+ {"version":3,"sources":["../../src/components/api-key-dialogs.tsx"],"sourcesContent":["'use client';\n\n\n//===========================================\n// THIS FILE IS AUTO-GENERATED FROM TEMPLATE. DO NOT EDIT IT DIRECTLY\n//===========================================\n\nimport { yupResolver } from \"@hookform/resolvers/yup\";\nimport { yupObject, yupString } from '@stackframe/stack-shared/dist/schema-fields';\nimport { captureError } from '@stackframe/stack-shared/dist/utils/errors';\nimport { runAsynchronously } from '@stackframe/stack-shared/dist/utils/promises';\nimport { ActionDialog, Button, CopyField, Input, Label, Typography } from '@stackframe/stack-ui';\nimport { useState } from \"react\";\nimport { useForm } from 'react-hook-form';\nimport * as yup from \"yup\";\nimport { useUser } from '..';\nimport { FormWarningText } from '../components/elements/form-warning';\nimport { ApiKey, ApiKeyCreationOptions, ApiKeyType } from \"../lib/stack-app/api-keys\";\nimport { useTranslation } from \"../lib/translations\";\n\n// Constants for expiration options\nexport const neverInMs = 1000 * 60 * 60 * 24 * 365 * 200;\nexport const expiresInOptions = {\n [1000 * 60 * 60 * 24 * 1]: \"1 day\",\n [1000 * 60 * 60 * 24 * 7]: \"7 days\",\n [1000 * 60 * 60 * 24 * 30]: \"30 days\",\n [1000 * 60 * 60 * 24 * 90]: \"90 days\",\n [1000 * 60 * 60 * 24 * 365]: \"1 year\",\n [neverInMs]: \"Never\",\n} as const;\n\n/**\n * Dialog for creating a new API key\n */\nexport function CreateApiKeyDialog<Type extends ApiKeyType = ApiKeyType>(props: {\n open: boolean,\n onOpenChange: (open: boolean) => void,\n onKeyCreated?: (key: ApiKey<Type, true>) => void,\n createApiKey: (data: ApiKeyCreationOptions<Type>) => Promise<ApiKey<Type, true>>,\n mockMode?: boolean,\n}) {\n const { t } = useTranslation();\n const user = useUser({ or: props.mockMode ? 'return-null' : 'redirect' });\n const [loading, setLoading] = useState(false);\n\n const apiKeySchema = yupObject({\n description: yupString().defined().nonEmpty(t('Description is required')),\n expiresIn: yupString().defined(),\n });\n\n const { register, handleSubmit, formState: { errors }, reset } = useForm({\n resolver: yupResolver(apiKeySchema),\n defaultValues: {\n description: '',\n expiresIn: Object.keys(expiresInOptions)[2], // Default to 30 days\n }\n });\n\n const onSubmit = async (data: yup.InferType<typeof apiKeySchema>) => {\n setLoading(true);\n try {\n const expiresAt = new Date(Date.now() + parseInt(data.expiresIn));\n const apiKey = await props.createApiKey({\n description: data.description,\n expiresAt,\n });\n\n if (props.onKeyCreated) {\n props.onKeyCreated(apiKey);\n }\n\n reset();\n props.onOpenChange(false);\n } catch (error) {\n captureError(\"Failed to create API key\", { error });\n } finally {\n setLoading(false);\n }\n };\n\n return (\n <ActionDialog\n open={props.open}\n onOpenChange={props.onOpenChange}\n title={t('Create API Key')}\n description={t('API keys grant programmatic access to your account.')}\n >\n <form\n onSubmit={(e) => {\n e.preventDefault();\n runAsynchronously(handleSubmit(onSubmit));\n }}\n className=\"space-y-4\"\n >\n <div className=\"space-y-2\">\n <Label htmlFor=\"description\">{t('Description')}</Label>\n <Input\n id=\"description\"\n placeholder={t('e.g. Development, Production, CI/CD')}\n {...register('description')}\n />\n {errors.description && <FormWarningText text={errors.description.message} />}\n </div>\n\n <div className=\"space-y-2\">\n <Label htmlFor=\"expiresIn\">{t('Expires In')}</Label>\n <select\n id=\"expiresIn\"\n className=\"w-full p-2 border border-input rounded-md bg-background\"\n {...register('expiresIn')}\n >\n {Object.entries(expiresInOptions).map(([value, label]) => (\n <option key={value} value={value}>{t(label)}</option>\n ))}\n </select>\n {errors.expiresIn && <FormWarningText text={errors.expiresIn.message} />}\n </div>\n\n <div className=\"flex justify-end gap-2 pt-4\">\n <Button\n type=\"button\"\n variant=\"secondary\"\n onClick={() => {\n reset();\n props.onOpenChange(false);\n }}\n >\n {t('Cancel')}\n </Button>\n <Button type=\"submit\" loading={loading}>\n {t('Create')}\n </Button>\n </div>\n </form>\n </ActionDialog>\n );\n}\n\n/**\n * Dialog for showing the newly created API key\n */\nexport function ShowApiKeyDialog<Type extends ApiKeyType = ApiKeyType>(props: {\n apiKey: ApiKey<Type, true> | null,\n onClose?: () => void,\n}) {\n const { t } = useTranslation();\n\n return (\n <ActionDialog\n open={!!props.apiKey}\n title={t(\"API Key\")}\n okButton={{ label: t(\"Close\") }}\n onClose={props.onClose}\n preventClose\n confirmText={t(\"I understand that I will not be able to view this key again.\")}\n >\n <div className=\"flex flex-col gap-4\">\n <Typography>\n {t(\"Here is your API key.\")}{\" \"}\n <span className=\"font-bold\">\n {t(\"Copy it to a safe place. You will not be able to view it again.\")}\n </span>\n </Typography>\n <CopyField\n type=\"input\"\n monospace\n value={props.apiKey?.value ?? ''}\n label={t(\"Secret API Key\")}\n />\n </div>\n </ActionDialog>\n );\n}\n"],"mappings":"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","names":[]}
@@ -31,10 +31,10 @@ var import_promises = require("@stackframe/stack-shared/dist/utils/promises");
31
31
  var import_stack_ui = require("@stackframe/stack-ui");
32
32
  var import_react = require("react");
33
33
  var import_react_hook_form = require("react-hook-form");
34
- var import__ = require("..");
35
- var import_translations = require("../lib/translations");
36
- var import_form_warning = require("./elements/form-warning");
37
- var import_link = require("./link");
34
+ var import__ = require("../index.js");
35
+ var import_translations = require("../lib/translations.js");
36
+ var import_form_warning = require("./elements/form-warning.js");
37
+ var import_link = require("./link.js");
38
38
  var import_jsx_runtime = require("react/jsx-runtime");
39
39
  function CredentialSignIn() {
40
40
  const { t } = (0, import_translations.useTranslation)();
@@ -43,9 +43,9 @@ var import_stack_ui = require("@stackframe/stack-ui");
43
43
  var import_react = require("react");
44
44
  var import_react_hook_form = require("react-hook-form");
45
45
  var yup = __toESM(require("yup"));
46
- var import__ = require("..");
47
- var import_translations = require("../lib/translations");
48
- var import_form_warning = require("./elements/form-warning");
46
+ var import__ = require("../index.js");
47
+ var import_translations = require("../lib/translations.js");
48
+ var import_form_warning = require("./elements/form-warning.js");
49
49
  var import_jsx_runtime = require("react/jsx-runtime");
50
50
  function CredentialSignUp(props) {
51
51
  const { t } = (0, import_translations.useTranslation)();
@@ -26,7 +26,7 @@ __export(maybe_full_page_exports, {
26
26
  });
27
27
  module.exports = __toCommonJS(maybe_full_page_exports);
28
28
  var import_react = require("react");
29
- var import_ssr_layout_effect = require("./ssr-layout-effect");
29
+ var import_ssr_layout_effect = require("./ssr-layout-effect.js");
30
30
  var import_jsx_runtime = require("react/jsx-runtime");
31
31
  function MaybeFullPage({
32
32
  children,
@@ -28,7 +28,7 @@ module.exports = __toCommonJS(sidebar_layout_exports);
28
28
  var import_use_hash = require("@stackframe/stack-shared/dist/hooks/use-hash");
29
29
  var import_stack_ui = require("@stackframe/stack-ui");
30
30
  var import_lucide_react = require("lucide-react");
31
- var import__ = require("../..");
31
+ var import__ = require("../../index.js");
32
32
  var import_jsx_runtime = require("react/jsx-runtime");
33
33
  function SidebarLayout(props) {
34
34
  const hash = (0, import_use_hash.useHash)();
@@ -32,9 +32,9 @@ var import_promises = require("@stackframe/stack-shared/dist/utils/promises");
32
32
  var import_stack_ui = require("@stackframe/stack-ui");
33
33
  var import_react = require("react");
34
34
  var import_react_hook_form = require("react-hook-form");
35
- var import__ = require("..");
36
- var import_translations = require("../lib/translations");
37
- var import_form_warning = require("./elements/form-warning");
35
+ var import__ = require("../index.js");
36
+ var import_translations = require("../lib/translations.js");
37
+ var import_form_warning = require("./elements/form-warning.js");
38
38
  var import_jsx_runtime = require("react/jsx-runtime");
39
39
  function OTP(props) {
40
40
  const { t } = (0, import_translations.useTranslation)();
@@ -47,9 +47,9 @@ function OTP(props) {
47
47
  setSubmitting(true);
48
48
  stackApp.signInWithMagicLink(otp + props.nonce).then((result) => {
49
49
  if (result.status === "error") {
50
- if (result.error instanceof import_stack_shared.KnownErrors.VerificationCodeError) {
50
+ if (import_stack_shared.KnownErrors.VerificationCodeError.isInstance(result.error)) {
51
51
  setError(t("Invalid code"));
52
- } else if (result.error instanceof import_stack_shared.KnownErrors.InvalidTotpCode) {
52
+ } else if (import_stack_shared.KnownErrors.InvalidTotpCode.isInstance(result.error)) {
53
53
  setError(t("Invalid TOTP code"));
54
54
  } else {
55
55
  throw result.error;
@@ -108,7 +108,7 @@ function MagicLinkSignIn() {
108
108
  setNonce(result.data.nonce);
109
109
  }
110
110
  } catch (e) {
111
- if (e instanceof import_stack_shared.KnownErrors.SignUpNotEnabled) {
111
+ if (import_stack_shared.KnownErrors.SignUpNotEnabled.isInstance(e)) {
112
112
  setError("email", { type: "manual", message: t("New account registration is not allowed") });
113
113
  } else {
114
114
  throw e;
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/components/magic-link-sign-in.tsx"],"sourcesContent":["'use client';\n\n\n//===========================================\n// THIS FILE IS AUTO-GENERATED FROM TEMPLATE. DO NOT EDIT IT DIRECTLY\n//===========================================\n\nimport { yupResolver } from \"@hookform/resolvers/yup\";\nimport { KnownErrors } from \"@stackframe/stack-shared\";\nimport { strictEmailSchema, yupObject } from \"@stackframe/stack-shared/dist/schema-fields\";\nimport { runAsynchronouslyWithAlert } from \"@stackframe/stack-shared/dist/utils/promises\";\nimport { Button, Input, InputOTP, InputOTPGroup, InputOTPSlot, Label, Typography } from \"@stackframe/stack-ui\";\nimport { useEffect, useState } from \"react\";\nimport { useForm } from \"react-hook-form\";\nimport * as yup from \"yup\";\nimport { useStackApp } from \"..\";\nimport { useTranslation } from \"../lib/translations\";\nimport { FormWarningText } from \"./elements/form-warning\";\n\nfunction OTP(props: {\n onBack: () => void,\n nonce: string,\n}) {\n const { t } = useTranslation();\n const [otp, setOtp] = useState<string>('');\n const [submitting, setSubmitting] = useState<boolean>(false);\n const stackApp = useStackApp();\n const [error, setError] = useState<string | null>(null);\n\n useEffect(() => {\n if (otp.length === 6 && !submitting) {\n setSubmitting(true);\n stackApp.signInWithMagicLink(otp + props.nonce)\n .then(result => {\n if (result.status === 'error') {\n if (result.error instanceof KnownErrors.VerificationCodeError) {\n setError(t(\"Invalid code\"));\n } else if (result.error instanceof KnownErrors.InvalidTotpCode) {\n setError(t(\"Invalid TOTP code\"));\n } else {\n throw result.error;\n }\n }\n })\n .catch(e => console.error(e))\n .finally(() => {\n setSubmitting(false);\n setOtp('');\n });\n }\n if (otp.length !== 0 && otp.length !== 6) {\n setError(null);\n }\n }, [otp, submitting]);\n\n return (\n <div className=\"flex flex-col items-stretch stack-scope\">\n <form className='w-full flex flex-col items-center mb-2'>\n <Typography className='mb-2' >{t('Enter the code from your email')}</Typography>\n <InputOTP\n maxLength={6}\n type=\"text\"\n inputMode=\"text\"\n pattern={\"^[a-zA-Z0-9]+$\"}\n value={otp}\n onChange={value => setOtp(value.toUpperCase())}\n disabled={submitting}\n >\n <InputOTPGroup>\n {[0, 1, 2, 3, 4, 5].map((index) => (\n <InputOTPSlot key={index} index={index} size='lg' />\n ))}\n </InputOTPGroup>\n </InputOTP>\n {error && <FormWarningText text={error} />}\n </form>\n <Button variant='link' onClick={props.onBack} className='underline'>{t('Cancel')}</Button>\n </div>\n );\n}\n\nexport function MagicLinkSignIn() {\n const { t } = useTranslation();\n const app = useStackApp();\n const [loading, setLoading] = useState(false);\n const [nonce, setNonce] = useState<string | null>(null);\n\n const schema = yupObject({\n email: strictEmailSchema(t('Please enter a valid email')).defined().nonEmpty(t('Please enter your email'))\n });\n\n const { register, handleSubmit, setError, formState: { errors } } = useForm({\n resolver: yupResolver(schema)\n });\n\n const onSubmit = async (data: yup.InferType<typeof schema>) => {\n setLoading(true);\n try {\n const { email } = data;\n const result = await app.sendMagicLinkEmail(email);\n if (result.status === 'error') {\n setError('email', { type: 'manual', message: result.error.message });\n return;\n } else {\n setNonce(result.data.nonce);\n }\n } catch (e) {\n if (e instanceof KnownErrors.SignUpNotEnabled) {\n setError('email', { type: 'manual', message: t('New account registration is not allowed') });\n } else {\n throw e;\n }\n } finally {\n setLoading(false);\n }\n };\n\n if (nonce) {\n return <OTP nonce={nonce} onBack={() => setNonce(null)} />;\n } else {\n return (\n <form\n className=\"flex flex-col items-stretch stack-scope\"\n onSubmit={e => runAsynchronouslyWithAlert(handleSubmit(onSubmit)(e))}\n noValidate\n >\n <Label htmlFor=\"email\" className=\"mb-1\">{t('Email')}</Label>\n <Input\n id=\"email\"\n type=\"email\"\n autoComplete=\"email\"\n {...register('email')}\n />\n <FormWarningText text={errors.email?.message?.toString()} />\n\n <Button type=\"submit\" className=\"mt-6\" loading={loading}>\n {t('Send email')}\n </Button>\n </form>\n );\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAOA,iBAA4B;AAC5B,0BAA4B;AAC5B,2BAA6C;AAC7C,sBAA2C;AAC3C,sBAAwF;AACxF,mBAAoC;AACpC,6BAAwB;AAExB,eAA4B;AAC5B,0BAA+B;AAC/B,0BAAgC;AAwC1B;AAtCN,SAAS,IAAI,OAGV;AACD,QAAM,EAAE,EAAE,QAAI,oCAAe;AAC7B,QAAM,CAAC,KAAK,MAAM,QAAI,uBAAiB,EAAE;AACzC,QAAM,CAAC,YAAY,aAAa,QAAI,uBAAkB,KAAK;AAC3D,QAAM,eAAW,sBAAY;AAC7B,QAAM,CAAC,OAAO,QAAQ,QAAI,uBAAwB,IAAI;AAEtD,8BAAU,MAAM;AACd,QAAI,IAAI,WAAW,KAAK,CAAC,YAAY;AACnC,oBAAc,IAAI;AAClB,eAAS,oBAAoB,MAAM,MAAM,KAAK,EAC3C,KAAK,YAAU;AACd,YAAI,OAAO,WAAW,SAAS;AAC7B,cAAI,OAAO,iBAAiB,gCAAY,uBAAuB;AAC7D,qBAAS,EAAE,cAAc,CAAC;AAAA,UAC5B,WAAW,OAAO,iBAAiB,gCAAY,iBAAiB;AAC9D,qBAAS,EAAE,mBAAmB,CAAC;AAAA,UACjC,OAAO;AACL,kBAAM,OAAO;AAAA,UACf;AAAA,QACF;AAAA,MACF,CAAC,EACA,MAAM,OAAK,QAAQ,MAAM,CAAC,CAAC,EAC3B,QAAQ,MAAM;AACb,sBAAc,KAAK;AACnB,eAAO,EAAE;AAAA,MACX,CAAC;AAAA,IACL;AACA,QAAI,IAAI,WAAW,KAAK,IAAI,WAAW,GAAG;AACxC,eAAS,IAAI;AAAA,IACf;AAAA,EACF,GAAG,CAAC,KAAK,UAAU,CAAC;AAEpB,SACE,6CAAC,SAAI,WAAU,2CACb;AAAA,iDAAC,UAAK,WAAU,0CACd;AAAA,kDAAC,8BAAW,WAAU,QAAS,YAAE,gCAAgC,GAAE;AAAA,MACnE;AAAA,QAAC;AAAA;AAAA,UACC,WAAW;AAAA,UACX,MAAK;AAAA,UACL,WAAU;AAAA,UACV,SAAS;AAAA,UACT,OAAO;AAAA,UACP,UAAU,WAAS,OAAO,MAAM,YAAY,CAAC;AAAA,UAC7C,UAAU;AAAA,UAEV,sDAAC,iCACE,WAAC,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC,EAAE,IAAI,CAAC,UACvB,4CAAC,gCAAyB,OAAc,MAAK,QAA1B,KAA+B,CACnD,GACH;AAAA;AAAA,MACF;AAAA,MACC,SAAS,4CAAC,uCAAgB,MAAM,OAAO;AAAA,OAC1C;AAAA,IACA,4CAAC,0BAAO,SAAQ,QAAO,SAAS,MAAM,QAAQ,WAAU,aAAa,YAAE,QAAQ,GAAE;AAAA,KACnF;AAEJ;AAEO,SAAS,kBAAkB;AAChC,QAAM,EAAE,EAAE,QAAI,oCAAe;AAC7B,QAAM,UAAM,sBAAY;AACxB,QAAM,CAAC,SAAS,UAAU,QAAI,uBAAS,KAAK;AAC5C,QAAM,CAAC,OAAO,QAAQ,QAAI,uBAAwB,IAAI;AAEtD,QAAM,aAAS,gCAAU;AAAA,IACvB,WAAO,wCAAkB,EAAE,4BAA4B,CAAC,EAAE,QAAQ,EAAE,SAAS,EAAE,yBAAyB,CAAC;AAAA,EAC3G,CAAC;AAED,QAAM,EAAE,UAAU,cAAc,UAAU,WAAW,EAAE,OAAO,EAAE,QAAI,gCAAQ;AAAA,IAC1E,cAAU,wBAAY,MAAM;AAAA,EAC9B,CAAC;AAED,QAAM,WAAW,OAAO,SAAuC;AAC7D,eAAW,IAAI;AACf,QAAI;AACF,YAAM,EAAE,MAAM,IAAI;AAClB,YAAM,SAAS,MAAM,IAAI,mBAAmB,KAAK;AACjD,UAAI,OAAO,WAAW,SAAS;AAC7B,iBAAS,SAAS,EAAE,MAAM,UAAU,SAAS,OAAO,MAAM,QAAQ,CAAC;AACnE;AAAA,MACF,OAAO;AACL,iBAAS,OAAO,KAAK,KAAK;AAAA,MAC5B;AAAA,IACF,SAAS,GAAG;AACV,UAAI,aAAa,gCAAY,kBAAkB;AAC7C,iBAAS,SAAS,EAAE,MAAM,UAAU,SAAS,EAAE,yCAAyC,EAAE,CAAC;AAAA,MAC7F,OAAO;AACL,cAAM;AAAA,MACR;AAAA,IACF,UAAE;AACA,iBAAW,KAAK;AAAA,IAClB;AAAA,EACF;AAEA,MAAI,OAAO;AACT,WAAO,4CAAC,OAAI,OAAc,QAAQ,MAAM,SAAS,IAAI,GAAG;AAAA,EAC1D,OAAO;AACL,WACE;AAAA,MAAC;AAAA;AAAA,QACC,WAAU;AAAA,QACV,UAAU,WAAK,4CAA2B,aAAa,QAAQ,EAAE,CAAC,CAAC;AAAA,QACnE,YAAU;AAAA,QAEV;AAAA,sDAAC,yBAAM,SAAQ,SAAQ,WAAU,QAAQ,YAAE,OAAO,GAAE;AAAA,UACpD;AAAA,YAAC;AAAA;AAAA,cACC,IAAG;AAAA,cACH,MAAK;AAAA,cACL,cAAa;AAAA,cACZ,GAAG,SAAS,OAAO;AAAA;AAAA,UACtB;AAAA,UACA,4CAAC,uCAAgB,MAAM,OAAO,OAAO,SAAS,SAAS,GAAG;AAAA,UAE1D,4CAAC,0BAAO,MAAK,UAAS,WAAU,QAAO,SACpC,YAAE,YAAY,GACjB;AAAA;AAAA;AAAA,IACF;AAAA,EAEJ;AACF;","names":[]}
1
+ {"version":3,"sources":["../../src/components/magic-link-sign-in.tsx"],"sourcesContent":["'use client';\n\n\n//===========================================\n// THIS FILE IS AUTO-GENERATED FROM TEMPLATE. DO NOT EDIT IT DIRECTLY\n//===========================================\n\nimport { yupResolver } from \"@hookform/resolvers/yup\";\nimport { KnownErrors } from \"@stackframe/stack-shared\";\nimport { strictEmailSchema, yupObject } from \"@stackframe/stack-shared/dist/schema-fields\";\nimport { runAsynchronouslyWithAlert } from \"@stackframe/stack-shared/dist/utils/promises\";\nimport { Button, Input, InputOTP, InputOTPGroup, InputOTPSlot, Label, Typography } from \"@stackframe/stack-ui\";\nimport { useEffect, useState } from \"react\";\nimport { useForm } from \"react-hook-form\";\nimport * as yup from \"yup\";\nimport { useStackApp } from \"..\";\nimport { useTranslation } from \"../lib/translations\";\nimport { FormWarningText } from \"./elements/form-warning\";\n\nfunction OTP(props: {\n onBack: () => void,\n nonce: string,\n}) {\n const { t } = useTranslation();\n const [otp, setOtp] = useState<string>('');\n const [submitting, setSubmitting] = useState<boolean>(false);\n const stackApp = useStackApp();\n const [error, setError] = useState<string | null>(null);\n\n useEffect(() => {\n if (otp.length === 6 && !submitting) {\n setSubmitting(true);\n stackApp.signInWithMagicLink(otp + props.nonce)\n .then(result => {\n if (result.status === 'error') {\n if (KnownErrors.VerificationCodeError.isInstance(result.error)) {\n setError(t(\"Invalid code\"));\n } else if (KnownErrors.InvalidTotpCode.isInstance(result.error)) {\n setError(t(\"Invalid TOTP code\"));\n } else {\n throw result.error;\n }\n }\n })\n .catch(e => console.error(e))\n .finally(() => {\n setSubmitting(false);\n setOtp('');\n });\n }\n if (otp.length !== 0 && otp.length !== 6) {\n setError(null);\n }\n }, [otp, submitting]);\n\n return (\n <div className=\"flex flex-col items-stretch stack-scope\">\n <form className='w-full flex flex-col items-center mb-2'>\n <Typography className='mb-2' >{t('Enter the code from your email')}</Typography>\n <InputOTP\n maxLength={6}\n type=\"text\"\n inputMode=\"text\"\n pattern={\"^[a-zA-Z0-9]+$\"}\n value={otp}\n onChange={value => setOtp(value.toUpperCase())}\n disabled={submitting}\n >\n <InputOTPGroup>\n {[0, 1, 2, 3, 4, 5].map((index) => (\n <InputOTPSlot key={index} index={index} size='lg' />\n ))}\n </InputOTPGroup>\n </InputOTP>\n {error && <FormWarningText text={error} />}\n </form>\n <Button variant='link' onClick={props.onBack} className='underline'>{t('Cancel')}</Button>\n </div>\n );\n}\n\nexport function MagicLinkSignIn() {\n const { t } = useTranslation();\n const app = useStackApp();\n const [loading, setLoading] = useState(false);\n const [nonce, setNonce] = useState<string | null>(null);\n\n const schema = yupObject({\n email: strictEmailSchema(t('Please enter a valid email')).defined().nonEmpty(t('Please enter your email'))\n });\n\n const { register, handleSubmit, setError, formState: { errors } } = useForm({\n resolver: yupResolver(schema)\n });\n\n const onSubmit = async (data: yup.InferType<typeof schema>) => {\n setLoading(true);\n try {\n const { email } = data;\n const result = await app.sendMagicLinkEmail(email);\n if (result.status === 'error') {\n setError('email', { type: 'manual', message: result.error.message });\n return;\n } else {\n setNonce(result.data.nonce);\n }\n } catch (e) {\n if (KnownErrors.SignUpNotEnabled.isInstance(e)) {\n setError('email', { type: 'manual', message: t('New account registration is not allowed') });\n } else {\n throw e;\n }\n } finally {\n setLoading(false);\n }\n };\n\n if (nonce) {\n return <OTP nonce={nonce} onBack={() => setNonce(null)} />;\n } else {\n return (\n <form\n className=\"flex flex-col items-stretch stack-scope\"\n onSubmit={e => runAsynchronouslyWithAlert(handleSubmit(onSubmit)(e))}\n noValidate\n >\n <Label htmlFor=\"email\" className=\"mb-1\">{t('Email')}</Label>\n <Input\n id=\"email\"\n type=\"email\"\n autoComplete=\"email\"\n {...register('email')}\n />\n <FormWarningText text={errors.email?.message?.toString()} />\n\n <Button type=\"submit\" className=\"mt-6\" loading={loading}>\n {t('Send email')}\n </Button>\n </form>\n );\n }\n}\n"],"mappings":"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","names":[]}
@@ -26,8 +26,8 @@ __export(known_error_message_card_exports, {
26
26
  });
27
27
  module.exports = __toCommonJS(known_error_message_card_exports);
28
28
  var import_stack_ui = require("@stackframe/stack-ui");
29
- var import__ = require("../..");
30
- var import_message_card = require("./message-card");
29
+ var import__ = require("../../index.js");
30
+ var import_message_card = require("./message-card.js");
31
31
  var import_jsx_runtime = require("react/jsx-runtime");
32
32
  function KnownErrorMessageCard({
33
33
  error,
@@ -25,7 +25,7 @@ __export(message_card_exports, {
25
25
  MessageCard: () => MessageCard
26
26
  });
27
27
  module.exports = __toCommonJS(message_card_exports);
28
- var import_maybe_full_page = require("../elements/maybe-full-page");
28
+ var import_maybe_full_page = require("../elements/maybe-full-page.js");
29
29
  var import_stack_ui = require("@stackframe/stack-ui");
30
30
  var import_jsx_runtime = require("react/jsx-runtime");
31
31
  function MessageCard({ fullPage = false, ...props }) {
@@ -26,9 +26,9 @@ __export(predefined_message_card_exports, {
26
26
  });
27
27
  module.exports = __toCommonJS(predefined_message_card_exports);
28
28
  var import_stack_ui = require("@stackframe/stack-ui");
29
- var import__ = require("../..");
30
- var import_translations = require("../../lib/translations");
31
- var import_message_card = require("./message-card");
29
+ var import__ = require("../../index.js");
30
+ var import_translations = require("../../lib/translations.js");
31
+ var import_message_card = require("./message-card.js");
32
32
  var import_jsx_runtime = require("react/jsx-runtime");
33
33
  function PredefinedMessageCard({
34
34
  type,
@@ -25,8 +25,8 @@ __export(oauth_button_group_exports, {
25
25
  OAuthButtonGroup: () => OAuthButtonGroup
26
26
  });
27
27
  module.exports = __toCommonJS(oauth_button_group_exports);
28
- var import_hooks = require("../lib/hooks");
29
- var import_oauth_button = require("./oauth-button");
28
+ var import_hooks = require("../lib/hooks.js");
29
+ var import_oauth_button = require("./oauth-button.js");
30
30
  var import_jsx_runtime = require("react/jsx-runtime");
31
31
  function OAuthButtonGroup({
32
32
  type,
@@ -38,8 +38,9 @@ module.exports = __toCommonJS(oauth_button_exports);
38
38
  var import_stack_ui = require("@stackframe/stack-ui");
39
39
  var import_color = __toESM(require("color"));
40
40
  var import_react = require("react");
41
- var import__ = require("..");
42
- var import_translations = require("../lib/translations");
41
+ var import__ = require("../index.js");
42
+ var import_translations = require("../lib/translations.js");
43
+ var import_use_in_iframe = require("./use-in-iframe.js");
43
44
  var import_jsx_runtime = require("react/jsx-runtime");
44
45
  var iconSize = 22;
45
46
  var changeColor = (c, value) => {
@@ -56,6 +57,7 @@ function OAuthButton({
56
57
  const { t } = (0, import_translations.useTranslation)();
57
58
  const stackApp = (0, import__.useStackApp)();
58
59
  const styleId = (0, import_react.useId)().replaceAll(":", "-");
60
+ const isIframe = (0, import_use_in_iframe.useInIframe)();
59
61
  const [lastUsed, setLastUsed] = (0, import_react.useState)(null);
60
62
  (0, import_react.useEffect)(() => {
61
63
  setLastUsed(localStorage.getItem("_STACK_AUTH.lastUsed"));
@@ -185,21 +187,30 @@ function OAuthButton({
185
187
  `;
186
188
  return /* @__PURE__ */ (0, import_jsx_runtime.jsxs)(import_jsx_runtime.Fragment, { children: [
187
189
  /* @__PURE__ */ (0, import_jsx_runtime.jsx)("style", { children: styleSheet }),
188
- /* @__PURE__ */ (0, import_jsx_runtime.jsxs)(
189
- import_stack_ui.Button,
190
+ /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
191
+ import_stack_ui.SimpleTooltip,
190
192
  {
191
- onClick: async () => {
192
- localStorage.setItem("_STACK_AUTH.lastUsed", provider);
193
- await stackApp.signInWithOAuth(provider);
194
- },
195
- className: `stack-oauth-button-${styleId} stack-scope relative`,
196
- children: [
197
- !isMock && lastUsed === provider && /* @__PURE__ */ (0, import_jsx_runtime.jsx)("span", { className: "absolute -top-2 -right-2 bg-blue-500 text-white text-xs px-2 py-1 rounded-md", children: "last" }),
198
- /* @__PURE__ */ (0, import_jsx_runtime.jsxs)("div", { className: "flex items-center w-full gap-4", children: [
199
- style.icon,
200
- /* @__PURE__ */ (0, import_jsx_runtime.jsx)("span", { className: "flex-1", children: type === "sign-up" ? t("Sign up with {provider}", { provider: style.name }) : t("Sign in with {provider}", { provider: style.name }) })
201
- ] })
202
- ]
193
+ disabled: !isIframe,
194
+ tooltip: isIframe ? "This auth provider is not supported in an iframe for security reasons." : void 0,
195
+ className: "stack-scope w-full inline-flex",
196
+ children: /* @__PURE__ */ (0, import_jsx_runtime.jsxs)(
197
+ import_stack_ui.Button,
198
+ {
199
+ onClick: async () => {
200
+ localStorage.setItem("_STACK_AUTH.lastUsed", provider);
201
+ await stackApp.signInWithOAuth(provider);
202
+ },
203
+ className: `stack-oauth-button-${styleId} stack-scope relative w-full`,
204
+ disabled: isIframe,
205
+ children: [
206
+ !isMock && lastUsed === provider && /* @__PURE__ */ (0, import_jsx_runtime.jsx)("span", { className: "absolute -top-2 -right-2 bg-blue-500 text-white text-xs px-2 py-1 rounded-md", children: "last" }),
207
+ /* @__PURE__ */ (0, import_jsx_runtime.jsxs)("div", { className: "flex items-center w-full gap-4", children: [
208
+ style.icon,
209
+ /* @__PURE__ */ (0, import_jsx_runtime.jsx)("span", { className: "flex-1", children: type === "sign-up" ? t("Sign up with {provider}", { provider: style.name }) : t("Sign in with {provider}", { provider: style.name }) })
210
+ ] })
211
+ ]
212
+ }
213
+ )
203
214
  }
204
215
  )
205
216
  ] });
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/components/oauth-button.tsx"],"sourcesContent":["'use client';\n\n\n//===========================================\n// THIS FILE IS AUTO-GENERATED FROM TEMPLATE. DO NOT EDIT IT DIRECTLY\n//===========================================\n\nimport { BrandIcons, Button } from '@stackframe/stack-ui';\nimport Color from 'color';\nimport { useEffect, useId, useState } from 'react';\nimport { useStackApp } from '..';\nimport { useTranslation } from '../lib/translations';\n\nconst iconSize = 22;\n\nconst changeColor = (c: Color, value: number) => {\n if (c.isLight()) {\n value = -value;\n }\n return c.hsl(c.hue(), c.saturationl(), c.lightness() + value).toString();\n};\n\nexport function OAuthButton({\n provider,\n type,\n isMock = false,\n}: {\n provider: string,\n type: 'sign-in' | 'sign-up',\n isMock?: boolean,\n}) {\n const { t } = useTranslation();\n const stackApp = useStackApp();\n const styleId = useId().replaceAll(':', '-');\n\n const [lastUsed, setLastUsed] = useState<string | null>(null);\n useEffect(() => {\n setLastUsed(localStorage.getItem('_STACK_AUTH.lastUsed'));\n }, []);\n\n let style : {\n backgroundColor?: string,\n textColor?: string,\n name: string,\n icon: JSX.Element | null,\n border?: string,\n };\n switch (provider) {\n case 'google': {\n style = {\n backgroundColor: '#fff',\n textColor: '#000',\n name: 'Google',\n border: '1px solid #ddd',\n icon: <BrandIcons.Google iconSize={iconSize} />,\n };\n break;\n }\n case 'github': {\n style = {\n backgroundColor: '#111',\n textColor: '#fff',\n border: '1px solid #333',\n name: 'GitHub',\n icon: <BrandIcons.GitHub iconSize={iconSize} />,\n };\n break;\n }\n case 'facebook': {\n style = {\n backgroundColor: '#1877F2',\n textColor: '#fff',\n name: 'Facebook',\n icon: <BrandIcons.Facebook iconSize={iconSize} />,\n };\n break;\n }\n case 'microsoft': {\n style = {\n backgroundColor: '#2f2f2f',\n textColor: '#fff',\n name: 'Microsoft',\n icon: <BrandIcons.Microsoft iconSize={iconSize} />,\n };\n break;\n }\n case 'spotify': {\n style = {\n backgroundColor: '#1DB954',\n textColor: '#fff',\n name: 'Spotify',\n icon: <BrandIcons.Spotify iconSize={iconSize} />,\n };\n break;\n }\n case 'discord': {\n style = {\n backgroundColor: '#5865F2',\n textColor: '#fff',\n name: 'Discord',\n icon: <BrandIcons.Discord iconSize={iconSize} />,\n };\n break;\n }\n case 'gitlab': {\n style = {\n backgroundColor: \"#111\",\n textColor: \"#fff\",\n border: \"1px solid #333\",\n name: \"Gitlab\",\n icon: <BrandIcons.Gitlab iconSize={iconSize} />,\n };\n break;\n }\n case 'apple': {\n style = {\n backgroundColor: \"#000\",\n textColor: \"#fff\",\n border: \"1px solid #333\",\n name: \"Apple\",\n icon: <BrandIcons.Apple iconSize={iconSize} />,\n };\n break;\n }\n case \"bitbucket\": {\n style = {\n backgroundColor: \"#fff\",\n textColor: \"#000\",\n border: \"1px solid #ddd\",\n name: \"Bitbucket\",\n icon: <BrandIcons.Bitbucket iconSize={iconSize} />,\n };\n break;\n }\n case 'linkedin': {\n style = {\n backgroundColor: \"#0073b1\",\n textColor: \"#fff\",\n name: \"LinkedIn\",\n icon: <BrandIcons.LinkedIn iconSize={iconSize} />,\n };\n break;\n }\n case 'x': {\n style = {\n backgroundColor: \"#000\",\n textColor: \"#fff\",\n name: \"X\",\n icon: <BrandIcons.X iconSize={iconSize} />,\n };\n break;\n }\n default: {\n style = {\n name: provider,\n icon: null,\n };\n }\n }\n\n const styleSheet = `\n .stack-oauth-button-${styleId} {\n background-color: ${style.backgroundColor} !important;\n color: ${style.textColor} !important;\n border: ${style.border} !important;\n }\n .stack-oauth-button-${styleId}:hover {\n background-color: ${changeColor(Color(style.backgroundColor), 10)} !important;\n }\n `;\n\n return (\n <>\n <style>{styleSheet}</style>\n <Button\n onClick={async () => {\n localStorage.setItem('_STACK_AUTH.lastUsed', provider);\n await stackApp.signInWithOAuth(provider);\n }}\n className={`stack-oauth-button-${styleId} stack-scope relative`}\n >\n {!isMock && lastUsed === provider && (\n <span className=\"absolute -top-2 -right-2 bg-blue-500 text-white text-xs px-2 py-1 rounded-md\">\n last\n </span>\n )}\n <div className='flex items-center w-full gap-4'>\n {style.icon}\n <span className='flex-1'>\n {type === 'sign-up' ?\n t('Sign up with {provider}', { provider: style.name }) :\n t('Sign in with {provider}', { provider: style.name })\n }\n </span>\n </div>\n </Button>\n </>\n );\n}\n"],"mappings":"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","names":["Color"]}
1
+ {"version":3,"sources":["../../src/components/oauth-button.tsx"],"sourcesContent":["'use client';\n\n\n//===========================================\n// THIS FILE IS AUTO-GENERATED FROM TEMPLATE. DO NOT EDIT IT DIRECTLY\n//===========================================\n\nimport { BrandIcons, Button, SimpleTooltip } from '@stackframe/stack-ui';\nimport Color from 'color';\nimport { useEffect, useId, useState } from 'react';\nimport { useStackApp } from '..';\nimport { useTranslation } from '../lib/translations';\nimport { useInIframe } from './use-in-iframe';\n\nconst iconSize = 22;\n\nconst changeColor = (c: Color, value: number) => {\n if (c.isLight()) {\n value = -value;\n }\n return c.hsl(c.hue(), c.saturationl(), c.lightness() + value).toString();\n};\n\nexport function OAuthButton({\n provider,\n type,\n isMock = false,\n}: {\n provider: string,\n type: 'sign-in' | 'sign-up',\n isMock?: boolean,\n}) {\n const { t } = useTranslation();\n const stackApp = useStackApp();\n const styleId = useId().replaceAll(':', '-');\n const isIframe = useInIframe();\n\n const [lastUsed, setLastUsed] = useState<string | null>(null);\n useEffect(() => {\n setLastUsed(localStorage.getItem('_STACK_AUTH.lastUsed'));\n }, []);\n\n let style : {\n backgroundColor?: string,\n textColor?: string,\n name: string,\n icon: JSX.Element | null,\n border?: string,\n };\n switch (provider) {\n case 'google': {\n style = {\n backgroundColor: '#fff',\n textColor: '#000',\n name: 'Google',\n border: '1px solid #ddd',\n icon: <BrandIcons.Google iconSize={iconSize} />,\n };\n break;\n }\n case 'github': {\n style = {\n backgroundColor: '#111',\n textColor: '#fff',\n border: '1px solid #333',\n name: 'GitHub',\n icon: <BrandIcons.GitHub iconSize={iconSize} />,\n };\n break;\n }\n case 'facebook': {\n style = {\n backgroundColor: '#1877F2',\n textColor: '#fff',\n name: 'Facebook',\n icon: <BrandIcons.Facebook iconSize={iconSize} />,\n };\n break;\n }\n case 'microsoft': {\n style = {\n backgroundColor: '#2f2f2f',\n textColor: '#fff',\n name: 'Microsoft',\n icon: <BrandIcons.Microsoft iconSize={iconSize} />,\n };\n break;\n }\n case 'spotify': {\n style = {\n backgroundColor: '#1DB954',\n textColor: '#fff',\n name: 'Spotify',\n icon: <BrandIcons.Spotify iconSize={iconSize} />,\n };\n break;\n }\n case 'discord': {\n style = {\n backgroundColor: '#5865F2',\n textColor: '#fff',\n name: 'Discord',\n icon: <BrandIcons.Discord iconSize={iconSize} />,\n };\n break;\n }\n case 'gitlab': {\n style = {\n backgroundColor: \"#111\",\n textColor: \"#fff\",\n border: \"1px solid #333\",\n name: \"Gitlab\",\n icon: <BrandIcons.Gitlab iconSize={iconSize} />,\n };\n break;\n }\n case 'apple': {\n style = {\n backgroundColor: \"#000\",\n textColor: \"#fff\",\n border: \"1px solid #333\",\n name: \"Apple\",\n icon: <BrandIcons.Apple iconSize={iconSize} />,\n };\n break;\n }\n case \"bitbucket\": {\n style = {\n backgroundColor: \"#fff\",\n textColor: \"#000\",\n border: \"1px solid #ddd\",\n name: \"Bitbucket\",\n icon: <BrandIcons.Bitbucket iconSize={iconSize} />,\n };\n break;\n }\n case 'linkedin': {\n style = {\n backgroundColor: \"#0073b1\",\n textColor: \"#fff\",\n name: \"LinkedIn\",\n icon: <BrandIcons.LinkedIn iconSize={iconSize} />,\n };\n break;\n }\n case 'x': {\n style = {\n backgroundColor: \"#000\",\n textColor: \"#fff\",\n name: \"X\",\n icon: <BrandIcons.X iconSize={iconSize} />,\n };\n break;\n }\n default: {\n style = {\n name: provider,\n icon: null,\n };\n }\n }\n\n const styleSheet = `\n .stack-oauth-button-${styleId} {\n background-color: ${style.backgroundColor} !important;\n color: ${style.textColor} !important;\n border: ${style.border} !important;\n }\n .stack-oauth-button-${styleId}:hover {\n background-color: ${changeColor(Color(style.backgroundColor), 10)} !important;\n }\n `;\n\n return (\n <>\n <style>{styleSheet}</style>\n <SimpleTooltip\n disabled={!isIframe}\n tooltip={isIframe ? \"This auth provider is not supported in an iframe for security reasons.\" : undefined}\n className='stack-scope w-full inline-flex'\n >\n <Button\n onClick={async () => {\n localStorage.setItem('_STACK_AUTH.lastUsed', provider);\n await stackApp.signInWithOAuth(provider);\n }}\n className={`stack-oauth-button-${styleId} stack-scope relative w-full`}\n disabled={isIframe}\n >\n {!isMock && lastUsed === provider && (\n <span className=\"absolute -top-2 -right-2 bg-blue-500 text-white text-xs px-2 py-1 rounded-md\">\n last\n </span>\n )}\n <div className='flex items-center w-full gap-4'>\n {style.icon}\n <span className='flex-1'>\n {type === 'sign-up' ?\n t('Sign up with {provider}', { provider: style.name }) :\n t('Sign in with {provider}', { provider: style.name })\n }\n </span>\n </div>\n </Button>\n </SimpleTooltip>\n </>\n );\n}\n"],"mappings":"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","names":["Color"]}
@@ -27,8 +27,8 @@ __export(passkey_button_exports, {
27
27
  module.exports = __toCommonJS(passkey_button_exports);
28
28
  var import_stack_ui = require("@stackframe/stack-ui");
29
29
  var import_react = require("react");
30
- var import__ = require("..");
31
- var import_translations = require("../lib/translations");
30
+ var import__ = require("../index.js");
31
+ var import_translations = require("../lib/translations.js");
32
32
  var import_lucide_react = require("lucide-react");
33
33
  var import_jsx_runtime = require("react/jsx-runtime");
34
34
  function PasskeyButton({
@@ -31,7 +31,8 @@ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: tru
31
31
  var profile_image_editor_exports = {};
32
32
  __export(profile_image_editor_exports, {
33
33
  ProfileImageEditor: () => ProfileImageEditor,
34
- checkImageUrl: () => checkImageUrl
34
+ checkImageUrl: () => checkImageUrl,
35
+ getCroppedImg: () => getCroppedImg
35
36
  });
36
37
  module.exports = __toCommonJS(profile_image_editor_exports);
37
38
  var import_base64 = require("@stackframe/stack-shared/dist/utils/base64");
@@ -40,9 +41,9 @@ var import_stack_ui = require("@stackframe/stack-ui");
40
41
  var import_browser_image_compression = __toESM(require("browser-image-compression"));
41
42
  var import_lucide_react = require("lucide-react");
42
43
  var import_react = require("react");
43
- var import_react_avatar_editor = __toESM(require("react-avatar-editor"));
44
- var import_translations = require("../lib/translations");
45
- var import_user_avatar = require("./elements/user-avatar");
44
+ var import_react_easy_crop = __toESM(require("react-easy-crop"));
45
+ var import_translations = require("../lib/translations.js");
46
+ var import_user_avatar = require("./elements/user-avatar.js");
46
47
  var import_jsx_runtime = require("react/jsx-runtime");
47
48
  async function checkImageUrl(url) {
48
49
  try {
@@ -53,17 +54,64 @@ async function checkImageUrl(url) {
53
54
  return false;
54
55
  }
55
56
  }
57
+ var createImage = (url) => new Promise((resolve, reject) => {
58
+ const image = new Image();
59
+ image.addEventListener("load", () => resolve(image));
60
+ image.addEventListener("error", (error) => reject(error));
61
+ image.setAttribute("crossOrigin", "anonymous");
62
+ image.src = url;
63
+ });
64
+ async function getCroppedImg(imageSrc, pixelCrop) {
65
+ const image = await createImage(imageSrc);
66
+ const canvas = document.createElement("canvas");
67
+ const ctx = canvas.getContext("2d");
68
+ if (!ctx) {
69
+ return null;
70
+ }
71
+ const safeCrop = {
72
+ x: Math.max(0, pixelCrop.x),
73
+ y: Math.max(0, pixelCrop.y),
74
+ width: Math.max(1, pixelCrop.width),
75
+ height: Math.max(1, pixelCrop.height)
76
+ };
77
+ canvas.width = safeCrop.width;
78
+ canvas.height = safeCrop.height;
79
+ ctx.drawImage(
80
+ image,
81
+ safeCrop.x,
82
+ safeCrop.y,
83
+ safeCrop.width,
84
+ safeCrop.height,
85
+ 0,
86
+ 0,
87
+ safeCrop.width,
88
+ safeCrop.height
89
+ );
90
+ return canvas.toDataURL("image/jpeg");
91
+ }
56
92
  function ProfileImageEditor(props) {
57
93
  const { t } = (0, import_translations.useTranslation)();
58
- const cropRef = (0, import_react.useRef)(null);
59
- const [slideValue, setSlideValue] = (0, import_react.useState)(1);
60
94
  const [rawUrl, setRawUrl] = (0, import_react.useState)(null);
61
95
  const [error, setError] = (0, import_react.useState)(null);
96
+ const [crop, setCrop] = (0, import_react.useState)({ x: 0, y: 0 });
97
+ const [zoom, setZoom] = (0, import_react.useState)(1);
98
+ const [croppedAreaPixels, setCroppedAreaPixels] = (0, import_react.useState)(null);
62
99
  function reset() {
63
- setSlideValue(1);
64
100
  setRawUrl(null);
65
101
  setError(null);
102
+ setCrop({ x: 0, y: 0 });
103
+ setZoom(1);
104
+ setCroppedAreaPixels(null);
66
105
  }
106
+ const onCropChange = (0, import_react.useCallback)((crop2) => {
107
+ setCrop(crop2);
108
+ }, []);
109
+ const onCropComplete = (0, import_react.useCallback)((croppedArea, croppedAreaPixels2) => {
110
+ setCroppedAreaPixels(croppedAreaPixels2);
111
+ }, []);
112
+ const onZoomChange = (0, import_react.useCallback)((zoom2) => {
113
+ setZoom(zoom2);
114
+ }, []);
67
115
  function upload() {
68
116
  const input = document.createElement("input");
69
117
  input.type = "file";
@@ -100,28 +148,28 @@ function ProfileImageEditor(props) {
100
148
  ] });
101
149
  }
102
150
  return /* @__PURE__ */ (0, import_jsx_runtime.jsxs)("div", { className: "flex flex-col items-center gap-4", children: [
103
- /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
104
- import_react_avatar_editor.default,
151
+ /* @__PURE__ */ (0, import_jsx_runtime.jsx)("div", { className: "relative w-64 h-64", children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
152
+ import_react_easy_crop.default,
105
153
  {
106
- ref: cropRef,
107
154
  image: rawUrl || props.user.profileImageUrl || "",
108
- borderRadius: 1e3,
109
- color: [0, 0, 0, 0.72],
110
- scale: slideValue,
111
- rotate: 0,
112
- border: 20,
113
- className: "border"
155
+ crop,
156
+ zoom,
157
+ aspect: 1,
158
+ cropShape: "round",
159
+ showGrid: false,
160
+ onCropChange,
161
+ onCropComplete,
162
+ onZoomChange
114
163
  }
115
- ),
164
+ ) }),
116
165
  /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
117
166
  import_stack_ui.Slider,
118
167
  {
119
168
  min: 1,
120
- max: 5,
169
+ max: 3,
121
170
  step: 0.1,
122
- defaultValue: [slideValue],
123
- value: [slideValue],
124
- onValueChange: (v) => setSlideValue(v[0])
171
+ value: [zoom],
172
+ onValueChange: (v) => onZoomChange(v[0])
125
173
  }
126
174
  ),
127
175
  /* @__PURE__ */ (0, import_jsx_runtime.jsxs)("div", { className: "flex flex-row gap-2", children: [
@@ -129,18 +177,22 @@ function ProfileImageEditor(props) {
129
177
  import_stack_ui.Button,
130
178
  {
131
179
  onClick: async () => {
132
- if (cropRef.current && rawUrl) {
133
- const croppedUrl = cropRef.current.getImage().toDataURL("image/jpeg");
134
- const compressedFile = await (0, import_browser_image_compression.default)(
135
- await import_browser_image_compression.default.getFilefromDataUrl(croppedUrl, "profile-image"),
136
- {
137
- maxSizeMB: 0.1,
138
- fileType: "image/jpeg"
139
- }
140
- );
141
- const compressedUrl = await import_browser_image_compression.default.getDataUrlFromFile(compressedFile);
142
- await props.onProfileImageUrlChange(compressedUrl);
143
- reset();
180
+ if (rawUrl && croppedAreaPixels) {
181
+ const croppedImageUrl = await getCroppedImg(rawUrl, croppedAreaPixels);
182
+ if (croppedImageUrl) {
183
+ const compressedFile = await (0, import_browser_image_compression.default)(
184
+ await import_browser_image_compression.default.getFilefromDataUrl(croppedImageUrl, "profile-image"),
185
+ {
186
+ maxSizeMB: 0.1,
187
+ fileType: "image/jpeg"
188
+ }
189
+ );
190
+ const compressedUrl = await import_browser_image_compression.default.getDataUrlFromFile(compressedFile);
191
+ await props.onProfileImageUrlChange(compressedUrl);
192
+ reset();
193
+ } else {
194
+ setError(t("Could not crop image."));
195
+ }
144
196
  }
145
197
  },
146
198
  children: t("Save")
@@ -160,6 +212,7 @@ function ProfileImageEditor(props) {
160
212
  // Annotate the CommonJS export names for ESM import in node:
161
213
  0 && (module.exports = {
162
214
  ProfileImageEditor,
163
- checkImageUrl
215
+ checkImageUrl,
216
+ getCroppedImg
164
217
  });
165
218
  //# sourceMappingURL=profile-image-editor.js.map