Skip to content

Gatsby/React app example with PHP back-end to receive emails from a contact form.

License

Notifications You must be signed in to change notification settings

frankagathos/gatsby-with-php-form

Repository files navigation

React/Gatsby - PHP form

Intro

This repo includes:

  1. The client app with Gatsby using Gatsby default starter. Please note that the method we use here to send emails will apply to any static site generator builder framework(next.js, create react app etc.).
  2. The back-end API using PHP to handle the requests from the client and send the emails.

In order to send emails with PHP you will need a local web server on your computer with a solution like XAMPP. If you have a LAMP stack server then you can deploy directly on your server. Current examples use axios to send the request from the client but other methods can be used instead.

Installation

After you clone the repo use the console to cd to the project's root directory and run:

  1. npm install - to install npm packages.
  2. npm start - to start the development server.

Quick start for Gatsby

Use form-A or form-B example components and follow the steps below:

  1. Replace the email address in config.php with your email.
  2. Replace the domain in the form-A component to the domain of your website or localhost if you are in dev.
  3. Create a static Gatsby site build using npm run build or gatsby build.
  4. Deploy the generated Gatsby static app found in the public folder to the server..

Quick start for any React application

Use form-A or form-B example components and follow the steps below:

  1. Follow steps 1. and 2. from above.
  2. Add the form-A component in your app.
  3. Add the api folder in the same directory you deploy your app.

More examples with hooks and front-end and back-end validation soon to come!

Star if you found this helpful and enjoy!