aboutsummaryrefslogtreecommitdiff
path: root/IkiWiki/Plugin/sidebar.pm
diff options
context:
space:
mode:
authorjoey <joey@0fa5a96a-9a0e-0410-b3b2-a0fd24251071>2006-08-18 00:24:22 +0000
committerjoey <joey@0fa5a96a-9a0e-0410-b3b2-a0fd24251071>2006-08-18 00:24:22 +0000
commitcedb48765b52d3e074f43703cf55611b3bce101d (patch)
treeeb35fa82b6ed9f2c63cb111453de2a5af59d9188 /IkiWiki/Plugin/sidebar.pm
parent5d37a3837c6a047d47ec6eadc0859c97db65416e (diff)
downloadikiwiki-cedb48765b52d3e074f43703cf55611b3bce101d.tar
ikiwiki-cedb48765b52d3e074f43703cf55611b3bce101d.tar.gz
* Add a tail fin^W^Wsidebar plugin by Tuomo Valkonen.
* If a page links to itself, mark up the link text in a span with class="selflink" so that it can be styled. I don't have a useful style defined for that though.
Diffstat (limited to 'IkiWiki/Plugin/sidebar.pm')
-rw-r--r--IkiWiki/Plugin/sidebar.pm48
1 files changed, 48 insertions, 0 deletions
diff --git a/IkiWiki/Plugin/sidebar.pm b/IkiWiki/Plugin/sidebar.pm
new file mode 100644
index 000000000..a6efc6b8e
--- /dev/null
+++ b/IkiWiki/Plugin/sidebar.pm
@@ -0,0 +1,48 @@
+#!/usr/bin/perl
+# Sidebar plugin.
+# by Tuomo Valkonen <tuomov at iki dot fi>
+
+package IkiWiki::Plugin::sidebar;
+
+use warnings;
+use strict;
+use IkiWiki;
+
+sub import { #{{{
+ IkiWiki::hook(type => "pagetemplate", id => "sidebar",
+ call => \&pagetemplate);
+} # }}}
+
+sub sidebar_content ($) { #{{{
+ my $page=shift;
+
+ my $sidebar_page=IkiWiki::bestlink($page, "sidebar") || return;
+ my $sidebar_file=$IkiWiki::pagesources{$sidebar_page} || return;
+ my $sidebar_type=IkiWiki::pagetype($sidebar_file);
+
+ if (defined $sidebar_type) {
+ IkiWiki::add_depends($page, $sidebar_page);
+ my $content=IkiWiki::readfile(IkiWiki::srcfile($sidebar_file));
+ return unless length $content;
+ return IkiWiki::htmlize($sidebar_type,
+ IkiWiki::preprocess($sidebar_page, $page,
+ IkiWiki::linkify($sidebar_page, $page, $content)));
+ }
+
+} # }}}
+
+sub pagetemplate (@) { #{{{
+ my %params=@_;
+
+ my $page=$params{page};
+ my $template=$params{template};
+
+ if ($template->query(name => "sidebar")) {
+ my $content=sidebar_content($page);
+ if (defined $content && length $content) {
+ $template->param(sidebar => $content);
+ }
+ }
+} # }}}
+
+1