stackable_flash
===============
* Allows flashes to stack intelligently like arrays.
* Follows the *principle of least surprise* for existing behavior of Rails' FlashHash.
| Project | Stackable Flash |
|------------------------ | ----------------- |
| gem name | stackable_flash |
| license | [data:image/s3,"s3://crabby-images/7a4eb/7a4eb7dde90b3c6effc80e7c87d5259e805747df" alt="License: MIT"](https://opensource.org/licenses/MIT) |
| expert support | [data:image/s3,"s3://crabby-images/9e659/9e659b01c11ac548fcbbe2f0b3317432cbd48454" alt="Get help on Codementor"](https://www.codementor.io/peterboling?utm_source=github&utm_medium=button&utm_term=peterboling&utm_campaign=github) |
| download rank | [data:image/s3,"s3://crabby-images/713d9/713d91836c92df3aebbabd42adb9f28921eb07af" alt="Total Downloads"](https://rubygems.org/gems/stackable_flash) |
| version | [data:image/s3,"s3://crabby-images/f6f33/f6f33a9c6e91b8896a8e1c700dc38a3a3f4167b0" alt="Gem Version"](http://badge.fury.io/rb/stackable_flash) |
| dependencies | [data:image/s3,"s3://crabby-images/2e205/2e205b44a3f94b41c31d55aa3e77b38de9dd5e75" alt="Dependency Status"](https://gemnasium.com/pboling/stackable_flash) |
| code quality | [data:image/s3,"s3://crabby-images/add6f/add6f0437bfb77e046ed0fb72bd607f491626001" alt="Code Climate"](https://codeclimate.com/github/pboling/stackable_flash) |
| inline documenation | [data:image/s3,"s3://crabby-images/a0036/a00365b2c94741dd4c19953f777b7f433029a820" alt="Inline docs"](http://inch-ci.org/github/pboling/stackable_flash) |
| continuous integration | [data:image/s3,"s3://crabby-images/1bc91/1bc91a0c59b2bcb6c41f41c51d933411f8f4a975" alt="Build Status"](https://travis-ci.org/pboling/stackable_flash) |
| test coverage | [data:image/s3,"s3://crabby-images/7fdd7/7fdd793f2a2063f5ea3166e5e92393c1301cd562" alt="Coverage Status"](https://coveralls.io/r/pboling/stackable_flash) |
| homepage | [on Github.com][homepage] |
| documentation | [on Rdoc.info][documentation] |
| live chat | [data:image/s3,"s3://crabby-images/55d7b/55d7baa2b87b297b8fc1aec61f3df1ba76ba0e45" alt="Join the chat at https://gitter.im/pboling/stackable_flash"](https://gitter.im/pboling/stackable_flash?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge) |
| Spread ~♡ⓛⓞⓥⓔ♡~ | [on Coderwall][coderwall] |
[semver]: http://semver.org/
[pvc]: http://docs.rubygems.org/read/chapter/16#page74
[railsbling]: http://www.railsbling.com
[peterboling]: http://www.peterboling.com
[coderwall]: http://coderwall.com/pboling
[documentation]: http://rdoc.info/github/pboling/stackable_flash/frames
[homepage]: https://github.com/pboling/stackable_flash
## Description
Stackable Flash overrides the `:[]=` method of Rails' FlashHash with the result being that each flash key is an array.
It is designed following the "Principle of least surprise", so in most ways the flash works as it always has.
Only now you can push things onto the array with `:<<`, and generally interact with the flash as an array.
In order to be as compatible as possible with existing implementations of the FlashHash on websites, `:[]=` will still
replace the entire object at that key.
## Installation
Add this line to your application's Gemfile:
gem 'stackable_flash'
And then execute:
$ bundle
Or install it yourself as:
$ gem install stackable_flash
## Config (Optional)
In an environment file, or application.rb
# Here are a few ideas (Don't do them all, pick one):
# You can use a lambda instead of a proc
StackableFlash::Config.configure do
# Leave it as an array
config[:stack_with_proc] = Proc.new {|arr| arr }
# Make a set of statements separated by br tags
config[:stack_with_proc] = Proc.new {|arr| arr.join('
') } # THIS IS DEFAULT IF LEFT UNCONFIGURED
# Make a set of p tags:
config[:stack_with_proc] = Proc.new {|arr| arr.map! {|x| "
#{x}
"}.join } # Make an unordered list of tags: config[:stack_with_proc] = Proc.new {|arr| '#{x}
"}.join } } ) do flash[:error] = 'original' flash[:error] << 'message' flash[:error] # => ['original','message'] flash[:error].stack # => 'original
message
' end And StackableFlash.not_stacked do flash[:notice] = 'original' flash[:notice] << ' message' flash[:notice] # => 'original message' # Uses the :stack_with_proc to transform flash[:notice].stack # => NoMethodError !!! end ## Sightings This gem is used by the [cacheable_flash](https://github.com/pboling/cacheable-flash) gem to provide stacking flashes. You can check it out for a working example. ## Contributing 1. Fork it 2. Create your feature branch (`git checkout -b my-new-feature`) 3. Commit your changes (`git commit -am 'Added some feature'`) 4. Push to the branch (`git push origin my-new-feature`) 5. Make sure to add tests for it. This is important so I don't break it in a future version unintentionally. 6. Create new Pull Request ## Versioning This library aims to adhere to [Semantic Versioning 2.0.0][semver]. Violations of this scheme should be reported as bugs. Specifically, if a minor or patch version is released that breaks backward compatibility, a new version should be immediately released that restores compatibility. Breaking changes to the public API will only be introduced with new major versions. As a result of this policy, you can (and should) specify a dependency on this gem using the [Pessimistic Version Constraint][pvc] with two digits of precision. For example: spec.add_dependency 'stackable_flash', '~> 4.0' [semver]: http://semver.org/ [pvc]: http://docs.rubygems.org/read/chapter/16#page74 ## Copyright Licensed under the MIT License. * Copyright (c) 2012-17 Peter H. Boling (http://railsbling.com). See LICENSE for further details.