X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=SL%2FController%2FCustomerVendor.pm;h=da4b7c9d5d1c99ac187953cb725a36bf770a4192;hb=3c90061ba294d86b5e92bfe3e7b47c1005209937;hp=767ffa51dd212fb7e36ecb30638a166508e215f3;hpb=382890fe41b27b14c74d15587396255988883448;p=kivitendo-erp.git diff --git a/SL/Controller/CustomerVendor.pm b/SL/Controller/CustomerVendor.pm index 767ffa51d..da4b7c9d5 100644 --- a/SL/Controller/CustomerVendor.pm +++ b/SL/Controller/CustomerVendor.pm @@ -133,10 +133,6 @@ sub _save { $self->{note_followup_link}->save(); SL::Helper::Flash::flash_later('info', $::locale->text('Follow-Up saved.')); - - $self->{note} = SL::DB::Note->new(); - $self->{note_followup} = SL::DB::FollowUp->new(); - $self->{note_followup_link} = SL::DB::FollowUpLink->new(); } $self->{shipto}->trans_id($self->{cv}->id); @@ -174,6 +170,10 @@ sub action_save { push(@redirect_params, shipto_id => $self->{shipto}->shipto_id); } + if ( $self->{note}->id ) { + push(@redirect_params, note_id => $self->{note}->id); + } + $self->redirect_to(@redirect_params); } @@ -355,13 +355,17 @@ sub action_delete_shipto { sub action_search { my ($self) = @_; - my $url = 'ct.pl?action=search&db='. ($self->is_vendor() ? 'vendor' : 'customer'); + my @url_params = ( + controller => 'ct.pl', + action => 'search', + db => $self->is_vendor() ? 'vendor' : 'customer', + ); if ( $::form->{callback} ) { - $url .= '&callback='. $::from->escape($::form->{callback}); + push(@url_params, callback => $::form->{callback}); } - print $::form->redirect_header($url); + $self->redirect_to(@url_params); } @@ -371,7 +375,7 @@ sub action_search_contact { my $url = 'ct.pl?action=search_contact&db=customer'; if ( $::form->{callback} ) { - $url .= '&callback='. $::from->escape($::form->{callback}); + $url .= '&callback='. $::form->escape($::form->{callback}); } print $::form->redirect_header($url); @@ -622,22 +626,33 @@ sub _instantiate_args { if ( $::form->{note}->{id} ) { $self->{note} = SL::DB::Note->new(id => $::form->{note}->{id})->load(); + + $self->{note_followup_link} = SL::DB::Manager::FollowUpLink->get_all( + query => [ + 'follow_up.note_id' => $self->{note}->id, + trans_id => $self->{cv}->id, + trans_type => ($self->is_vendor() ? 'vendor' : 'customer'), + ], + with_objects => ['follow_up'], + )->[0]; + + $self->{note_followup} = $self->{note_followup_link}->follow_up; } else { $self->{note} = SL::DB::Note->new(); + $self->{note_followup} = SL::DB::FollowUp->new(); + $self->{note_followup_link} = SL::DB::FollowUpLink->new(); } + $self->{note}->assign_attributes(%{$::form->{note}}); $self->{note}->created_by($curr_employee->id); $self->{note}->trans_module('ct'); - $self->{note_followup} = SL::DB::FollowUp->new(); $self->{note_followup}->assign_attributes(%{$::form->{note_followup}}); $self->{note_followup}->note($self->{note}); $self->{note_followup}->created_by($curr_employee->id); - $self->{note_followup_link} = SL::DB::FollowUpLink->new( - trans_type => ($self->is_vendor() ? 'vendor' : 'customer'), - trans_info => $self->{cv}->name - ); + $self->{note_followup_link}->trans_type($self->is_vendor() ? 'vendor' : 'customer'); + $self->{note_followup_link}->trans_info($self->{cv}->name); if ( $::form->{shipto}->{shipto_id} ) { $self->{shipto} = SL::DB::Shipto->new(shipto_id => $::form->{shipto}->{shipto_id})->load(); @@ -674,9 +689,24 @@ sub _load_customer_vendor { $self->{cv} = SL::DB::Customer->new(id => $::form->{id})->load(); } - $self->{note} = SL::DB::Note->new(); - $self->{note_followup} = SL::DB::FollowUp->new(); - $self->{note_followup_link} = SL::DB::FollowUpLink->new(); + if ( $::form->{note_id} ) { + $self->{note} = SL::DB::Note->new(id => $::form->{note_id})->load(); + + $self->{note_followup_link} = SL::DB::Manager::FollowUpLink->get_all( + query => [ + 'follow_up.note_id' => $self->{note}->id, + trans_id => $self->{cv}->id, + trans_type => ($self->is_vendor() ? 'vendor' : 'customer'), + ], + with_objects => ['follow_up'], + )->[0]; + + $self->{note_followup} = $self->{note_followup_link}->follow_up; + } else { + $self->{note} = SL::DB::Note->new(); + $self->{note_followup} = SL::DB::FollowUp->new(); + $self->{note_followup_link} = SL::DB::FollowUpLink->new(); + } if ( $::form->{shipto_id} ) { $self->{shipto} = SL::DB::Shipto->new(shipto_id => $::form->{shipto_id})->load();