word/quiz: automatic subpage setup including specific css
[sheet.git] / word.plp
1 <(common.inc.plp)><:
2
3 our $lang = $get{lang} || 'en';
4 our $wordlistbase = "data/wordlist";
5
6 if ($Request and $Request =~ m{\A([^/]+)}) {
7         my $name = $1;
8         my $page = "word/$name.plp";
9         if (-e $page) {
10                 utf8::downgrade($page); # unicode filename breaks contents encoding
11                 Include $page;
12         }
13         else {
14                 Html({
15                         raw => join("\n",
16                                 (map {qq(<script src="/word/$_"></script>)}
17                                         'put.min.js', 'quiz.js', "$name.js",
18                                 ),
19                                 (map {qq(<link rel="stylesheet" type="text/css" href="/$_">)}
20                                         grep {-e} "word/$name.css"
21                                 ),
22                         ),
23                         lang => $lang,
24                 });
25                 say '<h1>Words</h1>';
26                 say '<section id="quiz"></section>';
27                 say "<script>new Word\u$name()</script>";
28         }
29         exit;
30 }
31
32 my $limit = $get{v} // (exists $get{v} ? 5 : 3);
33
34 Html({
35         title => 'words cheat sheet',
36         version => '1.0',
37         lang => $lang,
38         description => "Visual words",
39         keywords => [qw'
40                 language
41         '],
42         data => ["$wordlistbase.inc.pl"],
43         raw => exists $get{q} ? <<'EOT' : undef,
44 <style>
45 .gallery figure {
46         grid-row: span 1 !important;
47         grid-column: span 1 !important;
48 }
49 .gallery figcaption {
50         /* keep hover position */
51         right: 50%;
52         bottom: 50%;
53         transform: translate(50%, 50%);
54         /* hide */
55         visibility: hidden;
56         font-size: 0 !important;
57 }
58 .gallery figure:active > figcaption {
59         visibility: visible;
60         font-size: 175% !important;
61 }
62 </style>
63 EOT
64 });
65
66 if (exists $get{debug}) {
67         say '<style>';
68         include 'word-debug.css';
69         say '</style>';
70 }
71 :>
72 <h1>Words</h1>
73
74 <p>
75 Under construction.
76 Zie ook <a href="/dieren">dieren</a>.
77 <a href="?q">Omit translations</a> to test.
78 </p>
79
80 <:
81 my $table = Data($wordlistbase);
82
83 sub showimg {
84         my ($id, $name) = @_;
85         my ($imgname) = $name =~ m{^([^/]+)};
86         ($name, my @morenames) = split m{/}, $name;
87         $name =~ s{\( ([^/]+) \)}{<small>$1</small>}x;
88         $name .= " <small>($_)</small>" for @morenames;
89         my $hidden = $name =~ s/\?$//;
90         $name = "<q>$name</q>" if $name =~ s/\?$//;
91         $name = "<figcaption>$name</figcaption>";
92
93         if ($id and -e (my $img = "data/word/32/$id.jpg")) {
94                 $name .= sprintf '<img src="/%s" alt="%s" />', $img, $imgname;
95         }
96         return sprintf '<figure%s>%s</figure>', $hidden && !exists $get{v} && ' hidden', $name;
97 }
98
99 sub printimgs {
100         say '<ul>';
101         for my $row (@_) {
102                 my ($id, $level, $title) = @{$row};
103                 $id or die "empty reference"; # assertion to prevent loops
104                 my @type;
105                 push @type, 'parent' if defined $table->{$id};
106                 push @type, 'large'  if $level =~ s/c$//;
107                 push @type, 'level'.($level || 0);
108                 printf '<li%s>', @type ? sprintf ' class="%s"', join ' ', @type : '';
109                 print showimg($id, $title) if $level <= $limit;
110                 printimgs(@{$_}) for $table->{$id} // ();
111                 print '</li>';
112         }
113         say '</ul>';
114 }
115
116 say '<section class="gallery">';
117 if (exists $get{q}) {
118         my @rows;
119         if ($Request) {
120                 my @query = $Request;
121                 while (@query) {
122                         push @rows, grep { $_->[1] <= $limit } @query;
123                         $_ = $_->[0] for @query;
124                         @query = map {$_ ? @{$_} : ()} @{$table}{@query};
125                 }
126         }
127         else {
128                 @rows = map {ref ? @$_ : $_} values %{$table}; # flatten categories
129         }
130         @rows = sort { rand <=> .5 } @rows;
131         $table = {};
132         printimgs(@rows);
133 }
134 elsif ($Request and $Request =~ /^\d+$/) {
135         printimgs([$Request]);
136 }
137 else {
138         printimgs($table->{''}->[0]);
139 }
140 say '</section>';