Sha256: 33222783e28efac88392738491fa84af6707f8aac4ec83af4e8f750d2753ef7f
Contents?: true
Size: 1.92 KB
Versions: 27
Compression:
Stored size: 1.92 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 module Flash include Innate::Traited trait :flashbox => "<div class='flash' id='flash_%key'>%value</div>" # answers with Current.session.flash def flash Current.session.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 end
Version data entries
27 entries across 27 versions & 4 rubygems