X-Git-Url: http://git.shiar.nl/sheet.git/blobdiff_plain/2ae4ccbb6ac3ce310890beef55fda11f670772bb..fe2afa53dfb9a89386d31bd3fd80f4bfdfa16030:/browser.plp
diff --git a/browser.plp b/browser.plp
index 3f7b6f8..a4af534 100644
--- a/browser.plp
+++ b/browser.plp
@@ -20,6 +20,7 @@ Html({
with Wikimedia
browser usage statistics.
+
<:
my $caniuse = do 'browser-support.inc.pl' or die $! || $@;
@@ -42,17 +43,31 @@ my %CSTATUS = (
rec => 'l6', # recommendation
ietf => 'l6', # standard
);
-my @browsers = qw(trident gecko webkit_saf webkit_chr presto);
my %versions;
if (my ($somerow) = values %{ $caniuse->{data} }) {
while (my ($browser, $row) = each %{ $somerow->{stats} }) {
$versions{$browser} = [ sort { paddedver($a) cmp paddedver($b) } keys %$row ];
}
}
+my @browsers = grep { $versions{$_} }
+ qw(trident gecko webkit_saf ios_saf webkit_chr android presto op_mob op_mini);
-my $canihas = do 'browser-usage.inc.pl' or do {
+my $canihas = do 'browser-usage.inc.pl' || do {
printf "
Browser usage data not found: %s.
\n", $_
for $! || $@;
+ +{
+ map {
+ $_ => +{
+ map {
+ ($_->[4] => 0 ), # future
+ ($_->[3] => .5), # next
+ ($_->[0] => 5 ), # past
+ ($_->[1] => 10 ), # previous
+ ($_->[2] => 30 ), # current
+ } $caniuse->{agents}->{$_}->{versions}
+ }
+ } @browsers
+ }; # fallback hash based on release semantics
};
my $scorediv = (max(map { sum(values %$_) } values %$canihas) // 1) / 100;
@@ -95,6 +110,7 @@ sub featurescore {
if (my $row = shift) {
if ($canihas) {
while (my ($browser, $versions) = each %$row) {
+ ref $versions eq 'HASH' or next;
while (my ($version, $_) = each %$versions) {
$rank += $canihas->{$browser}->{$version} * $statspts->{$_};
}
@@ -131,7 +147,22 @@ for my $id (sort {
my $cell = $_ ? lc $_->[0] : '-';
print '
', $cell;
}
- printf ' | %s', $row->{description}, $row->{title};
+ print ' | ', map {
+ sprintf('%s',
+ "#$id",
+ sprintf("try { %s; return false } catch(err) { return true }",
+ "document.getElementById('$id').classList.toggle('target')",
+ ),
+ $_,
+ );
+ } $row->{title};
+ print '';
+ s/\.?$/./, print " $_ " for map { ref $_ ? @$_ : $_ || () }
+ $row->{description}, $row->{notes};
+ printf 'Resources: %s.', join(', ',
+ map { qq( $_->{title}) } @$_
+ ) for grep { @$_ } $row->{links} // ();
+ print ' ';
for ($row->{status}) {
my $cell = $_ // '-';
$cell = sprintf '%s', $_, $cell for $row->{spec} // ();
@@ -142,11 +173,15 @@ for my $id (sort {
my ($prev, @span);
for my $ver (@{ $versions{$browser} }, undef) {
unless (!defined $prev
- or $data->{$browser}->{$prev} ~~ $data->{$browser}->{$ver}) {
+ or ref $data->{$browser} eq 'HASH'
+ && $data->{$browser}->{$prev} ~~ $data->{$browser}->{$ver}) {
my $usage = sum(map { $canihas->{$browser}->{$_} } @span);
printf ' | %s',
join(' ',
- X => $CSTATS{ $data->{$browser}->{$prev} },
+ X => $CSTATS{
+ ref $data->{$browser} ne 'HASH' ? 'u' :
+ $data->{$browser}->{$prev} // 'u'
+ },
!$usage ? ('p0') : ('p',
sprintf('p%01d', $usage / 10),
sprintf('p%02d', $usage),
@@ -174,7 +209,7 @@ print '';
sub paddedver {
# normalised version number comparable as string (cmp)
shift =~ /^(\d*)(.*)/;
- return sprintf('%02d', $1) . $2;
+ return sprintf('%02d', $1 || 0) . $2;
}
sub showversions {
@@ -186,7 +221,8 @@ sub showversions {
return join('â', @span);
}
-:>
+:>
+
@@ -196,6 +232,7 @@ sub showversions {
partial
| external (js/plugin)
| missing
+ | unknown
| |