X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=SL%2FController%2FRequirementSpec.pm;h=6f5bf21e3b5aee935bc74404ad436183e2195ba7;hb=24bb9ded832e2ed1054973fd025cfa6c5fec021e;hp=68969e61b31e2bcc209a059b73e28f87facab170;hpb=96670fe82a38116ac10592a6ccbd34800f8ad9f8;p=kivitendo-erp.git diff --git a/SL/Controller/RequirementSpec.pm b/SL/Controller/RequirementSpec.pm index 68969e61b..6f5bf21e3 100644 --- a/SL/Controller/RequirementSpec.pm +++ b/SL/Controller/RequirementSpec.pm @@ -53,6 +53,7 @@ my %sort_columns = ( sub action_list { my ($self) = @_; + $self->_setup_search_action_bar; $self->prepare_report; $self->report_generator_list_objects(report => $self->{report}, objects => $self->models->get); } @@ -66,6 +67,8 @@ sub action_new { $self->requirement_spec->$_($self->copy_source->$_) for qw(type_id status_id customer_id title hourly_rate is_template) } + $self->_setup_form_action_bar; + $self->render('requirement_spec/new', title => $self->requirement_spec->is_template ? t8('Create a new requirement spec template') : t8('Create a new requirement spec')); } @@ -322,7 +325,7 @@ sub setup { $::auth->assert('requirement_spec_edit'); $::request->{layout}->use_stylesheet("${_}.css") for qw(jquery.contextMenu requirement_spec); - $::request->{layout}->use_javascript("${_}.js") for qw(jquery.jstree jquery/jquery.contextMenu jquery/jquery.hotkeys requirement_spec ckeditor/ckeditor ckeditor/adapters/jquery autocomplete_part autocomplete_customer); + $::request->{layout}->use_javascript("${_}.js") for qw(jquery.jstree jquery/jquery.contextMenu jquery/jquery.hotkeys requirement_spec ckeditor/ckeditor ckeditor/adapters/jquery kivi.Part autocomplete_customer); $self->init_visible_section; return 1; @@ -380,10 +383,11 @@ sub init_include_cvars { # sub create_or_update { - my $self = shift; - my $is_new = !$self->requirement_spec->id; - my $params = delete($::form->{requirement_spec}) || { }; - my $cvars = delete($::form->{cvars}) || { }; + my $self = shift; + my $is_new = !$self->requirement_spec->id; + my $previous_customer_id = $self->requirement_spec->customer_id; + my $params = delete($::form->{requirement_spec}) || { }; + my $cvars = delete($::form->{cvars}) || { }; # Forcefully make it clear to Rose which custom_variables exist (or don't), so that the ones added with »add_custom_variables« are visible when calling »custom_variables«. if ($is_new) { @@ -422,6 +426,18 @@ sub create_or_update { $self->requirement_spec($self->copy_source->create_copy(%{ $params })); } else { $self->requirement_spec->save(cascade => 1); + + # If the current requirement spec has versions and the + # customer's been changed, then the customer of all the versions + # has to be changed, too. + if ( !$is_new + && !$self->requirement_spec->is_template + && ($previous_customer_id != $self->requirement_spec->customer_id)) { + SL::DB::Manager::RequirementSpec->update_all( + set => { customer_id => $self->requirement_spec->customer_id }, + where => [ working_copy_id => $self->requirement_spec->id ], + ); + } } 1; })) { @@ -682,4 +698,41 @@ sub init_html_template { return !!$template; } +sub _setup_form_action_bar { + my ($self) = @_; + + for my $bar ($::request->layout->get('actionbar')) { + $bar->add( + action => [ + t8('Save'), + submit => [ '#basic_settings_form', { action => 'RequirementSpec/' . ($self->requirement_spec->id ? 'update' : 'create') } ], + accesskey => 'enter', + ], + + link => [ + t8('Abort'), + link => $self->url_for(action => 'list', is_template => $self->requirement_spec->is_template), + ], + ); + } +} + +sub _setup_search_action_bar { + my ($self, %params) = @_; + + for my $bar ($::request->layout->get('actionbar')) { + $bar->add( + action => [ + t8('Update'), + submit => [ '#search_form', { action => 'RequirementSpec/list' } ], + accesskey => 'enter', + ], + link => [ + t8('Add'), + link => $self->url_for(action => 'new', is_template => $::form->{is_template}), + ], + ); + } +} + 1;