Sha256: 740de1c9aa3e5a1c866af6cbdeffe90a0165c8846557a47667b2a87def435edd
Contents?: true
Size: 1.82 KB
Versions: 12
Compression:
Stored size: 1.82 KB
Contents
# Copyright (c) 2008 Michael Fellinger m.fellinger@gmail.com # All files in this distribution are subject to the terms of the Ruby license. module Ramaze # The purpose of this class is to provide an easy way of setting/retrieving # from the current flash. # # Flash is a way to keep a temporary pairs of keys and values for the duration # of two requests, the current and following. # # Very vague Example: # # On the first request, for example on registering: # # flash[:error] = "You should reconsider your username, it's taken already" # redirect R(self, :register) # # This is the request from the redirect: # # do_stuff if flash[:error] # # On the request after this, flash[:error] is gone. module Helper::Flash trait :flashbox => "<div class='flash' id='flash_%key'>%value</div>" # answers with Session.current.flash def flash Session.current.flash end # Use in your template to display all flash messages that may be stored. # For example, given you stored: # # flash # => { :error => 'Pleae enter your name' # :info => 'Do you see the fnords?' } # # Then a flashbox would display: # # <div class='flash' id='flash_error'>Please enter your name</div> # <div class='flash' id='flash_info'>Do you see the fnords?</div> # # This is designed to be customized permanently or per usage: # # flashbox("<div class='flash_%key'>%value</div>") # # Where any occurrence of %key and %value will be replaced by the actual # contents of each element of flash def flashbox(tag = ancestral_trait[:flashbox]) flash.map{|key, *values| values.flatten.map do |value| tag.gsub(/%key/, key.to_s).gsub(/%value/, value.to_s) end }.flatten.join("\n") end end end
Version data entries
12 entries across 12 versions & 3 rubygems