payload-auth 1.7.1 → 1.8.0-canary.2
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 +1 -1
- package/dist/better-auth/adapter/index.d.ts.map +1 -1
- package/dist/better-auth/adapter/index.js +57 -7
- package/dist/better-auth/adapter/transform/index.d.ts.map +1 -1
- package/dist/better-auth/adapter/transform/index.js +47 -7
- package/dist/better-auth/generated-types.d.ts +13 -11
- package/dist/better-auth/generated-types.d.ts.map +1 -1
- package/dist/better-auth/generated-types.js +1 -1
- package/dist/better-auth/plugin/index.d.ts.map +1 -1
- package/dist/better-auth/plugin/index.js +3 -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 +3 -2
- package/dist/better-auth/plugin/lib/build-collections/users/hooks/sync-account.js +5 -5
- 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 +31 -1
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/index.d.ts +3 -1
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/index.d.ts.map +1 -1
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/index.js +17 -8
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/apply-save-to-jwt-returned.d.ts +14 -0
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/apply-save-to-jwt-returned.d.ts.map +1 -0
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/apply-save-to-jwt-returned.js +38 -0
- package/dist/better-auth/plugin/payload/components/login-form/alternative-methods.d.ts +4 -0
- package/dist/better-auth/plugin/payload/components/login-form/alternative-methods.d.ts.map +1 -0
- package/dist/better-auth/plugin/payload/components/login-form/alternative-methods.js +197 -0
- package/dist/better-auth/plugin/payload/components/login-form/context.d.ts +49 -0
- package/dist/better-auth/plugin/payload/components/login-form/context.d.ts.map +1 -0
- package/dist/better-auth/plugin/payload/components/login-form/context.js +94 -0
- package/dist/better-auth/plugin/payload/components/login-form/credentials-form.d.ts +4 -0
- package/dist/better-auth/plugin/payload/components/login-form/credentials-form.d.ts.map +1 -0
- package/dist/better-auth/plugin/payload/components/login-form/credentials-form.js +167 -0
- package/dist/better-auth/plugin/payload/components/login-form/index.d.ts +4 -0
- package/dist/better-auth/plugin/payload/components/login-form/index.d.ts.map +1 -0
- package/dist/better-auth/plugin/payload/components/login-form/index.js +6 -0
- package/dist/better-auth/plugin/payload/components/{social-provider-buttons → login-form}/index.scss +17 -12
- package/dist/better-auth/plugin/payload/components/passkeys/add-button.js +2 -2
- package/dist/better-auth/plugin/payload/components/rsc-redirect.d.ts +1 -0
- package/dist/better-auth/plugin/payload/components/rsc-redirect.d.ts.map +1 -1
- package/dist/better-auth/plugin/payload/components/rsc-redirect.js +7 -2
- package/dist/better-auth/plugin/payload/exports/client.d.ts +3 -2
- package/dist/better-auth/plugin/payload/exports/client.d.ts.map +1 -1
- package/dist/better-auth/plugin/payload/exports/client.js +4 -3
- package/dist/better-auth/plugin/payload/views/admin-login/client.d.ts +11 -7
- 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 +17 -193
- 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 +25 -8
- package/dist/better-auth/plugin/payload/views/admin-signup/client.d.ts +6 -0
- package/dist/better-auth/plugin/payload/views/admin-signup/client.d.ts.map +1 -1
- package/dist/better-auth/plugin/payload/views/admin-signup/client.js +12 -10
- package/dist/better-auth/plugin/payload/views/admin-signup/index.d.ts.map +1 -1
- package/dist/better-auth/plugin/payload/views/admin-signup/index.js +22 -3
- package/dist/better-auth/plugin/payload/views/forgot-password/client.d.ts.map +1 -1
- package/dist/better-auth/plugin/payload/views/forgot-password/client.js +17 -5
- package/dist/better-auth/plugin/payload/views/reset-password/index.js +2 -2
- package/dist/better-auth/scripts/generate-types.js +2 -2
- package/dist/index.js +2 -2
- package/dist/shared/form/fields/text-field.d.ts +2 -1
- package/dist/shared/form/fields/text-field.d.ts.map +1 -1
- package/dist/shared/form/fields/text-field.js +6 -3
- package/dist/shared/form/validation.d.ts +9 -69
- package/dist/shared/form/validation.d.ts.map +1 -1
- package/dist/shared/form/validation.js +11 -24
- package/package.json +40 -13
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/save-to-jwt-middleware.d.ts +0 -16
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/save-to-jwt-middleware.d.ts.map +0 -1
- package/dist/better-auth/plugin/lib/sanitize-better-auth-options/utils/save-to-jwt-middleware.js +0 -41
- package/dist/better-auth/plugin/payload/components/social-provider-buttons/index.d.ts +0 -16
- package/dist/better-auth/plugin/payload/components/social-provider-buttons/index.d.ts.map +0 -1
- package/dist/better-auth/plugin/payload/components/social-provider-buttons/index.js +0 -144
|
@@ -0,0 +1,197 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
3
|
+
import { socialProviders } from "../../../constants";
|
|
4
|
+
import { Icons } from "../../../../../shared/components/icons";
|
|
5
|
+
import { isValidEmail } from "../../../../../shared/form/validation";
|
|
6
|
+
import { Button, toast } from "@payloadcms/ui";
|
|
7
|
+
import { Key, Mail } from "lucide-react";
|
|
8
|
+
import { useRouter } from "next/navigation";
|
|
9
|
+
import React, { useEffect, useRef, useState } from "react";
|
|
10
|
+
import { useLoginForm } from "./context";
|
|
11
|
+
import "./index.scss";
|
|
12
|
+
const baseClass = 'login-form-methods';
|
|
13
|
+
const MagicLinkButton = ()=>{
|
|
14
|
+
const { email, authClient, redirectUrl, showIconOnly } = useLoginForm();
|
|
15
|
+
const [loading, setLoading] = useState(false);
|
|
16
|
+
const [sent, setSent] = useState(false);
|
|
17
|
+
const sentEmailRef = useRef('');
|
|
18
|
+
useEffect(()=>{
|
|
19
|
+
if (sent && email !== sentEmailRef.current) {
|
|
20
|
+
setSent(false);
|
|
21
|
+
}
|
|
22
|
+
}, [
|
|
23
|
+
email,
|
|
24
|
+
sent
|
|
25
|
+
]);
|
|
26
|
+
const handleClick = async ()=>{
|
|
27
|
+
if (!email) {
|
|
28
|
+
toast.error('Please enter your email address');
|
|
29
|
+
return;
|
|
30
|
+
}
|
|
31
|
+
if (!isValidEmail(email)) {
|
|
32
|
+
toast.error('Please enter a valid email address');
|
|
33
|
+
return;
|
|
34
|
+
}
|
|
35
|
+
setLoading(true);
|
|
36
|
+
try {
|
|
37
|
+
const { error } = await authClient.signIn.magicLink({
|
|
38
|
+
email,
|
|
39
|
+
callbackURL: redirectUrl
|
|
40
|
+
});
|
|
41
|
+
if (error) {
|
|
42
|
+
toast.error(error.message || 'Failed to send magic link');
|
|
43
|
+
} else {
|
|
44
|
+
sentEmailRef.current = email;
|
|
45
|
+
setSent(true);
|
|
46
|
+
toast.success('Magic link sent! Check your email.');
|
|
47
|
+
}
|
|
48
|
+
} catch (error) {
|
|
49
|
+
toast.error(error?.message || 'Failed to send magic link');
|
|
50
|
+
} finally{
|
|
51
|
+
setLoading(false);
|
|
52
|
+
}
|
|
53
|
+
};
|
|
54
|
+
const label = sent ? 'Resend Magic Link' : 'Magic Link';
|
|
55
|
+
return /*#__PURE__*/ _jsx(Button, {
|
|
56
|
+
type: "button",
|
|
57
|
+
size: "large",
|
|
58
|
+
className: `${baseClass}__button provider--magic-link`,
|
|
59
|
+
onClick: handleClick,
|
|
60
|
+
disabled: loading,
|
|
61
|
+
iconPosition: "left",
|
|
62
|
+
icon: /*#__PURE__*/ _jsx(Mail, {
|
|
63
|
+
className: `${baseClass}__icon`
|
|
64
|
+
}),
|
|
65
|
+
tooltip: showIconOnly ? 'Sign in with Magic Link' : undefined,
|
|
66
|
+
children: !showIconOnly && /*#__PURE__*/ _jsx("span", {
|
|
67
|
+
children: loading ? 'Sending...' : label
|
|
68
|
+
})
|
|
69
|
+
});
|
|
70
|
+
};
|
|
71
|
+
const PasskeyButton = ({ setLoading })=>{
|
|
72
|
+
const router = useRouter();
|
|
73
|
+
const { authClient, redirectUrl, showIconOnly } = useLoginForm();
|
|
74
|
+
const handleClick = async ()=>{
|
|
75
|
+
setLoading(true);
|
|
76
|
+
try {
|
|
77
|
+
await authClient.signIn.passkey({
|
|
78
|
+
fetchOptions: {
|
|
79
|
+
onSuccess () {
|
|
80
|
+
if (redirectUrl) router.push(redirectUrl);
|
|
81
|
+
},
|
|
82
|
+
onError (context) {
|
|
83
|
+
toast.error(context.error.message || 'Failed to sign in with passkey');
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
});
|
|
87
|
+
} catch (error) {
|
|
88
|
+
toast.error(error?.message || 'Failed to sign in with passkey');
|
|
89
|
+
} finally{
|
|
90
|
+
setLoading(false);
|
|
91
|
+
}
|
|
92
|
+
};
|
|
93
|
+
return /*#__PURE__*/ _jsx(Button, {
|
|
94
|
+
type: "button",
|
|
95
|
+
size: "large",
|
|
96
|
+
className: `${baseClass}__button provider--passkey`,
|
|
97
|
+
onClick: handleClick,
|
|
98
|
+
iconPosition: "left",
|
|
99
|
+
icon: /*#__PURE__*/ _jsx(Key, {
|
|
100
|
+
className: `${baseClass}__icon`
|
|
101
|
+
}),
|
|
102
|
+
tooltip: showIconOnly ? 'Sign in with Passkey' : undefined,
|
|
103
|
+
children: !showIconOnly && /*#__PURE__*/ _jsx("span", {
|
|
104
|
+
children: "Passkey"
|
|
105
|
+
})
|
|
106
|
+
});
|
|
107
|
+
};
|
|
108
|
+
const SocialButton = ({ provider, setLoading })=>{
|
|
109
|
+
const { authClient, redirectUrl, isSignup, showIconOnly, adminInviteToken, newUserCallbackURL } = useLoginForm();
|
|
110
|
+
const Icon = Icons[provider] ?? null;
|
|
111
|
+
const providerName = provider.charAt(0).toUpperCase() + provider.slice(1);
|
|
112
|
+
const handleClick = async ()=>{
|
|
113
|
+
setLoading(true);
|
|
114
|
+
try {
|
|
115
|
+
const { error } = await authClient.signIn.social({
|
|
116
|
+
provider,
|
|
117
|
+
fetchOptions: {
|
|
118
|
+
query: {
|
|
119
|
+
...isSignup && {
|
|
120
|
+
adminInviteToken
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
},
|
|
124
|
+
errorCallbackURL: window.location.href,
|
|
125
|
+
callbackURL: redirectUrl,
|
|
126
|
+
newUserCallbackURL,
|
|
127
|
+
...isSignup && {
|
|
128
|
+
requestSignUp: true
|
|
129
|
+
}
|
|
130
|
+
});
|
|
131
|
+
if (error) {
|
|
132
|
+
toast.error(error.message);
|
|
133
|
+
}
|
|
134
|
+
} catch {
|
|
135
|
+
toast.error(`Failed to sign in with ${providerName}`);
|
|
136
|
+
} finally{
|
|
137
|
+
setLoading(false);
|
|
138
|
+
}
|
|
139
|
+
};
|
|
140
|
+
return /*#__PURE__*/ _jsx(Button, {
|
|
141
|
+
type: "button",
|
|
142
|
+
size: "large",
|
|
143
|
+
className: `${baseClass}__button provider--${provider}`,
|
|
144
|
+
onClick: handleClick,
|
|
145
|
+
iconPosition: "left",
|
|
146
|
+
icon: Icon ? /*#__PURE__*/ _jsx(Icon, {
|
|
147
|
+
className: `${baseClass}__icon`
|
|
148
|
+
}) : undefined,
|
|
149
|
+
tooltip: showIconOnly ? `Sign in with ${providerName}` : undefined,
|
|
150
|
+
children: !showIconOnly && /*#__PURE__*/ _jsx("span", {
|
|
151
|
+
children: providerName
|
|
152
|
+
})
|
|
153
|
+
});
|
|
154
|
+
};
|
|
155
|
+
export const AlternativeMethods = ()=>{
|
|
156
|
+
const { alternativeMethods, hasMethod, isSignup, showIconOnly } = useLoginForm();
|
|
157
|
+
const [loading, setLoading] = useState(false);
|
|
158
|
+
if (alternativeMethods.length === 0) return null;
|
|
159
|
+
return /*#__PURE__*/ _jsxs(_Fragment, {
|
|
160
|
+
children: [
|
|
161
|
+
hasMethod('emailPassword') && /*#__PURE__*/ _jsx("div", {
|
|
162
|
+
className: `${baseClass}__divider`,
|
|
163
|
+
children: /*#__PURE__*/ _jsxs("span", {
|
|
164
|
+
children: [
|
|
165
|
+
"Or ",
|
|
166
|
+
isSignup ? 'sign up' : 'login',
|
|
167
|
+
" with"
|
|
168
|
+
]
|
|
169
|
+
})
|
|
170
|
+
}),
|
|
171
|
+
/*#__PURE__*/ _jsx("div", {
|
|
172
|
+
className: `${baseClass} ${baseClass}--count-${showIconOnly ? 'many' : alternativeMethods.length}`,
|
|
173
|
+
children: alternativeMethods.map((method)=>{
|
|
174
|
+
if (method === 'passkey') {
|
|
175
|
+
if (isSignup) return null;
|
|
176
|
+
return /*#__PURE__*/ _jsx(PasskeyButton, {
|
|
177
|
+
setLoading: setLoading
|
|
178
|
+
}, method);
|
|
179
|
+
}
|
|
180
|
+
if (method === 'magicLink') {
|
|
181
|
+
if (isSignup) return null;
|
|
182
|
+
return /*#__PURE__*/ _jsx(MagicLinkButton, {}, method);
|
|
183
|
+
}
|
|
184
|
+
if (socialProviders.includes(method)) {
|
|
185
|
+
return /*#__PURE__*/ _jsx(SocialButton, {
|
|
186
|
+
provider: method,
|
|
187
|
+
setLoading: setLoading
|
|
188
|
+
}, method);
|
|
189
|
+
}
|
|
190
|
+
return null;
|
|
191
|
+
})
|
|
192
|
+
})
|
|
193
|
+
]
|
|
194
|
+
});
|
|
195
|
+
};
|
|
196
|
+
|
|
197
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../../src/better-auth/plugin/payload/components/login-form/alternative-methods.tsx"],"sourcesContent":["'use client'\n\nimport { socialProviders } from '@/better-auth/plugin/constants'\nimport type { SocialProvider } from '@/better-auth/plugin/types'\nimport { Icons } from '@/shared/components/icons'\nimport { isValidEmail } from '@/shared/form/validation'\nimport { Button, toast } from '@payloadcms/ui'\nimport { Key, Mail } from 'lucide-react'\nimport { useRouter } from 'next/navigation'\nimport React, { useEffect, useRef, useState } from 'react'\nimport { useLoginForm } from './context'\nimport './index.scss'\n\nconst baseClass = 'login-form-methods'\n\nconst MagicLinkButton: React.FC = () => {\n  const { email, authClient, redirectUrl, showIconOnly } = useLoginForm()\n  const [loading, setLoading] = useState(false)\n  const [sent, setSent] = useState(false)\n  const sentEmailRef = useRef('')\n\n  useEffect(() => {\n    if (sent && email !== sentEmailRef.current) {\n      setSent(false)\n    }\n  }, [email, sent])\n\n  const handleClick = async () => {\n    if (!email) {\n      toast.error('Please enter your email address')\n      return\n    }\n    if (!isValidEmail(email)) {\n      toast.error('Please enter a valid email address')\n      return\n    }\n\n    setLoading(true)\n    try {\n      const { error } = await authClient.signIn.magicLink({ email, callbackURL: redirectUrl })\n      if (error) {\n        toast.error(error.message || 'Failed to send magic link')\n      } else {\n        sentEmailRef.current = email\n        setSent(true)\n        toast.success('Magic link sent! Check your email.')\n      }\n    } catch (error: any) {\n      toast.error(error?.message || 'Failed to send magic link')\n    } finally {\n      setLoading(false)\n    }\n  }\n\n  const label = sent ? 'Resend Magic Link' : 'Magic Link'\n\n  return (\n    <Button\n      type=\"button\"\n      size=\"large\"\n      className={`${baseClass}__button provider--magic-link`}\n      onClick={handleClick}\n      disabled={loading}\n      iconPosition=\"left\"\n      icon={<Mail className={`${baseClass}__icon`} />}\n      tooltip={showIconOnly ? 'Sign in with Magic Link' : undefined}>\n      {!showIconOnly && <span>{loading ? 'Sending...' : label}</span>}\n    </Button>\n  )\n}\n\ntype PasskeyButtonProps = {\n  setLoading: (loading: boolean) => void\n}\n\nconst PasskeyButton: React.FC<PasskeyButtonProps> = ({ setLoading }) => {\n  const router = useRouter()\n  const { authClient, redirectUrl, showIconOnly } = useLoginForm()\n\n  const handleClick = async () => {\n    setLoading(true)\n    try {\n      await authClient.signIn.passkey({\n        fetchOptions: {\n          onSuccess() {\n            if (redirectUrl) router.push(redirectUrl)\n          },\n          onError(context: any) {\n            toast.error(context.error.message || 'Failed to sign in with passkey')\n          }\n        }\n      })\n    } catch (error: any) {\n      toast.error(error?.message || 'Failed to sign in with passkey')\n    } finally {\n      setLoading(false)\n    }\n  }\n\n  return (\n    <Button\n      type=\"button\"\n      size=\"large\"\n      className={`${baseClass}__button provider--passkey`}\n      onClick={handleClick}\n      iconPosition=\"left\"\n      icon={<Key className={`${baseClass}__icon`} />}\n      tooltip={showIconOnly ? 'Sign in with Passkey' : undefined}>\n      {!showIconOnly && <span>Passkey</span>}\n    </Button>\n  )\n}\n\ntype SocialButtonProps = {\n  provider: SocialProvider\n  setLoading: (loading: boolean) => void\n}\n\nconst SocialButton: React.FC<SocialButtonProps> = ({ provider, setLoading }) => {\n  const { authClient, redirectUrl, isSignup, showIconOnly, adminInviteToken, newUserCallbackURL } = useLoginForm()\n  const Icon = Icons[provider as keyof typeof Icons] ?? null\n  const providerName = provider.charAt(0).toUpperCase() + provider.slice(1)\n\n  const handleClick = async () => {\n    setLoading(true)\n    try {\n      const { error } = await authClient.signIn.social({\n        provider,\n        fetchOptions: {\n          query: {\n            ...(isSignup && { adminInviteToken })\n          }\n        },\n        errorCallbackURL: window.location.href,\n        callbackURL: redirectUrl,\n        newUserCallbackURL,\n        ...(isSignup && { requestSignUp: true })\n      })\n      if (error) {\n        toast.error(error.message)\n      }\n    } catch {\n      toast.error(`Failed to sign in with ${providerName}`)\n    } finally {\n      setLoading(false)\n    }\n  }\n\n  return (\n    <Button\n      type=\"button\"\n      size=\"large\"\n      className={`${baseClass}__button provider--${provider}`}\n      onClick={handleClick}\n      iconPosition=\"left\"\n      icon={Icon ? <Icon className={`${baseClass}__icon`} /> : undefined}\n      tooltip={showIconOnly ? `Sign in with ${providerName}` : undefined}>\n      {!showIconOnly && <span>{providerName}</span>}\n    </Button>\n  )\n}\n\nexport const AlternativeMethods: React.FC = () => {\n  const { alternativeMethods, hasMethod, isSignup, showIconOnly } = useLoginForm()\n  const [loading, setLoading] = useState(false)\n  \n  if (alternativeMethods.length === 0) return null\n\n  return (\n    <>\n      {hasMethod('emailPassword') && (\n        <div className={`${baseClass}__divider`}>\n          <span>Or {isSignup ? 'sign up' : 'login'} with</span>\n        </div>\n      )}\n      <div className={`${baseClass} ${baseClass}--count-${showIconOnly ? 'many' : alternativeMethods.length}`}>\n        {alternativeMethods.map((method) => {\n          if (method === 'passkey') {\n            if (isSignup) return null\n            return <PasskeyButton key={method} setLoading={setLoading} />\n          }\n\n          if (method === 'magicLink') {\n            if (isSignup) return null\n            return <MagicLinkButton key={method} />\n          }\n\n          if (socialProviders.includes(method as SocialProvider)) {\n            return <SocialButton key={method} provider={method as SocialProvider} setLoading={setLoading} />\n          }\n\n          return null\n        })}\n      </div>\n    </>\n  )\n}\n\n"],"names":["socialProviders","Icons","isValidEmail","Button","toast","Key","Mail","useRouter","React","useEffect","useRef","useState","useLoginForm","baseClass","MagicLinkButton","email","authClient","redirectUrl","showIconOnly","loading","setLoading","sent","setSent","sentEmailRef","current","handleClick","error","signIn","magicLink","callbackURL","message","success","label","type","size","className","onClick","disabled","iconPosition","icon","tooltip","undefined","span","PasskeyButton","router","passkey","fetchOptions","onSuccess","push","onError","context","SocialButton","provider","isSignup","adminInviteToken","newUserCallbackURL","Icon","providerName","charAt","toUpperCase","slice","social","query","errorCallbackURL","window","location","href","requestSignUp","AlternativeMethods","alternativeMethods","hasMethod","length","div","map","method","includes"],"mappings":"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"}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import type { LoginMethod } from '@/better-auth/plugin/types';
|
|
2
|
+
import React from 'react';
|
|
3
|
+
type LoginFormContextValue = {
|
|
4
|
+
loginMethods: LoginMethod[];
|
|
5
|
+
email: string;
|
|
6
|
+
setEmail: (email: string) => void;
|
|
7
|
+
redirectUrl: string;
|
|
8
|
+
isSignup: boolean;
|
|
9
|
+
authClient: any;
|
|
10
|
+
loginType: 'email' | 'username' | 'emailOrUsername';
|
|
11
|
+
hasMethod: (method: LoginMethod) => boolean;
|
|
12
|
+
alternativeMethods: LoginMethod[];
|
|
13
|
+
showIconOnly: boolean;
|
|
14
|
+
adminInviteToken?: string;
|
|
15
|
+
newUserCallbackURL?: string;
|
|
16
|
+
prefill: {
|
|
17
|
+
email?: string;
|
|
18
|
+
password?: string;
|
|
19
|
+
username?: string;
|
|
20
|
+
};
|
|
21
|
+
};
|
|
22
|
+
type Prefill = {
|
|
23
|
+
email?: string;
|
|
24
|
+
password?: string;
|
|
25
|
+
username?: string;
|
|
26
|
+
};
|
|
27
|
+
type Plugins = {
|
|
28
|
+
username?: boolean;
|
|
29
|
+
passkey?: boolean;
|
|
30
|
+
magicLink?: boolean;
|
|
31
|
+
};
|
|
32
|
+
type LoginIdentifier = 'email' | 'username';
|
|
33
|
+
export type LoginFormProviderProps = {
|
|
34
|
+
children: React.ReactNode;
|
|
35
|
+
loginMethods: LoginMethod[];
|
|
36
|
+
redirectUrl: string;
|
|
37
|
+
baseURL?: string;
|
|
38
|
+
basePath?: string;
|
|
39
|
+
isSignup?: boolean;
|
|
40
|
+
loginIdentifiers: LoginIdentifier[];
|
|
41
|
+
plugins?: Plugins;
|
|
42
|
+
prefill?: Prefill;
|
|
43
|
+
adminInviteToken?: string;
|
|
44
|
+
newUserCallbackURL?: string;
|
|
45
|
+
};
|
|
46
|
+
export declare const LoginFormProvider: React.FC<LoginFormProviderProps>;
|
|
47
|
+
export declare const useLoginForm: () => LoginFormContextValue;
|
|
48
|
+
export {};
|
|
49
|
+
//# sourceMappingURL=context.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"context.d.ts","sourceRoot":"","sources":["../../../../../../src/better-auth/plugin/payload/components/login-form/context.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,4BAA4B,CAAA;AAC7D,OAAO,KAAuD,MAAM,OAAO,CAAA;AAO3E,KAAK,qBAAqB,GAAG;IAC3B,YAAY,EAAE,WAAW,EAAE,CAAA;IAC3B,KAAK,EAAE,MAAM,CAAA;IACb,QAAQ,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAA;IACjC,WAAW,EAAE,MAAM,CAAA;IACnB,QAAQ,EAAE,OAAO,CAAA;IACjB,UAAU,EAAE,GAAG,CAAA;IACf,SAAS,EAAE,OAAO,GAAG,UAAU,GAAG,iBAAiB,CAAA;IACnD,SAAS,EAAE,CAAC,MAAM,EAAE,WAAW,KAAK,OAAO,CAAA;IAC3C,kBAAkB,EAAE,WAAW,EAAE,CAAA;IACjC,YAAY,EAAE,OAAO,CAAA;IACrB,gBAAgB,CAAC,EAAE,MAAM,CAAA;IACzB,kBAAkB,CAAC,EAAE,MAAM,CAAA;IAC3B,OAAO,EAAE;QACP,KAAK,CAAC,EAAE,MAAM,CAAA;QACd,QAAQ,CAAC,EAAE,MAAM,CAAA;QACjB,QAAQ,CAAC,EAAE,MAAM,CAAA;KAClB,CAAA;CACF,CAAA;AAID,KAAK,OAAO,GAAG;IACb,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,QAAQ,CAAC,EAAE,MAAM,CAAA;CAClB,CAAA;AAED,KAAK,OAAO,GAAG;IACb,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,OAAO,CAAC,EAAE,OAAO,CAAA;IACjB,SAAS,CAAC,EAAE,OAAO,CAAA;CACpB,CAAA;AAED,KAAK,eAAe,GAAG,OAAO,GAAG,UAAU,CAAA;AAE3C,MAAM,MAAM,sBAAsB,GAAG;IACnC,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAA;IACzB,YAAY,EAAE,WAAW,EAAE,CAAA;IAC3B,WAAW,EAAE,MAAM,CAAA;IACnB,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,gBAAgB,EAAE,eAAe,EAAE,CAAA;IACnC,OAAO,CAAC,EAAE,OAAO,CAAA;IACjB,OAAO,CAAC,EAAE,OAAO,CAAA;IACjB,gBAAgB,CAAC,EAAE,MAAM,CAAA;IACzB,kBAAkB,CAAC,EAAE,MAAM,CAAA;CAC5B,CAAA;AAED,eAAO,MAAM,iBAAiB,EAAE,KAAK,CAAC,EAAE,CAAC,sBAAsB,CAgF9D,CAAA;AAED,eAAO,MAAM,YAAY,6BAMxB,CAAA"}
|
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
3
|
+
import React, { createContext, useContext, useMemo, useState } from "react";
|
|
4
|
+
import { createAuthClient } from "better-auth/react";
|
|
5
|
+
import { usernameClient, twoFactorClient, magicLinkClient } from "better-auth/client/plugins";
|
|
6
|
+
import { passkeyClient } from "@better-auth/passkey/client";
|
|
7
|
+
import { useRouter } from "next/navigation";
|
|
8
|
+
import { adminRoutes } from "../../../constants";
|
|
9
|
+
const LoginFormContext = /*#__PURE__*/ createContext(null);
|
|
10
|
+
export const LoginFormProvider = ({ children, loginMethods, redirectUrl, baseURL, basePath, isSignup = false, loginIdentifiers, plugins, prefill, adminInviteToken, newUserCallbackURL })=>{
|
|
11
|
+
const { username: hasUsernamePlugin = false, passkey: hasPasskeyPlugin = false, magicLink: hasMagicLinkPlugin = false } = plugins ?? {};
|
|
12
|
+
const resolvedPrefill = prefill ?? {};
|
|
13
|
+
const router = useRouter();
|
|
14
|
+
const [email, setEmail] = useState(resolvedPrefill.email ?? '');
|
|
15
|
+
const authClient = useMemo(()=>createAuthClient({
|
|
16
|
+
baseURL,
|
|
17
|
+
basePath,
|
|
18
|
+
plugins: [
|
|
19
|
+
usernameClient(),
|
|
20
|
+
twoFactorClient({
|
|
21
|
+
onTwoFactorRedirect () {
|
|
22
|
+
router.push(`${redirectUrl.split('?')[0]}${adminRoutes.twoFactorVerify}?redirect=${redirectUrl}`);
|
|
23
|
+
}
|
|
24
|
+
}),
|
|
25
|
+
...hasPasskeyPlugin ? [
|
|
26
|
+
passkeyClient()
|
|
27
|
+
] : [],
|
|
28
|
+
...hasMagicLinkPlugin || loginMethods.includes('magicLink') ? [
|
|
29
|
+
magicLinkClient()
|
|
30
|
+
] : []
|
|
31
|
+
]
|
|
32
|
+
}), [
|
|
33
|
+
baseURL,
|
|
34
|
+
basePath,
|
|
35
|
+
hasMagicLinkPlugin,
|
|
36
|
+
hasPasskeyPlugin,
|
|
37
|
+
loginMethods,
|
|
38
|
+
redirectUrl,
|
|
39
|
+
router
|
|
40
|
+
]);
|
|
41
|
+
const canLoginWithEmail = loginIdentifiers.includes('email');
|
|
42
|
+
const canLoginWithUsername = loginIdentifiers.includes('username');
|
|
43
|
+
const loginType = useMemo(()=>{
|
|
44
|
+
if (canLoginWithEmail && canLoginWithUsername && hasUsernamePlugin) return 'emailOrUsername';
|
|
45
|
+
if (canLoginWithUsername && hasUsernamePlugin) return 'username';
|
|
46
|
+
return 'email';
|
|
47
|
+
}, [
|
|
48
|
+
canLoginWithEmail,
|
|
49
|
+
canLoginWithUsername,
|
|
50
|
+
hasUsernamePlugin
|
|
51
|
+
]);
|
|
52
|
+
const hasMethod = (method)=>loginMethods.includes(method);
|
|
53
|
+
const alternativeMethods = useMemo(()=>loginMethods.filter((m)=>{
|
|
54
|
+
if (m === 'emailPassword') return false;
|
|
55
|
+
if (isSignup && (m === 'passkey' || m === 'magicLink')) return false;
|
|
56
|
+
return true;
|
|
57
|
+
}), [
|
|
58
|
+
loginMethods,
|
|
59
|
+
isSignup
|
|
60
|
+
]);
|
|
61
|
+
const showIconOnly = alternativeMethods.length >= 3;
|
|
62
|
+
const value = {
|
|
63
|
+
loginMethods,
|
|
64
|
+
email,
|
|
65
|
+
setEmail,
|
|
66
|
+
redirectUrl,
|
|
67
|
+
isSignup,
|
|
68
|
+
authClient,
|
|
69
|
+
loginType,
|
|
70
|
+
hasMethod,
|
|
71
|
+
alternativeMethods,
|
|
72
|
+
showIconOnly,
|
|
73
|
+
adminInviteToken,
|
|
74
|
+
newUserCallbackURL,
|
|
75
|
+
prefill: {
|
|
76
|
+
email: resolvedPrefill.email,
|
|
77
|
+
password: resolvedPrefill.password,
|
|
78
|
+
username: resolvedPrefill.username
|
|
79
|
+
}
|
|
80
|
+
};
|
|
81
|
+
return /*#__PURE__*/ _jsx(LoginFormContext.Provider, {
|
|
82
|
+
value: value,
|
|
83
|
+
children: children
|
|
84
|
+
});
|
|
85
|
+
};
|
|
86
|
+
export const useLoginForm = ()=>{
|
|
87
|
+
const context = useContext(LoginFormContext);
|
|
88
|
+
if (!context) {
|
|
89
|
+
throw new Error('useLoginForm must be used within a LoginFormProvider');
|
|
90
|
+
}
|
|
91
|
+
return context;
|
|
92
|
+
};
|
|
93
|
+
|
|
94
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../../src/better-auth/plugin/payload/components/login-form/context.tsx"],"sourcesContent":["'use client'\n\nimport type { LoginMethod } from '@/better-auth/plugin/types'\nimport React, { createContext, useContext, useMemo, useState } from 'react'\nimport { createAuthClient } from 'better-auth/react'\nimport { usernameClient, twoFactorClient, magicLinkClient } from 'better-auth/client/plugins'\nimport { passkeyClient } from '@better-auth/passkey/client'\nimport { useRouter } from 'next/navigation'\nimport { adminRoutes } from '@/better-auth/plugin/constants'\n\ntype LoginFormContextValue = {\n  loginMethods: LoginMethod[]\n  email: string\n  setEmail: (email: string) => void\n  redirectUrl: string\n  isSignup: boolean\n  authClient: any\n  loginType: 'email' | 'username' | 'emailOrUsername'\n  hasMethod: (method: LoginMethod) => boolean\n  alternativeMethods: LoginMethod[]\n  showIconOnly: boolean\n  adminInviteToken?: string\n  newUserCallbackURL?: string\n  prefill: {\n    email?: string\n    password?: string\n    username?: string\n  }\n}\n\nconst LoginFormContext = createContext<LoginFormContextValue | null>(null)\n\ntype Prefill = {\n  email?: string\n  password?: string\n  username?: string\n}\n\ntype Plugins = {\n  username?: boolean\n  passkey?: boolean\n  magicLink?: boolean\n}\n\ntype LoginIdentifier = 'email' | 'username'\n\nexport type LoginFormProviderProps = {\n  children: React.ReactNode\n  loginMethods: LoginMethod[]\n  redirectUrl: string\n  baseURL?: string\n  basePath?: string\n  isSignup?: boolean\n  loginIdentifiers: LoginIdentifier[]\n  plugins?: Plugins\n  prefill?: Prefill\n  adminInviteToken?: string\n  newUserCallbackURL?: string\n}\n\nexport const LoginFormProvider: React.FC<LoginFormProviderProps> = ({\n  children,\n  loginMethods,\n  redirectUrl,\n  baseURL,\n  basePath,\n  isSignup = false,\n  loginIdentifiers,\n  plugins,\n  prefill,\n  adminInviteToken,\n  newUserCallbackURL\n}) => {\n  const { username: hasUsernamePlugin = false, passkey: hasPasskeyPlugin = false, magicLink: hasMagicLinkPlugin = false } = plugins ?? {}\n  const resolvedPrefill: Prefill = prefill ?? {}\n\n  const router = useRouter()\n  const [email, setEmail] = useState(resolvedPrefill.email ?? '')\n\n  const authClient = useMemo(\n    () =>\n      createAuthClient({\n        baseURL,\n        basePath,\n        plugins: [\n          usernameClient(),\n          twoFactorClient({\n            onTwoFactorRedirect() {\n              router.push(`${redirectUrl.split('?')[0]}${adminRoutes.twoFactorVerify}?redirect=${redirectUrl}`)\n            }\n          }),\n          ...(hasPasskeyPlugin ? [passkeyClient()] : []),\n          ...(hasMagicLinkPlugin || loginMethods.includes('magicLink') ? [magicLinkClient()] : [])\n        ]\n      }),\n    [baseURL, basePath, hasMagicLinkPlugin, hasPasskeyPlugin, loginMethods, redirectUrl, router]\n  )\n\n  const canLoginWithEmail = loginIdentifiers.includes('email')\n  const canLoginWithUsername = loginIdentifiers.includes('username')\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\n  const hasMethod = (method: LoginMethod) => loginMethods.includes(method)\n  const alternativeMethods = useMemo(\n    () =>\n      loginMethods.filter((m) => {\n        if (m === 'emailPassword') return false\n        if (isSignup && (m === 'passkey' || m === 'magicLink')) return false\n        return true\n      }),\n    [loginMethods, isSignup]\n  )\n  const showIconOnly = alternativeMethods.length >= 3\n\n  const value: LoginFormContextValue = {\n    loginMethods,\n    email,\n    setEmail,\n    redirectUrl,\n    isSignup,\n    authClient,\n    loginType,\n    hasMethod,\n    alternativeMethods,\n    showIconOnly,\n    adminInviteToken,\n    newUserCallbackURL,\n    prefill: {\n      email: resolvedPrefill.email,\n      password: resolvedPrefill.password,\n      username: resolvedPrefill.username\n    }\n  }\n\n  return <LoginFormContext.Provider value={value}>{children}</LoginFormContext.Provider>\n}\n\nexport const useLoginForm = () => {\n  const context = useContext(LoginFormContext)\n  if (!context) {\n    throw new Error('useLoginForm must be used within a LoginFormProvider')\n  }\n  return context\n}\n"],"names":["React","createContext","useContext","useMemo","useState","createAuthClient","usernameClient","twoFactorClient","magicLinkClient","passkeyClient","useRouter","adminRoutes","LoginFormContext","LoginFormProvider","children","loginMethods","redirectUrl","baseURL","basePath","isSignup","loginIdentifiers","plugins","prefill","adminInviteToken","newUserCallbackURL","username","hasUsernamePlugin","passkey","hasPasskeyPlugin","magicLink","hasMagicLinkPlugin","resolvedPrefill","router","email","setEmail","authClient","onTwoFactorRedirect","push","split","twoFactorVerify","includes","canLoginWithEmail","canLoginWithUsername","loginType","hasMethod","method","alternativeMethods","filter","m","showIconOnly","length","value","password","Provider","useLoginForm","context","Error"],"mappings":"AAAA;;AAGA,OAAOA,SAASC,aAAa,EAAEC,UAAU,EAAEC,OAAO,EAAEC,QAAQ,QAAQ,QAAO;AAC3E,SAASC,gBAAgB,QAAQ,oBAAmB;AACpD,SAASC,cAAc,EAAEC,eAAe,EAAEC,eAAe,QAAQ,6BAA4B;AAC7F,SAASC,aAAa,QAAQ,8BAA6B;AAC3D,SAASC,SAAS,QAAQ,kBAAiB;AAC3C,SAASC,WAAW,QAAQ,qBAAgC;AAsB5D,MAAMC,iCAAmBX,cAA4C;AA8BrE,OAAO,MAAMY,oBAAsD,CAAC,EAClEC,QAAQ,EACRC,YAAY,EACZC,WAAW,EACXC,OAAO,EACPC,QAAQ,EACRC,WAAW,KAAK,EAChBC,gBAAgB,EAChBC,OAAO,EACPC,OAAO,EACPC,gBAAgB,EAChBC,kBAAkB,EACnB;IACC,MAAM,EAAEC,UAAUC,oBAAoB,KAAK,EAAEC,SAASC,mBAAmB,KAAK,EAAEC,WAAWC,qBAAqB,KAAK,EAAE,GAAGT,WAAW,CAAC;IACtI,MAAMU,kBAA2BT,WAAW,CAAC;IAE7C,MAAMU,SAAStB;IACf,MAAM,CAACuB,OAAOC,SAAS,GAAG9B,SAAS2B,gBAAgBE,KAAK,IAAI;IAE5D,MAAME,aAAahC,QACjB,IACEE,iBAAiB;YACfY;YACAC;YACAG,SAAS;gBACPf;gBACAC,gBAAgB;oBACd6B;wBACEJ,OAAOK,IAAI,CAAC,GAAGrB,YAAYsB,KAAK,CAAC,IAAI,CAAC,EAAE,GAAG3B,YAAY4B,eAAe,CAAC,UAAU,EAAEvB,aAAa;oBAClG;gBACF;mBACIY,mBAAmB;oBAACnB;iBAAgB,GAAG,EAAE;mBACzCqB,sBAAsBf,aAAayB,QAAQ,CAAC,eAAe;oBAAChC;iBAAkB,GAAG,EAAE;aACxF;QACH,IACF;QAACS;QAASC;QAAUY;QAAoBF;QAAkBb;QAAcC;QAAagB;KAAO;IAG9F,MAAMS,oBAAoBrB,iBAAiBoB,QAAQ,CAAC;IACpD,MAAME,uBAAuBtB,iBAAiBoB,QAAQ,CAAC;IAEvD,MAAMG,YAAYxC,QAAQ;QACxB,IAAIsC,qBAAqBC,wBAAwBhB,mBAAmB,OAAO;QAC3E,IAAIgB,wBAAwBhB,mBAAmB,OAAO;QACtD,OAAO;IACT,GAAG;QAACe;QAAmBC;QAAsBhB;KAAkB;IAE/D,MAAMkB,YAAY,CAACC,SAAwB9B,aAAayB,QAAQ,CAACK;IACjE,MAAMC,qBAAqB3C,QACzB,IACEY,aAAagC,MAAM,CAAC,CAACC;YACnB,IAAIA,MAAM,iBAAiB,OAAO;YAClC,IAAI7B,YAAa6B,CAAAA,MAAM,aAAaA,MAAM,WAAU,GAAI,OAAO;YAC/D,OAAO;QACT,IACF;QAACjC;QAAcI;KAAS;IAE1B,MAAM8B,eAAeH,mBAAmBI,MAAM,IAAI;IAElD,MAAMC,QAA+B;QACnCpC;QACAkB;QACAC;QACAlB;QACAG;QACAgB;QACAQ;QACAC;QACAE;QACAG;QACA1B;QACAC;QACAF,SAAS;YACPW,OAAOF,gBAAgBE,KAAK;YAC5BmB,UAAUrB,gBAAgBqB,QAAQ;YAClC3B,UAAUM,gBAAgBN,QAAQ;QACpC;IACF;IAEA,qBAAO,KAACb,iBAAiByC,QAAQ;QAACF,OAAOA;kBAAQrC;;AACnD,EAAC;AAED,OAAO,MAAMwC,eAAe;IAC1B,MAAMC,UAAUrD,WAAWU;IAC3B,IAAI,CAAC2C,SAAS;QACZ,MAAM,IAAIC,MAAM;IAClB;IACA,OAAOD;AACT,EAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"credentials-form.d.ts","sourceRoot":"","sources":["../../../../../../src/better-auth/plugin/payload/components/login-form/credentials-form.tsx"],"names":[],"mappings":"AAUA,OAAO,KAAmB,MAAM,OAAO,CAAA;AAEvC,OAAO,cAAc,CAAA;AAIrB,eAAO,MAAM,eAAe,EAAE,KAAK,CAAC,EAyHnC,CAAA"}
|
|
@@ -0,0 +1,167 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
3
|
+
import { adminRoutes } from "../../../constants";
|
|
4
|
+
import { useAppForm } from "../../../../../shared/form";
|
|
5
|
+
import { Form, FormError, FormInputWrap } from "../../../../../shared/form/ui";
|
|
6
|
+
import { FormHeader } from "../../../../../shared/form/ui/header";
|
|
7
|
+
import { createLoginSchema, isValidEmail } from "../../../../../shared/form/validation";
|
|
8
|
+
import { valueOrDefaultString } from "../../../../../shared/utils/value-or-default";
|
|
9
|
+
import { useConfig, Link, toast, useTranslation } from "@payloadcms/ui";
|
|
10
|
+
import { formatAdminURL } from "payload/shared";
|
|
11
|
+
import React, { useState } from "react";
|
|
12
|
+
import { useLoginForm } from "./context";
|
|
13
|
+
import "./index.scss";
|
|
14
|
+
const baseClass = 'login__form';
|
|
15
|
+
export const CredentialsForm = ()=>{
|
|
16
|
+
const { config } = useConfig();
|
|
17
|
+
const { t } = useTranslation();
|
|
18
|
+
const { authClient, loginType, hasMethod, setEmail, redirectUrl, prefill } = useLoginForm();
|
|
19
|
+
const adminRoute = valueOrDefaultString(config?.routes?.admin, '/admin');
|
|
20
|
+
const hasEmailPassword = hasMethod('emailPassword');
|
|
21
|
+
const hasMagicLink = hasMethod('magicLink');
|
|
22
|
+
const showEmailField = hasEmailPassword || hasMagicLink;
|
|
23
|
+
const showPasswordField = hasEmailPassword;
|
|
24
|
+
const [requireEmailVerification, setRequireEmailVerification] = useState(false);
|
|
25
|
+
const [searchParamError] = useState(()=>{
|
|
26
|
+
if (typeof window !== 'undefined') {
|
|
27
|
+
const params = new URLSearchParams(window.location.search);
|
|
28
|
+
return params.get('error');
|
|
29
|
+
}
|
|
30
|
+
return null;
|
|
31
|
+
});
|
|
32
|
+
const forgotPasswordUrl = formatAdminURL({
|
|
33
|
+
adminRoute,
|
|
34
|
+
path: adminRoutes?.forgotPassword
|
|
35
|
+
});
|
|
36
|
+
const loginSchema = createLoginSchema({
|
|
37
|
+
t,
|
|
38
|
+
loginType,
|
|
39
|
+
canLoginWithUsername: loginType !== 'email'
|
|
40
|
+
});
|
|
41
|
+
const form = useAppForm({
|
|
42
|
+
defaultValues: {
|
|
43
|
+
login: prefill.email ?? prefill.username ?? '',
|
|
44
|
+
password: prefill.password ?? ''
|
|
45
|
+
},
|
|
46
|
+
onSubmit: async ({ value })=>{
|
|
47
|
+
if (!showPasswordField) return;
|
|
48
|
+
const { login, password } = value;
|
|
49
|
+
const isEmail = isValidEmail(login);
|
|
50
|
+
console.log(value);
|
|
51
|
+
try {
|
|
52
|
+
const { data, error } = await (loginType === 'email' || loginType === 'emailOrUsername' && isEmail ? authClient.signIn.email({
|
|
53
|
+
email: login,
|
|
54
|
+
password,
|
|
55
|
+
callbackURL: redirectUrl
|
|
56
|
+
}) : authClient.signIn.username({
|
|
57
|
+
username: login,
|
|
58
|
+
password
|
|
59
|
+
}));
|
|
60
|
+
if (error) {
|
|
61
|
+
if (error.code === 'EMAIL_NOT_VERIFIED') {
|
|
62
|
+
setRequireEmailVerification(true);
|
|
63
|
+
}
|
|
64
|
+
if (error.message) {
|
|
65
|
+
toast.error(error.message.charAt(0).toUpperCase() + error.message.slice(1));
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
if (data?.token) {
|
|
69
|
+
toast.success(t('general:success'));
|
|
70
|
+
window.location.href = redirectUrl;
|
|
71
|
+
}
|
|
72
|
+
} catch {
|
|
73
|
+
toast.error(t('error:unknown') || 'An unexpected error occurred');
|
|
74
|
+
}
|
|
75
|
+
},
|
|
76
|
+
validators: showPasswordField ? {
|
|
77
|
+
onSubmit: loginSchema
|
|
78
|
+
} : undefined
|
|
79
|
+
});
|
|
80
|
+
if (!showEmailField) return null;
|
|
81
|
+
if (requireEmailVerification) {
|
|
82
|
+
return /*#__PURE__*/ _jsx(FormHeader, {
|
|
83
|
+
heading: "Please verify your email",
|
|
84
|
+
description: t('authentication:emailSent'),
|
|
85
|
+
style: {
|
|
86
|
+
textAlign: 'center'
|
|
87
|
+
}
|
|
88
|
+
});
|
|
89
|
+
}
|
|
90
|
+
const getLoginTypeLabel = ()=>{
|
|
91
|
+
const labels = {
|
|
92
|
+
email: t('general:email') || 'Email',
|
|
93
|
+
username: t('authentication:username') || 'Username',
|
|
94
|
+
emailOrUsername: t('authentication:emailOrUsername') || 'Email or Username'
|
|
95
|
+
};
|
|
96
|
+
return labels[loginType];
|
|
97
|
+
};
|
|
98
|
+
return /*#__PURE__*/ _jsxs("div", {
|
|
99
|
+
className: `${baseClass}__wrapper`,
|
|
100
|
+
children: [
|
|
101
|
+
searchParamError === 'signup_disabled' && /*#__PURE__*/ _jsx(FormError, {
|
|
102
|
+
errors: [
|
|
103
|
+
'Sign up is disabled.'
|
|
104
|
+
]
|
|
105
|
+
}),
|
|
106
|
+
/*#__PURE__*/ _jsxs(Form, {
|
|
107
|
+
className: baseClass,
|
|
108
|
+
onSubmit: (e)=>{
|
|
109
|
+
e.preventDefault();
|
|
110
|
+
if (showPasswordField) {
|
|
111
|
+
void form.handleSubmit();
|
|
112
|
+
}
|
|
113
|
+
},
|
|
114
|
+
children: [
|
|
115
|
+
/*#__PURE__*/ _jsxs(FormInputWrap, {
|
|
116
|
+
className: baseClass,
|
|
117
|
+
children: [
|
|
118
|
+
/*#__PURE__*/ _jsx(form.AppField, {
|
|
119
|
+
name: "login",
|
|
120
|
+
children: (field)=>/*#__PURE__*/ _jsx(field.TextField, {
|
|
121
|
+
type: "text",
|
|
122
|
+
className: "email",
|
|
123
|
+
autoComplete: "email",
|
|
124
|
+
label: getLoginTypeLabel(),
|
|
125
|
+
onValueChange: setEmail
|
|
126
|
+
})
|
|
127
|
+
}),
|
|
128
|
+
showPasswordField && /*#__PURE__*/ _jsx(form.AppField, {
|
|
129
|
+
name: "password",
|
|
130
|
+
children: (field)=>/*#__PURE__*/ _jsx(field.TextField, {
|
|
131
|
+
type: "password",
|
|
132
|
+
className: "password",
|
|
133
|
+
autoComplete: "password",
|
|
134
|
+
label: t('general:password')
|
|
135
|
+
})
|
|
136
|
+
})
|
|
137
|
+
]
|
|
138
|
+
}),
|
|
139
|
+
showPasswordField && /*#__PURE__*/ _jsxs(_Fragment, {
|
|
140
|
+
children: [
|
|
141
|
+
/*#__PURE__*/ _jsx(Link, {
|
|
142
|
+
href: forgotPasswordUrl,
|
|
143
|
+
prefetch: false,
|
|
144
|
+
children: t('authentication:forgotPasswordQuestion')
|
|
145
|
+
}),
|
|
146
|
+
/*#__PURE__*/ _jsx("button", {
|
|
147
|
+
type: "submit",
|
|
148
|
+
style: {
|
|
149
|
+
display: 'none'
|
|
150
|
+
},
|
|
151
|
+
tabIndex: -1
|
|
152
|
+
}),
|
|
153
|
+
/*#__PURE__*/ _jsx(form.AppForm, {
|
|
154
|
+
children: /*#__PURE__*/ _jsx(form.Submit, {
|
|
155
|
+
label: t('authentication:login'),
|
|
156
|
+
loadingLabel: t('general:loading')
|
|
157
|
+
})
|
|
158
|
+
})
|
|
159
|
+
]
|
|
160
|
+
})
|
|
161
|
+
]
|
|
162
|
+
})
|
|
163
|
+
]
|
|
164
|
+
});
|
|
165
|
+
};
|
|
166
|
+
|
|
167
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../../src/better-auth/plugin/payload/components/login-form/credentials-form.tsx"],"sourcesContent":["'use client'\n\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 { valueOrDefaultString } from '@/shared/utils/value-or-default'\nimport { useConfig, Link, toast, useTranslation } from '@payloadcms/ui'\nimport { formatAdminURL } from 'payload/shared'\nimport React, { useState } from 'react'\nimport { useLoginForm } from './context'\nimport './index.scss'\n\nconst baseClass = 'login__form'\n\nexport const CredentialsForm: React.FC = () => {\n  const { config } = useConfig()\n  const { t } = useTranslation()\n  const { authClient, loginType, hasMethod, setEmail, redirectUrl, prefill } = useLoginForm()\n  const adminRoute = valueOrDefaultString(config?.routes?.admin, '/admin')\n\n  const hasEmailPassword = hasMethod('emailPassword')\n  const hasMagicLink = hasMethod('magicLink')\n  const showEmailField = hasEmailPassword || hasMagicLink\n  const showPasswordField = hasEmailPassword\n\n  const [requireEmailVerification, setRequireEmailVerification] = useState(false)\n  const [searchParamError] = useState(() => {\n    if (typeof window !== 'undefined') {\n      const params = new URLSearchParams(window.location.search)\n      return params.get('error')\n    }\n    return null\n  })\n\n  const forgotPasswordUrl = formatAdminURL({\n    adminRoute,\n    path: adminRoutes?.forgotPassword as `/${string}`\n  })\n\n  const loginSchema = createLoginSchema({ t, loginType, canLoginWithUsername: loginType !== 'email' })\n\n  const form = useAppForm({\n    defaultValues: {\n      login: prefill.email ?? prefill.username ?? '',\n      password: prefill.password ?? ''\n    },\n    onSubmit: async ({ value }) => {\n      if (!showPasswordField) return\n\n      const { login, password } = value\n      const isEmail = isValidEmail(login)\n      console.log(value)\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 {\n        toast.error(t('error:unknown') || 'An unexpected error occurred')\n      }\n    },\n    validators: showPasswordField ? { onSubmit: loginSchema } : undefined\n  })\n\n  if (!showEmailField) return null\n\n  if (requireEmailVerification) {\n    return <FormHeader heading=\"Please verify your email\" description={t('authentication:emailSent')} style={{ textAlign: 'center' }} />\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 === 'signup_disabled' && <FormError errors={['Sign up is disabled.']} />}\n      <Form\n        className={baseClass}\n        onSubmit={(e) => {\n          e.preventDefault()\n          if (showPasswordField) {\n            void form.handleSubmit()\n          }\n        }}>\n        <FormInputWrap className={baseClass}>\n          <form.AppField\n            name=\"login\"\n            children={(field) => (\n              <field.TextField\n                type=\"text\"\n                className=\"email\"\n                autoComplete=\"email\"\n                label={getLoginTypeLabel()}\n                onValueChange={setEmail}\n              />\n            )}\n          />\n          {showPasswordField && (\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          )}\n        </FormInputWrap>\n        {showPasswordField && (\n          <>\n            <Link href={forgotPasswordUrl} prefetch={false}>\n              {t('authentication:forgotPasswordQuestion')}\n            </Link>\n            <button type=\"submit\" style={{ display: 'none' }} tabIndex={-1} />\n            <form.AppForm children={<form.Submit label={t('authentication:login')} loadingLabel={t('general:loading')} />} />\n          </>\n        )}\n      </Form>\n    </div>\n  )\n}\n\n"],"names":["adminRoutes","useAppForm","Form","FormError","FormInputWrap","FormHeader","createLoginSchema","isValidEmail","valueOrDefaultString","useConfig","Link","toast","useTranslation","formatAdminURL","React","useState","useLoginForm","baseClass","CredentialsForm","config","t","authClient","loginType","hasMethod","setEmail","redirectUrl","prefill","adminRoute","routes","admin","hasEmailPassword","hasMagicLink","showEmailField","showPasswordField","requireEmailVerification","setRequireEmailVerification","searchParamError","window","params","URLSearchParams","location","search","get","forgotPasswordUrl","path","forgotPassword","loginSchema","canLoginWithUsername","form","defaultValues","login","email","username","password","onSubmit","value","isEmail","console","log","data","error","signIn","callbackURL","code","message","charAt","toUpperCase","slice","token","success","href","validators","undefined","heading","description","style","textAlign","getLoginTypeLabel","labels","emailOrUsername","div","className","errors","e","preventDefault","handleSubmit","AppField","name","children","field","TextField","type","autoComplete","label","onValueChange","prefetch","button","display","tabIndex","AppForm","Submit","loadingLabel"],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../../src/better-auth/plugin/payload/components/login-form/index.tsx"],"names":[],"mappings":"AAEA,OAAO,EAAE,iBAAiB,EAAE,YAAY,EAAE,KAAK,sBAAsB,EAAE,MAAM,WAAW,CAAA;AACxF,OAAO,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAA;AACpD,OAAO,EAAE,kBAAkB,EAAE,MAAM,uBAAuB,CAAA"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
export { LoginFormProvider, useLoginForm } from "./context";
|
|
3
|
+
export { CredentialsForm } from "./credentials-form";
|
|
4
|
+
export { AlternativeMethods } from "./alternative-methods";
|
|
5
|
+
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3NyYy9iZXR0ZXItYXV0aC9wbHVnaW4vcGF5bG9hZC9jb21wb25lbnRzL2xvZ2luLWZvcm0vaW5kZXgudHN4Il0sInNvdXJjZXNDb250ZW50IjpbIid1c2UgY2xpZW50J1xuXG5leHBvcnQgeyBMb2dpbkZvcm1Qcm92aWRlciwgdXNlTG9naW5Gb3JtLCB0eXBlIExvZ2luRm9ybVByb3ZpZGVyUHJvcHMgfSBmcm9tICcuL2NvbnRleHQnXG5leHBvcnQgeyBDcmVkZW50aWFsc0Zvcm0gfSBmcm9tICcuL2NyZWRlbnRpYWxzLWZvcm0nXG5leHBvcnQgeyBBbHRlcm5hdGl2ZU1ldGhvZHMgfSBmcm9tICcuL2FsdGVybmF0aXZlLW1ldGhvZHMnXG5cbiJdLCJuYW1lcyI6WyJMb2dpbkZvcm1Qcm92aWRlciIsInVzZUxvZ2luRm9ybSIsIkNyZWRlbnRpYWxzRm9ybSIsIkFsdGVybmF0aXZlTWV0aG9kcyJdLCJtYXBwaW5ncyI6IkFBQUE7QUFFQSxTQUFTQSxpQkFBaUIsRUFBRUMsWUFBWSxRQUFxQyxZQUFXO0FBQ3hGLFNBQVNDLGVBQWUsUUFBUSxxQkFBb0I7QUFDcEQsU0FBU0Msa0JBQWtCLFFBQVEsd0JBQXVCIn0=
|