tag containing the text "random content" and assigns the tag a css class called +very_important+.
# <%= list.tag :div, class: "very_important" do %>
# random content
# <% end %>
def tag(tag_name, options = {}, &block)
if @output.present?
raise '"list.tag" can only be called once per iteration!'
else
@output = @template.content_tag(tag_name, options, &block) + "\n"
nil
end
end
end
# @param tag_name [String, Symbol] Name of the html tag (e.g. +:h1+ or +:div+).
# @param obj [Obj] A {Obj} from which method_name is read.
# @param method_name [String, Symbol] Which method_name of the Obj should be rendered. Currently only +toclist+ is supported
# @param options [Hash] Additional options, which are passed to +content_tag+. Use them to add HTML attributes to the tag.
# @yieldparam [List] list An instance, where +tag+ should be called once.
# @yieldparam [Obj] child Each child of +toclist+
# @return [String] The rendered html tag
#
# @example
# <%= cms_tag_list :div, @obj, :toclist, class: "very_important" do |list, child| %>
# <%= list.tag :div, class: "also_important" do %>
# <%= link_to cms_path(child) do %>
# <%= cms_tag :span, child, :title %>
# <% end %>
# <% end %>
# <% end %>
#
# # results for an obj with two children in
#
#
def cms_tag_list(tag_name, obj, method_name, options = {})
if method_name.to_s == 'toclist'
items = obj.toclist
else
raise "#{method_name} is not (yet) supported. Currently only toclist is supported."
end
inner_html = "\n".html_safe
items.each do |item|
list = List.new(self)
yield list, item
inner_html << list.output
end
options = options.merge({
'data-ip-child-list-path' => obj.path,
}) if inplace_editing_allowed?
content_tag(tag_name, inner_html, options)
end
def render_widget(widget, obj, field_name, container)
options = {
'data-ip-widget-id' => widget.id,
'data-ip-widget-obj-class' => widget.obj_class,
} if inplace_editing_allowed?
content_tag(:div, options || {}) do
WidgetRenderer.new(request).process('show', widget, obj, field_name, container)
end
end
end
end