new login design (#4442)

* new login design

* remove effects file (wrong direction)

* add Known Hosts dropdown component

Co-authored-by: Jeremy Letto <jeremy.letto@datasite.com>
This commit is contained in:
Jeremy Letto 2021-10-25 13:28:43 -05:00 committed by GitHub
parent 6f360374cc
commit d684a9c5fc
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
25 changed files with 675 additions and 212 deletions

View file

@ -0,0 +1,20 @@
.loginForm {
width: 100%;
}
.loginForm-item {
margin-bottom: 20px;
}
.loginForm-actions {
display: flex;
justify-content: space-between;
align-items: center;
margin-top: -20px;
margin-bottom: 20px;
font-weight: bold;
}
.loginForm-submit {
width: 100%;
}

View file

@ -0,0 +1,73 @@
// eslint-disable-next-line
import React from "react";
import { connect } from "react-redux";
import { Form, Field, reduxForm, change } from "redux-form"
import Button from "@material-ui/core/Button";
import { InputField, KnownHosts } from "components";
// import { ServerDispatch } from "store";
import { FormKey } from 'types';
import "./LoginForm.css";
const LoginForm = (props) => {
const { dispatch, handleSubmit } = props;
const forgotPassword = () => {
console.log('LoginForm.forgotPassword->openForgotPasswordDialog');
};
const onHostChange = ({ host, port }) => {
dispatch(change(FormKey.LOGIN, 'host', host));
dispatch(change(FormKey.LOGIN, 'port', port));
}
return (
<Form className="loginForm" onSubmit={handleSubmit}>
<div className="loginForm-items">
<div className="loginForm-item">
<Field label="User" name="user" component={InputField} autoComplete="username" />
</div>
<div className="loginForm-item">
<Field label="Pass" name="pass" type="password" component={InputField} autoComplete="current-password" />
</div>
<div className="loginForm-actions">
<span>Auto Connect</span>
<Button color="primary" onClick={forgotPassword}>Forgot Password</Button>
</div>
<div className="loginForm-item">
<KnownHosts onChange={onHostChange} />
</div>
</div>
<Button className="loginForm-submit rounded tall" color="primary" variant="contained" type="submit">
Login
</Button>
</Form>
);
}
const propsMap = {
form: FormKey.LOGIN,
validate: values => {
const errors: any = {};
if (!values.user) errors.user = 'Required';
if (!values.pass) errors.pass = 'Required';
if (!values.host) errors.host = 'Required';
if (!values.port) errors.port = 'Required';
return errors;
}
};
const mapStateToProps = () => ({
initialValues: {
// host: "mtg.tetrarch.co/servatrice",
// port: "443"
// host: "server.cockatrice.us",
// port: "4748"
}
});
export default connect(mapStateToProps)(reduxForm(propsMap)(LoginForm));

View file

@ -1,4 +1,5 @@
export { default as CardImportForm } from './CardImportForm/CardImportForm';
export { default as ConnectForm } from './ConnectForm/ConnectForm';
export { default as LoginForm } from './LoginForm/LoginForm';
export { default as RegisterForm } from './RegisterForm/RegisterForm';
export { default as SearchForm } from './SearchForm/SearchForm';