X-Git-Url: http://git.freeside.biz/gitweb/?p=freeside.git;a=blobdiff_plain;f=rt%2Fshare%2Fhtml%2FSearch%2FChart.html;h=bab963995206a1d2d0286656be567482951b440d;hp=6ec578945e7b31f320491fbd9b941bddaf602a2b;hb=187086c479a09629b7d180eec513fb7657f4e291;hpb=7588a4ac90a9b07c08a3107cd1107d773be1c991 diff --git a/rt/share/html/Search/Chart.html b/rt/share/html/Search/Chart.html index 6ec578945..bab963995 100644 --- a/rt/share/html/Search/Chart.html +++ b/rt/share/html/Search/Chart.html @@ -2,7 +2,7 @@ %# %# COPYRIGHT: %# -%# This software is Copyright (c) 1996-2013 Best Practical Solutions, LLC +%# This software is Copyright (c) 1996-2018 Best Practical Solutions, LLC %# %# %# (Except where explicitly superseded by other copyright notices) @@ -45,34 +45,23 @@ %# those contributions and any derivatives thereof. %# %# END BPS TAGGED BLOCK }}} -<%args> -$PrimaryGroupBy => 'Queue' -$ChartStyle => 'bars' -$Description => undef - <%init> -$ARGS{Query} ||= 'id > 0'; - -# FIXME: should be factored with RT::Report::Tickets::Label :( -my $PrimaryGroupByLabel; -if ( $PrimaryGroupBy =~ /^(?:CF|CustomField)\.{(.*)}$/ ) { - my $cf = $1; - if ( $cf =~ /\D/ ) { - $PrimaryGroupByLabel = loc( "custom field '[_1]'", $cf ); - } else { - my $obj = RT::CustomField->new( $session{'CurrentUser'} ); - $obj->Load( $cf ); - $PrimaryGroupByLabel = loc( "custom field '[_1]'", $obj->Name ); - } -} else { - $PrimaryGroupByLabel = loc( $PrimaryGroupBy ); -} +my $default_value = { + Query => 'id > 0', + GroupBy => ['Status'], + ChartStyle => ['bar+table+sql'], + ChartFunction => ['COUNT'], +}; + +$m->callback( ARGSRef => \%ARGS, CallbackName => 'Initial' ); -my $title = loc( "Search results grouped by [_1]", $PrimaryGroupByLabel ); +my $title = loc( "Grouped search results"); +my @search_fields = qw(Query GroupBy ChartStyle ChartFunction Width Height); my $saved_search = $m->comp( '/Widgets/SavedSearch:new', SearchType => 'Chart', - SearchFields => [qw(Query PrimaryGroupBy ChartStyle)] ); + SearchFields => [@search_fields], +); my @actions = $m->comp( '/Widgets/SavedSearch:process', args => \%ARGS, self => $saved_search ); @@ -97,8 +86,8 @@ my %query; ); for(@session_fields) { - $query{$_} = $current->{$_} unless defined $query{$_}; $query{$_} = $DECODED_ARGS->{$_} unless defined $query{$_}; + $query{$_} = $current->{$_} unless defined $query{$_}; } if ($DECODED_ARGS->{'SavedSearchLoadSubmit'}) { @@ -111,23 +100,122 @@ my %query; } +foreach (@search_fields) { + if ( ref $default_value->{$_} ) { + $query{$_} = ref $ARGS{$_} ? $ARGS{$_} : [ $ARGS{$_} ]; + $query{$_} = $default_value->{$_} + unless defined $query{$_} && defined $query{$_}[0]; + } + else { + $query{$_} = ref $ARGS{$_} ? $ARGS{$_} : $ARGS{$_}; + $query{$_} = $default_value->{$_} + unless defined $query{$_}; + } +} + +$m->callback( ARGSRef => \%ARGS, QueryArgsRef => \%query ); + <& /Elements/Header, Title => $title &> <& /Elements/Tabs, QueryArgs => \%query &> <& /Elements/ListActions, actions => \@actions &> + +% $m->callback( ARGSRef => \%ARGS, CallbackName => 'BeforeChart' ); + <& /Search/Elements/Chart, %ARGS &> +% $m->callback( ARGSRef => \%ARGS, CallbackName => 'AfterChart' ); +
-<&| /Widgets/TitleBox, title => loc('Chart Properties')&> -
- + + + -<&|/l_unsafe, $m->scomp('Elements/SelectChartType', Name => 'ChartStyle', Default => $ChartStyle), $m->scomp('Elements/SelectGroupBy', Name => 'PrimaryGroupBy', Query => $ARGS{Query}, Default => $PrimaryGroupBy) -&>[_1] chart by [_2] -
+<&| /Widgets/TitleBox, title => loc('Group by'), class => "chart-group-by" &> +
<% loc('Group tickets by') %> +<& Elements/SelectGroupBy, + Name => 'GroupBy', + Query => $query{Query}, + Default => $query{'GroupBy'}[0], + &> +
+
<% loc('and then') %> +<& Elements/SelectGroupBy, + Name => 'GroupBy', + Query => $query{Query}, + Default => $query{'GroupBy'}[1] // q{}, + ShowEmpty => 1, + &> +
+
<% loc('and then') %> +<& Elements/SelectGroupBy, + Name => 'GroupBy', + Query => $query{Query}, + Default => $query{'GroupBy'}[2] // q{}, + ShowEmpty => 1, + &> +
+ +<&| /Widgets/TitleBox, title => loc("Calculate"), class => "chart-calculate" &> + +
<% loc('Calculate values of') %> +<& Elements/SelectChartFunction, Default => $query{'ChartFunction'}[0] &> +
+
<% loc('and then') %> +<& Elements/SelectChartFunction, Default => $query{'ChartFunction'}[1] // q{}, ShowEmpty => 1 &> +
+
<% loc('and then') %> +<& Elements/SelectChartFunction, Default => $query{'ChartFunction'}[2] // q{}, ShowEmpty => 1 &> +
+ + + +<&| /Widgets/TitleBox, title => loc('Picture'), class => "chart-picture" &> + + + + + + + × + + +
+ > <% loc('Include data table') %> +
+
+ > <% loc('Include TicketSQL query') %> +
+ + + +<& /Elements/Submit, Label => loc('Update Chart'), Name => 'Update' &> + +