@worktile/theia 2.2.7 → 2.3.0-next.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/bundles/worktile-theia.umd.js +852 -249
- package/bundles/worktile-theia.umd.js.map +1 -1
- package/components/toolbar/toolbar.component.d.ts +3 -2
- package/components/toolbar-item/toolbar-item.component.d.ts +3 -4
- package/constants/default.d.ts +3 -0
- package/constants/node-types.d.ts +4 -0
- package/custom-types.d.ts +3 -1
- package/editor.component.d.ts +3 -1
- package/editor.module.d.ts +26 -24
- package/esm2015/components/toolbar/toolbar.component.js +6 -4
- package/esm2015/components/toolbar-item/toolbar-item.component.js +4 -4
- package/esm2015/constants/auto-format-rules.js +26 -7
- package/esm2015/constants/default.js +2 -1
- package/esm2015/constants/node-types.js +6 -1
- package/esm2015/custom-types.js +1 -1
- package/esm2015/editor.component.js +12 -6
- package/esm2015/editor.module.js +6 -3
- package/esm2015/interfaces/editor.js +1 -1
- package/esm2015/interfaces/image.js +1 -1
- package/esm2015/interfaces/valid-children-types.js +2 -1
- package/esm2015/plugins/align/align.editor.js +10 -2
- package/esm2015/plugins/align/options.js +3 -2
- package/esm2015/plugins/common/auto-insert-data..js +2 -18
- package/esm2015/plugins/dnd/component/dnd.component.js +260 -0
- package/esm2015/plugins/dnd/utils/get-current-target.js +19 -0
- package/esm2015/plugins/dnd/utils/get-hover-direction.js +13 -0
- package/esm2015/plugins/dnd/utils/is-valid-drag.js +38 -0
- package/esm2015/plugins/dnd/utils/move-drag-node.js +30 -0
- package/esm2015/plugins/dnd/utils/remove-drop-thumb-line.js +10 -0
- package/esm2015/plugins/image/image.component.js +167 -14
- package/esm2015/plugins/image/image.editor.js +4 -1
- package/esm2015/plugins/indent/on-keydown-indent.js +2 -3
- package/esm2015/plugins/list/list.editor.js +2 -2
- package/esm2015/plugins/quick-insert/components/quick-insert.component.js +13 -2
- package/esm2015/plugins/quick-insert/components/quick-toolbar/quick-toolbar.component.js +1 -1
- package/esm2015/services/context.service.js +5 -1
- package/esm2015/utils/dom.js +39 -1
- package/esm2015/utils/is-clean-empty-paragraph.js +4 -4
- package/esm2015/utils/merge-element-options.js +20 -0
- package/fesm2015/worktile-theia.js +786 -201
- package/fesm2015/worktile-theia.js.map +1 -1
- package/interfaces/editor.d.ts +9 -1
- package/interfaces/image.d.ts +7 -1
- package/interfaces/valid-children-types.d.ts +1 -0
- package/package.json +1 -1
- package/plugins/align/align.editor.d.ts +1 -0
- package/plugins/dnd/component/dnd.component.d.ts +42 -0
- package/plugins/dnd/component/dnd.component.scss +61 -0
- package/plugins/dnd/utils/get-current-target.d.ts +2 -0
- package/plugins/dnd/utils/get-hover-direction.d.ts +3 -0
- package/plugins/dnd/utils/is-valid-drag.d.ts +3 -0
- package/plugins/dnd/utils/move-drag-node.d.ts +2 -0
- package/plugins/dnd/utils/remove-drop-thumb-line.d.ts +2 -0
- package/plugins/image/image.component.d.ts +27 -3
- package/plugins/image/image.component.scss +9 -2
- package/plugins/image/image.editor.d.ts +6 -1
- package/plugins/quick-insert/components/quick-insert.component.d.ts +1 -0
- package/plugins/table/components/table.component.scss +1 -0
- package/services/context.service.d.ts +1 -0
- package/styles/editor.scss +4 -0
- package/styles/index.scss +1 -0
- package/styles/typo.scss +44 -0
- package/utils/dom.d.ts +5 -1
- package/utils/merge-element-options.d.ts +2 -0
|
@@ -4,6 +4,7 @@ import * as TheQueries from '../../queries';
|
|
|
4
4
|
import { DefaultElementOptions } from '../../interfaces';
|
|
5
5
|
import * as TheTransforms from '../../transforms';
|
|
6
6
|
import { extractFragment } from '../../utils/fragment';
|
|
7
|
+
import { mergeElementOptions } from '../../utils/merge-element-options';
|
|
7
8
|
export const withAutoInsertData = (validChildren) => (editor) => {
|
|
8
9
|
const { insertData } = editor;
|
|
9
10
|
let allElementOptions = DefaultElementOptions;
|
|
@@ -69,21 +70,4 @@ export const withAutoInsertData = (validChildren) => (editor) => {
|
|
|
69
70
|
};
|
|
70
71
|
return editor;
|
|
71
72
|
};
|
|
72
|
-
|
|
73
|
-
elementOptions = elementOptions.filter(item => item.inValidChildrenTypes.length > 0);
|
|
74
|
-
const combinationData = [...DefaultElementOptions, ...elementOptions];
|
|
75
|
-
const dataInfo = {};
|
|
76
|
-
combinationData.forEach(item => {
|
|
77
|
-
const { type, inValidChildrenTypes, isIndivisible } = item;
|
|
78
|
-
if (!dataInfo[type]) {
|
|
79
|
-
dataInfo[type] = {
|
|
80
|
-
type,
|
|
81
|
-
inValidChildrenTypes,
|
|
82
|
-
isIndivisible
|
|
83
|
-
};
|
|
84
|
-
}
|
|
85
|
-
dataInfo[type].inValidChildrenTypes = Array.from(new Set([...inValidChildrenTypes, ...dataInfo[type].inValidChildrenTypes]));
|
|
86
|
-
});
|
|
87
|
-
return dataInfo;
|
|
88
|
-
};
|
|
89
|
-
//# 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 * as TheQueries from '../../queries';\nimport { DefaultElementOptions, ElementOptionsInfo } from '../../interfaces';\nimport * as TheTransforms from '../../transforms';\nimport { extractFragment } from '../../utils/fragment';\n\nexport const withAutoInsertData = (validChildren?: ElementOptionsInfo[]) => (editor: Editor) => {\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 indivisibleTypes = allElementOptions.filter(item => item.isIndivisible).map(item => item.type);\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 validFragmentData = fragment.slice(0, invalidIndex);\n                        const invalidFragmentData = fragment.slice(invalidIndex, fragment.length);\n                        Editor.withoutNormalizing(editor, () => {\n                            if (validFragmentData.length > 0) {\n                                validFragmentData.forEach(item => {\n                                    Transforms.insertNodes(editor, item);\n                                });\n                            }\n                            // split node\n                            const path = TheTransforms.splitNode(editor, indivisibleTypes);\n                            Transforms.insertNodes(editor, invalidFragmentData, {\n                                at: Path.next(path)\n                            });\n                        });\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\nconst mergeElementOptions = (elementOptions: ElementOptionsInfo[]) => {\n    elementOptions = elementOptions.filter(item => item.inValidChildrenTypes.length > 0);\n    const combinationData = [...DefaultElementOptions, ...elementOptions];\n    const dataInfo = {};\n    combinationData.forEach(item => {\n        const { type, inValidChildrenTypes, isIndivisible } = item;\n        if (!dataInfo[type]) {\n            dataInfo[type] = {\n                type,\n                inValidChildrenTypes,\n                isIndivisible\n            };\n        }\n        dataInfo[type].inValidChildrenTypes = Array.from(new Set([...inValidChildrenTypes, ...dataInfo[type].inValidChildrenTypes]));\n    });\n    return dataInfo;\n};\n"]}
|
|
73
|
+
//# 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 * as TheQueries from '../../queries';\nimport { DefaultElementOptions, ElementOptionsInfo } from '../../interfaces';\nimport * as TheTransforms from '../../transforms';\nimport { extractFragment } from '../../utils/fragment';\nimport { mergeElementOptions } from '../../utils/merge-element-options';\n\nexport const withAutoInsertData = (validChildren?: ElementOptionsInfo[]) => (editor: Editor) => {\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 indivisibleTypes = allElementOptions.filter(item => item.isIndivisible).map(item => item.type);\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 validFragmentData = fragment.slice(0, invalidIndex);\n                        const invalidFragmentData = fragment.slice(invalidIndex, fragment.length);\n                        Editor.withoutNormalizing(editor, () => {\n                            if (validFragmentData.length > 0) {\n                                validFragmentData.forEach(item => {\n                                    Transforms.insertNodes(editor, item);\n                                });\n                            }\n                            // split node\n                            const path = TheTransforms.splitNode(editor, indivisibleTypes);\n                            Transforms.insertNodes(editor, invalidFragmentData, {\n                                at: Path.next(path)\n                            });\n                        });\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"]}
|
|
@@ -0,0 +1,260 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
|
|
2
|
+
import { fromEvent, merge, Subject } from 'rxjs';
|
|
3
|
+
import { filter, takeUntil } from 'rxjs/operators';
|
|
4
|
+
import { Editor, Operation } from 'slate';
|
|
5
|
+
import { AngularEditor, EDITOR_TO_ELEMENT } from 'slate-angular';
|
|
6
|
+
import { DROP_THUMB_LINE } from '../../../constants';
|
|
7
|
+
import { TheContextService } from '../../../services/context.service';
|
|
8
|
+
import { coercePixelsFromCssValue, findNodeEntryByPoint } from '../../../utils/dom';
|
|
9
|
+
import { getCurrentTarget } from '../utils/get-current-target';
|
|
10
|
+
import { getHoverDirection } from '../utils/get-hover-direction';
|
|
11
|
+
import { moveDragNode } from '../utils/move-drag-node';
|
|
12
|
+
import { isValidDrag } from '../utils/is-valid-drag';
|
|
13
|
+
import * as i0 from "@angular/core";
|
|
14
|
+
import * as i1 from "ngx-tethys/icon";
|
|
15
|
+
import * as i2 from "@angular/common";
|
|
16
|
+
const SNAPSHOT_PADDING_WIDTH = 5;
|
|
17
|
+
const SNAPSHOT_LIMI_HEIGHT = 70;
|
|
18
|
+
const DRAG_ICON_SIZE = 24;
|
|
19
|
+
const DRAG_ICON_OFFSET = 5;
|
|
20
|
+
export class TheDndComponent {
|
|
21
|
+
constructor(renderer, elementRef, ngZone, cdr) {
|
|
22
|
+
this.renderer = renderer;
|
|
23
|
+
this.elementRef = elementRef;
|
|
24
|
+
this.ngZone = ngZone;
|
|
25
|
+
this.cdr = cdr;
|
|
26
|
+
this.isDraging = false;
|
|
27
|
+
this.destroy$ = new Subject();
|
|
28
|
+
this.dragChange = new EventEmitter();
|
|
29
|
+
this.dropThumbLine = document.createElement('div');
|
|
30
|
+
this.dropThumbLine.className = DROP_THUMB_LINE;
|
|
31
|
+
}
|
|
32
|
+
get nativeElement() {
|
|
33
|
+
return this.elementRef.nativeElement;
|
|
34
|
+
}
|
|
35
|
+
get editableElement() {
|
|
36
|
+
return this.editor && EDITOR_TO_ELEMENT.get(this.editor);
|
|
37
|
+
}
|
|
38
|
+
ngAfterViewInit() {
|
|
39
|
+
const contextService = this.editor.injector.get(TheContextService);
|
|
40
|
+
this.ngZone.runOutsideAngular(() => {
|
|
41
|
+
merge(fromEvent(this.editableElement, `mousemove`), fromEvent(this.editableElement, `mouseleave`))
|
|
42
|
+
.pipe(takeUntil(this.destroy$), filter(() => {
|
|
43
|
+
return !contextService.getOptions().theOptions.readonly && contextService.getOptions().theOptions.dragAndDrop;
|
|
44
|
+
}))
|
|
45
|
+
.subscribe(e => this.setDragIcon(e));
|
|
46
|
+
fromEvent(document, `drop`)
|
|
47
|
+
.pipe(takeUntil(this.destroy$), filter(() => {
|
|
48
|
+
return !contextService.getOptions().theOptions.readonly && contextService.getOptions().theOptions.dragAndDrop;
|
|
49
|
+
}))
|
|
50
|
+
.subscribe(e => this.onDrop(e));
|
|
51
|
+
fromEvent(document, `dragover`)
|
|
52
|
+
.pipe(takeUntil(this.destroy$), filter(() => {
|
|
53
|
+
return !contextService.getOptions().theOptions.readonly && contextService.getOptions().theOptions.dragAndDrop;
|
|
54
|
+
}))
|
|
55
|
+
.subscribe(e => this.onDragover(e));
|
|
56
|
+
fromEvent(document, `scroll`)
|
|
57
|
+
.pipe(takeUntil(this.destroy$), filter(() => {
|
|
58
|
+
return !contextService.getOptions().theOptions.readonly && contextService.getOptions().theOptions.dragAndDrop;
|
|
59
|
+
}))
|
|
60
|
+
.subscribe(e => {
|
|
61
|
+
e.preventDefault();
|
|
62
|
+
let scrollPosition = window.scrollY;
|
|
63
|
+
if (!this.isScrolling && this.isDraging) {
|
|
64
|
+
window.requestAnimationFrame(() => {
|
|
65
|
+
if (this.editableTop) {
|
|
66
|
+
// 滚动过程中,通过设置父级元素来设置snapshot位置
|
|
67
|
+
this.updateDndContainerPosition(null, scrollPosition + this.editableTop + 'px');
|
|
68
|
+
}
|
|
69
|
+
this.isScrolling = false;
|
|
70
|
+
});
|
|
71
|
+
this.isScrolling = true;
|
|
72
|
+
}
|
|
73
|
+
});
|
|
74
|
+
});
|
|
75
|
+
this.setVisibility(false);
|
|
76
|
+
this.valueChangeHandle();
|
|
77
|
+
}
|
|
78
|
+
valueChangeHandle() {
|
|
79
|
+
const { onChange } = this.editor;
|
|
80
|
+
this.editor.onChange = () => {
|
|
81
|
+
const ops = this.editor.operations;
|
|
82
|
+
const skip = ops.length === 1 && Operation.isSelectionOperation(ops[0]);
|
|
83
|
+
if (!skip) {
|
|
84
|
+
this.setVisibility(false);
|
|
85
|
+
}
|
|
86
|
+
onChange();
|
|
87
|
+
};
|
|
88
|
+
}
|
|
89
|
+
updateDndContainerPosition(left, top) {
|
|
90
|
+
const element = this.elementRef.nativeElement;
|
|
91
|
+
const parentElement = element.parentElement;
|
|
92
|
+
top && this.renderer.setStyle(parentElement, 'top', top);
|
|
93
|
+
left && this.renderer.setStyle(parentElement, 'left', left);
|
|
94
|
+
}
|
|
95
|
+
getEditableTop(event) {
|
|
96
|
+
const offsetHeight = document.documentElement.offsetHeight;
|
|
97
|
+
const { height } = this.editableElement.getBoundingClientRect();
|
|
98
|
+
if (event.clientY < this.dragElementHeight) {
|
|
99
|
+
this.editableTop = -this.editableElement.offsetTop;
|
|
100
|
+
return;
|
|
101
|
+
}
|
|
102
|
+
if (height > event.pageY && event.clientY + this.dragElementHeight >= offsetHeight) {
|
|
103
|
+
this.editableTop = event.clientY - this.editableElement.offsetTop;
|
|
104
|
+
return;
|
|
105
|
+
}
|
|
106
|
+
this.editableTop = null;
|
|
107
|
+
}
|
|
108
|
+
onDragStart(event) {
|
|
109
|
+
this.isDraging = true;
|
|
110
|
+
this.dragChange.emit(this.isDraging);
|
|
111
|
+
this.dragSnapshotContent = document.querySelector('.drag-snapshot-container');
|
|
112
|
+
this.dragSnapshotContent.className = 'the-editor-typo drag-snapshot-container';
|
|
113
|
+
this.dragSnapshotContent.appendChild(this.dragElement.cloneNode(true));
|
|
114
|
+
this.dragElement.style.opacity = '0.3';
|
|
115
|
+
}
|
|
116
|
+
onDragEnd(event) {
|
|
117
|
+
this.dragElement.style.opacity = '';
|
|
118
|
+
this.isDraging = false;
|
|
119
|
+
this.setVisibility(false);
|
|
120
|
+
this.resetDragSnapshotContent();
|
|
121
|
+
this.dragChange.emit(this.isDraging);
|
|
122
|
+
}
|
|
123
|
+
onDrop(event) {
|
|
124
|
+
event.preventDefault();
|
|
125
|
+
if (this.isDraging) {
|
|
126
|
+
moveDragNode(this.editor, this.dragNode, event);
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
onDragover(event) {
|
|
130
|
+
event.preventDefault();
|
|
131
|
+
if (this.isDraging && !this.isScrolling) {
|
|
132
|
+
this.getEditableTop(event);
|
|
133
|
+
const offsetWidth = document.documentElement.offsetWidth;
|
|
134
|
+
const { left: editorLeft, top: editorTop, height } = this.editableElement.getBoundingClientRect();
|
|
135
|
+
let top = 0;
|
|
136
|
+
let left = 0;
|
|
137
|
+
if (editorLeft > 0) {
|
|
138
|
+
if (event.clientX + this.dragElementWidth / 2 > offsetWidth) {
|
|
139
|
+
left = event.pageX - editorLeft - this.elementRef.nativeElement.offsetWidth;
|
|
140
|
+
}
|
|
141
|
+
else {
|
|
142
|
+
left = Math.max(event.pageX - editorLeft, -editorLeft) + 10;
|
|
143
|
+
}
|
|
144
|
+
}
|
|
145
|
+
let paddingTop = 0; // paddingTop: 编辑器距离顶部的距离
|
|
146
|
+
if (editorTop >= 0) {
|
|
147
|
+
// 无滚动情况下
|
|
148
|
+
top = event.clientY - this.editableElement.offsetTop;
|
|
149
|
+
paddingTop = editorTop - this.editableElement.offsetTop;
|
|
150
|
+
}
|
|
151
|
+
else {
|
|
152
|
+
// 有滚动距离
|
|
153
|
+
top = Math.abs(editorTop) + event.clientY; // 滚动距离 + 鼠标clientY
|
|
154
|
+
paddingTop = event.pageY - this.editableElement.offsetTop - top;
|
|
155
|
+
// 防止底部出现滚动条
|
|
156
|
+
if (paddingTop < height - top) {
|
|
157
|
+
top = top + paddingTop;
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
this.updateDndContainerPosition(left + 'px', top + 'px');
|
|
161
|
+
this.setSnapshotStyle(event);
|
|
162
|
+
this.setDropThumbLine(event);
|
|
163
|
+
}
|
|
164
|
+
}
|
|
165
|
+
setDropThumbLine(event) {
|
|
166
|
+
var _a;
|
|
167
|
+
let element = getCurrentTarget(this.editor, event);
|
|
168
|
+
const direction = getHoverDirection(this.editor, event);
|
|
169
|
+
if (element) {
|
|
170
|
+
if (direction && direction === 'top') {
|
|
171
|
+
element = (_a = element.previousElementSibling) === null || _a === void 0 ? void 0 : _a.querySelector('[data-slate-node="element"]');
|
|
172
|
+
}
|
|
173
|
+
if (element && isValidDrag(this.editor, this.dragNode.node, element)) {
|
|
174
|
+
element.appendChild(this.dropThumbLine);
|
|
175
|
+
}
|
|
176
|
+
}
|
|
177
|
+
}
|
|
178
|
+
setDragIcon(event) {
|
|
179
|
+
if (!this.isDraging) {
|
|
180
|
+
const nodeEntry = findNodeEntryByPoint(this.editor, event.x, event.y, 'highest');
|
|
181
|
+
if (nodeEntry && !Editor.isEmpty(this.editor, nodeEntry[0])) {
|
|
182
|
+
const rootNode = AngularEditor.toDOMNode(this.editor, nodeEntry[0]);
|
|
183
|
+
this.dragNode = {
|
|
184
|
+
node: nodeEntry[0],
|
|
185
|
+
path: nodeEntry[1]
|
|
186
|
+
};
|
|
187
|
+
this.dragElement = rootNode;
|
|
188
|
+
let lineHeight = coercePixelsFromCssValue(window.getComputedStyle(rootNode)['lineHeight']);
|
|
189
|
+
const offsetTop = rootNode.offsetTop + rootNode.offsetParent.offsetTop + (lineHeight - DRAG_ICON_SIZE) / 2;
|
|
190
|
+
const offsetLeft = rootNode.offsetLeft + rootNode.offsetParent.offsetLeft;
|
|
191
|
+
this.updateDndContainerPosition(offsetLeft - DRAG_ICON_SIZE - DRAG_ICON_OFFSET + 'px', offsetTop + 'px');
|
|
192
|
+
this.setVisibility(true);
|
|
193
|
+
}
|
|
194
|
+
else {
|
|
195
|
+
this.setVisibility(false);
|
|
196
|
+
}
|
|
197
|
+
}
|
|
198
|
+
}
|
|
199
|
+
setSnapshotStyle(event) {
|
|
200
|
+
const { width, height } = this.dragElement.getBoundingClientRect();
|
|
201
|
+
this.dragElementHeight = height;
|
|
202
|
+
this.dragElementWidth = width;
|
|
203
|
+
let dragSnapshotContentStyle = `visibility: visible; width: ${width + SNAPSHOT_PADDING_WIDTH * 2}px;`;
|
|
204
|
+
if (height > SNAPSHOT_LIMI_HEIGHT) {
|
|
205
|
+
dragSnapshotContentStyle = dragSnapshotContentStyle + 'transform: scale(0.45);';
|
|
206
|
+
this.dragElementHeight = this.dragElementHeight * 0.45;
|
|
207
|
+
this.dragElementWidth = this.dragElementWidth * 0.45;
|
|
208
|
+
}
|
|
209
|
+
let snapshotTop = 0;
|
|
210
|
+
let snapshotLeft = 0;
|
|
211
|
+
// 上下移动:超出屏幕高度,重新设置snapshot的位置
|
|
212
|
+
if (event.clientY + this.dragElementHeight > document.documentElement.offsetHeight) {
|
|
213
|
+
snapshotTop = this.dragElementHeight;
|
|
214
|
+
}
|
|
215
|
+
else {
|
|
216
|
+
snapshotTop = 0;
|
|
217
|
+
}
|
|
218
|
+
// 左右移动:超出屏幕宽度,重新设置snapshot的位置
|
|
219
|
+
if (event.clientX + this.dragElementWidth / 2 > document.documentElement.offsetWidth) {
|
|
220
|
+
snapshotLeft = this.dragElementWidth;
|
|
221
|
+
}
|
|
222
|
+
else {
|
|
223
|
+
snapshotLeft = 0;
|
|
224
|
+
}
|
|
225
|
+
dragSnapshotContentStyle = dragSnapshotContentStyle + `top: ${-snapshotTop}px; left: ${-snapshotLeft}px;`;
|
|
226
|
+
this.dragSnapshotContent.setAttribute('style', dragSnapshotContentStyle);
|
|
227
|
+
}
|
|
228
|
+
resetDragSnapshotContent() {
|
|
229
|
+
this.dragSnapshotContent.className = 'drag-snapshot-container';
|
|
230
|
+
this.dragSnapshotContent.setAttribute('style', '');
|
|
231
|
+
this.dragSnapshotContent.innerHTML = '';
|
|
232
|
+
}
|
|
233
|
+
setVisibility(visible = true) {
|
|
234
|
+
this.nativeElement.parentNode.style.visibility = visible ? 'visible' : 'hidden';
|
|
235
|
+
}
|
|
236
|
+
ngOnDestroy() {
|
|
237
|
+
this.destroy$.next();
|
|
238
|
+
this.destroy$.complete();
|
|
239
|
+
}
|
|
240
|
+
}
|
|
241
|
+
TheDndComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: TheDndComponent, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }, { token: i0.NgZone }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
242
|
+
TheDndComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.15", type: TheDndComponent, selector: "[theDnd]", inputs: { editor: "editor" }, outputs: { dragChange: "dragChange" }, host: { classAttribute: "the-drag-drop" }, viewQueries: [{ propertyName: "content", first: true, predicate: ["content"], descendants: true }], ngImport: i0, template: "<div\n draggable=\"true\"\n class=\"the-drag-drop-icon\"\n [ngStyle]=\"{ opacity: isDraging ? 0 : '' }\"\n (dragstart)=\"onDragStart($event)\"\n (dragend)=\"onDragEnd($event)\"\n>\n <thy-icon thyIconName=\"drag\"> </thy-icon>\n</div>\n", components: [{ type: i1.ThyIconComponent, selector: "thy-icon", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }], directives: [{ type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] });
|
|
243
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: TheDndComponent, decorators: [{
|
|
244
|
+
type: Component,
|
|
245
|
+
args: [{
|
|
246
|
+
selector: '[theDnd]',
|
|
247
|
+
templateUrl: './dnd.component.html',
|
|
248
|
+
host: {
|
|
249
|
+
class: 'the-drag-drop'
|
|
250
|
+
}
|
|
251
|
+
}]
|
|
252
|
+
}], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i0.ElementRef }, { type: i0.NgZone }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { editor: [{
|
|
253
|
+
type: Input
|
|
254
|
+
}], dragChange: [{
|
|
255
|
+
type: Output
|
|
256
|
+
}], content: [{
|
|
257
|
+
type: ViewChild,
|
|
258
|
+
args: ['content', { static: false }]
|
|
259
|
+
}] } });
|
|
260
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dnd.component.js","sourceRoot":"","sources":["../../../../../../packages/src/plugins/dnd/component/dnd.component.ts","../../../../../../packages/src/plugins/dnd/component/dnd.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter,\n    Input,\n    NgZone,\n    OnDestroy,\n    Output,\n    Renderer2,\n    ViewChild\n} from '@angular/core';\nimport { fromEvent, merge, Subject } from 'rxjs';\nimport { filter, takeUntil } from 'rxjs/operators';\nimport { Editor, Operation } from 'slate';\nimport { AngularEditor, EDITOR_TO_ELEMENT } from 'slate-angular';\nimport { DROP_THUMB_LINE } from '../../../constants';\nimport { DragNode, ElementOptionsInfo } from '../../../interfaces';\nimport { TheContextService } from '../../../services/context.service';\nimport { coercePixelsFromCssValue, findNodeEntryByPoint } from '../../../utils/dom';\nimport { getCurrentTarget } from '../utils/get-current-target';\nimport { getHoverDirection } from '../utils/get-hover-direction';\nimport { moveDragNode } from '../utils/move-drag-node';\nimport { isValidDrag } from '../utils/is-valid-drag';\n\nconst SNAPSHOT_PADDING_WIDTH = 5;\nconst SNAPSHOT_LIMI_HEIGHT = 70;\nconst DRAG_ICON_SIZE = 24;\nconst DRAG_ICON_OFFSET = 5;\n\n@Component({\n    selector: '[theDnd]',\n    templateUrl: './dnd.component.html',\n    host: {\n        class: 'the-drag-drop'\n    }\n})\nexport class TheDndComponent implements AfterViewInit, OnDestroy {\n    isDraging = false;\n\n    dragNode: DragNode;\n\n    dragSnapshotContent: HTMLElement;\n\n    private destroy$: Subject<any> = new Subject<any>();\n\n    @Input() editor: Editor;\n\n    @Output() dragChange: EventEmitter<boolean> = new EventEmitter();\n\n    dragElement: HTMLElement;\n\n    dragElementHeight: number;\n\n    dragElementWidth: number;\n\n    isScrolling: boolean;\n\n    dropThumbLine: HTMLElement;\n\n    editableTop: number;\n\n    @ViewChild('content', { static: false }) content: ElementRef;\n\n    get nativeElement(): HTMLElement {\n        return this.elementRef.nativeElement;\n    }\n\n    get editableElement() {\n        return this.editor && EDITOR_TO_ELEMENT.get(this.editor);\n    }\n\n    constructor(private renderer: Renderer2, private elementRef: ElementRef, private ngZone: NgZone, private cdr: ChangeDetectorRef) {\n        this.dropThumbLine = document.createElement('div');\n        this.dropThumbLine.className = DROP_THUMB_LINE;\n    }\n\n    ngAfterViewInit(): void {\n        const contextService = this.editor.injector.get(TheContextService);\n        this.ngZone.runOutsideAngular(() => {\n            merge(fromEvent<MouseEvent>(this.editableElement, `mousemove`), fromEvent<MouseEvent>(this.editableElement, `mouseleave`))\n                .pipe(\n                    takeUntil(this.destroy$),\n                    filter(() => {\n                        return !contextService.getOptions().theOptions.readonly && contextService.getOptions().theOptions.dragAndDrop;\n                    })\n                )\n                .subscribe(e => this.setDragIcon(e));\n            fromEvent<MouseEvent>(document, `drop`)\n                .pipe(\n                    takeUntil(this.destroy$),\n                    filter(() => {\n                        return !contextService.getOptions().theOptions.readonly && contextService.getOptions().theOptions.dragAndDrop;\n                    })\n                )\n                .subscribe(e => this.onDrop(e));\n            fromEvent<MouseEvent>(document, `dragover`)\n                .pipe(\n                    takeUntil(this.destroy$),\n                    filter(() => {\n                        return !contextService.getOptions().theOptions.readonly && contextService.getOptions().theOptions.dragAndDrop;\n                    })\n                )\n                .subscribe(e => this.onDragover(e));\n            fromEvent<MouseEvent>(document, `scroll`)\n                .pipe(\n                    takeUntil(this.destroy$),\n                    filter(() => {\n                        return !contextService.getOptions().theOptions.readonly && contextService.getOptions().theOptions.dragAndDrop;\n                    })\n                )\n                .subscribe(e => {\n                    e.preventDefault();\n                    let scrollPosition = window.scrollY;\n                    if (!this.isScrolling && this.isDraging) {\n                        window.requestAnimationFrame(() => {\n                            if (this.editableTop) {\n                                // 滚动过程中，通过设置父级元素来设置snapshot位置\n                                this.updateDndContainerPosition(null, scrollPosition + this.editableTop + 'px');\n                            }\n                            this.isScrolling = false;\n                        });\n                        this.isScrolling = true;\n                    }\n                });\n        });\n        this.setVisibility(false);\n        this.valueChangeHandle();\n    }\n\n    valueChangeHandle() {\n        const { onChange } = this.editor;\n        this.editor.onChange = () => {\n            const ops = this.editor.operations;\n            const skip = ops.length === 1 && Operation.isSelectionOperation(ops[0]);\n            if (!skip) {\n                this.setVisibility(false);\n            }\n            onChange();\n        };\n    }\n\n    private updateDndContainerPosition(left: string, top: string) {\n        const element = this.elementRef.nativeElement as HTMLElement;\n        const parentElement = element.parentElement;\n        top && this.renderer.setStyle(parentElement, 'top', top);\n        left && this.renderer.setStyle(parentElement, 'left', left);\n    }\n\n    getEditableTop(event: MouseEvent) {\n        const offsetHeight = document.documentElement.offsetHeight;\n        const { height } = this.editableElement.getBoundingClientRect();\n        if (event.clientY < this.dragElementHeight) {\n            this.editableTop = -this.editableElement.offsetTop;\n            return;\n        }\n        if (height > event.pageY && event.clientY + this.dragElementHeight >= offsetHeight) {\n            this.editableTop = event.clientY - this.editableElement.offsetTop;\n            return;\n        }\n        this.editableTop = null;\n    }\n\n    onDragStart(event: DragEvent) {\n        this.isDraging = true;\n        this.dragChange.emit(this.isDraging);\n        this.dragSnapshotContent = document.querySelector('.drag-snapshot-container') as HTMLElement;\n        this.dragSnapshotContent.className = 'the-editor-typo drag-snapshot-container';\n        this.dragSnapshotContent.appendChild(this.dragElement.cloneNode(true));\n        this.dragElement.style.opacity = '0.3';\n    }\n\n    onDragEnd(event: DragEvent) {\n        this.dragElement.style.opacity = '';\n        this.isDraging = false;\n        this.setVisibility(false);\n        this.resetDragSnapshotContent();\n        this.dragChange.emit(this.isDraging);\n    }\n\n    onDrop(event: MouseEvent) {\n        event.preventDefault();\n        if (this.isDraging) {\n            moveDragNode(this.editor, this.dragNode, event);\n        }\n    }\n\n    onDragover(event: MouseEvent) {\n        event.preventDefault();\n        if (this.isDraging && !this.isScrolling) {\n            this.getEditableTop(event);\n            const offsetWidth = document.documentElement.offsetWidth;\n            const { left: editorLeft, top: editorTop, height } = this.editableElement.getBoundingClientRect();\n            let top = 0;\n            let left = 0;\n\n            if (editorLeft > 0) {\n                if (event.clientX + this.dragElementWidth / 2 > offsetWidth) {\n                    left = event.pageX - editorLeft - (this.elementRef.nativeElement as HTMLElement).offsetWidth;\n                } else {\n                    left = Math.max(event.pageX - editorLeft, -editorLeft) + 10;\n                }\n            }\n\n            let paddingTop = 0; // paddingTop: 编辑器距离顶部的距离\n            if (editorTop >= 0) {\n                // 无滚动情况下\n                top = event.clientY - this.editableElement.offsetTop;\n                paddingTop = editorTop - this.editableElement.offsetTop;\n            } else {\n                // 有滚动距离\n                top = Math.abs(editorTop) + event.clientY; // 滚动距离 + 鼠标clientY\n                paddingTop = event.pageY - this.editableElement.offsetTop - top;\n                // 防止底部出现滚动条\n                if (paddingTop < height - top) {\n                    top = top + paddingTop;\n                }\n            }\n            this.updateDndContainerPosition(left + 'px', top + 'px');\n            this.setSnapshotStyle(event);\n            this.setDropThumbLine(event);\n        }\n    }\n\n    setDropThumbLine(event: MouseEvent) {\n        let element = getCurrentTarget(this.editor, event);\n        const direction = getHoverDirection(this.editor, event);\n        if (element) {\n            if (direction && direction === 'top') {\n                element = element.previousElementSibling?.querySelector('[data-slate-node=\"element\"]') as HTMLElement;\n            }\n            if (element && isValidDrag(this.editor, this.dragNode.node, element)) {\n                element.appendChild(this.dropThumbLine);\n            }\n        }\n    }\n\n    setDragIcon(event: MouseEvent) {\n        if (!this.isDraging) {\n            const nodeEntry = findNodeEntryByPoint(this.editor, event.x, event.y, 'highest');\n            if (nodeEntry && !Editor.isEmpty(this.editor, nodeEntry[0])) {\n                const rootNode = AngularEditor.toDOMNode(this.editor, nodeEntry[0]);\n                this.dragNode = {\n                    node: nodeEntry[0],\n                    path: nodeEntry[1]\n                };\n                this.dragElement = rootNode;\n                let lineHeight = coercePixelsFromCssValue(window.getComputedStyle(rootNode)['lineHeight']);\n                const offsetTop = rootNode.offsetTop + (rootNode.offsetParent as HTMLElement).offsetTop + (lineHeight - DRAG_ICON_SIZE) / 2;\n                const offsetLeft = rootNode.offsetLeft + (rootNode.offsetParent as HTMLElement).offsetLeft;\n                this.updateDndContainerPosition(offsetLeft - DRAG_ICON_SIZE - DRAG_ICON_OFFSET + 'px', offsetTop + 'px');\n                this.setVisibility(true);\n            } else {\n                this.setVisibility(false);\n            }\n        }\n    }\n\n    setSnapshotStyle(event: MouseEvent) {\n        const { width, height } = this.dragElement.getBoundingClientRect();\n        this.dragElementHeight = height;\n        this.dragElementWidth = width;\n\n        let dragSnapshotContentStyle = `visibility: visible; width: ${width + SNAPSHOT_PADDING_WIDTH * 2}px;`;\n        if (height > SNAPSHOT_LIMI_HEIGHT) {\n            dragSnapshotContentStyle = dragSnapshotContentStyle + 'transform: scale(0.45);';\n            this.dragElementHeight = this.dragElementHeight * 0.45;\n            this.dragElementWidth = this.dragElementWidth * 0.45;\n        }\n        let snapshotTop = 0;\n        let snapshotLeft = 0;\n        // 上下移动：超出屏幕高度，重新设置snapshot的位置\n        if (event.clientY + this.dragElementHeight > document.documentElement.offsetHeight) {\n            snapshotTop = this.dragElementHeight;\n        } else {\n            snapshotTop = 0;\n        }\n\n        // 左右移动：超出屏幕宽度，重新设置snapshot的位置\n        if (event.clientX + this.dragElementWidth / 2 > document.documentElement.offsetWidth) {\n            snapshotLeft = this.dragElementWidth;\n        } else {\n            snapshotLeft = 0;\n        }\n        dragSnapshotContentStyle = dragSnapshotContentStyle + `top: ${-snapshotTop}px; left: ${-snapshotLeft}px;`;\n        this.dragSnapshotContent.setAttribute('style', dragSnapshotContentStyle);\n    }\n\n    resetDragSnapshotContent() {\n        this.dragSnapshotContent.className = 'drag-snapshot-container';\n        this.dragSnapshotContent.setAttribute('style', '');\n        this.dragSnapshotContent.innerHTML = '';\n    }\n\n    setVisibility(visible = true) {\n        (this.nativeElement.parentNode as HTMLElement).style.visibility = visible ? 'visible' : 'hidden';\n    }\n\n    ngOnDestroy() {\n        this.destroy$.next();\n        this.destroy$.complete();\n    }\n}\n","<div\n    draggable=\"true\"\n    class=\"the-drag-drop-icon\"\n    [ngStyle]=\"{ opacity: isDraging ? 0 : '' }\"\n    (dragstart)=\"onDragStart($event)\"\n    (dragend)=\"onDragEnd($event)\"\n>\n    <thy-icon thyIconName=\"drag\"> </thy-icon>\n</div>\n"]}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { coercePixelsFromCssValue, findNodeEntryByPoint } from '../../../utils/dom';
|
|
2
|
+
import { TheEditor } from '../../../interfaces';
|
|
3
|
+
import { EDITOR_TO_ELEMENT } from 'slate-angular';
|
|
4
|
+
export const getCurrentTarget = (editor, event) => {
|
|
5
|
+
const editorElement = EDITOR_TO_ELEMENT.get(editor);
|
|
6
|
+
const { left, right } = editorElement.getBoundingClientRect();
|
|
7
|
+
let { paddingLeft, paddingRight } = window.getComputedStyle(editorElement, null);
|
|
8
|
+
const paddingLeftPixels = coercePixelsFromCssValue(paddingLeft);
|
|
9
|
+
const paddingRightPixels = coercePixelsFromCssValue(paddingRight);
|
|
10
|
+
let x = event.x;
|
|
11
|
+
if (event.x <= left + paddingLeftPixels || event.x >= right - paddingRightPixels) {
|
|
12
|
+
x = left + paddingLeftPixels;
|
|
13
|
+
}
|
|
14
|
+
const nodeEntry = findNodeEntryByPoint(editor, x, event.y);
|
|
15
|
+
if (nodeEntry) {
|
|
16
|
+
return TheEditor.toDOMNode(editor, nodeEntry[0]);
|
|
17
|
+
}
|
|
18
|
+
};
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2V0LWN1cnJlbnQtdGFyZ2V0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvc3JjL3BsdWdpbnMvZG5kL3V0aWxzL2dldC1jdXJyZW50LXRhcmdldC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUNwRixPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDaEQsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRWxELE1BQU0sQ0FBQyxNQUFNLGdCQUFnQixHQUFHLENBQUMsTUFBaUIsRUFBRSxLQUFpQixFQUFlLEVBQUU7SUFDbEYsTUFBTSxhQUFhLEdBQUcsaUJBQWlCLENBQUMsR0FBRyxDQUFDLE1BQU0sQ0FBZ0IsQ0FBQztJQUNuRSxNQUFNLEVBQUUsSUFBSSxFQUFFLEtBQUssRUFBRSxHQUFHLGFBQWEsQ0FBQyxxQkFBcUIsRUFBRSxDQUFDO0lBQzlELElBQUksRUFBRSxXQUFXLEVBQUUsWUFBWSxFQUFFLEdBQUcsTUFBTSxDQUFDLGdCQUFnQixDQUFDLGFBQWEsRUFBRSxJQUFJLENBQUMsQ0FBQztJQUNqRixNQUFNLGlCQUFpQixHQUFHLHdCQUF3QixDQUFDLFdBQVcsQ0FBQyxDQUFDO0lBQ2hFLE1BQU0sa0JBQWtCLEdBQUcsd0JBQXdCLENBQUMsWUFBWSxDQUFDLENBQUM7SUFDbEUsSUFBSSxDQUFDLEdBQUcsS0FBSyxDQUFDLENBQUMsQ0FBQztJQUNoQixJQUFJLEtBQUssQ0FBQyxDQUFDLElBQUksSUFBSSxHQUFHLGlCQUFpQixJQUFJLEtBQUssQ0FBQyxDQUFDLElBQUksS0FBSyxHQUFHLGtCQUFrQixFQUFFO1FBQzlFLENBQUMsR0FBRyxJQUFJLEdBQUcsaUJBQWlCLENBQUM7S0FDaEM7SUFDRCxNQUFNLFNBQVMsR0FBRyxvQkFBb0IsQ0FBQyxNQUFNLEVBQUUsQ0FBQyxFQUFFLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUMzRCxJQUFJLFNBQVMsRUFBRTtRQUNYLE9BQU8sU0FBUyxDQUFDLFNBQVMsQ0FBQyxNQUFNLEVBQUUsU0FBUyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7S0FDcEQ7QUFDTCxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjb2VyY2VQaXhlbHNGcm9tQ3NzVmFsdWUsIGZpbmROb2RlRW50cnlCeVBvaW50IH0gZnJvbSAnLi4vLi4vLi4vdXRpbHMvZG9tJztcbmltcG9ydCB7IFRoZUVkaXRvciB9IGZyb20gJy4uLy4uLy4uL2ludGVyZmFjZXMnO1xuaW1wb3J0IHsgRURJVE9SX1RPX0VMRU1FTlQgfSBmcm9tICdzbGF0ZS1hbmd1bGFyJztcblxuZXhwb3J0IGNvbnN0IGdldEN1cnJlbnRUYXJnZXQgPSAoZWRpdG9yOiBUaGVFZGl0b3IsIGV2ZW50OiBNb3VzZUV2ZW50KTogSFRNTEVsZW1lbnQgPT4ge1xuICAgIGNvbnN0IGVkaXRvckVsZW1lbnQgPSBFRElUT1JfVE9fRUxFTUVOVC5nZXQoZWRpdG9yKSBhcyBIVE1MRWxlbWVudDtcbiAgICBjb25zdCB7IGxlZnQsIHJpZ2h0IH0gPSBlZGl0b3JFbGVtZW50LmdldEJvdW5kaW5nQ2xpZW50UmVjdCgpO1xuICAgIGxldCB7IHBhZGRpbmdMZWZ0LCBwYWRkaW5nUmlnaHQgfSA9IHdpbmRvdy5nZXRDb21wdXRlZFN0eWxlKGVkaXRvckVsZW1lbnQsIG51bGwpO1xuICAgIGNvbnN0IHBhZGRpbmdMZWZ0UGl4ZWxzID0gY29lcmNlUGl4ZWxzRnJvbUNzc1ZhbHVlKHBhZGRpbmdMZWZ0KTtcbiAgICBjb25zdCBwYWRkaW5nUmlnaHRQaXhlbHMgPSBjb2VyY2VQaXhlbHNGcm9tQ3NzVmFsdWUocGFkZGluZ1JpZ2h0KTtcbiAgICBsZXQgeCA9IGV2ZW50Lng7XG4gICAgaWYgKGV2ZW50LnggPD0gbGVmdCArIHBhZGRpbmdMZWZ0UGl4ZWxzIHx8IGV2ZW50LnggPj0gcmlnaHQgLSBwYWRkaW5nUmlnaHRQaXhlbHMpIHtcbiAgICAgICAgeCA9IGxlZnQgKyBwYWRkaW5nTGVmdFBpeGVscztcbiAgICB9XG4gICAgY29uc3Qgbm9kZUVudHJ5ID0gZmluZE5vZGVFbnRyeUJ5UG9pbnQoZWRpdG9yLCB4LCBldmVudC55KTtcbiAgICBpZiAobm9kZUVudHJ5KSB7XG4gICAgICAgIHJldHVybiBUaGVFZGl0b3IudG9ET01Ob2RlKGVkaXRvciwgbm9kZUVudHJ5WzBdKTtcbiAgICB9XG59O1xuIl19
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { getCurrentTarget } from './get-current-target';
|
|
2
|
+
export const getHoverDirection = (editor, event) => {
|
|
3
|
+
const rootNode = getCurrentTarget(editor, event);
|
|
4
|
+
if (rootNode) {
|
|
5
|
+
const { top, bottom } = rootNode.getBoundingClientRect();
|
|
6
|
+
const middleHeight = (bottom - top) / 2;
|
|
7
|
+
if (top + middleHeight > event.clientY) {
|
|
8
|
+
return 'top';
|
|
9
|
+
}
|
|
10
|
+
return 'bottom';
|
|
11
|
+
}
|
|
12
|
+
};
|
|
13
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2V0LWhvdmVyLWRpcmVjdGlvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3NyYy9wbHVnaW5zL2RuZC91dGlscy9nZXQtaG92ZXItZGlyZWN0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBRXhELE1BQU0sQ0FBQyxNQUFNLGlCQUFpQixHQUFHLENBQUMsTUFBaUIsRUFBRSxLQUFpQixFQUFpQixFQUFFO0lBQ3JGLE1BQU0sUUFBUSxHQUFHLGdCQUFnQixDQUFDLE1BQU0sRUFBRSxLQUFLLENBQUMsQ0FBQztJQUNqRCxJQUFJLFFBQVEsRUFBRTtRQUNWLE1BQU0sRUFBRSxHQUFHLEVBQUUsTUFBTSxFQUFFLEdBQUcsUUFBUSxDQUFDLHFCQUFxQixFQUFFLENBQUM7UUFDekQsTUFBTSxZQUFZLEdBQUcsQ0FBQyxNQUFNLEdBQUcsR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQ3hDLElBQUksR0FBRyxHQUFHLFlBQVksR0FBRyxLQUFLLENBQUMsT0FBTyxFQUFFO1lBQ3BDLE9BQU8sS0FBSyxDQUFDO1NBQ2hCO1FBQ0QsT0FBTyxRQUFRLENBQUM7S0FDbkI7QUFDTCxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUaGVFZGl0b3IgfSBmcm9tICcuLi8uLi8uLi9pbnRlcmZhY2VzJztcbmltcG9ydCB7IERyb3BEaXJlY3Rpb24gfSBmcm9tICcuLi8uLi8uLi9jb25zdGFudHMnO1xuaW1wb3J0IHsgZ2V0Q3VycmVudFRhcmdldCB9IGZyb20gJy4vZ2V0LWN1cnJlbnQtdGFyZ2V0JztcblxuZXhwb3J0IGNvbnN0IGdldEhvdmVyRGlyZWN0aW9uID0gKGVkaXRvcjogVGhlRWRpdG9yLCBldmVudDogTW91c2VFdmVudCk6IERyb3BEaXJlY3Rpb24gPT4ge1xuICAgIGNvbnN0IHJvb3ROb2RlID0gZ2V0Q3VycmVudFRhcmdldChlZGl0b3IsIGV2ZW50KTtcbiAgICBpZiAocm9vdE5vZGUpIHtcbiAgICAgICAgY29uc3QgeyB0b3AsIGJvdHRvbSB9ID0gcm9vdE5vZGUuZ2V0Qm91bmRpbmdDbGllbnRSZWN0KCk7XG4gICAgICAgIGNvbnN0IG1pZGRsZUhlaWdodCA9IChib3R0b20gLSB0b3ApIC8gMjtcbiAgICAgICAgaWYgKHRvcCArIG1pZGRsZUhlaWdodCA+IGV2ZW50LmNsaWVudFkpIHtcbiAgICAgICAgICAgIHJldHVybiAndG9wJztcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gJ2JvdHRvbSc7XG4gICAgfVxufTtcbiJdfQ==
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { Editor } from 'slate';
|
|
2
|
+
import { DefaultElementOptions, TheEditor } from '../../../interfaces';
|
|
3
|
+
import { mergeElementOptions } from '../../../utils/merge-element-options';
|
|
4
|
+
export const isValidDrag = (editor, dragNode, currentTarget) => {
|
|
5
|
+
var _a;
|
|
6
|
+
const node = TheEditor.toSlateNode(editor, currentTarget);
|
|
7
|
+
const dropPath = TheEditor.findPath(editor, node);
|
|
8
|
+
const dragPath = TheEditor.findPath(editor, dragNode);
|
|
9
|
+
if (dragPath[0] === dropPath[0] && dropPath.length > 1) {
|
|
10
|
+
// 阻止list元素拖入自身
|
|
11
|
+
return false;
|
|
12
|
+
}
|
|
13
|
+
let allElementOptions = DefaultElementOptions;
|
|
14
|
+
if ((_a = editor.extraElementOptions) === null || _a === void 0 ? void 0 : _a.length) {
|
|
15
|
+
const extraInfo = mergeElementOptions(editor.extraElementOptions);
|
|
16
|
+
allElementOptions = Object.values(extraInfo);
|
|
17
|
+
}
|
|
18
|
+
const types = allElementOptions.map(item => item.type);
|
|
19
|
+
if (types.indexOf(node.type) > -1 && allElementOptions[types.indexOf(node.type)].isSecondaryContainer) {
|
|
20
|
+
// 阻止向table-celld等二级容器中拖入
|
|
21
|
+
return false;
|
|
22
|
+
}
|
|
23
|
+
let containerParent = Editor.above(editor, {
|
|
24
|
+
at: dropPath,
|
|
25
|
+
mode: 'lowest',
|
|
26
|
+
match: (node) => {
|
|
27
|
+
return node && node.type && types.includes(node.type);
|
|
28
|
+
}
|
|
29
|
+
});
|
|
30
|
+
if (containerParent) {
|
|
31
|
+
const { inValidChildrenTypes } = allElementOptions.find(item => item.type === containerParent[0].type);
|
|
32
|
+
if (inValidChildrenTypes.includes(dragNode.type)) {
|
|
33
|
+
return false;
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
return true;
|
|
37
|
+
};
|
|
38
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaXMtdmFsaWQtZHJhZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3NyYy9wbHVnaW5zL2RuZC91dGlscy9pcy12YWxpZC1kcmFnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxPQUFPLENBQUM7QUFFL0IsT0FBTyxFQUFFLHFCQUFxQixFQUFFLFNBQVMsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ3ZFLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHNDQUFzQyxDQUFDO0FBRTNFLE1BQU0sQ0FBQyxNQUFNLFdBQVcsR0FBRyxDQUFDLE1BQWlCLEVBQUUsUUFBdUIsRUFBRSxhQUEwQixFQUFFLEVBQUU7O0lBQ2xHLE1BQU0sSUFBSSxHQUFHLFNBQVMsQ0FBQyxXQUFXLENBQUMsTUFBTSxFQUFFLGFBQWEsQ0FBa0IsQ0FBQztJQUMzRSxNQUFNLFFBQVEsR0FBRyxTQUFTLENBQUMsUUFBUSxDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUMsQ0FBQztJQUNsRCxNQUFNLFFBQVEsR0FBRyxTQUFTLENBQUMsUUFBUSxDQUFDLE1BQU0sRUFBRSxRQUFRLENBQUMsQ0FBQztJQUN0RCxJQUFJLFFBQVEsQ0FBQyxDQUFDLENBQUMsS0FBSyxRQUFRLENBQUMsQ0FBQyxDQUFDLElBQUksUUFBUSxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUU7UUFDcEQsZUFBZTtRQUNmLE9BQU8sS0FBSyxDQUFDO0tBQ2hCO0lBQ0QsSUFBSSxpQkFBaUIsR0FBRyxxQkFBcUIsQ0FBQztJQUM5QyxJQUFJLE1BQUEsTUFBTSxDQUFDLG1CQUFtQiwwQ0FBRSxNQUFNLEVBQUU7UUFDcEMsTUFBTSxTQUFTLEdBQUcsbUJBQW1CLENBQUMsTUFBTSxDQUFDLG1CQUFtQixDQUFDLENBQUM7UUFDbEUsaUJBQWlCLEdBQUcsTUFBTSxDQUFDLE1BQU0sQ0FBQyxTQUFTLENBQUMsQ0FBQztLQUNoRDtJQUNELE1BQU0sS0FBSyxHQUFHLGlCQUFpQixDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUN2RCxJQUFJLEtBQUssQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxJQUFJLGlCQUFpQixDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsb0JBQW9CLEVBQUU7UUFDbkcseUJBQXlCO1FBQ3pCLE9BQU8sS0FBSyxDQUFDO0tBQ2hCO0lBQ0QsSUFBSSxlQUFlLEdBQUcsTUFBTSxDQUFDLEtBQUssQ0FBQyxNQUFNLEVBQUU7UUFDdkMsRUFBRSxFQUFFLFFBQVE7UUFDWixJQUFJLEVBQUUsUUFBUTtRQUNkLEtBQUssRUFBRSxDQUFDLElBQW1CLEVBQUUsRUFBRTtZQUMzQixPQUFPLElBQUksSUFBSSxJQUFJLENBQUMsSUFBSSxJQUFJLEtBQUssQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQzFELENBQUM7S0FDSixDQUFDLENBQUM7SUFFSCxJQUFJLGVBQWUsRUFBRTtRQUNqQixNQUFNLEVBQUUsb0JBQW9CLEVBQUUsR0FBRyxpQkFBaUIsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsSUFBSSxLQUFLLGVBQWUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUN2RyxJQUFJLG9CQUFvQixDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLEVBQUU7WUFDOUMsT0FBTyxLQUFLLENBQUM7U0FDaEI7S0FDSjtJQUNELE9BQU8sSUFBSSxDQUFDO0FBQ2hCLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEVkaXRvciB9IGZyb20gJ3NsYXRlJztcbmltcG9ydCB7IEN1c3RvbUVsZW1lbnQgfSBmcm9tICcuLi8uLi8uLi9jdXN0b20tdHlwZXMnO1xuaW1wb3J0IHsgRGVmYXVsdEVsZW1lbnRPcHRpb25zLCBUaGVFZGl0b3IgfSBmcm9tICcuLi8uLi8uLi9pbnRlcmZhY2VzJztcbmltcG9ydCB7IG1lcmdlRWxlbWVudE9wdGlvbnMgfSBmcm9tICcuLi8uLi8uLi91dGlscy9tZXJnZS1lbGVtZW50LW9wdGlvbnMnO1xuXG5leHBvcnQgY29uc3QgaXNWYWxpZERyYWcgPSAoZWRpdG9yOiBUaGVFZGl0b3IsIGRyYWdOb2RlOiBDdXN0b21FbGVtZW50LCBjdXJyZW50VGFyZ2V0OiBIVE1MRWxlbWVudCkgPT4ge1xuICAgIGNvbnN0IG5vZGUgPSBUaGVFZGl0b3IudG9TbGF0ZU5vZGUoZWRpdG9yLCBjdXJyZW50VGFyZ2V0KSBhcyBDdXN0b21FbGVtZW50O1xuICAgIGNvbnN0IGRyb3BQYXRoID0gVGhlRWRpdG9yLmZpbmRQYXRoKGVkaXRvciwgbm9kZSk7XG4gICAgY29uc3QgZHJhZ1BhdGggPSBUaGVFZGl0b3IuZmluZFBhdGgoZWRpdG9yLCBkcmFnTm9kZSk7XG4gICAgaWYgKGRyYWdQYXRoWzBdID09PSBkcm9wUGF0aFswXSAmJiBkcm9wUGF0aC5sZW5ndGggPiAxKSB7XG4gICAgICAgIC8vIOmYu+atomxpc3TlhYPntKDmi5blhaXoh6rouqtcbiAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cbiAgICBsZXQgYWxsRWxlbWVudE9wdGlvbnMgPSBEZWZhdWx0RWxlbWVudE9wdGlvbnM7XG4gICAgaWYgKGVkaXRvci5leHRyYUVsZW1lbnRPcHRpb25zPy5sZW5ndGgpIHtcbiAgICAgICAgY29uc3QgZXh0cmFJbmZvID0gbWVyZ2VFbGVtZW50T3B0aW9ucyhlZGl0b3IuZXh0cmFFbGVtZW50T3B0aW9ucyk7XG4gICAgICAgIGFsbEVsZW1lbnRPcHRpb25zID0gT2JqZWN0LnZhbHVlcyhleHRyYUluZm8pO1xuICAgIH1cbiAgICBjb25zdCB0eXBlcyA9IGFsbEVsZW1lbnRPcHRpb25zLm1hcChpdGVtID0+IGl0ZW0udHlwZSk7XG4gICAgaWYgKHR5cGVzLmluZGV4T2Yobm9kZS50eXBlKSA+IC0xICYmIGFsbEVsZW1lbnRPcHRpb25zW3R5cGVzLmluZGV4T2Yobm9kZS50eXBlKV0uaXNTZWNvbmRhcnlDb250YWluZXIpIHtcbiAgICAgICAgLy8g6Zi75q2i5ZCRdGFibGUtY2VsbGTnrYnkuoznuqflrrnlmajkuK3mi5blhaVcbiAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cbiAgICBsZXQgY29udGFpbmVyUGFyZW50ID0gRWRpdG9yLmFib3ZlKGVkaXRvciwge1xuICAgICAgICBhdDogZHJvcFBhdGgsXG4gICAgICAgIG1vZGU6ICdsb3dlc3QnLFxuICAgICAgICBtYXRjaDogKG5vZGU6IEN1c3RvbUVsZW1lbnQpID0+IHtcbiAgICAgICAgICAgIHJldHVybiBub2RlICYmIG5vZGUudHlwZSAmJiB0eXBlcy5pbmNsdWRlcyhub2RlLnR5cGUpO1xuICAgICAgICB9XG4gICAgfSk7XG5cbiAgICBpZiAoY29udGFpbmVyUGFyZW50KSB7XG4gICAgICAgIGNvbnN0IHsgaW5WYWxpZENoaWxkcmVuVHlwZXMgfSA9IGFsbEVsZW1lbnRPcHRpb25zLmZpbmQoaXRlbSA9PiBpdGVtLnR5cGUgPT09IGNvbnRhaW5lclBhcmVudFswXS50eXBlKTtcbiAgICAgICAgaWYgKGluVmFsaWRDaGlsZHJlblR5cGVzLmluY2x1ZGVzKGRyYWdOb2RlLnR5cGUpKSB7XG4gICAgICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgICAgIH1cbiAgICB9XG4gICAgcmV0dXJuIHRydWU7XG59O1xuIl19
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { TheEditor } from '../../../interfaces';
|
|
2
|
+
import { Path, Editor, Transforms } from 'slate';
|
|
3
|
+
import { removeDropThumbLine } from './remove-drop-thumb-line';
|
|
4
|
+
import { EDITOR_TO_ELEMENT } from 'slate-angular';
|
|
5
|
+
import { DROP_THUMB_LINE } from '../../../constants';
|
|
6
|
+
export const moveDragNode = (editor, dragNode, event) => {
|
|
7
|
+
event.stopPropagation();
|
|
8
|
+
const element = EDITOR_TO_ELEMENT.get(editor);
|
|
9
|
+
const dropThumbLine = element.querySelector('.' + DROP_THUMB_LINE);
|
|
10
|
+
const parentElement = dropThumbLine && dropThumbLine.parentNode;
|
|
11
|
+
if (parentElement) {
|
|
12
|
+
const node = TheEditor.toSlateNode(editor, parentElement);
|
|
13
|
+
let dropPath = node && TheEditor.findPath(editor, node);
|
|
14
|
+
if (dropPath.length) {
|
|
15
|
+
const dragPath = dragNode.path;
|
|
16
|
+
const before = Path.isBefore(dragPath, dropPath) && Path.isSibling(dragPath, dropPath);
|
|
17
|
+
dropPath = before ? dropPath : Path.next(dropPath);
|
|
18
|
+
if (dropPath.length) {
|
|
19
|
+
Editor.withoutNormalizing(editor, () => {
|
|
20
|
+
Transforms.moveNodes(editor, {
|
|
21
|
+
at: dragPath,
|
|
22
|
+
to: dropPath
|
|
23
|
+
});
|
|
24
|
+
});
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
removeDropThumbLine(editor);
|
|
29
|
+
};
|
|
30
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW92ZS1kcmFnLW5vZGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9zcmMvcGx1Z2lucy9kbmQvdXRpbHMvbW92ZS1kcmFnLW5vZGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFZLFNBQVMsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQzFELE9BQU8sRUFBRSxJQUFJLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBRSxNQUFNLE9BQU8sQ0FBQztBQUNqRCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUMvRCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDbEQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBRXJELE1BQU0sQ0FBQyxNQUFNLFlBQVksR0FBRyxDQUFDLE1BQWlCLEVBQUUsUUFBa0IsRUFBRSxLQUFpQixFQUFFLEVBQUU7SUFDckYsS0FBSyxDQUFDLGVBQWUsRUFBRSxDQUFDO0lBQ3hCLE1BQU0sT0FBTyxHQUFHLGlCQUFpQixDQUFDLEdBQUcsQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUM5QyxNQUFNLGFBQWEsR0FBRyxPQUFPLENBQUMsYUFBYSxDQUFDLEdBQUcsR0FBRyxlQUFlLENBQUMsQ0FBQztJQUNuRSxNQUFNLGFBQWEsR0FBRyxhQUFhLElBQUksYUFBYSxDQUFDLFVBQVUsQ0FBQztJQUNoRSxJQUFJLGFBQWEsRUFBRTtRQUNmLE1BQU0sSUFBSSxHQUFHLFNBQVMsQ0FBQyxXQUFXLENBQUMsTUFBTSxFQUFFLGFBQWEsQ0FBQyxDQUFDO1FBQzFELElBQUksUUFBUSxHQUFHLElBQUksSUFBSSxTQUFTLENBQUMsUUFBUSxDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUMsQ0FBQztRQUN4RCxJQUFJLFFBQVEsQ0FBQyxNQUFNLEVBQUU7WUFDakIsTUFBTSxRQUFRLEdBQUcsUUFBUSxDQUFDLElBQUksQ0FBQztZQUMvQixNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsUUFBUSxDQUFDLFFBQVEsRUFBRSxRQUFRLENBQUMsSUFBSSxJQUFJLENBQUMsU0FBUyxDQUFDLFFBQVEsRUFBRSxRQUFRLENBQUMsQ0FBQztZQUN2RixRQUFRLEdBQUcsTUFBTSxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUM7WUFDbkQsSUFBSSxRQUFRLENBQUMsTUFBTSxFQUFFO2dCQUNqQixNQUFNLENBQUMsa0JBQWtCLENBQUMsTUFBTSxFQUFFLEdBQUcsRUFBRTtvQkFDbkMsVUFBVSxDQUFDLFNBQVMsQ0FBQyxNQUFNLEVBQUU7d0JBQ3pCLEVBQUUsRUFBRSxRQUFRO3dCQUNaLEVBQUUsRUFBRSxRQUFRO3FCQUNmLENBQUMsQ0FBQztnQkFDUCxDQUFDLENBQUMsQ0FBQzthQUNOO1NBQ0o7S0FDSjtJQUVELG1CQUFtQixDQUFDLE1BQU0sQ0FBQyxDQUFDO0FBQ2hDLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERyYWdOb2RlLCBUaGVFZGl0b3IgfSBmcm9tICcuLi8uLi8uLi9pbnRlcmZhY2VzJztcbmltcG9ydCB7IFBhdGgsIEVkaXRvciwgVHJhbnNmb3JtcyB9IGZyb20gJ3NsYXRlJztcbmltcG9ydCB7IHJlbW92ZURyb3BUaHVtYkxpbmUgfSBmcm9tICcuL3JlbW92ZS1kcm9wLXRodW1iLWxpbmUnO1xuaW1wb3J0IHsgRURJVE9SX1RPX0VMRU1FTlQgfSBmcm9tICdzbGF0ZS1hbmd1bGFyJztcbmltcG9ydCB7IERST1BfVEhVTUJfTElORSB9IGZyb20gJy4uLy4uLy4uL2NvbnN0YW50cyc7XG5cbmV4cG9ydCBjb25zdCBtb3ZlRHJhZ05vZGUgPSAoZWRpdG9yOiBUaGVFZGl0b3IsIGRyYWdOb2RlOiBEcmFnTm9kZSwgZXZlbnQ6IE1vdXNlRXZlbnQpID0+IHtcbiAgICBldmVudC5zdG9wUHJvcGFnYXRpb24oKTtcbiAgICBjb25zdCBlbGVtZW50ID0gRURJVE9SX1RPX0VMRU1FTlQuZ2V0KGVkaXRvcik7XG4gICAgY29uc3QgZHJvcFRodW1iTGluZSA9IGVsZW1lbnQucXVlcnlTZWxlY3RvcignLicgKyBEUk9QX1RIVU1CX0xJTkUpO1xuICAgIGNvbnN0IHBhcmVudEVsZW1lbnQgPSBkcm9wVGh1bWJMaW5lICYmIGRyb3BUaHVtYkxpbmUucGFyZW50Tm9kZTtcbiAgICBpZiAocGFyZW50RWxlbWVudCkge1xuICAgICAgICBjb25zdCBub2RlID0gVGhlRWRpdG9yLnRvU2xhdGVOb2RlKGVkaXRvciwgcGFyZW50RWxlbWVudCk7XG4gICAgICAgIGxldCBkcm9wUGF0aCA9IG5vZGUgJiYgVGhlRWRpdG9yLmZpbmRQYXRoKGVkaXRvciwgbm9kZSk7XG4gICAgICAgIGlmIChkcm9wUGF0aC5sZW5ndGgpIHtcbiAgICAgICAgICAgIGNvbnN0IGRyYWdQYXRoID0gZHJhZ05vZGUucGF0aDtcbiAgICAgICAgICAgIGNvbnN0IGJlZm9yZSA9IFBhdGguaXNCZWZvcmUoZHJhZ1BhdGgsIGRyb3BQYXRoKSAmJiBQYXRoLmlzU2libGluZyhkcmFnUGF0aCwgZHJvcFBhdGgpO1xuICAgICAgICAgICAgZHJvcFBhdGggPSBiZWZvcmUgPyBkcm9wUGF0aCA6IFBhdGgubmV4dChkcm9wUGF0aCk7XG4gICAgICAgICAgICBpZiAoZHJvcFBhdGgubGVuZ3RoKSB7XG4gICAgICAgICAgICAgICAgRWRpdG9yLndpdGhvdXROb3JtYWxpemluZyhlZGl0b3IsICgpID0+IHtcbiAgICAgICAgICAgICAgICAgICAgVHJhbnNmb3Jtcy5tb3ZlTm9kZXMoZWRpdG9yLCB7XG4gICAgICAgICAgICAgICAgICAgICAgICBhdDogZHJhZ1BhdGgsXG4gICAgICAgICAgICAgICAgICAgICAgICB0bzogZHJvcFBhdGhcbiAgICAgICAgICAgICAgICAgICAgfSk7XG4gICAgICAgICAgICAgICAgfSk7XG4gICAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICByZW1vdmVEcm9wVGh1bWJMaW5lKGVkaXRvcik7XG59O1xuIl19
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { EDITOR_TO_ELEMENT } from 'slate-angular';
|
|
2
|
+
import { DROP_THUMB_LINE } from '../../../constants';
|
|
3
|
+
export const removeDropThumbLine = (editor) => {
|
|
4
|
+
const element = EDITOR_TO_ELEMENT.get(editor);
|
|
5
|
+
const dropThumbLine = element.querySelector('.' + DROP_THUMB_LINE);
|
|
6
|
+
if (dropThumbLine) {
|
|
7
|
+
dropThumbLine.remove();
|
|
8
|
+
}
|
|
9
|
+
};
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVtb3ZlLWRyb3AtdGh1bWItbGluZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3NyYy9wbHVnaW5zL2RuZC91dGlscy9yZW1vdmUtZHJvcC10aHVtYi1saW5lLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNsRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFHckQsTUFBTSxDQUFDLE1BQU0sbUJBQW1CLEdBQUcsQ0FBQyxNQUFpQixFQUFFLEVBQUU7SUFDckQsTUFBTSxPQUFPLEdBQUcsaUJBQWlCLENBQUMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQzlDLE1BQU0sYUFBYSxHQUFHLE9BQU8sQ0FBQyxhQUFhLENBQUMsR0FBRyxHQUFHLGVBQWUsQ0FBQyxDQUFDO0lBQ25FLElBQUksYUFBYSxFQUFFO1FBQ2YsYUFBYSxDQUFDLE1BQU0sRUFBRSxDQUFDO0tBQzFCO0FBQ0wsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRURJVE9SX1RPX0VMRU1FTlQgfSBmcm9tICdzbGF0ZS1hbmd1bGFyJztcbmltcG9ydCB7IERST1BfVEhVTUJfTElORSB9IGZyb20gJy4uLy4uLy4uL2NvbnN0YW50cyc7XG5pbXBvcnQgeyBUaGVFZGl0b3IgfSBmcm9tICcuLi8uLi8uLi9pbnRlcmZhY2VzJztcblxuZXhwb3J0IGNvbnN0IHJlbW92ZURyb3BUaHVtYkxpbmUgPSAoZWRpdG9yOiBUaGVFZGl0b3IpID0+IHtcbiAgICBjb25zdCBlbGVtZW50ID0gRURJVE9SX1RPX0VMRU1FTlQuZ2V0KGVkaXRvcik7XG4gICAgY29uc3QgZHJvcFRodW1iTGluZSA9IGVsZW1lbnQucXVlcnlTZWxlY3RvcignLicgKyBEUk9QX1RIVU1CX0xJTkUpO1xuICAgIGlmIChkcm9wVGh1bWJMaW5lKSB7XG4gICAgICAgIGRyb3BUaHVtYkxpbmUucmVtb3ZlKCk7XG4gICAgfVxufTtcbiJdfQ==
|