FIX: Retrigger search scoped to a topic if topic changes.
https://meta.discourse.org/t/highlight-the-search-results/10322/12?u=tgxworld
This commit is contained in:
parent
b18e0825b5
commit
4f4c576311
|
@ -12,6 +12,7 @@ export function initSearchData() {
|
||||||
searchData.term = undefined;
|
searchData.term = undefined;
|
||||||
searchData.typeFilter = null;
|
searchData.typeFilter = null;
|
||||||
searchData.invalidTerm = false;
|
searchData.invalidTerm = false;
|
||||||
|
searchData.topicId = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
initSearchData();
|
initSearchData();
|
||||||
|
@ -64,7 +65,11 @@ const SearchHelper = {
|
||||||
}
|
}
|
||||||
|
|
||||||
searchData.results = content;
|
searchData.results = content;
|
||||||
|
|
||||||
|
if (searchContext.type === 'topic') {
|
||||||
widget.appEvents.trigger('post-stream:refresh', { force: true });
|
widget.appEvents.trigger('post-stream:refresh', { force: true });
|
||||||
|
searchData.topicId = searchContext.id;
|
||||||
|
}
|
||||||
}).finally(() => {
|
}).finally(() => {
|
||||||
searchData.loading = false;
|
searchData.loading = false;
|
||||||
widget.scheduleRerender();
|
widget.scheduleRerender();
|
||||||
|
@ -164,11 +169,15 @@ export default createWidget('search-menu', {
|
||||||
},
|
},
|
||||||
|
|
||||||
html(attrs) {
|
html(attrs) {
|
||||||
if (searchData.contextEnabled !== attrs.contextEnabled) {
|
|
||||||
searchData.contextEnabled = attrs.contextEnabled;
|
|
||||||
if (searchData.term) this.triggerSearch();
|
|
||||||
} else {
|
|
||||||
searchData.contextEnabled = attrs.contextEnabled;
|
searchData.contextEnabled = attrs.contextEnabled;
|
||||||
|
|
||||||
|
const shouldTriggerSearch = (
|
||||||
|
(searchData.contextEnabled !== attrs.contextEnabled) ||
|
||||||
|
(this.searchContext().type === 'topic' && searchData.topicId !== this.searchContext().id)
|
||||||
|
);
|
||||||
|
|
||||||
|
if (shouldTriggerSearch && searchData.term) {
|
||||||
|
this.triggerSearch();
|
||||||
}
|
}
|
||||||
|
|
||||||
return this.attach('menu-panel', { maxWidth: 500, contents: () => this.panelContents() });
|
return this.attach('menu-panel', { maxWidth: 500, contents: () => this.panelContents() });
|
||||||
|
|
Loading…
Reference in New Issue