Hey there disclaimer that I'm new to using Gatsby, but I'm having some troubles with getting my form to submit properly using Netlify forms. Unsure if this is a Gatsby or Netlify related problem.
Steps to reproduce:
Any additional input you can provide would be very helpful and appreciated. Did a quick scan of open issues and wasn't able to locate anything that looked related.
Thanks for your work on this open source project...aside from this issue using Gatsby has been great thus far!
404
error for the POST
to /success
after submitting the form via the live site deploy on Netlify in my Chrome dev tools > Network tabgatsby-remark-images
, did an rm -rf
of my node_modules
and my package-lock.json
and did a fresh npm i
System:
OS: macOS 10.14.3
CPU: (8) x64 Intel(R) Core(TM) i5-8259U CPU @ 2.30GHz
Shell: 3.2.57 - /bin/bash
Binaries:
Node: 8.12.0 - ~/.nvm/versions/node/v8.12.0/bin/node
npm: 6.4.1 - ~/.nvm/versions/node/v8.12.0/bin/npm
Languages:
Python: 2.7.15 - /usr/local/bin/python
Browsers:
Chrome: 72.0.3626.109
Firefox: 63.0.3
Safari: 12.0.3
npmPackages:
gatsby: ^2.1.17 => 2.1.17
gatsby-image: ^2.0.29 => 2.0.29
gatsby-plugin-feed: ^2.0.13 => 2.0.13
gatsby-plugin-google-analytics: ^2.0.14 => 2.0.14
gatsby-plugin-manifest: ^2.0.19 => 2.0.19
gatsby-plugin-offline: ^2.0.24 => 2.0.24
gatsby-plugin-react-helmet: ^3.0.6 => 3.0.6
gatsby-plugin-sharp: ^2.0.22 => 2.0.22
gatsby-plugin-typography: ^2.2.7 => 2.2.7
gatsby-remark-copy-linked-files: ^2.0.9 => 2.0.9
gatsby-remark-images: ^2.0.6 => 2.0.6
gatsby-remark-prismjs: ^3.2.4 => 3.2.4
gatsby-remark-responsive-iframe: ^2.0.9 => 2.0.9
gatsby-remark-smartypants: ^2.0.8 => 2.0.8
gatsby-source-filesystem: ^2.0.22 => 2.0.22
gatsby-transformer-remark: ^2.2.6 => 2.2.6
gatsby-transformer-sharp: ^2.1.14 => 2.1.14
@deeheber a quick glance at your code repository i saw that you have gatsby-plugin-offline
installed and activated in your gatsby-config.js
, so with that i would like to you to do the following:
gatsby-config.js
file.gatsby clean
, so that the .cache
and public
folders are purged.gatsby develop
and send something through the form.This because at first glance, it looks like the service worker might be the culprit.
Hey @jonniebigodes thanks for the reply!
I tried those things out and am still experiencing the same issue. Noticing it flashes a 404 page real quick and then redirects to the /success
page when hitting submit if that's helpful?
Looked at my form submissions and did get one at 10:49AM PT from a Dustin at Gatsby...unsure how he successfully submitted that. I have my netlify setup to auto deploy when I push to master, so what's in master is what's up on the live netlify site.
@deeheber I didn't do anything special--just filled out the form!
I did disable the service worker, but that seems like a sorta unlikely culprit.
Happy to debug this further, but at first glance--this seems like a Netlify issue rather than a Gatsby issue.
I may recommend checking out some of these resources:
Sounds good @DSchau. I sent an email to Netlify asking for input from them.
@deeheber Did you hear anything back from Netlify? I'm experiencing the same issue.
@j-651 They said they thought it was the service worker (the gatsby-plugin-offline
). I just gave up bc I'd like a reliable form anyway. Good it know it wasn't just me having the issue...thought I'm sorry you're also experiencing it.
I would love for someone to help me figure this out. I am having the same exact problem as deeheber. I've tried just about every little thing I could find after endless googling...
@valdezDev i picked up on your comment and i was able to connect Gatsby and netlify forms.
Here are the steps i took
dummyForm.js
under src/components
with the following content:import React from "react"
export default () => (
<form
name="contact"
method="post"
action="/success"
data-netlify="true"
data-netlify-honeypot="bot-field"
>
<input type="hidden" name="bot-field" />
<div>
<label htmlFor="name">Name</label>
<input type="text" name="name" id="name" />
</div>
<div>
<label htmlFor="email">Email</label>
<input type="text" name="email" id="email" />
</div>
<div>
<label htmlFor="message">Message</label>
<textarea name="message" id="message" rows="6" required />
</div>
<div>
<input type="submit" value="Drop a line" />
<input type="reset" value="Eraser" />
</div>
</form>
)
src\pages/index.js
transforming it into:import React from "react"
import DummyForm from "../components/dummyForm"
export default () => (
<div>
<h2>Send me a line</h2>
<DummyForm/>
</div>
)
success.js
, so that i have something to show when the form submission is done with the following content:import React from "react"
export default () => (
<div>
<h2>You dropped me a new line</h2>
<h4> Congrats,i'll be sure to check it out when i can and add a reply</h4>
</div>
)
As you can see both submissions were added with success.
I hope my reproduction can help you solve your issue. If not. feel free to add a minimal reproduction of your issue. Feel free to provide feedback
Hi @jonniebigodes thank you so much for taking the time to help me troubleshoot this issue. I will start by posting the link to my repo: https://github.com/valdezDev/gatsby-portfolio so you can refer to commits if needed. I know my code might look a little bit messy at the moment. I got my form to work by doing exactly what you suggested and found that it can only work on the index page. Do you think there's any way that I can have this wire up in the same way on my contact page with the same functionality? If not, I can readjust my index page to incorporate the contact form. Thanks again!
@valdezDev What I did to fix this issue, first confirm you have the hidden input field for the bot detection when using honey bot, make sure all the other essentials are covered you can refer to the Forms.
Once you can confirm you did all of this then go into your developers tab look at the Post data which can be found under the network tab. check to see if the request is truncating your post form name, you can confirm this by comparing the post parameters. First preserve the log then disable javascript sumbit a form request, confirm that the form is submitted to Netlify. If it was submitted then I urge you to refer to this piece of code.
Strangely, having a field with name email
and type text
wouldn't post the form to Netlify for me, but once I changed the type of the field to email
it worked.
Why did this get closed? I'm having the exact same issue as others here.
@gastongarcia this isn't a Gatsby issue.
@KyleAMathews You're right.
Here's a the fix that probably everyone needs:
For Netlify Forms, if you're using a SSG like Gatsby, a hidden input field with the form name is needed. Without this it won't work.
https://www.netlify.com/blog/2017/07/20/how-to-integrate-netlifys-form-handling-in-a-react-app/#step-2
I will be soon publishing a YouTube video as well as a blog post going over
this issue if anyone is interested. As I've stated before, I found that a
correctly set up Netlify form can only work on the index page that the
gatsby boilerplate provides the dev. I had it set up so that the user would
have to navigate to a 'contact' page where the form would be and I would
only get 404 errors. If anyone wants to peek at my unfinished portfolio
code base, feel free! https://github.com/valdezDev/gatsby-portfolio
On Sat, Apr 27, 2019 at 6:24 PM Gaston Garcia notifications@github.com
wrote:
@KyleAMathews https://github.com/KyleAMathews You're right.
Here's a the fix that probably everyone needs:
For Netlify Forms, if you're using a SSG like Gatsby, a hidden input field
with the form name is needed. Without this it won't work.https://www.netlify.com/blog/2017/07/20/how-to-integrate-netlifys-form-handling-in-a-react-app/#step-2
—
You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub
https://github.com/gatsbyjs/gatsby/issues/12040#issuecomment-487324295,
or mute the thread
https://github.com/notifications/unsubscribe-auth/AH6IEIB2PT72ULYHQNMYUK3PSTHDHANCNFSM4GZ2ZC7A
.
Catch up on this and it looks like my reproduction not the one above, but the one directed specifically at valdezDev magically disappeared. Humm interesting......Anyway, I've made a pull request to valdezDev repository and you can see there the code i used to make it work.
You can have the contact form wherever you want. As I posted above, the problem is not having the hidden input field. When using a Static Site Generator it's best to set it up that way.
I'm also facing the same problem, but somehow on the Netlify app dashboard, I can submit the form. but on the site, I can't.
Anothing is that data-netlify="true" and data-netlify-honeypot="bot-field" are visible in my form on the website only after I tried to submit the form on the Netlify App dashboard. But on the website, it is still unable to submit the form.
@duongthienlee if you check the network tab on your development tools you're probably seeing that you're getting some 404. The code below was the one used to correct the issue at hand, it worked for @valdezDev in my now missing comment when i made a reproduction for solving the issue for him.
import React, { Component } from "react"
import { navigate } from "gatsby"
class ContactForm extends Component {
constructor(props) {
super(props)
this.ContactForm = React.createRef()
this.state = {}
}
encode = data => {
return Object.keys(data)
.map(key => encodeURIComponent(key) + "=" + encodeURIComponent(data[key]))
.join("&")
}
handleChange = e => {
this.setState({ [e.target.name]: e.target.value })
}
handleSubmit = e => {
e.preventDefault()
const form = this.ContactForm.current
fetch("/", {
method: "POST",
headers: { "Content-Type": "application/x-www-form-urlencoded" },
body: this.encode({
"form-name": form.getAttribute("name"),
...this.state,
}),
})
.then(response => {
console.log("====================================")
console.log(`${JSON.stringify(response, null, 2)}`)
console.log("====================================")
navigate(form.getAttribute("action"))
})
.catch(error => {
console.log("====================================")
console.log(`error in submiting the form data:${error}`)
console.log("====================================")
})
}
render() {
return (
<form
name="contact"
method="post"
action="/success/"
data-netlify="true"
data-netlify-honeypot="bot-field"
onSubmit={this.handleSubmit}
ref={this.ContactForm}
>
<input type="hidden" name="form-name" value="contact" />
<p hidden>
<label>
Don’t fill this out:{" "}
<input name="bot-field" onChange={this.handleChange} />
</label>
</p>
<p>
<label>
Your name:
<br />
<input type="text" name="name" onChange={this.handleChange} />
</label>
</p>
<p>
<label>
Your email:
<br />
<input type="email" name="email" onChange={this.handleChange} />
</label>
</p>
<p>
<label>
Message:
<br />
<textarea name="message" onChange={this.handleChange} />
</label>
</p>
<p>
<button type="submit">Send</button>
<input type="reset" value="Eraser" />
</p>
</form>
)
}
}
export default ContactForm
see if the code above helps you in any shape or form and report back.
Thanks @jonniebigodes, the code above actually works for me "sometimes". But it looks like the data-netlify="true" and data-netlify-honeypot="bot-field" on the form will be gone if I enter my website with the direct link https://thienwinchester.netlify.com/contact.
However, If I enter the home page first : https://thienwinchester.netlify.com, then navigate to the contact page, it sometimes works, sometimes doesn't. Don't know why? I entered my site by incognito tab, but it still doesn't work.
One thing is that I am able to submit form on mobile chrome. I tried safari, firefox on my laptop, still doesnt work. The first time I deployed the modified form you suggest, it works, but then I tried again, it doesn't
I confirm that the code from @jonniebigodes actually works for me. The reason why I couldn't submit the form is because on my app, I'm using another onClick event on my page, which properly prevent from clicking the submit button. That's why on mobile, it works like charm
@duongthienlee glad to hear it. I'm leaving the code here, so that future people that come across this issue could try the code i posted and see if it helps them in any way, shape or form and with that avoid creating further issues in here.
I'm having the same issue. I have actually been able to make this work on a previous project without a hitch, but have not been able to replicate it. I have adapted @jonniebigodes code, but I still keep getting a 404 error. Specifically, the console.log of the response returns empty.
I'm having the same issue. I have actually been able to make this work on a previous project without a hitch, but have not been able to replicate it. I have adapted @jonniebigodes code, but I still keep getting a 404 error. Specifically, the console.log of the response returns empty.
Can confirm that the stringified response returns empty, but the form does submit successfully for me.
@orshick and @MirelesCloud the console.log
was not supposed to be there, i forgot to remove it, i only used it when i was testing.
Strangely, having a field with name
text
wouldn't post the form to Netlify for me, but once I changed the type of the field to
This worked for me also
I'm still getting a 404 when submitting a Netlify form from my Gatsby site.
Here's my code:
import React, {useState} from 'react';
import {navigate} from 'gatsby';
import {Button} from '@material-ui/core';
function encode(data) {
return Object.keys(data)
.map(key => encodeURIComponent(key) + '=' + encodeURIComponent(data[key]))
.join('&');
}
export default function PaperForm({children, ...rest}) {
const handleSubmit = e => {
e.preventDefault();
const form = e.target;
fetch('/', {
method: 'POST',
headers: {'Content-Type': 'application/x-www-form-urlencoded'},
body: encode({
'form-name': form.getAttribute('name'),
'name': 'Brendan',
'email': '[email protected]',
'tel': '403.393.0000',
'description': 'Lorem ipsum sit amet'
})
})
.then(response => {
console.log('====================================');
console.log(`${JSON.stringify(response, null, 2)}`);
console.log('====================================');
navigate(form.getAttribute("action"))
})
.catch(error => {
console.log('====================================');
console.log(`error in submiting the form data:${error}`);
console.log('====================================');
});
};
const recaptchaSubmit = e => {
setVerified(true);
};
return (
<form
name="contact"
method="POST"
action='/thanks'
onSubmit={handleSubmit}
data-netlify="true"
data-netlify-honeypot="bot-field"
{...rest}
>
{/* Used to detect spam bots */}
<input type="hidden" name="bot-field" />
<input type="hidden" name="form-name" value="contact" />
... other inputs
<Button
variant="contained"
color="primary"
type="submit"
>
Send
</Button>
</form>
);
}
I just put some dummy data in the request, and otherwise have followed the instructions provided by Netlify and in this thread.
EDIT: Made a blog post on debugging GatsbyJS forms with Netlify.
Hi all - just been stung by this & found the issue. Hopefully this will help people debug.
form-name
input:Ensure all input/selects/textareas etc have a name
attribute.
Check Gatsby is actually outputting the form into the built HTML:
rm -rf .cache && rm -rf public && gatsby build
. public/contact/index.html
.<form
redux-persist
(which renders content when the client has loaded, but nothing on the server).@Ehesp thank you for the info.
For whatever it's worth, you can also delete the .cache
and public folders by running gatsby clean
. See here for more info on the command.
Hi all , i had the same problem and i solved it , all i did is Empty Cache and Hard Reload in the browser . To do so : press F12. This opens the Chrome Developer Tools. Next, right-click on the browser Reload button click on Emty Cache and hard reload . I hope it works for you all .
Hi everyone,
Just had a similar problem, was sending the form, was redirected to my success page, but nothing on netlify.
For me the issue was using data-netlify
instead of netlify
, i didn't investigate further (sorry) for the real reason why the data-netlify
does not work.
Here is the working code for my case
<form
name="form-contact"
action="/contact-thank-you"
className="tr"
netlify="true"
method="POST"
netlify-honeypot="not-today"
>
<Input label="Ton Email" name="email" type="email" required />
<input name="not-today" hidden />
<input name="form-name" value="form-contact" hidden />
<Textarea label="Ton Message" name="message" required />
<Button icon="fa-paper-plane" type="submit">
Envoyer
</Button>
</form>
Input, Textarea and Button components are just for styling, nothing fancy/hidden happening there.
import React from "react"
const Button = ({ children, icon, ...props }) => {
return (
<button
{...props}
className="border-box f5 f4-ns tc mid-gray pv2 ph4 br-pill b--mid-gray bg-transparent bw1 ba"
>
{children}
<i className={`fas ${icon} ml2`} />
</button>
)
}
export default Button
I hope this can help someone someday :)
Here's a the fix that probably everyone needs:
For Netlify Forms, if you're using a SSG like Gatsby, a hidden input field with the form name is needed. Without this it won't work.
https://www.netlify.com/blog/2017/07/20/how-to-integrate-netlifys-form-handling-in-a-react-app/#step-2
For what it's worth, this did NOT work for me using the framework Angular. It may still be necessary, but it didn't solve the problem.
Hello, I have read all the comments on this issue because I have the same problem. This handleSubmit function works for me in Local (200 res), but once deployed in Netlify, throws a 404 error. It is strange because I can see the page where I am redirected once the form is submitted(/success page).
I had the same issue, it worked whene i added hidden fields to the form
<input type="hidden" name="bot-field" />
<input type="hidden" name="form-name" value="contact" />
@jonniebigodes code worked for me! Thank you!. I would remember that when using hooks set state this way setState({ ...state, [e.target.name]: e.target.value });
Also if you're using plugin-offline need to add ?no-cache=1
as posted in here: https://github.com/gatsbyjs/gatsby/issues/7997
@Lucascoorek that's great. Glad to hear it that it worked for you. And it goes without saying, really no need to thank, just glad that the code/comment helped you aswell.
Just wanted to let everyone know this helped me a ton so grateful for all of you, thanks!
Most helpful comment
@KyleAMathews You're right.
Here's a the fix that probably everyone needs:
For Netlify Forms, if you're using a SSG like Gatsby, a hidden input field with the form name is needed. Without this it won't work.
https://www.netlify.com/blog/2017/07/20/how-to-integrate-netlifys-form-handling-in-a-react-app/#step-2