module Locomotive module Liquid module Tags # Display the children pages of the site or the current page. If not precised, nav is applied on the current page. # The html output is based on the ul/li tags. # # Usage: # # {% nav site %} => # class Nav < ::Liquid::Tag Syntax = /(#{::Liquid::Expression}+)?/ def initialize(tag_name, markup, tokens) if markup =~ Syntax @site_or_page = $1 || 'page' @options = {} markup.scan(::Liquid::TagAttributes) { |key, value| @options[key.to_sym] = value } else raise ::Liquid::SyntaxError.new("Syntax Error in 'nav' - Valid syntax: nav ") end super end def render(context) @current_page = context.registers[:page] source = context.registers[@site_or_page.to_sym] # puts "#{@site_or_page.to_sym} / source = #{source.inspect}" if source.respond_to?(:name) # site ? source = source.pages.index.first # start from home page else source = source.parent || source end output = %{} output end private def render_child_link(page) selected = @current_page._id == page._id ? ' on' : '' icon = @options[:icon] ? '' : '' label = %{#{icon if @options[:icon] != 'after' }#{page.title}#{icon if @options[:icon] == 'after' }} %{
  • #{label}
  • }.strip end ::Liquid::Template.register_tag('nav', Nav) end end end end