- if ($r->path_info =~ /^\/\+tags\/?/) {
- # Tag cloud
- my $q = $dbh->prepare('SELECT tag,COUNT(*) AS frequency FROM tags t JOIN images i ON t.image=i.id WHERE vhost=? GROUP BY tag ORDER BY COUNT(*) DESC LIMIT 75')
- or return dberror($r, "Couldn't list events");
- $q->execute(Sesse::pr0n::Common::get_server_name($r))
- or return dberror($r, "Couldn't get events");
-
- Sesse::pr0n::Common::header($r, $io, Sesse::pr0n::Templates::fetch_template($r, 'tag-listing'));
- Sesse::pr0n::Templates::print_template($r, $io, 'mainmenu-tags');
-
- my $cloud = HTML::TagCloud->new;
-
- while (my $ref = $q->fetchrow_hashref()) {
- my $tag = $ref->{'tag'};
- my $html = HTML::Entities::encode_entities($tag); # is this right?
- my $uri = Sesse::pr0n::Common::pretty_escape($tag); # and this?
-
- $cloud->add($html, "/+tags/$uri/", $ref->{'frequency'});
- }
-
- $io->print($cloud->html_and_css());
- Sesse::pr0n::Common::footer($r, $io);
-
- $q->finish();
- } else {
- # main listing