FEATURE: site setting enable_mentions to turn on/off mentions

This commit is contained in:
Joffrey JAFFEUX 2017-12-07 11:30:47 -05:00 committed by Robin Ward
parent 3e4f02a180
commit fd99e1ef56
6 changed files with 38 additions and 20 deletions

View File

@ -77,6 +77,7 @@ export default Ember.Component.extend({
const $input = this.$('.d-editor-input'); const $input = this.$('.d-editor-input');
const $preview = this.$('.d-editor-preview-wrapper'); const $preview = this.$('.d-editor-preview-wrapper');
if (this.siteSettings.enable_mentions) {
$input.autocomplete({ $input.autocomplete({
template: findRawTemplate('user-selector-autocomplete'), template: findRawTemplate('user-selector-autocomplete'),
dataSource: term => userSearch({ dataSource: term => userSearch({
@ -87,6 +88,7 @@ export default Ember.Component.extend({
key: "@", key: "@",
transformComplete: v => v.username || v.name transformComplete: v => v.username || v.name
}); });
}
if (this._enableAdvancedEditorPreviewSync()) { if (this._enableAdvancedEditorPreviewSync()) {
this._initInputPreviewSync($input, $preview); this._initInputPreviewSync($input, $preview);

View File

@ -154,6 +154,7 @@ export function applySearchAutocomplete($input, siteSettings, appEvents, options
afterComplete afterComplete
}, options)); }, options));
if (Discourse.SiteSettings.enable_mentions) {
$input.autocomplete(_.merge({ $input.autocomplete(_.merge({
template: findRawTemplate('user-selector-autocomplete'), template: findRawTemplate('user-selector-autocomplete'),
key: "@", key: "@",
@ -163,4 +164,5 @@ export function applySearchAutocomplete($input, siteSettings, appEvents, options
dataSource: term => userSearch({ term, includeGroups: true }), dataSource: term => userSearch({ term, includeGroups: true }),
afterComplete afterComplete
}, options)); }, options));
}
}; };

View File

@ -38,6 +38,10 @@ function addMention(buffer, matches, state) {
} }
export function setup(helper) { export function setup(helper) {
helper.registerOptions((opts, siteSettings) => {
opts.features.mentions = !!siteSettings.enable_mentions;
});
helper.registerPlugin(md => { helper.registerPlugin(md => {
const rule = { const rule = {

View File

@ -1283,6 +1283,7 @@ en:
newuser_max_replies_per_topic: "Maximum number of replies a new user can make in a single topic until someone replies to them." newuser_max_replies_per_topic: "Maximum number of replies a new user can make in a single topic until someone replies to them."
max_mentions_per_post: "Maximum number of @name notifications anyone can use in a post." max_mentions_per_post: "Maximum number of @name notifications anyone can use in a post."
max_users_notified_per_group_mention: "Maximum number of users that may receive a notification if a group is mentioned (if threshold is met no notifications will be raised)" max_users_notified_per_group_mention: "Maximum number of users that may receive a notification if a group is mentioned (if threshold is met no notifications will be raised)"
enable_mentions: "Allow users to mention other users."
create_thumbnails: "Create thumbnails and lightbox images that are too large to fit in a post." create_thumbnails: "Create thumbnails and lightbox images that are too large to fit in a post."

View File

@ -537,6 +537,9 @@ posting:
default: 1 default: 1
client: true client: true
post_undo_action_window_mins: 10 post_undo_action_window_mins: 10
enable_mentions:
default: true
client: true
max_mentions_per_post: 10 max_mentions_per_post: 10
max_users_notified_per_group_mention: 100 max_users_notified_per_group_mention: 100
newuser_max_replies_per_topic: 3 newuser_max_replies_per_topic: 3

View File

@ -8,6 +8,7 @@ QUnit.module("lib:pretty-text");
const rawOpts = { const rawOpts = {
siteSettings: { siteSettings: {
enable_emoji: true, enable_emoji: true,
enable_mentions: true,
emoji_set: 'emoji_one', emoji_set: 'emoji_one',
highlighted_languages: 'json|ruby|javascript', highlighted_languages: 'json|ruby|javascript',
default_code_lang: 'auto', default_code_lang: 'auto',
@ -282,7 +283,6 @@ QUnit.test("Quotes", assert => {
}); });
QUnit.test("Mentions", assert => { QUnit.test("Mentions", assert => {
const alwaysTrue = { mentionLookup: (function() { return "user"; }) }; const alwaysTrue = { mentionLookup: (function() { return "user"; }) };
assert.cookedOptions("Hello @sam", alwaysTrue, assert.cookedOptions("Hello @sam", alwaysTrue,
@ -370,6 +370,12 @@ QUnit.test("Mentions", assert => {
"it allows mentions within HTML tags"); "it allows mentions within HTML tags");
}); });
QUnit.test("Mentions - disabled", assert => {
assert.cookedOptions("@eviltrout",
{ siteSettings : { enable_mentions: false }},
"<p>@eviltrout</p>");
});
QUnit.test("Category hashtags", assert => { QUnit.test("Category hashtags", assert => {
const alwaysTrue = { categoryHashtagLookup: (function() { return ["http://test.discourse.org/category-hashtag", "category-hashtag"]; }) }; const alwaysTrue = { categoryHashtagLookup: (function() { return ["http://test.discourse.org/category-hashtag", "category-hashtag"]; }) };