2005-01-24 18:52:04 +00:00
|
|
|
require 'chunks/chunk'
|
|
|
|
|
|
|
|
# The category chunk looks for "category: news" on a line by
|
|
|
|
# itself and parses the terms after the ':' as categories.
|
|
|
|
# Other classes can search for Category chunks within
|
|
|
|
# rendered content to find out what categories this page
|
|
|
|
# should be in.
|
|
|
|
#
|
|
|
|
# Category lines can be hidden using ':category: news', for example
|
|
|
|
class Category < Chunk::Abstract
|
2005-02-04 19:00:28 +00:00
|
|
|
CATEGORY_PATTERN = /^(:)?category\s*:(.*)$/i
|
|
|
|
def self.pattern() CATEGORY_PATTERN end
|
2005-01-24 18:52:04 +00:00
|
|
|
|
|
|
|
attr_reader :hidden, :list
|
|
|
|
|
2005-03-27 18:13:43 +00:00
|
|
|
def initialize(match_data, content)
|
|
|
|
super(match_data, content)
|
|
|
|
@hidden = match_data[1]
|
2005-01-24 18:52:04 +00:00
|
|
|
@list = match_data[2].split(',').map { |c| c.strip }
|
2005-03-27 18:13:43 +00:00
|
|
|
@unmask_text = ''
|
|
|
|
if @hidden
|
|
|
|
@unmask_text = ''
|
|
|
|
else
|
|
|
|
category_urls = @list.map { |category| url(category) }.join(', ')
|
|
|
|
@unmask_text = '<div class="property"> category: ' + category_urls + '</div>'
|
|
|
|
end
|
2005-01-24 18:52:04 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
# TODO move presentation of page metadata to controller/view
|
|
|
|
def url(category)
|
|
|
|
%{<a class="category_link" href="../list/?category=#{category}">#{category}</a>}
|
|
|
|
end
|
|
|
|
end
|