<(common.inc.plp)><:
-my $wordlist = 'wordlist.en.inc.pl';
+if ($Request and $Request =~ s{^edit/?}{}) {
+ Include 'writer.plp';
+ exit;
+}
+
+if ($Request and $Request =~ s{^quiz/?}{}) {
+ Html({
+ raw => <<'EOT',
+<script src="/wordquiz.js"></script>
+<style>
+.wrong {background: red}
+.good {background: green}
+</style>
+EOT
+ });
+ say '<h1>quiz</h1><p id="quiz">test</p>';
+ exit;
+}
+
+my $lang = $get{lang} || 'en';
+my $wordlist = "data/wordlist.$lang.inc.pl";
my $limit = $get{v} // (exists $get{v} ? 4 : 3);
Html({
language
'],
data => [$wordlist],
- raw => <<'EOT',
+ raw => (exists $get{q} && <<'EOT')
+<style>
+.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
+ . <<'EOT',
<style>
body {
margin: 8px 1px;
<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)/­/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/en/$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) = split /:/, $row, 3;
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 { (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>';