From a0e993ad27d26acca64201ab16e858a639e611b0 Mon Sep 17 00:00:00 2001 From: John Livingston Date: Fri, 6 Sep 2024 12:50:44 +0200 Subject: [PATCH] Fix emojis vs uppercase letters: * Fix: trying to use an emojis with an uppercase letter breaks the message field. * Fix: isOnlyEmojis vs uppercase letters. * Fix: renaming getEmojisByAtrribute to getEmojisByAttribute. --- CHANGES.md | 3 ++- src/headless/plugins/emoji/utils.js | 12 ++++++------ 2 files changed, 8 insertions(+), 7 deletions(-) diff --git a/CHANGES.md b/CHANGES.md index 7d3fc976ea..5b6a3c5e96 100644 --- a/CHANGES.md +++ b/CHANGES.md @@ -38,7 +38,8 @@ - Improved accessibility. - New "getOccupantActionButtons" hook, so that plugins can add actions on MUC occupants. - MUC occupants badges: displays short labels, with full label as title. - +- Fix: trying to use an emojis with an uppercase letter breaks the message field. +- Fix: renaming getEmojisByAtrribute to getEmojisByAttribute. - New config option [stanza_timeout](https://conversejs.org/docs/html/configuration.html#show-background) ### Breaking changes: diff --git a/src/headless/plugins/emoji/utils.js b/src/headless/plugins/emoji/utils.js index 5f3e0d5fb8..dc075ae342 100644 --- a/src/headless/plugins/emoji/utils.js +++ b/src/headless/plugins/emoji/utils.js @@ -108,7 +108,7 @@ export function getShortnameReferences (text) { } const references = [...text.matchAll(converse.emojis.shortnames_regex)].filter(ref => ref[0].length > 0); return references.map(ref => { - const cp = converse.emojis.by_sn[ref[0]].cp; + const cp = converse.emojis.by_sn[ref[0].toLowerCase()].cp; return { cp, 'begin': ref.index, @@ -146,7 +146,7 @@ export function getCodePointReferences (text) { 'cp': icon_id, 'emoji': emoji, 'end': offset + emoji.length, - 'shortname': getEmojisByAtrribute('cp')[icon_id]?.sn || '' + 'shortname': getEmojisByAttribute('cp')[icon_id]?.sn || '' }); }); return references; @@ -190,20 +190,20 @@ export function isOnlyEmojis (text) { } const emojis = words.filter(text => { const refs = getCodePointReferences(u.shortnamesToUnicode(text)); - return refs.length === 1 && (text === refs[0]['shortname'] || text === refs[0]['emoji']); + return refs.length === 1 && (text.toLowerCase() === refs[0]['shortname'] || text === refs[0]['emoji']); }); return emojis.length === words.length; } /** * @namespace u - * @method u.getEmojisByAtrribute + * @method u.getEmojisByAttribute * @param { 'category'|'cp'|'sn' } attr * The attribute according to which the returned map should be keyed. * @returns { Object } * Map of emojis with the passed in `attr` used as key and a list of emojis as values. */ -function getEmojisByAtrribute (attr) { +function getEmojisByAttribute (attr) { if (emojis_by_attribute[attr]) { return emojis_by_attribute[attr]; } @@ -223,7 +223,7 @@ Object.assign(u, { getCodePointReferences, getShortnameReferences, convertASCII2Emoji, - getEmojisByAtrribute, + getEmojisByAttribute, isOnlyEmojis, shortnamesToUnicode, });