@toptal/picasso-rich-text-editor 4.0.2 → 4.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LexicalEditor/styles.d.ts +1 -1
- package/LexicalEditor/styles.js +4 -1
- package/LexicalEditor/styles.js.map +1 -1
- package/LexicalEditor/utils/createLexicalTheme.js +1 -0
- package/LexicalEditor/utils/createLexicalTheme.js.map +1 -1
- package/RichText/components/Code.d.ts +6 -0
- package/RichText/components/Code.js +10 -0
- package/RichText/components/Code.js.map +1 -0
- package/RichText/components/styles.d.ts +12 -0
- package/RichText/components/styles.js +14 -0
- package/RichText/components/styles.js.map +1 -0
- package/RichText/hooks/useRichText/useRichText.js +2 -0
- package/RichText/hooks/useRichText/useRichText.js.map +1 -1
- package/RichText/types.d.ts +1 -1
- package/index.d.ts +1 -1
- package/index.js +1 -1
- package/index.js.map +1 -1
- package/package.json +1 -1
- package/plugins/CodePlugin/CodeButton.d.ts +6 -0
- package/plugins/CodePlugin/CodeButton.js +23 -0
- package/plugins/CodePlugin/CodeButton.js.map +1 -0
- package/plugins/CodePlugin/CodePlugin.d.ts +8 -0
- package/plugins/CodePlugin/CodePlugin.js +13 -0
- package/plugins/CodePlugin/CodePlugin.js.map +1 -0
- package/plugins/CodePlugin/index.d.ts +1 -0
- package/plugins/CodePlugin/index.js +2 -0
- package/plugins/CodePlugin/index.js.map +1 -0
- package/plugins/index.d.ts +1 -0
- package/plugins/index.js +1 -0
- package/plugins/index.js.map +1 -1
- package/utils/html-to-hast.js +13 -1
- package/utils/html-to-hast.js.map +1 -1
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
import type { Theme } from '@material-ui/core/styles';
|
|
2
|
-
declare const _default: (
|
|
2
|
+
declare const _default: (theme: Theme) => import("@material-ui/styles").StyleRules<{}, "italic" | "bold" | "code" | "ol" | "ul" | "contentEditable" | "placeholder" | "paragraph" | "listItem" | "customEmoji" | "editorContainer">;
|
|
3
3
|
export default _default;
|
package/LexicalEditor/styles.js
CHANGED
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { createStyles } from '@material-ui/core/styles';
|
|
2
2
|
import { rem } from '@toptal/picasso-shared';
|
|
3
|
+
import { codeStyles } from '../RichText/components/styles';
|
|
3
4
|
const margins = {
|
|
4
5
|
'& p': {
|
|
5
6
|
margin: '0.5rem 0',
|
|
@@ -62,7 +63,8 @@ const listStyles = Object.assign({ '& p,& ol,& ul,& pre,& blockquote,& h1,& h2,&
|
|
|
62
63
|
}, '& *:not(li)': {
|
|
63
64
|
counterReset: 'list-0',
|
|
64
65
|
} }, indentStyles);
|
|
65
|
-
export default (
|
|
66
|
+
export default (theme) => {
|
|
67
|
+
const { typography } = theme;
|
|
66
68
|
return createStyles({
|
|
67
69
|
editorContainer: Object.assign(Object.assign({ height: '12.5em', overflowY: 'hidden', resize: 'vertical', position: 'relative', fontSize: '14px' }, listStyles), margins),
|
|
68
70
|
contentEditable: {
|
|
@@ -131,6 +133,7 @@ export default ({ typography }) => {
|
|
|
131
133
|
height: '22px',
|
|
132
134
|
},
|
|
133
135
|
},
|
|
136
|
+
code: codeStyles(theme),
|
|
134
137
|
});
|
|
135
138
|
};
|
|
136
139
|
//# sourceMappingURL=styles.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"styles.js","sourceRoot":"","sources":["../../src/LexicalEditor/styles.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAA;AAGvD,OAAO,EAAE,GAAG,EAAE,MAAM,wBAAwB,CAAA;AAE5C,MAAM,OAAO,GAAG;IACd,KAAK,EAAE;QACL,MAAM,EAAE,UAAU;KACnB;IACD,MAAM,EAAE;QACN,MAAM,EAAE,eAAe;KACxB;IACD,mCAAmC,EAAE;QACnC,MAAM,EAAE,YAAY;KACrB;IACD,uBAAuB,EAAE;QACvB,MAAM,EAAE,YAAY;KACrB;IACD,YAAY,EAAE;QACZ,OAAO,EAAE,CAAC;QACV,MAAM,EAAE,UAAU;KACnB;CACF,CAAA;AAED,MAAM,cAAc,GAAG,kUAAkU,CAAA;AACzV,MAAM,MAAM,GAAG,qKAAqK,CAAA;AAEpL,IAAK,YAKJ;AALD,WAAK,YAAY;IACf,qDAAW,CAAA;IACX,2DAAc,CAAA;IACd,6DAAe,CAAA;IACf,6DAAe,CAAA;AACjB,CAAC,EALI,YAAY,KAAZ,YAAY,QAKhB;AACD,MAAM,cAAc,GAAG,CAAC,MAAc,EAAU,EAAE;IAChD,QAAQ,MAAM,EAAE;QACd,KAAK,YAAY,CAAC,OAAO;YACvB,OAAO,gBAAgB,MAAM,gBAAgB,CAAA;QAC/C,KAAK,YAAY,CAAC,UAAU;YAC1B,OAAO,gBAAgB,MAAM,oBAAoB,CAAA;QACnD,KAAK,YAAY,CAAC,WAAW,CAAC;QAC9B,KAAK,YAAY,CAAC,WAAW;YAC3B,OAAO,gBAAgB,MAAM,oBAAoB,CAAA;QACnD;YACE,OAAO,EAAE,CAAA;KACZ;AACH,CAAC,CAAA;AAED,MAAM,YAAY,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CACtC,CAAC,GAAqC,EAAE,MAAc,EAAE,EAAE;IACxD,MAAM,MAAM,GAAG,qBAAqB,MAAM,8BAA8B,CAAA;IACxE,MAAM,YAAY,GAAG,GAAG,MAAM,SAAS,CAAA;IACvC,MAAM,YAAY,GAAG,qBAAqB,MAAM,qCAAqC,CAAA;IAErF,GAAG,CAAC,MAAM,CAAC,GAAG;QACZ,gBAAgB,EAAE,QAAQ,MAAM,EAAE;KACnC,CAAA;IACD,GAAG,CAAC,YAAY,CAAC,GAAG;QAClB,OAAO,EAAE,cAAc,CAAC,MAAM,CAAC;KAChC,CAAA;IACD,IAAI,MAAM,GAAG,CAAC,KAAK,CAAC,EAAE;QACpB,GAAG,CAAC,YAAY,CAAC,GAAG;YAClB,eAAe,EAAE,cAAc;SAChC,CAAA;KACF;IAED,OAAO,GAAG,CAAA;AACZ,CAAC,EACD,EAAE,CACH,CAAA;AAED,MAAM,UAAU,mBACd,gEAAgE,EAAE;QAChE,YAAY,EACV,gEAAgE;KACnE,EACD,aAAa,EAAE;QACb,YAAY,EAAE,QAAQ;KACvB,IACE,YAAY,CAChB,CAAA;AAED,eAAe,CAAC,EAAE,
|
|
1
|
+
{"version":3,"file":"styles.js","sourceRoot":"","sources":["../../src/LexicalEditor/styles.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"createLexicalTheme.js","sourceRoot":"","sources":["../../../src/LexicalEditor/utils/createLexicalTheme.ts"],"names":[],"mappings":"AASA,MAAM,CAAC,MAAM,kBAAkB,GAAG,CAAC,EACjC,oBAAoB,EACpB,OAAO,GACD,EAAE,EAAE;IACV,MAAM,YAAY,GAAG,KAAK,CAAC,IAAI,CAC7B,EAAE,MAAM,EAAE,CAAC,EAAE,EACb,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,CAAC,gBAAgB,KAAK,GAAG,CAAC,EAAE,CAC1C,CAAA;IAED,MAAM,KAAK,GAAuB;QAChC,IAAI,EAAE,oBAAoB;QAC1B,SAAS,EAAE,OAAO,CAAC,SAAS;QAC5B,IAAI,EAAE;YACJ,MAAM,EAAE,OAAO,CAAC,MAAM;YACtB,IAAI,EAAE,OAAO,CAAC,IAAI;SACnB;QAED,IAAI,EAAE;YACJ,QAAQ,EAAE,OAAO,CAAC,QAAQ;YAC1B,MAAM,EAAE;gBACN,QAAQ,EAAE,kBAAkB;aAC7B;YACD,OAAO,EAAE,YAAY;YACrB,OAAO,EAAE,YAAY;YACrB,EAAE,EAAE,OAAO,CAAC,EAAE;YACd,EAAE,EAAE,OAAO,CAAC,EAAE;SACf;QACD,WAAW,EAAE,OAAO,CAAC,WAAW;KACjC,CAAA;IAED,OAAO,KAAK,CAAA;AACd,CAAC,CAAA"}
|
|
1
|
+
{"version":3,"file":"createLexicalTheme.js","sourceRoot":"","sources":["../../../src/LexicalEditor/utils/createLexicalTheme.ts"],"names":[],"mappings":"AASA,MAAM,CAAC,MAAM,kBAAkB,GAAG,CAAC,EACjC,oBAAoB,EACpB,OAAO,GACD,EAAE,EAAE;IACV,MAAM,YAAY,GAAG,KAAK,CAAC,IAAI,CAC7B,EAAE,MAAM,EAAE,CAAC,EAAE,EACb,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,CAAC,gBAAgB,KAAK,GAAG,CAAC,EAAE,CAC1C,CAAA;IAED,MAAM,KAAK,GAAuB;QAChC,IAAI,EAAE,oBAAoB;QAC1B,SAAS,EAAE,OAAO,CAAC,SAAS;QAC5B,IAAI,EAAE;YACJ,MAAM,EAAE,OAAO,CAAC,MAAM;YACtB,IAAI,EAAE,OAAO,CAAC,IAAI;YAClB,IAAI,EAAE,OAAO,CAAC,IAAI;SACnB;QAED,IAAI,EAAE;YACJ,QAAQ,EAAE,OAAO,CAAC,QAAQ;YAC1B,MAAM,EAAE;gBACN,QAAQ,EAAE,kBAAkB;aAC7B;YACD,OAAO,EAAE,YAAY;YACrB,OAAO,EAAE,YAAY;YACrB,EAAE,EAAE,OAAO,CAAC,EAAE;YACd,EAAE,EAAE,OAAO,CAAC,EAAE;SACf;QACD,WAAW,EAAE,OAAO,CAAC,WAAW;KACjC,CAAA;IAED,OAAO,KAAK,CAAA;AACd,CAAC,CAAA"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { makeStyles } from '@material-ui/core/styles';
|
|
3
|
+
import styles from './styles';
|
|
4
|
+
const useStyles = makeStyles(styles, { name: 'PicassoCode' });
|
|
5
|
+
const CodeComponent = ({ children }) => {
|
|
6
|
+
const classes = useStyles();
|
|
7
|
+
return React.createElement("code", { className: classes.code }, children);
|
|
8
|
+
};
|
|
9
|
+
export default CodeComponent;
|
|
10
|
+
//# sourceMappingURL=Code.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Code.js","sourceRoot":"","sources":["../../../src/RichText/components/Code.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAA;AAErD,OAAO,MAAM,MAAM,UAAU,CAAA;AAM7B,MAAM,SAAS,GAAG,UAAU,CAAQ,MAAM,EAAE,EAAE,IAAI,EAAE,aAAa,EAAE,CAAC,CAAA;AAEpE,MAAM,aAAa,GAAG,CAAC,EAAE,QAAQ,EAAS,EAAE,EAAE;IAC5C,MAAM,OAAO,GAAG,SAAS,EAAE,CAAA;IAE3B,OAAO,8BAAM,SAAS,EAAE,OAAO,CAAC,IAAI,IAAG,QAAQ,CAAQ,CAAA;AACzD,CAAC,CAAA;AAED,eAAe,aAAa,CAAA"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type { Theme } from '@material-ui/core/styles';
|
|
2
|
+
export declare const codeStyles: ({ palette, typography }: Theme) => {
|
|
3
|
+
color: string;
|
|
4
|
+
backgroundColor: string | undefined;
|
|
5
|
+
border: string;
|
|
6
|
+
borderRadius: string;
|
|
7
|
+
padding: string;
|
|
8
|
+
fontSize: string;
|
|
9
|
+
fontFamily: string;
|
|
10
|
+
};
|
|
11
|
+
declare const _default: (theme: Theme) => import("@material-ui/styles").StyleRules<{}, "code">;
|
|
12
|
+
export default _default;
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { createStyles } from '@material-ui/core/styles';
|
|
2
|
+
export const codeStyles = ({ palette, typography }) => ({
|
|
3
|
+
color: palette.red.main,
|
|
4
|
+
backgroundColor: palette.grey.lighter,
|
|
5
|
+
border: `1px solid ${palette.grey.light}`,
|
|
6
|
+
borderRadius: '2px',
|
|
7
|
+
padding: '1px 0.25rem',
|
|
8
|
+
fontSize: typography.fontSizes.xsmall,
|
|
9
|
+
fontFamily: 'monospace',
|
|
10
|
+
});
|
|
11
|
+
export default (theme) => createStyles({
|
|
12
|
+
code: codeStyles(theme),
|
|
13
|
+
});
|
|
14
|
+
//# sourceMappingURL=styles.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"styles.js","sourceRoot":"","sources":["../../../src/RichText/components/styles.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAA;AAEvD,MAAM,CAAC,MAAM,UAAU,GAAG,CAAC,EAAE,OAAO,EAAE,UAAU,EAAS,EAAE,EAAE,CAAC,CAAC;IAC7D,KAAK,EAAE,OAAO,CAAC,GAAG,CAAC,IAAI;IACvB,eAAe,EAAE,OAAO,CAAC,IAAI,CAAC,OAAO;IACrC,MAAM,EAAE,aAAa,OAAO,CAAC,IAAI,CAAC,KAAK,EAAE;IACzC,YAAY,EAAE,KAAK;IACnB,OAAO,EAAE,aAAa;IACtB,QAAQ,EAAE,UAAU,CAAC,SAAS,CAAC,MAAM;IACrC,UAAU,EAAE,WAAW;CACxB,CAAC,CAAA;AAEF,eAAe,CAAC,KAAY,EAAE,EAAE,CAC9B,YAAY,CAAC;IACX,IAAI,EAAE,UAAU,CAAC,KAAK,CAAC;CACxB,CAAC,CAAA"}
|
|
@@ -18,6 +18,7 @@ import ListItem from '@toptal/picasso/ListItem';
|
|
|
18
18
|
import Link from '@toptal/picasso/Link';
|
|
19
19
|
import { Emoji, Image } from '../../components';
|
|
20
20
|
import { isCustomEmoji } from '../../../utils';
|
|
21
|
+
import Code from '../../components/Code';
|
|
21
22
|
// List internaly passes another props to ListItem
|
|
22
23
|
const Li = (_a) => {
|
|
23
24
|
var { children } = _a, props = __rest(_a, ["children"]);
|
|
@@ -49,6 +50,7 @@ const componentMap = {
|
|
|
49
50
|
ul: Ul,
|
|
50
51
|
a: A,
|
|
51
52
|
img: Img,
|
|
53
|
+
code: Code,
|
|
52
54
|
};
|
|
53
55
|
const picassoMapper = (child) => {
|
|
54
56
|
var _a, _b;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useRichText.js","sourceRoot":"","sources":["../../../../src/RichText/hooks/useRichText/useRichText.tsx"],"names":[],"mappings":";;;;;;;;;;;AAAA,OAAO,GAAG,MAAM,qBAAqB,CAAA;AAErC,OAAO,KAAK,EAAE,EAAE,OAAO,EAAE,aAAa,EAAE,cAAc,EAAE,MAAM,OAAO,CAAA;AACrE,OAAO,UAAU,MAAM,4BAA4B,CAAA;AACnD,OAAO,SAAS,MAAM,2BAA2B,CAAA;AACjD,OAAO,IAAI,MAAM,sBAAsB,CAAA;AACvC,OAAO,QAAQ,MAAM,0BAA0B,CAAA;AAC/C,OAAO,IAAI,MAAM,sBAAsB,CAAA;AAGvC,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,kBAAkB,CAAA;AAC/C,OAAO,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAA;
|
|
1
|
+
{"version":3,"file":"useRichText.js","sourceRoot":"","sources":["../../../../src/RichText/hooks/useRichText/useRichText.tsx"],"names":[],"mappings":"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"}
|
package/RichText/types.d.ts
CHANGED
|
@@ -4,7 +4,7 @@ export declare type TextType = {
|
|
|
4
4
|
};
|
|
5
5
|
export declare type ElementType = {
|
|
6
6
|
type: 'element';
|
|
7
|
-
tagName: 'p' | 'h3' | 'strong' | 'em' | 'ul' | 'ol' | 'li' | 'br' | 'a' | 'img';
|
|
7
|
+
tagName: 'p' | 'h3' | 'strong' | 'em' | 'ul' | 'ol' | 'li' | 'br' | 'a' | 'img' | 'code';
|
|
8
8
|
properties: {};
|
|
9
9
|
children: ASTChildType[];
|
|
10
10
|
};
|
package/index.d.ts
CHANGED
|
@@ -2,5 +2,5 @@ export { default as RichTextEditor } from './RichTextEditor';
|
|
|
2
2
|
export type { RichTextEditorProps, RichTextEditorChangeHandler, } from './RichTextEditor';
|
|
3
3
|
export { default as RichText } from './RichText';
|
|
4
4
|
export type { RichTextProps, ASTType } from './RichText';
|
|
5
|
-
export { ImagePlugin, EmojiPlugin, LinkPlugin } from './plugins';
|
|
5
|
+
export { ImagePlugin, EmojiPlugin, LinkPlugin, CodePlugin } from './plugins';
|
|
6
6
|
export type { UploadedImage, CustomEmoji, CustomEmojiGroup } from './plugins';
|
package/index.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
export { default as RichTextEditor } from './RichTextEditor';
|
|
2
2
|
export { default as RichText } from './RichText';
|
|
3
|
-
export { ImagePlugin, EmojiPlugin, LinkPlugin } from './plugins';
|
|
3
|
+
export { ImagePlugin, EmojiPlugin, LinkPlugin, CodePlugin } from './plugins';
|
|
4
4
|
//# sourceMappingURL=index.js.map
|
package/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,IAAI,cAAc,EAAE,MAAM,kBAAkB,CAAA;AAK5D,OAAO,EAAE,OAAO,IAAI,QAAQ,EAAE,MAAM,YAAY,CAAA;AAEhD,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,UAAU,EAAE,MAAM,WAAW,CAAA"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,IAAI,cAAc,EAAE,MAAM,kBAAkB,CAAA;AAK5D,OAAO,EAAE,OAAO,IAAI,QAAQ,EAAE,MAAM,YAAY,CAAA;AAEhD,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,WAAW,CAAA"}
|
package/package.json
CHANGED
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { useLexicalComposerContext } from '@lexical/react/LexicalComposerContext';
|
|
2
|
+
import { Code16 } from '@toptal/picasso';
|
|
3
|
+
import { $getSelection, $isRangeSelection, FORMAT_TEXT_COMMAND } from 'lexical';
|
|
4
|
+
import React, { useState } from 'react';
|
|
5
|
+
import { useRTEPluginContext, useRTEUpdate } from '../api';
|
|
6
|
+
import RichTextEditorButton from '../../RichTextEditorButton';
|
|
7
|
+
const CodeButton = ({ 'data-testid': testId }) => {
|
|
8
|
+
const [active, setActive] = useState(false);
|
|
9
|
+
const [editor] = useLexicalComposerContext();
|
|
10
|
+
const { disabled, focused } = useRTEPluginContext();
|
|
11
|
+
useRTEUpdate(() => {
|
|
12
|
+
const selection = $getSelection();
|
|
13
|
+
if ($isRangeSelection(selection)) {
|
|
14
|
+
setActive(selection.hasFormat('code'));
|
|
15
|
+
}
|
|
16
|
+
});
|
|
17
|
+
const handleCodeClick = () => {
|
|
18
|
+
editor.dispatchCommand(FORMAT_TEXT_COMMAND, 'code');
|
|
19
|
+
};
|
|
20
|
+
return (React.createElement(RichTextEditorButton, { icon: React.createElement(Code16, null), onClick: handleCodeClick, active: active, disabled: disabled || !focused, "data-testid": testId }));
|
|
21
|
+
};
|
|
22
|
+
export default CodeButton;
|
|
23
|
+
//# sourceMappingURL=CodeButton.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CodeButton.js","sourceRoot":"","sources":["../../../src/plugins/CodePlugin/CodeButton.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,yBAAyB,EAAE,MAAM,uCAAuC,CAAA;AACjF,OAAO,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAA;AACxC,OAAO,EAAE,aAAa,EAAE,iBAAiB,EAAE,mBAAmB,EAAE,MAAM,SAAS,CAAA;AAC/E,OAAO,KAAK,EAAE,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AAEvC,OAAO,EAAE,mBAAmB,EAAE,YAAY,EAAE,MAAM,QAAQ,CAAA;AAC1D,OAAO,oBAAoB,MAAM,4BAA4B,CAAA;AAM7D,MAAM,UAAU,GAAG,CAAC,EAAE,aAAa,EAAE,MAAM,EAAS,EAAE,EAAE;IACtD,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAA;IAC3C,MAAM,CAAC,MAAM,CAAC,GAAG,yBAAyB,EAAE,CAAA;IAC5C,MAAM,EAAE,QAAQ,EAAE,OAAO,EAAE,GAAG,mBAAmB,EAAE,CAAA;IAEnD,YAAY,CAAC,GAAG,EAAE;QAChB,MAAM,SAAS,GAAG,aAAa,EAAE,CAAA;QAEjC,IAAI,iBAAiB,CAAC,SAAS,CAAC,EAAE;YAChC,SAAS,CAAC,SAAS,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAA;SACvC;IACH,CAAC,CAAC,CAAA;IAEF,MAAM,eAAe,GAAG,GAAG,EAAE;QAC3B,MAAM,CAAC,eAAe,CAAC,mBAAmB,EAAE,MAAM,CAAC,CAAA;IACrD,CAAC,CAAA;IAED,OAAO,CACL,oBAAC,oBAAoB,IACnB,IAAI,EAAE,oBAAC,MAAM,OAAG,EAChB,OAAO,EAAE,eAAe,EACxB,MAAM,EAAE,MAAM,EACd,QAAQ,EAAE,QAAQ,IAAI,CAAC,OAAO,iBACjB,MAAM,GACnB,CACH,CAAA;AACH,CAAC,CAAA;AAED,eAAe,UAAU,CAAA"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { RTEPluginMeta, Toolbar } from '../api';
|
|
3
|
+
import CodeButton from './CodeButton';
|
|
4
|
+
const PLUGIN_NAME = 'code';
|
|
5
|
+
const CodePlugin = ({ testIds }) => {
|
|
6
|
+
return (React.createElement(Toolbar, { keyName: PLUGIN_NAME },
|
|
7
|
+
React.createElement(CodeButton, { "data-testid": testIds === null || testIds === void 0 ? void 0 : testIds.button })));
|
|
8
|
+
};
|
|
9
|
+
CodePlugin[RTEPluginMeta] = {
|
|
10
|
+
name: PLUGIN_NAME,
|
|
11
|
+
};
|
|
12
|
+
export default CodePlugin;
|
|
13
|
+
//# sourceMappingURL=CodePlugin.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"CodePlugin.js","sourceRoot":"","sources":["../../../src/plugins/CodePlugin/CodePlugin.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AAGzB,OAAO,EAAE,aAAa,EAAE,OAAO,EAAE,MAAM,QAAQ,CAAA;AAC/C,OAAO,UAAU,MAAM,cAAc,CAAA;AAErC,MAAM,WAAW,GAAG,MAAM,CAAA;AAQ1B,MAAM,UAAU,GAAqB,CAAC,EAAE,OAAO,EAAE,EAAE,EAAE;IACnD,OAAO,CACL,oBAAC,OAAO,IAAC,OAAO,EAAE,WAAW;QAC3B,oBAAC,UAAU,mBAAc,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,MAAM,GAAI,CACpC,CACX,CAAA;AACH,CAAC,CAAA;AAED,UAAU,CAAC,aAAa,CAAC,GAAG;IAC1B,IAAI,EAAE,WAAW;CAClB,CAAA;AAED,eAAe,UAAU,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { default } from './CodePlugin';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/plugins/CodePlugin/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAA"}
|
package/plugins/index.d.ts
CHANGED
|
@@ -7,5 +7,6 @@ export { default as ListPlugin } from './ListPlugin';
|
|
|
7
7
|
export { default as TextLengthPlugin } from './TextLengthPlugin';
|
|
8
8
|
export { default as TriggerInitialOnChangePlugin } from './TriggerInitialOnChangePlugin';
|
|
9
9
|
export { default as FocusOnLabelClickPlugin } from './FocusOnLabelClickPlugin';
|
|
10
|
+
export { default as CodePlugin } from './CodePlugin';
|
|
10
11
|
export { default as ImagePlugin } from './ImagePlugin';
|
|
11
12
|
export type { UploadedImage } from './ImagePlugin';
|
package/plugins/index.js
CHANGED
|
@@ -6,5 +6,6 @@ export { default as ListPlugin } from './ListPlugin';
|
|
|
6
6
|
export { default as TextLengthPlugin } from './TextLengthPlugin';
|
|
7
7
|
export { default as TriggerInitialOnChangePlugin } from './TriggerInitialOnChangePlugin';
|
|
8
8
|
export { default as FocusOnLabelClickPlugin } from './FocusOnLabelClickPlugin';
|
|
9
|
+
export { default as CodePlugin } from './CodePlugin';
|
|
9
10
|
export { default as ImagePlugin } from './ImagePlugin';
|
|
10
11
|
//# sourceMappingURL=index.js.map
|
package/plugins/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/plugins/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,IAAI,0BAA0B,EAAE,MAAM,8BAA8B,CAAA;AACpF,OAAO,EAAE,OAAO,IAAI,WAAW,EAAE,MAAM,eAAe,CAAA;AAEtD,OAAO,EAAE,OAAO,IAAI,yBAAyB,EAAE,MAAM,6BAA6B,CAAA;AAClF,OAAO,EAAE,OAAO,IAAI,UAAU,EAA4B,MAAM,cAAc,CAAA;AAC9E,OAAO,EAAE,OAAO,IAAI,UAAU,EAAE,MAAM,cAAc,CAAA;AACpD,OAAO,EAAE,OAAO,IAAI,gBAAgB,EAAE,MAAM,oBAAoB,CAAA;AAChE,OAAO,EAAE,OAAO,IAAI,4BAA4B,EAAE,MAAM,gCAAgC,CAAA;AACxF,OAAO,EAAE,OAAO,IAAI,uBAAuB,EAAE,MAAM,2BAA2B,CAAA;AAC9E,OAAO,EAAE,OAAO,IAAI,WAAW,EAAE,MAAM,eAAe,CAAA"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/plugins/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,IAAI,0BAA0B,EAAE,MAAM,8BAA8B,CAAA;AACpF,OAAO,EAAE,OAAO,IAAI,WAAW,EAAE,MAAM,eAAe,CAAA;AAEtD,OAAO,EAAE,OAAO,IAAI,yBAAyB,EAAE,MAAM,6BAA6B,CAAA;AAClF,OAAO,EAAE,OAAO,IAAI,UAAU,EAA4B,MAAM,cAAc,CAAA;AAC9E,OAAO,EAAE,OAAO,IAAI,UAAU,EAAE,MAAM,cAAc,CAAA;AACpD,OAAO,EAAE,OAAO,IAAI,gBAAgB,EAAE,MAAM,oBAAoB,CAAA;AAChE,OAAO,EAAE,OAAO,IAAI,4BAA4B,EAAE,MAAM,gCAAgC,CAAA;AACxF,OAAO,EAAE,OAAO,IAAI,uBAAuB,EAAE,MAAM,2BAA2B,CAAA;AAC9E,OAAO,EAAE,OAAO,IAAI,UAAU,EAAE,MAAM,cAAc,CAAA;AACpD,OAAO,EAAE,OAAO,IAAI,WAAW,EAAE,MAAM,eAAe,CAAA"}
|
package/utils/html-to-hast.js
CHANGED
|
@@ -11,7 +11,19 @@ export const hastSanitizeSchema = {
|
|
|
11
11
|
img: ['src', 'data*', 'class'],
|
|
12
12
|
'*': [],
|
|
13
13
|
},
|
|
14
|
-
tagNames: [
|
|
14
|
+
tagNames: [
|
|
15
|
+
'h3',
|
|
16
|
+
'p',
|
|
17
|
+
'br',
|
|
18
|
+
'strong',
|
|
19
|
+
'em',
|
|
20
|
+
'ul',
|
|
21
|
+
'ol',
|
|
22
|
+
'li',
|
|
23
|
+
'a',
|
|
24
|
+
'img',
|
|
25
|
+
'code',
|
|
26
|
+
],
|
|
15
27
|
strip: ['script'],
|
|
16
28
|
};
|
|
17
29
|
const htmlToAst = (html) => {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"html-to-hast.js","sourceRoot":"","sources":["../../src/utils/html-to-hast.ts"],"names":[],"mappings":"AACA,OAAO,YAAY,MAAM,oBAAoB,CAAA;AAC7C,OAAO,WAAW,MAAM,oBAAoB,CAAA;AAI5C,MAAM,CAAC,MAAM,kBAAkB,GAAW;IACxC,aAAa,EAAE,KAAK;IACpB,aAAa,EAAE,KAAK;IACpB,SAAS,EAAE;QACT,EAAE,EAAE,CAAC,IAAI,EAAE,IAAI,CAAC;KACjB;IACD,UAAU,EAAE;QACV,CAAC,EAAE,CAAC,MAAM,CAAC;QACX,GAAG,EAAE,CAAC,KAAK,EAAE,OAAO,EAAE,OAAO,CAAC;QAC9B,GAAG,EAAE,EAAE;KACR;IACD,QAAQ,EAAE,
|
|
1
|
+
{"version":3,"file":"html-to-hast.js","sourceRoot":"","sources":["../../src/utils/html-to-hast.ts"],"names":[],"mappings":"AACA,OAAO,YAAY,MAAM,oBAAoB,CAAA;AAC7C,OAAO,WAAW,MAAM,oBAAoB,CAAA;AAI5C,MAAM,CAAC,MAAM,kBAAkB,GAAW;IACxC,aAAa,EAAE,KAAK;IACpB,aAAa,EAAE,KAAK;IACpB,SAAS,EAAE;QACT,EAAE,EAAE,CAAC,IAAI,EAAE,IAAI,CAAC;KACjB;IACD,UAAU,EAAE;QACV,CAAC,EAAE,CAAC,MAAM,CAAC;QACX,GAAG,EAAE,CAAC,KAAK,EAAE,OAAO,EAAE,OAAO,CAAC;QAC9B,GAAG,EAAE,EAAE;KACR;IACD,QAAQ,EAAE;QACR,IAAI;QACJ,GAAG;QACH,IAAI;QACJ,QAAQ;QACR,IAAI;QACJ,IAAI;QACJ,IAAI;QACJ,IAAI;QACJ,GAAG;QACH,KAAK;QACL,MAAM;KACP;IACD,KAAK,EAAE,CAAC,QAAQ,CAAC;CAClB,CAAA;AAED,MAAM,SAAS,GAAG,CAAC,IAAY,EAAE,EAAE;IACjC,MAAM,GAAG,GAAG,IAAI,SAAS,EAAE,CAAC,eAAe,CAAC,IAAI,EAAE,WAAW,CAAC,CAAA;IAC9D,MAAM,OAAO,GAAG,YAAY,CAAC,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,kBAAkB,CAEtD,CAAA;IAEhB,MAAM,GAAG,GAAY;QACnB,IAAI,EAAE,MAAM;QACZ,QAAQ,EAAE,OAAO,CAAC,IAAI,KAAK,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC;KACjE,CAAA;IAED,OAAO,GAAG,CAAA;AACZ,CAAC,CAAA;AAED,eAAe,SAAS,CAAA"}
|