keyboard/altgr/unigraph: diagonals and dots in rightmost columns
[sheet.git] / keyboard / altgr / index.inc.plp
index 0bb7774112193b414cab1a65531cf966ccc66a9b..172d93105074b8d7528fff8a95346c6c9281ee7a 100644 (file)
@@ -1,6 +1,7 @@
 <: # included from keyboard.plp
 use 5.014;
 use warnings;
+use utf8;
 
 my @incs = glob 'keyboard/altgr/*.eng.inc.pl';
 
@@ -31,6 +32,14 @@ Html({
 .keys.big.cmp tbody {
        font-size: 150%;
 }
+@media (max-width: 48em) {
+       .keys.big.cmp tbody {
+               font-size: 100%;
+       }
+       .keys.big.cmp tbody a {
+               white-space: normal;
+       }
+}
 .keys.cmp tbody {
        display: table-row-group;
 }
@@ -46,6 +55,18 @@ Html({
        text-align: right;
 }
 
+@font-face {
+       font-family: osicons;
+       src: url(/osicon.ttf);
+}
+.icon {
+       font-family: osicons;
+}
+.keys.cmp tbody .ni {
+       font-size: 80%;
+       padding: 0 .2em;
+}
+
 .graph {
        display: block;
        line-height: 1ex;
@@ -96,10 +117,17 @@ my @sample = split /(?<!\+)/, $get{sample} // 'asSci1!+1';
 require Shiar_Sheet::Keyboard;
 use List::Util qw( uniq max );
 
+my %caticon = (
+       legacy  => qq{<span class=icon title="deprecated">\N{TOP HAT}</span>},
+       windows => qq{<span class=icon title="Windows">\x{1FA9F}</span>}, # \N{WINDOW}
+       macos   => qq{<span class=icon title="MacOS">\N{RED APPLE}</span>},
+       xorg    => qq{<span class=icon title="Xorg">\N{PENGUIN}</span>},
+);
+
 printf '<section class="%s">', @sample ? 'section' : 'gallery';
 if (@sample) {
        print '<table class="big keys cmp">';
-       print '<thead><tr><th>';
+       print '<thead><tr><th colspan=2>';
        print "<th>$_" for @sample;
        say '</tr></thead>';
 }
@@ -127,7 +155,8 @@ for my $inc (sort {
                my $keys = Shiar_Sheet::Keyboard->new($table);
                for my $mode ($keys->{mode} ? sort keys %{ $keys->{mode} } : '') {
                        my %inventory;
-                       $inventory{ s/ (?!ext).*//r }++ for values %{ $keys->{def}{$mode} };
+                       $inventory{$_}++ for grep { /^g[2-9]/ } map { s/ (?!ext).*//r }
+                               values %{ $keys->{def}{$mode} };
                        print '<span class=graph>';
                        print "<label>$_</label>" for $keys->{key}{$mode} =~ s/\s.*//r || ();
                        for my $g (sort keys %inventory) {
@@ -140,7 +169,11 @@ for my $inc (sort {
                        }
                        say '</span>';
                }
-               $keys->print_key('', $_, $keys->{def}{''}{$_} // 'ni') for @sample;
+               print "\t<td class=ni>";
+               print join ' ', map { $caticon{$_} // () } split m{/}, $keys->{category};
+               say '';
+               $keys->print_key('', $_, ($keys->{def}{''}{$_} // 'ni') =~ s/ mode\S*//r)
+                       for @sample;
                say '</tr>';
        }
 }