X-Git-Url: http://git.shiar.nl/sheet.git/blobdiff_plain/52115de0b42272dd62f54f234590ae5b4d086565..2f52ab48dabb037b6ef93468a8ba2db6bc9c9428:/browser.plp diff --git a/browser.plp b/browser.plp index 151daeb..5afabaf 100644 --- a/browser.plp +++ b/browser.plp @@ -1,5 +1,6 @@ <(common.inc.plp)><: use 5.010; +use List::Util qw(sum max); Html({ title => 'browser compatibility cheat sheet', @@ -14,7 +15,9 @@ Html({ :>

Browser compatibility

-

Alternate view of Fyrd's when can I use... site.

+

Alternate view of Fyrd's when can I use... page +with Wikimedia +browser usage statistics.

<: use JSON; @@ -44,9 +47,11 @@ my $caniuse = from_json($source, { my %CSTATS = ( n => 'di-b', y => 'di-aa', - a => 'di-d', - j => 'di-prop', - p => 'di-prop', + a => 'di-d', + 'a x' => 'di-d', + j => 'di-prop', + p => 'di-prop', + 'p j' => 'di-prop', 'y x' => 'di-a', ); my %CSTATUS = ( @@ -65,6 +70,12 @@ if (my ($somerow) = values %{ $caniuse->{data} }) { } } +my $canihas = do 'browser-usage.inc.pl' or do { + printf "

Browser usage data not found: %s.

\n", $_ + for $! || $@; +}; +my $scorediv = (max(map { sum(values %$_) } values %$canihas) // 1) / 100; + print ''; print '' x 3; printf '', scalar @{ $versions{$_} } for @browsers; @@ -75,6 +86,7 @@ print ''; print '
feature'; printf '%s', scalar @{ $versions{$_} }, $caniuse->{agents}->{$_}->{browser} for @browsers; +print '%'; # preceding row without any colspan to work around gecko bug print '
' x $_ for 3, (map { scalar @{ $versions{$_} } } @browsers), 1; @@ -82,9 +94,18 @@ print "\n"; sub featurescore { # relative amount of support for given feature - state $statspts = { y=>10, 'y x'=>9, a=>5, j=>2, p=>1 }; + state $statspts = { y=>10, 'y x'=>9, a=>5, 'a x'=>5, j=>2, 'p j'=>2, p=>1 }; my $rank = 0; if (my $row = shift) { + if ($canihas) { + while (my ($browser, $versions) = each %$row) { + while (my ($version, $_) = each %$versions) { + $rank += $canihas->{$browser}->{$version} * $statspts->{$_}; + } + } + return $rank; + } + while (my ($browser, $vercols) = each %versions) { my $div = 0; # multiplier exponent (decreased to lower value) my @vers = map { $row->{$browser}->{$_} } @$vercols; @@ -126,10 +147,15 @@ for my $id (sort { for my $ver (@{ $versions{$browser} }, undef) { unless (!defined $prev or $data->{$browser}->{$prev} ~~ $data->{$browser}->{$ver}) { - printf '%s', - $CSTATS{ $data->{$browser}->{$prev} }, + my $usage = sum(map { $canihas->{$browser}->{$_} } @span); + printf '%s', + join(' ', + $CSTATS{ $data->{$browser}->{$prev} }, + sprintf('opacity%.0f', $usage / $scorediv), + ), scalar @span, - join('‒', $span[0], @span > 1 ? $span[-1] : ()); + $usage, + showversions(\@span), undef $prev; @span = (); } @@ -150,6 +176,16 @@ sub paddedver { return sprintf('%02d', $1) . $2; } +sub showversions { + my ($span) = @_; + splice @$span, 1, -1; + for (@$span) { + s/^\./0./; + s/x$/.*/; + } + return join('‒', @$span); +} + :>