]> sipb.mit.edu Git - ikiwiki.git/blobdiff - IkiWiki/Plugin/sidebar.pm
Add a fullpage arg to filter.
[ikiwiki.git] / IkiWiki / Plugin / sidebar.pm
index 808f0bed29d8dea4349874109b53e109501f6511..100015ceeeeb4f035e165e64713e907ee4d47eb6 100644 (file)
@@ -22,7 +22,7 @@ sub getsetup () {
                },
                global_sidebars => {
                        type => "boolean",
-                       examples => 1,
+                       example => 1,
                        description => "show sidebar page on all pages?",
                        safe => 1,
                        rebuild => 1,
@@ -60,7 +60,7 @@ my $oldcontent;
 sub sidebar_content ($) {
        my $page=shift;
        
-       return $pagesidebar{$page} if defined $pagesidebar{$page};
+       return delete $pagesidebar{$page} if defined $pagesidebar{$page};
 
        return if ! exists $pagesidebar{$page} && 
                defined $config{global_sidebars} && ! $config{global_sidebars};
@@ -89,7 +89,7 @@ sub sidebar_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))));
+                      IkiWiki::filter($sidebar_page, $page, $content, 'fullpage'))));
        }
 
 }
@@ -97,11 +97,10 @@ sub sidebar_content ($) {
 sub pagetemplate (@) {
        my %params=@_;
 
-       my $page=$params{page};
        my $template=$params{template};
-       
-       if ($template->query(name => "sidebar")) {
-               my $content=sidebar_content($page);
+       if ($params{destpage} eq $params{page} &&
+           $template->query(name => "sidebar")) {
+               my $content=sidebar_content($params{destpage});
                if (defined $content && length $content) {
                        $template->param(sidebar => $content);
                }