2020-10-30 20:34:04 +00:00
|
|
|
// Copyright 2020 Signal Messenger, LLC
|
|
|
|
// SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
|
2020-10-21 16:53:32 +00:00
|
|
|
import React from 'react';
|
|
|
|
import Parchment from 'parchment';
|
|
|
|
import Quill from 'quill';
|
|
|
|
import { render } from 'react-dom';
|
|
|
|
|
|
|
|
import { Emoji } from '../../components/emoji/Emoji';
|
|
|
|
|
|
|
|
const Embed: typeof Parchment.Embed = Quill.import('blots/embed');
|
|
|
|
|
|
|
|
export class EmojiBlot extends Embed {
|
|
|
|
static blotName = 'emoji';
|
|
|
|
|
|
|
|
static tagName = 'span';
|
|
|
|
|
|
|
|
static className = 'emoji-blot';
|
|
|
|
|
|
|
|
static create(emoji: string): Node {
|
|
|
|
const node = super.create(undefined) as HTMLElement;
|
|
|
|
node.dataset.emoji = emoji;
|
|
|
|
|
|
|
|
const emojiSpan = document.createElement('span');
|
|
|
|
render(
|
|
|
|
<Emoji emoji={emoji} inline size={20}>
|
|
|
|
{emoji}
|
|
|
|
</Emoji>,
|
|
|
|
emojiSpan
|
|
|
|
);
|
|
|
|
node.appendChild(emojiSpan);
|
|
|
|
|
|
|
|
return node;
|
|
|
|
}
|
|
|
|
|
|
|
|
static value(node: HTMLElement): string | undefined {
|
|
|
|
return node.dataset.emoji;
|
|
|
|
}
|
|
|
|
}
|