81 lines
2.1 KiB
TypeScript
81 lines
2.1 KiB
TypeScript
|
// Copyright 2021 Signal Messenger, LLC
|
||
|
// SPDX-License-Identifier: AGPL-3.0-only
|
||
|
|
||
|
import Delta from 'quill-delta';
|
||
|
import { QuillFormattingStyle } from './menu';
|
||
|
|
||
|
function applyStyleToOps(delta: Delta, style: QuillFormattingStyle): Delta {
|
||
|
return new Delta(
|
||
|
delta.map(op => ({
|
||
|
...op,
|
||
|
attributes: {
|
||
|
...op.attributes,
|
||
|
[style]: true,
|
||
|
},
|
||
|
}))
|
||
|
);
|
||
|
}
|
||
|
|
||
|
export const matchBold = (_node: HTMLElement, delta: Delta): Delta => {
|
||
|
if (delta.length() > 0) {
|
||
|
return applyStyleToOps(delta, QuillFormattingStyle.bold);
|
||
|
}
|
||
|
|
||
|
return delta;
|
||
|
};
|
||
|
|
||
|
export const matchItalic = (_node: HTMLElement, delta: Delta): Delta => {
|
||
|
if (delta.length() > 0) {
|
||
|
return applyStyleToOps(delta, QuillFormattingStyle.italic);
|
||
|
}
|
||
|
|
||
|
return delta;
|
||
|
};
|
||
|
|
||
|
export const matchStrikethrough = (_node: HTMLElement, delta: Delta): Delta => {
|
||
|
if (delta.length() > 0) {
|
||
|
return applyStyleToOps(delta, QuillFormattingStyle.strike);
|
||
|
}
|
||
|
|
||
|
return delta;
|
||
|
};
|
||
|
|
||
|
export const matchMonospace = (node: HTMLElement, delta: Delta): Delta => {
|
||
|
const classes = [
|
||
|
'MessageTextRenderer__formatting--monospace',
|
||
|
'quill--monospace',
|
||
|
];
|
||
|
// Note: This is defined as $monospace in _variables.scss
|
||
|
const fontFamily =
|
||
|
'font-family: "SF Mono", SFMono-Regular, ui-monospace, "DejaVu Sans Mono", Menlo, Consolas, monospace;';
|
||
|
|
||
|
if (
|
||
|
delta.length() > 0 &&
|
||
|
(node.classList.contains(classes[0]) ||
|
||
|
node.classList.contains(classes[1]) ||
|
||
|
node.attributes.getNamedItem('style')?.value?.includes(fontFamily))
|
||
|
) {
|
||
|
return applyStyleToOps(delta, QuillFormattingStyle.monospace);
|
||
|
}
|
||
|
|
||
|
return delta;
|
||
|
};
|
||
|
|
||
|
export const matchSpoiler = (node: HTMLElement, delta: Delta): Delta => {
|
||
|
const classes = [
|
||
|
'quill--spoiler',
|
||
|
'MessageTextRenderer__formatting--spoiler--revealed',
|
||
|
// Note: we don't match on hidden spoilers in message body; we use copy-target text
|
||
|
];
|
||
|
|
||
|
if (
|
||
|
delta.length() > 0 &&
|
||
|
(node.classList.contains(classes[0]) ||
|
||
|
node.classList.contains(classes[1]) ||
|
||
|
node.classList.contains(classes[2]))
|
||
|
) {
|
||
|
return applyStyleToOps(delta, QuillFormattingStyle.spoiler);
|
||
|
}
|
||
|
return delta;
|
||
|
};
|