@worktile/theia 15.0.19 → 15.1.1

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.
Files changed (29) hide show
  1. package/esm2020/interfaces/editor.mjs +1 -1
  2. package/esm2020/interfaces/plugins/plugin-key.mjs +2 -2
  3. package/esm2020/interfaces/valid-children-types.mjs +7 -7
  4. package/esm2020/plugins/common/insert-data-by-invalid-type.mjs +23 -0
  5. package/esm2020/plugins/deserialize/deserialize-html.plugin.mjs +53 -0
  6. package/esm2020/plugins/deserialize/deserialize-md.plugin.mjs +130 -0
  7. package/esm2020/plugins/index.mjs +5 -5
  8. package/esm2020/plugins/mention/mention.plugin.mjs +3 -2
  9. package/esm2020/plugins/mention/mention.type.mjs +1 -1
  10. package/esm2020/utils/index.mjs +2 -1
  11. package/esm2020/utils/insert-data-by-invalid-type.mjs +62 -0
  12. package/esm2020/utils/merge-element-options.mjs +5 -5
  13. package/fesm2015/worktile-theia.mjs +82 -70
  14. package/fesm2015/worktile-theia.mjs.map +1 -1
  15. package/fesm2020/worktile-theia.mjs +81 -69
  16. package/fesm2020/worktile-theia.mjs.map +1 -1
  17. package/interfaces/plugins/plugin-key.d.ts +1 -1
  18. package/interfaces/valid-children-types.d.ts +1 -1
  19. package/package.json +1 -1
  20. package/plugins/common/insert-data-by-invalid-type.d.ts +2 -0
  21. package/plugins/mention/mention.type.d.ts +3 -1
  22. package/utils/index.d.ts +1 -0
  23. package/utils/insert-data-by-invalid-type.d.ts +1 -0
  24. package/esm2020/plugins/common/auto-insert-data.mjs +0 -75
  25. package/esm2020/plugins/deserializers/deserialize-html.plugin.mjs +0 -48
  26. package/esm2020/plugins/deserializers/deserialize-md.plugin.mjs +0 -130
  27. package/plugins/common/auto-insert-data.d.ts +0 -2
  28. /package/plugins/{deserializers → deserialize}/deserialize-html.plugin.d.ts +0 -0
  29. /package/plugins/{deserializers → deserialize}/deserialize-md.plugin.d.ts +0 -0
@@ -24,7 +24,7 @@ export declare enum PluginKeys {
24
24
  removeVoid = "remove-void",
25
25
  removeEmpty = "remove-empty",
26
26
  theHistory = "the-history",
27
- autoInsertData = "auto-insert-data",
27
+ insertDataByInvalidType = "insert-data-by-invalid-type",
28
28
  autoFormat = "auto-format",
29
29
  transforms = "transforms",
30
30
  moveSelection = "move-selection",
@@ -1,7 +1,7 @@
1
1
  import { CustomElementKinds } from '../custom-types';
2
2
  export interface ElementOptionsInfo {
3
3
  type: CustomElementKinds;
4
- inValidChildrenTypes: CustomElementKinds[];
4
+ invalidChildrenTypes: CustomElementKinds[];
5
5
  isSecondaryContainer?: boolean;
6
6
  }
7
7
  export declare const inValidTypes: CustomElementKinds[];
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@worktile/theia",
3
- "version": "15.0.19",
3
+ "version": "15.1.1",
4
4
  "description": "theia editor",
5
5
  "author": "YanDong <nanianqiumo@foxmail.com>",
6
6
  "homepage": "https://github.com/atinc/theia#readme",
@@ -0,0 +1,2 @@
1
+ export declare const withInsertDataByInvalidType: <T extends import("../../interfaces").TheEditor>(editor: T) => T;
2
+ export declare const createInsertDataByInvalidTypePlugin: <T = {}>(override?: Partial<import("../../interfaces").ThePlugin<T, {}>>, overrideByKey?: import("../../interfaces").OverrideByKey) => import("../../interfaces").ThePlugin<T, {}>;
@@ -1,9 +1,11 @@
1
1
  import { ComponentType } from '@angular/cdk/portal';
2
- export interface TheMention<T = unknown> {
2
+ import { TheEditor } from '../../interfaces';
3
+ export interface TheMention {
3
4
  type: string;
4
5
  trigger: string;
5
6
  suggestion: ComponentType<any>;
6
7
  render: ComponentType<any>;
8
+ disableTrigger?: (editor: TheEditor) => boolean;
7
9
  }
8
10
  export interface MentionPluginOptions {
9
11
  mentions: TheMention[];
package/utils/index.d.ts CHANGED
@@ -14,3 +14,4 @@ export * from './editor-uuid';
14
14
  export * from './blob';
15
15
  export * from './copy-node';
16
16
  export * from './refocus';
17
+ export * from './insert-data-by-invalid-type';
@@ -0,0 +1 @@
1
+ export declare function insertDataByInvalidType(editor: any, fragment: any): boolean;
@@ -1,75 +0,0 @@
1
- import { Editor, Path, Transforms } from 'slate';
2
- import { AngularEditor } from 'slate-angular';
3
- import { DefaultElementOptions, PluginKeys } from '../../interfaces';
4
- import { createPluginFactory, getPluginOptions } from '../../core';
5
- import { extractFragment } from '../../utils/fragment';
6
- import { mergeElementOptions } from '../../utils/merge-element-options';
7
- import * as TheQueries from '../../queries';
8
- export const withAutoInsertData = (editor) => {
9
- const { insertData } = editor;
10
- let allElementOptions = DefaultElementOptions;
11
- // if (validChildren?.length) {
12
- // const validInfo = mergeElementOptions(validChildren);
13
- // allElementOptions = Object.values(validInfo);
14
- // }
15
- editor.insertData = (data) => {
16
- if (editor.extraElementOptions?.length) {
17
- const extraInfo = mergeElementOptions(editor.extraElementOptions);
18
- allElementOptions = Object.values(extraInfo);
19
- }
20
- const fragment = extractFragment(data);
21
- if (fragment) {
22
- if (TheQueries.isAcrossBlocks(editor, fragment) || Editor.isVoid(editor, fragment[0])) {
23
- const { selection } = editor;
24
- const [start] = Editor.edges(editor, selection);
25
- // query whether there is a node to be verified
26
- const tryVerifyNode = allElementOptions.find(item => TheQueries.getAboveByType(editor, item.type, { at: start, mode: 'lowest' }));
27
- if (tryVerifyNode) {
28
- // is exist invalid element type in fragment
29
- const invalidIndex = fragment.findIndex(item => tryVerifyNode.inValidChildrenTypes.includes(item.type));
30
- if (invalidIndex > -1) {
31
- const invalidFragmentData = fragment.slice(invalidIndex, fragment.length);
32
- const allowParentTypes = getPluginOptions(editor, invalidFragmentData[0].type)?.allowParentTypes || [];
33
- const insertNodePath = TheQueries.getInsertElementsPath(editor, allowParentTypes);
34
- if (insertNodePath) {
35
- Editor.withoutNormalizing(editor, () => {
36
- Transforms.insertNodes(editor, fragment, { at: insertNodePath });
37
- Transforms.select(editor, Editor.start(editor, insertNodePath));
38
- });
39
- return;
40
- }
41
- const [, anchorBlockPath] = TheQueries.anchorBlockEntry(editor);
42
- const nextPath = Path.next([anchorBlockPath[0]]);
43
- Transforms.insertNodes(editor, fragment, { at: nextPath });
44
- Transforms.select(editor, Editor.start(editor, nextPath));
45
- return;
46
- }
47
- }
48
- Editor.withoutNormalizing(editor, () => {
49
- const isEmptyParagraph = TheQueries.isEmptyParagraph(editor, editor.selection.anchor);
50
- const emptyPath = Path.parent(editor.selection.anchor.path);
51
- Transforms.insertNodes(editor, fragment);
52
- if (isEmptyParagraph) {
53
- Transforms.delete(editor, { at: emptyPath });
54
- const lastPath = emptyPath.pop();
55
- Transforms.select(editor, [...emptyPath, lastPath + fragment.length - 1]);
56
- }
57
- else {
58
- const lastPath = emptyPath.pop();
59
- Transforms.select(editor, [...emptyPath, lastPath + fragment.length]);
60
- }
61
- AngularEditor.focus(editor);
62
- Transforms.collapse(editor, { edge: 'end' });
63
- });
64
- return;
65
- }
66
- }
67
- insertData(data);
68
- };
69
- return editor;
70
- };
71
- export const createAutoInsertDataPlugin = createPluginFactory({
72
- key: PluginKeys.autoInsertData,
73
- withOverrides: withAutoInsertData
74
- });
75
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auto-insert-data.js","sourceRoot":"","sources":["../../../../../packages/src/plugins/common/auto-insert-data.ts"],"names":[],"mappings":"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","sourcesContent":["import { Editor, Path, Transforms } from 'slate';\nimport { AngularEditor } from 'slate-angular';\nimport { DefaultElementOptions, PluginKeys } from '../../interfaces';\nimport { createPluginFactory, getPluginOptions } from '../../core';\nimport { extractFragment } from '../../utils/fragment';\nimport { mergeElementOptions } from '../../utils/merge-element-options';\nimport * as TheQueries from '../../queries';\nimport { CustomElementKinds } from '../../custom-types';\n\nexport const withAutoInsertData = <T extends Editor>(editor: T): T => {\n    const { insertData } = editor;\n    let allElementOptions = DefaultElementOptions;\n    // if (validChildren?.length) {\n    //     const validInfo = mergeElementOptions(validChildren);\n    //     allElementOptions = Object.values(validInfo);\n    // }\n\n    editor.insertData = (data: DataTransfer) => {\n        if (editor.extraElementOptions?.length) {\n            const extraInfo = mergeElementOptions(editor.extraElementOptions);\n            allElementOptions = Object.values(extraInfo);\n        }\n        const fragment = extractFragment(data);\n        if (fragment) {\n            if (TheQueries.isAcrossBlocks(editor, fragment) || Editor.isVoid(editor, fragment[0])) {\n                const { selection } = editor;\n                const [start] = Editor.edges(editor, selection);\n                // query whether there is a node to be verified\n                const tryVerifyNode = allElementOptions.find(item =>\n                    TheQueries.getAboveByType(editor, item.type, { at: start, mode: 'lowest' })\n                );\n                if (tryVerifyNode) {\n                    // is exist invalid element type in fragment\n                    const invalidIndex = fragment.findIndex(item => tryVerifyNode.inValidChildrenTypes.includes(item.type));\n                    if (invalidIndex > -1) {\n                        const invalidFragmentData = fragment.slice(invalidIndex, fragment.length);\n                        const allowParentTypes = getPluginOptions(editor, invalidFragmentData[0].type)?.allowParentTypes || [];\n                        const insertNodePath = TheQueries.getInsertElementsPath(editor, allowParentTypes as CustomElementKinds[]);\n                        if (insertNodePath) {\n                            Editor.withoutNormalizing(editor, () => {\n                                Transforms.insertNodes(editor, fragment, { at: insertNodePath });\n                                Transforms.select(editor, Editor.start(editor, insertNodePath));\n                            });\n                            return;\n                        }\n                        const [, anchorBlockPath] = TheQueries.anchorBlockEntry(editor);\n                        const nextPath = Path.next([anchorBlockPath[0]]);\n                        Transforms.insertNodes(editor, fragment, { at: nextPath });\n                        Transforms.select(editor, Editor.start(editor, nextPath));\n                        return;\n                    }\n                }\n                Editor.withoutNormalizing(editor, () => {\n                    const isEmptyParagraph = TheQueries.isEmptyParagraph(editor, editor.selection.anchor);\n                    const emptyPath = Path.parent(editor.selection.anchor.path);\n                    Transforms.insertNodes(editor, fragment);\n                    if (isEmptyParagraph) {\n                        Transforms.delete(editor, { at: emptyPath });\n                        const lastPath = emptyPath.pop();\n                        Transforms.select(editor, [...emptyPath, lastPath + fragment.length - 1]);\n                    } else {\n                        const lastPath = emptyPath.pop();\n                        Transforms.select(editor, [...emptyPath, lastPath + fragment.length]);\n                    }\n                    AngularEditor.focus(editor);\n                    Transforms.collapse(editor, { edge: 'end' });\n                });\n                return;\n            }\n        }\n        insertData(data);\n    };\n\n    return editor;\n};\n\nexport const createAutoInsertDataPlugin = createPluginFactory({\n    key: PluginKeys.autoInsertData,\n    withOverrides: withAutoInsertData\n});\n"]}
@@ -1,48 +0,0 @@
1
- import { Element, Transforms } from 'slate';
2
- import { TheiaConverter } from '@atinc/selene';
3
- import { CLIPBOARD_FORMAT_KEY, ElementKinds } from '../../constants';
4
- import { filterTextFormat, recursionNodes } from '../../utils/fragment';
5
- import { createPluginFactory } from '../../core';
6
- import { PluginKeys } from '../../interfaces';
7
- import { ImageEditor } from '../image/image.editor';
8
- import { isLogicEmptyParagraphElement } from '../../queries/is-empty-paragraph';
9
- export const withDeserializeHTML = (editor) => {
10
- const { insertData } = editor;
11
- editor.insertData = (data) => {
12
- const html = data.getData(`text/html`);
13
- const slateFragment = data.getData(`application/${CLIPBOARD_FORMAT_KEY}`);
14
- if (html && !slateFragment) {
15
- const htmlDom = new DOMParser().parseFromString(html, 'text/html');
16
- const fragment = TheiaConverter.convertToTheia(Array.from(htmlDom.body.children));
17
- // 无法识别HTML内容时后退一下:识别纯文本
18
- if (fragment.every(block => block.type === ElementKinds.paragraph && isLogicEmptyParagraphElement(editor, block))) {
19
- insertData(data);
20
- return;
21
- }
22
- // 识出纯图片并且粘贴板中存在文件则不进行处理, hook 直接右键复制图片的场景,流转到上传图片流程
23
- // 后续需要做识别html图片后自动上传处理
24
- if (fragment.length === 1 && fragment[0].type === ElementKinds.image && data.files.length > 0) {
25
- insertData(data);
26
- return;
27
- }
28
- // 过滤 text 节点的 color/background-color 属性
29
- fragment.forEach(node => filterTextFormat(node));
30
- // base 64 图片处理
31
- recursionNodes(fragment, (node) => {
32
- const isImage = Element.isElement(node) && node.type === ElementKinds.image;
33
- if (isImage) {
34
- ImageEditor.handleBase64ImageElement(editor, node);
35
- }
36
- });
37
- Transforms.insertFragment(editor, fragment);
38
- return;
39
- }
40
- insertData(data);
41
- };
42
- return editor;
43
- };
44
- export const createDeserializeHTMLPlugin = createPluginFactory({
45
- key: PluginKeys.deserializeHtml,
46
- withOverrides: withDeserializeHTML
47
- });
48
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVzZXJpYWxpemUtaHRtbC5wbHVnaW4uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9zcmMvcGx1Z2lucy9kZXNlcmlhbGl6ZXJzL2Rlc2VyaWFsaXplLWh0bWwucGx1Z2luLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBVSxPQUFPLEVBQUUsVUFBVSxFQUFRLE1BQU0sT0FBTyxDQUFDO0FBQzFELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDL0MsT0FBTyxFQUFFLG9CQUFvQixFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQ3JFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxjQUFjLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUN4RSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxZQUFZLENBQUM7QUFDakQsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBQzlDLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUNwRCxPQUFPLEVBQUUsNEJBQTRCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUVoRixNQUFNLENBQUMsTUFBTSxtQkFBbUIsR0FBRyxDQUFtQixNQUFTLEVBQUssRUFBRTtJQUNsRSxNQUFNLEVBQUUsVUFBVSxFQUFFLEdBQUcsTUFBTSxDQUFDO0lBRTlCLE1BQU0sQ0FBQyxVQUFVLEdBQUcsQ0FBQyxJQUFrQixFQUFFLEVBQUU7UUFDdkMsTUFBTSxJQUFJLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUN2QyxNQUFNLGFBQWEsR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLGVBQWUsb0JBQW9CLEVBQUUsQ0FBQyxDQUFDO1FBRTFFLElBQUksSUFBSSxJQUFJLENBQUMsYUFBYSxFQUFFO1lBQ3hCLE1BQU0sT0FBTyxHQUFHLElBQUksU0FBUyxFQUFFLENBQUMsZUFBZSxDQUFDLElBQUksRUFBRSxXQUFXLENBQUMsQ0FBQztZQUNuRSxNQUFNLFFBQVEsR0FBRyxjQUFjLENBQUMsY0FBYyxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBYyxDQUFDO1lBQy9GLHdCQUF3QjtZQUN4QixJQUFJLFFBQVEsQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxLQUFLLENBQUMsSUFBSSxLQUFLLFlBQVksQ0FBQyxTQUFTLElBQUksNEJBQTRCLENBQUMsTUFBTSxFQUFFLEtBQUssQ0FBQyxDQUFDLEVBQUU7Z0JBQy9HLFVBQVUsQ0FBQyxJQUFJLENBQUMsQ0FBQztnQkFDakIsT0FBTzthQUNWO1lBQ0Qsb0RBQW9EO1lBQ3BELHVCQUF1QjtZQUN2QixJQUFJLFFBQVEsQ0FBQyxNQUFNLEtBQUssQ0FBQyxJQUFJLFFBQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLEtBQUssWUFBWSxDQUFDLEtBQUssSUFBSSxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUU7Z0JBQzNGLFVBQVUsQ0FBQyxJQUFJLENBQUMsQ0FBQztnQkFDakIsT0FBTzthQUNWO1lBQ0Qsd0NBQXdDO1lBQ3hDLFFBQVEsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDO1lBRWpELGVBQWU7WUFDZixjQUFjLENBQUMsUUFBUSxFQUFFLENBQUMsSUFBVSxFQUFFLEVBQUU7Z0JBQ3BDLE1BQU0sT0FBTyxHQUFHLE9BQU8sQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLElBQUksSUFBSSxDQUFDLElBQUksS0FBSyxZQUFZLENBQUMsS0FBSyxDQUFDO2dCQUM1RSxJQUFJLE9BQU8sRUFBRTtvQkFDVCxXQUFXLENBQUMsd0JBQXdCLENBQUMsTUFBTSxFQUFFLElBQUksQ0FBQyxDQUFDO2lCQUN0RDtZQUNMLENBQUMsQ0FBQyxDQUFDO1lBQ0gsVUFBVSxDQUFDLGNBQWMsQ0FBQyxNQUFNLEVBQUUsUUFBUSxDQUFDLENBQUM7WUFDNUMsT0FBTztTQUNWO1FBRUQsVUFBVSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ3JCLENBQUMsQ0FBQztJQUNGLE9BQU8sTUFBTSxDQUFDO0FBQ2xCLENBQUMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLDJCQUEyQixHQUFHLG1CQUFtQixDQUFDO0lBQzNELEdBQUcsRUFBRSxVQUFVLENBQUMsZUFBZTtJQUMvQixhQUFhLEVBQUUsbUJBQW1CO0NBQ3JDLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEVkaXRvciwgRWxlbWVudCwgVHJhbnNmb3JtcywgTm9kZSB9IGZyb20gJ3NsYXRlJztcbmltcG9ydCB7IFRoZWlhQ29udmVydGVyIH0gZnJvbSAnQGF0aW5jL3NlbGVuZSc7XG5pbXBvcnQgeyBDTElQQk9BUkRfRk9STUFUX0tFWSwgRWxlbWVudEtpbmRzIH0gZnJvbSAnLi4vLi4vY29uc3RhbnRzJztcbmltcG9ydCB7IGZpbHRlclRleHRGb3JtYXQsIHJlY3Vyc2lvbk5vZGVzIH0gZnJvbSAnLi4vLi4vdXRpbHMvZnJhZ21lbnQnO1xuaW1wb3J0IHsgY3JlYXRlUGx1Z2luRmFjdG9yeSB9IGZyb20gJy4uLy4uL2NvcmUnO1xuaW1wb3J0IHsgUGx1Z2luS2V5cyB9IGZyb20gJy4uLy4uL2ludGVyZmFjZXMnO1xuaW1wb3J0IHsgSW1hZ2VFZGl0b3IgfSBmcm9tICcuLi9pbWFnZS9pbWFnZS5lZGl0b3InO1xuaW1wb3J0IHsgaXNMb2dpY0VtcHR5UGFyYWdyYXBoRWxlbWVudCB9IGZyb20gJy4uLy4uL3F1ZXJpZXMvaXMtZW1wdHktcGFyYWdyYXBoJztcblxuZXhwb3J0IGNvbnN0IHdpdGhEZXNlcmlhbGl6ZUhUTUwgPSA8VCBleHRlbmRzIEVkaXRvcj4oZWRpdG9yOiBUKTogVCA9PiB7XG4gICAgY29uc3QgeyBpbnNlcnREYXRhIH0gPSBlZGl0b3I7XG5cbiAgICBlZGl0b3IuaW5zZXJ0RGF0YSA9IChkYXRhOiBEYXRhVHJhbnNmZXIpID0+IHtcbiAgICAgICAgY29uc3QgaHRtbCA9IGRhdGEuZ2V0RGF0YShgdGV4dC9odG1sYCk7XG4gICAgICAgIGNvbnN0IHNsYXRlRnJhZ21lbnQgPSBkYXRhLmdldERhdGEoYGFwcGxpY2F0aW9uLyR7Q0xJUEJPQVJEX0ZPUk1BVF9LRVl9YCk7XG5cbiAgICAgICAgaWYgKGh0bWwgJiYgIXNsYXRlRnJhZ21lbnQpIHtcbiAgICAgICAgICAgIGNvbnN0IGh0bWxEb20gPSBuZXcgRE9NUGFyc2VyKCkucGFyc2VGcm9tU3RyaW5nKGh0bWwsICd0ZXh0L2h0bWwnKTtcbiAgICAgICAgICAgIGNvbnN0IGZyYWdtZW50ID0gVGhlaWFDb252ZXJ0ZXIuY29udmVydFRvVGhlaWEoQXJyYXkuZnJvbShodG1sRG9tLmJvZHkuY2hpbGRyZW4pKSBhcyBFbGVtZW50W107XG4gICAgICAgICAgICAvLyDml6Dms5Xor4bliKtIVE1M5YaF5a655pe25ZCO6YCA5LiA5LiL77ya6K+G5Yir57qv5paH5pysXG4gICAgICAgICAgICBpZiAoZnJhZ21lbnQuZXZlcnkoYmxvY2sgPT4gYmxvY2sudHlwZSA9PT0gRWxlbWVudEtpbmRzLnBhcmFncmFwaCAmJiBpc0xvZ2ljRW1wdHlQYXJhZ3JhcGhFbGVtZW50KGVkaXRvciwgYmxvY2spKSkge1xuICAgICAgICAgICAgICAgIGluc2VydERhdGEoZGF0YSk7XG4gICAgICAgICAgICAgICAgcmV0dXJuO1xuICAgICAgICAgICAgfVxuICAgICAgICAgICAgLy8g6K+G5Ye657qv5Zu+54mH5bm25LiU57KY6LS05p2/5Lit5a2Y5Zyo5paH5Lu25YiZ5LiN6L+b6KGM5aSE55CGLCBob29rIOebtOaOpeWPs+mUruWkjeWItuWbvueJh+eahOWcuuaZr++8jOa1gei9rOWIsOS4iuS8oOWbvueJh+a1geeoi1xuICAgICAgICAgICAgLy8g5ZCO57ut6ZyA6KaB5YGa6K+G5YiraHRtbOWbvueJh+WQjuiHquWKqOS4iuS8oOWkhOeQhlxuICAgICAgICAgICAgaWYgKGZyYWdtZW50Lmxlbmd0aCA9PT0gMSAmJiBmcmFnbWVudFswXS50eXBlID09PSBFbGVtZW50S2luZHMuaW1hZ2UgJiYgZGF0YS5maWxlcy5sZW5ndGggPiAwKSB7XG4gICAgICAgICAgICAgICAgaW5zZXJ0RGF0YShkYXRhKTtcbiAgICAgICAgICAgICAgICByZXR1cm47XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICAvLyDov4fmu6QgdGV4dCDoioLngrnnmoQgY29sb3IvYmFja2dyb3VuZC1jb2xvciDlsZ7mgKdcbiAgICAgICAgICAgIGZyYWdtZW50LmZvckVhY2gobm9kZSA9PiBmaWx0ZXJUZXh0Rm9ybWF0KG5vZGUpKTtcblxuICAgICAgICAgICAgLy8gYmFzZSA2NCDlm77niYflpITnkIZcbiAgICAgICAgICAgIHJlY3Vyc2lvbk5vZGVzKGZyYWdtZW50LCAobm9kZTogTm9kZSkgPT4ge1xuICAgICAgICAgICAgICAgIGNvbnN0IGlzSW1hZ2UgPSBFbGVtZW50LmlzRWxlbWVudChub2RlKSAmJiBub2RlLnR5cGUgPT09IEVsZW1lbnRLaW5kcy5pbWFnZTtcbiAgICAgICAgICAgICAgICBpZiAoaXNJbWFnZSkge1xuICAgICAgICAgICAgICAgICAgICBJbWFnZUVkaXRvci5oYW5kbGVCYXNlNjRJbWFnZUVsZW1lbnQoZWRpdG9yLCBub2RlKTtcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9KTtcbiAgICAgICAgICAgIFRyYW5zZm9ybXMuaW5zZXJ0RnJhZ21lbnQoZWRpdG9yLCBmcmFnbWVudCk7XG4gICAgICAgICAgICByZXR1cm47XG4gICAgICAgIH1cblxuICAgICAgICBpbnNlcnREYXRhKGRhdGEpO1xuICAgIH07XG4gICAgcmV0dXJuIGVkaXRvcjtcbn07XG5cbmV4cG9ydCBjb25zdCBjcmVhdGVEZXNlcmlhbGl6ZUhUTUxQbHVnaW4gPSBjcmVhdGVQbHVnaW5GYWN0b3J5KHtcbiAgICBrZXk6IFBsdWdpbktleXMuZGVzZXJpYWxpemVIdG1sLFxuICAgIHdpdGhPdmVycmlkZXM6IHdpdGhEZXNlcmlhbGl6ZUhUTUxcbn0pO1xuIl19
@@ -1,130 +0,0 @@
1
- import { ChangeDetectorRef, ViewContainerRef } from '@angular/core';
2
- import { Overlay } from '@angular/cdk/overlay';
3
- import { ThyPopover } from 'ngx-tethys/popover';
4
- import { Element, Text, Transforms } from 'slate';
5
- import { AngularEditor } from 'slate-angular';
6
- import marked from 'marked';
7
- import { TheiaConverter } from '@atinc/selene';
8
- import { CLIPBOARD_FORMAT_KEY, ElementKinds } from '../../constants';
9
- import * as TheTransforms from '../../transforms';
10
- import { TheConversionHintComponent } from '../../components/conversion-hint/conversion-hint.component';
11
- import { THE_EDITOR_CONVERSION_HINT_REF, getToolbarClass, recursionNodes } from '../../utils';
12
- import { createPluginFactory } from '../../core';
13
- import { PluginKeys } from '../../interfaces';
14
- import { ImageEditor } from '../image/image.editor';
15
- export const withDeserializeMd = (editor) => {
16
- const { insertData, onKeydown } = editor;
17
- editor.onKeydown = (event) => {
18
- TheTransforms.closeConversionHint(editor);
19
- onKeydown(event);
20
- };
21
- editor.insertData = (data) => {
22
- const popover = editor.injector.get(ThyPopover);
23
- const viewContainerRef = editor.injector.get(ViewContainerRef);
24
- const cdr = editor.injector.get(ChangeDetectorRef);
25
- const plainFragment = data.getData('text/plain');
26
- const slateFragment = data.getData(`application/${CLIPBOARD_FORMAT_KEY}`);
27
- const oldRange = editor.selection;
28
- TheTransforms.closeConversionHint(editor);
29
- if (plainFragment && isMarkdownStynx(plainFragment) && !slateFragment) {
30
- setTimeout(() => {
31
- const overlay = editor.injector.get(Overlay);
32
- const bodyElement = document.body;
33
- const toolbarClass = getToolbarClass(editor);
34
- const toolbarElement = document.querySelector(`.${toolbarClass}`);
35
- const origin = toolbarElement ? toolbarElement : bodyElement;
36
- const placement = toolbarElement ? 'top' : 'topRight';
37
- const hintPopverRef = popover.open(TheConversionHintComponent, {
38
- initialState: {
39
- editor,
40
- conversion: () => {
41
- try {
42
- const html = marked(plainFragment.replace(/\n```/g, '\n\n```'), { gfm: true });
43
- const htmlDom = new DOMParser().parseFromString(html, 'text/html');
44
- const fragment = TheiaConverter.convertToTheia(Array.from(htmlDom.body.children));
45
- if (!isUnformatted(fragment)) {
46
- TheTransforms.closeConversionHint(editor);
47
- editor.undo();
48
- setTimeout(() => {
49
- Transforms.select(editor, oldRange);
50
- // base 64 图片处理
51
- recursionNodes(fragment, (node) => {
52
- const isImage = Element.isElement(node) && node.type === ElementKinds.image;
53
- if (isImage) {
54
- ImageEditor.handleBase64ImageElement(editor, node);
55
- }
56
- });
57
- Transforms.insertFragment(editor, fragment);
58
- AngularEditor.focus(editor);
59
- });
60
- return;
61
- }
62
- else {
63
- TheTransforms.closeConversionHint(editor);
64
- }
65
- }
66
- catch (error) {
67
- TheTransforms.closeConversionHint(editor);
68
- }
69
- }
70
- },
71
- origin,
72
- viewContainerRef,
73
- placement,
74
- offset: -100,
75
- minWidth: 0,
76
- hasBackdrop: false,
77
- backdropClosable: false,
78
- closeOnNavigation: false,
79
- scrollStrategy: overlay.scrollStrategies.reposition()
80
- });
81
- THE_EDITOR_CONVERSION_HINT_REF.set(editor, hintPopverRef);
82
- cdr.markForCheck();
83
- });
84
- }
85
- insertData(data);
86
- };
87
- return editor;
88
- };
89
- export const createDeserializeMdPlugin = createPluginFactory({
90
- key: PluginKeys.deserializeMd,
91
- withOverrides: withDeserializeMd
92
- });
93
- const isUnformatted = (elements) => {
94
- return elements.every(element => element.type === ElementKinds.default &&
95
- element.children.every((node) => {
96
- return Text.isText(node) && Object.keys(node).length === 1;
97
- }));
98
- };
99
- const isMarkdownStynx = content => {
100
- // https://github.com/Chalarangelo/parse-md-js/blob/master/parsemd.js
101
- const codeBlockRegex = /((\n\t)(.*))+/g;
102
- const inlineCodeRegex = /(`)(.*?)\1/g;
103
- const imageRegex = /!\[([^\[]+)\]\(([^\)]+)\)/g;
104
- const linkRegex = /\[([^\[]+)\]\(([^\)]+)\)/g;
105
- const headingRegex = /(#+\s*)(.*)/g;
106
- const boldItalicsRegex = /(\*{1,2})(\S+)\1/g;
107
- const strikethroughRegex = /(\~\~)(.*?)\1/g;
108
- const blockquoteRegex = /\n(&gt;|\>)(.*)/g;
109
- const horizontalRuleRegex = /\n((\-{3,})|(={3,}))/g;
110
- const unorderedListRegex = /(\n\s*(\-|\+)\s.*)+/g;
111
- const orderedListRegex = /(\n\s*([0-9]+\.)\s.*)+/g;
112
- const paragraphRegex = /\n+(?!<pre>)(?!<h)(?!<ul>)(?!<blockquote)(?!<hr)(?!\t)([^\n]+)\n/g;
113
- // from marked
114
- const table = /^\s*([^\s].*\|.*)\s{0,3}(?:\|\s*)?(:?-+:?\s*(?:\|\s*:?-+:?\s*)*)\|?(?:\s*((?:(?!|hr|heading|blockquote|code|fences|list|html).*(?:|$))*)*|$)/g;
115
- const regexps = [
116
- inlineCodeRegex,
117
- imageRegex,
118
- linkRegex,
119
- headingRegex,
120
- boldItalicsRegex,
121
- strikethroughRegex,
122
- blockquoteRegex,
123
- horizontalRuleRegex,
124
- unorderedListRegex,
125
- orderedListRegex,
126
- table
127
- ];
128
- return regexps.some(regexp => regexp.test(content));
129
- };
130
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"deserialize-md.plugin.js","sourceRoot":"","sources":["../../../../../packages/src/plugins/deserializers/deserialize-md.plugin.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, ViewContainerRef } from '@angular/core';\nimport { Overlay } from '@angular/cdk/overlay';\nimport { ThyPopover } from 'ngx-tethys/popover';\nimport { Editor, Element, Node, Text, Transforms } from 'slate';\nimport { AngularEditor } from 'slate-angular';\nimport marked from 'marked';\nimport { TheiaConverter } from '@atinc/selene';\nimport { CLIPBOARD_FORMAT_KEY, ElementKinds } from '../../constants';\nimport * as TheTransforms from '../../transforms';\nimport { TheConversionHintComponent } from '../../components/conversion-hint/conversion-hint.component';\nimport { THE_EDITOR_CONVERSION_HINT_REF, getToolbarClass, recursionNodes } from '../../utils';\nimport { createPluginFactory } from '../../core';\nimport { PluginKeys } from '../../interfaces';\nimport { ImageEditor } from '../image/image.editor';\n\nexport const withDeserializeMd = <T extends Editor>(editor: T): T => {\n    const { insertData, onKeydown } = editor;\n\n    editor.onKeydown = (event: KeyboardEvent) => {\n        TheTransforms.closeConversionHint(editor);\n        onKeydown(event);\n    };\n\n    editor.insertData = (data: DataTransfer) => {\n        const popover = editor.injector.get(ThyPopover);\n        const viewContainerRef = editor.injector.get(ViewContainerRef);\n        const cdr = editor.injector.get(ChangeDetectorRef);\n\n        const plainFragment = data.getData('text/plain');\n        const slateFragment = data.getData(`application/${CLIPBOARD_FORMAT_KEY}`);\n        const oldRange = editor.selection;\n        TheTransforms.closeConversionHint(editor);\n\n        if (plainFragment && isMarkdownStynx(plainFragment) && !slateFragment) {\n            setTimeout(() => {\n                const overlay = editor.injector.get(Overlay);\n                const bodyElement = document.body;\n                const toolbarClass = getToolbarClass(editor);\n                const toolbarElement = document.querySelector(`.${toolbarClass}`) as HTMLElement;\n                const origin = toolbarElement ? toolbarElement : bodyElement;\n                const placement = toolbarElement ? 'top' : 'topRight';\n\n                const hintPopverRef = popover.open(TheConversionHintComponent, {\n                    initialState: {\n                        editor,\n                        conversion: () => {\n                            try {\n                                const html = marked(plainFragment.replace(/\\n```/g, '\\n\\n```'), { gfm: true });\n                                const htmlDom = new DOMParser().parseFromString(html, 'text/html');\n                                const fragment = TheiaConverter.convertToTheia(Array.from(htmlDom.body.children));\n\n                                if (!isUnformatted(fragment)) {\n                                    TheTransforms.closeConversionHint(editor);\n\n                                    editor.undo();\n\n                                    setTimeout(() => {\n                                        Transforms.select(editor, oldRange);\n                                        // base 64 图片处理\n                                        recursionNodes(fragment, (node: Node) => {\n                                            const isImage = Element.isElement(node) && node.type === ElementKinds.image;\n                                            if (isImage) {\n                                                ImageEditor.handleBase64ImageElement(editor, node);\n                                            }\n                                        });\n                                        Transforms.insertFragment(editor, fragment);\n                                        AngularEditor.focus(editor);\n                                    });\n                                    return;\n                                } else {\n                                    TheTransforms.closeConversionHint(editor);\n                                }\n                            } catch (error) {\n                                TheTransforms.closeConversionHint(editor);\n                            }\n                        }\n                    },\n                    origin,\n                    viewContainerRef,\n                    placement,\n                    offset: -100,\n                    minWidth: 0,\n                    hasBackdrop: false,\n                    backdropClosable: false,\n                    closeOnNavigation: false,\n                    scrollStrategy: overlay.scrollStrategies.reposition()\n                });\n                THE_EDITOR_CONVERSION_HINT_REF.set(editor, hintPopverRef);\n                cdr.markForCheck();\n            });\n        }\n\n        insertData(data);\n    };\n    return editor;\n};\n\nexport const createDeserializeMdPlugin = createPluginFactory({\n    key: PluginKeys.deserializeMd,\n    withOverrides: withDeserializeMd\n});\n\nconst isUnformatted = (elements: Element[]) => {\n    return elements.every(\n        element =>\n            element.type === ElementKinds.default &&\n            element.children.every((node: Node) => {\n                return Text.isText(node) && Object.keys(node).length === 1;\n            })\n    );\n};\n\nconst isMarkdownStynx = content => {\n    // https://github.com/Chalarangelo/parse-md-js/blob/master/parsemd.js\n    const codeBlockRegex = /((\\n\\t)(.*))+/g;\n    const inlineCodeRegex = /(`)(.*?)\\1/g;\n    const imageRegex = /!\\[([^\\[]+)\\]\\(([^\\)]+)\\)/g;\n    const linkRegex = /\\[([^\\[]+)\\]\\(([^\\)]+)\\)/g;\n    const headingRegex = /(#+\\s*)(.*)/g;\n    const boldItalicsRegex = /(\\*{1,2})(\\S+)\\1/g;\n    const strikethroughRegex = /(\\~\\~)(.*?)\\1/g;\n    const blockquoteRegex = /\\n(&gt;|\\>)(.*)/g;\n    const horizontalRuleRegex = /\\n((\\-{3,})|(={3,}))/g;\n    const unorderedListRegex = /(\\n\\s*(\\-|\\+)\\s.*)+/g;\n    const orderedListRegex = /(\\n\\s*([0-9]+\\.)\\s.*)+/g;\n    const paragraphRegex = /\\n+(?!<pre>)(?!<h)(?!<ul>)(?!<blockquote)(?!<hr)(?!\\t)([^\\n]+)\\n/g;\n    // from marked\n    const table =\n        /^\\s*([^\\s].*\\|.*)\\s{0,3}(?:\\|\\s*)?(:?-+:?\\s*(?:\\|\\s*:?-+:?\\s*)*)\\|?(?:\\s*((?:(?!|hr|heading|blockquote|code|fences|list|html).*(?:|$))*)*|$)/g;\n    const regexps = [\n        inlineCodeRegex,\n        imageRegex,\n        linkRegex,\n        headingRegex,\n        boldItalicsRegex,\n        strikethroughRegex,\n        blockquoteRegex,\n        horizontalRuleRegex,\n        unorderedListRegex,\n        orderedListRegex,\n        table\n    ];\n    return regexps.some(regexp => regexp.test(content));\n};\n"]}
@@ -1,2 +0,0 @@
1
- export declare const withAutoInsertData: <T extends import("../../interfaces").TheEditor>(editor: T) => T;
2
- export declare const createAutoInsertDataPlugin: <T = {}>(override?: Partial<import("../../interfaces").ThePlugin<T, {}>>, overrideByKey?: import("../../interfaces").OverrideByKey) => import("../../interfaces").ThePlugin<T, {}>;