TeaWeb/shared/js/text/bbcode/emoji.tsx

55 lines
2 KiB
TypeScript
Raw Normal View History

2020-07-19 16:34:08 +02:00
import * as loader from "tc-loader";
import { rendererReact } from "tc-shared/text/bbcode/renderer";
import {ElementRenderer} from "vendor/xbbcode/renderer/base";
import {TextElement} from "vendor/xbbcode/elements";
import * as React from "react";
import ReactRenderer from "vendor/xbbcode/renderer/react";
import {Settings, settings} from "tc-shared/settings";
import * as emojiRegex from "emoji-regex";
2021-02-15 19:03:22 +01:00
import {getTwenmojiHashFromNativeEmoji} from "tc-shared/text/bbcode/EmojiUtil";
2020-07-19 16:34:08 +02:00
const emojiRegexInstance = (emojiRegex as any)() as RegExp;
loader.register_task(loader.Stage.JAVASCRIPT_INITIALIZING, {
name: "XBBCode emoji init",
function: async () => {
let reactId = 0;
rendererReact.setTextRenderer(new class extends ElementRenderer<TextElement, React.ReactNode> {
render(element: TextElement, renderer: ReactRenderer): React.ReactNode {
2021-02-15 19:03:22 +01:00
if(!settings.getValue(Settings.KEY_CHAT_COLORED_EMOJIES)) {
2020-07-19 16:34:08 +02:00
return element.text();
2021-02-15 19:03:22 +01:00
}
2020-07-19 16:34:08 +02:00
let text = element.text();
emojiRegexInstance.lastIndex = 0;
const result = [];
let lastIndex = 0;
while(true) {
let match = emojiRegexInstance.exec(text);
const rawText = text.substring(lastIndex, match?.index);
2021-02-15 19:03:22 +01:00
if(rawText) {
2020-07-19 16:34:08 +02:00
result.push(renderer.renderAsText(rawText, false));
2021-02-15 19:03:22 +01:00
}
2020-07-19 16:34:08 +02:00
2021-02-15 19:03:22 +01:00
if(!match) {
2020-07-19 16:34:08 +02:00
break;
2021-02-15 19:03:22 +01:00
}
2020-07-19 16:34:08 +02:00
2021-02-15 19:03:22 +01:00
let hash = getTwenmojiHashFromNativeEmoji(match[0]);
2020-07-19 16:34:08 +02:00
result.push(<img key={"er-" + ++reactId} draggable={false} src={"https://twemoji.maxcdn.com/v/12.1.2/72x72/" + hash + ".png"} alt={match[0]} className={"chat-emoji"} />);
lastIndex = match.index + match[0].length;
}
return result;
}
tags(): string | string[] { return undefined; }
});
},
priority: 10
});