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.
- package/dist/better-auth/adapter/index.d.ts +10 -0
- package/dist/better-auth/adapter/index.d.ts.map +1 -1
- package/dist/better-auth/adapter/index.js +151 -125
- package/dist/better-auth/adapter/transform/index.d.ts +2 -4
- package/dist/better-auth/adapter/transform/index.d.ts.map +1 -1
- package/dist/better-auth/adapter/transform/index.js +433 -309
- package/dist/better-auth/plugin/constants.d.ts +2 -0
- package/dist/better-auth/plugin/constants.d.ts.map +1 -1
- package/dist/better-auth/plugin/constants.js +4 -2
- package/dist/better-auth/plugin/helpers/check-passkey-plugin.d.ts.map +1 -1
- package/dist/better-auth/plugin/helpers/check-passkey-plugin.js +3 -2
- package/dist/better-auth/plugin/helpers/check-two-factor-plugin.d.ts +3 -0
- package/dist/better-auth/plugin/helpers/check-two-factor-plugin.d.ts.map +1 -0
- package/dist/better-auth/plugin/helpers/check-two-factor-plugin.js +6 -0
- package/dist/better-auth/plugin/helpers/check-username-plugin.d.ts.map +1 -1
- package/dist/better-auth/plugin/helpers/check-username-plugin.js +3 -2
- package/dist/better-auth/plugin/helpers/prepare-session-data.d.ts +52 -6
- package/dist/better-auth/plugin/helpers/prepare-session-data.d.ts.map +1 -1
- package/dist/better-auth/plugin/helpers/prepare-session-data.js +52 -35
- package/dist/better-auth/plugin/index.d.ts.map +1 -1
- package/dist/better-auth/plugin/index.js +16 -2
- package/dist/better-auth/plugin/lib/build-collections/sessions.d.ts.map +1 -1
- package/dist/better-auth/plugin/lib/build-collections/sessions.js +3 -1
- package/dist/better-auth/plugin/lib/build-collections/users/better-auth-strategy.d.ts.map +1 -1
- package/dist/better-auth/plugin/lib/build-collections/users/better-auth-strategy.js +2 -2
- package/dist/better-auth/plugin/lib/build-collections/users/hooks/after-login.d.ts.map +1 -1
- package/dist/better-auth/plugin/lib/build-collections/users/hooks/after-login.js +6 -4
- package/dist/better-auth/plugin/lib/build-collections/users/index.d.ts.map +1 -1
- package/dist/better-auth/plugin/lib/build-collections/users/index.js +7 -2
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/save-to-jwt-middleware.d.ts +1 -1
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/save-to-jwt-middleware.d.ts.map +1 -1
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/save-to-jwt-middleware.js +16 -14
- package/dist/better-auth/plugin/payload/components/two-factor-auth/index.d.ts +4 -0
- package/dist/better-auth/plugin/payload/components/two-factor-auth/index.d.ts.map +1 -0
- package/dist/better-auth/plugin/payload/components/two-factor-auth/index.js +344 -0
- package/dist/better-auth/plugin/payload/components/two-factor-auth/index.scss +113 -0
- package/dist/better-auth/plugin/payload/exports/client.d.ts +2 -1
- package/dist/better-auth/plugin/payload/exports/client.d.ts.map +1 -1
- package/dist/better-auth/plugin/payload/exports/client.js +3 -2
- package/dist/better-auth/plugin/payload/exports/rsc.d.ts +2 -1
- package/dist/better-auth/plugin/payload/exports/rsc.d.ts.map +1 -1
- package/dist/better-auth/plugin/payload/exports/rsc.js +3 -2
- package/dist/better-auth/plugin/payload/views/admin-login/client.d.ts.map +1 -1
- package/dist/better-auth/plugin/payload/views/admin-login/client.js +14 -5
- package/dist/better-auth/plugin/payload/views/admin-login/index.d.ts.map +1 -1
- package/dist/better-auth/plugin/payload/views/admin-login/index.js +1 -3
- package/dist/better-auth/plugin/payload/views/two-factor-verify/client.d.ts +5 -0
- package/dist/better-auth/plugin/payload/views/two-factor-verify/client.d.ts.map +1 -0
- package/dist/better-auth/plugin/payload/views/two-factor-verify/client.js +77 -0
- package/dist/better-auth/plugin/payload/views/two-factor-verify/index.d.ts +10 -0
- package/dist/better-auth/plugin/payload/views/two-factor-verify/index.d.ts.map +1 -0
- package/dist/better-auth/plugin/payload/views/two-factor-verify/index.js +44 -0
- package/dist/shared/form/components/submit.js +3 -1
- package/dist/shared/utils/value-or-default.d.ts +10 -0
- package/dist/shared/utils/value-or-default.d.ts.map +1 -0
- package/dist/shared/utils/value-or-default.js +12 -0
- 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
|
-
|
|
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;
|
|
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
|
-
|
|
5
|
+
import { TwoFactorAuth } from "../components/two-factor-auth";
|
|
6
|
+
export { AdminButtons, AdminInviteButton, LogoutButton, AdminSocialProviderButtons, TwoFactorAuth };
|
|
6
7
|
|
|
7
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
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
|
-
|
|
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;
|
|
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
|
-
|
|
6
|
+
import TwoFactorVerify from "../views/two-factor-verify";
|
|
7
|
+
export { AdminSignup, AdminLogin, ForgotPassword, ResetPassword, RSCRedirect, TwoFactorVerify };
|
|
7
8
|
|
|
8
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
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;
|
|
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,
|
|
25
|
+
const redirectUrl = getSafeRedirect(searchParams?.redirect, adminRoute);
|
|
22
26
|
const forgotPasswordUrl = formatAdminURL({
|
|
23
|
-
adminRoute:
|
|
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":"AAAA;;AAEA,SAASA,0BAA0B,QAAQ,2CAAiE;AAC5G,SAASC,eAAe,QAAQ,gCAAsD;AACtF,SAASC,SAAS,EAAEC,IAAI,EAAEC,KAAK,EAAEC,cAAc,QAAQ,iBAAgB;AACvE,OAAOC,SAASC,OAAO,EAAEC,QAAQ,QAAQ,QAAO;AAGhD,SAASC,WAAW,QAAQ,qBAAgC;AAC5D,SAASC,UAAU,QAAQ,6BAAe;AAC1C,SAASC,IAAI,EAAEC,SAAS,EAAEC,aAAa,QAAQ,gCAAkB;AACjE,SAASC,UAAU,QAAQ,uCAAyB;AACpD,SAASC,iBAAiB,EAAEC,YAAY,QAAQ,wCAA0B;AAC1E,SAASC,gBAAgB,QAAQ,qBAAoB;AACrD,SAASC,cAAc,EAAEC,eAAe,QAAQ,6BAA4B;AAC5E,SAASC,cAAc,EAAEC,eAAe,QAAQ,iBAAgB;AAChE,SAASC,SAAS,QAAQ,kBAAiB;AAC3C,SAASC,oBAAoB,QAAQ,+CAAiC;AAYtE,MAAMC,YAAY;AAElB,MAAMC,YAOD,CAAC,EACJC,iBAAiB,EACjBC,YAAY,EACZC,eAAe,EACfC,eAAe,EACfC,YAAY,EACZC,iBAAiB,EAClB;IACC,MAAM,EAAEC,MAAM,EAAE,GAAG9B;IACnB,MAAM+B,SAASX;IACf,MAAMY,aAAaX,qBAAqBS,QAAQG,QAAQC,OAAO;IAC/D,MAAM,EAAEC,CAAC,EAAE,GAAGhC;IACd,MAAM,EAAEiC,iBAAiB,EAAEC,oBAAoB,EAAE,GAAGlB,gBAAgBU;IACpE,MAAMS,mBAAmBV,cAAcW;IACvC,MAAMC,cAAczC,gBAAgB6B,cAAca,UAAoBT;IACtE,MAAMU,oBAAoBxB,eAAe;QACvCc,YAAYA;QACZW,MAAMpC,aAAaqC;IACrB;IACA,MAAMC,aAAaxC,QAAQ,IACzBU,iBAAiB;YACf+B,SAAS;gBACP9B;gBACAC,gBAAgB;oBACd8B;wBACEhB,OAAOiB,IAAI,CAAC,GAAGhB,WAAW,4BAA4B,EAAEQ,aAAa;oBACvE;gBACF;aACD;QACH,IACA,EAAE;IAEJ,MAAMS,YAAY5C,QAAQ;QACxB,IAAI+B,qBAAqBC,wBAAwBb,mBAAmB,OAAO;QAC3E,IAAIa,wBAAwBb,mBAAmB,OAAO;QACtD,OAAO;IACT,GAAG;QAACY;QAAmBC;QAAsBb;KAAkB;IAC/D,MAAM,CAAC0B,0BAA0BC,4BAA4B,GAAG7C,SAAkB;IAElF,IAAI4C,0BAA0B;QAC5B,qBAAO,KAACtC;YAAWwC,SAAQ;YAA2BC,aAAalB,EAAE;YAA6BmB,OAAO;gBAAEC,WAAW;YAAS;;IACjI;IAEA,MAAMC,cAAc3C,kBAAkB;QAAEsB;QAAGc;QAAWZ;IAAqB;IAE3E,MAAMoB,OAAOjD,WAAW;QACtBkD,eAAe;YACbC,OAAOlC,gBAAgBE,mBAAmB;YAC1CiC,UAAUlC,mBAAmB;QAC/B;QACAmC,UAAU,OAAO,EAAEC,KAAK,EAAE;YACxB,MAAM,EAAEH,KAAK,EAAEC,QAAQ,EAAE,GAAGE;YAC5B,MAAMC,UAAUjD,aAAa6C;YAC7B,IAAI;gBACF,MAAM,EAAEK,IAAI,EAAEzB,KAAK,EAAE,GAAG,MAAOU,CAAAA,cAAc,WAAYA,cAAc,qBAAqBc,UACxFlB,WAAWoB,MAAM,CAACC,KAAK,CAAC;oBAAEA,OAAOP;oBAAOC;oBAAUO,aAAa3B;gBAAY,KAC3EK,WAAWoB,MAAM,CAACG,QAAQ,CAAC;oBAAEA,UAAUT;oBAAOC;gBAAS,EAAC;gBAC5D,IAAIrB,OAAO;oBACT,IAAIA,MAAM8B,IAAI,KAAK,sBAAsB;wBACvClB,4BAA4B;oBAC9B;oBACA,IAAIZ,MAAM+B,OAAO,EAAE;wBACjBpE,MAAMqC,KAAK,CAACA,MAAM+B,OAAO,CAACC,MAAM,CAAC,GAAGC,WAAW,KAAKjC,MAAM+B,OAAO,CAACG,KAAK,CAAC;oBAC1E;gBACF;gBACA,IAAIT,MAAMU,OAAO;oBACfxE,MAAMyE,OAAO,CAACxC,EAAE;oBAChByC,OAAOC,QAAQ,CAACC,IAAI,GAAGtC;gBACzB;YACF,EAAE,OAAOuC,KAAK;gBACZ7E,MAAMqC,KAAK,CAACJ,EAAE,oBAAoB;YACpC;QACF;QACA6C,YAAY;YACVnB,UAAUL;QACZ;IACF;IAEA,MAAMyB,oBAAoB;QACxB,MAAMC,SAAS;YACbhB,OAAO/B,EAAE,oBAAoB;YAC7BiC,UAAUjC,EAAE,8BAA8B;YAC1CgD,iBAAiBhD,EAAE,qCAAqC;QAC1D;QACA,OAAO+C,MAAM,CAACjC,UAAU;IAC1B;IAEA,qBACE,MAACmC;QAAIC,WAAW,GAAG/D,UAAU,SAAS,CAAC;;YACpCgB,oBAAoBA,qBAAqB,mCAAqB,KAAC5B;gBAAU4E,QAAQ;oBAAC;iBAAuB;;0BAC1G,MAAC7E;gBACC4E,WAAW/D;gBACXuC,UAAU0B,CAAAA;oBACRA,EAAEC,cAAc;oBAChB,KAAK/B,KAAKgC,YAAY;gBACxB;;kCAEA,MAAC9E;wBAAc0E,WAAW/D;;0CACxB,KAACmC,KAAKiC,QAAQ;gCACZC,MAAK;gCACLC,UAAUC,CAAAA,sBAAS,KAACA,MAAMC,SAAS;wCAACC,MAAK;wCAAOV,WAAU;wCAAQW,cAAa;wCAAQC,OAAOhB;;;0CAEhG,KAACxB,KAAKiC,QAAQ;gCACZC,MAAK;gCACLC,UAAUC,CAAAA,sBACR,KAACA,MAAMC,SAAS;wCAACC,MAAK;wCAAWV,WAAU;wCAAWW,cAAa;wCAAWC,OAAO9D,EAAE;;;;;kCAI7F,KAAClC;wBAAK6E,MAAMpC;wBAAmBwD,UAAU;kCACtC/D,EAAE;;kCAEL,KAACsB,KAAK0C,OAAO;wBAACP,wBAAU,KAACnC,KAAK2C,MAAM;4BAACH,OAAO9D,EAAE;4BAAyBkE,cAAclE,EAAE;;;;;;;AAI/F;AAEA,OAAO,MAAMmE,mBAAoD,CAAC,EAChEC,YAAY,EACZ/E,iBAAiB,EACjBC,YAAY,EACZC,eAAe,EACfC,eAAe,EACfC,YAAY,EACZC,iBAAiB,EAClB;IACC,qBACE;;YACG0E,aAAaC,QAAQ,CAAC,kCACrB,KAACjF;gBACCC,mBAAmBA;gBACnBC,cAAcA;gBACdC,iBAAiBA;gBACjBC,iBAAiBA;gBACjBC,cAAcA;gBACdC,mBAAmBA;;0BAGvB,KAAC/B;gBACC2G,UAAU;gBACVF,cAAcA;gBACdG,YAAY,KAAO;gBACnBlE,aAAazC,gBAAgB6B,cAAca,UAAoBzC,YAAY8B,MAAM,CAACG,MAAM,CAACC,KAAK;;;;AAItG,EAAC"}
|
|
@@ -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,
|
|
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 @@
|
|
|
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+
|
|
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=
|