Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/owpac/boilerplate_rails_inertia

Rails application working with Inertia and React!
https://github.com/owpac/boilerplate_rails_inertia

esbuild inertiajs postcss propshaft rails react tailwind typescript

Last synced: 14 days ago
JSON representation

Rails application working with Inertia and React!

Awesome Lists containing this project

README

        

# README

This project is a boilerplate for a basic Rails app with Inertia. Here is the tech stack:

- Propshaft
- esbuild
- Postcss with Tailwind
- Litestack as DB
- React as frontend framework
- Inertia

# How to reproduce?

### Step 1: Create your Rails app

```bash
rails new app --asset-pipeline=propshaft --javascript=esbuild --css=postcss --skip-hotwire
```

### Step 2: Configure Inertia

```bash
gem "inertia_rails"
```

```bash
yarn add react react-dom @inertiajs/react
```

Add in `config/initializers/inertia.rb`

```ruby
InertiaRails.configure do |config|
config.default_render = true
end

```

Add `use_inertia_instance_props` in `app/controllers/application_controller.rb`

Add in `app/javascript/application.jsx`

```jsx
import { createInertiaApp } from "@inertiajs/react";
import { createRoot } from "react-dom/client";

createInertiaApp({
resolve: (name) => require(`./pages/${name}.jsx`),
setup({ el, App, props }) {
createRoot(el).render();
},
});
```

### Step 3: Configure Tailwind

```bash
yarn add tailwindcss postcss autoprefixer

yarn tailwindcss init
```

Add in `postcss.config.js`

```js
/** @type {import('tailwindcss').Config} */
module.exports = {
content: [
"./app/views/**/*.html.erb",
"./app/helpers/**/*.rb",
"./app/assets/stylesheets/**/*.css",
"./app/javascript/**/*.{js,jsx}",
],
theme: {
extend: {},
},
plugins: [],
};
```

Add in `app/assets/stylesheets/application.postcss.css`

```css
@tailwind base;
@tailwind components;
@tailwind utilities;
```

#### Step 4: Configure litestack

```bash
gem "litestack"

bin/rails generate litestack:install
```