X-Git-Url: http://wagnertech.de/git?a=blobdiff_plain;f=SL%2FController%2FRequirementSpec.pm;h=875f170733b8bd9c004803ff1b38daab238f5f0e;hb=20004cac8f656f67e86e63fdb85f6dc083cf83d7;hp=b45080dcb0807438e796115d3f0c6d23d221ad48;hpb=62bf9a5c87218a9c1205c594c500346b4a7ec670;p=kivitendo-erp.git diff --git a/SL/Controller/RequirementSpec.pm b/SL/Controller/RequirementSpec.pm index b45080dcb..875f17073 100644 --- a/SL/Controller/RequirementSpec.pm +++ b/SL/Controller/RequirementSpec.pm @@ -325,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 kivi.Part kivi.CustomerVendor.js); + $::request->{layout}->use_javascript("${_}.js") for qw(jquery.jstree jquery/jquery.contextMenu jquery/jquery.hotkeys requirement_spec ckeditor/ckeditor ckeditor/adapters/jquery kivi.Part kivi.CustomerVendor); $self->init_visible_section; return 1; @@ -374,7 +374,7 @@ sub init_includeable_cvar_configs { sub init_include_cvars { my ($self) = @_; - return $::form->{include_cvars} if $::form->{include_cvars} && (ref($::form->{include_cvars}) eq 'HASH'); + return { map { ($_->name => $::form->{"include_cvars_" . $_->name}) } @{ $self->cvar_configs } } if $::form->{_include_cvars_from_form}; return { map { ($_->name => ($_->includeable && $_->included_by_default)) } @{ $self->cvar_configs } }; } @@ -490,9 +490,9 @@ sub prepare_report { if (!$is_template) { %column_defs = ( %column_defs, - customer => { raw_data => sub { $self->presenter->customer($_[0]->customer, display => 'table-cell', callback => $callback) }, + customer => { raw_data => sub { $_[0]->customer->presenter->customer(display => 'table-cell', callback => $callback) }, sub => sub { $_[0]->customer->name } }, - projectnumber => { raw_data => sub { $self->presenter->project($_[0]->project, display => 'table-cell', callback => $callback) }, + projectnumber => { raw_data => sub { $_[0]->project ? $_[0]->project->presenter->project(display => 'table-cell', callback => $callback) : '' }, sub => sub { $_[0]->project_id ? $_[0]->project->projectnumber : '' } }, status => { sub => sub { $_[0]->status->description } }, type => { sub => sub { $_[0]->type->description } }, @@ -516,6 +516,8 @@ sub prepare_report { %column_defs = (%column_defs, %cvar_column_defs); } + my @cvar_column_form_names = ('_include_cvars_from_form', map { "include_cvars_" . $_->name } @{ $self->includeable_cvar_configs }); + $report->set_options( std_column_visibility => 1, controller_class => 'RequirementSpec', @@ -528,7 +530,7 @@ sub prepare_report { ); $report->set_columns(%column_defs); $report->set_column_order(@columns); - $report->set_export_options(qw(list filter)); + $report->set_export_options(qw(list filter), @cvar_column_form_names); $report->set_options_from_form; $self->models->set_report_generator_sort_options(report => $report, sortable_columns => \@sortable); } @@ -555,7 +557,7 @@ sub render_pasted_text_block { ->hide('#text-block-list-empty'); } - my $node = $self->presenter->requirement_spec_text_block_jstree_data($text_block); + my $node = $text_block->presenter->jstree_data; my $front_back = $text_block->output_position == 0 ? 'front' : 'back'; $self->js ->jstree->create_node('#tree', "#tb-${front_back}", 'last', $node) @@ -577,7 +579,7 @@ sub set_default_filter_args { sub render_pasted_section { my ($self, $item, $parent_id) = @_; - my $node = $self->presenter->requirement_spec_item_jstree_data($item); + my $node = $item->presenter->jstree_data; $self->js ->jstree->create_node('#tree', $parent_id ? "#fb-${parent_id}" : '#sections', 'last', $node) ->jstree->open_node( '#tree', $parent_id ? "#fb-${parent_id}" : '#sections');