Sha256: 2a0d6a90ec677c1e0c0787e026fa6a668a6c6c7278c55b024333e1d9aab72c11
Contents?: true
Size: 1.4 KB
Versions: 5
Compression:
Stored size: 1.4 KB
Contents
module SimpleNavigation module Renderer # Renders an ItemContainer as a <div> element and its containing items as <a> elements. # It only renders 'selected' elements. # # By default, the renderer sets the item's key as dom_id for the rendered <a> element unless the config option <tt>autogenerate_item_ids</tt> is set to false. # The id can also be explicitely specified by setting the id in the html-options of the 'item' method in the config/navigation.rb file. # The ItemContainer's dom_class and dom_id are applied to the surrounding <div> element. # class Breadcrumbs < SimpleNavigation::Renderer::Base def render(item_container) a_tags = a_tags(item_container) content_tag(:div, html_safe(a_tags(item_container).join(join_with)), {:id => item_container.dom_id, :class => item_container.dom_class}) end protected def a_tags(item_container) item_container.items.inject([]) do |list, item| if item.selected? list << link_to(html_safe(item.name), item.url, {:method => item.method}.merge(item.html_options.except(:class,:id))) if item.selected? if include_sub_navigation?(item) list.concat a_tags(item.sub_navigation) end end list end end def join_with @join_with ||= options[:join_with] || " " end end end end
Version data entries
5 entries across 5 versions & 1 rubygems