FEATURE: improve flags reminder email

This commit is contained in:
Régis Hanol 2014-09-23 18:37:31 +02:00
parent f6ee235611
commit 7bc223ef7c
4 changed files with 37 additions and 29 deletions

View File

@ -7,24 +7,33 @@ class PendingFlagsMailer < ActionMailer::Base
def notify def notify
return unless SiteSetting.contact_email return unless SiteSetting.contact_email
@posts, users = FlagQuery.flagged_posts_report(Discourse.system_user, 'active', 0, 20) @posts, @topics, @users = FlagQuery.flagged_posts_report(Discourse.system_user, 'active', 0, 20)
@posts.each do |post| # Note: post is a Hash, not a Post. @posts.each do |post| # Note: post is a Hash, not a Post.
topic = @topics.select { |t| t[:id] == post[:topic_id] }.first
post[:title] = topic[:title]
post[:url] = "#{Discourse.base_url}#{Post.url(topic[:slug], topic[:id], post[:post_number])}"
post[:user] = @users.select { |u| u[:id] == post[:user_id] }.first
counts = flag_reason_counts(post) counts = flag_reason_counts(post)
post[:reason_counts] = counts.map do |reason, count| post[:reason_counts] = counts.map { |reason, count| "#{I18n.t('post_action_types.' + reason.to_s + '.title')}: #{count}" }.join(', ')
"#{I18n.t('post_action_types.' + reason.to_s + '.title')}: #{count}" post[:html_reason_counts] = counts.map { |reason, count| "<strong>#{I18n.t('post_action_types.' + reason.to_s + '.title')}:</strong> #{count}" }.join(', ')
end.join(', ')
end end
@hours = SiteSetting.notify_about_flags_after @hours = SiteSetting.notify_about_flags_after
build_email( SiteSetting.contact_email, subject = "[#{SiteSetting.title}] " + I18n.t('flags_reminder.subject_template', { count: PostAction.flagged_posts_count })
subject: "[#{SiteSetting.title}] " + I18n.t('flags_reminder.subject_template', {count: PostAction.flagged_posts_count}) ) build_email(SiteSetting.contact_email, subject: subject)
end end
private private
def flag_reason_counts(post) def flag_reason_counts(post)
post[:post_actions].inject({}) {|h,v| h[v[:name_key]] ||= 0; h[v[:name_key]] += 1; h } post[:post_actions].inject({}) do |h,v|
h[v[:name_key]] ||= 0
h[v[:name_key]] += 1
h
end
end end
end end

View File

@ -351,7 +351,6 @@ class User < ActiveRecord::Base
"//www.gravatar.com/avatar/#{email_hash}.png?s={size}&r=pg&d=identicon" "//www.gravatar.com/avatar/#{email_hash}.png?s={size}&r=pg&d=identicon"
end end
# Don't pass this up to the client - it's meant for server side use # Don't pass this up to the client - it's meant for server side use
# This is used in # This is used in
# - self oneboxes in open graph data # - self oneboxes in open graph data

View File

@ -1,27 +1,27 @@
<p> <p>
<%=t 'flags_reminder.flags_were_submitted', count: @hours %> <%= t 'flags_reminder.flags_were_submitted', count: @hours %>
<a href="<%= Discourse.base_url + '/admin/flags/active' %>"><%=t 'flags_reminder.please_review' %></a> <a href="<%= Discourse.base_url + '/admin/flags/active' %>"><%= t 'flags_reminder.please_review' %></a>
</p> </p>
<hr/> <table style="border-collapse: collapse; border-spacing: 0;">
<table>
<tr>
<td></td>
<td><%=t 'flags_reminder.post_number' %></td>
<td></td>
</tr>
<% @posts.each do |post| %> <% @posts.each do |post| %>
<tr> <tr style="border-bottom: 1px solid #e9e9e9; border-top: 1px solid #e9e9e9;">
<td><%= link_to post[:title], "#{Discourse.base_url}/t/#{post[:topic_slug]}/#{post[:topic_id]}/#{post[:post_number]}" %></td> <td style="width: 25px; padding: 8px 0 0 0; text-align: center; vertical-align: top;">
<td align="center"><%= post[:post_number] %></td> <a href='<%= Discourse.base_url + "/admin/users/#{post[:user].username.downcase}" %>'>
<td><%= post[:reason_counts] %></td> <img width="25" height="25" src="<%= Discourse.base_url + post[:user].avatar_template.gsub("{size}", "45") %>" title="<%= post[:user].username %>">
</a>
</td>
<td style="padding: 8px; word-wrap: break-word; vertical-align: top;">
<h3 style="margin: 0 !important;"><%= link_to post[:title], post[:url] %></h3>
<p style="margin: 0 2px;"><%= raw post[:excerpt] %></p>
</td>
<td style="vertical-align: middle; min-width: 120px;">
<%= raw post[:html_reason_counts] %>
</td>
</tr> </tr>
<% end %> <% end %>
</table> </table>
<hr/>
<p> <p>
<%=t 'flags_reminder.how_to_disable' %> <%= t 'flags_reminder.how_to_disable' %>
</p> </p>

View File

@ -3,7 +3,7 @@
<%= Discourse.base_url + '/admin/flags/active' %> <%= Discourse.base_url + '/admin/flags/active' %>
<% @posts.each do |post| %> <% @posts.each do |post| %>
<%= post[:title] %>: <%=t 'flags_reminder.post_number' %> <%= post[:post_number] %> - <%= post[:reason_counts] %> - <%= post[:title] %>: <%=t 'flags_reminder.post_number' %> <%= post[:post_number] %> - <%= post[:reason_counts] %>
<% end %> <% end %>
<%=t 'flags_reminder.how_to_disable' %> <%=t 'flags_reminder.how_to_disable' %>