* port webclient POC into react shell * Abstract websocket messaging behind redux store * refactor architecture * add rooms store * introduce application service layer and login form * display room messages * implement roomSay * improve Room view styling * display room games * improve gameList update logic * hide protected games * improve game update logic * move mapping to earlier lifecycle hook * add autoscroll to bottom * tabs to spaces, refresh guard * implement server joins/leaves * show users in room * add material-ui to build * refactor, add room joins/leaves to store and render * begin using Material UI components * fix spectatorsCount * remove unused package * improve Server and Room styling * fix scroll context * route on room join * refactor room path * add auth guard * refactor authGuard export * add missing files * clear store on disconnect, add logout button to Account view * fix disconnect handling * Safari fixes * organize current todos * improve login page and server status tracking * improve login page * introduce sorting arch, refine reducers, begin viewLogHistory * audit fix for handlebars * implement moderator log view * comply with code style rules * remove original POC from codebase * add missing semi * minor improvements, begin registration functionality * retry as ws when wss fails additionally, dont mutate the default options when connecting * retain user/pass in WebClient.options for login * take protocol off of options, make it a connect param that defaults to wss * cleanup server page styling * match wss logic with desktop client * add virtual scroll component, add context menu to UserDisplay * revert VirtualTable on messages * improve styling for Room view * add routing to Player view * increase tooltip delay * begin implementing Account view * disable app level contextMenu * implement buddy/ignore list management * fix gitignore Co-authored-by: Jay Letto <jeremy.letto@merrillcorp.com> Co-authored-by: skwerlman <skwerlman@users.noreply.github.com> Co-authored-by: Jeremy Letto <jeremy.letto@datasite.com>
58 lines
2 KiB
TypeScript
58 lines
2 KiB
TypeScript
// eslint-disable-next-line
|
|
import React, { Component } from 'react';
|
|
import { connect } from 'react-redux';
|
|
import { Form, Field, InjectedFormProps, reduxForm } from 'redux-form'
|
|
|
|
import Button from '@material-ui/core/Button';
|
|
|
|
import InputField from 'AppShell/common/components/InputField/InputField';
|
|
|
|
import './RegisterForm.css';
|
|
|
|
class RegisterForm extends Component<InjectedFormProps> {
|
|
render() {
|
|
return (
|
|
<Form className="registerForm" onSubmit={this.props.handleSubmit} autoComplete="off">
|
|
<div className="registerForm-item">
|
|
<Field label="Host" name="host" component={InputField} />
|
|
</div>
|
|
<div className="registerForm-item">
|
|
<Field label="Port" name="port" component={InputField} />
|
|
</div>
|
|
<div className="registerForm-item">
|
|
<Field label="Player Name" name="userName" component={InputField} />
|
|
</div>
|
|
<div className="registerForm-item">
|
|
<Field label="Password" name="password" type="password" component={InputField} />
|
|
</div>
|
|
<div className="registerForm-item">
|
|
<Field label="Password (again)" name="passwordConfirm" type="password" component={InputField} />
|
|
</div>
|
|
<div className="registerForm-item">
|
|
<Field label="Email" name="email" type="email" component={InputField} />
|
|
</div>
|
|
<div className="registerForm-item">
|
|
<Field label="Email (again)" name="emailConfirm" type="email" component={InputField} />
|
|
</div>
|
|
<div className="registerForm-item">
|
|
<Field label="Real Name" name="realName" component={InputField} />
|
|
</div>
|
|
<Button className="registerForm-submit" color="primary" variant="contained" type="submit">
|
|
Register
|
|
</Button>
|
|
</Form>
|
|
);
|
|
}
|
|
}
|
|
|
|
const propsMap = {
|
|
form: 'register'
|
|
};
|
|
|
|
const mapStateToProps = () => ({
|
|
initialValues: {
|
|
|
|
}
|
|
});
|
|
|
|
export default connect(mapStateToProps)(reduxForm(propsMap)(RegisterForm));
|