slate-angular 16.1.0-next.8 → 17.0.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/components/children/children.component.d.ts +6 -1
- package/components/descendant/descendant.component.d.ts +35 -0
- package/components/editable/editable.component.d.ts +5 -15
- package/components/leaf/leaf.component.d.ts +16 -0
- package/components/leaves/leaves.component.d.ts +14 -1
- package/components/string/default-string.component.d.ts +1 -1
- package/components/string/string.component.d.ts +0 -8
- package/esm2022/components/block-card/block-card.component.mjs +2 -2
- package/esm2022/components/children/children.component.mjs +33 -5
- package/esm2022/components/descendant/descendant.component.mjs +186 -0
- package/esm2022/components/editable/editable.component.mjs +38 -115
- package/esm2022/components/element/default-element.component.mjs +3 -3
- package/esm2022/components/element/element.component.mjs +3 -3
- package/esm2022/components/leaf/leaf.component.mjs +38 -0
- package/esm2022/components/leaves/leaves.component.mjs +50 -5
- package/esm2022/components/string/default-string.component.mjs +1 -1
- package/esm2022/components/string/string.component.mjs +6 -16
- package/esm2022/components/text/default-text.component.mjs +3 -3
- package/esm2022/components/text/void-text.component.mjs +3 -3
- package/esm2022/module.mjs +22 -7
- package/esm2022/plugins/angular-editor.mjs +6 -7
- package/esm2022/plugins/with-angular.mjs +4 -4
- package/esm2022/public-api.mjs +2 -3
- package/esm2022/utils/index.mjs +1 -2
- package/esm2022/view/base.mjs +17 -51
- package/esm2022/view/before-context-change.mjs +7 -0
- package/esm2022/view/container.mjs +82 -2
- package/esm2022/view/context.mjs +1 -1
- package/fesm2022/slate-angular.mjs +747 -1004
- package/fesm2022/slate-angular.mjs.map +1 -1
- package/module.d.ts +8 -7
- package/package.json +5 -5
- package/plugins/angular-editor.d.ts +1 -1
- package/public-api.d.ts +1 -2
- package/utils/index.d.ts +0 -1
- package/view/base.d.ts +4 -15
- package/view/{context-change.d.ts → before-context-change.d.ts} +0 -4
- package/view/container.d.ts +7 -3
- package/view/context.d.ts +1 -6
- package/components/children/children-outlet.component.d.ts +0 -9
- package/components/leaf/token.d.ts +0 -4
- package/components/text/token.d.ts +0 -5
- package/esm2022/components/children/children-outlet.component.mjs +0 -22
- package/esm2022/components/leaf/token.mjs +0 -3
- package/esm2022/components/text/token.mjs +0 -4
- package/esm2022/utils/throttle.mjs +0 -18
- package/esm2022/view/context-change.mjs +0 -13
- package/esm2022/view/render/leaves-render.mjs +0 -107
- package/esm2022/view/render/list-render.mjs +0 -253
- package/esm2022/view/render/utils.mjs +0 -117
- package/utils/throttle.d.ts +0 -2
- package/view/render/leaves-render.d.ts +0 -21
- package/view/render/list-render.d.ts +0 -32
- package/view/render/utils.d.ts +0 -11
|
@@ -1,253 +0,0 @@
|
|
|
1
|
-
import { Range, Editor, Element } from 'slate';
|
|
2
|
-
import { IterableDiffers } from '@angular/core';
|
|
3
|
-
import { AngularEditor } from '../../plugins/angular-editor';
|
|
4
|
-
import { SlateErrorCode } from '../../types/error';
|
|
5
|
-
import { NODE_TO_INDEX, NODE_TO_PARENT } from '../../utils/weak-maps';
|
|
6
|
-
import { isDecoratorRangeListEqual } from '../../utils/range-list';
|
|
7
|
-
import { SlateBlockCard } from '../../components/block-card/block-card.component';
|
|
8
|
-
import { createEmbeddedViewOrComponent, getRootNodes, mount, mountOnItemChange, updateContext } from './utils';
|
|
9
|
-
export class ListRender {
|
|
10
|
-
constructor(viewContext, viewContainerRef, getOutletParent, getOutletElement) {
|
|
11
|
-
this.viewContext = viewContext;
|
|
12
|
-
this.viewContainerRef = viewContainerRef;
|
|
13
|
-
this.getOutletParent = getOutletParent;
|
|
14
|
-
this.getOutletElement = getOutletElement;
|
|
15
|
-
this.views = [];
|
|
16
|
-
this.blockCards = [];
|
|
17
|
-
this.contexts = [];
|
|
18
|
-
this.viewTypes = [];
|
|
19
|
-
this.initialized = false;
|
|
20
|
-
}
|
|
21
|
-
initialize(children, parent, childrenContext) {
|
|
22
|
-
this.initialized = true;
|
|
23
|
-
this.children = children;
|
|
24
|
-
const parentPath = AngularEditor.findPath(this.viewContext.editor, parent);
|
|
25
|
-
children.forEach((descendant, index) => {
|
|
26
|
-
NODE_TO_INDEX.set(descendant, index);
|
|
27
|
-
NODE_TO_PARENT.set(descendant, parent);
|
|
28
|
-
const context = getContext(index, descendant, parentPath, childrenContext, this.viewContext);
|
|
29
|
-
const viewType = getViewType(descendant, parent, this.viewContext);
|
|
30
|
-
const view = createEmbeddedViewOrComponent(viewType, context, this.viewContext, this.viewContainerRef);
|
|
31
|
-
const blockCard = createBlockCard(descendant, view, this.viewContainerRef, this.viewContext);
|
|
32
|
-
this.views.push(view);
|
|
33
|
-
this.contexts.push(context);
|
|
34
|
-
this.viewTypes.push(viewType);
|
|
35
|
-
this.blockCards.push(blockCard);
|
|
36
|
-
});
|
|
37
|
-
mount(this.views, this.blockCards, this.getOutletParent(), this.getOutletElement());
|
|
38
|
-
const newDiffers = this.viewContainerRef.injector.get(IterableDiffers);
|
|
39
|
-
this.differ = newDiffers.find(children).create(trackBy(this.viewContext));
|
|
40
|
-
this.differ.diff(children);
|
|
41
|
-
}
|
|
42
|
-
update(children, parent, childrenContext) {
|
|
43
|
-
if (!this.initialized) {
|
|
44
|
-
this.initialize(children, parent, childrenContext);
|
|
45
|
-
return;
|
|
46
|
-
}
|
|
47
|
-
const outletParent = this.getOutletParent();
|
|
48
|
-
const diffResult = this.differ.diff(children);
|
|
49
|
-
const parentPath = AngularEditor.findPath(this.viewContext.editor, parent);
|
|
50
|
-
if (diffResult) {
|
|
51
|
-
let firstRootNode = getRootNodes(this.views[0], this.blockCards[0])[0];
|
|
52
|
-
const newContexts = [];
|
|
53
|
-
const newViewTypes = [];
|
|
54
|
-
const newViews = [];
|
|
55
|
-
const newBlockCards = [];
|
|
56
|
-
diffResult.forEachItem(record => {
|
|
57
|
-
NODE_TO_INDEX.set(record.item, record.currentIndex);
|
|
58
|
-
NODE_TO_PARENT.set(record.item, parent);
|
|
59
|
-
let context = getContext(record.currentIndex, record.item, parentPath, childrenContext, this.viewContext);
|
|
60
|
-
const viewType = getViewType(record.item, parent, this.viewContext);
|
|
61
|
-
newViewTypes.push(viewType);
|
|
62
|
-
let view;
|
|
63
|
-
let blockCard;
|
|
64
|
-
if (record.previousIndex === null) {
|
|
65
|
-
view = createEmbeddedViewOrComponent(viewType, context, this.viewContext, this.viewContainerRef);
|
|
66
|
-
blockCard = createBlockCard(record.item, view, this.viewContainerRef, this.viewContext);
|
|
67
|
-
newContexts.push(context);
|
|
68
|
-
newViews.push(view);
|
|
69
|
-
newBlockCards.push(blockCard);
|
|
70
|
-
mountOnItemChange(record.currentIndex, record.item, newViews, newBlockCards, outletParent, firstRootNode, this.viewContext);
|
|
71
|
-
}
|
|
72
|
-
else {
|
|
73
|
-
const previousView = this.views[record.previousIndex];
|
|
74
|
-
const previousViewType = this.viewTypes[record.previousIndex];
|
|
75
|
-
const previousContext = this.contexts[record.previousIndex];
|
|
76
|
-
const previousBlockCard = this.blockCards[record.previousIndex];
|
|
77
|
-
if (previousViewType !== viewType) {
|
|
78
|
-
view = createEmbeddedViewOrComponent(viewType, context, this.viewContext, this.viewContainerRef);
|
|
79
|
-
blockCard = createBlockCard(record.item, view, this.viewContainerRef, this.viewContext);
|
|
80
|
-
const firstRootNode = getRootNodes(previousView, previousBlockCard)[0];
|
|
81
|
-
const newRootNodes = getRootNodes(view, blockCard);
|
|
82
|
-
firstRootNode.replaceWith(...newRootNodes);
|
|
83
|
-
previousView.destroy();
|
|
84
|
-
previousBlockCard?.destroy();
|
|
85
|
-
}
|
|
86
|
-
else {
|
|
87
|
-
view = previousView;
|
|
88
|
-
blockCard = previousBlockCard;
|
|
89
|
-
if (memoizedContext(this.viewContext, record.item, previousContext, context)) {
|
|
90
|
-
context = previousContext;
|
|
91
|
-
}
|
|
92
|
-
else {
|
|
93
|
-
updateContext(previousView, context, this.viewContext);
|
|
94
|
-
}
|
|
95
|
-
}
|
|
96
|
-
newContexts.push(context);
|
|
97
|
-
newViews.push(view);
|
|
98
|
-
newBlockCards.push(blockCard);
|
|
99
|
-
}
|
|
100
|
-
});
|
|
101
|
-
diffResult.forEachOperation(record => {
|
|
102
|
-
// removed
|
|
103
|
-
if (record.currentIndex === null) {
|
|
104
|
-
const view = this.views[record.previousIndex];
|
|
105
|
-
const blockCard = this.blockCards[record.previousIndex];
|
|
106
|
-
view.destroy();
|
|
107
|
-
blockCard?.destroy();
|
|
108
|
-
}
|
|
109
|
-
// moved
|
|
110
|
-
if (record.previousIndex !== null && record.currentIndex !== null) {
|
|
111
|
-
mountOnItemChange(record.currentIndex, record.item, newViews, newBlockCards, outletParent, firstRootNode, this.viewContext);
|
|
112
|
-
// Solve the block-card DOMElement loss when moving nodes
|
|
113
|
-
newBlockCards[record.currentIndex]?.instance.append();
|
|
114
|
-
}
|
|
115
|
-
});
|
|
116
|
-
this.viewTypes = newViewTypes;
|
|
117
|
-
this.views = newViews;
|
|
118
|
-
this.contexts = newContexts;
|
|
119
|
-
this.children = children;
|
|
120
|
-
this.blockCards = newBlockCards;
|
|
121
|
-
}
|
|
122
|
-
else {
|
|
123
|
-
const newContexts = [];
|
|
124
|
-
this.children.forEach((child, index) => {
|
|
125
|
-
let context = getContext(index, child, parentPath, childrenContext, this.viewContext);
|
|
126
|
-
const previousContext = this.contexts[index];
|
|
127
|
-
if (memoizedContext(this.viewContext, child, previousContext, context)) {
|
|
128
|
-
context = previousContext;
|
|
129
|
-
}
|
|
130
|
-
else {
|
|
131
|
-
updateContext(this.views[index], context, this.viewContext);
|
|
132
|
-
}
|
|
133
|
-
newContexts.push(context);
|
|
134
|
-
});
|
|
135
|
-
this.contexts = newContexts;
|
|
136
|
-
}
|
|
137
|
-
}
|
|
138
|
-
}
|
|
139
|
-
export function getContext(index, item, parentPath, childrenContext, viewContext) {
|
|
140
|
-
if (Element.isElement(item)) {
|
|
141
|
-
const computedContext = getCommonContext(index, item, parentPath, viewContext, childrenContext);
|
|
142
|
-
const key = AngularEditor.findKey(viewContext.editor, item);
|
|
143
|
-
const isInline = viewContext.editor.isInline(item);
|
|
144
|
-
const isVoid = viewContext.editor.isVoid(item);
|
|
145
|
-
const elementContext = {
|
|
146
|
-
element: item,
|
|
147
|
-
...computedContext,
|
|
148
|
-
attributes: {
|
|
149
|
-
'data-slate-node': 'element',
|
|
150
|
-
'data-slate-key': key.id
|
|
151
|
-
},
|
|
152
|
-
decorate: childrenContext.decorate,
|
|
153
|
-
readonly: childrenContext.readonly
|
|
154
|
-
};
|
|
155
|
-
if (isInline) {
|
|
156
|
-
elementContext.attributes['data-slate-inline'] = true;
|
|
157
|
-
}
|
|
158
|
-
if (isVoid) {
|
|
159
|
-
elementContext.attributes['data-slate-void'] = true;
|
|
160
|
-
elementContext.attributes.contenteditable = false;
|
|
161
|
-
}
|
|
162
|
-
return elementContext;
|
|
163
|
-
}
|
|
164
|
-
else {
|
|
165
|
-
const computedContext = getCommonContext(index, item, parentPath, viewContext, childrenContext);
|
|
166
|
-
const isLeafBlock = AngularEditor.isLeafBlock(viewContext.editor, childrenContext.parent);
|
|
167
|
-
const textContext = {
|
|
168
|
-
decorations: computedContext.decorations,
|
|
169
|
-
isLast: isLeafBlock && index === childrenContext.parent.children.length - 1,
|
|
170
|
-
parent: childrenContext.parent,
|
|
171
|
-
text: item
|
|
172
|
-
};
|
|
173
|
-
return textContext;
|
|
174
|
-
}
|
|
175
|
-
}
|
|
176
|
-
export function getCommonContext(index, item, parentPath, viewContext, childrenContext) {
|
|
177
|
-
const p = parentPath.concat(index);
|
|
178
|
-
try {
|
|
179
|
-
const ds = childrenContext.decorate([item, p]);
|
|
180
|
-
// [list-render] performance optimization: reduce the number of calls to the `Editor.range(viewContext.editor, p)` method
|
|
181
|
-
if (childrenContext.selection || childrenContext.decorations.length > 0) {
|
|
182
|
-
const range = Editor.range(viewContext.editor, p);
|
|
183
|
-
const sel = childrenContext.selection && Range.intersection(range, childrenContext.selection);
|
|
184
|
-
for (const dec of childrenContext.decorations) {
|
|
185
|
-
const d = Range.intersection(dec, range);
|
|
186
|
-
if (d) {
|
|
187
|
-
ds.push(d);
|
|
188
|
-
}
|
|
189
|
-
}
|
|
190
|
-
return { selection: sel, decorations: ds };
|
|
191
|
-
}
|
|
192
|
-
else {
|
|
193
|
-
return { selection: null, decorations: ds };
|
|
194
|
-
}
|
|
195
|
-
}
|
|
196
|
-
catch (error) {
|
|
197
|
-
this.options.viewContext.editor.onError({
|
|
198
|
-
code: SlateErrorCode.GetStartPointError,
|
|
199
|
-
nativeError: error
|
|
200
|
-
});
|
|
201
|
-
return { selection: null, decorations: [] };
|
|
202
|
-
}
|
|
203
|
-
}
|
|
204
|
-
export function getViewType(item, parent, viewContext) {
|
|
205
|
-
if (Element.isElement(item)) {
|
|
206
|
-
return (viewContext.renderElement && viewContext.renderElement(item)) || viewContext.defaultElement;
|
|
207
|
-
}
|
|
208
|
-
else {
|
|
209
|
-
const isVoid = viewContext.editor.isVoid(parent);
|
|
210
|
-
return isVoid ? viewContext.defaultVoidText : (viewContext.renderText && viewContext.renderText(item)) || viewContext.defaultText;
|
|
211
|
-
}
|
|
212
|
-
}
|
|
213
|
-
export function createBlockCard(item, view, viewContainerRef, viewContext) {
|
|
214
|
-
const isBlockCard = viewContext.editor.isBlockCard(item);
|
|
215
|
-
if (isBlockCard) {
|
|
216
|
-
const rootNodes = getRootNodes(view);
|
|
217
|
-
const blockCardComponentRef = viewContainerRef.createComponent(SlateBlockCard, {
|
|
218
|
-
injector: viewContainerRef.injector
|
|
219
|
-
});
|
|
220
|
-
blockCardComponentRef.instance.initializeCenter(rootNodes);
|
|
221
|
-
return blockCardComponentRef;
|
|
222
|
-
}
|
|
223
|
-
else {
|
|
224
|
-
return null;
|
|
225
|
-
}
|
|
226
|
-
}
|
|
227
|
-
export function trackBy(viewContext) {
|
|
228
|
-
return (index, node) => {
|
|
229
|
-
return viewContext.trackBy(node) || AngularEditor.findKey(viewContext.editor, node);
|
|
230
|
-
};
|
|
231
|
-
}
|
|
232
|
-
export function memoizedContext(viewContext, descendant, prev, next) {
|
|
233
|
-
if (Element.isElement(descendant)) {
|
|
234
|
-
return memoizedElementContext(viewContext, prev, next);
|
|
235
|
-
}
|
|
236
|
-
else {
|
|
237
|
-
return memoizedTextContext(prev, next);
|
|
238
|
-
}
|
|
239
|
-
}
|
|
240
|
-
export function memoizedElementContext(viewContext, prev, next) {
|
|
241
|
-
return (prev.element === next.element &&
|
|
242
|
-
(!viewContext.isStrictDecorate || prev.decorate === next.decorate) &&
|
|
243
|
-
prev.readonly === next.readonly &&
|
|
244
|
-
isDecoratorRangeListEqual(prev.decorations, next.decorations) &&
|
|
245
|
-
(prev.selection === next.selection || (!!prev.selection && !!next.selection && Range.equals(prev.selection, next.selection))));
|
|
246
|
-
}
|
|
247
|
-
export function memoizedTextContext(prev, next) {
|
|
248
|
-
return (next.parent === prev.parent &&
|
|
249
|
-
next.isLast === prev.isLast &&
|
|
250
|
-
next.text === prev.text &&
|
|
251
|
-
isDecoratorRangeListEqual(next.decorations, prev.decorations));
|
|
252
|
-
}
|
|
253
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list-render.js","sourceRoot":"","sources":["../../../../packages/src/view/render/list-render.ts"],"names":[],"mappings":"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","sourcesContent":["import { Ancestor, Descendant, Range, Editor, Element, Path } from 'slate';\nimport { ComponentRef, EmbeddedViewRef, IterableDiffer, IterableDiffers, ViewContainerRef } from '@angular/core';\nimport { ViewType } from '../../types/view';\nimport { SlateChildrenContext, SlateElementContext, SlateTextContext, SlateViewContext } from '../context';\nimport { AngularEditor } from '../../plugins/angular-editor';\nimport { SlateErrorCode } from '../../types/error';\nimport { NODE_TO_INDEX, NODE_TO_PARENT } from '../../utils/weak-maps';\nimport { isDecoratorRangeListEqual } from '../../utils/range-list';\nimport { SlateBlockCard } from '../../components/block-card/block-card.component';\nimport { createEmbeddedViewOrComponent, getRootNodes, mount, mountOnItemChange, renderView, updateContext } from './utils';\n\nexport class ListRender {\n    private children: Descendant[];\n    private views: (EmbeddedViewRef<any> | ComponentRef<any>)[] = [];\n    private blockCards: (ComponentRef<SlateBlockCard> | null)[] = [];\n    private contexts: (SlateTextContext | SlateElementContext)[] = [];\n    private viewTypes: ViewType[] = [];\n    private differ: IterableDiffer<any>;\n    public initialized = false;\n\n    constructor(\n        private viewContext: SlateViewContext,\n        private viewContainerRef: ViewContainerRef,\n        private getOutletParent: () => HTMLElement,\n        private getOutletElement: () => HTMLElement | null\n    ) {}\n\n    public initialize(children: Descendant[], parent: Ancestor, childrenContext: SlateChildrenContext) {\n        this.initialized = true;\n        this.children = children;\n        const parentPath = AngularEditor.findPath(this.viewContext.editor, parent);\n        children.forEach((descendant, index) => {\n            NODE_TO_INDEX.set(descendant, index);\n            NODE_TO_PARENT.set(descendant, parent);\n            const context = getContext(index, descendant, parentPath, childrenContext, this.viewContext);\n            const viewType = getViewType(descendant, parent, this.viewContext);\n            const view = createEmbeddedViewOrComponent(viewType, context, this.viewContext, this.viewContainerRef);\n            const blockCard = createBlockCard(descendant, view, this.viewContainerRef, this.viewContext);\n            this.views.push(view);\n            this.contexts.push(context);\n            this.viewTypes.push(viewType);\n            this.blockCards.push(blockCard);\n        });\n        mount(this.views, this.blockCards, this.getOutletParent(), this.getOutletElement());\n        const newDiffers = this.viewContainerRef.injector.get(IterableDiffers);\n        this.differ = newDiffers.find(children).create(trackBy(this.viewContext));\n        this.differ.diff(children);\n    }\n\n    public update(children: Descendant[], parent: Ancestor, childrenContext: SlateChildrenContext) {\n        if (!this.initialized) {\n            this.initialize(children, parent, childrenContext);\n            return;\n        }\n        const outletParent = this.getOutletParent();\n        const diffResult = this.differ.diff(children);\n        const parentPath = AngularEditor.findPath(this.viewContext.editor, parent);\n        if (diffResult) {\n            let firstRootNode = getRootNodes(this.views[0], this.blockCards[0])[0];\n            const newContexts = [];\n            const newViewTypes = [];\n            const newViews = [];\n            const newBlockCards: (ComponentRef<SlateBlockCard> | null)[] = [];\n            diffResult.forEachItem(record => {\n                NODE_TO_INDEX.set(record.item, record.currentIndex);\n                NODE_TO_PARENT.set(record.item, parent);\n                let context = getContext(record.currentIndex, record.item, parentPath, childrenContext, this.viewContext);\n                const viewType = getViewType(record.item, parent, this.viewContext);\n                newViewTypes.push(viewType);\n                let view: EmbeddedViewRef<any> | ComponentRef<any>;\n                let blockCard: ComponentRef<SlateBlockCard> | null;\n                if (record.previousIndex === null) {\n                    view = createEmbeddedViewOrComponent(viewType, context, this.viewContext, this.viewContainerRef);\n                    blockCard = createBlockCard(record.item, view, this.viewContainerRef, this.viewContext);\n                    newContexts.push(context);\n                    newViews.push(view);\n                    newBlockCards.push(blockCard);\n                    mountOnItemChange(\n                        record.currentIndex,\n                        record.item,\n                        newViews,\n                        newBlockCards,\n                        outletParent,\n                        firstRootNode,\n                        this.viewContext\n                    );\n                } else {\n                    const previousView = this.views[record.previousIndex];\n                    const previousViewType = this.viewTypes[record.previousIndex];\n                    const previousContext = this.contexts[record.previousIndex];\n                    const previousBlockCard = this.blockCards[record.previousIndex];\n                    if (previousViewType !== viewType) {\n                        view = createEmbeddedViewOrComponent(viewType, context, this.viewContext, this.viewContainerRef);\n                        blockCard = createBlockCard(record.item, view, this.viewContainerRef, this.viewContext);\n                        const firstRootNode = getRootNodes(previousView, previousBlockCard)[0];\n                        const newRootNodes = getRootNodes(view, blockCard);\n                        firstRootNode.replaceWith(...newRootNodes);\n                        previousView.destroy();\n                        previousBlockCard?.destroy();\n                    } else {\n                        view = previousView;\n                        blockCard = previousBlockCard;\n                        if (memoizedContext(this.viewContext, record.item, previousContext as any, context as any)) {\n                            context = previousContext;\n                        } else {\n                            updateContext(previousView, context, this.viewContext);\n                        }\n                    }\n                    newContexts.push(context);\n                    newViews.push(view);\n                    newBlockCards.push(blockCard);\n                }\n            });\n            diffResult.forEachOperation(record => {\n                // removed\n                if (record.currentIndex === null) {\n                    const view = this.views[record.previousIndex];\n                    const blockCard = this.blockCards[record.previousIndex];\n                    view.destroy();\n                    blockCard?.destroy();\n                }\n                // moved\n                if (record.previousIndex !== null && record.currentIndex !== null) {\n                    mountOnItemChange(\n                        record.currentIndex,\n                        record.item,\n                        newViews,\n                        newBlockCards,\n                        outletParent,\n                        firstRootNode,\n                        this.viewContext\n                    );\n                    // Solve the block-card DOMElement loss when moving nodes\n                    newBlockCards[record.currentIndex]?.instance.append();\n                }\n            });\n            this.viewTypes = newViewTypes;\n            this.views = newViews;\n            this.contexts = newContexts;\n            this.children = children;\n            this.blockCards = newBlockCards;\n        } else {\n            const newContexts = [];\n            this.children.forEach((child, index) => {\n                let context = getContext(index, child, parentPath, childrenContext, this.viewContext);\n                const previousContext = this.contexts[index];\n                if (memoizedContext(this.viewContext, child, previousContext as any, context as any)) {\n                    context = previousContext;\n                } else {\n                    updateContext(this.views[index], context, this.viewContext);\n                }\n                newContexts.push(context);\n            });\n            this.contexts = newContexts;\n        }\n    }\n}\n\nexport function getContext(\n    index: number,\n    item: Descendant,\n    parentPath: Path,\n    childrenContext: SlateChildrenContext,\n    viewContext: SlateViewContext\n): SlateElementContext | SlateTextContext {\n    if (Element.isElement(item)) {\n        const computedContext = getCommonContext(index, item, parentPath, viewContext, childrenContext);\n        const key = AngularEditor.findKey(viewContext.editor, item);\n        const isInline = viewContext.editor.isInline(item);\n        const isVoid = viewContext.editor.isVoid(item);\n        const elementContext: SlateElementContext = {\n            element: item,\n            ...computedContext,\n            attributes: {\n                'data-slate-node': 'element',\n                'data-slate-key': key.id\n            },\n            decorate: childrenContext.decorate,\n            readonly: childrenContext.readonly\n        };\n        if (isInline) {\n            elementContext.attributes['data-slate-inline'] = true;\n        }\n        if (isVoid) {\n            elementContext.attributes['data-slate-void'] = true;\n            elementContext.attributes.contenteditable = false;\n        }\n        return elementContext;\n    } else {\n        const computedContext = getCommonContext(index, item, parentPath, viewContext, childrenContext);\n        const isLeafBlock = AngularEditor.isLeafBlock(viewContext.editor, childrenContext.parent);\n        const textContext: SlateTextContext = {\n            decorations: computedContext.decorations,\n            isLast: isLeafBlock && index === childrenContext.parent.children.length - 1,\n            parent: childrenContext.parent as Element,\n            text: item\n        };\n        return textContext;\n    }\n}\n\nexport function getCommonContext(\n    index: number,\n    item: Descendant,\n    parentPath: Path,\n    viewContext: SlateViewContext,\n    childrenContext: SlateChildrenContext\n): { selection: Range; decorations: Range[] } {\n    const p = parentPath.concat(index);\n    try {\n        const ds = childrenContext.decorate([item, p]);\n        // [list-render] performance optimization: reduce the number of calls to the `Editor.range(viewContext.editor, p)` method\n        if (childrenContext.selection || childrenContext.decorations.length > 0) {\n            const range = Editor.range(viewContext.editor, p);\n            const sel = childrenContext.selection && Range.intersection(range, childrenContext.selection);\n            for (const dec of childrenContext.decorations) {\n                const d = Range.intersection(dec, range);\n                if (d) {\n                    ds.push(d);\n                }\n            }\n            return { selection: sel, decorations: ds };\n        } else {\n            return { selection: null, decorations: ds };\n        }\n    } catch (error) {\n        this.options.viewContext.editor.onError({\n            code: SlateErrorCode.GetStartPointError,\n            nativeError: error\n        });\n        return { selection: null, decorations: [] };\n    }\n}\n\nexport function getViewType(item: Descendant, parent: Ancestor, viewContext: SlateViewContext) {\n    if (Element.isElement(item)) {\n        return (viewContext.renderElement && viewContext.renderElement(item)) || viewContext.defaultElement;\n    } else {\n        const isVoid = viewContext.editor.isVoid(parent as Element);\n        return isVoid ? viewContext.defaultVoidText : (viewContext.renderText && viewContext.renderText(item)) || viewContext.defaultText;\n    }\n}\n\nexport function createBlockCard(\n    item: Descendant,\n    view: EmbeddedViewRef<any> | ComponentRef<any>,\n    viewContainerRef: ViewContainerRef,\n    viewContext: SlateViewContext\n) {\n    const isBlockCard = viewContext.editor.isBlockCard(item);\n    if (isBlockCard) {\n        const rootNodes = getRootNodes(view);\n        const blockCardComponentRef = viewContainerRef.createComponent<SlateBlockCard>(SlateBlockCard, {\n            injector: viewContainerRef.injector\n        });\n        blockCardComponentRef.instance.initializeCenter(rootNodes);\n        return blockCardComponentRef;\n    } else {\n        return null;\n    }\n}\n\nexport function trackBy(viewContext: SlateViewContext) {\n    return (index, node) => {\n        return viewContext.trackBy(node) || AngularEditor.findKey(viewContext.editor, node);\n    };\n}\n\nexport function memoizedContext(\n    viewContext: SlateViewContext,\n    descendant: Descendant,\n    prev: SlateElementContext | SlateTextContext,\n    next: SlateElementContext | SlateTextContext\n): boolean {\n    if (Element.isElement(descendant)) {\n        return memoizedElementContext(viewContext, prev as SlateElementContext, next as SlateElementContext);\n    } else {\n        return memoizedTextContext(prev as SlateTextContext, next as SlateTextContext);\n    }\n}\n\nexport function memoizedElementContext(viewContext: SlateViewContext, prev: SlateElementContext, next: SlateElementContext) {\n    return (\n        prev.element === next.element &&\n        (!viewContext.isStrictDecorate || prev.decorate === next.decorate) &&\n        prev.readonly === next.readonly &&\n        isDecoratorRangeListEqual(prev.decorations, next.decorations) &&\n        (prev.selection === next.selection || (!!prev.selection && !!next.selection && Range.equals(prev.selection, next.selection)))\n    );\n}\n\nexport function memoizedTextContext(prev: SlateTextContext, next: SlateTextContext) {\n    return (\n        next.parent === prev.parent &&\n        next.isLast === prev.isLast &&\n        next.text === prev.text &&\n        isDecoratorRangeListEqual(next.decorations, prev.decorations)\n    );\n}\n"]}
|
|
@@ -1,117 +0,0 @@
|
|
|
1
|
-
import { ComponentRef } from '@angular/core';
|
|
2
|
-
import { isComponentType, isTemplateRef } from '../../utils/view';
|
|
3
|
-
export function createEmbeddedViewOrComponent(viewType, context, viewContext, viewContainerRef) {
|
|
4
|
-
if (isTemplateRef(viewType)) {
|
|
5
|
-
const embeddedViewContext = {
|
|
6
|
-
context,
|
|
7
|
-
viewContext
|
|
8
|
-
};
|
|
9
|
-
const embeddedViewRef = viewContainerRef.createEmbeddedView(viewType, embeddedViewContext);
|
|
10
|
-
embeddedViewRef.detectChanges();
|
|
11
|
-
return embeddedViewRef;
|
|
12
|
-
}
|
|
13
|
-
if (isComponentType(viewType)) {
|
|
14
|
-
const componentRef = viewContainerRef.createComponent(viewType, {
|
|
15
|
-
injector: viewContainerRef.injector
|
|
16
|
-
});
|
|
17
|
-
componentRef.instance.viewContext = viewContext;
|
|
18
|
-
componentRef.instance.context = context;
|
|
19
|
-
componentRef.changeDetectorRef.detectChanges();
|
|
20
|
-
return componentRef;
|
|
21
|
-
}
|
|
22
|
-
}
|
|
23
|
-
export function renderView(view) {
|
|
24
|
-
if (view instanceof ComponentRef) {
|
|
25
|
-
view.changeDetectorRef.detectChanges();
|
|
26
|
-
}
|
|
27
|
-
else {
|
|
28
|
-
view.detectChanges();
|
|
29
|
-
}
|
|
30
|
-
}
|
|
31
|
-
export function updateContext(view, newContext, viewContext) {
|
|
32
|
-
if (view instanceof ComponentRef) {
|
|
33
|
-
view.instance.context = newContext;
|
|
34
|
-
}
|
|
35
|
-
else {
|
|
36
|
-
const embeddedViewContext = {
|
|
37
|
-
context: newContext,
|
|
38
|
-
viewContext
|
|
39
|
-
};
|
|
40
|
-
view.context = embeddedViewContext;
|
|
41
|
-
view.detectChanges();
|
|
42
|
-
}
|
|
43
|
-
}
|
|
44
|
-
export function mount(views, blockCards, outletParent, outletElement) {
|
|
45
|
-
if (views.length > 0) {
|
|
46
|
-
const fragment = document.createDocumentFragment();
|
|
47
|
-
views.forEach((view, index) => {
|
|
48
|
-
const blockCard = blockCards ? blockCards[index] : undefined;
|
|
49
|
-
fragment.append(...getRootNodes(view, blockCard));
|
|
50
|
-
});
|
|
51
|
-
if (outletElement) {
|
|
52
|
-
outletParent.insertBefore(fragment, outletElement);
|
|
53
|
-
outletElement.remove();
|
|
54
|
-
}
|
|
55
|
-
else {
|
|
56
|
-
outletParent.prepend(fragment);
|
|
57
|
-
}
|
|
58
|
-
}
|
|
59
|
-
}
|
|
60
|
-
export function getRootNodes(ref, blockCard) {
|
|
61
|
-
if (blockCard) {
|
|
62
|
-
return [blockCard.instance.nativeElement];
|
|
63
|
-
}
|
|
64
|
-
if (ref instanceof ComponentRef) {
|
|
65
|
-
ref.hostView.rootNodes.forEach(ele => {
|
|
66
|
-
if (!(ele instanceof HTMLElement)) {
|
|
67
|
-
ele.remove();
|
|
68
|
-
}
|
|
69
|
-
});
|
|
70
|
-
return [ref.instance.nativeElement];
|
|
71
|
-
}
|
|
72
|
-
else {
|
|
73
|
-
const result = [];
|
|
74
|
-
ref.rootNodes.forEach(rootNode => {
|
|
75
|
-
const isHTMLElement = rootNode instanceof HTMLElement;
|
|
76
|
-
if (isHTMLElement && result.every(item => !item.contains(rootNode))) {
|
|
77
|
-
result.push(rootNode);
|
|
78
|
-
}
|
|
79
|
-
if (!isHTMLElement) {
|
|
80
|
-
rootNode.remove();
|
|
81
|
-
}
|
|
82
|
-
});
|
|
83
|
-
return result;
|
|
84
|
-
}
|
|
85
|
-
}
|
|
86
|
-
export function mountOnItemChange(index, item, views, blockCards, outletParent, firstRootNode, viewContext) {
|
|
87
|
-
const view = views[index];
|
|
88
|
-
let rootNodes = getRootNodes(view);
|
|
89
|
-
if (blockCards) {
|
|
90
|
-
const isBlockCard = viewContext.editor.isBlockCard(item);
|
|
91
|
-
if (isBlockCard) {
|
|
92
|
-
const blockCard = blockCards[index];
|
|
93
|
-
rootNodes = [blockCard.instance.nativeElement];
|
|
94
|
-
}
|
|
95
|
-
}
|
|
96
|
-
if (index === 0) {
|
|
97
|
-
if (firstRootNode) {
|
|
98
|
-
rootNodes.forEach(rootNode => {
|
|
99
|
-
firstRootNode.insertAdjacentElement('beforebegin', rootNode);
|
|
100
|
-
});
|
|
101
|
-
}
|
|
102
|
-
else {
|
|
103
|
-
outletParent.prepend(...rootNodes);
|
|
104
|
-
}
|
|
105
|
-
}
|
|
106
|
-
else {
|
|
107
|
-
const previousView = views[index - 1];
|
|
108
|
-
const blockCard = blockCards ? blockCards[index - 1] : null;
|
|
109
|
-
const previousRootNodes = getRootNodes(previousView, blockCard);
|
|
110
|
-
let previousRootNode = previousRootNodes[previousRootNodes.length - 1];
|
|
111
|
-
rootNodes.forEach(rootNode => {
|
|
112
|
-
previousRootNode.insertAdjacentElement('afterend', rootNode);
|
|
113
|
-
previousRootNode = rootNode;
|
|
114
|
-
});
|
|
115
|
-
}
|
|
116
|
-
}
|
|
117
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../packages/src/view/render/utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { Descendant } from 'slate';\nimport { ComponentRef, EmbeddedViewRef, ViewContainerRef } from '@angular/core';\nimport { ViewType } from '../../types/view';\nimport { isComponentType, isTemplateRef } from '../../utils/view';\nimport { SlateElementContext, SlateLeafContext, SlateTextContext, SlateViewContext } from '../context';\nimport { SlateBlockCard } from '../../components/block-card/block-card.component';\n\nexport function createEmbeddedViewOrComponent(\n    viewType: ViewType,\n    context: any,\n    viewContext: SlateViewContext,\n    viewContainerRef: ViewContainerRef\n) {\n    if (isTemplateRef(viewType)) {\n        const embeddedViewContext = {\n            context,\n            viewContext\n        };\n        const embeddedViewRef = viewContainerRef.createEmbeddedView<any>(viewType, embeddedViewContext);\n        embeddedViewRef.detectChanges();\n        return embeddedViewRef;\n    }\n    if (isComponentType(viewType)) {\n        const componentRef = viewContainerRef.createComponent(viewType, {\n            injector: viewContainerRef.injector\n        }) as ComponentRef<any>;\n        componentRef.instance.viewContext = viewContext;\n        componentRef.instance.context = context;\n        componentRef.changeDetectorRef.detectChanges();\n        return componentRef;\n    }\n}\n\nexport function renderView(view: EmbeddedViewRef<any> | ComponentRef<any>) {\n    if (view instanceof ComponentRef) {\n        view.changeDetectorRef.detectChanges();\n    } else {\n        view.detectChanges();\n    }\n}\n\nexport function updateContext(\n    view: EmbeddedViewRef<any> | ComponentRef<any>,\n    newContext: SlateElementContext | SlateTextContext | SlateLeafContext,\n    viewContext: SlateViewContext\n) {\n    if (view instanceof ComponentRef) {\n        view.instance.context = newContext;\n    } else {\n        const embeddedViewContext = {\n            context: newContext,\n            viewContext\n        };\n        view.context = embeddedViewContext;\n        view.detectChanges();\n    }\n}\n\nexport function mount(\n    views: (EmbeddedViewRef<any> | ComponentRef<any>)[],\n    blockCards: (ComponentRef<SlateBlockCard> | null)[] | null,\n    outletParent: HTMLElement,\n    outletElement: HTMLElement | null\n) {\n    if (views.length > 0) {\n        const fragment = document.createDocumentFragment();\n        views.forEach((view, index) => {\n            const blockCard = blockCards ? blockCards[index] : undefined;\n            fragment.append(...getRootNodes(view, blockCard));\n        });\n        if (outletElement) {\n            outletParent.insertBefore(fragment, outletElement);\n            outletElement.remove();\n        } else {\n            outletParent.prepend(fragment);\n        }\n    }\n}\n\nexport function getRootNodes(ref: EmbeddedViewRef<any> | ComponentRef<any>, blockCard?: ComponentRef<SlateBlockCard>): HTMLElement[] {\n    if (blockCard) {\n        return [blockCard.instance.nativeElement];\n    }\n    if (ref instanceof ComponentRef) {\n        ((ref.hostView as any).rootNodes as (HTMLElement | any)[]).forEach(ele => {\n            if (!(ele instanceof HTMLElement)) {\n                ele.remove();\n            }\n        });\n        return [ref.instance.nativeElement];\n    } else {\n        const result: HTMLElement[] = [];\n        ref.rootNodes.forEach(rootNode => {\n            const isHTMLElement = rootNode instanceof HTMLElement;\n            if (isHTMLElement && result.every(item => !item.contains(rootNode))) {\n                result.push(rootNode);\n            }\n            if (!isHTMLElement) {\n                rootNode.remove();\n            }\n        });\n        return result;\n    }\n}\n\nexport function mountOnItemChange(\n    index: number,\n    item: Descendant,\n    views: (EmbeddedViewRef<any> | ComponentRef<any>)[],\n    blockCards: (ComponentRef<SlateBlockCard> | null)[] | null,\n    outletParent: HTMLElement,\n    firstRootNode: HTMLElement | null,\n    viewContext: SlateViewContext\n) {\n    const view = views[index];\n    let rootNodes = getRootNodes(view);\n    if (blockCards) {\n        const isBlockCard = viewContext.editor.isBlockCard(item);\n        if (isBlockCard) {\n            const blockCard = blockCards[index];\n            rootNodes = [blockCard.instance.nativeElement];\n        }\n    }\n    if (index === 0) {\n        if (firstRootNode) {\n            rootNodes.forEach(rootNode => {\n                firstRootNode.insertAdjacentElement('beforebegin', rootNode);\n            });\n        } else {\n            outletParent.prepend(...rootNodes);\n        }\n    } else {\n        const previousView = views[index - 1];\n        const blockCard = blockCards ? blockCards[index - 1] : null;\n        const previousRootNodes = getRootNodes(previousView, blockCard);\n        let previousRootNode = previousRootNodes[previousRootNodes.length - 1];\n        rootNodes.forEach(rootNode => {\n            previousRootNode.insertAdjacentElement('afterend', rootNode);\n            previousRootNode = rootNode;\n        });\n    }\n}\n"]}
|
package/utils/throttle.d.ts
DELETED
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
import { ViewContainerRef } from '@angular/core';
|
|
2
|
-
import { ViewType } from '../../types/view';
|
|
3
|
-
import { SlateLeafContext, SlateTextContext, SlateViewContext } from '../context';
|
|
4
|
-
export declare class LeavesRender {
|
|
5
|
-
private viewContext;
|
|
6
|
-
private viewContainerRef;
|
|
7
|
-
private getOutletParent;
|
|
8
|
-
private getOutletElement;
|
|
9
|
-
private leaves;
|
|
10
|
-
private views;
|
|
11
|
-
private contexts;
|
|
12
|
-
private viewTypes;
|
|
13
|
-
private differ;
|
|
14
|
-
constructor(viewContext: SlateViewContext, viewContainerRef: ViewContainerRef, getOutletParent: () => HTMLElement, getOutletElement: () => HTMLElement);
|
|
15
|
-
initialize(context: SlateTextContext): void;
|
|
16
|
-
update(context: SlateTextContext): void;
|
|
17
|
-
private getLeaves;
|
|
18
|
-
}
|
|
19
|
-
export declare function getContext(index: number, leafContexts: SlateLeafContext[]): SlateLeafContext;
|
|
20
|
-
export declare function getViewType(leafContext: SlateLeafContext, viewContext: SlateViewContext): ViewType;
|
|
21
|
-
export declare function trackBy(viewContext: SlateViewContext): (index: any, node: any) => any;
|
|
@@ -1,32 +0,0 @@
|
|
|
1
|
-
import { Ancestor, Descendant, Range, Path } from 'slate';
|
|
2
|
-
import { ComponentRef, EmbeddedViewRef, ViewContainerRef } from '@angular/core';
|
|
3
|
-
import { ViewType } from '../../types/view';
|
|
4
|
-
import { SlateChildrenContext, SlateElementContext, SlateTextContext, SlateViewContext } from '../context';
|
|
5
|
-
import { SlateBlockCard } from '../../components/block-card/block-card.component';
|
|
6
|
-
export declare class ListRender {
|
|
7
|
-
private viewContext;
|
|
8
|
-
private viewContainerRef;
|
|
9
|
-
private getOutletParent;
|
|
10
|
-
private getOutletElement;
|
|
11
|
-
private children;
|
|
12
|
-
private views;
|
|
13
|
-
private blockCards;
|
|
14
|
-
private contexts;
|
|
15
|
-
private viewTypes;
|
|
16
|
-
private differ;
|
|
17
|
-
initialized: boolean;
|
|
18
|
-
constructor(viewContext: SlateViewContext, viewContainerRef: ViewContainerRef, getOutletParent: () => HTMLElement, getOutletElement: () => HTMLElement | null);
|
|
19
|
-
initialize(children: Descendant[], parent: Ancestor, childrenContext: SlateChildrenContext): void;
|
|
20
|
-
update(children: Descendant[], parent: Ancestor, childrenContext: SlateChildrenContext): void;
|
|
21
|
-
}
|
|
22
|
-
export declare function getContext(index: number, item: Descendant, parentPath: Path, childrenContext: SlateChildrenContext, viewContext: SlateViewContext): SlateElementContext | SlateTextContext;
|
|
23
|
-
export declare function getCommonContext(index: number, item: Descendant, parentPath: Path, viewContext: SlateViewContext, childrenContext: SlateChildrenContext): {
|
|
24
|
-
selection: Range;
|
|
25
|
-
decorations: Range[];
|
|
26
|
-
};
|
|
27
|
-
export declare function getViewType(item: Descendant, parent: Ancestor, viewContext: SlateViewContext): ViewType;
|
|
28
|
-
export declare function createBlockCard(item: Descendant, view: EmbeddedViewRef<any> | ComponentRef<any>, viewContainerRef: ViewContainerRef, viewContext: SlateViewContext): ComponentRef<SlateBlockCard>;
|
|
29
|
-
export declare function trackBy(viewContext: SlateViewContext): (index: any, node: any) => any;
|
|
30
|
-
export declare function memoizedContext(viewContext: SlateViewContext, descendant: Descendant, prev: SlateElementContext | SlateTextContext, next: SlateElementContext | SlateTextContext): boolean;
|
|
31
|
-
export declare function memoizedElementContext(viewContext: SlateViewContext, prev: SlateElementContext, next: SlateElementContext): boolean;
|
|
32
|
-
export declare function memoizedTextContext(prev: SlateTextContext, next: SlateTextContext): boolean;
|
package/view/render/utils.d.ts
DELETED
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
import { Descendant } from 'slate';
|
|
2
|
-
import { ComponentRef, EmbeddedViewRef, ViewContainerRef } from '@angular/core';
|
|
3
|
-
import { ViewType } from '../../types/view';
|
|
4
|
-
import { SlateElementContext, SlateLeafContext, SlateTextContext, SlateViewContext } from '../context';
|
|
5
|
-
import { SlateBlockCard } from '../../components/block-card/block-card.component';
|
|
6
|
-
export declare function createEmbeddedViewOrComponent(viewType: ViewType, context: any, viewContext: SlateViewContext, viewContainerRef: ViewContainerRef): EmbeddedViewRef<any> | ComponentRef<any>;
|
|
7
|
-
export declare function renderView(view: EmbeddedViewRef<any> | ComponentRef<any>): void;
|
|
8
|
-
export declare function updateContext(view: EmbeddedViewRef<any> | ComponentRef<any>, newContext: SlateElementContext | SlateTextContext | SlateLeafContext, viewContext: SlateViewContext): void;
|
|
9
|
-
export declare function mount(views: (EmbeddedViewRef<any> | ComponentRef<any>)[], blockCards: (ComponentRef<SlateBlockCard> | null)[] | null, outletParent: HTMLElement, outletElement: HTMLElement | null): void;
|
|
10
|
-
export declare function getRootNodes(ref: EmbeddedViewRef<any> | ComponentRef<any>, blockCard?: ComponentRef<SlateBlockCard>): HTMLElement[];
|
|
11
|
-
export declare function mountOnItemChange(index: number, item: Descendant, views: (EmbeddedViewRef<any> | ComponentRef<any>)[], blockCards: (ComponentRef<SlateBlockCard> | null)[] | null, outletParent: HTMLElement, firstRootNode: HTMLElement | null, viewContext: SlateViewContext): void;
|