fix: speed up emoji parsing and replacements

extract the invariant/const parts out of the inner loop
(`emojiJSON.emoji_json.filter`); greatly speeds up typing speed
This commit is contained in:
Lukáš Tinkl 2023-04-05 12:57:23 +02:00 committed by Lukáš Tinkl
parent 5dbc08dca3
commit c8877aaf97
1 changed files with 8 additions and 6 deletions

View File

@ -1292,14 +1292,16 @@ Rectangle {
onTextChanged: {
if (length <= control.messageLimit) {
var symbols = ":='xX><0O;*dB8-D#%\\";
var symbolIdx = ((cursorPosition > 2) && (symbols.indexOf(getText((cursorPosition - 2), (cursorPosition - 1)))!==-1))
const symbols = ":='xX><0O;*dB8-D#%\\";
const symbolIdx = ((cursorPosition > 2) && (symbols.indexOf(getText((cursorPosition - 2), (cursorPosition - 1)))!==-1))
? (cursorPosition -1) : (symbols.indexOf(getText(0, 1))!==-1) ? 2 : -1;
if ((getText(symbolIdx-2, (symbolIdx-1)) === " ") || (symbolIdx === 2)) {
const textBefore1 = getText((symbolIdx-1), (symbolIdx+1))
const textBefore2 = getText((symbolIdx-2), (symbolIdx+1))
const has2CharsText = getText((symbolIdx-4), (symbolIdx-2))
const emojis = StatusQUtils.Emoji.emojiJSON.emoji_json.filter(function (emoji) {
if (emoji.aliases_ascii.includes(getText((symbolIdx-1), (symbolIdx+1))) ||
emoji.aliases_ascii.includes(getText((symbolIdx-2), (symbolIdx+1)))) {
var has2Chars = emoji.aliases_ascii.includes(getText((symbolIdx-4), (symbolIdx-2)));
if (emoji.aliases_ascii.includes(textBefore1) || emoji.aliases_ascii.includes(textBefore2)) {
const has2Chars = emoji.aliases_ascii.includes(has2CharsText)
replaceWithEmoji("", getText((symbolIdx - (has2Chars ? 3 : 2)), symbolIdx), emoji.unicode);
}
})
@ -1308,7 +1310,7 @@ Rectangle {
mentionsPos = [];
}
} else {
var removeFrom = (cursorPosition < messageLimit) ? cursorWhenPressed : messageLimit;
const removeFrom = (cursorPosition < messageLimit) ? cursorWhenPressed : messageLimit;
remove(removeFrom, cursorPosition);
}