index.pl 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  1. # Copyright (C) 2004, 2007 Alex Schroeder <alex@emacswiki.org>
  2. #
  3. # This program is free software; you can redistribute it and/or modify
  4. # it under the terms of the GNU General Public License as published by
  5. # the Free Software Foundation; either version 2 of the License, or
  6. # (at your option) any later version.
  7. #
  8. # This program is distributed in the hope that it will be useful,
  9. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  10. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  11. # GNU General Public License for more details.
  12. #
  13. # You should have received a copy of the GNU General Public License
  14. # along with this program; if not, write to the
  15. # Free Software Foundation, Inc.
  16. # 59 Temple Place, Suite 330
  17. # Boston, MA 02111-1307 USA
  18. use strict;
  19. use v5.10;
  20. AddModuleDescription('index.pl', 'Index Extension');
  21. our ($q, %Action, %PermanentAnchors, %NearSource);
  22. $Action{'printable-index'} = \&DoPrintableIndex;
  23. sub DoPrintableIndex {
  24. print GetHeader('', T('Index'), '');
  25. my @pages = PrintableIndexPages();
  26. my %hash;
  27. map { push(@{$hash{substr($_,0,1)}}, $_); } @pages;
  28. print '<div class="content printable index">';
  29. print $q->p($q->a({-name=>"top"}),
  30. map { $q->a({-href=>"#$_"}, $_); } sort keys %hash);
  31. foreach my $title (sort keys %hash) {
  32. print '<div class="letter">';
  33. print $q->h2($q->a({-name=>$title}, $title));
  34. foreach my $id (@{$hash{$title}}) {
  35. PrintPage($id);
  36. }
  37. print '</div>';
  38. }
  39. print '</div>';
  40. PrintFooter();
  41. }
  42. # Mostly DoIndex() without the printing.
  43. sub PrintableIndexPages {
  44. my @pages;
  45. push(@pages, AllPagesList()) if GetParam('pages', 1);
  46. push(@pages, keys %PermanentAnchors) if GetParam('permanentanchors', 1);
  47. push(@pages, keys %NearSource) if GetParam('near', 0);
  48. my $match = GetParam('match', '');
  49. @pages = grep /$match/i, @pages if $match;
  50. @pages = sort @pages;
  51. return @pages;
  52. }