aboutsummaryrefslogblamecommitdiff
path: root/src/NewThread.js
blob: 4452f3582c0b777343374c6b037e26ba91ed66a3 (plain) (tree)
1
2
3
4
5
6
7
8
9

                                         



           

          
                           
                                  










                                   





                           

                                                     

                                                     



                                     







































































































                                                                              


            
                                                 






                   

                
                   

            





















                                                                               
                         



                               


                                            






                                                   
                                              
                  




































                                                                               
              










                                                           




                         
import React, { Component } from "react";
import {
  Button,
  Form,
  Icon,
  Checkbox,
  Message,
  Modal
} from "semantic-ui-react";
import { quotes } from "./Quotes";

class NewThread extends Component {
  constructor(props) {
    super(props);
    this.state = {
      subject: "",
      name: "",
      email: "",
      message: "",
      attachment: "",
      selectedFile: null,
      isSpoiler: false,
      submittedName: "",
      submittedEmail: "",
      submittedMessage: "",
      submittedSubject: "",
      replyRes: null
    };
    this.handleChange = this.handleChange.bind(this);
    this.handleSubmit = this.handleSubmit.bind(this);
    this.handleClick = this.handleClick.bind(this);
  }

  handleChange(e) {
    const { name, value } = e.target;
    if (name === "hiddenInput") {
      let hiddenInput = document.getElementById("hiddenInput");
      if (hiddenInput.files.length === 0) {
        this.setState({ selectedFile: null });
      } else {
        let file = hiddenInput.files[0].name;
        this.setState({ selectedFile: file });
      }
    } else {
      this.setState({ [name]: value });
    }
  }

  handleClick(e) {
    e.preventDefault();
    document.getElementById("hiddenInput").click();
  }
  handleSubmit() {
    const { name, email, message, subject } = this.state;
    this.setState(
      {
        submittedName: name,
        submittedEmail: email,
        submittedMessage: message,
        submittedSubject: subject,
        replyRes: null
      },
      () => {
        var {
          submittedName,
          submittedEmail,
          submittedMessage,
          submittedSubject,
          selectedFile,
          isSpoiler
        } = this.state;
        const { currentBoard } = this.props;
        let password = JSON.parse(localStorage.getItem("settings"))
          .postPassword;
        let data = {
          board: currentBoard.dir,
          name: "",
          email: "",
          fielda: submittedName,
          fieldb: submittedEmail,
          message: submittedMessage,
          subject: submittedSubject,
          password: password
        };

        if (selectedFile !== null) {
          let file = document.getElementById("hiddenInput").files[0];
          data["file"] = file;
        }

        if (currentBoard.allow_spoilers) {
          data["spoil"] = isSpoiler;
        }

        let userData = { name: name, email: email };
        localStorage.setItem("userData", JSON.stringify(userData));

        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 => {
            if (resource.state === "success") {
              this.randomQuote =
                quotes[Math.floor(Math.random() * quotes.length)];
              this.setState({
                replyRes: resource,
                message: "",
                selectedFile: null
              });
              let ownPosts = JSON.parse(localStorage.getItem("ownPosts"));
              if (ownPosts === null) {
                ownPosts = {};
              }
              // eslint-disable-next-line no-prototype-builtins
              if (!ownPosts.hasOwnProperty(currentBoard.dir)) {
                ownPosts[currentBoard.dir] = [];
              }
              ownPosts[currentBoard.dir] = ownPosts[currentBoard.dir].concat({
                thread_id: resource.post_id,
                reply_id: resource.post_id
              });
              localStorage.setItem("ownPosts", JSON.stringify(ownPosts));
            } else {
              this.setState({ replyRes: resource });
            }
          });
      }
    );
  }

  render() {
    const { currentBoard, trigger } = this.props;
    const {
      subject,
      name,
      email,
      message,
      attachment,
      selectedFile,
      isSpoiler,
      replyRes
    } = this.state;

    return (
      <Modal trigger={trigger}>
        <Modal.Header>Crear un nuevo hilo en {currentBoard.name}</Modal.Header>
        <Modal.Content>
          {replyRes !== null &&
            (replyRes.state === "success" ? (
              <Message positive>
                <Message.Header>Gracias por tu post</Message.Header>
                {this.randomQuote}
                <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>
            ))}

          <Form onSubmit={this.handleSubmit}>
            {currentBoard.disable_subject === 0 && (
              <Form.Input
                id="subject"
                name="subject"
                label="Asunto"
                value={subject}
                onChange={this.handleChange}
              />
            )}
            <Form.Group widths="equal">
              {currentBoard.disable_name === 0 && (
                <Form.Input
                  id="name"
                  name="name"
                  label="Nombre"
                  value={name}
                  onChange={this.handleChange}
                />
              )}
              <Form.Input
                id="email"
                name="email"
                label="E-mail"
                value={email}
                onChange={this.handleChange}
              />
              {currentBoard.allow_image_replies === 1 && (
                <React.Fragment>
                  <input
                    id="hiddenInput"
                    name="hiddenInput"
                    type="file"
                    hidden
                    onChange={this.handleChange}
                    multiple={false}
                  />
                  <Form.Button
                    label="Adjunto"
                    fluid
                    value={attachment}
                    onClick={this.handleClick}
                  >
                    <Icon name="attach" />
                    {selectedFile === null ? "Adjuntar archivo" : selectedFile}
                  </Form.Button>
                </React.Fragment>
              )}
            </Form.Group>
            <Form.TextArea
              name="message"
              value={message}
              label="Mensaje"
              placeholder="( ・ω・) Cuentáme algo interesante ..."
              onChange={this.handleChange}
              rows={7}
            />
            {currentBoard.allow_spoilers === 1 && (
              <Checkbox
                label="El archivo adjunto es un spoiler"
                checked={isSpoiler}
                className="spoilerCheckbox"
              />
            )}
            <Button type="submit">Crear nuevo hilo</Button>
          </Form>
        </Modal.Content>
      </Modal>
    );
  }
}

export default NewThread;