X-Git-Url: http://git.vanrenterghem.biz/git.ikiwiki.info.git/blobdiff_plain/8e7b31a19cc9f9d68d6c936d3d36e1d48c82248f..a1df39ed4ad4b17e4dde765d584376dfb05640dc:/IkiWiki/Plugin/remove.pm?ds=inline diff --git a/IkiWiki/Plugin/remove.pm b/IkiWiki/Plugin/remove.pm index 77ddd63ba..98f2f9459 100644 --- a/IkiWiki/Plugin/remove.pm +++ b/IkiWiki/Plugin/remove.pm @@ -18,20 +18,23 @@ sub formbuilder_setup (@) { #{{{ my $q=$params{cgi}; if (defined $form->field("do") && $form->field("do") eq "edit") { + # Removal button for the page, and also for attachments. push @{$params{buttons}}, "Remove"; - # TODO button for attachments + $form->tmpl_param("field-remove" => ''); } } #}}} -sub confirmation_form ($$) { #{{{ +sub confirmation_form ($$$) { #{{{ my $q=shift; my $session=shift; + my $page=shift; eval q{use CGI::FormBuilder}; error($@) if $@; my @fields=qw(do page); my $f = CGI::FormBuilder->new( - title => "confirm removal", + title => sprintf(gettext("confirm removal of %s"), + IkiWiki::pagetitle($page)), name => "remove", header => 0, charset => "utf-8", @@ -42,19 +45,9 @@ sub confirmation_form ($$) { #{{{ stylesheet => IkiWiki::baseurl()."style.css", fields => \@fields, ); - + $f->field(name => "do", type => "hidden", value => "remove", force => 1); - $f->field(name => "page", label => "Will remove:", validate => sub { - my $page=shift; - if (! exists $pagesources{$page}) { - $f->field(name => "page", message => gettext("page does not exist")); - return 0; - } - else { - IkiWiki::check_canedit($page, $q, $session); - return 1; - } - }); + $f->field(name => "page", type => "hidden", value => $page, force => 1); return $f, ["Remove", "Cancel"]; } #}}} @@ -63,22 +56,28 @@ sub formbuilder (@) { #{{{ my %params=@_; my $form=$params{form}; - if (defined $form->field("do") && $form->field("do") eq "edit" && - $form->submitted eq "Remove") { - # When the remove button is pressed on the edit form, - # save the rest of the form state and generate a small - # remove confirmation form. - - # TODO save state - - - my $q=$params{cgi}; - my $session=$params{session}; - my ($f, $buttons)=confirmation_form($q, $session); - $f->field(name => "page", value => $form->field("page"), - force => 1); - IkiWiki::showform($f, $buttons, $session, $q); - exit 0; + if (defined $form->field("do") && $form->field("do") eq "edit") { + if ($form->submitted eq "Remove") { + my $q=$params{cgi}; + my $session=$params{session}; + + # Save current form state to allow returning to it later + # without losing any edits. + # (But don't save what button was submitted, to avoid + # looping back to here.) + # Note: "_submit" is CGI::FormBuilder internals. + $q->param(-name => "_submit", -value => ""); + $session->param(postremove => scalar $q->Vars); + IkiWiki::cgi_savesession($session); + + # Display a small confirmation form. + my ($f, $buttons)=confirmation_form($q, $session, $form->field("page")); + IkiWiki::showform($f, $buttons, $session, $q); + exit 0; + } + elsif ($form->submitted eq "Remove Attachments") { + + } } } #}}} @@ -87,18 +86,55 @@ sub sessioncgi ($$) { #{{{ if ($q->param("do") eq 'remove') { my $session=shift; - my ($form, $buttons)=confirmation_form($q, $session); + my ($form, $buttons)=confirmation_form($q, $session, $session->param("page")); IkiWiki::decode_form_utf8($form); + if ($form->submitted eq 'Cancel') { - error("canceled"); # TODO load state + # Load saved form state and return to edit form. + my $postremove=CGI->new($session->param("postremove")); + $session->clear("postremove"); + IkiWiki::cgi_savesession($session); + IkiWiki::cgi($postremove, $session); } elsif ($form->submitted eq 'Remove' && $form->validate) { - error("removal not yet implemented"); # TODO + my $page=$form->field("page"); + my $file=$pagesources{$page}; + + # Validate removal by checking that the page exists, + # and that the user is allowed to edit(/remove) it. + if (! exists $pagesources{$page}) { + error(sprintf(gettext("%s does not exist"), + htmllink("", "", $page, noimageinline => 1))); + } + IkiWiki::check_canedit($page, $q, $session); + + # Do removal, and update the wiki. + require IkiWiki::Render; + if ($config{rcs}) { + IkiWiki::rcs_remove($file); + IkiWiki::disable_commit_hook(); + IkiWiki::rcs_commit($file, gettext("removed"), + IkiWiki::rcs_prepedit($file), + $session->param("name"), $ENV{REMOTE_ADDR}); + IkiWiki::enable_commit_hook(); + IkiWiki::rcs_update(); + } + IkiWiki::prune("$config{srcdir}/$file"); + IkiWiki::refresh(); + IkiWiki::saveindex(); + + # Redirect to parent of the page. + my $parent=IkiWiki::dirname($page); + if (! exists $pagesources{$parent}) { + $parent="index"; + } + IkiWiki::redirect($q, $config{url}."/".htmlpage($parent)); } else { IkiWiki::showform($form, $buttons, $session, $q); - exit 0; } + + exit 0; } }