This gem is intended to simplify flash object presentation when an AJAX request was done. Its work is very simple. Explained below:
- Controller detects is an AJAX request is made
- If flash object exists, then it's serialized into response attributes
- Flash object is discarded
- The client browser will be capable of render the message by mean of some javascript.
Add this line to your application's Gemfile:
gem 'xhr_flash'
And then execute:
$ bundle
Or install it yourself as:
$ gem install xhr_flash
Add the following to your app/assets/javascript/application.js
//= require "jquery.xhrflash"
For example, if you want all messages to appear into a div with class messages, do this:
$(function(){
$('.messages').xhrflash();
})
...
<div class="messages"></div>
XHR-Flash JQuery plugin, by default, renders the next html code:
<div class="messages">
<div class="alert alert-success">All went right</div>
<div class="alert alert-error">Oops!, something was wrong</div>
</div>
Yes, you can customize it a bit. You can pass the following parameters to xhrflash:
-
msgs: It accepts a list of expected kind of messages to be displayed later. e.g.:
$('.messages').xhrflash({msgs : ['Notice', 'Errors']}); // It only allow X-Flash-Notice and X-Flash-Errors to be displayed in the container.
-
tag: Instead of divs, we can change the tag to wrap the messages.
-
class: By default each message has alert and alert-... classes. It can be coustomized as well.
-
timeout: Messages are visible for 5 seconds. You can specify another value here (in milliseconds).
- Fork it
- Create your feature branch (
git checkout -b my-new-feature
) - Commit your changes (
git commit -am 'Added some feature'
) - Push to the branch (
git push origin my-new-feature
) - Create new Pull Request