FEATURE: improve flags reminder email
This commit is contained in:
parent
f6ee235611
commit
7bc223ef7c
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -3,25 +3,25 @@
|
||||||
<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>
|
|
@ -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' %>
|
Loading…
Reference in New Issue