mirror of
https://github.com/discourse/discourse.git
synced 2025-01-18 13:43:16 +08:00
REFACTOR: Remove Ember.get
This commit is contained in:
parent
89f602f66b
commit
640a05c4ee
|
@ -1,3 +1,4 @@
|
|||
import { get } from "@ember/object";
|
||||
import { isEmpty } from "@ember/utils";
|
||||
import { or, gt } from "@ember/object/computed";
|
||||
import RestModel from "discourse/models/rest";
|
||||
|
@ -243,7 +244,7 @@ const Theme = RestModel.extend({
|
|||
@computed("childThemes.[]")
|
||||
child_theme_ids(childThemes) {
|
||||
if (childThemes) {
|
||||
return childThemes.map(theme => Ember.get(theme, "id"));
|
||||
return childThemes.map(theme => get(theme, "id"));
|
||||
}
|
||||
},
|
||||
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import { get } from "@ember/object";
|
||||
import Route from "@ember/routing/route";
|
||||
import { ajax } from "discourse/lib/ajax";
|
||||
import Badge from "discourse/models/badge";
|
||||
|
@ -5,7 +6,7 @@ import showModal from "discourse/lib/show-modal";
|
|||
|
||||
export default Route.extend({
|
||||
serialize(m) {
|
||||
return { badge_id: Ember.get(m, "id") || "new" };
|
||||
return { badge_id: get(m, "id") || "new" };
|
||||
},
|
||||
|
||||
model(params) {
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import { get } from "@ember/object";
|
||||
import DiscourseRoute from "discourse/routes/discourse";
|
||||
import AdminUser from "admin/models/admin-user";
|
||||
|
||||
|
@ -10,7 +11,7 @@ export default DiscourseRoute.extend({
|
|||
},
|
||||
|
||||
model(params) {
|
||||
return AdminUser.find(Ember.get(params, "user_id"));
|
||||
return AdminUser.find(get(params, "user_id"));
|
||||
},
|
||||
|
||||
renderTemplate() {
|
||||
|
|
|
@ -1,10 +1,11 @@
|
|||
import { get } from "@ember/object";
|
||||
import DiscourseRoute from "discourse/routes/discourse";
|
||||
|
||||
export default DiscourseRoute.extend({
|
||||
model(params) {
|
||||
return this.store.findAll(
|
||||
"web-hook-event",
|
||||
Ember.get(params, "web_hook_id")
|
||||
get(params, "web_hook_id")
|
||||
);
|
||||
},
|
||||
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import { get } from "@ember/object";
|
||||
import { isEmpty } from "@ember/utils";
|
||||
import DiscourseRoute from "discourse/routes/discourse";
|
||||
|
||||
|
@ -10,7 +11,7 @@ export default DiscourseRoute.extend({
|
|||
if (params.web_hook_id === "new") {
|
||||
return this.store.createRecord("web-hook");
|
||||
}
|
||||
return this.store.find("web-hook", Ember.get(params, "web_hook_id"));
|
||||
return this.store.find("web-hook", get(params, "web_hook_id"));
|
||||
},
|
||||
|
||||
setupController(controller, model) {
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
import { get } from "discourse-common/lib/raw-handlebars";
|
||||
import { rawGet } from "discourse-common/lib/raw-handlebars";
|
||||
|
||||
export function htmlHelper(fn) {
|
||||
return Ember.Helper.helper(function(...args) {
|
||||
|
@ -39,7 +39,7 @@ function resolveParams(ctx, options) {
|
|||
) {
|
||||
params[k] = hash[k];
|
||||
} else if (type === "ID" || type === "PathExpression") {
|
||||
params[k] = get(ctx, hash[k], options);
|
||||
params[k] = rawGet(ctx, hash[k], options);
|
||||
}
|
||||
});
|
||||
} else {
|
||||
|
@ -59,7 +59,7 @@ export function registerUnbound(name, fn) {
|
|||
options.types &&
|
||||
(options.types[i] === "ID" || options.types[i] === "PathExpression")
|
||||
) {
|
||||
properties[i] = get(this, properties[i], options);
|
||||
properties[i] = rawGet(this, properties[i], options);
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -1,3 +1,5 @@
|
|||
import { get } from "@ember/object";
|
||||
|
||||
// This is a mechanism for quickly rendering templates which is Ember aware
|
||||
// templates are highly compatible with Ember so you don't need to worry about calling "get"
|
||||
// and computed properties function, additionally it uses stringParams like Ember does
|
||||
|
@ -24,7 +26,7 @@ RawHandlebars.helpers["get"] = function(context, options) {
|
|||
context = context.slice(context.indexOf(".") + 1);
|
||||
}
|
||||
|
||||
return val === undefined ? Ember.get(firstContext, context) : val;
|
||||
return val === undefined ? get(firstContext, context) : val;
|
||||
};
|
||||
|
||||
// adds compatability so this works with stringParams
|
||||
|
@ -45,7 +47,7 @@ RawHandlebars.registerHelper("each", function(
|
|||
contextName,
|
||||
options
|
||||
) {
|
||||
var list = Ember.get(this, contextName);
|
||||
var list = get(this, contextName);
|
||||
var output = [];
|
||||
var innerContext = objectCreate(this);
|
||||
for (var i = 0; i < list.length; i++) {
|
||||
|
@ -178,7 +180,7 @@ RawHandlebars.get = function(ctx, property, options) {
|
|||
? view.getStream(property).value()
|
||||
: view.getAttr(property);
|
||||
} else {
|
||||
return Ember.get(ctx, property);
|
||||
return get(ctx, property);
|
||||
}
|
||||
};
|
||||
|
||||
|
@ -194,7 +196,7 @@ export function compile() {
|
|||
return RawHandlebars.compile.apply(this, arguments);
|
||||
}
|
||||
|
||||
export function get() {
|
||||
export function rawGet() {
|
||||
return RawHandlebars.get.apply(this, arguments);
|
||||
}
|
||||
|
||||
|
|
|
@ -11,7 +11,10 @@ var define, requirejs;
|
|||
default: Ember.Controller,
|
||||
inject: Ember.inject.controller
|
||||
},
|
||||
"@ember/object": { default: Ember.Object },
|
||||
"@ember/object": {
|
||||
default: Ember.Object,
|
||||
get: Ember.get
|
||||
},
|
||||
"@ember/object/computed": {
|
||||
default: Ember.computed,
|
||||
alias: Ember.computed.alias,
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import { get } from "@ember/object";
|
||||
import { isEmpty } from "@ember/utils";
|
||||
import { next } from "@ember/runloop";
|
||||
import Component from "@ember/component";
|
||||
|
@ -57,7 +58,7 @@ export default Component.extend({
|
|||
|
||||
actions: {
|
||||
chooseMessage(message) {
|
||||
const messageId = Ember.get(message, "id");
|
||||
const messageId = get(message, "id");
|
||||
this.set("selectedTopicId", messageId);
|
||||
next(() => $(`#choose-message-${messageId}`).prop("checked", "true"));
|
||||
return false;
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import { get } from "@ember/object";
|
||||
import Component from "@ember/component";
|
||||
import computed from "ember-addons/ember-computed-decorators";
|
||||
import { categoryBadgeHTML } from "discourse/helpers/category-link";
|
||||
|
@ -35,7 +36,7 @@ export default Component.extend({
|
|||
|
||||
if (
|
||||
category &&
|
||||
Ember.get(category, "id") ===
|
||||
get(category, "id") ===
|
||||
Discourse.Site.currentProp("uncategorized_category_id")
|
||||
) {
|
||||
category = null;
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import { get } from "@ember/object";
|
||||
import { isEmpty } from "@ember/utils";
|
||||
import { htmlHelper } from "discourse-common/lib/helpers";
|
||||
import { avatarImg } from "discourse/lib/utilities";
|
||||
|
@ -8,6 +9,6 @@ export default htmlHelper((user, size) => {
|
|||
return "<div class='avatar-placeholder'></div>";
|
||||
}
|
||||
|
||||
const avatarTemplate = Ember.get(user, "avatar_template");
|
||||
const avatarTemplate = get(user, "avatar_template");
|
||||
return avatarImg(addExtraUserClasses(user, { size, avatarTemplate }));
|
||||
});
|
||||
|
|
|
@ -1,10 +1,9 @@
|
|||
import { get } from "@ember/object";
|
||||
import { registerUnbound } from "discourse-common/lib/helpers";
|
||||
import { isRTL } from "discourse/lib/text-direction";
|
||||
import { iconHTML } from "discourse-common/lib/icon-library";
|
||||
|
||||
var get = Ember.get,
|
||||
escapeExpression = Handlebars.Utils.escapeExpression;
|
||||
|
||||
let escapeExpression = Handlebars.Utils.escapeExpression;
|
||||
let _renderer = defaultCategoryLinkRenderer;
|
||||
|
||||
export function replaceCategoryLinkRenderer(fn) {
|
||||
|
@ -32,7 +31,7 @@ export function categoryBadgeHTML(category, opts) {
|
|||
if (
|
||||
!category ||
|
||||
(!opts.allowUncategorized &&
|
||||
Ember.get(category, "id") ===
|
||||
get(category, "id") ===
|
||||
Discourse.Site.currentProp("uncategorized_category_id") &&
|
||||
Discourse.SiteSettings.suppress_uncategorized_badge)
|
||||
)
|
||||
|
|
|
@ -1,10 +1,11 @@
|
|||
import { get } from "@ember/object";
|
||||
export function formatCurrency([reviewable, fieldId]) {
|
||||
// The field `category_id` corresponds to `category`
|
||||
if (fieldId === "category_id") {
|
||||
fieldId = "category.id";
|
||||
}
|
||||
|
||||
let value = Ember.get(reviewable, fieldId);
|
||||
let value = get(reviewable, fieldId);
|
||||
|
||||
// If it's an array, say tags, make a copy so we aren't mutating the original
|
||||
if (Array.isArray(value)) {
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import { get } from "@ember/object";
|
||||
import { registerUnbound } from "discourse-common/lib/helpers";
|
||||
import { avatarImg, formatUsername } from "discourse/lib/utilities";
|
||||
|
||||
|
@ -30,9 +31,9 @@ function renderAvatar(user, options) {
|
|||
options = options || {};
|
||||
|
||||
if (user) {
|
||||
const name = Ember.get(user, options.namePath || "name");
|
||||
const username = Ember.get(user, options.usernamePath || "username");
|
||||
const avatarTemplate = Ember.get(
|
||||
const name = get(user, options.namePath || "name");
|
||||
const username = get(user, options.usernamePath || "username");
|
||||
const avatarTemplate = get(
|
||||
user,
|
||||
options.avatarTemplatePath || "avatar_template"
|
||||
);
|
||||
|
@ -46,11 +47,11 @@ function renderAvatar(user, options) {
|
|||
let title = options.title;
|
||||
if (!title && !options.ignoreTitle) {
|
||||
// first try to get a title
|
||||
title = Ember.get(user, "title");
|
||||
title = get(user, "title");
|
||||
// if there was no title provided
|
||||
if (!title) {
|
||||
// try to retrieve a description
|
||||
const description = Ember.get(user, "description");
|
||||
const description = get(user, "description");
|
||||
// if a description has been provided
|
||||
if (description && description.length > 0) {
|
||||
// preprend the username before the description
|
||||
|
@ -61,7 +62,7 @@ function renderAvatar(user, options) {
|
|||
|
||||
return avatarImg({
|
||||
size: options.imageSize,
|
||||
extraClasses: Ember.get(user, "extras") || options.extraClasses,
|
||||
extraClasses: get(user, "extras") || options.extraClasses,
|
||||
title: title || displayName,
|
||||
avatarTemplate: avatarTemplate
|
||||
});
|
||||
|
|
|
@ -463,7 +463,7 @@ class PluginApi {
|
|||
|
||||
```javascript
|
||||
api.customUserAvatarClasses(user => {
|
||||
if (Ember.get(user, 'primary_group_name') === 'managers') {
|
||||
if (get(user, 'primary_group_name') === 'managers') {
|
||||
return ['managers'];
|
||||
}
|
||||
});
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import { get } from "@ember/object";
|
||||
import { ajax } from "discourse/lib/ajax";
|
||||
import RestModel from "discourse/models/rest";
|
||||
import computed from "ember-addons/ember-computed-decorators";
|
||||
|
@ -232,15 +233,15 @@ Category.reopenClass({
|
|||
slugFor(category, separator = "/") {
|
||||
if (!category) return "";
|
||||
|
||||
const parentCategory = Ember.get(category, "parentCategory");
|
||||
const parentCategory = get(category, "parentCategory");
|
||||
let result = "";
|
||||
|
||||
if (parentCategory) {
|
||||
result = Category.slugFor(parentCategory) + separator;
|
||||
}
|
||||
|
||||
const id = Ember.get(category, "id"),
|
||||
slug = Ember.get(category, "slug");
|
||||
const id = get(category, "id"),
|
||||
slug = get(category, "slug");
|
||||
|
||||
return !slug || slug.trim().length === 0
|
||||
? `${result}${id}-category`
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import { get } from "@ember/object";
|
||||
import { isEmpty } from "@ember/utils";
|
||||
import { or, not, and } from "@ember/object/computed";
|
||||
import { ajax } from "discourse/lib/ajax";
|
||||
|
@ -882,12 +883,12 @@ export default RestModel.extend({
|
|||
than you supplied if the post has already been loaded.
|
||||
**/
|
||||
storePost(post) {
|
||||
// Calling `Ember.get(undefined)` raises an error
|
||||
// Calling `get(undefined)` raises an error
|
||||
if (!post) {
|
||||
return;
|
||||
}
|
||||
|
||||
const postId = Ember.get(post, "id");
|
||||
const postId = get(post, "id");
|
||||
if (postId) {
|
||||
const existing = this._identityMap[post.get("id")];
|
||||
|
||||
|
@ -931,7 +932,7 @@ export default RestModel.extend({
|
|||
this.set("topic.suggested_topics", result.suggested_topics);
|
||||
}
|
||||
|
||||
const posts = Ember.get(result, "post_stream.posts");
|
||||
const posts = get(result, "post_stream.posts");
|
||||
|
||||
if (posts) {
|
||||
posts.forEach(p => {
|
||||
|
@ -971,7 +972,7 @@ export default RestModel.extend({
|
|||
this.set("topic.suggested_topics", result.suggested_topics);
|
||||
}
|
||||
|
||||
const posts = Ember.get(result, "post_stream.posts");
|
||||
const posts = get(result, "post_stream.posts");
|
||||
|
||||
if (posts) {
|
||||
posts.forEach(p => this.storePost(store.createRecord("post", p)));
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import { get } from "@ember/object";
|
||||
import { isEmpty } from "@ember/utils";
|
||||
import { equal, and, or, not } from "@ember/object/computed";
|
||||
import EmberObject from "@ember/object";
|
||||
|
@ -282,7 +283,7 @@ const Post = RestModel.extend({
|
|||
if (key === "reply_to_user" && value && oldValue) {
|
||||
skip =
|
||||
value.username === oldValue.username ||
|
||||
Ember.get(value, "username") === Ember.get(oldValue, "username");
|
||||
get(value, "username") === get(oldValue, "username");
|
||||
}
|
||||
|
||||
if (!skip) {
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import { get } from "@ember/object";
|
||||
import { isEmpty } from "@ember/utils";
|
||||
import { alias, sort } from "@ember/object/computed";
|
||||
import EmberObject from "@ember/object";
|
||||
|
@ -110,7 +111,7 @@ const Site = RestModel.extend({
|
|||
|
||||
updateCategory(newCategory) {
|
||||
const categories = this.categories;
|
||||
const categoryId = Ember.get(newCategory, "id");
|
||||
const categoryId = get(newCategory, "id");
|
||||
const existingCategory = categories.findBy("id", categoryId);
|
||||
|
||||
// Don't update null permissions
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import { get } from "@ember/object";
|
||||
import { isEmpty } from "@ember/utils";
|
||||
import { NotificationLevels } from "discourse/lib/notification-levels";
|
||||
import {
|
||||
|
@ -390,8 +391,8 @@ const TopicTrackingState = Discourse.Model.extend({
|
|||
);
|
||||
}
|
||||
|
||||
let categoryId = category ? Ember.get(category, "id") : null;
|
||||
let categoryName = category ? Ember.get(category, "name") : null;
|
||||
let categoryId = category ? get(category, "id") : null;
|
||||
let categoryName = category ? get(category, "name") : null;
|
||||
|
||||
if (name === "new") {
|
||||
return this.countNew(categoryId);
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import { get } from "@ember/object";
|
||||
import { not, notEmpty, equal, and, or } from "@ember/object/computed";
|
||||
import EmberObject from "@ember/object";
|
||||
import { ajax } from "discourse/lib/ajax";
|
||||
|
@ -378,7 +379,7 @@ const Topic = RestModel.extend({
|
|||
this.set("bookmarking", true);
|
||||
|
||||
const stream = this.postStream;
|
||||
const posts = Ember.get(stream, "posts");
|
||||
const posts = get(stream, "posts");
|
||||
const firstPost =
|
||||
posts && posts[0] && posts[0].get("post_number") === 1 && posts[0];
|
||||
const bookmark = !this.bookmarked;
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import { get } from "@ember/object";
|
||||
import DiscourseRoute from "discourse/routes/discourse";
|
||||
|
||||
export function buildGroupPage(type) {
|
||||
|
@ -9,7 +10,7 @@ export function buildGroupPage(type) {
|
|||
},
|
||||
|
||||
model(params, transition) {
|
||||
let categoryId = Ember.get(transition.to, "queryParams.category_id");
|
||||
let categoryId = get(transition.to, "queryParams.category_id");
|
||||
return this.modelFor("group").findPosts({ type, categoryId });
|
||||
},
|
||||
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import { get } from "@ember/object";
|
||||
import { isEmpty } from "@ember/utils";
|
||||
import { cancel } from "@ember/runloop";
|
||||
import { scheduleOnce } from "@ember/runloop";
|
||||
|
@ -215,9 +216,9 @@ const TopicRoute = DiscourseRoute.extend({
|
|||
|
||||
setupParams(topic, params) {
|
||||
const postStream = topic.get("postStream");
|
||||
postStream.set("summary", Ember.get(params, "filter") === "summary");
|
||||
postStream.set("summary", get(params, "filter") === "summary");
|
||||
|
||||
const usernames = Ember.get(params, "username_filters"),
|
||||
const usernames = get(params, "username_filters"),
|
||||
userFilters = postStream.get("userFilters");
|
||||
|
||||
userFilters.clear();
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import { get } from "@ember/object";
|
||||
import EmberObject from "@ember/object";
|
||||
import {
|
||||
default as computed,
|
||||
|
@ -19,7 +20,7 @@ export default EmberObject.extend({
|
|||
contextType: {
|
||||
get(searchContext) {
|
||||
if (searchContext) {
|
||||
return Ember.get(searchContext, "type");
|
||||
return get(searchContext, "type");
|
||||
}
|
||||
},
|
||||
set(value, searchContext) {
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import { get } from "@ember/object";
|
||||
import Service from "@ember/service";
|
||||
|
||||
export default Service.extend({
|
||||
|
@ -14,7 +15,7 @@ export default Service.extend({
|
|||
|
||||
getSetting(themeId, settingsKey) {
|
||||
if (this._settings[themeId]) {
|
||||
return Ember.get(this._settings[themeId], settingsKey);
|
||||
return get(this._settings[themeId], settingsKey);
|
||||
}
|
||||
return null;
|
||||
},
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import { get } from "@ember/object";
|
||||
import { schedule } from "@ember/runloop";
|
||||
import { createWidget } from "discourse/widgets/widget";
|
||||
import { iconNode } from "discourse-common/lib/icon-library";
|
||||
|
@ -558,7 +559,7 @@ export default createWidget("header", {
|
|||
if (service) {
|
||||
const ctx = service.get("searchContext");
|
||||
if (ctx) {
|
||||
return Ember.get(ctx, "type");
|
||||
return get(ctx, "type");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import { get } from "@ember/object";
|
||||
import { searchContextDescription } from "discourse/lib/search";
|
||||
import { h } from "virtual-dom";
|
||||
import { createWidget } from "discourse/widgets/widget";
|
||||
|
@ -52,8 +53,8 @@ createWidget("search-context", {
|
|||
const result = [];
|
||||
if (ctx) {
|
||||
const description = searchContextDescription(
|
||||
Ember.get(ctx, "type"),
|
||||
Ember.get(ctx, "user.username") || Ember.get(ctx, "category.name")
|
||||
get(ctx, "type"),
|
||||
get(ctx, "user.username") || get(ctx, "category.name")
|
||||
);
|
||||
result.push(
|
||||
h("label", [
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import { get } from "@ember/object";
|
||||
import { debounce } from "@ember/runloop";
|
||||
import { later } from "@ember/runloop";
|
||||
import { popupAjaxError } from "discourse/lib/ajax-error";
|
||||
|
@ -99,7 +100,7 @@ export default createWidget("search-menu", {
|
|||
const contextEnabled = searchData.contextEnabled;
|
||||
|
||||
const ctx = contextEnabled ? this.searchContext() : null;
|
||||
const type = ctx ? Ember.get(ctx, "type") : null;
|
||||
const type = ctx ? get(ctx, "type") : null;
|
||||
|
||||
let url = "/search";
|
||||
const params = [];
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import { get } from "@ember/object";
|
||||
import { makeArray } from "discourse/lib/utilities";
|
||||
import MultiSelectComponent from "select-kit/components/multi-select";
|
||||
import Category from "discourse/models/category";
|
||||
|
@ -39,7 +40,7 @@ export default MultiSelectComponent.extend({
|
|||
filterComputedContent(computedContent, computedValues, filter) {
|
||||
const regex = new RegExp(filter, "i");
|
||||
return computedContent.filter(category =>
|
||||
this._normalize(Ember.get(category, "name")).match(regex)
|
||||
this._normalize(get(category, "name")).match(regex)
|
||||
);
|
||||
},
|
||||
|
||||
|
|
|
@ -1,3 +1,5 @@
|
|||
import { isEmpty } from "@ember/utils";
|
||||
import { get } from "@ember/object";
|
||||
import { makeArray } from "discourse/lib/utilities";
|
||||
import Category from "discourse/models/category";
|
||||
import ComboBox from "select-kit/components/combo-box";
|
||||
|
@ -6,7 +8,6 @@ import { default as computed } from "ember-addons/ember-computed-decorators";
|
|||
import renderTag from "discourse/lib/render-tag";
|
||||
import { escapeExpression } from "discourse/lib/utilities";
|
||||
import { iconHTML } from "discourse-common/lib/icon-library";
|
||||
const { get, isEmpty, run } = Ember;
|
||||
|
||||
export default ComboBox.extend(TagsMixin, {
|
||||
allowContentReplacement: true,
|
||||
|
@ -168,9 +169,7 @@ export default ComboBox.extend(TagsMixin, {
|
|||
computeHeaderContent() {
|
||||
let content = this._super(...arguments);
|
||||
|
||||
const joinedTags = this.selection
|
||||
.map(s => Ember.get(s, "value"))
|
||||
.join(", ");
|
||||
const joinedTags = this.selection.map(s => get(s, "value")).join(", ");
|
||||
|
||||
if (isEmpty(this.selection)) {
|
||||
content.label = I18n.t("tagging.choose_for_topic");
|
||||
|
@ -198,7 +197,7 @@ export default ComboBox.extend(TagsMixin, {
|
|||
|
||||
if (this.selection) {
|
||||
data.selected_tags = this.selection
|
||||
.map(s => Ember.get(s, "value"))
|
||||
.map(s => get(s, "value"))
|
||||
.slice(0, 100);
|
||||
}
|
||||
|
||||
|
|
|
@ -1,3 +1,4 @@
|
|||
import { get } from "@ember/object";
|
||||
import { makeArray } from "discourse/lib/utilities";
|
||||
import { isEmpty } from "@ember/utils";
|
||||
import { throttle } from "@ember/runloop";
|
||||
|
@ -298,7 +299,7 @@ export default Mixin.create({
|
|||
.slice()
|
||||
.reverse()
|
||||
.some(selection => {
|
||||
if (!Ember.get(selection, "locked")) {
|
||||
if (!get(selection, "locked")) {
|
||||
this.highlightSelection(selection);
|
||||
return true;
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue
Block a user