A rapid Rails 6.1+ application template. This particular template utilizes WindiCSS, a utility-first CSS framework for rapid UI development and Vite, a build tool that aims to provide a faster and leaner development experience for modern web projects.
Inspired heavily by Jumpstart from Chris Oliver and my previous Kickoff Tailwind Rails application that utilized Webpack/Tailwind CSS.
Be sure to also check out Jumpstart Pro to save loads of time creating your next Rails application. Chris, Jason, and I teamed up on it.
New to Rails? Check out my course called Hello Rails or my YouTube channel for a bunch of free tutorials.
With Rails 6 we have webpacker by default now but it can become extremely slow to recompile as your application grows. Vite is an answer to this issue.
Vite consists of two major parts:
-
A dev server that provides rich feature enhancements over native ES modules, for example extremely fast Hot Module Replacement (HMR).
-
A build command that bundles your code with Rollup, pre-configured to output highly optimized static assets for production.
When creating a new rails app simply pass the template file through.
Because Rails 6.1 ships with webpacker by default we need to skip installing it all together when creating a new app. The main flags you need are --skip-webpack-install
and --skip-javascript
.
Important - using these flags means zero javascript gets added to the app so you'll need to add libraries as you go. This template adds the following packages as a starting point:
trix
@rails/actiontext
@rails/ujs
@rails/activestorage
stimulus
stimulus-vite-helpers
typescript
vite-plugin-stimulus-hmr
vite-plugin-full-reload
vite-plugin-windicss windicss
⬇️ Clone the repo
git clone [email protected]:justalever/kickoff_vite_rails.git
🏈 Kickoff a new app
rails new sample_app --skip-webpack-install --skip-javascript -m kickoff_vite_rails/template.rb
- Vite + WindiCSS configured in the
app/frontend
directory. - Devise with a new
name
field already migrated in. The name field maps to thefirst_name
andlast_name
fields in the database thanks to thename_of_person
gem. - Enhanced views using WindiCSS.
- Support for Friendly IDs thanks to the handy friendly_id gem. Note that you'll still need to do some work inside your models for this to work. This template installs the gem and runs the associated generator.
- Git initialization out of the box.
- Custom defaults for button and form elements.
$ rails server
$ bin/vite dev
📹 https://web-crunch.com/posts/vite-ruby-on-rails-application-template
Check out the Vite Ruby website for ideas on how to integrate more frameworks and toolings into your application.