156 lines
8.1 KiB
TypeScript
Raw Normal View History

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";
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 }}
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>
}
/>
);
});