urlencode "$SCRIPTURL/$uplink";
}
(my $nosl = $path) =~ s!/$!!;
+
+ my %tn;
+ for my $f (@$ff)
+ { $tn{$f} = TrivGal::Image->new($path . $f->name); }
+ for my $d (@$dd) {
+ my ($ddd, $fff, $iii) = listdir $real . "/" . $d->name;
+ $tn{$d} = $iii ?
+ TrivGal::Image->new(join_paths $path, $d->name, $iii->name) :
+ undef;
+ }
</%perl>
%
<&| .html, title => "Folder " . $m->interp->apply_escapes($nosl || "[top]", "h"),
%
% if (@$dd) {
<h2>Subfolders</h2>
-<div class=gallery>
-% for my $d (@$dd) {
-% my ($ddd, $fff, $iii) = listdir $real . "/" . $d->name;
-% my $tn = $iii ?
-% TrivGal::Image->new(join_paths $path, $d->name, $iii->name) :
-% undef;
+% for my $size (qw{bigthumb}) {
+<div class="gallery <% $size %>">
+% for my $d (@$dd) {
<& .thumbnail, target => $d->name . "/", comment => $d->comment,
- img => $tn, size => "bigthumb",
+ img => $tn{$d}, size => $size,
caption => $m->interp->apply_escapes($d->name, "h") &>\
-% }
+% }
</div>
+% }
% }
%
% if (@$ff) {
<h2>Images</h2>
-<div class=gallery>
-% for my $f (@$ff) {
+% for my $size (qw{bigthumb}) {
+<div class="gallery <% $size %>">
+% for my $f (@$ff) {
<& .thumbnail, target => $f->name, comment => $f->comment,
- img => TrivGal::Image->new($path . $f->name),
- size => "bigthumb",
+ img => $tn{$f}, size => "bigthumb",
caption => $m->interp->apply_escapes($f->name, "h") &>\
-% }
+% }
</div>
+% }
% }
%
<div class=fill></div>
% }
</div>
%
-<div class=thumbstrip>
-% for my $f (@$ff) {
-% my $img = TrivGal::Image->new($dir . "/" . $f->name);
- <& .thumbnail, target => $f->name, img => $img, size => "bigthumb",
+% my %img = map { $_ => TrivGal::Image->new($dir . "/" . $_->name) } @$ff;
+% for my $size (qw{bigthumb}) {
+<div class="thumbstrip <% $size %>">
+% for my $f (@$ff) {
+ <& .thumbnail, target => $f->name, img => $img{$f}, size => $size,
caption => $m->interp->apply_escapes($f->name, "h"),
focus => $f->name eq "$base$ext" &>\
-% }
+% }
</div>
+% }
<& .footer, path => $dir &>
</&>
%
}
div.gallery {
- display: flex; flex-direction: row; flex-wrap: wrap;
+ flex-direction: row; flex-wrap: wrap;
align-items: start; justify-content: space-evenly;
}
+div.gallery.bigthumb { display: flex; }
figure.thumb {
display: inline-block;
max-width: 100%;
overflow-x: auto;
text-align: center;
- display: flex; flex-direction: row; align-self: center;
+ flex-direction: row; align-self: center;
}
+div.thumbstrip.bigthumb { display: flex; }
/*----- That's all, folks -------------------------------------------------*/