mirror of
https://github.com/Cockatrice/Cockatrice.git
synced 2026-04-27 07:48:01 -07:00
Webatrice P.O.C. (#3854)
* 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>
This commit is contained in:
parent
d5b36e8b8a
commit
0457e65751
152 changed files with 19573 additions and 1071 deletions
68
webclient/src/AppShell/Logs/SearchForm/SearchForm.tsx
Normal file
68
webclient/src/AppShell/Logs/SearchForm/SearchForm.tsx
Normal file
|
|
@ -0,0 +1,68 @@
|
|||
// 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 Divider from "@material-ui/core/Divider";
|
||||
import Paper from "@material-ui/core/Paper";
|
||||
|
||||
import InputField from "AppShell/common/components/InputField/InputField";
|
||||
import CheckboxField from "AppShell/common/components/CheckboxField/CheckboxField";
|
||||
|
||||
import "./SearchForm.css";
|
||||
|
||||
class SearchForm extends Component<InjectedFormProps> {
|
||||
render() {
|
||||
return (
|
||||
<Paper className="log-search">
|
||||
<Form className="log-search__form" onSubmit={this.props.handleSubmit}>
|
||||
<div className="log-search__form-item">
|
||||
<Field label="Username" name="userName" component={InputField} />
|
||||
</div>
|
||||
<div className="log-search__form-item">
|
||||
<Field label="IP Address" name="ipAddress" component={InputField} />
|
||||
</div>
|
||||
<div className="log-search__form-item">
|
||||
<Field label="Game Name" name="gameName" component={InputField} />
|
||||
</div>
|
||||
<div className="log-search__form-item">
|
||||
<Field label="GameID" name="gameId" component={InputField} />
|
||||
</div>
|
||||
<div className="log-search__form-item">
|
||||
<Field label="Message" name="message" component={InputField} />
|
||||
</div>
|
||||
<Divider />
|
||||
<div className="log-search__form-item log-location">
|
||||
<Field label="Rooms" name="logLocation.room" component={CheckboxField} />
|
||||
<Field label="Games" name="logLocation.game" component={CheckboxField} />
|
||||
<Field label="Chats" name="logLocation.chat" component={CheckboxField} />
|
||||
</div>
|
||||
<Divider />
|
||||
<div className="log-search__form-item">
|
||||
<span>Date Range: Coming Soon</span>
|
||||
</div>
|
||||
<Divider />
|
||||
<div className="log-search__form-item">
|
||||
<span>Maximum Results: 1000</span>
|
||||
</div>
|
||||
<Divider />
|
||||
<Button className="log-search__form-submit" color="primary" variant="contained" type="submit">
|
||||
Search Logs
|
||||
</Button>
|
||||
</Form>
|
||||
</Paper>
|
||||
)
|
||||
}
|
||||
}
|
||||
|
||||
const propsMap = {
|
||||
form: "logs"
|
||||
};
|
||||
|
||||
const mapStateToProps = () => ({
|
||||
|
||||
});
|
||||
|
||||
export default connect(mapStateToProps)(reduxForm(propsMap)(SearchForm));
|
||||
|
||||
Loading…
Add table
Add a link
Reference in a new issue