The fastest way to start a new React on Rails project. One command creates a fully configured Rails + React application with TypeScript, server-side rendering, hot module replacement, and, optionally, React Server Components (RSC).
npx create-react-on-rails-app my-app
cd my-app
bin/rails db:prepare
bin/devOn fresh apps, bin/dev will try to open http://localhost:3000 the first time the app boots successfully.
The generated home page links to the example pages, the key files React on Rails created for you,
and follow-on docs for OSS vs Pro, React Server Components, and the marketplace demo.
The generated app also includes a step-by-step git history so you can inspect each major scaffold phase with git log --oneline --reverse.
When no --pro or --rsc flag is given, the CLI prompts you to choose a setup mode:
- Standard — open-source React on Rails with SSR
- Pro — adds Node.js server rendering (requires
react_on_rails_pro) - RSC — React Server Components (requires
react_on_rails_pro) (recommended, default)
The default choice is RSC. Press Enter to accept it, or type 1 or 2 to pick a different mode.
In non-interactive environments (CI, pipes), standard mode is used automatically.
To skip the prompt, pass --standard, --pro, or --rsc explicitly.
All mode flags support JavaScript (.jsx) and TypeScript (.tsx) templates.
--pro and --rsc require react_on_rails_pro to be installable in your environment
(Pro setup docs).
# Prompts for mode (Standard / Pro / RSC), defaults to RSC
npx create-react-on-rails-app my-app
# Skip prompt — use RSC directly
npx create-react-on-rails-app my-app --rsc
# Skip prompt — use Pro directly
npx create-react-on-rails-app my-app --pro
# Skip prompt — use Standard (open-source) directly
npx create-react-on-rails-app my-app --standard
# JavaScript instead of TypeScript
npx create-react-on-rails-app my-app --template javascript
# Use Rspack for ~20x faster builds
npx create-react-on-rails-app my-app --rspack
# Specify package manager
npx create-react-on-rails-app my-app --package-manager pnpm
# Combine RSC with Rspack
npx create-react-on-rails-app my-app --rspack --rsc| Option | Description | Default |
|---|---|---|
-t, --template <type> |
javascript or typescript |
typescript |
--rspack |
Use Rspack instead of Webpack (~20x faster) | false |
--standard |
Use open-source React on Rails (skip prompt) | false |
--pro |
Enable React on Rails Pro (requires react_on_rails_pro) |
false |
--rsc |
Enable React Server Components (requires react_on_rails_pro) |
false |
-p, --package-manager <pm> |
npm or pnpm |
auto-detected |
When none of --standard, --pro, or --rsc is given, the CLI prompts interactively in TTY environments (default: RSC). In non-TTY environments (CI, pipes, redirected output), standard mode is used automatically.
The CLI runs these steps automatically:
- Creates a Rails app (
rails newwith PostgreSQL, no default JS) - Adds required gems (
bundle add react_on_rails, plusreact_on_rails_profor--pro/--rsc) - Runs the generator (
rails generate react_on_rails:installwith your selected flags) - Creates educational git commits for each logical setup step
After completion, you get:
- A Rails 7+ app with PostgreSQL
- Shakapacker configured with Webpack (or Rspack) and HMR
- A working HelloWorld React component (TypeScript by default)
- A generated home page at
/with links to the example pages, important project files, and Pro/RSC learning resources - A teaching-friendly git history that separates Rails creation, gem installation, generator output, and pnpm normalization
- Standard Rails git scaffold files (
.gitignoreand.gitattributes) preserved in the generated app - Optional Pro setup (
--pro) with Pro Node renderer wiring and the generated/hello_worldexample - Optional RSC setup (
--rsc) with HelloServer route and Pro Node renderer wiring - Server-side rendering ready
- Development scripts (
bin/devwith hot reloading and first-run browser open)
The CLI checks for these before starting:
- Node.js 18+
- Ruby 3.0+
- Rails 7.0+ (
gem install rails) - git
- npm or pnpm
- PostgreSQL running locally (needed at
bin/rails db:prepare, not validated by the CLI)
If any of the first five are missing, you'll get a clear error message with installation instructions.
If you already have a Rails app, use the generator directly instead:
bundle add react_on_rails --strict
rails generate react_on_rails:install --typescript # TypeScript (recommended)
rails generate react_on_rails:install # JavaScriptSee Installation into an Existing Rails App for details.
Now that you have React on Rails running, here are ways to level up:
- Add server-side rendering — SSR guide
- See the feature comparison — OSS vs Pro
- Upgrade to Pro for React Server Components, streaming SSR, and 3-10x faster SSR — 3-step upgrade guide
- Explore the full docs — Documentation index