mirror of
https://github.com/discourse/discourse.git
synced 2025-01-19 02:22:46 +08:00
FIX: allows mini-tag-chooser to fetch tags in background (#8033)
This is useful when changing the category in the composer for example. When opening mini-tag-chooser after, tags will be correctly updated for the selected category.
This commit is contained in:
parent
2ff5592941
commit
171618e7d6
|
@ -188,7 +188,7 @@ export default ComboBox.extend(TagsMixin, {
|
|||
return content;
|
||||
},
|
||||
|
||||
_prepareSearch(query) {
|
||||
_prepareSearch(query, options) {
|
||||
const data = {
|
||||
q: query,
|
||||
limit: this.get("siteSettings.max_tag_search_results"),
|
||||
|
@ -203,7 +203,7 @@ export default ComboBox.extend(TagsMixin, {
|
|||
|
||||
if (!this.everyTag) data.filterForInput = true;
|
||||
|
||||
this.searchTags("/tags/filter/search", data, this._transformJson);
|
||||
this.searchTags("/tags/filter/search", data, this._transformJson, options);
|
||||
},
|
||||
|
||||
_transformJson(context, json) {
|
||||
|
@ -245,6 +245,12 @@ export default ComboBox.extend(TagsMixin, {
|
|||
this.destroyTags(tags);
|
||||
},
|
||||
|
||||
didUpdateAttrs() {
|
||||
this._super(...arguments);
|
||||
|
||||
this._prepareSearch(this.filter, { background: true });
|
||||
},
|
||||
|
||||
_tagsChanged() {
|
||||
if (this.attrs.onChangeTags) {
|
||||
this.attrs.onChangeTags({ target: { value: this.tags } });
|
||||
|
|
|
@ -10,8 +10,10 @@ export default Ember.Mixin.create({
|
|||
if (searchDebounce) run.cancel(searchDebounce);
|
||||
},
|
||||
|
||||
searchTags(url, data, callback) {
|
||||
this.startLoading();
|
||||
searchTags(url, data, callback, options) {
|
||||
options = options || {};
|
||||
|
||||
if (!options.background) this.startLoading();
|
||||
|
||||
return ajax(Discourse.getURL(url), {
|
||||
quietMillis: 200,
|
||||
|
@ -21,10 +23,12 @@ export default Ember.Mixin.create({
|
|||
})
|
||||
.then(json => {
|
||||
this.set("asyncContent", callback(this, json));
|
||||
this.autoHighlight();
|
||||
if (!options.background) this.autoHighlight();
|
||||
})
|
||||
.catch(error => popupAjaxError(error))
|
||||
.finally(() => this.stopLoading());
|
||||
.finally(() => {
|
||||
if (!options.background) this.stopLoading();
|
||||
});
|
||||
},
|
||||
|
||||
validateCreate(term) {
|
||||
|
|
Loading…
Reference in New Issue
Block a user