word: debugging stylesheet to colourise levels
[sheet.git] / word.plp
index d594370e2d09728ec6b9dab79c97527a811d2ddf..5739731d6e8eed613b39c38439e1b8cb8e2f2142 100644 (file)
--- a/word.plp
+++ b/word.plp
@@ -1,6 +1,8 @@
 <(common.inc.plp)><:
 
-my $wordlist = 'wordlist.inc.pl';
+my $wordlist = 'wordlist.eng.inc.pl';
+my $limit = $get{v} // (exists $get{v} ? 4 : 3);
+
 Html({
        title => 'words cheat sheet',
        version => '1.0',
@@ -12,26 +14,32 @@ Html({
        raw => <<'EOT',
 <style>
 ul {
-       display: flex;
-       flex-wrap: wrap;
-       align-items: end;
-       margin: -1px;
+       display: grid;
+       grid: auto-flow dense / repeat(auto-fit, minmax(200px, 1fr));
+       grid-gap: 1px;
 }
 li, ul ul {
        display: contents;
-       height: 100%;
 }
 figure {
-       flex: 200px;
-       flex-grow: 1;
-       max-width: 300px;
        overflow: hidden;
-       padding: 1px;
+       box-sizing: border-box;
 }
 figcaption > small {
        display: inline-block;
 }
 
+li.large > figure {
+       grid-row: span 2;
+       grid-column: span 2;
+}
+@media (min-width: 600px) and (min-height: 400px) {
+       p + ul > li:first-child > figure {
+               grid-row: span 3;
+               grid-column: span 3;
+       }
+}
+
 figure:hover ~ ul figure,
 figure:hover ~ ul figcaption {
        background: #CCC;
@@ -56,6 +64,11 @@ figure:hover > figcaption {
 EOT
 });
 
+if (exists $get{debug}) {
+       say '<style>';
+       include 'word-debug.css';
+       say '</style>';
+}
 :>
 <h1>Words</h1>
 
@@ -65,30 +78,20 @@ Zie ook <a href="/dieren">dieren</a>.
 </p>
 
 <:
-my %table = do 'wordlist.inc.pl' or die $@ // $!;
+my $table = do $wordlist or die $@ // $!;
 
 sub showimg {
        my ($name) = @_;
-       my ($img) = $name =~ /^([\w -]+)/;
+       my ($imgname) = $name =~ /^([\w -]+)/;
        $name =~ s/\w{4} [^aoeuiyc\W] [rl]?+ \K (?= [^aoeuiy\W] [rl]? [aoeuiy] \w)/&shy;/gx;
        $name =~ s{/(.*)}{ <small>($1)</small>}g;
        my $hidden = $name =~ s/\?$//;
        my $alt = $name;
        $name = "<q>$name</q>" if $name =~ s/\?$//;
+       $name = "<figcaption>$name</figcaption>";
 
-       if ($img and -e ($img = "data/word/$img.jpg")) {
-               my $alt = -l $img && readlink($img) =~ s/\.jpg$//r;
-               if ($alt) {
-                       $name .= " ($alt)";
-               }
-               else {
-                       $alt = $name;
-               }
-               $name = "<figcaption>$name</figcaption>";
-               $name .= sprintf '<img src="/%s" alt="%s" />', $img, $alt;
-       }
-       elsif ($hidden) {
-               $name = "<figcaption>$name?</figcaption>";
+       if ($imgname and -e ($img = "data/word/eng/$imgname.jpg")) {
+               $name .= sprintf '<img src="/%s" alt="%s" />', $img, $imgname;
        }
        return sprintf '<figure%s>%s</figure>', $hidden && !exists $get{v} && ' hidden', $name;
 }
@@ -96,8 +99,13 @@ sub showimg {
 sub printimgs {
        say '<ul>';
        for my $row (@_) {
-               printf '<li%s>', defined $table->{$row} && ' class="parent"';
-               print showimg($row);
+               my ($level, $mark, $title) = split /([a-z]*):/, $row, 2;
+               my @type;
+               push @type, 'parent' if defined $table->{$row};
+               push @type, 'large'  if $mark;
+               push @type, 'level'.($level || 0);
+               printf '<li%s>', @type ? sprintf ' class="%s"', join ' ', @type : '';
+               print showimg($title) if $level <= $limit;
                printimgs(@{$_}) for $table->{$row} // ();
                print '</li>';
        }