'<th colspan="3">feature',
(map {
my $name = $caniuse->{agents}->{$_}->{browser};
- sprintf('<th colspan="%d" title="%s">%s',
+ sprintf('<th colspan="%d" class="%s" title="%s">%s',
scalar @{ $versions{$_} },
+ join(' ', map {"b-a-$_"} grep {$_}
+ $_, $caniuse->{agents}->{$_}->{prefix},
+ ),
join(' ',
sprintf('%.1f%%', sum(values %{ $canihas->{$_} })),
$name,
}
}
+function filtercols(table, match, action) {
+ var matchloc;
+ for (var y = 0; y < table.rows.length; y++) {
+ var loc = 0;
+ for (var x = 0; x < table.rows[y].cells.length; x++) {
+ var cell = table.rows[y].cells[x];
+ if (y == 0) {
+ if (match(cell)) {
+ if (!matchloc) matchloc = [loc];
+ matchloc[1] = loc + cell.colSpan;
+ filtercell(table.children.item(x+2), true, action); // colgroup
+ }
+ }
+ var keep = matchloc && loc >= matchloc[0] && loc < matchloc[1];
+ filtercell(cell, keep, action);
+ loc += cell.colSpan;
+ }
+ }
+}
+
function filterrows(table, match, action) {
var rows = table.tBodies[0].rows;
for (var i = 0; i < rows.length; i++) {
query = match[2];
}
+ if (document.querySelector('.b-a-'+query)) {
+ // column if class b-a-* exists
+ var match = function(th) {
+ return new RegExp('-'+query+'\\b').test(th.className);
+ }
+ return filtercols(table, match, action || 'toggle');
+ }
+
if (/^[A-Z0-9 ]{2,}$/.test(query)) {
// category title if all uppercase
var match = function(row) {