@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.
- package/esm2020/interfaces/editor.mjs +1 -1
- package/esm2020/interfaces/plugins/plugin-key.mjs +2 -2
- package/esm2020/interfaces/valid-children-types.mjs +7 -7
- package/esm2020/plugins/common/insert-data-by-invalid-type.mjs +23 -0
- package/esm2020/plugins/deserialize/deserialize-html.plugin.mjs +53 -0
- package/esm2020/plugins/deserialize/deserialize-md.plugin.mjs +130 -0
- package/esm2020/plugins/index.mjs +5 -5
- package/esm2020/plugins/mention/mention.plugin.mjs +3 -2
- package/esm2020/plugins/mention/mention.type.mjs +1 -1
- package/esm2020/utils/index.mjs +2 -1
- package/esm2020/utils/insert-data-by-invalid-type.mjs +62 -0
- package/esm2020/utils/merge-element-options.mjs +5 -5
- package/fesm2015/worktile-theia.mjs +82 -70
- package/fesm2015/worktile-theia.mjs.map +1 -1
- package/fesm2020/worktile-theia.mjs +81 -69
- package/fesm2020/worktile-theia.mjs.map +1 -1
- package/interfaces/plugins/plugin-key.d.ts +1 -1
- package/interfaces/valid-children-types.d.ts +1 -1
- package/package.json +1 -1
- package/plugins/common/insert-data-by-invalid-type.d.ts +2 -0
- package/plugins/mention/mention.type.d.ts +3 -1
- package/utils/index.d.ts +1 -0
- package/utils/insert-data-by-invalid-type.d.ts +1 -0
- package/esm2020/plugins/common/auto-insert-data.mjs +0 -75
- package/esm2020/plugins/deserializers/deserialize-html.plugin.mjs +0 -48
- package/esm2020/plugins/deserializers/deserialize-md.plugin.mjs +0 -130
- package/plugins/common/auto-insert-data.d.ts +0 -2
- /package/plugins/{deserializers → deserialize}/deserialize-html.plugin.d.ts +0 -0
- /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
|
-
|
|
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
|
-
|
|
4
|
+
invalidChildrenTypes: CustomElementKinds[];
|
|
5
5
|
isSecondaryContainer?: boolean;
|
|
6
6
|
}
|
|
7
7
|
export declare const inValidTypes: CustomElementKinds[];
|
package/package.json
CHANGED
|
@@ -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
|
-
|
|
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
|
@@ -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(>|\>)(.*)/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, {}>;
|
|
File without changes
|
|
File without changes
|