X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=bin%2Fmozilla%2Fdrafts.pl;h=7670c7e5ec02f0bfa5bc6ddccd2f4874e06f0271;hb=fdf5b8ae58b69b3a96a2255128e0524323d18cd7;hp=d754a693b43977b3b596d5daf18f2fadbe75871a;hpb=58e4b8099a5969b105f86e07de50a44a6aa04c84;p=kivitendo-erp.git diff --git a/bin/mozilla/drafts.pl b/bin/mozilla/drafts.pl index d754a693b..7670c7e5e 100644 --- a/bin/mozilla/drafts.pl +++ b/bin/mozilla/drafts.pl @@ -13,6 +13,8 @@ use SL::Drafts; require "bin/mozilla/common.pl"; +use strict; + sub save_draft { $main::lxdebug->enter_sub(); @@ -24,7 +26,7 @@ sub save_draft { restore_form($form->{SAVED_FORM}, 1) if ($form->{SAVED_FORM}); delete $form->{SAVED_FORM}; - $form->{SAVED_FORM} = save_form(qw(stylesheet login password)); + $form->{SAVED_FORM} = save_form(qw(login password)); $form->{remove_draft} = 1; $form->header(); @@ -77,7 +79,7 @@ sub load_draft_maybe { $draft_nextsub = "add" unless ($draft_nextsub); delete $form->{action}; - my $saved_form = save_form(qw(stylesheet login password)); + my $saved_form = save_form(qw(login password)); $form->header(); print($form->parse_html_template("drafts/load", @@ -113,12 +115,22 @@ sub load_draft { my $form = $main::form; my %myconfig = %main::myconfig; + # check and store certain form parameters that might have been passed as get, so we can later overwrite the values from the draft + # the overwrite happens at the end of this function + my @valid_overwrite_vars = qw(remove_draft amount_1 invnumber ordnumber transdate duedate notes datepaid_1 paid_1 callback AP_paid_1 currency); # reference description + my $overwrite_hash; + # my @valid_fields; + foreach ( @valid_overwrite_vars ) { + $overwrite_hash->{$_} = $form->{$_} if exists $form->{$_}; # variant 1 + # push(@valid_fields, $_) if exists $form->{$_}; # variant 2 + }; + my ($old_form, $id, $description) = Drafts->load(\%myconfig, $form, $form->{id}); if ($old_form) { $old_form = YAML::Load($old_form); - my %dont_save_vars = map { $_ => 1 } @Drafts::dont_save; + my %dont_save_vars = map { $_ => 1 } Drafts->dont_save; my @restore_vars = grep { !$dont_save_vars{$_} } keys %{ $old_form }; @{$form}{@restore_vars} = @{$old_form}{@restore_vars}; @@ -127,6 +139,17 @@ sub load_draft { $form->{draft_description} = $description; $form->{remove_draft} = 'checked'; } + # Ich vergesse bei Rechnungsentwürfe das Rechnungsdatum zu ändern. Dadurch entstehen + # ungültige Belege. Vielleicht geht es anderen ähnlich jan 19.2.2011 + $form->{invdate} = $form->current_date(\%myconfig); # Aktuelles Rechnungsdatum ... + $form->{duedate} = $form->current_date(\%myconfig); # Aktuelles Fälligkeitsdatum ... + + if ( $overwrite_hash ) { + foreach ( keys %$overwrite_hash ) { + $form->{$_} = $overwrite_hash->{$_}; # variante 1 + }; + }; + # @{$form}{@valid_fields} = @{$overwrite_hash}{@valid_fields}; # variante 2 update();