Class: SimpleNavigation::Renderer::List

Inherits:
Base
  • Object
show all
Defined in:
lib/simple_navigation/rendering/renderer/list.rb

Overview

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 (based on the level and expand_all options), it renders another <ul> containing the sub navigation inside the active <li> element.

By default, the renderer sets the item’s key as dom_id for the rendered <li> element unless the config option autogenerate_item_ids 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.

Instance Attribute Summary

Attributes inherited from Base

#adapter, #options

Instance Method Summary collapse

Methods inherited from Base

#expand_all?, #include_sub_navigation?, #initialize, #level, #render_sub_navigation_for, #skip_if_empty?

Constructor Details

This class inherits a constructor from SimpleNavigation::Renderer::Base

Instance Method Details

#render(item_container) ⇒ Object



13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
# File 'lib/simple_navigation/rendering/renderer/list.rb', line 13

def render(item_container)
  list_content = item_container.items.inject([]) do |list, item|
    li_options = item.html_options.reject {|k, v| k == :link}
    li_content = link_to(item.name, item.url, link_options_for(item))
    if include_sub_navigation?(item)
      li_content << render_sub_navigation_for(item)
    end
    list << (:li, li_content, li_options)
  end.join
  if skip_if_empty? && item_container.empty?
    ''
  else  
    (:ul, list_content, {:id => item_container.dom_id, :class => item_container.dom_class}) 
  end
end