-li, ul ul {
- display: contents;
- height: 100%;
-}
-figure {
- flex: 200px;
- flex-grow: 1;
- max-width: 300px;
- overflow: hidden;
- padding: 1px;
-}
-figcaption > small {
- display: inline-block;
-}
-
-figure:hover ~ ul figure,
-figure:hover ~ ul figcaption {
- background: #CCC;
- color: #000;
-}
-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%;
- right: 50%;
- bottom: 50%;
- transform: translate(50%, 50%);
- margin-left: -60%; /* keep width */
-}
-</style>
-EOT
-});
-
-:>
-<h1>Words</h1>
-
-<p>
-Under construction.
-Zie ook <a href="/dieren">dieren</a>.
-</p>
-
-<:
-my $table = do $wordlist or die $@ // $!;
-
-sub showimg {
- my ($name) = @_;
- my ($img) = $name =~ /^([\w -]+)/;
- $name =~ s/\w{4} [^aoeuiyc\W] [rl]?+ \K (?= [^aoeuiy\W] [rl]? [aoeuiy] \w)/­/gx;
- $name =~ s{/(.*)}{ <small>($1)</small>}g;
- my $hidden = $name =~ s/\?$//;
- my $alt = $name;
- $name = "<q>$name</q>" if $name =~ s/\?$//;
-
- if ($img and -e ($img = "data/word/eng/$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>";
- }
- return sprintf '<figure%s>%s</figure>', $hidden && !exists $get{v} && ' hidden', $name;
-}
-
-sub printimgs {
- say '<ul>';
- for my $row (@_) {
- printf '<li%s>', defined $table->{$row} && ' class="parent"';
- print showimg($row);
- printimgs(@{$_}) for $table->{$row} // ();
- print '</li>';
- }
- say '</ul>';
-}
-
-printimgs(@{$table->{''}});