2021-03-02 23:48:31 +01:00
|
|
|
|
|
|
|
import { useState, memo } from "react";
|
|
|
|
import { Template } from "./Template";
|
2021-03-06 14:42:56 +01:00
|
|
|
import type { KcProps } from "./KcProps";
|
2021-06-23 08:16:51 +02:00
|
|
|
import type { KcContextBase } from "../getKcContext/KcContextBase";
|
2021-03-07 15:37:37 +01:00
|
|
|
import { useKcMessage } from "../i18n/useKcMessage";
|
2021-03-02 23:48:31 +01:00
|
|
|
import { cx } from "tss-react";
|
2021-07-21 22:10:28 +02:00
|
|
|
import { useConstCallback } from "powerhooks/useConstCallback";
|
2021-03-02 23:48:31 +01:00
|
|
|
|
2021-06-23 08:16:51 +02:00
|
|
|
export const Login = memo(({ kcContext, ...props }: { kcContext: KcContextBase.Login; } & KcProps) => {
|
2021-03-02 23:48:31 +01:00
|
|
|
|
2021-03-07 15:37:37 +01:00
|
|
|
const { msg, msgStr } = useKcMessage();
|
2021-03-02 23:48:31 +01:00
|
|
|
|
2021-03-06 14:42:56 +01:00
|
|
|
const {
|
2021-03-02 23:48:31 +01:00
|
|
|
social, realm, url,
|
|
|
|
usernameEditDisabled, login,
|
|
|
|
auth, registrationDisabled
|
2021-03-06 14:42:56 +01:00
|
|
|
} = kcContext;
|
2021-03-02 23:48:31 +01:00
|
|
|
|
|
|
|
const [isLoginButtonDisabled, setIsLoginButtonDisabled] = useState(false);
|
|
|
|
|
|
|
|
const onSubmit = useConstCallback(() =>
|
|
|
|
(setIsLoginButtonDisabled(true), true)
|
|
|
|
);
|
|
|
|
|
|
|
|
return (
|
|
|
|
<Template
|
2021-03-08 00:09:52 +01:00
|
|
|
{...{ kcContext, ...props }}
|
2021-06-23 18:27:41 +02:00
|
|
|
doFetchDefaultThemeResources={true}
|
2021-03-02 23:48:31 +01:00
|
|
|
displayInfo={social.displayInfo}
|
|
|
|
displayWide={realm.password && social.providers !== undefined}
|
2021-03-07 15:37:37 +01:00
|
|
|
headerNode={msg("doLogIn")}
|
2021-03-02 23:48:31 +01:00
|
|
|
formNode={
|
|
|
|
<div
|
|
|
|
id="kc-form"
|
2021-03-06 14:42:56 +01:00
|
|
|
className={cx(realm.password && social.providers !== undefined && props.kcContentWrapperClass)}
|
2021-03-02 23:48:31 +01:00
|
|
|
>
|
|
|
|
<div
|
|
|
|
id="kc-form-wrapper"
|
2021-03-06 14:42:56 +01:00
|
|
|
className={cx(realm.password && social.providers && [props.kcFormSocialAccountContentClass, props.kcFormSocialAccountClass])}
|
2021-03-02 23:48:31 +01:00
|
|
|
>
|
|
|
|
{
|
|
|
|
realm.password &&
|
|
|
|
(
|
|
|
|
<form id="kc-form-login" onSubmit={onSubmit} action={url.loginAction} method="post">
|
2021-03-06 14:42:56 +01:00
|
|
|
<div className={cx(props.kcFormGroupClass)}>
|
|
|
|
<label htmlFor="username" className={cx(props.kcLabelClass)}>
|
2021-03-02 23:48:31 +01:00
|
|
|
{
|
|
|
|
!realm.loginWithEmailAllowed ?
|
2021-03-07 15:37:37 +01:00
|
|
|
msg("username")
|
2021-03-02 23:48:31 +01:00
|
|
|
:
|
|
|
|
(
|
|
|
|
!realm.registrationEmailAsUsername ?
|
2021-03-07 15:37:37 +01:00
|
|
|
msg("usernameOrEmail") :
|
|
|
|
msg("email")
|
2021-03-02 23:48:31 +01:00
|
|
|
)
|
|
|
|
}
|
|
|
|
</label>
|
|
|
|
<input
|
|
|
|
tabIndex={1}
|
|
|
|
id="username"
|
2021-03-06 14:42:56 +01:00
|
|
|
className={cx(props.kcInputClass)}
|
2021-03-02 23:48:31 +01:00
|
|
|
name="username"
|
2021-03-05 00:44:27 +01:00
|
|
|
defaultValue={login.username ?? ''}
|
2021-03-02 23:48:31 +01:00
|
|
|
type="text"
|
2021-03-08 00:09:52 +01:00
|
|
|
{...(usernameEditDisabled ? { "disabled": true } : { "autoFocus": true, "autoComplete": "off" })}
|
2021-03-02 23:48:31 +01:00
|
|
|
/>
|
|
|
|
</div>
|
2021-03-06 14:42:56 +01:00
|
|
|
<div className={cx(props.kcFormGroupClass)}>
|
|
|
|
<label htmlFor="password" className={cx(props.kcLabelClass)}>
|
2021-03-07 15:37:37 +01:00
|
|
|
{msg("password")}
|
2021-03-02 23:48:31 +01:00
|
|
|
</label>
|
2021-03-06 14:42:56 +01:00
|
|
|
<input tabIndex={2} id="password" className={cx(props.kcInputClass)} name="password" type="password" autoComplete="off" />
|
2021-03-02 23:48:31 +01:00
|
|
|
</div>
|
2021-03-06 14:42:56 +01:00
|
|
|
<div className={cx(props.kcFormGroupClass, props.kcFormSettingClass)}>
|
2021-03-02 23:48:31 +01:00
|
|
|
<div id="kc-form-options">
|
|
|
|
{
|
2021-03-06 14:42:56 +01:00
|
|
|
(
|
|
|
|
realm.rememberMe &&
|
2021-03-02 23:48:31 +01:00
|
|
|
!usernameEditDisabled
|
|
|
|
) &&
|
|
|
|
<div className="checkbox">
|
|
|
|
<label>
|
2021-03-06 14:42:56 +01:00
|
|
|
<input tabIndex={3} id="rememberMe" name="rememberMe" type="checkbox" {...(login.rememberMe ? { "checked": true } : {})} />
|
2021-03-07 15:37:37 +01:00
|
|
|
{msg("rememberMe")}
|
2021-03-02 23:48:31 +01:00
|
|
|
</label>
|
|
|
|
</div>
|
|
|
|
}
|
|
|
|
</div>
|
2021-03-06 14:42:56 +01:00
|
|
|
<div className={cx(props.kcFormOptionsWrapperClass)}>
|
2021-03-02 23:48:31 +01:00
|
|
|
{
|
|
|
|
realm.resetPasswordAllowed &&
|
|
|
|
<span>
|
2021-03-07 15:37:37 +01:00
|
|
|
<a tabIndex={5} href={url.loginResetCredentialsUrl}>{msg("doForgotPassword")}</a>
|
2021-03-02 23:48:31 +01:00
|
|
|
</span>
|
|
|
|
}
|
|
|
|
</div>
|
|
|
|
|
|
|
|
</div>
|
2021-03-06 14:42:56 +01:00
|
|
|
<div id="kc-form-buttons" className={cx(props.kcFormGroupClass)}>
|
2021-03-02 23:48:31 +01:00
|
|
|
<input
|
|
|
|
type="hidden"
|
|
|
|
id="id-hidden-input"
|
|
|
|
name="credentialId"
|
|
|
|
{...(auth?.selectedCredential !== undefined ? { "value": auth.selectedCredential } : {})}
|
|
|
|
/>
|
|
|
|
<input
|
|
|
|
tabIndex={4}
|
2021-03-06 14:42:56 +01:00
|
|
|
className={cx(props.kcButtonClass, props.kcButtonPrimaryClass, props.kcButtonBlockClass, props.kcButtonLargeClass)} name="login" id="kc-login" type="submit"
|
2021-03-07 15:37:37 +01:00
|
|
|
value={msgStr("doLogIn")}
|
2021-03-02 23:48:31 +01:00
|
|
|
disabled={isLoginButtonDisabled}
|
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
</form>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
</div>
|
|
|
|
{
|
|
|
|
(realm.password && social.providers !== undefined) &&
|
2021-03-06 14:42:56 +01:00
|
|
|
<div id="kc-social-providers" className={cx(props.kcFormSocialAccountContentClass, props.kcFormSocialAccountClass)}>
|
|
|
|
<ul className={cx(props.kcFormSocialAccountListClass, social.providers.length > 4 && props.kcFormSocialAccountDoubleListClass)}>
|
2021-03-02 23:48:31 +01:00
|
|
|
{
|
|
|
|
social.providers.map(p =>
|
2021-06-15 00:31:20 +02:00
|
|
|
<li key={p.providerId} className={cx(props.kcFormSocialAccountListLinkClass)}>
|
2021-03-02 23:48:31 +01:00
|
|
|
<a href={p.loginUrl} id={`zocial-${p.alias}`} className={cx("zocial", p.providerId)}>
|
|
|
|
<span>{p.displayName}</span>
|
|
|
|
</a>
|
|
|
|
</li>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
</ul>
|
|
|
|
</div>
|
|
|
|
}
|
|
|
|
</div>
|
|
|
|
}
|
2021-03-07 15:37:37 +01:00
|
|
|
infoNode={
|
2021-03-02 23:48:31 +01:00
|
|
|
(
|
|
|
|
realm.password &&
|
2021-03-04 23:24:43 +01:00
|
|
|
realm.registrationAllowed &&
|
2021-03-02 23:48:31 +01:00
|
|
|
!registrationDisabled
|
|
|
|
) &&
|
|
|
|
<div id="kc-registration">
|
|
|
|
<span>
|
2021-03-07 15:37:37 +01:00
|
|
|
{msg("noAccount")}
|
2021-03-02 23:48:31 +01:00
|
|
|
<a tabIndex={6} href={url.registrationUrl}>
|
2021-03-07 15:37:37 +01:00
|
|
|
{msg("doRegister")}
|
2021-03-02 23:48:31 +01:00
|
|
|
</a>
|
|
|
|
</span>
|
|
|
|
</div>
|
|
|
|
}
|
|
|
|
/>
|
|
|
|
);
|
|
|
|
});
|
|
|
|
|
|
|
|
|