/turbolinks_render

Support for `render` with Turbolinks in Rails controllers

Primary LanguageRubyMIT LicenseMIT

CircleCI

turbolinks_render

Use render in your Rails controllers and handle the response with Turbolinks.

Turbolinks supports redirect_to out of the box. But render is not supported and you have to use workarounds for common things like dealing with forms. This gem aims to fix that.

I think Turbolinks/Rails should handle this officially. If you agree you can vote for this idea.

Installation

Add this line to your application's Gemfile:

gem 'turbolinks_render'

And then execute:

$ bundle

Usage

By default, render will be handled by Turbolinks if these conditions are met:

  • It's an ajax request
  • It's not a get request
  • It generates an html response (text/html content type)

When these conditions are met and render is used:

  • The page content is replaced with the rendered content with Javascript. It uses Turbolinks to do this replacement, so it is pretty smart about keeping the <head> when it's identical, executing <script> elements, etc.
  • An event turbolinks:load is dispatched

You can disable turbolinks on a given request with:

render turbolinks: false

Configuration

You can invert the default behavior: never use turbolinks for rendering unless explicitly indicated. Create a file config/initializers/turbolinks_render.rb and toggle turbolinks_render.render_with_turbolinks_by_default:

Rails.application.config.turbolinks_render.render_with_turbolinks_by_default = false

In this case, to use turbolinks you should write:

render turbolinks: true

You can also ignore specific paths in your application. This can be useful if you're using an engine and don't have access to its code to change the render calls. For instance, to ignore anything that starts with /admin:

Rails.application.config.turbolinks_render.ignored_paths = [
  '/admin'
]

Implementation notes

  • It configures a rack middleware that intercept requests and modify responses when the expected conditions are met.
  • It uses some internal Turbolinks classes to perform the rendering. This makes the DOM-update logic very smart but it could introduce problems with future Turbolink versions , since this does not belong to its public API. I'll do my best to keep things up to date.

Example

An example and an explanatory blog post are also available.

Credits

License

The gem is available as open source under the terms of the MIT License.