Sha256: 801ebef1eb0b357493cfc9d6d84cad3582a742364b3b3778dde387ab032027a9
Contents?: true
Size: 1.53 KB
Versions: 2
Compression:
Stored size: 1.53 KB
Contents
require 'table_helper/row' module TableHelper # Represents the header of the table. In HTML, you can think of this as # the <tfoot> tag of the table. class Footer < HtmlElement # The table this footer is a part of attr_reader :table # The actual footer row attr_reader :row # Whether or not the footer should be hidden when the collection is # empty. Default is true. attr_accessor :hide_when_empty delegate :cell, :empty?, :to => :row def initialize(table) #:nodoc: super() @table = table @row = Row.new(self) @hide_when_empty = true end def html #:nodoc: # Force the last cell to span the remaining columns cells = row.cells.values colspan = table.header.columns.length - cells[0..-2].inject(0) {|count, (name, cell)| count += (cell[:colspan] || 1).to_i} cells.last[:colspan] ||= colspan if colspan > 1 html_options = @html_options.dup html_options[:style] = "display: none; #{html_options[:style]}".strip if table.empty? && hide_when_empty content_tag(tag_name, content, html_options) end private def tag_name 'tfoot' end # Generates the html for the footer. The footer generally consists of a # summary of the data in the body. This row will be wrapped inside of # a tfoot tag. If the collection is empty and hide_when_empty was set # to true, then the footer will be hidden. def content @row.html end end end
Version data entries
2 entries across 2 versions & 2 rubygems
Version | Path |
---|---|
pluginaweek-table_helper-0.2.1 | lib/table_helper/footer.rb |
table_helper-0.2.1 | lib/table_helper/footer.rb |