+});
+
+class ActivePrompt extends React.PureComponent {
+
+ constructor(props) {
+ super(props);
+ const items = props.prompt.items;
+
+ this.state = {
+ submitted: false
+ };
+
+ this.answers = [...Array(items)].map(() => React.createRef());
+ this.handle_submit = this.handle_submit.bind(this);
+ }
+
+ async handle_submit(event) {
+ const form = event.currentTarget;
+
+ /* Prevent the default page-changing form-submission behavior. */
+ event.preventDefault();
+
+ const response = await fetch_post_json(`answer/${this.props.prompt.id}`, {
+ answers: this.answers.map(r => r.current.value)
+ });
+ if (response.status == 200) {
+ const result = await response.json();
+ if (! result.valid) {
+ add_message("danger", result.message);
+ return;
+ }
+ } else {
+ add_message("danger", "An error occurred submitting your answers");
+ return;
+ }
+
+ /* Everything worked. Server is happy with our answers. */
+ form.reset();
+ this.setState({
+ submitted: true
+ });
+ }
+
+ render() {
+ if (this.state.submitted)
+ return (
+ <div className="please-wait">
+ <h2>{this.props.players_answered}/
+ {this.props.players_total} players have responded</h2>
+ <p>
+ Please wait for the rest of the players to submit their answers.
+ </p>
+ </div>
+ );
+
+ return (
+ <div className="active-prompt">
+ <h2>The Game of Empathy</h2>
+ <p>
+ Remember, you're trying to match your answers with
+ what the other players submit.
+ Give {this.props.prompt.items} answers for the following prompt:
+ </p>
+ <h2>{this.props.prompt.prompt}</h2>
+ <form onSubmit={this.handle_submit}>
+ {Array(this.props.prompt.items).fill(null).map((whocares,i) => {
+ return (
+ <div
+ key={i}
+ className="form-field large">
+ <input
+ type="text"
+ name={`answer_${i}`}
+ required
+ autoComplete="off"
+ ref={this.answers[i]}
+ />
+ </div>
+ );
+ })}
+
+ <div
+ key="submit-button"
+ className="form-field large">
+ <button type="submit">
+ Send
+ </button>
+ </div>
+
+ </form>
+ </div>
+ );
+ }