Mailspring/app/internal_packages/composer-emoji/lib/emoji-message-extension.jsx

45 lines
1.4 KiB
React
Raw Normal View History

/* eslint no-cond-assign:0 */
import { MessageViewExtension, RegExpUtils } from 'mailspring-exports';
2016-10-18 08:59:33 +08:00
import emoji from 'node-emoji';
import EmojiStore from './emoji-store';
2016-05-07 05:10:56 +08:00
function makeIntoEmojiTag(nodeArg, emojiName) {
const node = nodeArg;
node.src = EmojiStore.getImagePath(emojiName);
node.className = `emoji ${emojiName}`;
node.width = 14;
node.height = 14;
node.style = '';
node.style.marginTop = '-5px';
}
class EmojiMessageExtension extends MessageViewExtension {
2017-09-27 02:33:08 +08:00
static renderedMessageBodyIntoDocument({ document }) {
const emojiRegex = RegExpUtils.emojiRegex();
// Look for emoji in the content of text nodes
const treeWalker = document.createTreeWalker(document.body, NodeFilter.SHOW_TEXT);
while (treeWalker.nextNode()) {
emojiRegex.lastIndex = 0;
const node = treeWalker.currentNode;
let match = null;
2017-09-27 02:33:08 +08:00
while ((match = emojiRegex.exec(node.textContent))) {
const matchEmojiName = emoji.which(match[0]);
if (matchEmojiName) {
2017-09-27 02:33:08 +08:00
const matchNode = match.index === 0 ? node : node.splitText(match.index);
matchNode.splitText(match[0].length);
const imageNode = document.createElement('img');
makeIntoEmojiTag(imageNode, matchEmojiName);
matchNode.parentNode.replaceChild(imageNode, matchNode);
}
}
}
}
}
export default EmojiMessageExtension;