From 2918321a14086f2b1e37e9068da03d9dec3e9706 Mon Sep 17 00:00:00 2001 From: John Livingston Date: Thu, 5 Dec 2024 19:24:50 +0100 Subject: [PATCH] Fix: trying to use emojis with an uppercase letter breaks the message field. Previoux fix (https://github.com/conversejs/converse.js/pull/3501) was wrong and introduced other issues: * impossible to define an emoji with uppercase letters * possible to use an emoji :abc: by using :Abc:, but it won't display So, the correct fix is just to remove the 'i' modifier for the shortname_regex, to always have case sensitive emojis. --- src/headless/plugins/emoji/api.js | 2 +- src/headless/plugins/emoji/utils.js | 4 ++-- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/src/headless/plugins/emoji/api.js b/src/headless/plugins/emoji/api.js index edf6ab65fb..a7c925c5e4 100644 --- a/src/headless/plugins/emoji/api.js +++ b/src/headless/plugins/emoji/api.js @@ -49,7 +49,7 @@ const emojis = { converse.emojis.shortnames = converse.emojis.list.map((m) => m.sn); const getShortNames = () => converse.emojis.shortnames.map((s) => s.replace(/[+]/g, '\\$&')).join('|'); - converse.emojis.shortnames_regex = new RegExp(getShortNames(), 'gi'); + converse.emojis.shortnames_regex = new RegExp(getShortNames(), 'g'); converse.emojis.initialized_promise.resolve(); } return converse.emojis.initialized_promise; diff --git a/src/headless/plugins/emoji/utils.js b/src/headless/plugins/emoji/utils.js index dc075ae342..d947df7e43 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].toLowerCase()].cp; + const cp = converse.emojis.by_sn[ref[0]].cp; return { cp, 'begin': ref.index, @@ -190,7 +190,7 @@ export function isOnlyEmojis (text) { } const emojis = words.filter(text => { const refs = getCodePointReferences(u.shortnamesToUnicode(text)); - return refs.length === 1 && (text.toLowerCase() === refs[0]['shortname'] || text === refs[0]['emoji']); + return refs.length === 1 && (text === refs[0]['shortname'] || text === refs[0]['emoji']); }); return emojis.length === words.length; }