This project is scaffolded so that you can build a React frontend and Rails backend together, and easily deploy them to Heroku.
- Ruby 2.7.3
- NodeJS (v14 or higher), and npm
- Heroku CLI
- Postgresql
See Environment Setup below for instructions on installing these tools if you don't already have them.
Fork and clone this repository.
Then run:
bundle install
rails db:create
npm install --prefix client
You can use the following commands to run the application:
rails s
: run the backend on http://localhost:3000npm start --prefix client
: run the frontend on http://localhost:4000rails start
: run the frontend and backend together with one command
Make sure to also update this README to include documentation about your project. Here's a list of some awesome readmes for inspiration.
This application has all the starter code needed to help you deploy your application to Heroku. It's recommended to deploy your project early and push up changes often to ensure that your code works equally well in production and development environments.
To deploy, first log in to your Heroku account using the Heroku CLI:
heroku login
Create the new Heroku app:
heroku create my-app-name
Add the builds for Heroku to run the Rails app on Ruby and build the React app on Node:
heroku buildpacks:add heroku/nodejs --index 1
heroku buildpacks:add heroku/ruby --index 2
To deploy, commit your code and push the changes to Heroku:
git add .
git commit -m 'Commit message'
git push heroku main
Note: depending on your Git configuration, your default branch might be named
master
ormain
. You can verify which by runninggit branch --show-current
. If it'smaster
, you'll need to rungit push heroku master
instead.
Any time you have changes to deploy, just make sure your changes are committed on the main branch of your repo, and push those changes to Heroku to deploy them.
You can view your deployed app with:
heroku open
Ensure you are running the
latest Ruby release supported by Heroku. At the time of writing,
that's 2.7.3
. You can verify with:
ruby -v
If you don't see 2.7.3
, you can install it and set it as the default version:
rvm install 2.7.3
rvm --default use 2.7.3
You should also install the latest versions of bundler
and rails
:
gem install bundler
gem install rails
Verify you are running a recent version of Node with:
node -v
If your Node version is less than 14, update it with:
nvm install node
You can also update your npm version with:
npm i -g npm
Follow this guide to install Heroku CLI (if you don't already have it):
Heroku requires that you use Postgresql for your database instead of SQLite. Postgresql (or just Postgres for short) is an advanced database management system with more features than SQLite. If you don't already have it installed, you'll need to set it up.
To install Postgres for WSL, follow this guide:
To install Postgres for OSX, you can use Homebrew:
brew install postgresql