mirror of https://github.com/vector-im/riot-web
Merge pull request #2745 from matrix-org/anoa/emoji_with_spaces
Prevent space characters from stopping big emoji messagespull/21833/head
commit
109b912699
|
@ -48,6 +48,12 @@ const SURROGATE_PAIR_PATTERN = /([\ud800-\udbff])([\udc00-\udfff])/;
|
||||||
// (with plenty of false positives, but that's OK)
|
// (with plenty of false positives, but that's OK)
|
||||||
const SYMBOL_PATTERN = /([\u2100-\u2bff])/;
|
const SYMBOL_PATTERN = /([\u2100-\u2bff])/;
|
||||||
|
|
||||||
|
// Regex pattern for Zero-Width joiner unicode characters
|
||||||
|
const ZWJ_REGEX = new RegExp("\u200D|\u2003", "g");
|
||||||
|
|
||||||
|
// Regex pattern for whitespace characters
|
||||||
|
const WHITESPACE_REGEX = new RegExp("\\s", "g");
|
||||||
|
|
||||||
// And this is emojione's complete regex
|
// And this is emojione's complete regex
|
||||||
const EMOJI_REGEX = new RegExp(emojione.unicodeRegexp+"+", "gi");
|
const EMOJI_REGEX = new RegExp(emojione.unicodeRegexp+"+", "gi");
|
||||||
const COLOR_REGEX = /^#[0-9a-fA-F]{6}$/;
|
const COLOR_REGEX = /^#[0-9a-fA-F]{6}$/;
|
||||||
|
@ -231,7 +237,7 @@ const transformTags = { // custom to matrix
|
||||||
'code': function(tagName, attribs) {
|
'code': function(tagName, attribs) {
|
||||||
if (typeof attribs.class !== 'undefined') {
|
if (typeof attribs.class !== 'undefined') {
|
||||||
// Filter out all classes other than ones starting with language- for syntax highlighting.
|
// Filter out all classes other than ones starting with language- for syntax highlighting.
|
||||||
const classes = attribs.class.split(/\s+/).filter(function(cl) {
|
const classes = attribs.class.split(/\s/).filter(function(cl) {
|
||||||
return cl.startsWith('language-');
|
return cl.startsWith('language-');
|
||||||
});
|
});
|
||||||
attribs.class = classes.join(' ');
|
attribs.class = classes.join(' ');
|
||||||
|
@ -498,7 +504,17 @@ export function bodyToHtml(content, highlights, opts={}) {
|
||||||
let emojiBody = false;
|
let emojiBody = false;
|
||||||
if (!opts.disableBigEmoji && bodyHasEmoji) {
|
if (!opts.disableBigEmoji && bodyHasEmoji) {
|
||||||
EMOJI_REGEX.lastIndex = 0;
|
EMOJI_REGEX.lastIndex = 0;
|
||||||
const contentBodyTrimmed = strippedBody !== undefined ? strippedBody.trim() : '';
|
let contentBodyTrimmed = strippedBody !== undefined ? strippedBody.trim() : '';
|
||||||
|
|
||||||
|
// Ignore spaces in body text. Emojis with spaces in between should
|
||||||
|
// still be counted as purely emoji messages.
|
||||||
|
contentBodyTrimmed = contentBodyTrimmed.replace(WHITESPACE_REGEX, '');
|
||||||
|
|
||||||
|
// Remove zero width joiner characters from emoji messages. This ensures
|
||||||
|
// that emojis that are made up of multiple unicode characters are still
|
||||||
|
// presented as large.
|
||||||
|
contentBodyTrimmed = contentBodyTrimmed.replace(ZWJ_REGEX, '');
|
||||||
|
|
||||||
const match = EMOJI_REGEX.exec(contentBodyTrimmed);
|
const match = EMOJI_REGEX.exec(contentBodyTrimmed);
|
||||||
emojiBody = match && match[0] && match[0].length === contentBodyTrimmed.length;
|
emojiBody = match && match[0] && match[0].length === contentBodyTrimmed.length;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue