X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=bin%2Fmozilla%2Fdrafts.pl;h=18af531f2246dc4b4ef58c1775401ff5199aeaea;hb=3c5e4df9e938a8f2c9b045774bda00095b976e49;hp=3f5e527e1e14ba65c260700b8ccddb24e555a08e;hpb=bde667c235b2347bdd1322f118b032a2f0d93367;p=kivitendo-erp.git diff --git a/bin/mozilla/drafts.pl b/bin/mozilla/drafts.pl index 3f5e527e1..18af531f2 100644 --- a/bin/mozilla/drafts.pl +++ b/bin/mozilla/drafts.pl @@ -16,6 +16,8 @@ sub save_draft { if (!$form->{draft_id} && !$form->{draft_description}) { restore_form($form->{SAVED_FORM}, 1) if ($form->{SAVED_FORM}); + delete($form->{SAVED_FORM}); + $form->{remove_draft} = 1; $form->{SAVED_FORM} = save_form(); $form->header(); @@ -82,10 +84,11 @@ sub dont_load_draft { my $draft_nextsub = $form->{draft_nextsub}; $draft_nextsub = "add" unless ($form->{draft_nextsub}); restore_form($form->{SAVED_FORM}, 1); + delete($form->{SAVED_FORM}); delete($form->{action}); $form->{DONT_LOAD_DRAFT} = 1; - &{ $draft_nextsub }(); + call_sub($draft_nextsub); $lxdebug->leave_sub(); } @@ -98,7 +101,7 @@ sub load_draft { restore_form($old_form, 1); $form->{draft_id} = $id; $form->{draft_description} = $description; - $lxdebug->dump(0, "of", $old_form); + $form->{remove_draft} = 'checked'; } update(); @@ -106,4 +109,32 @@ sub load_draft { $lxdebug->leave_sub(); } +sub delete_drafts { + $lxdebug->enter_sub(); + + my @ids; + foreach (keys(%{$form})) { + push(@ids, $1) if (/^checked_(.*)/ && $form->{$_}); + } + Drafts->remove(\%myconfig, $form, @ids) if (@ids); + restore_form($form->{SAVED_FORM}, 1); + delete($form->{SAVED_FORM}); + + add(); + + $lxdebug->leave_sub(); +} + +sub draft_action_dispatcher { + $lxdebug->enter_sub(); + + if ($form->{draft_action} eq $locale->text("Skip")) { + dont_load_draft(); + } elsif ($form->{draft_action} eq $locale->text("Delete drafts")) { + delete_drafts(); + } + + $lxdebug->leave_sub(); +} + 1;