Sha256: 68097b5c6871f9e6dc472dcc79ed3b14ce0c0bc98ed848c8b13cbc184a65beee

Contents?: true

Size: 1.63 KB

Versions: 1

Compression:

Stored size: 1.63 KB

Contents

module SimpleNavigation
  module Renderer

    # Renders an ItemContainer as a <ul> element and its containing items as <li> elements.
    # It adds the 'selected' class to li element AND the link inside the li element that is currently active.
    #
    # If the sub navigation should be included, it renders another <ul> containing the sub navigation inside the active <li> element.
    #
    # If the SimpleNavigation.config.render_all_levels option is set to true, it always renders all levels of navigation (fully expanded tree).
    #
    # By default, the renderer sets the item's key as dom_id for the rendered <li> 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.
    class List < SimpleNavigation::Renderer::Base

      def render(item_container, include_sub_navigation=false, options={})
        list_content = item_container.items.inject([]) do |list, item|
          html_options = item.html_options
          li_content = link_to(item.name, item.url, :class => item.selected_class, :method => item.method)
          if item.sub_navigation
            if SimpleNavigation.config.render_all_levels || (include_sub_navigation && item.selected?) || options[:all]
              li_content << (item.sub_navigation.render(include_sub_navigation))
            end
          end
          list << content_tag(:li, li_content, html_options)
        end
        content_tag(:ul, list_content.join, {:id => item_container.dom_id, :class => item_container.dom_class})
      end

    end
  end
end

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
strikeroff-simple-navigation-2.0.2 lib/simple_navigation/renderer/list.rb