mirror of
https://github.com/grafana/grafana.git
synced 2025-02-25 18:55:37 -06:00
* Footer: Single footer implementation for both react & angular pages * Export type * Updates * Use footer links in help menu * Updates & Fixes * Updated snapshot * updated snapshot
66 lines
2.1 KiB
TypeScript
66 lines
2.1 KiB
TypeScript
import React, { FC } from 'react';
|
|
import { UserSignup } from './UserSignup';
|
|
import { LoginServiceButtons } from './LoginServiceButtons';
|
|
import LoginCtrl from './LoginCtrl';
|
|
import { LoginForm } from './LoginForm';
|
|
import { ChangePassword } from './ChangePassword';
|
|
import { CSSTransition } from 'react-transition-group';
|
|
import { Branding } from 'app/core/components/Branding/Branding';
|
|
|
|
export const LoginPage: FC = () => {
|
|
return (
|
|
<div className="login container">
|
|
<div className="login-content">
|
|
<div className="login-branding">
|
|
<Branding.LogoIcon className="logo-icon" />
|
|
<Branding.Wordmark className="logo-wordmark" />
|
|
</div>
|
|
<LoginCtrl>
|
|
{({
|
|
loginHint,
|
|
passwordHint,
|
|
isOauthEnabled,
|
|
ldapEnabled,
|
|
authProxyEnabled,
|
|
disableLoginForm,
|
|
disableUserSignUp,
|
|
login,
|
|
isLoggingIn,
|
|
changePassword,
|
|
skipPasswordChange,
|
|
isChangingPassword,
|
|
}) => (
|
|
<div className="login-outer-box">
|
|
<div className={`login-inner-box ${isChangingPassword ? 'hidden' : ''}`} id="login-view">
|
|
{!disableLoginForm ? (
|
|
<LoginForm
|
|
displayForgotPassword={!(ldapEnabled || authProxyEnabled)}
|
|
onSubmit={login}
|
|
loginHint={loginHint}
|
|
passwordHint={passwordHint}
|
|
isLoggingIn={isLoggingIn}
|
|
/>
|
|
) : null}
|
|
|
|
<LoginServiceButtons />
|
|
{!disableUserSignUp ? <UserSignup /> : null}
|
|
</div>
|
|
<CSSTransition
|
|
appear={true}
|
|
mountOnEnter={true}
|
|
in={isChangingPassword}
|
|
timeout={250}
|
|
classNames="login-inner-box"
|
|
>
|
|
<ChangePassword onSubmit={changePassword} onSkip={skipPasswordChange} focus={isChangingPassword} />
|
|
</CSSTransition>
|
|
</div>
|
|
)}
|
|
</LoginCtrl>
|
|
|
|
<div className="clearfix" />
|
|
</div>
|
|
</div>
|
|
);
|
|
};
|