aboutsummaryrefslogtreecommitdiff
path: root/src/ReplyForm.js
blob: 33a6af44ea2d308ab45271e84f6bab54a6ca1654 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
import React, { Component } from "react";
import { Form, Segment, Button, Message } from "semantic-ui-react";
import { quotes } from "./Quotes";

class ReplyForm extends Component {
  constructor(props) {
    super(props);
    this.state = {
      name: "",
      email: "",
      message: "",
      submittedName: "",
      submittedEmail: "",
      submittedMessage: "",
      replyRes: null
    };
    this.handleChange = this.handleChange.bind(this);
    this.handleSubmit = this.handleSubmit.bind(this);
  }

  handleChange(e) {
    const { name, value } = e.target;
    this.setState({ [name]: value });
  }

  handleSubmit() {
    const { submittedName, submittedEmail, name, email, message } = this.state;
    this.setState({
      submittedName: name,
      submittedEmail: email,
      submittedMessage: message
    });
    const data = {
      board: this.props.dir,
      parent: this.props.parent,
      name: "",
      email: "",
      fielda: submittedName,
      fieldb: submittedEmail,
      message: message,
      password: "bai-client"
    };

    const formData = new FormData();
    for (var key in data) {
      formData.append(key, data[key]);
    }

    fetch("https://bienvenidoainternet.org/cgi/api/post", {
      method: "POST",
      mode: "cors",
      redirect: "follow",
      body: formData
    })
      .then(response => {
        return response.json();
      })
      .then(resource => {
        console.log(resource);
        this.setState({ replyRes: resource });
      });
  }

  render() {
    const { name, email, message, replyRes } = this.state;
    return (
      <Segment>
        {replyRes !== null ? (
          replyRes.state === "success" ? (
            <Message positive>
              <Message.Header>Gracias por tu post</Message.Header>
              {quotes[Math.floor(Math.random() * quotes.length)]}
              <br />
              <span className="ui small text">
                Nos tomó {replyRes.time_taken} segundos procesar tu mensaje.
              </span>
            </Message>
          ) : (
            <Message negative>
              <Message.Header>{replyRes.state}</Message.Header>
              {replyRes.message}
            </Message>
          )
        ) : null}
        <Form onSubmit={this.handleSubmit}>
          <Form.Group widths="equal">
            <Form.Input
              label="Nombre"
              name="name"
              fluid
              placeholder="Nombre (Opcional)"
              value={name}
              onChange={this.handleChange}
            />
            <Form.Input
              label="E-mail"
              name="email"
              fluid
              placeholder="E-mail (Opcional)"
              value={email}
              onChange={this.handleChange}
            />
          </Form.Group>
          <Form.TextArea
            name="message"
            value={message}
            label="Mensaje"
            placeholder="( ・ω・) Cuentáme algo interesante ..."
            onChange={this.handleChange}
          />
          <Button type="submit" secondary>
            Enviar
          </Button>
        </Form>
      </Segment>
    );
  }
}

export default ReplyForm;