$::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.js 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 kivi.CustomerVendor);
$self->init_visible_section;
return 1;
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 } };
}
#
sub create_or_update {
- my $self = shift;
- my $is_new = !$self->requirement_spec->id;
+ 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}) || { };
+ 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) {
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 } },
%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',
);
$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);
}
->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)
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');