forked from FoundKeyGang/FoundKey
client: delay/batch emoji picker searches
This is particularly important for users that set limit to 0 (unlimited).
This commit is contained in:
parent
33ed6e98a7
commit
ed8e346ff9
1 changed files with 13 additions and 4 deletions
|
@ -142,8 +142,18 @@ function emojiSearch<Type>(src: Type[], max: number, query: string): Type[] {
|
|||
return matches.slice(0, max);
|
||||
}
|
||||
|
||||
watch(q, () => {
|
||||
let queryTimeoutId = -1;
|
||||
const queryCallback = (query) => {
|
||||
if (emojis.value) emojis.value.scrollTop = 0;
|
||||
searchResultCustom.value = emojiSearch(instance.emojis, maxCustomEmojiPicker.value, query);
|
||||
searchResultUnicode.value = emojiSearch(emojilist, maxUnicodeEmojiPicker.value, query);
|
||||
queryTimeoutId = -1;
|
||||
}
|
||||
watch(q, () => {
|
||||
if(queryTimeoutId >= 0) {
|
||||
clearTimeout(queryTimeoutId);
|
||||
queryTimeoutId = -1;
|
||||
}
|
||||
|
||||
const query = q.value;
|
||||
if (query == null || query === '') {
|
||||
|
@ -152,8 +162,7 @@ watch(q, () => {
|
|||
return;
|
||||
}
|
||||
|
||||
searchResultCustom.value = emojiSearch(instance.emojis, maxCustomEmojiPicker.value, query);
|
||||
searchResultUnicode.value = emojiSearch(emojilist, maxUnicodeEmojiPicker.value, query);
|
||||
queryTimeoutId = setTimeout(queryCallback, 300, query);
|
||||
});
|
||||
|
||||
function focus() {
|
||||
|
|
Loading…
Reference in a new issue