<(common.inc.plp)><:
-my $wordlist = 'wordlist.en.inc.pl';
-my $limit = $get{v} // (exists $get{v} ? 4 : 3);
+our $lang = $get{lang} || 'en';
+our $wordlistbase = "data/wordlist";
+
+if ($Request and $Request =~ m{\A([^/]+)}) {
+ my $page = "word/$1.plp";
+ utf8::downgrade($page); # unicode filename breaks contents encoding
+ if (-e $page) {
+ $wordlistbase .= ".$lang";
+ Include $page;
+ exit;
+ }
+}
+
+my $limit = $get{v} // (exists $get{v} ? 5 : 3);
Html({
title => 'words cheat sheet',
keywords => [qw'
language
'],
- data => [$wordlist],
- raw => <<'EOT',
+ data => ["$wordlistbase.inc.pl"],
+ raw => exists $get{q} ? <<'EOT' : undef,
<style>
-body {
- margin: 8px 1px;
+.gallery figure {
+ grid-row: span 1 !important;
+ grid-column: span 1 !important;
+}
+.gallery figcaption {
+ /* keep hover position */
+ right: 50%;
+ bottom: 50%;
+ transform: translate(50%, 50%);
+ /* hide */
+ visibility: hidden;
+ font-size: 0 !important;
+}
+.gallery figure:active > figcaption {
+ visibility: visible;
+ font-size: 175% !important;
}
</style>
EOT
<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 $@ // $!;
+my $table = Data($wordlistbase);
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)/­/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 (my $img = "data/word/en/$imgname.jpg")) {
+ if ($id and -e (my $img = "data/word/32/$id.jpg")) {
$name .= sprintf '<img src="/%s" alt="%s" />', $img, $imgname;
}
return sprintf '<figure%s>%s</figure>', $hidden && !exists $get{v} && ' hidden', $name;
sub printimgs {
say '<ul>';
for my $row (@_) {
- my ($level, $mark, $title) = split /([a-z]*):/, $row, 2;
+ my ($id, $level, $title) = @{$row};
+ $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>';
}
say '<section class="gallery">';
-printimgs(@{$table->{''}});
+if (exists $get{q}) {
+ my @rows;
+ if ($Request) {
+ my @query = $Request;
+ while (@query) {
+ push @rows, grep { $_->[1] <= $limit } @query;
+ $_ = $_->[0] for @query;
+ @query = map {$_ ? @{$_} : ()} @{$table}{@query};
+ }
+ }
+ else {
+ @rows = map {ref ? @$_ : $_} values %{$table}; # flatten categories
+ }
+ @rows = sort { rand <=> .5 } @rows;
+ $table = {};
+ printimgs(@rows);
+}
+elsif ($Request and $Request =~ /^\d+$/) {
+ printimgs([$Request]);
+}
+else {
+ printimgs($table->{''}->[0]);
+}
say '</section>';