Merge branch 'master' into vdom
This commit is contained in:
commit
3ea1f88cdc
|
@ -30,7 +30,13 @@
|
||||||
</td>
|
</td>
|
||||||
<td><a href='mailto:{{unbound l.to_address}}'>{{l.to_address}}</a></td>
|
<td><a href='mailto:{{unbound l.to_address}}'>{{l.to_address}}</a></td>
|
||||||
<td>{{l.email_type}}</td>
|
<td>{{l.email_type}}</td>
|
||||||
<td>{{l.reply_key}}</td>
|
<td>
|
||||||
|
{{#if l.post_url}}
|
||||||
|
<a href="{{l.post_url}}">{{l.reply_key}}</a>
|
||||||
|
{{else}}
|
||||||
|
{{l.reply_key}}
|
||||||
|
{{/if}}
|
||||||
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
{{else}}
|
{{else}}
|
||||||
<tr><td colspan="5">{{i18n 'admin.email.logs.none'}}</td></tr>
|
<tr><td colspan="5">{{i18n 'admin.email.logs.none'}}</td></tr>
|
||||||
|
|
|
@ -30,7 +30,13 @@
|
||||||
</td>
|
</td>
|
||||||
<td><a href='mailto:{{unbound l.to_address}}'>{{l.to_address}}</a></td>
|
<td><a href='mailto:{{unbound l.to_address}}'>{{l.to_address}}</a></td>
|
||||||
<td>{{l.email_type}}</td>
|
<td>{{l.email_type}}</td>
|
||||||
<td>{{l.skipped_reason}}</td>
|
<td>
|
||||||
|
{{#if l.post_url}}
|
||||||
|
<a href="{{l.post_url}}">{{l.skipped_reason}}</a>
|
||||||
|
{{else}}
|
||||||
|
{{l.skipped_reason}}
|
||||||
|
{{/if}}
|
||||||
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
{{else}}
|
{{else}}
|
||||||
<tr><td colspan="5">{{i18n 'admin.email.logs.none'}}</td></tr>
|
<tr><td colspan="5">{{i18n 'admin.email.logs.none'}}</td></tr>
|
||||||
|
|
|
@ -28,7 +28,7 @@
|
||||||
{{#if model.can_edit_name}}
|
{{#if model.can_edit_name}}
|
||||||
{{text-field value=newNameInput classNames="input-xxlarge"}}
|
{{text-field value=newNameInput classNames="input-xxlarge"}}
|
||||||
{{else}}
|
{{else}}
|
||||||
<span class='static'>{{name}}</span>
|
<span class='static'>{{model.name}}</span>
|
||||||
{{/if}}
|
{{/if}}
|
||||||
</div>
|
</div>
|
||||||
<div class='instructions'>
|
<div class='instructions'>
|
||||||
|
|
|
@ -9,9 +9,9 @@ createWidget('toggle-summary-description', {
|
||||||
|
|
||||||
if (attrs.topicWordCount) {
|
if (attrs.topicWordCount) {
|
||||||
const readingTime = Math.floor(attrs.topicWordCount / this.siteSettings.read_time_word_count);
|
const readingTime = Math.floor(attrs.topicWordCount / this.siteSettings.read_time_word_count);
|
||||||
return I18n.t('summary.description_time', { count: attrs.topicPostsCount, readingTime });
|
return I18n.t('summary.description_time', { replyCount: attrs.topicReplyCount, readingTime });
|
||||||
}
|
}
|
||||||
return I18n.t('summary.description', { count: attrs.topicPostsCount });
|
return I18n.t('summary.description', { replyCount: attrs.topicReplyCount });
|
||||||
},
|
},
|
||||||
|
|
||||||
html(attrs) {
|
html(attrs) {
|
||||||
|
|
|
@ -67,7 +67,7 @@ class Admin::EmailController < Admin::AdminController
|
||||||
private
|
private
|
||||||
|
|
||||||
def filter_email_logs(email_logs, params)
|
def filter_email_logs(email_logs, params)
|
||||||
email_logs = email_logs.includes(:user)
|
email_logs = email_logs.includes(:user, { post: :topic })
|
||||||
.references(:user)
|
.references(:user)
|
||||||
.order(created_at: :desc)
|
.order(created_at: :desc)
|
||||||
.offset(params[:offset] || 0)
|
.offset(params[:offset] || 0)
|
||||||
|
|
|
@ -15,7 +15,7 @@ module Jobs
|
||||||
user = User.find_by(id: args[:user_id])
|
user = User.find_by(id: args[:user_id])
|
||||||
to_address = args[:to_address].presence || user.try(:email).presence || "no_email_found"
|
to_address = args[:to_address].presence || user.try(:email).presence || "no_email_found"
|
||||||
|
|
||||||
set_skip_context(type, args[:user_id], to_address)
|
set_skip_context(type, args[:user_id], to_address, args[:post_id])
|
||||||
|
|
||||||
return skip(I18n.t("email_log.no_user", user_id: args[:user_id])) unless user
|
return skip(I18n.t("email_log.no_user", user_id: args[:user_id])) unless user
|
||||||
|
|
||||||
|
@ -44,8 +44,8 @@ module Jobs
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
def set_skip_context(type, user_id, to_address)
|
def set_skip_context(type, user_id, to_address, post_id)
|
||||||
@skip_context = { type: type, user_id: user_id, to_address: to_address }
|
@skip_context = { type: type, user_id: user_id, to_address: to_address, post_id: post_id }
|
||||||
end
|
end
|
||||||
|
|
||||||
NOTIFICATIONS_SENT_BY_MAILING_LIST ||= Set.new %w{posted replied mentioned group_mentioned quoted}
|
NOTIFICATIONS_SENT_BY_MAILING_LIST ||= Set.new %w{posted replied mentioned group_mentioned quoted}
|
||||||
|
@ -54,7 +54,7 @@ module Jobs
|
||||||
notification_type=nil, notification_data_hash=nil,
|
notification_type=nil, notification_data_hash=nil,
|
||||||
email_token=nil, to_address=nil)
|
email_token=nil, to_address=nil)
|
||||||
|
|
||||||
set_skip_context(type, user.id, to_address || user.email)
|
set_skip_context(type, user.id, to_address || user.email, post.try(:id))
|
||||||
|
|
||||||
return skip_message(I18n.t("email_log.anonymous_user")) if user.anonymous?
|
return skip_message(I18n.t("email_log.anonymous_user")) if user.anonymous?
|
||||||
return skip_message(I18n.t("email_log.suspended_not_pm")) if user.suspended? && type != :user_private_message
|
return skip_message(I18n.t("email_log.suspended_not_pm")) if user.suspended? && type != :user_private_message
|
||||||
|
@ -142,6 +142,7 @@ module Jobs
|
||||||
email_type: @skip_context[:type],
|
email_type: @skip_context[:type],
|
||||||
to_address: @skip_context[:to_address],
|
to_address: @skip_context[:to_address],
|
||||||
user_id: @skip_context[:user_id],
|
user_id: @skip_context[:user_id],
|
||||||
|
post_id: @skip_context[:post_id],
|
||||||
skipped: true,
|
skipped: true,
|
||||||
skipped_reason: "[UserEmail] #{reason}",
|
skipped_reason: "[UserEmail] #{reason}",
|
||||||
)
|
)
|
||||||
|
|
|
@ -7,11 +7,21 @@ class EmailLogSerializer < ApplicationSerializer
|
||||||
:user_id,
|
:user_id,
|
||||||
:created_at,
|
:created_at,
|
||||||
:skipped,
|
:skipped,
|
||||||
:skipped_reason
|
:skipped_reason,
|
||||||
|
:post_url
|
||||||
|
|
||||||
has_one :user, serializer: BasicUserSerializer, embed: :objects
|
has_one :user, serializer: BasicUserSerializer, embed: :objects
|
||||||
|
|
||||||
def include_skipped_reason?
|
def include_skipped_reason?
|
||||||
object.skipped
|
object.skipped
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def post_url
|
||||||
|
object.post.url
|
||||||
|
end
|
||||||
|
|
||||||
|
def include_post_url?
|
||||||
|
object.post.present?
|
||||||
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
|
@ -299,7 +299,7 @@ en:
|
||||||
other: "This topic has <b>{{count}}</b> posts awaiting approval"
|
other: "This topic has <b>{{count}}</b> posts awaiting approval"
|
||||||
|
|
||||||
confirm: "Save Changes"
|
confirm: "Save Changes"
|
||||||
delete_prompt: "Are you sure you want to delete <b>%{username}</b>? This will remove all of their posts and block their email and ip address."
|
delete_prompt: "Are you sure you want to delete <b>%{username}</b>? This will remove all of their posts and block their email and IP address."
|
||||||
|
|
||||||
approval:
|
approval:
|
||||||
title: "Post Needs Approval"
|
title: "Post Needs Approval"
|
||||||
|
@ -804,8 +804,8 @@ en:
|
||||||
|
|
||||||
summary:
|
summary:
|
||||||
enabled_description: "You're viewing a summary of this topic: the most interesting posts as determined by the community."
|
enabled_description: "You're viewing a summary of this topic: the most interesting posts as determined by the community."
|
||||||
description: "There are <b>{{count}}</b> replies."
|
description: "There are <b>{{replyCount}}</b> replies."
|
||||||
description_time: "There are <b>{{count}}</b> replies with an estimated read time of <b>{{readingTime}} minutes</b>."
|
description_time: "There are <b>{{replyCount}}</b> replies with an estimated read time of <b>{{readingTime}} minutes</b>."
|
||||||
enable: 'Summarize This Topic'
|
enable: 'Summarize This Topic'
|
||||||
disable: 'Show All Posts'
|
disable: 'Show All Posts'
|
||||||
|
|
||||||
|
|
|
@ -6,8 +6,8 @@ require "json"
|
||||||
|
|
||||||
module ImportExport
|
module ImportExport
|
||||||
|
|
||||||
def self.export_category(category_id)
|
def self.export_category(category_id, filename=nil)
|
||||||
ImportExport::CategoryExporter.new(category_id).perform.save_to_file
|
ImportExport::CategoryExporter.new(category_id).perform.save_to_file(filename)
|
||||||
end
|
end
|
||||||
|
|
||||||
def self.import_category(filename)
|
def self.import_category(filename)
|
||||||
|
|
|
@ -135,12 +135,12 @@ class DiscourseCLI < Thor
|
||||||
end
|
end
|
||||||
|
|
||||||
desc "export_category", "Export a category, all its topics, and all users who posted in those topics"
|
desc "export_category", "Export a category, all its topics, and all users who posted in those topics"
|
||||||
def export_category(category_id)
|
def export_category(category_id, filename=nil)
|
||||||
raise "Category id argument is missing!" unless category_id
|
raise "Category id argument is missing!" unless category_id
|
||||||
|
|
||||||
load_rails
|
load_rails
|
||||||
load_import_export
|
load_import_export
|
||||||
ImportExport.export_category(category_id)
|
ImportExport.export_category(category_id, filename)
|
||||||
puts "", "Done", ""
|
puts "", "Done", ""
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue