58 lines
No EOL
1.6 KiB
JavaScript
58 lines
No EOL
1.6 KiB
JavaScript
/**
|
|
* @extends {Component}
|
|
*/
|
|
import {htmlToDom} from "../services/dom";
|
|
|
|
class GlobalSearch {
|
|
|
|
setup() {
|
|
this.container = this.$el;
|
|
this.input = this.$refs.input;
|
|
this.suggestions = this.$refs.suggestions;
|
|
this.suggestionResultsWrap = this.$refs.suggestionResults;
|
|
|
|
this.setupListeners();
|
|
}
|
|
|
|
setupListeners() {
|
|
this.input.addEventListener('input', () => {
|
|
const value = this.input.value;
|
|
if (value.length > 0) {
|
|
this.updateSuggestions(value);
|
|
} else {
|
|
this.hideSuggestions();
|
|
}
|
|
});
|
|
}
|
|
|
|
async updateSuggestions(search) {
|
|
const {data: results} = await window.$http.get('/ajax/search/entities', {term: search, count: 5});
|
|
const resultDom = htmlToDom(results);
|
|
|
|
const childrenToTrim = Array.from(resultDom.children).slice(9);
|
|
for (const child of childrenToTrim) {
|
|
child.remove();
|
|
}
|
|
|
|
this.suggestionResultsWrap.innerHTML = '';
|
|
this.suggestionResultsWrap.append(resultDom);
|
|
if (!this.container.classList.contains('search-active')) {
|
|
this.showSuggestions();
|
|
}
|
|
}
|
|
|
|
showSuggestions() {
|
|
this.container.classList.add('search-active');
|
|
window.requestAnimationFrame(() => {
|
|
this.suggestions.classList.add('search-suggestions-animation');
|
|
})
|
|
}
|
|
|
|
hideSuggestions() {
|
|
this.container.classList.remove('search-active');
|
|
this.suggestions.classList.remove('search-suggestions-animation');
|
|
this.suggestionResultsWrap.innerHTML = '';
|
|
}
|
|
}
|
|
|
|
export default GlobalSearch; |