Skip to content

Latest commit

 

History

History
94 lines (66 loc) · 4.05 KB

README.md

File metadata and controls

94 lines (66 loc) · 4.05 KB

Hyperloop 🚄

Speed up your new Rails 8.0 projects with a preconfigured set of tools !

Note

This template has been built to match as best as possible default changes I make on every new Rails project I work on. It is very opinionated for some configuration so feel free to fork it and adapt it according to your needs.

Usage

If you don't have yet the project cloned, fetch it from remote URL:

$ rails new myapp -m https://raw.githubusercontent.com/anthony-robin/hyperloop/master/template.rb

If you already have it cloned:

$ rails new myapp -m hyperloop/template.rb

Warning

Some arguments from the rails new command might not be compatible with the template. Here are some flags that works well:

$ rails new myapp -m hyperloop/template.rb --css=tailwind --skip-ci --skip-test --skip-system-test --skip-brakeman --skip-active-storage --skip-action-text --skip-action-mailbox --skip-kamal --skip-git

Wait for the end of the installer, then start it with:

$ bin/dev

Tools

Gems

In production:

In development:

  • annotaterb to print model database structure (opinionated configuration)
  • bullet to track N+1 queries
  • chusaku to print routes URL above controller actions
  • letter_opener_web to intercept emails and print them in browser
  • rubocop and its extensions for coding conventions (very opinionated)
  • ribbonit to display Ruby and Rails informations
  • spark to reload browser page on HTML, CSS, JS modifications.

Frontend

Features

  • Rails authentication comes with session, registration and reset password features preconfigured as well as related mailers.

  • SEO is preconfigured to work in any pages by default and title/description can be specified directly in seo.{locale}.yml file.

  • Default browser confirm modal as been replaced with a pretty and friendly one following excellent gorails tutorial

  • Database is seed with default users corresponding to each access level

  • If using postgres adapter, database can be dockerized using:

    $ docker-compose up -d
  • Project is configured for french and english locales

Roadmap

See Github project for coming roadmap.

Credits

Hyperloop is inspired by:

Thank you :)