summaryrefslogtreecommitdiff
path: root/IkiWiki/Plugin/topbar.pm
diff options
context:
space:
mode:
Diffstat (limited to 'IkiWiki/Plugin/topbar.pm')
-rw-r--r--IkiWiki/Plugin/topbar.pm63
1 files changed, 32 insertions, 31 deletions
diff --git a/IkiWiki/Plugin/topbar.pm b/IkiWiki/Plugin/topbar.pm
index c1146b7..0cc8e28 100644
--- a/IkiWiki/Plugin/topbar.pm
+++ b/IkiWiki/Plugin/topbar.pm
@@ -1,17 +1,18 @@
#!/usr/bin/perl
-# Sidebar plugin.
-# by Tuomo Valkonen <tuomov at iki dot fi>
+# Topbar plugin.
+# by Jonas Smedegaard <dr@jones.dk>
+# Heavily based on Sidebar by Tuomo Valkonen <tuomov at iki dot fi>
-package IkiWiki::Plugin::sidebar;
+package IkiWiki::Plugin::topbar;
use warnings;
use strict;
use IkiWiki 3.00;
sub import {
- hook(type => "getsetup", id => "sidebar", call => \&getsetup);
- hook(type => "preprocess", id => "sidebar", call => \&preprocess);
- hook(type => "pagetemplate", id => "sidebar", call => \&pagetemplate);
+ hook(type => "getsetup", id => "topbar", call => \&getsetup);
+ hook(type => "preprocess", id => "topbar", call => \&preprocess);
+ hook(type => "pagetemplate", id => "topbar", call => \&pagetemplate);
}
sub getsetup () {
@@ -20,16 +21,16 @@ sub getsetup () {
safe => 1,
rebuild => 1,
},
- global_sidebars => {
+ global_topbars => {
type => "boolean",
example => 1,
- description => "show sidebar page on all pages?",
+ description => "show topbar page on all pages?",
safe => 1,
rebuild => 1,
},
}
-my %pagesidebar;
+my %pagetopbar;
sub preprocess (@) {
my %params=@_;
@@ -38,13 +39,13 @@ sub preprocess (@) {
return "" unless $page eq $params{destpage};
if (! defined $params{content}) {
- $pagesidebar{$page}=undef;
+ $pagetopbar{$page}=undef;
}
else {
my $file = $pagesources{$page};
my $type = pagetype($file);
- $pagesidebar{$page}=
+ $pagetopbar{$page}=
IkiWiki::htmlize($page, $page, $type,
IkiWiki::linkify($page, $page,
IkiWiki::preprocess($page, $page, $params{content})));
@@ -56,39 +57,39 @@ sub preprocess (@) {
my $oldfile;
my $oldcontent;
-sub sidebar_content ($) {
+sub topbar_content ($) {
my $page=shift;
- return delete $pagesidebar{$page} if defined $pagesidebar{$page};
+ return delete $pagetopbar{$page} if defined $pagetopbar{$page};
- return if ! exists $pagesidebar{$page} &&
- defined $config{global_sidebars} && ! $config{global_sidebars};
+ return if ! exists $pagetopbar{$page} &&
+ defined $config{global_topbars} && ! $config{global_topbars};
- my $sidebar_page=bestlink($page, "sidebar") || return;
- my $sidebar_file=$pagesources{$sidebar_page} || return;
- my $sidebar_type=pagetype($sidebar_file);
+ my $topbar_page=bestlink($page, "topbar") || return;
+ my $topbar_file=$pagesources{$topbar_page} || return;
+ my $topbar_type=pagetype($topbar_file);
- if (defined $sidebar_type) {
+ if (defined $topbar_type) {
# FIXME: This isn't quite right; it won't take into account
- # adding a new sidebar page. So adding such a page
+ # adding a new topbar page. So adding such a page
# currently requires a wiki rebuild.
- add_depends($page, $sidebar_page);
+ add_depends($page, $topbar_page);
my $content;
- if (defined $oldfile && $sidebar_file eq $oldfile) {
+ if (defined $oldfile && $topbar_file eq $oldfile) {
$content=$oldcontent;
}
else {
- $content=readfile(srcfile($sidebar_file));
+ $content=readfile(srcfile($topbar_file));
$oldcontent=$content;
- $oldfile=$sidebar_file;
+ $oldfile=$topbar_file;
}
return unless length $content;
- return IkiWiki::htmlize($sidebar_page, $page, $sidebar_type,
- IkiWiki::linkify($sidebar_page, $page,
- IkiWiki::preprocess($sidebar_page, $page,
- IkiWiki::filter($sidebar_page, $page, $content))));
+ return IkiWiki::htmlize($topbar_page, $page, $topbar_type,
+ IkiWiki::linkify($topbar_page, $page,
+ IkiWiki::preprocess($topbar_page, $page,
+ IkiWiki::filter($topbar_page, $page, $content))));
}
}
@@ -98,10 +99,10 @@ sub pagetemplate (@) {
my $template=$params{template};
if ($params{destpage} eq $params{page} &&
- $template->query(name => "sidebar")) {
- my $content=sidebar_content($params{destpage});
+ $template->query(name => "topbar")) {
+ my $content=topbar_content($params{destpage});
if (defined $content && length $content) {
- $template->param(sidebar => $content);
+ $template->param(topbar => $content);
}
}
}