X-Git-Url: http://git.shiar.net/sheet.git/blobdiff_plain/8b05556284ebbd6f2af9c9168b3ff3f3c69615d2..ebbfbfbb295d4268eba729b0cee0b85679a04e3f:/word.plp
diff --git a/word.plp b/word.plp
index 050ad90..5571299 100644
--- a/word.plp
+++ b/word.plp
@@ -1,17 +1,41 @@
<(common.inc.plp)><:
-my $wordlist = "data/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 $name = $1;
+ my $page = "word/$name.plp";
+ if (-e $page) {
+ utf8::downgrade($page); # unicode filename breaks contents encoding
+ Include $page;
+ }
+ else {
+ Html({
+ raw => join("\n", map qq(),
+ 'put.min.js', 'quiz.js', "$name.js",
+ ),
+ lang => $lang,
+ });
+ say '
Words
';
+ say '';
+ say "";
+ }
+ exit;
+}
+
+my $limit = $get{v} // (exists $get{v} ? 5 : 3);
Html({
title => 'words cheat sheet',
version => '1.0',
+ lang => $lang,
description => "Visual words",
keywords => [qw'
language
'],
- data => [$wordlist],
- raw => (exists $get{q} && <<'EOT')
+ data => ["$wordlistbase.inc.pl"],
+ raw => exists $get{q} ? <<'EOT' : undef,
-EOT
- . <<'EOT',
-
EOT
});
@@ -56,12 +73,11 @@ Zie ook dieren.
<:
-my $table = do $wordlist or die $@ // $!;
+my $table = Data($wordlistbase);
sub showimg {
my ($id, $name) = @_;
my ($imgname) = $name =~ m{^([^/]+)};
- $name =~ s/\w{4} [^aoeuiyc\W] [rl]?+ \K (?= [^aoeuiy\W] [rl]? [aoeuiy] \w)//gx;
($name, my @morenames) = split m{/}, $name;
$name =~ s{\( ([^/]+) \)}{$1}x;
$name .= " ($_)" for @morenames;
@@ -69,7 +85,7 @@ sub showimg {
$name = "$name
" if $name =~ s/\?$//;
$name = "$name";
- if ($id and -e (my $img = "data/word/en/$id.jpg")) {
+ if ($id and -e (my $img = "data/word/32/$id.jpg")) {
$name .= sprintf '', $img, $imgname;
}
return sprintf '', $hidden && !exists $get{v} && ' hidden', $name;
@@ -78,7 +94,8 @@ sub showimg {
sub printimgs {
say '';
for my $row (@_) {
- my ($id, $level, $title) = split /:/, $row, 3;
+ my ($id, $level, $title) = @{$row};
+ $id or die "empty reference"; # assertion to prevent loops
my @type;
push @type, 'parent' if defined $table->{$id};
push @type, 'large' if $level =~ s/c$//;
@@ -97,8 +114,8 @@ if (exists $get{q}) {
if ($Request) {
my @query = $Request;
while (@query) {
- push @rows, grep { (split /:/)[1] <= $limit } @query;
- s/:.*// for @query;
+ push @rows, grep { $_->[1] <= $limit } @query;
+ $_ = $_->[0] for @query;
@query = map {$_ ? @{$_} : ()} @{$table}{@query};
}
}
@@ -109,7 +126,10 @@ if (exists $get{q}) {
$table = {};
printimgs(@rows);
}
+elsif ($Request and $Request =~ /^\d+$/) {
+ printimgs([$Request]);
+}
else {
- printimgs($Request || $table->{''}->[0]);
+ printimgs($table->{''}->[0]);
}
say '';