aboutsummaryrefslogtreecommitdiff
path: root/diplomacy/web/src/gui/core/delete_button.jsx
diff options
context:
space:
mode:
authornotoraptor <notoraptor@users.noreply.github.com>2019-07-16 10:39:16 -0400
committerPhilip Paquette <pcpaquette@gmail.com>2019-07-16 10:39:16 -0400
commit09be214dfa0741df2399c3e0c928929138de226b (patch)
tree3d76cb1d9e6f3cd5452563b476fb251103fd3ec7 /diplomacy/web/src/gui/core/delete_button.jsx
parent5c71a0f73717bffefb5e23a9e100adb62fc54a61 (diff)
[web] Add a button to delete game. (#39)
- [server] Also delete game from RAM.
Diffstat (limited to 'diplomacy/web/src/gui/core/delete_button.jsx')
-rw-r--r--diplomacy/web/src/gui/core/delete_button.jsx43
1 files changed, 43 insertions, 0 deletions
diff --git a/diplomacy/web/src/gui/core/delete_button.jsx b/diplomacy/web/src/gui/core/delete_button.jsx
new file mode 100644
index 0000000..59141fd
--- /dev/null
+++ b/diplomacy/web/src/gui/core/delete_button.jsx
@@ -0,0 +1,43 @@
+import React from "react";
+import {Button} from "./button";
+import PropTypes from "prop-types";
+
+export class DeleteButton extends React.Component {
+ constructor(props) {
+ super(props);
+ this.state = {step: 0};
+ this.onClick = this.onClick.bind(this);
+ }
+
+ onClick() {
+ this.setState({step: this.state.step + 1}, () => {
+ if (this.state.step === 2)
+ this.props.onClick();
+ });
+ }
+
+ render() {
+ let title = '';
+ let color = '';
+ if (this.state.step === 0) {
+ title = this.props.title;
+ color = 'secondary';
+ } else if (this.state.step === 1) {
+ title = this.props.confirmTitle;
+ color = 'danger';
+ } else if (this.state.step === 2) {
+ title = this.props.waitingTitle;
+ color = 'danger';
+ }
+ return (
+ <Button title={title} color={color} onClick={this.onClick} small={true} large={true}/>
+ );
+ }
+}
+
+DeleteButton.propTypes = {
+ title: PropTypes.string.isRequired,
+ confirmTitle: PropTypes.string.isRequired,
+ waitingTitle: PropTypes.string.isRequired,
+ onClick: PropTypes.func.isRequired
+};