payload-auth 1.3.4 → 1.4.1

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 (57) hide show
  1. package/dist/better-auth/adapter/index.d.ts +10 -0
  2. package/dist/better-auth/adapter/index.d.ts.map +1 -1
  3. package/dist/better-auth/adapter/index.js +151 -125
  4. package/dist/better-auth/adapter/transform/index.d.ts +2 -4
  5. package/dist/better-auth/adapter/transform/index.d.ts.map +1 -1
  6. package/dist/better-auth/adapter/transform/index.js +433 -309
  7. package/dist/better-auth/plugin/constants.d.ts +2 -0
  8. package/dist/better-auth/plugin/constants.d.ts.map +1 -1
  9. package/dist/better-auth/plugin/constants.js +4 -2
  10. package/dist/better-auth/plugin/helpers/check-passkey-plugin.d.ts.map +1 -1
  11. package/dist/better-auth/plugin/helpers/check-passkey-plugin.js +3 -2
  12. package/dist/better-auth/plugin/helpers/check-two-factor-plugin.d.ts +3 -0
  13. package/dist/better-auth/plugin/helpers/check-two-factor-plugin.d.ts.map +1 -0
  14. package/dist/better-auth/plugin/helpers/check-two-factor-plugin.js +6 -0
  15. package/dist/better-auth/plugin/helpers/check-username-plugin.d.ts.map +1 -1
  16. package/dist/better-auth/plugin/helpers/check-username-plugin.js +3 -2
  17. package/dist/better-auth/plugin/helpers/prepare-session-data.d.ts +52 -6
  18. package/dist/better-auth/plugin/helpers/prepare-session-data.d.ts.map +1 -1
  19. package/dist/better-auth/plugin/helpers/prepare-session-data.js +52 -35
  20. package/dist/better-auth/plugin/index.d.ts.map +1 -1
  21. package/dist/better-auth/plugin/index.js +16 -2
  22. package/dist/better-auth/plugin/lib/build-collections/sessions.d.ts.map +1 -1
  23. package/dist/better-auth/plugin/lib/build-collections/sessions.js +3 -1
  24. package/dist/better-auth/plugin/lib/build-collections/users/better-auth-strategy.d.ts.map +1 -1
  25. package/dist/better-auth/plugin/lib/build-collections/users/better-auth-strategy.js +2 -2
  26. package/dist/better-auth/plugin/lib/build-collections/users/hooks/after-login.d.ts.map +1 -1
  27. package/dist/better-auth/plugin/lib/build-collections/users/hooks/after-login.js +6 -4
  28. package/dist/better-auth/plugin/lib/build-collections/users/index.d.ts.map +1 -1
  29. package/dist/better-auth/plugin/lib/build-collections/users/index.js +7 -2
  30. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/save-to-jwt-middleware.d.ts +1 -1
  31. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/save-to-jwt-middleware.d.ts.map +1 -1
  32. package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/save-to-jwt-middleware.js +16 -14
  33. package/dist/better-auth/plugin/payload/components/two-factor-auth/index.d.ts +4 -0
  34. package/dist/better-auth/plugin/payload/components/two-factor-auth/index.d.ts.map +1 -0
  35. package/dist/better-auth/plugin/payload/components/two-factor-auth/index.js +344 -0
  36. package/dist/better-auth/plugin/payload/components/two-factor-auth/index.scss +113 -0
  37. package/dist/better-auth/plugin/payload/exports/client.d.ts +2 -1
  38. package/dist/better-auth/plugin/payload/exports/client.d.ts.map +1 -1
  39. package/dist/better-auth/plugin/payload/exports/client.js +3 -2
  40. package/dist/better-auth/plugin/payload/exports/rsc.d.ts +2 -1
  41. package/dist/better-auth/plugin/payload/exports/rsc.d.ts.map +1 -1
  42. package/dist/better-auth/plugin/payload/exports/rsc.js +3 -2
  43. package/dist/better-auth/plugin/payload/views/admin-login/client.d.ts.map +1 -1
  44. package/dist/better-auth/plugin/payload/views/admin-login/client.js +14 -5
  45. package/dist/better-auth/plugin/payload/views/admin-login/index.d.ts.map +1 -1
  46. package/dist/better-auth/plugin/payload/views/admin-login/index.js +1 -3
  47. package/dist/better-auth/plugin/payload/views/two-factor-verify/client.d.ts +5 -0
  48. package/dist/better-auth/plugin/payload/views/two-factor-verify/client.d.ts.map +1 -0
  49. package/dist/better-auth/plugin/payload/views/two-factor-verify/client.js +77 -0
  50. package/dist/better-auth/plugin/payload/views/two-factor-verify/index.d.ts +10 -0
  51. package/dist/better-auth/plugin/payload/views/two-factor-verify/index.d.ts.map +1 -0
  52. package/dist/better-auth/plugin/payload/views/two-factor-verify/index.js +44 -0
  53. package/dist/shared/form/components/submit.js +3 -1
  54. package/dist/shared/utils/value-or-default.d.ts +10 -0
  55. package/dist/shared/utils/value-or-default.d.ts.map +1 -0
  56. package/dist/shared/utils/value-or-default.js +12 -0
  57. package/package.json +13 -7
@@ -0,0 +1,113 @@
1
+ @layer payload-default {
2
+ .two-factor-auth-modal {
3
+ position: fixed;
4
+ inset: 0;
5
+ z-index: 1000;
6
+ display: flex;
7
+ align-items: center;
8
+ justify-content: center;
9
+ height: 100%;
10
+
11
+ &:before {
12
+ content: '';
13
+ position: absolute;
14
+ inset: 0;
15
+ background: rgba(0, 0, 0, 0.8);
16
+ z-index: 0;
17
+ }
18
+
19
+ &__wrapper {
20
+ z-index: 1;
21
+ position: relative;
22
+ display: flex;
23
+ flex-direction: column;
24
+ gap: 16px;
25
+ border-radius: 3px;
26
+ border: 1px solid var(--theme-border-color);
27
+ background-color: var(--theme-elevation-50);
28
+ min-width: 340px;
29
+ max-width: 90vw;
30
+ box-shadow: 0 8px 32px rgba(0,0,0,0.18);
31
+ }
32
+
33
+ &__close-button {
34
+ position: absolute;
35
+ top: 0;
36
+ right: 0;
37
+ margin-block: 0 !important;
38
+ padding: 10px !important;
39
+ svg {
40
+ width: 24px;
41
+ height: 24px;
42
+ }
43
+ }
44
+
45
+ &__content {
46
+ display: flex;
47
+ flex-direction: column;
48
+ gap: 1.5rem;
49
+ padding: 1.5rem 1.5rem 1rem 1.5rem;
50
+ h2 {
51
+ font-size: 1.5rem;
52
+ font-weight: 600;
53
+ margin: 0;
54
+ }
55
+ p {
56
+ margin: 0;
57
+ color: var(--theme-elevation-500);
58
+ }
59
+ }
60
+
61
+ &__verify-block {
62
+ display: flex;
63
+ flex-direction: column;
64
+ gap: 1.5rem;
65
+ margin-top: 1.5rem;
66
+ }
67
+
68
+ &__backup-codes {
69
+ > ul {
70
+ padding: 1rem;
71
+ background-color: var(--theme-elevation-50);
72
+ border: 1px solid var(--theme-elevation-100);
73
+ border-radius: 4px;
74
+ columns: 2;
75
+ font-family: monospace;
76
+ margin-bottom: 1rem;
77
+ list-style: none;
78
+ text-align: center;
79
+ }
80
+ }
81
+
82
+ &__qrcode {
83
+ display: flex;
84
+ align-items: center;
85
+ justify-content: center;
86
+ margin-bottom: 0.5rem;
87
+ }
88
+
89
+ &__uri {
90
+ display: flex;
91
+ align-items: center;
92
+ gap: 0.5rem;
93
+ border-radius: 3px;
94
+ background: var(--theme-elevation-100, #f3f3f3);
95
+ padding: 0.5rem 1rem;
96
+ font-size: 0.95em;
97
+ word-break: break-all;
98
+ }
99
+
100
+ &__copy-btn {
101
+ margin-block: 0.5rem;
102
+ margin-inline: auto;
103
+ display: flex;
104
+ align-items: center;
105
+ gap: 0.5rem;
106
+ }
107
+
108
+ &__copy-icon {
109
+ margin-right: 0.25rem;
110
+ vertical-align: middle;
111
+ }
112
+ }
113
+ }
@@ -2,5 +2,6 @@ import { AdminButtons } from '../components/admin-buttons';
2
2
  import { AdminInviteButton } from '../components/admin-invite-button';
3
3
  import { LogoutButton } from '../components/logout-button';
4
4
  import { AdminSocialProviderButtons } from '../components/social-provider-buttons';
5
- export { AdminButtons, AdminInviteButton, LogoutButton, AdminSocialProviderButtons };
5
+ import { TwoFactorAuth } from '../components/two-factor-auth';
6
+ export { AdminButtons, AdminInviteButton, LogoutButton, AdminSocialProviderButtons, TwoFactorAuth };
6
7
  //# sourceMappingURL=client.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"client.d.ts","sourceRoot":"","sources":["../../../../../src/better-auth/plugin/payload/exports/client.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAA;AAC1D,OAAO,EAAE,iBAAiB,EAAE,MAAM,mCAAmC,CAAA;AACrE,OAAO,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAA;AAC1D,OAAO,EAAE,0BAA0B,EAAE,MAAM,uCAAuC,CAAA;AAElF,OAAO,EAAE,YAAY,EAAE,iBAAiB,EAAE,YAAY,EAAE,0BAA0B,EAAE,CAAA"}
1
+ {"version":3,"file":"client.d.ts","sourceRoot":"","sources":["../../../../../src/better-auth/plugin/payload/exports/client.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAA;AAC1D,OAAO,EAAE,iBAAiB,EAAE,MAAM,mCAAmC,CAAA;AACrE,OAAO,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAA;AAC1D,OAAO,EAAE,0BAA0B,EAAE,MAAM,uCAAuC,CAAA;AAClF,OAAO,EAAE,aAAa,EAAE,MAAM,+BAA+B,CAAA;AAE7D,OAAO,EAAE,YAAY,EAAE,iBAAiB,EAAE,YAAY,EAAE,0BAA0B,EAAE,aAAa,EAAE,CAAA"}
@@ -2,6 +2,7 @@ import { AdminButtons } from "../components/admin-buttons";
2
2
  import { AdminInviteButton } from "../components/admin-invite-button";
3
3
  import { LogoutButton } from "../components/logout-button";
4
4
  import { AdminSocialProviderButtons } from "../components/social-provider-buttons";
5
- export { AdminButtons, AdminInviteButton, LogoutButton, AdminSocialProviderButtons };
5
+ import { TwoFactorAuth } from "../components/two-factor-auth";
6
+ export { AdminButtons, AdminInviteButton, LogoutButton, AdminSocialProviderButtons, TwoFactorAuth };
6
7
 
7
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9iZXR0ZXItYXV0aC9wbHVnaW4vcGF5bG9hZC9leHBvcnRzL2NsaWVudC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBZG1pbkJ1dHRvbnMgfSBmcm9tICcuLi9jb21wb25lbnRzL2FkbWluLWJ1dHRvbnMnXG5pbXBvcnQgeyBBZG1pbkludml0ZUJ1dHRvbiB9IGZyb20gJy4uL2NvbXBvbmVudHMvYWRtaW4taW52aXRlLWJ1dHRvbidcbmltcG9ydCB7IExvZ291dEJ1dHRvbiB9IGZyb20gJy4uL2NvbXBvbmVudHMvbG9nb3V0LWJ1dHRvbidcbmltcG9ydCB7IEFkbWluU29jaWFsUHJvdmlkZXJCdXR0b25zIH0gZnJvbSAnLi4vY29tcG9uZW50cy9zb2NpYWwtcHJvdmlkZXItYnV0dG9ucydcblxuZXhwb3J0IHsgQWRtaW5CdXR0b25zLCBBZG1pbkludml0ZUJ1dHRvbiwgTG9nb3V0QnV0dG9uLCBBZG1pblNvY2lhbFByb3ZpZGVyQnV0dG9ucyB9XG4iXSwibmFtZXMiOlsiQWRtaW5CdXR0b25zIiwiQWRtaW5JbnZpdGVCdXR0b24iLCJMb2dvdXRCdXR0b24iLCJBZG1pblNvY2lhbFByb3ZpZGVyQnV0dG9ucyJdLCJtYXBwaW5ncyI6IkFBQUEsU0FBU0EsWUFBWSxRQUFRLDhCQUE2QjtBQUMxRCxTQUFTQyxpQkFBaUIsUUFBUSxvQ0FBbUM7QUFDckUsU0FBU0MsWUFBWSxRQUFRLDhCQUE2QjtBQUMxRCxTQUFTQywwQkFBMEIsUUFBUSx3Q0FBdUM7QUFFbEYsU0FBU0gsWUFBWSxFQUFFQyxpQkFBaUIsRUFBRUMsWUFBWSxFQUFFQywwQkFBMEIsR0FBRSJ9
8
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9iZXR0ZXItYXV0aC9wbHVnaW4vcGF5bG9hZC9leHBvcnRzL2NsaWVudC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBZG1pbkJ1dHRvbnMgfSBmcm9tICcuLi9jb21wb25lbnRzL2FkbWluLWJ1dHRvbnMnXG5pbXBvcnQgeyBBZG1pbkludml0ZUJ1dHRvbiB9IGZyb20gJy4uL2NvbXBvbmVudHMvYWRtaW4taW52aXRlLWJ1dHRvbidcbmltcG9ydCB7IExvZ291dEJ1dHRvbiB9IGZyb20gJy4uL2NvbXBvbmVudHMvbG9nb3V0LWJ1dHRvbidcbmltcG9ydCB7IEFkbWluU29jaWFsUHJvdmlkZXJCdXR0b25zIH0gZnJvbSAnLi4vY29tcG9uZW50cy9zb2NpYWwtcHJvdmlkZXItYnV0dG9ucydcbmltcG9ydCB7IFR3b0ZhY3RvckF1dGggfSBmcm9tICcuLi9jb21wb25lbnRzL3R3by1mYWN0b3ItYXV0aCdcblxuZXhwb3J0IHsgQWRtaW5CdXR0b25zLCBBZG1pbkludml0ZUJ1dHRvbiwgTG9nb3V0QnV0dG9uLCBBZG1pblNvY2lhbFByb3ZpZGVyQnV0dG9ucywgVHdvRmFjdG9yQXV0aCB9XG4iXSwibmFtZXMiOlsiQWRtaW5CdXR0b25zIiwiQWRtaW5JbnZpdGVCdXR0b24iLCJMb2dvdXRCdXR0b24iLCJBZG1pblNvY2lhbFByb3ZpZGVyQnV0dG9ucyIsIlR3b0ZhY3RvckF1dGgiXSwibWFwcGluZ3MiOiJBQUFBLFNBQVNBLFlBQVksUUFBUSw4QkFBNkI7QUFDMUQsU0FBU0MsaUJBQWlCLFFBQVEsb0NBQW1DO0FBQ3JFLFNBQVNDLFlBQVksUUFBUSw4QkFBNkI7QUFDMUQsU0FBU0MsMEJBQTBCLFFBQVEsd0NBQXVDO0FBQ2xGLFNBQVNDLGFBQWEsUUFBUSxnQ0FBK0I7QUFFN0QsU0FBU0osWUFBWSxFQUFFQyxpQkFBaUIsRUFBRUMsWUFBWSxFQUFFQywwQkFBMEIsRUFBRUMsYUFBYSxHQUFFIn0=
@@ -3,5 +3,6 @@ import AdminLogin from '../views/admin-login';
3
3
  import ForgotPassword from '../views/forgot-password';
4
4
  import ResetPassword from '../views/reset-password';
5
5
  import RSCRedirect from '../components/rsc-redirect';
6
- export { AdminSignup, AdminLogin, ForgotPassword, ResetPassword, RSCRedirect };
6
+ import TwoFactorVerify from '../views/two-factor-verify';
7
+ export { AdminSignup, AdminLogin, ForgotPassword, ResetPassword, RSCRedirect, TwoFactorVerify };
7
8
  //# sourceMappingURL=rsc.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"rsc.d.ts","sourceRoot":"","sources":["../../../../../src/better-auth/plugin/payload/exports/rsc.ts"],"names":[],"mappings":"AAAA,OAAO,WAAW,MAAM,uBAAuB,CAAA;AAC/C,OAAO,UAAU,MAAM,sBAAsB,CAAA;AAC7C,OAAO,cAAc,MAAM,0BAA0B,CAAA;AACrD,OAAO,aAAa,MAAM,yBAAyB,CAAA;AACnD,OAAO,WAAW,MAAM,4BAA4B,CAAA;AAEpD,OAAO,EAAE,WAAW,EAAE,UAAU,EAAE,cAAc,EAAE,aAAa,EAAE,WAAW,EAAE,CAAA"}
1
+ {"version":3,"file":"rsc.d.ts","sourceRoot":"","sources":["../../../../../src/better-auth/plugin/payload/exports/rsc.ts"],"names":[],"mappings":"AAAA,OAAO,WAAW,MAAM,uBAAuB,CAAA;AAC/C,OAAO,UAAU,MAAM,sBAAsB,CAAA;AAC7C,OAAO,cAAc,MAAM,0BAA0B,CAAA;AACrD,OAAO,aAAa,MAAM,yBAAyB,CAAA;AACnD,OAAO,WAAW,MAAM,4BAA4B,CAAA;AACpD,OAAO,eAAe,MAAM,4BAA4B,CAAA;AAExD,OAAO,EAAE,WAAW,EAAE,UAAU,EAAE,cAAc,EAAE,aAAa,EAAE,WAAW,EAAE,eAAe,EAAE,CAAA"}
@@ -3,6 +3,7 @@ import AdminLogin from "../views/admin-login";
3
3
  import ForgotPassword from "../views/forgot-password";
4
4
  import ResetPassword from "../views/reset-password";
5
5
  import RSCRedirect from "../components/rsc-redirect";
6
- export { AdminSignup, AdminLogin, ForgotPassword, ResetPassword, RSCRedirect };
6
+ import TwoFactorVerify from "../views/two-factor-verify";
7
+ export { AdminSignup, AdminLogin, ForgotPassword, ResetPassword, RSCRedirect, TwoFactorVerify };
7
8
 
8
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9iZXR0ZXItYXV0aC9wbHVnaW4vcGF5bG9hZC9leHBvcnRzL3JzYy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgQWRtaW5TaWdudXAgZnJvbSAnLi4vdmlld3MvYWRtaW4tc2lnbnVwJ1xuaW1wb3J0IEFkbWluTG9naW4gZnJvbSAnLi4vdmlld3MvYWRtaW4tbG9naW4nXG5pbXBvcnQgRm9yZ290UGFzc3dvcmQgZnJvbSAnLi4vdmlld3MvZm9yZ290LXBhc3N3b3JkJ1xuaW1wb3J0IFJlc2V0UGFzc3dvcmQgZnJvbSAnLi4vdmlld3MvcmVzZXQtcGFzc3dvcmQnXG5pbXBvcnQgUlNDUmVkaXJlY3QgZnJvbSAnLi4vY29tcG9uZW50cy9yc2MtcmVkaXJlY3QnXG5cbmV4cG9ydCB7IEFkbWluU2lnbnVwLCBBZG1pbkxvZ2luLCBGb3Jnb3RQYXNzd29yZCwgUmVzZXRQYXNzd29yZCwgUlNDUmVkaXJlY3QgfVxuIl0sIm5hbWVzIjpbIkFkbWluU2lnbnVwIiwiQWRtaW5Mb2dpbiIsIkZvcmdvdFBhc3N3b3JkIiwiUmVzZXRQYXNzd29yZCIsIlJTQ1JlZGlyZWN0Il0sIm1hcHBpbmdzIjoiQUFBQSxPQUFPQSxpQkFBaUIsd0JBQXVCO0FBQy9DLE9BQU9DLGdCQUFnQix1QkFBc0I7QUFDN0MsT0FBT0Msb0JBQW9CLDJCQUEwQjtBQUNyRCxPQUFPQyxtQkFBbUIsMEJBQXlCO0FBQ25ELE9BQU9DLGlCQUFpQiw2QkFBNEI7QUFFcEQsU0FBU0osV0FBVyxFQUFFQyxVQUFVLEVBQUVDLGNBQWMsRUFBRUMsYUFBYSxFQUFFQyxXQUFXLEdBQUUifQ==
9
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9iZXR0ZXItYXV0aC9wbHVnaW4vcGF5bG9hZC9leHBvcnRzL3JzYy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgQWRtaW5TaWdudXAgZnJvbSAnLi4vdmlld3MvYWRtaW4tc2lnbnVwJ1xuaW1wb3J0IEFkbWluTG9naW4gZnJvbSAnLi4vdmlld3MvYWRtaW4tbG9naW4nXG5pbXBvcnQgRm9yZ290UGFzc3dvcmQgZnJvbSAnLi4vdmlld3MvZm9yZ290LXBhc3N3b3JkJ1xuaW1wb3J0IFJlc2V0UGFzc3dvcmQgZnJvbSAnLi4vdmlld3MvcmVzZXQtcGFzc3dvcmQnXG5pbXBvcnQgUlNDUmVkaXJlY3QgZnJvbSAnLi4vY29tcG9uZW50cy9yc2MtcmVkaXJlY3QnXG5pbXBvcnQgVHdvRmFjdG9yVmVyaWZ5IGZyb20gJy4uL3ZpZXdzL3R3by1mYWN0b3ItdmVyaWZ5J1xuXG5leHBvcnQgeyBBZG1pblNpZ251cCwgQWRtaW5Mb2dpbiwgRm9yZ290UGFzc3dvcmQsIFJlc2V0UGFzc3dvcmQsIFJTQ1JlZGlyZWN0LCBUd29GYWN0b3JWZXJpZnkgfVxuIl0sIm5hbWVzIjpbIkFkbWluU2lnbnVwIiwiQWRtaW5Mb2dpbiIsIkZvcmdvdFBhc3N3b3JkIiwiUmVzZXRQYXNzd29yZCIsIlJTQ1JlZGlyZWN0IiwiVHdvRmFjdG9yVmVyaWZ5Il0sIm1hcHBpbmdzIjoiQUFBQSxPQUFPQSxpQkFBaUIsd0JBQXVCO0FBQy9DLE9BQU9DLGdCQUFnQix1QkFBc0I7QUFDN0MsT0FBT0Msb0JBQW9CLDJCQUEwQjtBQUNyRCxPQUFPQyxtQkFBbUIsMEJBQXlCO0FBQ25ELE9BQU9DLGlCQUFpQiw2QkFBNEI7QUFDcEQsT0FBT0MscUJBQXFCLDZCQUE0QjtBQUV4RCxTQUFTTCxXQUFXLEVBQUVDLFVBQVUsRUFBRUMsY0FBYyxFQUFFQyxhQUFhLEVBQUVDLFdBQVcsRUFBRUMsZUFBZSxHQUFFIn0=
@@ -1 +1 @@
1
- {"version":3,"file":"client.d.ts","sourceRoot":"","sources":["../../../../../../src/better-auth/plugin/payload/views/admin-login/client.tsx"],"names":[],"mappings":"AAKA,OAAO,KAA4B,MAAM,OAAO,CAAA;AAChD,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,4BAA4B,CAAA;AAC7D,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,SAAS,CAAA;AAUvD,KAAK,qBAAqB,GAAG;IAC3B,YAAY,EAAE,WAAW,EAAE,CAAA;IAC3B,iBAAiB,EAAE,OAAO,CAAA;IAC1B,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,eAAe,CAAC,EAAE,MAAM,CAAA;IACxB,eAAe,CAAC,EAAE,MAAM,CAAA;IACxB,YAAY,EAAE;QAAE,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,EAAE,GAAG,SAAS,CAAA;KAAE,CAAA;IAC9D,iBAAiB,EAAE,KAAK,GAAG,wBAAwB,CAAA;CACpD,CAAA;AAmHD,eAAO,MAAM,gBAAgB,EAAE,KAAK,CAAC,EAAE,CAAC,qBAAqB,CA6B5D,CAAA"}
1
+ {"version":3,"file":"client.d.ts","sourceRoot":"","sources":["../../../../../../src/better-auth/plugin/payload/views/admin-login/client.tsx"],"names":[],"mappings":"AAKA,OAAO,KAA4B,MAAM,OAAO,CAAA;AAChD,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,4BAA4B,CAAA;AAC7D,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,SAAS,CAAA;AAYvD,KAAK,qBAAqB,GAAG;IAC3B,YAAY,EAAE,WAAW,EAAE,CAAA;IAC3B,iBAAiB,EAAE,OAAO,CAAA;IAC1B,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,eAAe,CAAC,EAAE,MAAM,CAAA;IACxB,eAAe,CAAC,EAAE,MAAM,CAAA;IACxB,YAAY,EAAE;QAAE,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,EAAE,GAAG,SAAS,CAAA;KAAE,CAAA;IAC9D,iBAAiB,EAAE,KAAK,GAAG,wBAAwB,CAAA;CACpD,CAAA;AAiID,eAAO,MAAM,gBAAgB,EAAE,KAAK,CAAC,EAAE,CAAC,qBAAqB,CA6B5D,CAAA"}
@@ -10,22 +10,31 @@ import { Form, FormError, FormInputWrap } from "../../../../../shared/form/ui";
10
10
  import { FormHeader } from "../../../../../shared/form/ui/header";
11
11
  import { createLoginSchema, isValidEmail } from "../../../../../shared/form/validation";
12
12
  import { createAuthClient } from "better-auth/client";
13
- import { usernameClient } from "better-auth/client/plugins";
13
+ import { usernameClient, twoFactorClient } from "better-auth/client/plugins";
14
14
  import { formatAdminURL, getLoginOptions } from "payload/shared";
15
+ import { useRouter } from "next/navigation";
16
+ import { valueOrDefaultString } from "../../../../../shared/utils/value-or-default";
15
17
  const baseClass = 'login__form';
16
18
  const LoginForm = ({ hasUsernamePlugin, prefillEmail, prefillPassword, prefillUsername, searchParams, loginWithUsername })=>{
17
19
  const { config } = useConfig();
20
+ const router = useRouter();
21
+ const adminRoute = valueOrDefaultString(config?.routes?.admin, '/admin');
18
22
  const { t } = useTranslation();
19
23
  const { canLoginWithEmail, canLoginWithUsername } = getLoginOptions(loginWithUsername);
20
24
  const searchParamError = searchParams?.error;
21
- const redirectUrl = getSafeRedirect(searchParams?.redirect, config.routes.admin);
25
+ const redirectUrl = getSafeRedirect(searchParams?.redirect, adminRoute);
22
26
  const forgotPasswordUrl = formatAdminURL({
23
- adminRoute: config.routes.admin,
27
+ adminRoute: adminRoute,
24
28
  path: adminRoutes?.forgotPassword
25
29
  });
26
30
  const authClient = useMemo(()=>createAuthClient({
27
31
  plugins: [
28
- usernameClient()
32
+ usernameClient(),
33
+ twoFactorClient({
34
+ onTwoFactorRedirect () {
35
+ router.push(`${adminRoute}/two-factor-verify?redirect=${redirectUrl}`);
36
+ }
37
+ })
29
38
  ]
30
39
  }), []);
31
40
  const loginType = useMemo(()=>{
@@ -172,4 +181,4 @@ export const AdminLoginClient = ({ loginMethods, hasUsernamePlugin, prefillEmail
172
181
  });
173
182
  };
174
183
 
175
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../../src/better-auth/plugin/payload/views/admin-login/client.tsx"],"sourcesContent":["'use client'\n\nimport { AdminSocialProviderButtons } from '@/better-auth/plugin/payload/components/social-provider-buttons'\nimport { getSafeRedirect } from '@/better-auth/plugin/payload/utils/get-safe-redirect'\nimport { useConfig, Link, toast, useTranslation } from '@payloadcms/ui'\nimport React, { useMemo, useState } from 'react'\nimport type { LoginMethod } from '@/better-auth/plugin/types'\nimport type { LoginWithUsernameOptions } from 'payload'\nimport { adminRoutes } from '@/better-auth/plugin/constants'\nimport { useAppForm } from '@/shared/form'\nimport { Form, FormError, FormInputWrap } from '@/shared/form/ui'\nimport { FormHeader } from '@/shared/form/ui/header'\nimport { createLoginSchema, isValidEmail } from '@/shared/form/validation'\nimport { createAuthClient } from 'better-auth/client'\nimport { usernameClient } from 'better-auth/client/plugins'\nimport { formatAdminURL, getLoginOptions } from 'payload/shared'\n\ntype AdminLoginClientProps = {\n  loginMethods: LoginMethod[]\n  hasUsernamePlugin: boolean\n  prefillEmail?: string\n  prefillPassword?: string\n  prefillUsername?: string\n  searchParams: { [key: string]: string | string[] | undefined }\n  loginWithUsername: false | LoginWithUsernameOptions\n}\n\nconst baseClass = 'login__form'\n\nconst LoginForm: React.FC<{\n  hasUsernamePlugin: boolean\n  prefillEmail?: string\n  prefillPassword?: string\n  prefillUsername?: string\n  searchParams: { [key: string]: string | string[] | undefined }\n  loginWithUsername: false | LoginWithUsernameOptions\n}> = ({\n  hasUsernamePlugin,\n  prefillEmail,\n  prefillPassword,\n  prefillUsername,\n  searchParams,\n  loginWithUsername\n}) => {\n  const { config } = useConfig()\n  const { t } = useTranslation()\n  const { canLoginWithEmail, canLoginWithUsername } = getLoginOptions(loginWithUsername)\n  const searchParamError = searchParams?.error\n  const redirectUrl = getSafeRedirect(searchParams?.redirect as string, config.routes.admin)\n  const forgotPasswordUrl = formatAdminURL({\n    adminRoute: config.routes.admin,\n    path: adminRoutes?.forgotPassword as `/${string}`\n  })\n  const authClient = useMemo(() => createAuthClient({ plugins: [usernameClient()] }), [])\n  const loginType = useMemo(() => {\n    if (canLoginWithEmail && canLoginWithUsername && hasUsernamePlugin) return 'emailOrUsername'\n    if (canLoginWithUsername && hasUsernamePlugin) return 'username'\n    return 'email'\n  }, [canLoginWithEmail, canLoginWithUsername, hasUsernamePlugin])\n  const [requireEmailVerification, setRequireEmailVerification] = useState<boolean>(false)\n\n  if (requireEmailVerification) {\n    return <FormHeader heading=\"Please verify your email\" description={t('authentication:emailSent')} style={{ textAlign: 'center' }} />\n  }\n\n  const loginSchema = createLoginSchema({ t, loginType, canLoginWithUsername })\n\n  const form = useAppForm({\n    defaultValues: {\n      login: prefillEmail ?? prefillUsername ?? '',\n      password: prefillPassword ?? ''\n    },\n    onSubmit: async ({ value }) => {\n      const { login, password } = value\n      const isEmail = isValidEmail(login)\n      try {\n        const { data, error } = await (loginType === 'email' || (loginType === 'emailOrUsername' && isEmail)\n          ? authClient.signIn.email({ email: login, password, callbackURL: redirectUrl })\n          : authClient.signIn.username({ username: login, password }))\n        if (error) {\n          if (error.code === 'EMAIL_NOT_VERIFIED') {\n            setRequireEmailVerification(true)\n          }\n          if (error.message) {\n            toast.error(error.message.charAt(0).toUpperCase() + error.message.slice(1))\n          }\n        }\n        if (data?.token) {\n          toast.success(t('general:success'))\n          window.location.href = redirectUrl\n        }\n      } catch (err) {\n        toast.error(t('error:unknown') || 'An unexpected error occurred')\n      }\n    },\n    validators: {\n      onSubmit: loginSchema\n    }\n  })\n\n  const getLoginTypeLabel = () => {\n    const labels = {\n      email: t('general:email') || 'Email',\n      username: t('authentication:username') || 'Username',\n      emailOrUsername: t('authentication:emailOrUsername') || 'Email or Username'\n    }\n    return labels[loginType]\n  }\n\n  return (\n    <div className={`${baseClass}__wrapper`}>\n      {searchParamError && searchParamError === 'signup_disabled' && <FormError errors={['Sign up is disabled.']} />}\n      <Form\n        className={baseClass}\n        onSubmit={e => {\n          e.preventDefault()\n          void form.handleSubmit()\n        }}\n      >\n        <FormInputWrap className={baseClass}>\n          <form.AppField\n            name=\"login\"\n            children={field => <field.TextField type=\"text\" className=\"email\" autoComplete=\"email\" label={getLoginTypeLabel()} />}\n          />\n          <form.AppField\n            name=\"password\"\n            children={field => (\n              <field.TextField type=\"password\" className=\"password\" autoComplete=\"password\" label={t('general:password')} />\n            )}\n          />\n        </FormInputWrap>\n        <Link href={forgotPasswordUrl} prefetch={false}>\n          {t('authentication:forgotPasswordQuestion')}\n        </Link>\n        <form.AppForm children={<form.Submit label={t('authentication:login')} loadingLabel={t('general:loading')} />} />\n      </Form>\n    </div>\n  )\n}\n\nexport const AdminLoginClient: React.FC<AdminLoginClientProps> = ({\n  loginMethods,\n  hasUsernamePlugin,\n  prefillEmail,\n  prefillPassword,\n  prefillUsername,\n  searchParams,\n  loginWithUsername\n}) => {\n  return (\n    <>\n      {loginMethods.includes('emailPassword') && (\n        <LoginForm\n          hasUsernamePlugin={hasUsernamePlugin}\n          prefillEmail={prefillEmail}\n          prefillPassword={prefillPassword}\n          prefillUsername={prefillUsername}\n          searchParams={searchParams}\n          loginWithUsername={loginWithUsername}\n        />\n      )}\n      <AdminSocialProviderButtons\n        isSignup={false}\n        loginMethods={loginMethods}\n        setLoading={() => {}}\n        redirectUrl={getSafeRedirect(searchParams?.redirect as string, useConfig().config.routes.admin)}\n      />\n    </>\n  )\n}\n"],"names":["AdminSocialProviderButtons","getSafeRedirect","useConfig","Link","toast","useTranslation","React","useMemo","useState","adminRoutes","useAppForm","Form","FormError","FormInputWrap","FormHeader","createLoginSchema","isValidEmail","createAuthClient","usernameClient","formatAdminURL","getLoginOptions","baseClass","LoginForm","hasUsernamePlugin","prefillEmail","prefillPassword","prefillUsername","searchParams","loginWithUsername","config","t","canLoginWithEmail","canLoginWithUsername","searchParamError","error","redirectUrl","redirect","routes","admin","forgotPasswordUrl","adminRoute","path","forgotPassword","authClient","plugins","loginType","requireEmailVerification","setRequireEmailVerification","heading","description","style","textAlign","loginSchema","form","defaultValues","login","password","onSubmit","value","isEmail","data","signIn","email","callbackURL","username","code","message","charAt","toUpperCase","slice","token","success","window","location","href","err","validators","getLoginTypeLabel","labels","emailOrUsername","div","className","errors","e","preventDefault","handleSubmit","AppField","name","children","field","TextField","type","autoComplete","label","prefetch","AppForm","Submit","loadingLabel","AdminLoginClient","loginMethods","includes","isSignup","setLoading"],"mappings":"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"}
184
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../../src/better-auth/plugin/payload/views/admin-login/client.tsx"],"sourcesContent":["'use client'\n\nimport { AdminSocialProviderButtons } from '@/better-auth/plugin/payload/components/social-provider-buttons'\nimport { getSafeRedirect } from '@/better-auth/plugin/payload/utils/get-safe-redirect'\nimport { useConfig, Link, toast, useTranslation } from '@payloadcms/ui'\nimport React, { useMemo, useState } from 'react'\nimport type { LoginMethod } from '@/better-auth/plugin/types'\nimport type { LoginWithUsernameOptions } from 'payload'\nimport { adminRoutes } from '@/better-auth/plugin/constants'\nimport { useAppForm } from '@/shared/form'\nimport { Form, FormError, FormInputWrap } from '@/shared/form/ui'\nimport { FormHeader } from '@/shared/form/ui/header'\nimport { createLoginSchema, isValidEmail } from '@/shared/form/validation'\nimport { createAuthClient } from 'better-auth/client'\nimport { usernameClient, twoFactorClient } from 'better-auth/client/plugins'\nimport { formatAdminURL, getLoginOptions } from 'payload/shared'\nimport { useRouter } from 'next/navigation'\nimport { valueOrDefaultString } from '@/shared/utils/value-or-default'\n\ntype AdminLoginClientProps = {\n  loginMethods: LoginMethod[]\n  hasUsernamePlugin: boolean\n  prefillEmail?: string\n  prefillPassword?: string\n  prefillUsername?: string\n  searchParams: { [key: string]: string | string[] | undefined }\n  loginWithUsername: false | LoginWithUsernameOptions\n}\n\nconst baseClass = 'login__form'\n\nconst LoginForm: React.FC<{\n  hasUsernamePlugin: boolean\n  prefillEmail?: string\n  prefillPassword?: string\n  prefillUsername?: string\n  searchParams: { [key: string]: string | string[] | undefined }\n  loginWithUsername: false | LoginWithUsernameOptions\n}> = ({\n  hasUsernamePlugin,\n  prefillEmail,\n  prefillPassword,\n  prefillUsername,\n  searchParams,\n  loginWithUsername\n}) => {\n  const { config } = useConfig()\n  const router = useRouter()\n  const adminRoute = valueOrDefaultString(config?.routes?.admin, '/admin')\n  const { t } = useTranslation()\n  const { canLoginWithEmail, canLoginWithUsername } = getLoginOptions(loginWithUsername)\n  const searchParamError = searchParams?.error\n  const redirectUrl = getSafeRedirect(searchParams?.redirect as string, adminRoute)\n  const forgotPasswordUrl = formatAdminURL({\n    adminRoute: adminRoute,\n    path: adminRoutes?.forgotPassword as `/${string}`\n  })\n  const authClient = useMemo(() =>\n    createAuthClient({\n      plugins: [\n        usernameClient(),\n        twoFactorClient({\n          onTwoFactorRedirect() {\n            router.push(`${adminRoute}/two-factor-verify?redirect=${redirectUrl}`)\n          }\n        })\n      ]\n    }),\n    []\n  )\n  const loginType = useMemo(() => {\n    if (canLoginWithEmail && canLoginWithUsername && hasUsernamePlugin) return 'emailOrUsername'\n    if (canLoginWithUsername && hasUsernamePlugin) return 'username'\n    return 'email'\n  }, [canLoginWithEmail, canLoginWithUsername, hasUsernamePlugin])\n  const [requireEmailVerification, setRequireEmailVerification] = useState<boolean>(false)\n\n  if (requireEmailVerification) {\n    return <FormHeader heading=\"Please verify your email\" description={t('authentication:emailSent')} style={{ textAlign: 'center' }} />\n  }\n\n  const loginSchema = createLoginSchema({ t, loginType, canLoginWithUsername })\n\n  const form = useAppForm({\n    defaultValues: {\n      login: prefillEmail ?? prefillUsername ?? '',\n      password: prefillPassword ?? ''\n    },\n    onSubmit: async ({ value }) => {\n      const { login, password } = value\n      const isEmail = isValidEmail(login)\n      try {\n        const { data, error } = await (loginType === 'email' || (loginType === 'emailOrUsername' && isEmail)\n          ? authClient.signIn.email({ email: login, password, callbackURL: redirectUrl })\n          : authClient.signIn.username({ username: login, password }))\n        if (error) {\n          if (error.code === 'EMAIL_NOT_VERIFIED') {\n            setRequireEmailVerification(true)\n          }\n          if (error.message) {\n            toast.error(error.message.charAt(0).toUpperCase() + error.message.slice(1))\n          }\n        }\n        if (data?.token) {\n          toast.success(t('general:success'))\n          window.location.href = redirectUrl\n        }\n      } catch (err) {\n        toast.error(t('error:unknown') || 'An unexpected error occurred')\n      }\n    },\n    validators: {\n      onSubmit: loginSchema\n    }\n  })\n\n  const getLoginTypeLabel = () => {\n    const labels = {\n      email: t('general:email') || 'Email',\n      username: t('authentication:username') || 'Username',\n      emailOrUsername: t('authentication:emailOrUsername') || 'Email or Username'\n    }\n    return labels[loginType]\n  }\n\n  return (\n    <div className={`${baseClass}__wrapper`}>\n      {searchParamError && searchParamError === 'signup_disabled' && <FormError errors={['Sign up is disabled.']} />}\n      <Form\n        className={baseClass}\n        onSubmit={e => {\n          e.preventDefault()\n          void form.handleSubmit()\n        }}\n      >\n        <FormInputWrap className={baseClass}>\n          <form.AppField\n            name=\"login\"\n            children={field => <field.TextField type=\"text\" className=\"email\" autoComplete=\"email\" label={getLoginTypeLabel()} />}\n          />\n          <form.AppField\n            name=\"password\"\n            children={field => (\n              <field.TextField type=\"password\" className=\"password\" autoComplete=\"password\" label={t('general:password')} />\n            )}\n          />\n        </FormInputWrap>\n        <Link href={forgotPasswordUrl} prefetch={false}>\n          {t('authentication:forgotPasswordQuestion')}\n        </Link>\n        <form.AppForm children={<form.Submit label={t('authentication:login')} loadingLabel={t('general:loading')} />} />\n      </Form>\n    </div>\n  )\n}\n\nexport const AdminLoginClient: React.FC<AdminLoginClientProps> = ({\n  loginMethods,\n  hasUsernamePlugin,\n  prefillEmail,\n  prefillPassword,\n  prefillUsername,\n  searchParams,\n  loginWithUsername\n}) => {\n  return (\n    <>\n      {loginMethods.includes('emailPassword') && (\n        <LoginForm\n          hasUsernamePlugin={hasUsernamePlugin}\n          prefillEmail={prefillEmail}\n          prefillPassword={prefillPassword}\n          prefillUsername={prefillUsername}\n          searchParams={searchParams}\n          loginWithUsername={loginWithUsername}\n        />\n      )}\n      <AdminSocialProviderButtons\n        isSignup={false}\n        loginMethods={loginMethods}\n        setLoading={() => {}}\n        redirectUrl={getSafeRedirect(searchParams?.redirect as string, useConfig().config.routes.admin)}\n      />\n    </>\n  )\n}\n"],"names":["AdminSocialProviderButtons","getSafeRedirect","useConfig","Link","toast","useTranslation","React","useMemo","useState","adminRoutes","useAppForm","Form","FormError","FormInputWrap","FormHeader","createLoginSchema","isValidEmail","createAuthClient","usernameClient","twoFactorClient","formatAdminURL","getLoginOptions","useRouter","valueOrDefaultString","baseClass","LoginForm","hasUsernamePlugin","prefillEmail","prefillPassword","prefillUsername","searchParams","loginWithUsername","config","router","adminRoute","routes","admin","t","canLoginWithEmail","canLoginWithUsername","searchParamError","error","redirectUrl","redirect","forgotPasswordUrl","path","forgotPassword","authClient","plugins","onTwoFactorRedirect","push","loginType","requireEmailVerification","setRequireEmailVerification","heading","description","style","textAlign","loginSchema","form","defaultValues","login","password","onSubmit","value","isEmail","data","signIn","email","callbackURL","username","code","message","charAt","toUpperCase","slice","token","success","window","location","href","err","validators","getLoginTypeLabel","labels","emailOrUsername","div","className","errors","e","preventDefault","handleSubmit","AppField","name","children","field","TextField","type","autoComplete","label","prefetch","AppForm","Submit","loadingLabel","AdminLoginClient","loginMethods","includes","isSignup","setLoading"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../../src/better-auth/plugin/payload/views/admin-login/index.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AAWzB,OAAO,EAAE,KAAK,oBAAoB,EAAoB,MAAM,SAAS,CAAA;AACrE,OAAO,KAAK,EAAE,uBAAuB,EAAE,0BAA0B,EAAE,MAAM,4BAA4B,CAAA;AAErG,eAAO,MAAM,cAAc,UAAU,CAAA;AAErC,KAAK,eAAe,GAAG,oBAAoB,GAAG;IAC5C,aAAa,EAAE,uBAAuB,CAAA;IACtC,iBAAiB,EAAE,0BAA0B,CAAA;CAC9C,CAAA;AAED,QAAA,MAAM,UAAU,EAAE,KAAK,CAAC,EAAE,CAAC,eAAe,CAmIzC,CAAA;AAED,eAAe,UAAU,CAAA"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../../src/better-auth/plugin/payload/views/admin-login/index.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AAWzB,OAAO,EAAE,KAAK,oBAAoB,EAAoB,MAAM,SAAS,CAAA;AACrE,OAAO,KAAK,EAAE,uBAAuB,EAAE,0BAA0B,EAAE,MAAM,4BAA4B,CAAA;AAErG,eAAO,MAAM,cAAc,UAAU,CAAA;AAErC,KAAK,eAAe,GAAG,oBAAoB,GAAG;IAC5C,aAAa,EAAE,uBAAuB,CAAA;IACtC,iBAAiB,EAAE,0BAA0B,CAAA;CAC9C,CAAA;AAED,QAAA,MAAM,UAAU,EAAE,KAAK,CAAC,EAAE,CAAC,eAAe,CAkIzC,CAAA;AAED,eAAe,UAAU,CAAA"}
@@ -5,7 +5,6 @@ import { redirect } from "next/navigation";
5
5
  import { Logo } from "../../../../../shared/components/logo";
6
6
  import { getSafeRedirect } from "../../utils/get-safe-redirect";
7
7
  import { MinimalTemplate } from "@payloadcms/next/templates";
8
- import { checkPasskeyPlugin } from "../../../helpers/check-passkey-plugin";
9
8
  import { checkUsernamePlugin } from "../../../helpers/check-username-plugin";
10
9
  import { RenderServerComponent } from "@payloadcms/ui/elements/RenderServerComponent";
11
10
  import { adminRoutes, baseCollectionSlugs, defaults } from "../../../constants";
@@ -63,7 +62,6 @@ const AdminLogin = async ({ initPageResult, params, searchParams, pluginOptions,
63
62
  const prefillEmail = prefillAutoLogin && typeof config.admin?.autoLogin === 'object' ? config.admin?.autoLogin.email : undefined;
64
63
  const prefillPassword = prefillAutoLogin && typeof config.admin?.autoLogin === 'object' ? config.admin?.autoLogin.password : undefined;
65
64
  const hasUsernamePlugin = checkUsernamePlugin(betterAuthOptions);
66
- const hasPasskeyPlugin = checkPasskeyPlugin(betterAuthOptions);
67
65
  const loginMethods = pluginOptions.admin?.loginMethods ?? [];
68
66
  const loginWithUsername = collections?.[userSlug]?.config.auth.loginWithUsername;
69
67
  const canLoginWithUsername = (hasUsernamePlugin && loginWithUsername) ?? false;
@@ -122,4 +120,4 @@ const AdminLogin = async ({ initPageResult, params, searchParams, pluginOptions,
122
120
  };
123
121
  export default AdminLogin;
124
122
 
125
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../../src/better-auth/plugin/payload/views/admin-login/index.tsx"],"sourcesContent":["import React from 'react'\nimport { AdminLoginClient } from './client'\nimport { redirect } from 'next/navigation'\nimport { Logo } from '@/shared/components/logo'\nimport { getSafeRedirect } from '@/better-auth/plugin/payload/utils/get-safe-redirect'\nimport { MinimalTemplate } from '@payloadcms/next/templates'\nimport { checkPasskeyPlugin } from '@/better-auth/plugin/helpers/check-passkey-plugin'\nimport { checkUsernamePlugin } from '@/better-auth/plugin/helpers/check-username-plugin'\nimport { RenderServerComponent } from '@payloadcms/ui/elements/RenderServerComponent'\nimport { adminRoutes, baseCollectionSlugs, defaults } from '@/better-auth/plugin/constants'\n\nimport { type AdminViewServerProps, type ServerProps } from 'payload'\nimport type { BetterAuthPluginOptions, SanitizedBetterAuthOptions } from '@/better-auth/plugin/types'\n\nexport const loginBaseClass = 'login'\n\ntype AdminLoginProps = AdminViewServerProps & {\n  pluginOptions: BetterAuthPluginOptions\n  betterAuthOptions: SanitizedBetterAuthOptions\n}\n\nconst AdminLogin: React.FC<AdminLoginProps> = async ({\n  initPageResult,\n  params,\n  searchParams,\n  pluginOptions,\n  betterAuthOptions\n}: AdminLoginProps) => {\n  const { locale, permissions, req } = initPageResult\n  const {\n    i18n,\n    payload: { config, collections },\n    payload,\n    user\n  } = req\n\n  const {\n    admin: { components: { afterLogin, beforeLogin } = {}, user: userSlug },\n    routes: { admin: adminRoute }\n  } = config\n\n  const invitationsCollection = pluginOptions.adminInvitations?.slug ?? baseCollectionSlugs.adminInvitations\n  const adminRole = pluginOptions.users?.defaultAdminRole ?? defaults.adminRole\n  const redirectUrl = getSafeRedirect(searchParams?.redirect ?? '', adminRoute)\n\n  if (user) {\n    redirect(redirectUrl)\n  }\n\n  const adminCount = await req.payload.count({\n    collection: userSlug,\n    where: {\n      role: {\n        equals: adminRole\n      }\n    }\n  })\n\n  if (adminCount.totalDocs === 0) {\n    // Check if we already have an admin invitation\n    const existingInvitations = await req.payload.find({\n      collection: invitationsCollection,\n      where: {\n        role: {\n          equals: adminRole\n        }\n      }\n    })\n\n    let token\n\n    if (existingInvitations.totalDocs > 0) {\n      // Use existing token\n      token = existingInvitations.docs[0].token\n    } else {\n      // Generate a new secure invite token\n      token = crypto.randomUUID()\n      await req.payload.create({\n        collection: invitationsCollection,\n        data: {\n          role: adminRole,\n          token\n        }\n      })\n    }\n\n    redirect(`${adminRoute}${adminRoutes.adminSignup}?token=${token}`)\n  }\n\n  // Filter out the first component from afterLogin array or set to undefined if not more than 1\n  // This is because of the custom login redirect component, we don't want an infinite loop\n  const filteredAfterLogin = Array.isArray(afterLogin) && afterLogin.length > 1 ? afterLogin.slice(1) : undefined\n  const prefillAutoLogin = typeof config.admin?.autoLogin === 'object' && config.admin?.autoLogin.prefillOnly\n  const prefillUsername = prefillAutoLogin && typeof config.admin?.autoLogin === 'object' ? config.admin?.autoLogin.username : undefined\n  const prefillEmail = prefillAutoLogin && typeof config.admin?.autoLogin === 'object' ? config.admin?.autoLogin.email : undefined\n  const prefillPassword = prefillAutoLogin && typeof config.admin?.autoLogin === 'object' ? config.admin?.autoLogin.password : undefined\n  const hasUsernamePlugin = checkUsernamePlugin(betterAuthOptions)\n  const hasPasskeyPlugin = checkPasskeyPlugin(betterAuthOptions)\n  const loginMethods = pluginOptions.admin?.loginMethods ?? []\n  const loginWithUsername = collections?.[userSlug]?.config.auth.loginWithUsername\n  const canLoginWithUsername = (hasUsernamePlugin && loginWithUsername) ?? false\n\n  return (\n    <MinimalTemplate className={loginBaseClass}>\n      <div className={`${loginBaseClass}__brand`}>\n        <Logo\n          i18n={i18n}\n          locale={locale}\n          params={params}\n          payload={payload}\n          permissions={permissions}\n          searchParams={searchParams}\n          user={user ?? undefined}\n        />\n      </div>\n      {RenderServerComponent({\n        Component: beforeLogin,\n        importMap: payload.importMap,\n        serverProps: {\n          i18n,\n          locale,\n          params,\n          payload,\n          permissions,\n          searchParams,\n          user: user ?? undefined\n        } satisfies ServerProps\n      })}\n      <AdminLoginClient\n        loginWithUsername={canLoginWithUsername}\n        hasUsernamePlugin={hasUsernamePlugin}\n        loginMethods={loginMethods}\n        prefillEmail={prefillEmail}\n        prefillPassword={prefillPassword}\n        prefillUsername={prefillUsername}\n        searchParams={searchParams ?? {}}\n      />\n      {RenderServerComponent({\n        Component: filteredAfterLogin,\n        importMap: payload.importMap,\n        serverProps: {\n          i18n,\n          locale,\n          params,\n          payload,\n          permissions,\n          searchParams,\n          user: user ?? undefined\n        } satisfies ServerProps\n      })}\n    </MinimalTemplate>\n  )\n}\n\nexport default AdminLogin\n"],"names":["React","AdminLoginClient","redirect","Logo","getSafeRedirect","MinimalTemplate","checkPasskeyPlugin","checkUsernamePlugin","RenderServerComponent","adminRoutes","baseCollectionSlugs","defaults","loginBaseClass","AdminLogin","initPageResult","params","searchParams","pluginOptions","betterAuthOptions","locale","permissions","req","i18n","payload","config","collections","user","admin","components","afterLogin","beforeLogin","userSlug","routes","adminRoute","invitationsCollection","adminInvitations","slug","adminRole","users","defaultAdminRole","redirectUrl","adminCount","count","collection","where","role","equals","totalDocs","existingInvitations","find","token","docs","crypto","randomUUID","create","data","adminSignup","filteredAfterLogin","Array","isArray","length","slice","undefined","prefillAutoLogin","autoLogin","prefillOnly","prefillUsername","username","prefillEmail","email","prefillPassword","password","hasUsernamePlugin","hasPasskeyPlugin","loginMethods","loginWithUsername","auth","canLoginWithUsername","className","div","Component","importMap","serverProps"],"mappings":"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"}
123
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../../src/better-auth/plugin/payload/views/admin-login/index.tsx"],"sourcesContent":["import React from 'react'\nimport { AdminLoginClient } from './client'\nimport { redirect } from 'next/navigation'\nimport { Logo } from '@/shared/components/logo'\nimport { getSafeRedirect } from '@/better-auth/plugin/payload/utils/get-safe-redirect'\nimport { MinimalTemplate } from '@payloadcms/next/templates'\nimport { checkPasskeyPlugin } from '@/better-auth/plugin/helpers/check-passkey-plugin'\nimport { checkUsernamePlugin } from '@/better-auth/plugin/helpers/check-username-plugin'\nimport { RenderServerComponent } from '@payloadcms/ui/elements/RenderServerComponent'\nimport { adminRoutes, baseCollectionSlugs, defaults } from '@/better-auth/plugin/constants'\n\nimport { type AdminViewServerProps, type ServerProps } from 'payload'\nimport type { BetterAuthPluginOptions, SanitizedBetterAuthOptions } from '@/better-auth/plugin/types'\n\nexport const loginBaseClass = 'login'\n\ntype AdminLoginProps = AdminViewServerProps & {\n  pluginOptions: BetterAuthPluginOptions\n  betterAuthOptions: SanitizedBetterAuthOptions\n}\n\nconst AdminLogin: React.FC<AdminLoginProps> = async ({\n  initPageResult,\n  params,\n  searchParams,\n  pluginOptions,\n  betterAuthOptions\n}: AdminLoginProps) => {\n  const { locale, permissions, req } = initPageResult\n  const {\n    i18n,\n    payload: { config, collections },\n    payload,\n    user\n  } = req\n\n  const {\n    admin: { components: { afterLogin, beforeLogin } = {}, user: userSlug },\n    routes: { admin: adminRoute }\n  } = config\n\n  const invitationsCollection = pluginOptions.adminInvitations?.slug ?? baseCollectionSlugs.adminInvitations\n  const adminRole = pluginOptions.users?.defaultAdminRole ?? defaults.adminRole\n  const redirectUrl = getSafeRedirect(searchParams?.redirect ?? '', adminRoute)\n\n  if (user) {\n    redirect(redirectUrl)\n  }\n\n  const adminCount = await req.payload.count({\n    collection: userSlug,\n    where: {\n      role: {\n        equals: adminRole\n      }\n    }\n  })\n\n  if (adminCount.totalDocs === 0) {\n    // Check if we already have an admin invitation\n    const existingInvitations = await req.payload.find({\n      collection: invitationsCollection,\n      where: {\n        role: {\n          equals: adminRole\n        }\n      }\n    })\n\n    let token\n\n    if (existingInvitations.totalDocs > 0) {\n      // Use existing token\n      token = existingInvitations.docs[0].token\n    } else {\n      // Generate a new secure invite token\n      token = crypto.randomUUID()\n      await req.payload.create({\n        collection: invitationsCollection,\n        data: {\n          role: adminRole,\n          token\n        }\n      })\n    }\n\n    redirect(`${adminRoute}${adminRoutes.adminSignup}?token=${token}`)\n  }\n\n  // Filter out the first component from afterLogin array or set to undefined if not more than 1\n  // This is because of the custom login redirect component, we don't want an infinite loop\n  const filteredAfterLogin = Array.isArray(afterLogin) && afterLogin.length > 1 ? afterLogin.slice(1) : undefined\n  const prefillAutoLogin = typeof config.admin?.autoLogin === 'object' && config.admin?.autoLogin.prefillOnly\n  const prefillUsername = prefillAutoLogin && typeof config.admin?.autoLogin === 'object' ? config.admin?.autoLogin.username : undefined\n  const prefillEmail = prefillAutoLogin && typeof config.admin?.autoLogin === 'object' ? config.admin?.autoLogin.email : undefined\n  const prefillPassword = prefillAutoLogin && typeof config.admin?.autoLogin === 'object' ? config.admin?.autoLogin.password : undefined\n  const hasUsernamePlugin = checkUsernamePlugin(betterAuthOptions)\n  const loginMethods = pluginOptions.admin?.loginMethods ?? []\n  const loginWithUsername = collections?.[userSlug]?.config.auth.loginWithUsername\n  const canLoginWithUsername = (hasUsernamePlugin && loginWithUsername) ?? false\n\n  return (\n    <MinimalTemplate className={loginBaseClass}>\n      <div className={`${loginBaseClass}__brand`}>\n        <Logo\n          i18n={i18n}\n          locale={locale}\n          params={params}\n          payload={payload}\n          permissions={permissions}\n          searchParams={searchParams}\n          user={user ?? undefined}\n        />\n      </div>\n      {RenderServerComponent({\n        Component: beforeLogin,\n        importMap: payload.importMap,\n        serverProps: {\n          i18n,\n          locale,\n          params,\n          payload,\n          permissions,\n          searchParams,\n          user: user ?? undefined\n        } satisfies ServerProps\n      })}\n      <AdminLoginClient\n        loginWithUsername={canLoginWithUsername}\n        hasUsernamePlugin={hasUsernamePlugin}\n        loginMethods={loginMethods}\n        prefillEmail={prefillEmail}\n        prefillPassword={prefillPassword}\n        prefillUsername={prefillUsername}\n        searchParams={searchParams ?? {}}\n      />\n      {RenderServerComponent({\n        Component: filteredAfterLogin,\n        importMap: payload.importMap,\n        serverProps: {\n          i18n,\n          locale,\n          params,\n          payload,\n          permissions,\n          searchParams,\n          user: user ?? undefined\n        } satisfies ServerProps\n      })}\n    </MinimalTemplate>\n  )\n}\n\nexport default AdminLogin\n"],"names":["React","AdminLoginClient","redirect","Logo","getSafeRedirect","MinimalTemplate","checkUsernamePlugin","RenderServerComponent","adminRoutes","baseCollectionSlugs","defaults","loginBaseClass","AdminLogin","initPageResult","params","searchParams","pluginOptions","betterAuthOptions","locale","permissions","req","i18n","payload","config","collections","user","admin","components","afterLogin","beforeLogin","userSlug","routes","adminRoute","invitationsCollection","adminInvitations","slug","adminRole","users","defaultAdminRole","redirectUrl","adminCount","count","collection","where","role","equals","totalDocs","existingInvitations","find","token","docs","crypto","randomUUID","create","data","adminSignup","filteredAfterLogin","Array","isArray","length","slice","undefined","prefillAutoLogin","autoLogin","prefillOnly","prefillUsername","username","prefillEmail","email","prefillPassword","password","hasUsernamePlugin","loginMethods","loginWithUsername","auth","canLoginWithUsername","className","div","Component","importMap","serverProps"],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ export declare const TwoFactorVerifyForm: ({ redirect, twoFactorDigits }: {
2
+ redirect: string;
3
+ twoFactorDigits?: number;
4
+ }) => import("react").JSX.Element;
5
+ //# sourceMappingURL=client.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"client.d.ts","sourceRoot":"","sources":["../../../../../../src/better-auth/plugin/payload/views/two-factor-verify/client.tsx"],"names":[],"mappings":"AAYA,eAAO,MAAM,mBAAmB,GAAI,+BAAmC;IAAE,QAAQ,EAAE,MAAM,CAAC;IAAC,eAAe,CAAC,EAAE,MAAM,CAAA;CAAE,gCA+CpH,CAAA"}
@@ -0,0 +1,77 @@
1
+ 'use client';
2
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
+ import { useMemo } from "react";
4
+ import { createAuthClient } from "better-auth/react";
5
+ import { twoFactorClient } from "better-auth/client/plugins";
6
+ import { useAppForm } from "../../../../../shared/form";
7
+ import { Form, FormInputWrap } from "../../../../../shared/form/ui";
8
+ import { FormHeader } from "../../../../../shared/form/ui/header";
9
+ import { toast, useTranslation } from "@payloadcms/ui";
10
+ import { z } from "zod";
11
+ import { useRouter } from "next/navigation";
12
+ export const TwoFactorVerifyForm = ({ redirect, twoFactorDigits = 6 })=>{
13
+ const { t } = useTranslation();
14
+ const router = useRouter();
15
+ const authClient = useMemo(()=>createAuthClient({
16
+ plugins: [
17
+ twoFactorClient()
18
+ ]
19
+ }), []);
20
+ const otpSchema = z.object({
21
+ code: z.string().length(twoFactorDigits, `Code must be ${twoFactorDigits} digits`).refine((val)=>/^\d{${twoFactorDigits}}$/.test(val), `Code must be numeric`)
22
+ });
23
+ const form = useAppForm({
24
+ defaultValues: {
25
+ code: ''
26
+ },
27
+ onSubmit: async ({ value })=>{
28
+ const { code } = value;
29
+ const { error } = await authClient.twoFactor.verifyTotp({
30
+ code
31
+ });
32
+ if (error) {
33
+ toast.error(error.message);
34
+ return;
35
+ }
36
+ router.push(redirect);
37
+ toast.success('Two-factor verified!');
38
+ },
39
+ validators: {
40
+ onSubmit: otpSchema
41
+ }
42
+ });
43
+ return /*#__PURE__*/ _jsxs(Form, {
44
+ onSubmit: (e)=>{
45
+ e.preventDefault();
46
+ void form.handleSubmit();
47
+ },
48
+ children: [
49
+ /*#__PURE__*/ _jsx(FormHeader, {
50
+ style: {
51
+ textAlign: 'center'
52
+ },
53
+ heading: 'Verify Two-Factor'
54
+ }),
55
+ /*#__PURE__*/ _jsx(FormInputWrap, {
56
+ children: /*#__PURE__*/ _jsx(form.AppField, {
57
+ name: "code",
58
+ children: (field)=>/*#__PURE__*/ _jsx(field.TextField, {
59
+ type: "text",
60
+ className: "text otp",
61
+ label: '6-digit Code',
62
+ required: true,
63
+ autoComplete: "one-time-password"
64
+ })
65
+ })
66
+ }),
67
+ /*#__PURE__*/ _jsx(form.AppForm, {
68
+ children: /*#__PURE__*/ _jsx(form.Submit, {
69
+ label: t('authentication:verify') || 'Verify',
70
+ loadingLabel: t('general:loading') || 'Loading'
71
+ })
72
+ })
73
+ ]
74
+ });
75
+ };
76
+
77
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9iZXR0ZXItYXV0aC9wbHVnaW4vcGF5bG9hZC92aWV3cy90d28tZmFjdG9yLXZlcmlmeS9jbGllbnQudHN4Il0sInNvdXJjZXNDb250ZW50IjpbIid1c2UgY2xpZW50J1xuXG5pbXBvcnQgeyB1c2VNZW1vIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBjcmVhdGVBdXRoQ2xpZW50IH0gZnJvbSAnYmV0dGVyLWF1dGgvcmVhY3QnXG5pbXBvcnQgeyB0d29GYWN0b3JDbGllbnQgfSBmcm9tICdiZXR0ZXItYXV0aC9jbGllbnQvcGx1Z2lucydcbmltcG9ydCB7IHVzZUFwcEZvcm0gfSBmcm9tICdAL3NoYXJlZC9mb3JtJ1xuaW1wb3J0IHsgRm9ybSwgRm9ybUlucHV0V3JhcCB9IGZyb20gJ0Avc2hhcmVkL2Zvcm0vdWknXG5pbXBvcnQgeyBGb3JtSGVhZGVyIH0gZnJvbSAnQC9zaGFyZWQvZm9ybS91aS9oZWFkZXInXG5pbXBvcnQgeyB0b2FzdCwgdXNlVHJhbnNsYXRpb24gfSBmcm9tICdAcGF5bG9hZGNtcy91aSdcbmltcG9ydCB7IHogfSBmcm9tICd6b2QnXG5pbXBvcnQgeyB1c2VSb3V0ZXIgfSBmcm9tICduZXh0L25hdmlnYXRpb24nXG5cbmV4cG9ydCBjb25zdCBUd29GYWN0b3JWZXJpZnlGb3JtID0gKHsgcmVkaXJlY3QsIHR3b0ZhY3RvckRpZ2l0cyA9IDYgfTogeyByZWRpcmVjdDogc3RyaW5nOyB0d29GYWN0b3JEaWdpdHM/OiBudW1iZXIgfSkgPT4ge1xuICBjb25zdCB7IHQgfSA9IHVzZVRyYW5zbGF0aW9uKClcbiAgY29uc3Qgcm91dGVyID0gdXNlUm91dGVyKClcbiAgY29uc3QgYXV0aENsaWVudCA9IHVzZU1lbW8oKCkgPT4gY3JlYXRlQXV0aENsaWVudCh7IHBsdWdpbnM6IFt0d29GYWN0b3JDbGllbnQoKV0gfSksIFtdKVxuXG4gIGNvbnN0IG90cFNjaGVtYSA9IHoub2JqZWN0KHtcbiAgICBjb2RlOiB6XG4gICAgICAuc3RyaW5nKClcbiAgICAgIC5sZW5ndGgodHdvRmFjdG9yRGlnaXRzLCBgQ29kZSBtdXN0IGJlICR7dHdvRmFjdG9yRGlnaXRzfSBkaWdpdHNgKVxuICAgICAgLnJlZmluZSgodmFsKSA9PiAvXlxcZHske3R3b0ZhY3RvckRpZ2l0c319JC8udGVzdCh2YWwpLCBgQ29kZSBtdXN0IGJlIG51bWVyaWNgKVxuICB9KVxuXG4gIGNvbnN0IGZvcm0gPSB1c2VBcHBGb3JtKHtcbiAgICBkZWZhdWx0VmFsdWVzOiB7IGNvZGU6ICcnIH0sXG4gICAgb25TdWJtaXQ6IGFzeW5jICh7IHZhbHVlIH0pID0+IHtcbiAgICAgIGNvbnN0IHsgY29kZSB9ID0gdmFsdWVcbiAgICAgIGNvbnN0IHsgZXJyb3IgfSA9IGF3YWl0IGF1dGhDbGllbnQudHdvRmFjdG9yLnZlcmlmeVRvdHAoeyBjb2RlIH0pXG4gICAgICBpZiAoZXJyb3IpIHtcbiAgICAgICAgdG9hc3QuZXJyb3IoZXJyb3IubWVzc2FnZSlcbiAgICAgICAgcmV0dXJuXG4gICAgICB9XG4gICAgICByb3V0ZXIucHVzaChyZWRpcmVjdClcbiAgICAgIHRvYXN0LnN1Y2Nlc3MoJ1R3by1mYWN0b3IgdmVyaWZpZWQhJylcbiAgICB9LFxuICAgIHZhbGlkYXRvcnM6IHsgb25TdWJtaXQ6IG90cFNjaGVtYSB9XG4gIH0pXG5cbiAgcmV0dXJuIChcbiAgICA8Rm9ybVxuICAgICAgb25TdWJtaXQ9eyhlKSA9PiB7XG4gICAgICAgIGUucHJldmVudERlZmF1bHQoKVxuICAgICAgICB2b2lkIGZvcm0uaGFuZGxlU3VibWl0KClcbiAgICAgIH19PlxuICAgICAgPEZvcm1IZWFkZXIgc3R5bGU9e3sgdGV4dEFsaWduOiAnY2VudGVyJyB9fSBoZWFkaW5nPXsnVmVyaWZ5IFR3by1GYWN0b3InfSAvPlxuICAgICAgPEZvcm1JbnB1dFdyYXA+XG4gICAgICAgIDxmb3JtLkFwcEZpZWxkXG4gICAgICAgICAgbmFtZT1cImNvZGVcIlxuICAgICAgICAgIGNoaWxkcmVuPXsoZmllbGQpID0+IChcbiAgICAgICAgICAgIDxmaWVsZC5UZXh0RmllbGQgdHlwZT1cInRleHRcIiBjbGFzc05hbWU9XCJ0ZXh0IG90cFwiIGxhYmVsPXsnNi1kaWdpdCBDb2RlJ30gcmVxdWlyZWQgYXV0b0NvbXBsZXRlPVwib25lLXRpbWUtcGFzc3dvcmRcIiAvPlxuICAgICAgICAgICl9XG4gICAgICAgIC8+XG4gICAgICA8L0Zvcm1JbnB1dFdyYXA+XG4gICAgICA8Zm9ybS5BcHBGb3JtXG4gICAgICAgIGNoaWxkcmVuPXs8Zm9ybS5TdWJtaXQgbGFiZWw9e3QoJ2F1dGhlbnRpY2F0aW9uOnZlcmlmeScpIHx8ICdWZXJpZnknfSBsb2FkaW5nTGFiZWw9e3QoJ2dlbmVyYWw6bG9hZGluZycpIHx8ICdMb2FkaW5nJ30gLz59XG4gICAgICAvPlxuICAgIDwvRm9ybT5cbiAgKVxufVxuIl0sIm5hbWVzIjpbInVzZU1lbW8iLCJjcmVhdGVBdXRoQ2xpZW50IiwidHdvRmFjdG9yQ2xpZW50IiwidXNlQXBwRm9ybSIsIkZvcm0iLCJGb3JtSW5wdXRXcmFwIiwiRm9ybUhlYWRlciIsInRvYXN0IiwidXNlVHJhbnNsYXRpb24iLCJ6IiwidXNlUm91dGVyIiwiVHdvRmFjdG9yVmVyaWZ5Rm9ybSIsInJlZGlyZWN0IiwidHdvRmFjdG9yRGlnaXRzIiwidCIsInJvdXRlciIsImF1dGhDbGllbnQiLCJwbHVnaW5zIiwib3RwU2NoZW1hIiwib2JqZWN0IiwiY29kZSIsInN0cmluZyIsImxlbmd0aCIsInJlZmluZSIsInZhbCIsInRlc3QiLCJmb3JtIiwiZGVmYXVsdFZhbHVlcyIsIm9uU3VibWl0IiwidmFsdWUiLCJlcnJvciIsInR3b0ZhY3RvciIsInZlcmlmeVRvdHAiLCJtZXNzYWdlIiwicHVzaCIsInN1Y2Nlc3MiLCJ2YWxpZGF0b3JzIiwiZSIsInByZXZlbnREZWZhdWx0IiwiaGFuZGxlU3VibWl0Iiwic3R5bGUiLCJ0ZXh0QWxpZ24iLCJoZWFkaW5nIiwiQXBwRmllbGQiLCJuYW1lIiwiY2hpbGRyZW4iLCJmaWVsZCIsIlRleHRGaWVsZCIsInR5cGUiLCJjbGFzc05hbWUiLCJsYWJlbCIsInJlcXVpcmVkIiwiYXV0b0NvbXBsZXRlIiwiQXBwRm9ybSIsIlN1Ym1pdCIsImxvYWRpbmdMYWJlbCJdLCJtYXBwaW5ncyI6IkFBQUE7O0FBRUEsU0FBU0EsT0FBTyxRQUFRLFFBQU87QUFDL0IsU0FBU0MsZ0JBQWdCLFFBQVEsb0JBQW1CO0FBQ3BELFNBQVNDLGVBQWUsUUFBUSw2QkFBNEI7QUFDNUQsU0FBU0MsVUFBVSxRQUFRLDZCQUFlO0FBQzFDLFNBQVNDLElBQUksRUFBRUMsYUFBYSxRQUFRLGdDQUFrQjtBQUN0RCxTQUFTQyxVQUFVLFFBQVEsdUNBQXlCO0FBQ3BELFNBQVNDLEtBQUssRUFBRUMsY0FBYyxRQUFRLGlCQUFnQjtBQUN0RCxTQUFTQyxDQUFDLFFBQVEsTUFBSztBQUN2QixTQUFTQyxTQUFTLFFBQVEsa0JBQWlCO0FBRTNDLE9BQU8sTUFBTUMsc0JBQXNCLENBQUMsRUFBRUMsUUFBUSxFQUFFQyxrQkFBa0IsQ0FBQyxFQUFrRDtJQUNuSCxNQUFNLEVBQUVDLENBQUMsRUFBRSxHQUFHTjtJQUNkLE1BQU1PLFNBQVNMO0lBQ2YsTUFBTU0sYUFBYWhCLFFBQVEsSUFBTUMsaUJBQWlCO1lBQUVnQixTQUFTO2dCQUFDZjthQUFrQjtRQUFDLElBQUksRUFBRTtJQUV2RixNQUFNZ0IsWUFBWVQsRUFBRVUsTUFBTSxDQUFDO1FBQ3pCQyxNQUFNWCxFQUNIWSxNQUFNLEdBQ05DLE1BQU0sQ0FBQ1QsaUJBQWlCLENBQUMsYUFBYSxFQUFFQSxnQkFBZ0IsT0FBTyxDQUFDLEVBQ2hFVSxNQUFNLENBQUMsQ0FBQ0MsTUFBUSwyQkFBMkJDLElBQUksQ0FBQ0QsTUFBTSxDQUFDLG9CQUFvQixDQUFDO0lBQ2pGO0lBRUEsTUFBTUUsT0FBT3ZCLFdBQVc7UUFDdEJ3QixlQUFlO1lBQUVQLE1BQU07UUFBRztRQUMxQlEsVUFBVSxPQUFPLEVBQUVDLEtBQUssRUFBRTtZQUN4QixNQUFNLEVBQUVULElBQUksRUFBRSxHQUFHUztZQUNqQixNQUFNLEVBQUVDLEtBQUssRUFBRSxHQUFHLE1BQU1kLFdBQVdlLFNBQVMsQ0FBQ0MsVUFBVSxDQUFDO2dCQUFFWjtZQUFLO1lBQy9ELElBQUlVLE9BQU87Z0JBQ1R2QixNQUFNdUIsS0FBSyxDQUFDQSxNQUFNRyxPQUFPO2dCQUN6QjtZQUNGO1lBQ0FsQixPQUFPbUIsSUFBSSxDQUFDdEI7WUFDWkwsTUFBTTRCLE9BQU8sQ0FBQztRQUNoQjtRQUNBQyxZQUFZO1lBQUVSLFVBQVVWO1FBQVU7SUFDcEM7SUFFQSxxQkFDRSxNQUFDZDtRQUNDd0IsVUFBVSxDQUFDUztZQUNUQSxFQUFFQyxjQUFjO1lBQ2hCLEtBQUtaLEtBQUthLFlBQVk7UUFDeEI7OzBCQUNBLEtBQUNqQztnQkFBV2tDLE9BQU87b0JBQUVDLFdBQVc7Z0JBQVM7Z0JBQUdDLFNBQVM7OzBCQUNyRCxLQUFDckM7MEJBQ0MsY0FBQSxLQUFDcUIsS0FBS2lCLFFBQVE7b0JBQ1pDLE1BQUs7b0JBQ0xDLFVBQVUsQ0FBQ0Msc0JBQ1QsS0FBQ0EsTUFBTUMsU0FBUzs0QkFBQ0MsTUFBSzs0QkFBT0MsV0FBVTs0QkFBV0MsT0FBTzs0QkFBZ0JDLFFBQVE7NEJBQUNDLGNBQWE7Ozs7MEJBSXJHLEtBQUMxQixLQUFLMkIsT0FBTztnQkFDWFIsd0JBQVUsS0FBQ25CLEtBQUs0QixNQUFNO29CQUFDSixPQUFPcEMsRUFBRSw0QkFBNEI7b0JBQVV5QyxjQUFjekMsRUFBRSxzQkFBc0I7Ozs7O0FBSXBILEVBQUMifQ==
@@ -0,0 +1,10 @@
1
+ import type { AdminViewServerProps } from 'payload';
2
+ import React from 'react';
3
+ import type { TwoFactorOptions } from 'better-auth/plugins/two-factor';
4
+ interface TwoFactorVerifyProps extends AdminViewServerProps {
5
+ verificationSlug: string;
6
+ twoFactorOptions: TwoFactorOptions | undefined;
7
+ }
8
+ declare const TwoFactorVerify: React.FC<TwoFactorVerifyProps>;
9
+ export default TwoFactorVerify;
10
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../../src/better-auth/plugin/payload/views/two-factor-verify/index.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,SAAS,CAAA;AACnD,OAAO,KAAK,MAAM,OAAO,CAAA;AAMzB,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,gCAAgC,CAAA;AAEtE,UAAU,oBAAqB,SAAQ,oBAAoB;IACzD,gBAAgB,EAAE,MAAM,CAAA;IACxB,gBAAgB,EAAE,gBAAgB,GAAG,SAAS,CAAA;CAC/C;AAED,QAAA,MAAM,eAAe,EAAE,KAAK,CAAC,EAAE,CAAC,oBAAoB,CAoCnD,CAAA;AAED,eAAe,eAAe,CAAA"}
@@ -0,0 +1,44 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { MinimalTemplate } from "@payloadcms/next/templates";
3
+ import { redirect } from "next/navigation";
4
+ import React from "react";
5
+ import { TwoFactorVerifyForm } from "./client";
6
+ import { cookies } from "next/headers";
7
+ import { getSafeRedirect } from "../../utils/get-safe-redirect";
8
+ import { valueOrDefaultString } from "../../../../../shared/utils/value-or-default";
9
+ import { adminRoutes } from "../../../constants";
10
+ const TwoFactorVerify = async ({ clientConfig, payload, searchParams, initPageResult, verificationSlug, twoFactorOptions })=>{
11
+ const adminRoute = valueOrDefaultString(clientConfig?.routes?.admin, '/admin');
12
+ const loginRoute = valueOrDefaultString(clientConfig?.admin?.routes?.login, adminRoutes.adminLogin);
13
+ const cookieStore = await cookies();
14
+ const twoFactorCookie = cookieStore.get(`${process.env.NODE_ENV === 'production' ? '__Secure-' : ''}better-auth.two_factor`)?.value;
15
+ const redirectUrl = getSafeRedirect(searchParams?.redirect, adminRoute);
16
+ if (!twoFactorCookie) {
17
+ redirect(`${adminRoute}${loginRoute}`);
18
+ }
19
+ const twoFactorVerifyToken = twoFactorCookie.split('.').at(0);
20
+ if (!twoFactorVerifyToken) {
21
+ redirect(`${adminRoute}${loginRoute}`);
22
+ }
23
+ const { totalDocs: isValidTwoFactorToken } = await payload.count({
24
+ collection: verificationSlug,
25
+ where: {
26
+ identifier: {
27
+ equals: twoFactorVerifyToken
28
+ }
29
+ }
30
+ });
31
+ if (!isValidTwoFactorToken) {
32
+ redirect(`${adminRoute}${loginRoute}`);
33
+ }
34
+ return /*#__PURE__*/ _jsx(MinimalTemplate, {
35
+ className: "two-factor-verify",
36
+ children: /*#__PURE__*/ _jsx(TwoFactorVerifyForm, {
37
+ redirect: redirectUrl,
38
+ twoFactorDigits: twoFactorOptions?.totpOptions?.digits
39
+ })
40
+ });
41
+ };
42
+ export default TwoFactorVerify;
43
+
44
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9iZXR0ZXItYXV0aC9wbHVnaW4vcGF5bG9hZC92aWV3cy90d28tZmFjdG9yLXZlcmlmeS9pbmRleC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTWluaW1hbFRlbXBsYXRlIH0gZnJvbSAnQHBheWxvYWRjbXMvbmV4dC90ZW1wbGF0ZXMnXG5pbXBvcnQgeyByZWRpcmVjdCB9IGZyb20gJ25leHQvbmF2aWdhdGlvbidcbmltcG9ydCB0eXBlIHsgQWRtaW5WaWV3U2VydmVyUHJvcHMgfSBmcm9tICdwYXlsb2FkJ1xuaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgVHdvRmFjdG9yVmVyaWZ5Rm9ybSB9IGZyb20gJy4vY2xpZW50J1xuaW1wb3J0IHsgY29va2llcyB9IGZyb20gJ25leHQvaGVhZGVycydcbmltcG9ydCB7IGdldFNhZmVSZWRpcmVjdCB9IGZyb20gJy4uLy4uL3V0aWxzL2dldC1zYWZlLXJlZGlyZWN0J1xuaW1wb3J0IHsgdmFsdWVPckRlZmF1bHRTdHJpbmcgfSBmcm9tICdAL3NoYXJlZC91dGlscy92YWx1ZS1vci1kZWZhdWx0J1xuaW1wb3J0IHsgYWRtaW5Sb3V0ZXMgfSBmcm9tICdAL2JldHRlci1hdXRoL3BsdWdpbi9jb25zdGFudHMnXG5pbXBvcnQgdHlwZSB7IFR3b0ZhY3Rvck9wdGlvbnMgfSBmcm9tICdiZXR0ZXItYXV0aC9wbHVnaW5zL3R3by1mYWN0b3InXG5cbmludGVyZmFjZSBUd29GYWN0b3JWZXJpZnlQcm9wcyBleHRlbmRzIEFkbWluVmlld1NlcnZlclByb3BzIHtcbiAgdmVyaWZpY2F0aW9uU2x1Zzogc3RyaW5nXG4gIHR3b0ZhY3Rvck9wdGlvbnM6IFR3b0ZhY3Rvck9wdGlvbnMgfCB1bmRlZmluZWRcbn1cblxuY29uc3QgVHdvRmFjdG9yVmVyaWZ5OiBSZWFjdC5GQzxUd29GYWN0b3JWZXJpZnlQcm9wcz4gPSBhc3luYyAoe1xuICBjbGllbnRDb25maWcsXG4gIHBheWxvYWQsXG4gIHNlYXJjaFBhcmFtcyxcbiAgaW5pdFBhZ2VSZXN1bHQsXG4gIHZlcmlmaWNhdGlvblNsdWcsXG4gIHR3b0ZhY3Rvck9wdGlvbnNcbn0pID0+IHtcbiAgY29uc3QgYWRtaW5Sb3V0ZSA9IHZhbHVlT3JEZWZhdWx0U3RyaW5nKGNsaWVudENvbmZpZz8ucm91dGVzPy5hZG1pbiwgJy9hZG1pbicpXG4gIGNvbnN0IGxvZ2luUm91dGUgPSB2YWx1ZU9yRGVmYXVsdFN0cmluZyhjbGllbnRDb25maWc/LmFkbWluPy5yb3V0ZXM/LmxvZ2luLCBhZG1pblJvdXRlcy5hZG1pbkxvZ2luKVxuICBjb25zdCBjb29raWVTdG9yZSA9IGF3YWl0IGNvb2tpZXMoKVxuICBjb25zdCB0d29GYWN0b3JDb29raWUgPSBjb29raWVTdG9yZS5nZXQoYCR7cHJvY2Vzcy5lbnYuTk9ERV9FTlYgPT09ICdwcm9kdWN0aW9uJyA/ICdfX1NlY3VyZS0nIDogJyd9YmV0dGVyLWF1dGgudHdvX2ZhY3RvcmApPy52YWx1ZVxuICBjb25zdCByZWRpcmVjdFVybCA9IGdldFNhZmVSZWRpcmVjdChzZWFyY2hQYXJhbXM/LnJlZGlyZWN0IGFzIHN0cmluZywgYWRtaW5Sb3V0ZSlcbiAgaWYgKCF0d29GYWN0b3JDb29raWUpIHtcbiAgICByZWRpcmVjdChgJHthZG1pblJvdXRlfSR7bG9naW5Sb3V0ZX1gKVxuICB9XG4gIGNvbnN0IHR3b0ZhY3RvclZlcmlmeVRva2VuID0gdHdvRmFjdG9yQ29va2llLnNwbGl0KCcuJykuYXQoMClcbiAgaWYgKCF0d29GYWN0b3JWZXJpZnlUb2tlbikge1xuICAgIHJlZGlyZWN0KGAke2FkbWluUm91dGV9JHtsb2dpblJvdXRlfWApXG4gIH1cbiAgY29uc3QgeyB0b3RhbERvY3M6IGlzVmFsaWRUd29GYWN0b3JUb2tlbiB9ID0gYXdhaXQgcGF5bG9hZC5jb3VudCh7XG4gICAgY29sbGVjdGlvbjogdmVyaWZpY2F0aW9uU2x1ZyxcbiAgICB3aGVyZToge1xuICAgICAgaWRlbnRpZmllcjoge1xuICAgICAgICBlcXVhbHM6IHR3b0ZhY3RvclZlcmlmeVRva2VuXG4gICAgICB9XG4gICAgfVxuICB9KVxuICBpZiAoIWlzVmFsaWRUd29GYWN0b3JUb2tlbikge1xuICAgIHJlZGlyZWN0KGAke2FkbWluUm91dGV9JHtsb2dpblJvdXRlfWApXG4gIH1cbiAgcmV0dXJuIChcbiAgICA8TWluaW1hbFRlbXBsYXRlIGNsYXNzTmFtZT1cInR3by1mYWN0b3ItdmVyaWZ5XCI+XG4gICAgICA8VHdvRmFjdG9yVmVyaWZ5Rm9ybSByZWRpcmVjdD17cmVkaXJlY3RVcmx9IHR3b0ZhY3RvckRpZ2l0cz17dHdvRmFjdG9yT3B0aW9ucz8udG90cE9wdGlvbnM/LmRpZ2l0c30gLz5cbiAgICA8L01pbmltYWxUZW1wbGF0ZT5cbiAgKVxufVxuXG5leHBvcnQgZGVmYXVsdCBUd29GYWN0b3JWZXJpZnlcbiJdLCJuYW1lcyI6WyJNaW5pbWFsVGVtcGxhdGUiLCJyZWRpcmVjdCIsIlJlYWN0IiwiVHdvRmFjdG9yVmVyaWZ5Rm9ybSIsImNvb2tpZXMiLCJnZXRTYWZlUmVkaXJlY3QiLCJ2YWx1ZU9yRGVmYXVsdFN0cmluZyIsImFkbWluUm91dGVzIiwiVHdvRmFjdG9yVmVyaWZ5IiwiY2xpZW50Q29uZmlnIiwicGF5bG9hZCIsInNlYXJjaFBhcmFtcyIsImluaXRQYWdlUmVzdWx0IiwidmVyaWZpY2F0aW9uU2x1ZyIsInR3b0ZhY3Rvck9wdGlvbnMiLCJhZG1pblJvdXRlIiwicm91dGVzIiwiYWRtaW4iLCJsb2dpblJvdXRlIiwibG9naW4iLCJhZG1pbkxvZ2luIiwiY29va2llU3RvcmUiLCJ0d29GYWN0b3JDb29raWUiLCJnZXQiLCJwcm9jZXNzIiwiZW52IiwiTk9ERV9FTlYiLCJ2YWx1ZSIsInJlZGlyZWN0VXJsIiwidHdvRmFjdG9yVmVyaWZ5VG9rZW4iLCJzcGxpdCIsImF0IiwidG90YWxEb2NzIiwiaXNWYWxpZFR3b0ZhY3RvclRva2VuIiwiY291bnQiLCJjb2xsZWN0aW9uIiwid2hlcmUiLCJpZGVudGlmaWVyIiwiZXF1YWxzIiwiY2xhc3NOYW1lIiwidHdvRmFjdG9yRGlnaXRzIiwidG90cE9wdGlvbnMiLCJkaWdpdHMiXSwibWFwcGluZ3MiOiI7QUFBQSxTQUFTQSxlQUFlLFFBQVEsNkJBQTRCO0FBQzVELFNBQVNDLFFBQVEsUUFBUSxrQkFBaUI7QUFFMUMsT0FBT0MsV0FBVyxRQUFPO0FBQ3pCLFNBQVNDLG1CQUFtQixRQUFRLFdBQVU7QUFDOUMsU0FBU0MsT0FBTyxRQUFRLGVBQWM7QUFDdEMsU0FBU0MsZUFBZSxRQUFRLGdDQUErQjtBQUMvRCxTQUFTQyxvQkFBb0IsUUFBUSwrQ0FBaUM7QUFDdEUsU0FBU0MsV0FBVyxRQUFRLHFCQUFnQztBQVE1RCxNQUFNQyxrQkFBa0QsT0FBTyxFQUM3REMsWUFBWSxFQUNaQyxPQUFPLEVBQ1BDLFlBQVksRUFDWkMsY0FBYyxFQUNkQyxnQkFBZ0IsRUFDaEJDLGdCQUFnQixFQUNqQjtJQUNDLE1BQU1DLGFBQWFULHFCQUFxQkcsY0FBY08sUUFBUUMsT0FBTztJQUNyRSxNQUFNQyxhQUFhWixxQkFBcUJHLGNBQWNRLE9BQU9ELFFBQVFHLE9BQU9aLFlBQVlhLFVBQVU7SUFDbEcsTUFBTUMsY0FBYyxNQUFNakI7SUFDMUIsTUFBTWtCLGtCQUFrQkQsWUFBWUUsR0FBRyxDQUFDLEdBQUdDLFFBQVFDLEdBQUcsQ0FBQ0MsUUFBUSxLQUFLLGVBQWUsY0FBYyxHQUFHLHNCQUFzQixDQUFDLEdBQUdDO0lBQzlILE1BQU1DLGNBQWN2QixnQkFBZ0JNLGNBQWNWLFVBQW9CYztJQUN0RSxJQUFJLENBQUNPLGlCQUFpQjtRQUNwQnJCLFNBQVMsR0FBR2MsYUFBYUcsWUFBWTtJQUN2QztJQUNBLE1BQU1XLHVCQUF1QlAsZ0JBQWdCUSxLQUFLLENBQUMsS0FBS0MsRUFBRSxDQUFDO0lBQzNELElBQUksQ0FBQ0Ysc0JBQXNCO1FBQ3pCNUIsU0FBUyxHQUFHYyxhQUFhRyxZQUFZO0lBQ3ZDO0lBQ0EsTUFBTSxFQUFFYyxXQUFXQyxxQkFBcUIsRUFBRSxHQUFHLE1BQU12QixRQUFRd0IsS0FBSyxDQUFDO1FBQy9EQyxZQUFZdEI7UUFDWnVCLE9BQU87WUFDTEMsWUFBWTtnQkFDVkMsUUFBUVQ7WUFDVjtRQUNGO0lBQ0Y7SUFDQSxJQUFJLENBQUNJLHVCQUF1QjtRQUMxQmhDLFNBQVMsR0FBR2MsYUFBYUcsWUFBWTtJQUN2QztJQUNBLHFCQUNFLEtBQUNsQjtRQUFnQnVDLFdBQVU7a0JBQ3pCLGNBQUEsS0FBQ3BDO1lBQW9CRixVQUFVMkI7WUFBYVksaUJBQWlCMUIsa0JBQWtCMkIsYUFBYUM7OztBQUdsRztBQUVBLGVBQWVsQyxnQkFBZSJ9
@@ -11,6 +11,8 @@ export const Submit = ({ label, loadingLabel })=>{
11
11
  ],
12
12
  children: ([canSubmit, isSubmitting])=>/*#__PURE__*/ _jsx(FormSubmit, {
13
13
  buttonStyle: "primary",
14
+ type: "button",
15
+ onClick: ()=>form.handleSubmit(),
14
16
  size: "large",
15
17
  disabled: !canSubmit,
16
18
  children: isSubmitting ? loadingLabel : label
@@ -18,4 +20,4 @@ export const Submit = ({ label, loadingLabel })=>{
18
20
  });
19
21
  };
20
22
 
21
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9zaGFyZWQvZm9ybS9jb21wb25lbnRzL3N1Ym1pdC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgdXNlRm9ybUNvbnRleHQgfSBmcm9tICcuLidcbmltcG9ydCB7IEZvcm1TdWJtaXQgfSBmcm9tICdAcGF5bG9hZGNtcy91aSdcblxudHlwZSBTdWJtaXRQcm9wcyA9IHtcbiAgbGFiZWw6IHN0cmluZ1xuICBsb2FkaW5nTGFiZWw6IHN0cmluZ1xufVxuXG5leHBvcnQgY29uc3QgU3VibWl0OiBSZWFjdC5GQzxTdWJtaXRQcm9wcz4gPSAoeyBsYWJlbCwgbG9hZGluZ0xhYmVsIH0pID0+IHtcbiAgY29uc3QgZm9ybSA9IHVzZUZvcm1Db250ZXh0KClcblxuICByZXR1cm4gKFxuICAgIDxmb3JtLlN1YnNjcmliZVxuICAgICAgc2VsZWN0b3I9eyhzdGF0ZSkgPT4gW3N0YXRlLmNhblN1Ym1pdCwgc3RhdGUuaXNTdWJtaXR0aW5nXX1cbiAgICAgIGNoaWxkcmVuPXsoW2NhblN1Ym1pdCwgaXNTdWJtaXR0aW5nXSkgPT4gKFxuICAgICAgICA8Rm9ybVN1Ym1pdCBidXR0b25TdHlsZT1cInByaW1hcnlcIiBzaXplPVwibGFyZ2VcIiBkaXNhYmxlZD17IWNhblN1Ym1pdH0+XG4gICAgICAgICAge2lzU3VibWl0dGluZyA/IGxvYWRpbmdMYWJlbCA6IGxhYmVsfVxuICAgICAgICA8L0Zvcm1TdWJtaXQ+XG4gICAgICApfVxuICAgIC8+XG4gIClcbn1cbiJdLCJuYW1lcyI6WyJSZWFjdCIsInVzZUZvcm1Db250ZXh0IiwiRm9ybVN1Ym1pdCIsIlN1Ym1pdCIsImxhYmVsIiwibG9hZGluZ0xhYmVsIiwiZm9ybSIsIlN1YnNjcmliZSIsInNlbGVjdG9yIiwic3RhdGUiLCJjYW5TdWJtaXQiLCJpc1N1Ym1pdHRpbmciLCJjaGlsZHJlbiIsImJ1dHRvblN0eWxlIiwic2l6ZSIsImRpc2FibGVkIl0sIm1hcHBpbmdzIjoiO0FBQUEsT0FBT0EsV0FBVyxRQUFPO0FBQ3pCLFNBQVNDLGNBQWMsUUFBUSxLQUFJO0FBQ25DLFNBQVNDLFVBQVUsUUFBUSxpQkFBZ0I7QUFPM0MsT0FBTyxNQUFNQyxTQUFnQyxDQUFDLEVBQUVDLEtBQUssRUFBRUMsWUFBWSxFQUFFO0lBQ25FLE1BQU1DLE9BQU9MO0lBRWIscUJBQ0UsS0FBQ0ssS0FBS0MsU0FBUztRQUNiQyxVQUFVLENBQUNDLFFBQVU7Z0JBQUNBLE1BQU1DLFNBQVM7Z0JBQUVELE1BQU1FLFlBQVk7YUFBQztRQUMxREMsVUFBVSxDQUFDLENBQUNGLFdBQVdDLGFBQWEsaUJBQ2xDLEtBQUNUO2dCQUFXVyxhQUFZO2dCQUFVQyxNQUFLO2dCQUFRQyxVQUFVLENBQUNMOzBCQUN2REMsZUFBZU4sZUFBZUQ7OztBQUt6QyxFQUFDIn0=
23
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9zaGFyZWQvZm9ybS9jb21wb25lbnRzL3N1Ym1pdC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgdXNlRm9ybUNvbnRleHQgfSBmcm9tICcuLidcbmltcG9ydCB7IEZvcm1TdWJtaXQgfSBmcm9tICdAcGF5bG9hZGNtcy91aSdcblxudHlwZSBTdWJtaXRQcm9wcyA9IHtcbiAgbGFiZWw6IHN0cmluZ1xuICBsb2FkaW5nTGFiZWw6IHN0cmluZ1xufVxuXG5leHBvcnQgY29uc3QgU3VibWl0OiBSZWFjdC5GQzxTdWJtaXRQcm9wcz4gPSAoeyBsYWJlbCwgbG9hZGluZ0xhYmVsIH0pID0+IHtcbiAgY29uc3QgZm9ybSA9IHVzZUZvcm1Db250ZXh0KClcblxuICByZXR1cm4gKFxuICAgIDxmb3JtLlN1YnNjcmliZVxuICAgICAgc2VsZWN0b3I9eyhzdGF0ZSkgPT4gW3N0YXRlLmNhblN1Ym1pdCwgc3RhdGUuaXNTdWJtaXR0aW5nXX1cbiAgICAgIGNoaWxkcmVuPXsoW2NhblN1Ym1pdCwgaXNTdWJtaXR0aW5nXSkgPT4gKFxuICAgICAgICA8Rm9ybVN1Ym1pdCBidXR0b25TdHlsZT1cInByaW1hcnlcIiB0eXBlPVwiYnV0dG9uXCIgb25DbGljaz17KCkgPT4gZm9ybS5oYW5kbGVTdWJtaXQoKX0gc2l6ZT1cImxhcmdlXCIgZGlzYWJsZWQ9eyFjYW5TdWJtaXR9PlxuICAgICAgICAgIHtpc1N1Ym1pdHRpbmcgPyBsb2FkaW5nTGFiZWwgOiBsYWJlbH1cbiAgICAgICAgPC9Gb3JtU3VibWl0PlxuICAgICAgKX1cbiAgICAvPlxuICApXG59XG4iXSwibmFtZXMiOlsiUmVhY3QiLCJ1c2VGb3JtQ29udGV4dCIsIkZvcm1TdWJtaXQiLCJTdWJtaXQiLCJsYWJlbCIsImxvYWRpbmdMYWJlbCIsImZvcm0iLCJTdWJzY3JpYmUiLCJzZWxlY3RvciIsInN0YXRlIiwiY2FuU3VibWl0IiwiaXNTdWJtaXR0aW5nIiwiY2hpbGRyZW4iLCJidXR0b25TdHlsZSIsInR5cGUiLCJvbkNsaWNrIiwiaGFuZGxlU3VibWl0Iiwic2l6ZSIsImRpc2FibGVkIl0sIm1hcHBpbmdzIjoiO0FBQUEsT0FBT0EsV0FBVyxRQUFPO0FBQ3pCLFNBQVNDLGNBQWMsUUFBUSxLQUFJO0FBQ25DLFNBQVNDLFVBQVUsUUFBUSxpQkFBZ0I7QUFPM0MsT0FBTyxNQUFNQyxTQUFnQyxDQUFDLEVBQUVDLEtBQUssRUFBRUMsWUFBWSxFQUFFO0lBQ25FLE1BQU1DLE9BQU9MO0lBRWIscUJBQ0UsS0FBQ0ssS0FBS0MsU0FBUztRQUNiQyxVQUFVLENBQUNDLFFBQVU7Z0JBQUNBLE1BQU1DLFNBQVM7Z0JBQUVELE1BQU1FLFlBQVk7YUFBQztRQUMxREMsVUFBVSxDQUFDLENBQUNGLFdBQVdDLGFBQWEsaUJBQ2xDLEtBQUNUO2dCQUFXVyxhQUFZO2dCQUFVQyxNQUFLO2dCQUFTQyxTQUFTLElBQU1ULEtBQUtVLFlBQVk7Z0JBQUlDLE1BQUs7Z0JBQVFDLFVBQVUsQ0FBQ1I7MEJBQ3pHQyxlQUFlTixlQUFlRDs7O0FBS3pDLEVBQUMifQ==
@@ -0,0 +1,10 @@
1
+ /**
2
+ * Returns the provided value if it's defined (not undefined), otherwise returns the default value.
3
+ * Unlike null checks, this allows empty strings to pass through.
4
+ *
5
+ * @param value - The value to check
6
+ * @param defaultValue - The default value to return if the provided value is undefined
7
+ * @returns The provided value if defined, otherwise the default value
8
+ */
9
+ export declare function valueOrDefaultString<T extends string>(value: T | undefined, defaultValue: T): T;
10
+ //# sourceMappingURL=value-or-default.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"value-or-default.d.ts","sourceRoot":"","sources":["../../../src/shared/utils/value-or-default.ts"],"names":[],"mappings":"AAEA;;;;;;;GAOG;AACH,wBAAgB,oBAAoB,CAAC,CAAC,SAAS,MAAM,EAAE,KAAK,EAAE,CAAC,GAAG,SAAS,EAAE,YAAY,EAAE,CAAC,GAAG,CAAC,CAE/F"}
@@ -0,0 +1,12 @@
1
+ /**
2
+ * Returns the provided value if it's defined (not undefined), otherwise returns the default value.
3
+ * Unlike null checks, this allows empty strings to pass through.
4
+ *
5
+ * @param value - The value to check
6
+ * @param defaultValue - The default value to return if the provided value is undefined
7
+ * @returns The provided value if defined, otherwise the default value
8
+ */ export function valueOrDefaultString(value, defaultValue) {
9
+ return value !== undefined ? value : defaultValue;
10
+ }
11
+
12
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9zaGFyZWQvdXRpbHMvdmFsdWUtb3ItZGVmYXVsdC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJcblxuLyoqXG4gKiBSZXR1cm5zIHRoZSBwcm92aWRlZCB2YWx1ZSBpZiBpdCdzIGRlZmluZWQgKG5vdCB1bmRlZmluZWQpLCBvdGhlcndpc2UgcmV0dXJucyB0aGUgZGVmYXVsdCB2YWx1ZS5cbiAqIFVubGlrZSBudWxsIGNoZWNrcywgdGhpcyBhbGxvd3MgZW1wdHkgc3RyaW5ncyB0byBwYXNzIHRocm91Z2guXG4gKiBcbiAqIEBwYXJhbSB2YWx1ZSAtIFRoZSB2YWx1ZSB0byBjaGVja1xuICogQHBhcmFtIGRlZmF1bHRWYWx1ZSAtIFRoZSBkZWZhdWx0IHZhbHVlIHRvIHJldHVybiBpZiB0aGUgcHJvdmlkZWQgdmFsdWUgaXMgdW5kZWZpbmVkXG4gKiBAcmV0dXJucyBUaGUgcHJvdmlkZWQgdmFsdWUgaWYgZGVmaW5lZCwgb3RoZXJ3aXNlIHRoZSBkZWZhdWx0IHZhbHVlXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiB2YWx1ZU9yRGVmYXVsdFN0cmluZzxUIGV4dGVuZHMgc3RyaW5nPih2YWx1ZTogVCB8IHVuZGVmaW5lZCwgZGVmYXVsdFZhbHVlOiBUKTogVCB7XG4gIHJldHVybiB2YWx1ZSAhPT0gdW5kZWZpbmVkID8gdmFsdWUgOiBkZWZhdWx0VmFsdWU7XG59XG4iXSwibmFtZXMiOlsidmFsdWVPckRlZmF1bHRTdHJpbmciLCJ2YWx1ZSIsImRlZmF1bHRWYWx1ZSIsInVuZGVmaW5lZCJdLCJtYXBwaW5ncyI6IkFBRUE7Ozs7Ozs7Q0FPQyxHQUNELE9BQU8sU0FBU0EscUJBQXVDQyxLQUFvQixFQUFFQyxZQUFlO0lBQzFGLE9BQU9ELFVBQVVFLFlBQVlGLFFBQVFDO0FBQ3ZDIn0=