summaryrefslogtreecommitdiff
path: root/httemplate/view
diff options
context:
space:
mode:
authorMark Wells <mark@freeside.biz>2015-05-06 16:56:58 -0700
committerMark Wells <mark@freeside.biz>2015-05-06 16:56:58 -0700
commit3f36e519d061f6ca0102ba7887e9fee9b1bda874 (patch)
tree33cbdf4de40b085a17db44f2d259dd6a76ab7c2e /httemplate/view
parent9673c3dd4b15d76e4df583b1ec1df2e6964e948e (diff)
display N most recent emails in customer view, #30164
Diffstat (limited to 'httemplate/view')
-rwxr-xr-xhttemplate/view/cust_main/notes.html11
-rw-r--r--httemplate/view/cust_main/notes/email.html106
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>