Class: ActionDispatch::Flash::FlashHash
Relationships & Source Files | |
Super Chains via Extension / Inclusion / Inheritance | |
Instance Chain:
self,
::Enumerable
|
|
Inherits: | Object |
Defined in: | actionpack/lib/action_dispatch/middleware/flash.rb |
Instance Attribute Summary
-
#alert
rw
Convenience accessor for
flash[:alert]
. -
#alert=(message)
rw
Convenience accessor for
flash[:alert]=
. - #empty? ⇒ Boolean readonly
-
#notice
rw
Convenience accessor for
flash[:notice]
. -
#notice=(message)
rw
Convenience accessor for
flash[:notice]=
.
::Enumerable - Included
#many? | Returns |
Instance Method Summary
- #[](k)
- #[]=(k, v)
- #clear
- #delete(key)
-
#discard(k = nil)
Marks the entire flash or a single flash entry to be discarded by the end of the current action:
- #each(&block)
- #initialize_copy(other)
-
#keep(k = nil)
Keeps either the entire current flash or a specific flash entry available for the next action:
- #key?(name) ⇒ Boolean
- #keys
-
#merge!(h)
Alias for #update.
-
#now
Sets a flash that will not be available to the next action, only to the current.
- #to_hash
::Enumerable - Included
Instance Attribute Details
#alert (rw)
Convenience accessor for flash[:alert]
.
# File 'actionpack/lib/action_dispatch/middleware/flash.rb', line 224
def alert self[:alert] end
#alert=(message) (rw)
Convenience accessor for flash[:alert]=
.
# File 'actionpack/lib/action_dispatch/middleware/flash.rb', line 229
def alert=( ) self[:alert] = end
#empty? ⇒ Boolean
(readonly)
[ GitHub ]
# File 'actionpack/lib/action_dispatch/middleware/flash.rb', line 152
def empty? @flashes.empty? end
#notice (rw)
Convenience accessor for flash[:notice]
.
# File 'actionpack/lib/action_dispatch/middleware/flash.rb', line 234
def notice self[:notice] end
#notice=(message) (rw)
Convenience accessor for flash[:notice]=
.
# File 'actionpack/lib/action_dispatch/middleware/flash.rb', line 239
def notice=( ) self[:notice] = end
Instance Method Details
#[](k)
[ GitHub ]# File 'actionpack/lib/action_dispatch/middleware/flash.rb', line 123
def [](k) @flashes[k.to_s] end
#[]=(k, v)
[ GitHub ]# File 'actionpack/lib/action_dispatch/middleware/flash.rb', line 117
def []=(k, v) k = k.to_s @discard.delete k @flashes[k] = v end
#clear
[ GitHub ]# File 'actionpack/lib/action_dispatch/middleware/flash.rb', line 156
def clear @discard.clear @flashes.clear end
#delete(key)
[ GitHub ]# File 'actionpack/lib/action_dispatch/middleware/flash.rb', line 141
def delete(key) key = key.to_s @discard.delete key @flashes.delete key self end
#discard(k = nil)
Marks the entire flash or a single flash entry to be discarded by the end of the current action:
flash.discard # discard the entire flash at the end of the current action
flash.discard(:warning) # discard only the "warning" entry at the end of the current action
#each(&block)
[ GitHub ]# File 'actionpack/lib/action_dispatch/middleware/flash.rb', line 161
def each(&block) @flashes.each(&block) end
#initialize_copy(other)
[ GitHub ]# File 'actionpack/lib/action_dispatch/middleware/flash.rb', line 109
def initialize_copy(other) if other.now_is_loaded? @now = other.now.dup @now.flash = self end super end
#keep(k = nil)
Keeps either the entire current flash or a specific flash entry available for the next action:
flash.keep # keeps the entire flash
flash.keep(:notice) # keeps only the "notice" entry, the rest of the flash is discarded
#key?(name) ⇒ Boolean
# File 'actionpack/lib/action_dispatch/middleware/flash.rb', line 137
def key?(name) @flashes.key? name.to_s end
#keys
[ GitHub ]# File 'actionpack/lib/action_dispatch/middleware/flash.rb', line 133
def keys @flashes.keys end
#merge!(h)
Alias for #update.
# File 'actionpack/lib/action_dispatch/middleware/flash.rb', line 165
alias :merge! :update
#now
Sets a flash that will not be available to the next action, only to the current.
flash.now[: ] = "Hello current action"
This method enables you to use the flash as a central messaging system in your app. When you need to pass an object to the next action, you use the standard flash assign (#[]=). When you need to pass an object to the current action, you use now
, and your object will vanish when the current action is done.
Entries set via now
are accessed the same way as standard entries: flash['my-key']
.
Also, brings two convenience accessors:
flash.now.alert = "Beware now!"
# Equivalent to flash.now[:alert] = "Beware now!"
flash.now.notice = "Good luck now!"
# Equivalent to flash.now[:notice] = "Good luck now!"
#to_hash
[ GitHub ]# File 'actionpack/lib/action_dispatch/middleware/flash.rb', line 148
def to_hash @flashes.dup end