latin: palm graffiti font placeholder
[sheet.git] / word.plp
index 508fd06731147627776c01a344c01f69f296ea45..41d2bd330aa80a5d78b2a81c3a9e08284900ffdd 100644 (file)
--- a/word.plp
+++ b/word.plp
@@ -1,6 +1,18 @@
 <(common.inc.plp)><:
 
-my $wordlist = 'wordlist.en.inc.pl';
+our $lang = $get{lang} || 'en';
+our $wordlistbase = "data/wordlist.$lang";
+
+if ($Request and $Request =~ m{\A([^/]+)}) {
+       my $page = "word/$1.plp";
+       utf8::downgrade($page); # unicode filename breaks contents encoding
+       if (-e $page) {
+               Include $page;
+               exit;
+       }
+}
+
+my $wordlist = "$wordlistbase.inc.pl";
 my $limit = $get{v} // (exists $get{v} ? 4 : 3);
 
 Html({
@@ -11,54 +23,31 @@ Html({
                language
        '],
        data => [$wordlist],
-       raw => <<'EOT',
+       raw => (exists $get{q} && <<'EOT')
 <style>
-ul {
-       display: grid;
-       grid: auto-flow dense / repeat(auto-fit, minmax(200px, 1fr));
-       grid-gap: 1px;
-}
-li, ul ul {
-       display: contents;
-}
-figure {
-       overflow: hidden;
-       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;
-       color: #000;
+.gallery figure {
+       grid-row: span 1 !important;
+       grid-column: span 1 !important;
 }
-figure:hover ~ ul figcaption {
-       background: rgba(255, 255, 255, .5);
-}
-
-figure, figcaption {
-       transition: all .5s ease-in;
-}
-li.parent:hover > figure > figcaption,
-figure:hover > figcaption {
-       font-size: 175%;
+.gallery figcaption {
+       /* keep hover position */
        right: 50%;
        bottom: 50%;
        transform: translate(50%, 50%);
-       margin-left: -60%; /* keep width */
+       /* hide */
+       visibility: hidden;
+       font-size: 0 !important;
+}
+.gallery figure:active > figcaption {
+       visibility: visible;
+       font-size: 175% !important;
+}
+</style>
+EOT
+               . <<'EOT',
+<style>
+body {
+       margin: 8px 1px;
 }
 </style>
 EOT
@@ -75,22 +64,24 @@ if (exists $get{debug}) {
 <p>
 Under construction.
 Zie ook <a href="/dieren">dieren</a>.
+<a href="?q">Omit translations</a> to test.
 </p>
 
 <:
 my $table = do $wordlist or die $@ // $!;
 
 sub showimg {
-       my ($name) = @_;
-       my ($imgname) = $name =~ /^([\w -]+)/;
+       my ($id, $name) = @_;
+       my ($imgname) = $name =~ m{^([^/]+)};
        $name =~ s/\w{4} [^aoeuiyc\W] [rl]?+ \K (?= [^aoeuiy\W] [rl]? [aoeuiy] \w)/&shy;/gx;
-       $name =~ s{/(.*)}{ <small>($1)</small>}g;
+       ($name, my @morenames) = split m{/}, $name;
+       $name =~ s{\( ([^/]+) \)}{<small>$1</small>}x;
+       $name .= " <small>($_)</small>" for @morenames;
        my $hidden = $name =~ s/\?$//;
-       my $alt = $name;
        $name = "<q>$name</q>" if $name =~ s/\?$//;
        $name = "<figcaption>$name</figcaption>";
 
-       if ($imgname and -e ($img = "data/word/en/$imgname.jpg")) {
+       if ($id and -e (my $img = "data/word/en/$id.jpg")) {
                $name .= sprintf '<img src="/%s" alt="%s" />', $img, $imgname;
        }
        return sprintf '<figure%s>%s</figure>', $hidden && !exists $get{v} && ' hidden', $name;
@@ -99,17 +90,39 @@ sub showimg {
 sub printimgs {
        say '<ul>';
        for my $row (@_) {
-               my ($level, $mark, $title) = split /([a-z]*):/, $row, 2;
+               my ($id, $level, $title) = split /:/, $row, 3;
+               $id or die "empty reference"; # assertion to prevent loops
                my @type;
-               push @type, 'parent' if defined $table->{$row};
-               push @type, 'large'  if $mark;
+               push @type, 'parent' if defined $table->{$id};
+               push @type, 'large'  if $level =~ s/c$//;
                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 showimg($id, $title) if $level <= $limit;
+               printimgs(@{$_}) for $table->{$id} // ();
                print '</li>';
        }
        say '</ul>';
 }
 
-printimgs(@{$table->{''}});
+say '<section class="gallery">';
+if (exists $get{q}) {
+       my @rows;
+       if ($Request) {
+               my @query = $Request;
+               while (@query) {
+                       push @rows, grep { (split /:/)[1] <= $limit } @query;
+                       s/:.*// for @query;
+                       @query = map {$_ ? @{$_} : ()} @{$table}{@query};
+               }
+       }
+       else {
+               @rows = map {ref ? @$_ : $_} values %{$table}; # flatten categories
+       }
+       @rows = sort { rand <=> .5 } @rows;
+       $table = {};
+       printimgs(@rows);
+}
+else {
+       printimgs($Request || $table->{''}->[0]);
+}
+say '</section>';