require 'haml/helpers/action_view_mods' require 'haml/helpers/action_view_extensions' module Haml # This module contains various helpful methods to make it easier to do # various tasks. Haml::Helpers is automatically included in the context # that a Haml template is parsed in, so all these methods are at your # disposal from within the template. module Helpers self.extend self @@action_view_defined = defined?(ActionView) @@force_no_action_view = false # Returns whether or not ActionView is installed on the system. def self.action_view? @@action_view_defined end # Note: this does *not* need to be called # when using Haml helpers normally # in Rails. # # Initializes the current object # as though it were in the same context # as a normal ActionView rendering # using Haml. # This is useful if you want to use the helpers in a context # other than the normal setup with ActionView. # For example: # # context = Object.new # class << context # include Haml::Helpers # end # context.init_haml_helpers # context.haml_tag :p, "Stuff" # def init_haml_helpers @haml_buffer = Haml::Buffer.new(@haml_buffer, Haml::Engine.new('').send(:options_for_buffer)) nil end # call-seq: # non_haml { ... } # # Runs a block of code in a non-Haml context # (i.e. #is_haml? will return false). # # This is mainly useful for rendering sub-templates such as partials in a non-Haml language, # particularly where helpers may behave differently when run from Haml. # # Note that this is automatically applied to Rails partials. def non_haml was_active = @haml_buffer.active? @haml_buffer.active = false res = yield @haml_buffer.active = was_active res end # call-seq: # find_and_preserve(input) # find_and_preserve {...} # # Isolates the whitespace-sensitive tags in the string and uses preserve # to convert any endlines inside them into HTML entities for endlines. def find_and_preserve(input = '', &block) return find_and_preserve(capture_haml(&block)) if block input = input.to_s input.gsub(/<(textarea|code|pre)([^>]*)>(.*?)(<\/\1>)/im) do "<#{$1}#{$2}>#{preserve($3)}#{$1}>" end end # call-seq: # preserve(input) # preserve {...} # # Takes any string, finds all the endlines and converts them to # HTML entities for endlines so they'll render correctly in # whitespace-sensitive tags without screwing up the indentation. def preserve(input = '', &block) return preserve(capture_haml(&block)) if block input.gsub(/\n/, ' ').gsub(/\r/, '') end alias_method :flatten, :preserve # Takes an Enumerable object and a block # and iterates over the object, # yielding each element to a Haml block # and putting the result into elements. # This creates a list of the results of the block. # For example: # # = list_of([['hello'], ['yall']]) do |i| # = i[0] # # Produces: # #
All the stuff
#A book about all the stuff.
#bar
# baz # def tab_up(i = 1) haml_buffer.tabulation += i end # Decrements the number of tabs the buffer automatically adds # to the lines of the template. # # See also tab_up. def tab_down(i = 1) haml_buffer.tabulation -= i end # Surrounds the given block of Haml code with the given characters, # with no whitespace in between. # For example: # # = surround '(', ')' do # %a{:href => "food"} chicken # # Produces: # # (chicken) # # and # # = surround '*' do # %strong angry # # Produces: # # *angry* # def surround(front, back = nil, &block) back ||= front output = capture_haml(&block) "#{front}#{output.chomp}#{back}\n" end # Prepends the given character to the beginning of the Haml block, # with no whitespace between. # For example: # # = precede '*' do # %span.small Not really # # Produces: # # *Not really # def precede(char, &block) "#{char}#{capture_haml(&block).chomp}\n" end # Appends the given character to the end of the Haml block, # with no whitespace between. # For example: # # click # = succeed '.' do # %a{:href=>"thing"} here # # Produces: # # click # here. # def succeed(char, &block) "#{capture_haml(&block).chomp}#{char}\n" end # Captures the result of the given block of Haml code, # gets rid of the excess indentation, # and returns it as a string. # For example, after the following, # # .foo # - foo = capture_haml(13) do |a| # %p= a # # the local variable foo would be assigned to "13
\n". # def capture_haml(*args, &block) capture_haml_with_buffer(haml_buffer.buffer, *args, &block) end # Outputs text directly to the Haml buffer, with the proper tabulation def puts(text = "") haml_buffer.buffer << (' ' * haml_buffer.tabulation) << text.to_s << "\n" nil end # # call-seq: # haml_tag(name, attributes = {}) {...} # haml_tag(name, text, attributes = {}) {...} # # Creates an HTML tag with the given name and optionally text and attributes. # Can take a block that will be executed # between when the opening and closing tags are output. # If the block is a Haml block or outputs text using puts, # the text will be properly indented. # # For example, # # haml_tag :table do # haml_tag :tr do # haml_tag :td, {:class => 'cell'} do # haml_tag :strong, "strong!" # puts "data" # end # haml_tag :td do # puts "more_data" # end # end # end # # outputs # ## # strong! # # data # | ## more_data # | #