[Rt-commit] rt branch, 4.4/empty-dashboard-mail, created. rt-4.2.12-505-g936516b
Shawn Moore
shawn at bestpractical.com
Tue Nov 17 12:53:40 EST 2015
The branch, 4.4/empty-dashboard-mail has been created
at 936516bbbebcb282997ba98ad2733d9ed9eac388 (commit)
- Log -----------------------------------------------------------------
commit 936516bbbebcb282997ba98ad2733d9ed9eac388
Author: Shawn M Moore <shawn at bestpractical.com>
Date: Tue Nov 17 17:52:53 2015 +0000
Let users choose to suppress dashboards with no results
diff --git a/lib/RT/Dashboard/Mailer.pm b/lib/RT/Dashboard/Mailer.pm
index 276e93f..a2c32f6 100644
--- a/lib/RT/Dashboard/Mailer.pm
+++ b/lib/RT/Dashboard/Mailer.pm
@@ -240,12 +240,20 @@ SUMMARY
local $HTML::Mason::Commands::session{CurrentUser} = $currentuser;
local $HTML::Mason::Commands::r = RT::Dashboard::FakeRequest->new;
+ my $HasResults = 0;
+
my $content = RunComponent(
'/Dashboards/Render.html',
- id => $dashboard->Id,
- Preview => 0,
+ id => $dashboard->Id,
+ Preview => 0,
+ HasResults => \$HasResults,
);
+ if ($subscription->SubValue('SuppressIfEmpty') && !$HasResults) {
+ $RT::Logger->debug("Not sending because there are no results and the subscription has SuppressIfEmpty");
+ return;
+ }
+
if ( RT->Config->Get('EmailDashboardRemove') ) {
for ( RT->Config->Get('EmailDashboardRemove') ) {
$content =~ s/$_//g;
diff --git a/share/html/Dashboards/Elements/ShowPortlet/dashboard b/share/html/Dashboards/Elements/ShowPortlet/dashboard
index 3c35ea8..84c6ef9 100644
--- a/share/html/Dashboards/Elements/ShowPortlet/dashboard
+++ b/share/html/Dashboards/Elements/ShowPortlet/dashboard
@@ -52,6 +52,7 @@ $Portlet
$Rows => 20
$Preview => 0
$Depth => 0
+$HasResults
</%args>
<%init>
my $current_dashboard;
@@ -76,12 +77,13 @@ Abort("Possible recursive dashboard detected.") if $Depth > 8;
<%perl>
for my $portlet (@panes) {
$m->comp($portlet->{portlet_type},
- Portlet => $portlet,
- Rows => $Rows,
- Preview => $Preview,
- Dashboard => $current_dashboard,
- Pane => $Pane,
- Depth => $Depth + 1,
+ Portlet => $portlet,
+ Rows => $Rows,
+ Preview => $Preview,
+ Dashboard => $current_dashboard,
+ Pane => $Pane,
+ Depth => $Depth + 1,
+ HasResults => $HasResults
);
}
</%perl>
diff --git a/share/html/Dashboards/Elements/ShowPortlet/search b/share/html/Dashboards/Elements/ShowPortlet/search
index d190295..2910c36 100644
--- a/share/html/Dashboards/Elements/ShowPortlet/search
+++ b/share/html/Dashboards/Elements/ShowPortlet/search
@@ -50,6 +50,7 @@ $Dashboard
$Portlet
$Rows => 20
$Preview => 0
+$HasResults
</%args>
<%init>
my @for_showsearch = $Dashboard->ShowSearchName($Portlet);
@@ -57,7 +58,8 @@ my @for_showsearch = $Dashboard->ShowSearchName($Portlet);
<& /Elements/ShowSearch,
@for_showsearch,
- Override => { Rows => $Rows },
- hideable => $Preview,
+ Override => { Rows => $Rows },
+ hideable => $Preview,
ShowCustomize => $Preview,
+ HasResults => $HasResults,
&>
diff --git a/share/html/Dashboards/Render.html b/share/html/Dashboards/Render.html
index 0306077..6078c3a 100644
--- a/share/html/Dashboards/Render.html
+++ b/share/html/Dashboards/Render.html
@@ -122,12 +122,13 @@ my $title = loc '[_1] Dashboard', $Dashboard->Name;
my $show_cb = sub {
my $pane = shift;
$m->comp('Elements/ShowPortlet/dashboard',
- Portlet => $Dashboard,
- Rows => $rows,
- Preview => $Preview,
- Dashboard => $Dashboard,
- Pane => $pane,
- Depth => 0,
+ Portlet => $Dashboard,
+ Rows => $rows,
+ Preview => $Preview,
+ Dashboard => $Dashboard,
+ Pane => $pane,
+ Depth => 0,
+ HasResults => $HasResults,
);
};
@@ -140,5 +141,6 @@ my $Refresh = $Preview
<%ARGS>
$id => undef
$Preview => 1
+$HasResults => undef
</%ARGS>
diff --git a/share/html/Dashboards/Subscription.html b/share/html/Dashboards/Subscription.html
index d55076d..f9f2c76 100644
--- a/share/html/Dashboards/Subscription.html
+++ b/share/html/Dashboards/Subscription.html
@@ -180,6 +180,12 @@
<input name="Recipient" id="Recipient" size="30" value="<%$fields{Recipient} ? $fields{Recipient} : ''%>" />
<div class="hints"><% loc("Leave blank to send to your current email address ([_1])", $session{'CurrentUser'}->EmailAddress) %></div>
</td></tr>
+
+<tr><td align="right"><input type="checkbox" id="SuppressIfEmpty" name="SuppressIfEmpty" value="1" <% $fields{'SuppressIfEmpty'} ? 'checked="checked"' : "" |n %> /></td>
+<td><label for="SuppressIfEmpty"><&|/l&>Suppress if empty (Check this to avoid sending mail if all searches have no results)</&></label><br />
+<input type="hidden"class="hidden" name="SuppressIfEmpty-Magic" value=1 />
+</td></tr>
+
</table>
</&>
</td>
@@ -225,6 +231,7 @@ my %fields = (
Recipient => '',
Fow => 1,
Counter => 0,
+ SuppressIfEmpty => 0,
);
# update any fields with the values from the subscription object
diff --git a/share/html/Elements/CollectionList b/share/html/Elements/CollectionList
index 99a2f64..454feab 100644
--- a/share/html/Elements/CollectionList
+++ b/share/html/Elements/CollectionList
@@ -159,6 +159,8 @@ while ( my $record = $Collection->Next ) {
Warning => $warning,
Classes => $Classes,
);
+
+ $$HasResults++ if $HasResults;
}
$m->out('</table>');
@@ -202,4 +204,5 @@ $ShowNavigation => 1
$ShowHeader => 1
$ShowEmpty => 0
$Query => 0
+$HasResults => undef
</%ARGS>
diff --git a/share/html/Elements/ShowSearch b/share/html/Elements/ShowSearch
index 52e628b..b355557 100644
--- a/share/html/Elements/ShowSearch
+++ b/share/html/Elements/ShowSearch
@@ -51,7 +51,7 @@
titleright => $customize ? loc('Edit') : '',
titleright_href => $customize,
hideable => $hideable &>
-<& $query_display_component, hideable => $hideable, %$ProcessedSearchArg, ShowNavigation => 0, Class => 'RT::Tickets' &>
+<& $query_display_component, hideable => $hideable, %$ProcessedSearchArg, ShowNavigation => 0, Class => 'RT::Tickets', HasResults => $HasResults &>
</&>
<%init>
my $search;
@@ -135,5 +135,6 @@ $SavedSearch => undef
%Override => ()
$IgnoreMissing => undef
$hideable => 1
-$ShowCustomize => 1
+$ShowCustomize => 1
+$HasResults => undef
</%ARGS>
diff --git a/t/mail/dashboard-empty.t b/t/mail/dashboard-empty.t
new file mode 100644
index 0000000..9e80e75
--- /dev/null
+++ b/t/mail/dashboard-empty.t
@@ -0,0 +1,88 @@
+use strict;
+use warnings;
+
+use RT::Test tests => undef;
+use RT::Dashboard::Mailer;
+
+my $root = RT::Test->load_or_create_user( Name => 'root' );
+
+my ( $baseurl, $m ) = RT::Test->started_ok;
+ok( $m->login, 'logged in' );
+
+sub create_dashboard {
+ my ($name, $suppress_if_empty) = @_;
+
+ # first, create and populate a "suppress if empty" dashboard
+ $m->get_ok('/Dashboards/Modify.html?Create=1');
+ $m->form_name('ModifyDashboard');
+ $m->field( 'Name' => $name );
+ $m->click_button( value => 'Create' );
+
+ $m->follow_link_ok( { text => 'Content' } );
+ my $form = $m->form_name('Dashboard-Searches-body');
+ my @input = $form->find_input('Searches-body-Available');
+
+ my ($dashboards_component) =
+ map { ( $_->possible_values )[1] }
+ grep { ( $_->value_names )[1] =~ /My Tickets/ } @input;
+ $form->value( 'Searches-body-Available' => $dashboards_component );
+ $m->click_button( name => 'add' );
+ $m->content_contains('Dashboard updated');
+
+ $m->follow_link_ok( { text => 'Subscription' } );
+ $m->form_name('SubscribeDashboard');
+ $m->field( 'Frequency' => 'daily' );
+ $m->field( 'Hour' => '06:00' );
+
+ $m->field( 'SuppressIfEmpty' => 1 ) if $suppress_if_empty;
+
+ $m->click_button( name => 'Save' );
+ $m->content_contains("Subscribed to dashboard $name");
+}
+
+create_dashboard('Suppress if empty', 1);
+
+diag 'no mail since the dashboard is suppressed if empty' if $ENV{'TEST_VERBOSE'};
+{
+ RT::Dashboard::Mailer->MailDashboards(All => 1);
+
+ my @mails = RT::Test->fetch_caught_mails;
+ is @mails, 0, "got no dashboard mail because the dashboard is empty";
+}
+
+create_dashboard('Always send', 0);
+
+diag 'one mail since one of two dashboards is suppressed if empty' if $ENV{'TEST_VERBOSE'};
+{
+ RT::Dashboard::Mailer->MailDashboards(All => 1);
+
+ my @mails = RT::Test->fetch_caught_mails;
+ is @mails, 1, "got a dashboard mail from the always-send dashboard";
+ my $content = parse_mail( $mails[0] )->bodyhandle->as_string;
+ like($content, qr/highest priority tickets I own/);
+}
+
+RT::Test->create_ticket(
+ Queue => 'General',
+ Subject => 'a search result!',
+ Owner => $root,
+);
+RT::Test->fetch_caught_mails; # dump ticket notifications
+
+diag 'two mails since both dashboards now have results' if $ENV{'TEST_VERBOSE'};
+{
+ RT::Dashboard::Mailer->MailDashboards(All => 1);
+
+ my @mails = RT::Test->fetch_caught_mails;
+ is @mails, 2, "got a dashboard mail from the always-send dashboard";
+
+ for my $mail (@mails) {
+ my $content = parse_mail( $mail )->bodyhandle->as_string;
+ like($content, qr/highest priority tickets I own/);
+ like($content, qr/a search result!/);
+ }
+}
+
+undef $m;
+done_testing;
+
-----------------------------------------------------------------------
More information about the rt-commit
mailing list