Я хочу добиться чего-то вроде того, когда я нажимаю кнопку «Отправить», рядом с кнопкой должен появиться счетчик, а затем кнопка «Отправить» преобразуется в кнопку «Сообщение отправлено». Я мог добиться, чтобы кнопка менялась, но времени загрузки нет. Почему это происходит сразу?
React Frontend:
import React from 'react';
import './contact.css';
import tick4 from './tick4.svg';
import copy from './copy.svg';
import axios from 'axios';
class Contact extends React.Component {
constructor(props) {
super(props);
this.state = {
name: '',
email: '',
phone: '',
loading: false,
};
this.handleChange = this.handleChange.bind(this);
this.handleSubmit = this.handleSubmit.bind(this);
}
handleChange = (e) => {
this.setState({ [e.target.name]: e.target.value });
};
handleSubmit(e) {
e.preventDefault();
const { name, email, phone } = this.state;
axios.post('/api/contact', {
name,
email,
phone,
});
this.resetForm();
}
resetForm() {
this.setState({ name: '', email: '', phone: '', loading: true });
}
render() {
return (
<div className="contact">
<div className="contact-flex">
<div className="contact-right">
<h1>GET IN TOUCH</h1>
<div>
<form onSubmit={this.handleSubmit} method="POST">
<label htmlFor="name">NAME</label>
<br />
<input
onChange={this.handleChange}
value={this.state.name}
type="text"
id="name"
name="name"
placeholder="Your full name..."
required
/>
<br />
<label htmlFor="phone">PHONE</label>
<br />
<input
onChange={this.handleChange}
type="text"
id="phone"
name="phone"
placeholder="Your phone number..."
value={this.state.phone}
required
/>
<br />
<label htmlFor="email">EMAIL</label>
<br />
<input
onChange={this.handleChange}
type="email"
id="email"
name="email"
placeholder="Your email address..."
value={this.state.email}
required
/>
<br />
{!this.state.loading && (
<button className="contact-button" type="submit">
Send
</button>
)}
{this.state.loading && (
<button className="contact-button" type="submit">
Message Sent
</button>
)}
</form>
</div>
</div>
</div>
<div className="copy">
<img src={copy} className="copysvg" alt="copy"></img>
</div>
</div>
);
}
}
export default Contact;
Node Backend (Nodemailer):
var express = require('express');
const bodyParser = require('body-parser');
var nodemailer = require('nodemailer');
const creds = require('./config');
const app = express();
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: false }));
app.post('/api/contact', (req, res) => {
nodemailer.createTestAccount((err, account) => {
const htmlEmail = `
Name: ${req.body.name}
Phone: ${req.body.phone}
Email: ${req.body.email}
`;
let transporter = nodemailer.createTransport({
host: 'smtp.ethereal.email',
port: 587,
auth: {
user: 'MYEMAILHERE',
pass: 'MYPASSWORDHERE',
},
});
let mailOptions = {
from: req.body.name,
to: 'TOTHISEMAIL',
subject: 'Potential Client Message From The Workshop',
html: htmlEmail,
};
transporter.sendMail(mailOptions, (err, data) => {
console.log('message sent');
});
});
});
const PORT = process.env.PORT || 3001;
app.listen(PORT, () => {
console.log(`server listening on port ${PORT}`);
});