From: Mark Wells Date: Wed, 6 May 2015 23:43:45 +0000 (-0700) Subject: display N most recent emails in customer view, #30164 X-Git-Url: http://git.freeside.biz/gitweb/?p=freeside.git;a=commitdiff_plain;h=95606bc9db41352511c886773a311f2166cc6cf2 display N most recent emails in customer view, #30164 --- diff --git a/httemplate/pref/pref-process.html b/httemplate/pref/pref-process.html index cd400ee3f..68f0f6e2f 100644 --- a/httemplate/pref/pref-process.html +++ b/httemplate/pref/pref-process.html @@ -55,6 +55,7 @@ unless ( $error ) { # if ($access_user) { enable_fuzzy_on_exact disable_html_editor disable_enter_submit_onetimecharge enable_mask_clipboard_hack dashboard_customers + customer_view_emails email_address snom-ip snom-username snom-password vonage-fromnumber vonage-username vonage-password diff --git a/httemplate/pref/pref.html b/httemplate/pref/pref.html index 5e722b043..ffc90fde8 100644 --- a/httemplate/pref/pref.html +++ b/httemplate/pref/pref.html @@ -151,6 +151,15 @@ Interface + + How many recent outbound emails to show in customer view + + + + + + +
diff --git a/httemplate/search/cust_msg.html b/httemplate/search/cust_msg.html index d5b865c3b..401f52ebb 100644 --- a/httemplate/search/cust_msg.html +++ b/httemplate/search/cust_msg.html @@ -47,7 +47,7 @@ ], 'html_init' => $html_init, 'really_disable_download' => 1, - @_ #why? + 'order_by' => '_date DESC', &> <%init> #hmm... diff --git a/httemplate/search/elements/search.html b/httemplate/search/elements/search.html index 62a0e4786..64f3a665f 100644 --- a/httemplate/search/elements/search.html +++ b/httemplate/search/elements/search.html @@ -386,10 +386,7 @@ unless ( $type =~ /^(csv|xml|\w*.xls)$/) { } #order by override -my $order_by = ''; -#if ( $cgi->param('order_by') =~ /^([\w\, ]+)$/ ) { -# $order_by = $1; -#} +my $order_by = $opt{order_by} || ''; $order_by = $cgi->param('order_by') if $cgi->param('order_by'); # run the query @@ -415,6 +412,8 @@ if ( ref($opt{query}) ) { } } + $opt{query}->{'order_by'} .= " $limit"; + } elsif (ref($opt{query}) eq 'ARRAY') { @query = @{ $opt{query} }; } else { @@ -434,7 +433,7 @@ if ( ref($opt{query}) ) { } @query ], - 'order_by' => $opt{order_by}. " ". $limit, + #'order_by' => $opt{order_by}. " ". $limit, ) ]; } else { diff --git a/httemplate/view/cust_main/notes.html b/httemplate/view/cust_main/notes.html index 1cd6e0970..deba956ae 100755 --- a/httemplate/view/cust_main/notes.html +++ b/httemplate/view/cust_main/notes.html @@ -77,15 +77,8 @@ % if ( $curuser->access_right('View email logs') % and FS::cust_msg->count("custnum = $custnum")) {
-% if (!$cgi->param('order_by')) { -% my $order_by = '_date'; -% $order_by .= ' DESC' if $curuser->option('history_order') eq 'newest'; -% $cgi->param('order_by', $order_by); -% } -<& /search/cust_msg.html, - nohtmlheader => 1, - html_init => mt('Mail sent to this customer: '), -&> +<& notes/email.html, 'cust_main' => $cust_main &> +
% } <%init> diff --git a/httemplate/view/cust_main/notes/email.html b/httemplate/view/cust_main/notes/email.html new file mode 100644 index 000000000..da2c352b6 --- /dev/null +++ b/httemplate/view/cust_main/notes/email.html @@ -0,0 +1,106 @@ +% if ( scalar(@rows) ) { + +
+ <% mt('Email sent to this customer') %>
+% if ($maxrecords < $total) { +<% mt('Showing [_1] most recent of [quant,_2,total message]', $maxrecords, $total) %> + + (<% mt('view all') %>) + +% } else { +<% mt('[quant,_1,total message]', $total) %> +% } +
+<& /elements/table-grid.html &> + + <% mt('Date') %> + <% mt('Type') %> + <% mt('Destination') %> + <% mt('Subject') %> + + +% my $i = 0; +% foreach my $row (@rows) { +% my $onclick = $sub_popup_link->($row); +% my $link = qq!!; + + <% $link %> + <% $row->_date ? time2str('%Y-%m-%d %T', $row->_date) : '' %> + + <% $link %> + <% ucfirst($row->msgtype) || $row->msgname %> + + <% $link %> + <% join('
', split(/,\s*/, $row->env_to)) %> + + + <% $row->status %> + + + <% $row->error |h %> + + +% $i = 1 - $i; +% } + +
+% } +<%init> +my %opt = @_; + +my $curuser = $FS::CurrentUser::CurrentUser; +my $cust_main = $opt{'cust_main'} + or die "cust_main required"; +my $custnum = $cust_main->custnum; + +my $where = "WHERE cust_msg.custnum = $custnum"; +my $maxrecords = $curuser->option('customer_view_emails') || 10; + +my $order_by = '_date DESC'; + +my $query = { + 'table' => 'cust_msg', + 'select' => join(', ', + 'cust_msg.*', + 'msg_template.msgname', + ), + 'addl_from' => ' LEFT JOIN msg_template USING ( msgnum ) ', + 'hashref' => {}, + 'extra_sql' => $where, + 'order_by' => "ORDER BY $order_by LIMIT $maxrecords", +}; +my $count_query = "SELECT COUNT(*) FROM cust_msg $where"; + +my @rows = qsearch($query); +my $total = FS::Record->scalar_sql($count_query); + +my $sub_popup_link = sub { + my $custmsgnum = $_[0]->custmsgnum; + include('/elements/popup_link_onclick.html', + 'action' => $p. 'view/cust_msg.html?' . $custmsgnum, + 'actionlabel' => 'Message detail', + 'width' => 680, + 'height' => 550, + ); +}; + +my %color = ( + 'failed' => '#FF0000', + 'sent' => '#000000', + + 'invoice' => '#00CC00', + 'receipt' => '#0000CC', + 'admin' => '#CC0000', + '' => '#000000', +); +my $statuscolor = sub { $color{$_[0]->status} }; +my $typecolor = sub { $color{$_[0]->msgtype} }; + +