module ContentHelper
def published_at_formatted(article)
unless article && article.published?
if article.published_at&.future?
"Will publish on " + l(article.published_at, :format => (article.published_at.year == Time.now.year ? :short : :long))
else
"Draft"
end
else
l(article.published_at, :format => (article.published_at.year == Time.now.year ? :short : :long))
end
end
# def article_url(section, article, options = {})
# if article.section.is_a?(Blog)
# blog_article_url(section, article.full_permalink.merge(options))
# else
# page_article_url(*[section, article.permalink, options].compact)
# end
# end
def page_link_path section, link, options={}
link.body_html
end
def content_path(section, content, options={})
return article_path(section, content) if content.is_a? Article
link_path(section, content)
end
def content_status(content)
return " " unless content.respond_to?(:published?)
klass = content.published? ? 'published' : 'pending'
text = content.published? ? t(:'adva.titles.published') : t(:'adva.titles.pending')
"#{text}"
end
def link_to_preview(*args)
options = args.extract_options!
content, text = *args.reverse
text ||= :"adva.#{content.class.name.tableize}.links.preview"
url = show_path(content, :cl => content.class.locale, :namespace => nil)
options.reverse_merge!(:url => url, :class => "preview #{content.class.name.underscore}")
link_to_show(text, content, options)
end
def link_to_content(*args)
options = args.extract_options!
object, text = *args.reverse
link_to_show(text || (object.is_a?(Site) ? object.name : object.title), object, options) if object
end
def link_to_category(*args)
text = args.shift if args.first.is_a?(String)
category = args.pop
section = args.pop || category.section
route_name = :"#{section.class.name.downcase}_category_path"
text ||= category.title
link_to(text, send(route_name, :section_id => section.id, :category_id => category.id))
end
def links_to_content_categories(content, key = nil)
return if content.categories.empty?
links = content.categories.map { |category| link_to_category content.section, category }
key ? t(key, :links => links.join(', ')) : links
end
def link_to_tag(*args, &block)
tag = args.pop
section = args.pop
route_name = :"#{section.class.name.downcase}_tag_path"
if block_given?
link_to(send(route_name, section_permalink: section.permalink, tags: tag), &block)
else
text = args.pop || tag.name
link_to(text, send(route_name, section_permalink: section.permalink, tags: tag))
end
end
def links_to_content_tags(content, key = nil)
return if content.tags.empty?
links = content.tags.map { |tag| link_to_tag content.section, tag }
key ? t(key, links: links.join(', ')).html_safe : links
end
def content_category_checkbox(content, category)
type = content.type.downcase
checked = content.categories.include?(category)
name = "#{type}[category_ids][]"
id = "#{type}_category_#{category.id}"
check_box_tag(name, category.id, checked, :id => id)
end
end