From a66f2b3f757e294a1ad9abd830c635a594875b17 Mon Sep 17 00:00:00 2001 From: Alex Gleason Date: Sat, 10 Jul 2021 12:41:57 -0500 Subject: [PATCH] Big emojis: fix possible web crash --- app/soapbox/utils/rich_content.js | 31 +++++++++++++++++++------------ 1 file changed, 19 insertions(+), 12 deletions(-) diff --git a/app/soapbox/utils/rich_content.js b/app/soapbox/utils/rich_content.js index 256450a29..1c56a8b94 100644 --- a/app/soapbox/utils/rich_content.js +++ b/app/soapbox/utils/rich_content.js @@ -2,17 +2,24 @@ export const onlyEmoji = (node, limit = 1, ignoreMentions = true) => { if (!node) return false; - // Remove mentions before checking content - if (ignoreMentions) { - node = node.cloneNode(true); - node.querySelectorAll('a.mention').forEach(m => m.parentNode.removeChild(m)); - } + try { + // Remove mentions before checking content + if (ignoreMentions) { + node = node.cloneNode(true); + node.querySelectorAll('a.mention').forEach(m => m.parentNode.removeChild(m)); + } - if (node.textContent.replaceAll(' ', '') !== '') return false; - const emojis = Array.from(node.querySelectorAll('img.emojione')); - if (emojis.length === 0) return false; - if (emojis.length > limit) return false; - const images = Array.from(node.querySelectorAll('img')); - if (images.length > emojis.length) return false; - return true; + if (node.textContent.replaceAll(' ', '') !== '') return false; + const emojis = Array.from(node.querySelectorAll('img.emojione')); + if (emojis.length === 0) return false; + if (emojis.length > limit) return false; + const images = Array.from(node.querySelectorAll('img')); + if (images.length > emojis.length) return false; + return true; + } catch (e) { + // Apparently some browsers can't handle `node.textContent.replaceAll`?? + // If anything in here crashes, skipping it is inconsequential. + console.error(e); + return false; + } };