ruby-html-table 0.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +7 -0
- data/lib/assets/css/table_template.css +136 -0
- data/lib/assets/icons/show.icon +1 -0
- data/lib/assets/js/table_template.js +141 -0
- data/lib/html_table.rb +220 -0
- metadata +60 -0
checksums.yaml
ADDED
@@ -0,0 +1,7 @@
|
|
1
|
+
---
|
2
|
+
SHA256:
|
3
|
+
metadata.gz: 244c57db696c6f2e1e89481d89e5d91632e73e1cf9ca4e4e204ab4fde1de76e1
|
4
|
+
data.tar.gz: 25eb28e3b73f53165aab45a2fbef55a54303ea752ca70fe342e2162803ff4799
|
5
|
+
SHA512:
|
6
|
+
metadata.gz: d6612527c7bdea0562b53c552ad2ef903f9992466154dcf633668400f8be13a279cc4cb32a49e607303d631ca4cd002ab6fa28c71e894bdb40a65ac482cc1433
|
7
|
+
data.tar.gz: 4c9a3ec73fbe00c5553652675941bb727e053bbfa9d553045990e517c524de164492f9aec40a6e588a8fffbbddb5dcb4bb1977f5f996e59ea641c1845080618f
|
@@ -0,0 +1,136 @@
|
|
1
|
+
/* Table Styles */
|
2
|
+
|
3
|
+
.table-wrapper{
|
4
|
+
margin: 10px 10px 10px;
|
5
|
+
box-shadow: 0px 10px 10px rgba( 0, 0, 0, 0.2 );
|
6
|
+
}
|
7
|
+
|
8
|
+
.fl-table {
|
9
|
+
border-radius: 5px;
|
10
|
+
font-size: 12px;
|
11
|
+
font-weight: normal;
|
12
|
+
border: none;
|
13
|
+
border-collapse: collapse;
|
14
|
+
width: 100%;
|
15
|
+
max-width: 100%;
|
16
|
+
white-space: nowrap;
|
17
|
+
background-color: white;
|
18
|
+
}
|
19
|
+
|
20
|
+
.fl-table td, .fl-table th {
|
21
|
+
text-align: center;
|
22
|
+
padding: 8px;
|
23
|
+
}
|
24
|
+
|
25
|
+
.fl-table td {
|
26
|
+
border-right: 1px solid #f8f8f8;
|
27
|
+
font-size: 12px;
|
28
|
+
}
|
29
|
+
|
30
|
+
.fl-table thead th {
|
31
|
+
color: #ffffff;
|
32
|
+
/*PRIMARY_COLOR*/
|
33
|
+
}
|
34
|
+
|
35
|
+
#fl-table-even {
|
36
|
+
color: #ffffff;
|
37
|
+
/*PRIMARY_COLOR*/
|
38
|
+
}
|
39
|
+
|
40
|
+
#fl-table-odd {
|
41
|
+
color: #ffffff;
|
42
|
+
/*SECONDARY_COLOR*/
|
43
|
+
}
|
44
|
+
|
45
|
+
|
46
|
+
.fl-table thead th:nth-child(odd) {
|
47
|
+
color: #ffffff;
|
48
|
+
/*PRIMARY_COLOR*/
|
49
|
+
}
|
50
|
+
|
51
|
+
.fl-table tr:nth-child(even) {
|
52
|
+
background: #F8F8F8;
|
53
|
+
}
|
54
|
+
|
55
|
+
/* Responsive */
|
56
|
+
|
57
|
+
@media (max-width: 767px) {
|
58
|
+
.fl-table {
|
59
|
+
display: block;
|
60
|
+
width: 100%;
|
61
|
+
}
|
62
|
+
.table-wrapper:before{
|
63
|
+
content: "Scroll horizontally >";
|
64
|
+
display: block;
|
65
|
+
text-align: right;
|
66
|
+
font-size: 11px;
|
67
|
+
color: white;
|
68
|
+
padding: 0 0 10px;
|
69
|
+
}
|
70
|
+
.fl-table thead, .fl-table tbody, .fl-table thead th {
|
71
|
+
display: block;
|
72
|
+
}
|
73
|
+
.fl-table thead th:last-child{
|
74
|
+
border-bottom: none;
|
75
|
+
}
|
76
|
+
.fl-table thead {
|
77
|
+
float: left;
|
78
|
+
}
|
79
|
+
.fl-table tbody {
|
80
|
+
width: auto;
|
81
|
+
position: relative;
|
82
|
+
overflow-x: auto;
|
83
|
+
}
|
84
|
+
.fl-table td, .fl-table th {
|
85
|
+
padding: 20px .625em .625em .625em;
|
86
|
+
height: 60px;
|
87
|
+
vertical-align: middle;
|
88
|
+
box-sizing: border-box;
|
89
|
+
overflow-x: hidden;
|
90
|
+
overflow-y: auto;
|
91
|
+
width: 120px;
|
92
|
+
font-size: 13px;
|
93
|
+
text-overflow: ellipsis;
|
94
|
+
}
|
95
|
+
.fl-table thead th {
|
96
|
+
text-align: left;
|
97
|
+
border-bottom: 1px solid #f7f7f9;
|
98
|
+
}
|
99
|
+
.fl-table tbody tr {
|
100
|
+
display: table-cell;
|
101
|
+
}
|
102
|
+
.fl-table tbody tr:nth-child(odd) {
|
103
|
+
background: none;
|
104
|
+
}
|
105
|
+
.fl-table tr:nth-child(even) {
|
106
|
+
background: transparent;
|
107
|
+
}
|
108
|
+
.fl-table tr td:nth-child(odd) {
|
109
|
+
background: #F8F8F8;
|
110
|
+
border-right: 1px solid #E6E4E4;
|
111
|
+
}
|
112
|
+
.fl-table tr td:nth-child(even) {
|
113
|
+
border-right: 1px solid #E6E4E4;
|
114
|
+
}
|
115
|
+
.fl-table tbody td {
|
116
|
+
display: block;
|
117
|
+
text-align: center;
|
118
|
+
}
|
119
|
+
}
|
120
|
+
|
121
|
+
.pagination_footer ul {
|
122
|
+
width: fit-content;
|
123
|
+
margin-left: auto;
|
124
|
+
margin-right: 10px;
|
125
|
+
}
|
126
|
+
|
127
|
+
.pagination_footer ul li {
|
128
|
+
margin: 6px;
|
129
|
+
}
|
130
|
+
|
131
|
+
.pagination_header {
|
132
|
+
width: fit-content;
|
133
|
+
margin-left: auto;
|
134
|
+
margin-right: 10px;
|
135
|
+
margin-bottom: 3px;
|
136
|
+
}
|
@@ -0,0 +1 @@
|
|
1
|
+

|
@@ -0,0 +1,141 @@
|
|
1
|
+
getPagination('#table-id');
|
2
|
+
|
3
|
+
function getPagination(table) {
|
4
|
+
var lastPage = 1;
|
5
|
+
|
6
|
+
$('#maxRows')
|
7
|
+
.on('change', function(evt) {
|
8
|
+
//$('.paginationprev').html(''); // reset pagination
|
9
|
+
|
10
|
+
lastPage = 1;
|
11
|
+
$('.pagination')
|
12
|
+
.find('li')
|
13
|
+
.slice(1, -1)
|
14
|
+
.remove();
|
15
|
+
var trnum = 0; // reset tr counter
|
16
|
+
var maxRows = parseInt($(this).val()); // get Max Rows from select option
|
17
|
+
|
18
|
+
if (maxRows >= 5000) {
|
19
|
+
$('.pagination').hide();
|
20
|
+
} else {
|
21
|
+
$('.pagination').show();
|
22
|
+
}
|
23
|
+
|
24
|
+
var totalRows = $(table + ' tbody tr').length; // numbers of rows
|
25
|
+
$(table + ' tr:gt(0)').each(function() {
|
26
|
+
// each TR in table and not the header
|
27
|
+
trnum++; // Start Counter
|
28
|
+
if (trnum > maxRows) {
|
29
|
+
// if tr number gt maxRows
|
30
|
+
|
31
|
+
$(this).hide(); // fade it out
|
32
|
+
}
|
33
|
+
if (trnum <= maxRows) {
|
34
|
+
$(this).show();
|
35
|
+
} // else fade in Important in case if it ..
|
36
|
+
}); // was fade out to fade it in
|
37
|
+
if (totalRows > maxRows) {
|
38
|
+
// if tr total rows gt max rows option
|
39
|
+
var pagenum = Math.ceil(totalRows / maxRows); // ceil total(rows/maxrows) to get ..
|
40
|
+
// numbers of pages
|
41
|
+
for (var i = 1; i <= pagenum; ) {
|
42
|
+
// for each page append pagination li
|
43
|
+
$('.pagination #prev')
|
44
|
+
.before(
|
45
|
+
'<li style=\'cursor: pointer; display: inline-block;\' data-page="' +
|
46
|
+
i +
|
47
|
+
'">\
|
48
|
+
<span>' +
|
49
|
+
i++ +
|
50
|
+
'<span class="sr-only">(current)</span></span>\
|
51
|
+
</li>'
|
52
|
+
)
|
53
|
+
.show();
|
54
|
+
} // end for i
|
55
|
+
} // end if row count > max rows
|
56
|
+
$('.pagination [data-page="1"]').addClass('active'); // add active class to the first li
|
57
|
+
$('.pagination li').on('click', function(evt) {
|
58
|
+
// on click each page
|
59
|
+
evt.stopImmediatePropagation();
|
60
|
+
evt.preventDefault();
|
61
|
+
var pageNum = $(this).attr('data-page'); // get it's number
|
62
|
+
|
63
|
+
var maxRows = parseInt($('#maxRows').val()); // get Max Rows from select option
|
64
|
+
|
65
|
+
if (pageNum == 'prev') {
|
66
|
+
if (lastPage == 1) {
|
67
|
+
return;
|
68
|
+
}
|
69
|
+
pageNum = --lastPage;
|
70
|
+
}
|
71
|
+
if (pageNum == 'next') {
|
72
|
+
if (lastPage == $('.pagination li').length - 2) {
|
73
|
+
return;
|
74
|
+
}
|
75
|
+
pageNum = ++lastPage;
|
76
|
+
}
|
77
|
+
|
78
|
+
lastPage = pageNum;
|
79
|
+
var trIndex = 0; // reset tr counter
|
80
|
+
$('.pagination li').removeClass('active'); // remove active class from all li
|
81
|
+
$('.pagination [data-page="' + lastPage + '"]').addClass('active'); // add active class to the clicked
|
82
|
+
// $(this).addClass('active'); // add active class to the clicked
|
83
|
+
limitPagging();
|
84
|
+
$(table + ' tr:gt(0)').each(function() {
|
85
|
+
// each tr in table not the header
|
86
|
+
trIndex++; // tr index counter
|
87
|
+
// if tr index gt maxRows*pageNum or lt maxRows*pageNum-maxRows fade if out
|
88
|
+
if (
|
89
|
+
trIndex > maxRows * pageNum ||
|
90
|
+
trIndex <= maxRows * pageNum - maxRows
|
91
|
+
) {
|
92
|
+
$(this).hide();
|
93
|
+
} else {
|
94
|
+
$(this).show();
|
95
|
+
} //else fade in
|
96
|
+
}); // end of for each tr in table
|
97
|
+
}); // end of on click pagination list
|
98
|
+
limitPagging();
|
99
|
+
})
|
100
|
+
.val(5)
|
101
|
+
.change();
|
102
|
+
|
103
|
+
// end of on select change
|
104
|
+
|
105
|
+
// END OF PAGINATION
|
106
|
+
}
|
107
|
+
|
108
|
+
function limitPagging(){
|
109
|
+
// alert($('.pagination li').length)
|
110
|
+
|
111
|
+
if($('.pagination li').length > 7 ){
|
112
|
+
if( $('.pagination li.active').attr('data-page') <= 3 ){
|
113
|
+
$('.pagination li:gt(5)').hide();
|
114
|
+
$('.pagination li:lt(5)').show();
|
115
|
+
$('.pagination [data-page="next"]').show();
|
116
|
+
}if ($('.pagination li.active').attr('data-page') > 3){
|
117
|
+
$('.pagination li:gt(0)').hide();
|
118
|
+
$('.pagination [data-page="next"]').show();
|
119
|
+
for( let i = ( parseInt($('.pagination li.active').attr('data-page')) -2 ) ; i <= ( parseInt($('.pagination li.active').attr('data-page')) + 2 ) ; i++ ){
|
120
|
+
$('.pagination [data-page="'+i+'"]').show();
|
121
|
+
|
122
|
+
}
|
123
|
+
|
124
|
+
}
|
125
|
+
}
|
126
|
+
}
|
127
|
+
|
128
|
+
$(function() {
|
129
|
+
// Just to append id number for each row
|
130
|
+
$('#table-id tr:eq(0)').prepend('<th></th>');
|
131
|
+
|
132
|
+
var id = 0;
|
133
|
+
|
134
|
+
$('#table-id tr:gt(0)').each(function() {
|
135
|
+
id++;
|
136
|
+
$(this).prepend('<td>' + id + '</td>');
|
137
|
+
});
|
138
|
+
});
|
139
|
+
|
140
|
+
// Developed By Yasser Mas
|
141
|
+
// yasser.mas2@gmail.com
|
data/lib/html_table.rb
ADDED
@@ -0,0 +1,220 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require 'active_support/all'
|
4
|
+
require 'securerandom'
|
5
|
+
|
6
|
+
##
|
7
|
+
# Manage HTML table
|
8
|
+
#
|
9
|
+
class HtmlTable
|
10
|
+
#
|
11
|
+
# Constants
|
12
|
+
#
|
13
|
+
DEFAULT_COLOR = '#5bc0de'
|
14
|
+
DEFAULT_PAGINATION_OPTIONS = [5, 10, 20, 40].freeze
|
15
|
+
|
16
|
+
#
|
17
|
+
# Virtual attributes
|
18
|
+
#
|
19
|
+
|
20
|
+
attr_accessor :attributes, :base_url, :pagination_options, :primary_color, :resources, :resources_class,
|
21
|
+
:resources_count, :secondary_color, :show_resource_link, :table_id
|
22
|
+
|
23
|
+
##
|
24
|
+
# Initialize class
|
25
|
+
#
|
26
|
+
def initialize(resources_class, resources, attributes, params = {})
|
27
|
+
@attributes = attributes&.to_a
|
28
|
+
@resources = resources&.to_a
|
29
|
+
@resources_class = resources_class
|
30
|
+
@resources_count = resources.size
|
31
|
+
@base_url = params[:base_url]
|
32
|
+
@table_id = params[:table_id] || SecureRandom.hex
|
33
|
+
@show_resource_link = params[:show_resource_link] != false && resources_class.method_defined?('id')
|
34
|
+
@pagination_options = params[:pagination_options] || DEFAULT_PAGINATION_OPTIONS
|
35
|
+
@primary_color = params[:primary_color] || DEFAULT_COLOR
|
36
|
+
@secondary_color = params[:secondary_color] || DEFAULT_COLOR
|
37
|
+
end
|
38
|
+
|
39
|
+
##
|
40
|
+
# Generate HTML table
|
41
|
+
#
|
42
|
+
def generate!
|
43
|
+
return '' if invalid_data
|
44
|
+
|
45
|
+
complete_css + complete_div + complete_js
|
46
|
+
end
|
47
|
+
|
48
|
+
private
|
49
|
+
|
50
|
+
##
|
51
|
+
# Complete table css
|
52
|
+
#
|
53
|
+
def complete_css
|
54
|
+
"<style>#{css_file}</style>"
|
55
|
+
end
|
56
|
+
|
57
|
+
##
|
58
|
+
# Complete table divs
|
59
|
+
#
|
60
|
+
def complete_div
|
61
|
+
"<div class='table-wrapper'>
|
62
|
+
#{pagination_header}
|
63
|
+
<table class='fl-table' id='#{table_id}'>
|
64
|
+
<thead>
|
65
|
+
<tr>#{table_head}</tr>
|
66
|
+
</thead>
|
67
|
+
<tbody>
|
68
|
+
#{table_body}
|
69
|
+
<tbody>
|
70
|
+
</table>
|
71
|
+
</div>
|
72
|
+
#{pagination_footer}"
|
73
|
+
end
|
74
|
+
|
75
|
+
##
|
76
|
+
# Complete table JS
|
77
|
+
#
|
78
|
+
def complete_js
|
79
|
+
"<script>#{js_file}</script>"
|
80
|
+
end
|
81
|
+
|
82
|
+
##
|
83
|
+
# Pagination header
|
84
|
+
#
|
85
|
+
def pagination_header
|
86
|
+
"<div class='pagination_header'>Registros por página:
|
87
|
+
<select name='state' id='#{table_id}maxRows'>
|
88
|
+
<option value='#{resources_count}'>Mostrar Todos</option>
|
89
|
+
#{ pagination_options.map do |pagination_option|
|
90
|
+
"<option value='#{pagination_option}'>#{pagination_option}</option>"
|
91
|
+
end }
|
92
|
+
</select>
|
93
|
+
</div>"
|
94
|
+
end
|
95
|
+
|
96
|
+
##
|
97
|
+
# Pagination Footer
|
98
|
+
#
|
99
|
+
def pagination_footer
|
100
|
+
"<div class='pagination_footer'><nav>
|
101
|
+
<ul class='#{table_id}pagination'>
|
102
|
+
<li style='cursor: pointer; display: inline-block;' data-page='prev'>
|
103
|
+
<span> <b><</b> <span class='sr-only'>(current)</span></span>
|
104
|
+
</li>
|
105
|
+
<li style='cursor: pointer; display: inline-block;' data-page='next' id='prev'>
|
106
|
+
<span> <b>></b> <span class='sr-only'>(current)</span></span>
|
107
|
+
</li>
|
108
|
+
</ul>
|
109
|
+
</nav></div>"
|
110
|
+
end
|
111
|
+
|
112
|
+
##
|
113
|
+
# Table head
|
114
|
+
#
|
115
|
+
def table_head
|
116
|
+
block = String.new
|
117
|
+
attributes.each do |attribute|
|
118
|
+
block << '<th>' << head_cell_value(attribute) << '</th>'
|
119
|
+
end
|
120
|
+
block << "<th id='#{attributes.size.odd? ? 'fl-table-odd' : 'fl-table-even'}'></th>" if show_resource_link
|
121
|
+
block
|
122
|
+
end
|
123
|
+
|
124
|
+
##
|
125
|
+
# Head cell value
|
126
|
+
#
|
127
|
+
def head_cell_value(attribute)
|
128
|
+
return '-' if attribute.blank?
|
129
|
+
|
130
|
+
result = if resources_class.respond_to?('translated_field')
|
131
|
+
resources_class.translated_field(attribute.to_s)
|
132
|
+
else
|
133
|
+
attribute
|
134
|
+
end
|
135
|
+
(result.present? ? result : '-').to_s.titleize
|
136
|
+
end
|
137
|
+
|
138
|
+
##
|
139
|
+
# Table body
|
140
|
+
#
|
141
|
+
def table_body
|
142
|
+
block = String.new
|
143
|
+
resources.each do |resource|
|
144
|
+
block << '<tr>'
|
145
|
+
attributes.each do |attribute|
|
146
|
+
block << '<td>' << body_cell_value(resource, attribute) << '</td>'
|
147
|
+
end
|
148
|
+
block << resource_link(resource) if show_resource_link
|
149
|
+
block << '</tr>'
|
150
|
+
end
|
151
|
+
block
|
152
|
+
end
|
153
|
+
|
154
|
+
##
|
155
|
+
# Body cell value
|
156
|
+
#
|
157
|
+
def body_cell_value(resource, attribute)
|
158
|
+
return '-' if resource.blank? || attribute.blank?
|
159
|
+
|
160
|
+
result = if resource.respond_to?('enum_translation')
|
161
|
+
resource.send('enum_translation', attribute, resource.send(attribute))
|
162
|
+
else
|
163
|
+
resource.send(attribute)
|
164
|
+
end
|
165
|
+
result.present? ? result : '-'
|
166
|
+
end
|
167
|
+
|
168
|
+
##
|
169
|
+
# Generate link to resource
|
170
|
+
#
|
171
|
+
def resource_link(resource, size = 0.4)
|
172
|
+
block = String.new
|
173
|
+
block << "<td width='#{146 * size}px'>"
|
174
|
+
block << "<a href='#{base_url}/admin/#{resource.class.name.underscore}/#{resource.id}' target='_blank'>"
|
175
|
+
block << "<img width='#{73 * size}px' height='#{43 * size}px'
|
176
|
+
src='#{resource_link_icon}'>"
|
177
|
+
block << '</a></td>'
|
178
|
+
block
|
179
|
+
end
|
180
|
+
|
181
|
+
##
|
182
|
+
# Open show icon
|
183
|
+
#
|
184
|
+
def resource_link_icon
|
185
|
+
File.open("#{__dir__}/assets/icons/show.icon").read
|
186
|
+
end
|
187
|
+
|
188
|
+
##
|
189
|
+
# Parsed CSS file
|
190
|
+
#
|
191
|
+
def css_file
|
192
|
+
File.open("#{__dir__}/assets/css/table_template.css")
|
193
|
+
.read
|
194
|
+
.gsub('/*PRIMARY_COLOR*/', "background: #{primary_color};")
|
195
|
+
.gsub('/*SECONDARY_COLOR*/', "background: #{secondary_color};")
|
196
|
+
end
|
197
|
+
|
198
|
+
##
|
199
|
+
# Parsed JS file
|
200
|
+
#
|
201
|
+
def js_file
|
202
|
+
js_file = File.open("#{__dir__}/assets/js/table_template.js").read
|
203
|
+
js_file.gsub('table-id', table_id)
|
204
|
+
.gsub('pagination', "#{table_id}pagination")
|
205
|
+
.gsub('maxRows', "#{table_id}maxRows")
|
206
|
+
.gsub('5000', resources_count.to_s)
|
207
|
+
end
|
208
|
+
|
209
|
+
##
|
210
|
+
# Check if all parameters is valid
|
211
|
+
#
|
212
|
+
def invalid_data
|
213
|
+
if !resources.is_a?(Array) || !attributes.is_a?(Array)
|
214
|
+
true
|
215
|
+
elsif [resources_class, resources, attributes, table_id].any?(&:blank?) || attributes.any?(&:blank?)
|
216
|
+
true
|
217
|
+
end
|
218
|
+
false
|
219
|
+
end
|
220
|
+
end
|
metadata
ADDED
@@ -0,0 +1,60 @@
|
|
1
|
+
--- !ruby/object:Gem::Specification
|
2
|
+
name: ruby-html-table
|
3
|
+
version: !ruby/object:Gem::Version
|
4
|
+
version: 0.0.1
|
5
|
+
platform: ruby
|
6
|
+
authors:
|
7
|
+
- Arthur Ferraz
|
8
|
+
autorequire:
|
9
|
+
bindir: bin
|
10
|
+
cert_chain: []
|
11
|
+
date: 2021-04-06 00:00:00.000000000 Z
|
12
|
+
dependencies:
|
13
|
+
- !ruby/object:Gem::Dependency
|
14
|
+
name: activesupport
|
15
|
+
requirement: !ruby/object:Gem::Requirement
|
16
|
+
requirements:
|
17
|
+
- - ">="
|
18
|
+
- !ruby/object:Gem::Version
|
19
|
+
version: 4.2.6
|
20
|
+
type: :runtime
|
21
|
+
prerelease: false
|
22
|
+
version_requirements: !ruby/object:Gem::Requirement
|
23
|
+
requirements:
|
24
|
+
- - ">="
|
25
|
+
- !ruby/object:Gem::Version
|
26
|
+
version: 4.2.6
|
27
|
+
description: A simple gem to generate a HTML table based on object array
|
28
|
+
email: guidance.team.dev@gmail.com
|
29
|
+
executables: []
|
30
|
+
extensions: []
|
31
|
+
extra_rdoc_files: []
|
32
|
+
files:
|
33
|
+
- lib/assets/css/table_template.css
|
34
|
+
- lib/assets/icons/show.icon
|
35
|
+
- lib/assets/js/table_template.js
|
36
|
+
- lib/html_table.rb
|
37
|
+
homepage: ''
|
38
|
+
licenses:
|
39
|
+
- MIT
|
40
|
+
metadata: {}
|
41
|
+
post_install_message:
|
42
|
+
rdoc_options: []
|
43
|
+
require_paths:
|
44
|
+
- lib
|
45
|
+
required_ruby_version: !ruby/object:Gem::Requirement
|
46
|
+
requirements:
|
47
|
+
- - ">="
|
48
|
+
- !ruby/object:Gem::Version
|
49
|
+
version: '2.6'
|
50
|
+
required_rubygems_version: !ruby/object:Gem::Requirement
|
51
|
+
requirements:
|
52
|
+
- - ">="
|
53
|
+
- !ruby/object:Gem::Version
|
54
|
+
version: '0'
|
55
|
+
requirements: []
|
56
|
+
rubygems_version: 3.1.4
|
57
|
+
signing_key:
|
58
|
+
specification_version: 4
|
59
|
+
summary: HTML Table
|
60
|
+
test_files: []
|