diff options
author | Mark Wells <mark@freeside.biz> | 2015-05-06 16:56:58 -0700 |
---|---|---|
committer | Mark Wells <mark@freeside.biz> | 2015-05-06 16:56:58 -0700 |
commit | 3f36e519d061f6ca0102ba7887e9fee9b1bda874 (patch) | |
tree | 33cbdf4de40b085a17db44f2d259dd6a76ab7c2e /httemplate/view | |
parent | 9673c3dd4b15d76e4df583b1ec1df2e6964e948e (diff) |
display N most recent emails in customer view, #30164
Diffstat (limited to 'httemplate/view')
-rwxr-xr-x | httemplate/view/cust_main/notes.html | 11 | ||||
-rw-r--r-- | httemplate/view/cust_main/notes/email.html | 106 |
2 files changed, 108 insertions, 9 deletions
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")) { <BR> -% 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 &> +<BR> % } <%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) ) { +<STYLE type="text/css"> +#cust_msg td.grid a:link {text-decoration: none} +#cust_msg td.grid a:visited {text-decoration: none} +#cust_msg td.grid a:hover {text-decoration: underline} +#cust_msg th {background-color: #cccccc} +.row0 {background-color: #eeeeee} +.row1 {background-color: #ffffff} +</STYLE> +<DIV id="cust_msg"> +<FONT SIZE="+1"> <% mt('Email sent to this customer') %> </FONT><BR> +% if ($maxrecords < $total) { +<% mt('Showing [_1] most recent of [quant,_2,total message]', $maxrecords, $total) %> + <A HREF="<%$p%>search/cust_msg.html?custnum=<%$custnum%>"> + <i>(<% mt('view all') %>)</i> + </A> +% } else { +<% mt('[quant,_1,total message]', $total) %> +% } +<BR> +<& /elements/table-grid.html &> + <TR> + <TH CLASS="grid"><% mt('Date') %></TH> + <TH CLASS="grid"><% mt('Type') %></TH> + <TH CLASS="grid"><% mt('Destination') %></TH> + <TH CLASS="grid"><% mt('Subject') %></TH> + <TH CLASS="grid"></TH> + </TR> +% my $i = 0; +% foreach my $row (@rows) { +% my $onclick = $sub_popup_link->($row); +% my $link = qq!<A onclick="$onclick">!; + <TR CLASS="row<%$i%>"> + <TD CLASS="grid"><% $link %> + <% $row->_date ? time2str('%Y-%m-%d %T', $row->_date) : '' %> + </A></TD> + <TD CLASS="grid" STYLE="color: <% $typecolor->($row) %>"><% $link %> + <% ucfirst($row->msgtype) || $row->msgname %> + </A></TD> + <TD CLASS="grid"><% $link %> + <% join('<BR>', split(/,\s*/, $row->env_to)) %> + </A></TD> + <TD CLASS="grid" STYLE="color: <% $statuscolor->($row) %>"> + <% $row->status %> + </TD> + <TD CLASS="grid"> + <% $row->error |h %> + </TD> + </TR> +% $i = 1 - $i; +% } +</TABLE> +</DIV> +% } +<%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} }; + +</%init> |