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
package/module.d.ts
CHANGED
|
@@ -7,14 +7,15 @@ import * as i5 from "./components/text/void-text.component";
|
|
|
7
7
|
import * as i6 from "./components/text/default-text.component";
|
|
8
8
|
import * as i7 from "./components/string/string.component";
|
|
9
9
|
import * as i8 from "./components/string/template.component";
|
|
10
|
-
import * as i9 from "./components/
|
|
11
|
-
import * as i10 from "./components/
|
|
12
|
-
import * as i11 from "./components/
|
|
13
|
-
import * as i12 from "./components/leaf/
|
|
14
|
-
import * as i13 from "./components/
|
|
15
|
-
import * as i14 from "./components/
|
|
10
|
+
import * as i9 from "./components/descendant/descendant.component";
|
|
11
|
+
import * as i10 from "./components/children/children.component";
|
|
12
|
+
import * as i11 from "./components/block-card/block-card.component";
|
|
13
|
+
import * as i12 from "./components/leaf/leaf.component";
|
|
14
|
+
import * as i13 from "./components/leaves/leaves.component";
|
|
15
|
+
import * as i14 from "./components/leaf/default-leaf.component";
|
|
16
|
+
import * as i15 from "./components/string/default-string.component";
|
|
16
17
|
export declare class SlateModule {
|
|
17
18
|
static ɵfac: i0.ɵɵFactoryDeclaration<SlateModule, never>;
|
|
18
|
-
static ɵmod: i0.ɵɵNgModuleDeclaration<SlateModule, never, [typeof i1.CommonModule, typeof i2.SlateEditable, typeof i3.SlateDefaultElement, typeof i4.SlateElement, typeof i5.SlateVoidText, typeof i6.SlateDefaultText, typeof i7.SlateString, typeof i8.SlateStringTemplate, typeof i9.
|
|
19
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<SlateModule, never, [typeof i1.CommonModule, typeof i2.SlateEditable, typeof i3.SlateDefaultElement, typeof i4.SlateElement, typeof i5.SlateVoidText, typeof i6.SlateDefaultText, typeof i7.SlateString, typeof i8.SlateStringTemplate, typeof i9.SlateDescendant, typeof i10.SlateChildren, typeof i11.SlateBlockCard, typeof i12.SlateLeaf, typeof i13.SlateLeaves, typeof i14.SlateDefaultLeaf, typeof i15.SlateDefaultString], [typeof i2.SlateEditable, typeof i10.SlateChildren, typeof i4.SlateElement, typeof i13.SlateLeaves, typeof i7.SlateString, typeof i15.SlateDefaultString]>;
|
|
19
20
|
static ɵinj: i0.ɵɵInjectorDeclaration<SlateModule>;
|
|
20
21
|
}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "slate-angular",
|
|
3
|
-
"version": "
|
|
3
|
+
"version": "17.0.0-next.0",
|
|
4
4
|
"description": "Angular view layer for Slate",
|
|
5
5
|
"author": "pubuzhixing <pubuzhixing@gmail.com>",
|
|
6
6
|
"homepage": "https://github.com/worktile/slate-angular#readme",
|
|
@@ -14,12 +14,12 @@
|
|
|
14
14
|
"scroll-into-view-if-needed": "^2.2.20"
|
|
15
15
|
},
|
|
16
16
|
"dependencies": {
|
|
17
|
-
"slate": "^0.
|
|
18
|
-
"slate-history": "^0.
|
|
17
|
+
"slate": "^0.72.8",
|
|
18
|
+
"slate-history": "^0.66.0",
|
|
19
19
|
"direction": "^2.0.1",
|
|
20
20
|
"is-hotkey": "^0.2.0",
|
|
21
|
-
"scroll-into-view-if-needed": "^
|
|
22
|
-
"tslib": "^2.
|
|
21
|
+
"scroll-into-view-if-needed": "^2.2.20",
|
|
22
|
+
"tslib": "^2.5.0"
|
|
23
23
|
},
|
|
24
24
|
"exports": {
|
|
25
25
|
".": {
|
|
@@ -132,7 +132,7 @@ export declare const AngularEditor: {
|
|
|
132
132
|
getCardCursorNode(editor: AngularEditor, blockCardNode: Node, options: {
|
|
133
133
|
direction: 'left' | 'right' | 'center';
|
|
134
134
|
}): ChildNode;
|
|
135
|
-
toSlateCardEntry(editor: AngularEditor, node: DOMNode): NodeEntry
|
|
135
|
+
toSlateCardEntry(editor: AngularEditor, node: DOMNode): NodeEntry<Node>;
|
|
136
136
|
/**
|
|
137
137
|
* move native selection to card-left or card-right
|
|
138
138
|
* @param editor
|
package/public-api.d.ts
CHANGED
|
@@ -5,12 +5,11 @@ export * from './components/element/element.component';
|
|
|
5
5
|
export * from './components/string/string.component';
|
|
6
6
|
export * from './components/string/default-string.component';
|
|
7
7
|
export * from './components/children/children.component';
|
|
8
|
-
export * from './components/children/children-outlet.component';
|
|
9
8
|
export * from './components/leaves/leaves.component';
|
|
10
9
|
export * from './module';
|
|
11
10
|
export * from './types/error';
|
|
12
11
|
export * from './view/base';
|
|
13
12
|
export * from './view/context';
|
|
14
|
-
export * from './view/context-change';
|
|
13
|
+
export * from './view/before-context-change';
|
|
15
14
|
export * from './utils';
|
|
16
15
|
export * from './types';
|
package/utils/index.d.ts
CHANGED
package/view/base.d.ts
CHANGED
|
@@ -1,11 +1,8 @@
|
|
|
1
|
-
import { ChangeDetectorRef, ElementRef, OnDestroy, OnInit
|
|
1
|
+
import { ChangeDetectorRef, ElementRef, OnDestroy, OnInit } from '@angular/core';
|
|
2
2
|
import { AngularEditor } from '../plugins/angular-editor';
|
|
3
3
|
import { SlateViewContext, SlateElementContext, SlateTextContext, SlateLeafContext } from './context';
|
|
4
4
|
import { Descendant, Element, Range, Text } from 'slate';
|
|
5
5
|
import { SlateChildrenContext } from './context';
|
|
6
|
-
import { ListRender } from './render/list-render';
|
|
7
|
-
import { LeavesRender } from './render/leaves-render';
|
|
8
|
-
import { SlateChildrenOutlet } from '../components/children/children-outlet.component';
|
|
9
6
|
import * as i0 from "@angular/core";
|
|
10
7
|
/**
|
|
11
8
|
* base class for template
|
|
@@ -20,7 +17,6 @@ export interface BaseEmbeddedView<T, K extends AngularEditor = AngularEditor> {
|
|
|
20
17
|
export declare abstract class BaseComponent<T = SlateTextContext | SlateLeafContext | SlateElementContext, K extends AngularEditor = AngularEditor> {
|
|
21
18
|
elementRef: ElementRef;
|
|
22
19
|
cdr: ChangeDetectorRef;
|
|
23
|
-
initialized: boolean;
|
|
24
20
|
protected _context: T;
|
|
25
21
|
set context(value: T);
|
|
26
22
|
get context(): T;
|
|
@@ -36,6 +32,7 @@ export declare abstract class BaseComponent<T = SlateTextContext | SlateLeafCont
|
|
|
36
32
|
* base class for custom leaf component
|
|
37
33
|
*/
|
|
38
34
|
export declare class BaseLeafComponent extends BaseComponent<SlateLeafContext> implements OnInit {
|
|
35
|
+
initialized: boolean;
|
|
39
36
|
placeholderElement: HTMLSpanElement;
|
|
40
37
|
isSlateLeaf: boolean;
|
|
41
38
|
get text(): Text;
|
|
@@ -53,9 +50,8 @@ export declare class BaseLeafComponent extends BaseComponent<SlateLeafContext> i
|
|
|
53
50
|
* base class for custom element component
|
|
54
51
|
*/
|
|
55
52
|
export declare class BaseElementComponent<T extends Element = Element, K extends AngularEditor = AngularEditor> extends BaseComponent<SlateElementContext<T>, K> implements OnInit, OnDestroy {
|
|
56
|
-
|
|
53
|
+
initialized: boolean;
|
|
57
54
|
childrenContext: SlateChildrenContext;
|
|
58
|
-
childrenOutletInstance?: SlateChildrenOutlet;
|
|
59
55
|
get element(): T;
|
|
60
56
|
get selection(): Range;
|
|
61
57
|
get decorations(): Range[];
|
|
@@ -63,9 +59,6 @@ export declare class BaseElementComponent<T extends Element = Element, K extends
|
|
|
63
59
|
get isCollapsed(): boolean;
|
|
64
60
|
get isCollapsedAndNonReadonly(): boolean;
|
|
65
61
|
get readonly(): boolean;
|
|
66
|
-
getOutletParent: () => any;
|
|
67
|
-
getOutletElement: () => HTMLElement;
|
|
68
|
-
listRender: ListRender;
|
|
69
62
|
ngOnInit(): void;
|
|
70
63
|
updateWeakMap(): void;
|
|
71
64
|
ngOnDestroy(): void;
|
|
@@ -78,12 +71,8 @@ export declare class BaseElementComponent<T extends Element = Element, K extends
|
|
|
78
71
|
* base class for custom text component
|
|
79
72
|
*/
|
|
80
73
|
export declare class BaseTextComponent<T extends Text = Text> extends BaseComponent<SlateTextContext<T>> implements OnInit, OnDestroy {
|
|
81
|
-
|
|
74
|
+
initialized: boolean;
|
|
82
75
|
get text(): T;
|
|
83
|
-
leavesRender: LeavesRender;
|
|
84
|
-
childrenOutletInstance?: SlateChildrenOutlet;
|
|
85
|
-
getOutletParent: () => any;
|
|
86
|
-
getOutletElement: () => HTMLElement;
|
|
87
76
|
ngOnInit(): void;
|
|
88
77
|
updateWeakMap(): void;
|
|
89
78
|
ngOnDestroy(): void;
|
|
@@ -1,8 +1,4 @@
|
|
|
1
1
|
export interface BeforeContextChange<T> {
|
|
2
2
|
beforeContextChange: (value: T) => void;
|
|
3
3
|
}
|
|
4
|
-
export interface AfterContextChange {
|
|
5
|
-
afterContextChange: () => void;
|
|
6
|
-
}
|
|
7
4
|
export declare function hasBeforeContextChange<T>(value: any): value is BeforeContextChange<T>;
|
|
8
|
-
export declare function hasAfterContextChange<T>(value: any): value is AfterContextChange;
|
package/view/container.d.ts
CHANGED
|
@@ -1,18 +1,22 @@
|
|
|
1
|
-
import { ElementRef, IterableDiffers } from '@angular/core';
|
|
1
|
+
import { AfterViewInit, ElementRef, IterableChangeRecord, IterableDiffers, QueryList } from '@angular/core';
|
|
2
2
|
import { SlateViewContext } from './context';
|
|
3
3
|
import { ViewContainerItem } from './container-item';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
/**
|
|
6
|
-
* @deprecated
|
|
7
6
|
* the special container for angular template
|
|
8
7
|
* Add the rootNodes of each child component to the parentElement
|
|
9
8
|
* Remove useless DOM elements, eg: comment...
|
|
10
9
|
*/
|
|
11
|
-
export declare abstract class ViewContainer<T extends ViewContainerItem> {
|
|
10
|
+
export declare abstract class ViewContainer<T extends ViewContainerItem> implements AfterViewInit {
|
|
12
11
|
protected elementRef: ElementRef<any>;
|
|
13
12
|
protected differs: IterableDiffers;
|
|
13
|
+
abstract childrenComponent: QueryList<T>;
|
|
14
14
|
viewContext: SlateViewContext;
|
|
15
15
|
constructor(elementRef: ElementRef<any>, differs: IterableDiffers);
|
|
16
|
+
ngAfterViewInit(): void;
|
|
17
|
+
getPreviousRootNode(currentIndex: any): any;
|
|
18
|
+
createFragment(): DocumentFragment;
|
|
19
|
+
handleContainerItemChange(record: IterableChangeRecord<T>, parentElement: HTMLElement): void;
|
|
16
20
|
static ɵfac: i0.ɵɵFactoryDeclaration<ViewContainer<any>, never>;
|
|
17
21
|
static ɵdir: i0.ɵɵDirectiveDeclaration<ViewContainer<any>, never, never, { "viewContext": { "alias": "viewContext"; "required": false; }; }, {}, never, never, false, never>;
|
|
18
22
|
}
|
package/view/context.d.ts
CHANGED
|
@@ -1,15 +1,10 @@
|
|
|
1
1
|
import { NodeEntry, Range, Element, Ancestor, Text } from 'slate';
|
|
2
2
|
import { SlateStringTemplate } from '../components/string/template.component';
|
|
3
3
|
import { AngularEditor } from '../plugins/angular-editor';
|
|
4
|
-
import {
|
|
5
|
-
import { BaseElementComponent, BaseLeafComponent, BaseTextComponent } from './base';
|
|
4
|
+
import { ViewType } from '../types/view';
|
|
6
5
|
export interface SlateViewContext<T extends AngularEditor = AngularEditor> {
|
|
7
6
|
editor: T;
|
|
8
7
|
templateComponent: SlateStringTemplate;
|
|
9
|
-
defaultElement: ComponentType<BaseElementComponent>;
|
|
10
|
-
defaultText: ComponentType<BaseTextComponent>;
|
|
11
|
-
defaultVoidText: ComponentType<BaseTextComponent>;
|
|
12
|
-
defaultLeaf: ComponentType<BaseLeafComponent>;
|
|
13
8
|
trackBy: (element: Element) => any;
|
|
14
9
|
renderElement?: (element: Element) => ViewType;
|
|
15
10
|
renderLeaf?: (text: Text) => ViewType;
|
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
import { ElementRef } from '@angular/core';
|
|
2
|
-
import * as i0 from "@angular/core";
|
|
3
|
-
export declare class SlateChildrenOutlet {
|
|
4
|
-
private elementRef;
|
|
5
|
-
constructor(elementRef: ElementRef<HTMLElement>);
|
|
6
|
-
getNativeElement(): HTMLElement;
|
|
7
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<SlateChildrenOutlet, never>;
|
|
8
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<SlateChildrenOutlet, "slate-children-outlet", never, {}, {}, never, never, true, never>;
|
|
9
|
-
}
|
|
@@ -1,5 +0,0 @@
|
|
|
1
|
-
import { InjectionToken } from '@angular/core';
|
|
2
|
-
import { ComponentType } from '../../types/view';
|
|
3
|
-
import { BaseTextComponent } from '../../view/base';
|
|
4
|
-
export declare const SLATE_DEFAULT_TEXT_COMPONENT_TOKEN: InjectionToken<ComponentType<BaseTextComponent<import("slate").BaseText>>>;
|
|
5
|
-
export declare const SLATE_DEFAULT_VOID_TEXT_COMPONENT_TOKEN: InjectionToken<ComponentType<BaseTextComponent<import("slate").BaseText>>>;
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component } from '@angular/core';
|
|
2
|
-
import * as i0 from "@angular/core";
|
|
3
|
-
export class SlateChildrenOutlet {
|
|
4
|
-
constructor(elementRef) {
|
|
5
|
-
this.elementRef = elementRef;
|
|
6
|
-
}
|
|
7
|
-
getNativeElement() {
|
|
8
|
-
return this.elementRef.nativeElement;
|
|
9
|
-
}
|
|
10
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: SlateChildrenOutlet, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
11
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.1", type: SlateChildrenOutlet, isStandalone: true, selector: "slate-children-outlet", ngImport: i0, template: ``, isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
12
|
-
}
|
|
13
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: SlateChildrenOutlet, decorators: [{
|
|
14
|
-
type: Component,
|
|
15
|
-
args: [{
|
|
16
|
-
selector: 'slate-children-outlet',
|
|
17
|
-
template: ``,
|
|
18
|
-
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
19
|
-
standalone: true
|
|
20
|
-
}]
|
|
21
|
-
}], ctorParameters: function () { return [{ type: i0.ElementRef }]; } });
|
|
22
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hpbGRyZW4tb3V0bGV0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL3NyYy9jb21wb25lbnRzL2NoaWxkcmVuL2NoaWxkcmVuLW91dGxldC5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBYyxNQUFNLGVBQWUsQ0FBQzs7QUFRL0UsTUFBTSxPQUFPLG1CQUFtQjtJQUM1QixZQUFvQixVQUFtQztRQUFuQyxlQUFVLEdBQVYsVUFBVSxDQUF5QjtJQUFHLENBQUM7SUFDM0QsZ0JBQWdCO1FBQ1osT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDLGFBQWEsQ0FBQztJQUN6QyxDQUFDOzhHQUpRLG1CQUFtQjtrR0FBbkIsbUJBQW1CLGlGQUpsQixFQUFFOzsyRkFJSCxtQkFBbUI7a0JBTi9CLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLHVCQUF1QjtvQkFDakMsUUFBUSxFQUFFLEVBQUU7b0JBQ1osZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07b0JBQy9DLFVBQVUsRUFBRSxJQUFJO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIEVsZW1lbnRSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdzbGF0ZS1jaGlsZHJlbi1vdXRsZXQnLFxuICAgIHRlbXBsYXRlOiBgYCxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgICBzdGFuZGFsb25lOiB0cnVlXG59KVxuZXhwb3J0IGNsYXNzIFNsYXRlQ2hpbGRyZW5PdXRsZXQge1xuICAgIGNvbnN0cnVjdG9yKHByaXZhdGUgZWxlbWVudFJlZjogRWxlbWVudFJlZjxIVE1MRWxlbWVudD4pIHt9XG4gICAgZ2V0TmF0aXZlRWxlbWVudCgpIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50O1xuICAgIH1cbn1cbiJdfQ==
|
|
@@ -1,3 +0,0 @@
|
|
|
1
|
-
import { InjectionToken } from '@angular/core';
|
|
2
|
-
export const SLATE_DEFAULT_LEAF_COMPONENT_TOKEN = new InjectionToken('slate-default-leaf-token');
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9rZW4uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9zcmMvY29tcG9uZW50cy9sZWFmL3Rva2VuLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFJL0MsTUFBTSxDQUFDLE1BQU0sa0NBQWtDLEdBQUcsSUFBSSxjQUFjLENBQW1DLDBCQUEwQixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3Rpb25Ub2tlbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tcG9uZW50VHlwZSB9IGZyb20gJy4uLy4uL3R5cGVzL3ZpZXcnO1xuaW1wb3J0IHsgQmFzZUxlYWZDb21wb25lbnQgfSBmcm9tICcuLi8uLi92aWV3L2Jhc2UnO1xuXG5leHBvcnQgY29uc3QgU0xBVEVfREVGQVVMVF9MRUFGX0NPTVBPTkVOVF9UT0tFTiA9IG5ldyBJbmplY3Rpb25Ub2tlbjxDb21wb25lbnRUeXBlPEJhc2VMZWFmQ29tcG9uZW50Pj4oJ3NsYXRlLWRlZmF1bHQtbGVhZi10b2tlbicpO1xuIl19
|
|
@@ -1,4 +0,0 @@
|
|
|
1
|
-
import { InjectionToken } from '@angular/core';
|
|
2
|
-
export const SLATE_DEFAULT_TEXT_COMPONENT_TOKEN = new InjectionToken('slate-default-text-token');
|
|
3
|
-
export const SLATE_DEFAULT_VOID_TEXT_COMPONENT_TOKEN = new InjectionToken('slate-default-void-text-token');
|
|
4
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9rZW4uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9zcmMvY29tcG9uZW50cy90ZXh0L3Rva2VuLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFJL0MsTUFBTSxDQUFDLE1BQU0sa0NBQWtDLEdBQUcsSUFBSSxjQUFjLENBQW1DLDBCQUEwQixDQUFDLENBQUM7QUFFbkksTUFBTSxDQUFDLE1BQU0sdUNBQXVDLEdBQUcsSUFBSSxjQUFjLENBQ3JFLCtCQUErQixDQUNsQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0aW9uVG9rZW4gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbXBvbmVudFR5cGUgfSBmcm9tICcuLi8uLi90eXBlcy92aWV3JztcbmltcG9ydCB7IEJhc2VUZXh0Q29tcG9uZW50IH0gZnJvbSAnLi4vLi4vdmlldy9iYXNlJztcblxuZXhwb3J0IGNvbnN0IFNMQVRFX0RFRkFVTFRfVEVYVF9DT01QT05FTlRfVE9LRU4gPSBuZXcgSW5qZWN0aW9uVG9rZW48Q29tcG9uZW50VHlwZTxCYXNlVGV4dENvbXBvbmVudD4+KCdzbGF0ZS1kZWZhdWx0LXRleHQtdG9rZW4nKTtcblxuZXhwb3J0IGNvbnN0IFNMQVRFX0RFRkFVTFRfVk9JRF9URVhUX0NPTVBPTkVOVF9UT0tFTiA9IG5ldyBJbmplY3Rpb25Ub2tlbjxDb21wb25lbnRUeXBlPEJhc2VUZXh0Q29tcG9uZW50Pj4oXG4gICAgJ3NsYXRlLWRlZmF1bHQtdm9pZC10ZXh0LXRva2VuJ1xuKTtcbiJdfQ==
|
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
export const createThrottleRAF = () => {
|
|
2
|
-
let timerId = null;
|
|
3
|
-
const throttleRAF = (fn) => {
|
|
4
|
-
const scheduleFunc = () => {
|
|
5
|
-
timerId = requestAnimationFrame(() => {
|
|
6
|
-
timerId = null;
|
|
7
|
-
fn();
|
|
8
|
-
});
|
|
9
|
-
};
|
|
10
|
-
if (timerId !== null) {
|
|
11
|
-
cancelAnimationFrame(timerId);
|
|
12
|
-
timerId = null;
|
|
13
|
-
}
|
|
14
|
-
scheduleFunc();
|
|
15
|
-
};
|
|
16
|
-
return throttleRAF;
|
|
17
|
-
};
|
|
18
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGhyb3R0bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9wYWNrYWdlcy9zcmMvdXRpbHMvdGhyb3R0bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFDLE1BQU0saUJBQWlCLEdBQUcsR0FBRyxFQUFFO0lBQ2xDLElBQUksT0FBTyxHQUFrQixJQUFJLENBQUM7SUFDbEMsTUFBTSxXQUFXLEdBQUcsQ0FBQyxFQUFjLEVBQUUsRUFBRTtRQUNuQyxNQUFNLFlBQVksR0FBRyxHQUFHLEVBQUU7WUFDdEIsT0FBTyxHQUFHLHFCQUFxQixDQUFDLEdBQUcsRUFBRTtnQkFDakMsT0FBTyxHQUFHLElBQUksQ0FBQztnQkFDZixFQUFFLEVBQUUsQ0FBQztZQUNULENBQUMsQ0FBQyxDQUFDO1FBQ1AsQ0FBQyxDQUFDO1FBQ0YsSUFBSSxPQUFPLEtBQUssSUFBSSxFQUFFO1lBQ2xCLG9CQUFvQixDQUFDLE9BQU8sQ0FBQyxDQUFDO1lBQzlCLE9BQU8sR0FBRyxJQUFJLENBQUM7U0FDbEI7UUFDRCxZQUFZLEVBQUUsQ0FBQztJQUNuQixDQUFDLENBQUM7SUFDRixPQUFPLFdBQVcsQ0FBQztBQUN2QixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgY3JlYXRlVGhyb3R0bGVSQUYgPSAoKSA9PiB7XG4gICAgbGV0IHRpbWVySWQ6IG51bWJlciB8IG51bGwgPSBudWxsO1xuICAgIGNvbnN0IHRocm90dGxlUkFGID0gKGZuOiAoKSA9PiB2b2lkKSA9PiB7XG4gICAgICAgIGNvbnN0IHNjaGVkdWxlRnVuYyA9ICgpID0+IHtcbiAgICAgICAgICAgIHRpbWVySWQgPSByZXF1ZXN0QW5pbWF0aW9uRnJhbWUoKCkgPT4ge1xuICAgICAgICAgICAgICAgIHRpbWVySWQgPSBudWxsO1xuICAgICAgICAgICAgICAgIGZuKCk7XG4gICAgICAgICAgICB9KTtcbiAgICAgICAgfTtcbiAgICAgICAgaWYgKHRpbWVySWQgIT09IG51bGwpIHtcbiAgICAgICAgICAgIGNhbmNlbEFuaW1hdGlvbkZyYW1lKHRpbWVySWQpO1xuICAgICAgICAgICAgdGltZXJJZCA9IG51bGw7XG4gICAgICAgIH1cbiAgICAgICAgc2NoZWR1bGVGdW5jKCk7XG4gICAgfTtcbiAgICByZXR1cm4gdGhyb3R0bGVSQUY7XG59O1xuXG5leHBvcnQgdHlwZSBUaHJvdHRsZVJBRiA9IChmbjogKCkgPT4gdm9pZCkgPT4gdm9pZDtcbiJdfQ==
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
export function hasBeforeContextChange(value) {
|
|
2
|
-
if (value.beforeContextChange) {
|
|
3
|
-
return true;
|
|
4
|
-
}
|
|
5
|
-
return false;
|
|
6
|
-
}
|
|
7
|
-
export function hasAfterContextChange(value) {
|
|
8
|
-
if (value.afterContextChange) {
|
|
9
|
-
return true;
|
|
10
|
-
}
|
|
11
|
-
return false;
|
|
12
|
-
}
|
|
13
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGV4dC1jaGFuZ2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9wYWNrYWdlcy9zcmMvdmlldy9jb250ZXh0LWNoYW5nZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFRQSxNQUFNLFVBQVUsc0JBQXNCLENBQUksS0FBSztJQUMzQyxJQUFJLEtBQUssQ0FBQyxtQkFBbUIsRUFBRTtRQUMzQixPQUFPLElBQUksQ0FBQztLQUNmO0lBQ0QsT0FBTyxLQUFLLENBQUM7QUFDakIsQ0FBQztBQUVELE1BQU0sVUFBVSxxQkFBcUIsQ0FBSSxLQUFLO0lBQzFDLElBQUksS0FBSyxDQUFDLGtCQUFrQixFQUFFO1FBQzFCLE9BQU8sSUFBSSxDQUFDO0tBQ2Y7SUFDRCxPQUFPLEtBQUssQ0FBQztBQUNqQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBCZWZvcmVDb250ZXh0Q2hhbmdlPFQ+IHtcbiAgICBiZWZvcmVDb250ZXh0Q2hhbmdlOiAodmFsdWU6IFQpID0+IHZvaWQ7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQWZ0ZXJDb250ZXh0Q2hhbmdlPD4ge1xuICAgIGFmdGVyQ29udGV4dENoYW5nZTogKCkgPT4gdm9pZDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGhhc0JlZm9yZUNvbnRleHRDaGFuZ2U8VD4odmFsdWUpOiB2YWx1ZSBpcyBCZWZvcmVDb250ZXh0Q2hhbmdlPFQ+IHtcbiAgICBpZiAodmFsdWUuYmVmb3JlQ29udGV4dENoYW5nZSkge1xuICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICB9XG4gICAgcmV0dXJuIGZhbHNlO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gaGFzQWZ0ZXJDb250ZXh0Q2hhbmdlPFQ+KHZhbHVlKTogdmFsdWUgaXMgQWZ0ZXJDb250ZXh0Q2hhbmdlIHtcbiAgICBpZiAodmFsdWUuYWZ0ZXJDb250ZXh0Q2hhbmdlKSB7XG4gICAgICAgIHJldHVybiB0cnVlO1xuICAgIH1cbiAgICByZXR1cm4gZmFsc2U7XG59XG4iXX0=
|
|
@@ -1,107 +0,0 @@
|
|
|
1
|
-
import { Text } from 'slate';
|
|
2
|
-
import { IterableDiffers } from '@angular/core';
|
|
3
|
-
import { createEmbeddedViewOrComponent, getRootNodes, mount, mountOnItemChange, updateContext } from './utils';
|
|
4
|
-
export class LeavesRender {
|
|
5
|
-
constructor(viewContext, viewContainerRef, getOutletParent, getOutletElement) {
|
|
6
|
-
this.viewContext = viewContext;
|
|
7
|
-
this.viewContainerRef = viewContainerRef;
|
|
8
|
-
this.getOutletParent = getOutletParent;
|
|
9
|
-
this.getOutletElement = getOutletElement;
|
|
10
|
-
this.views = [];
|
|
11
|
-
this.contexts = [];
|
|
12
|
-
this.viewTypes = [];
|
|
13
|
-
}
|
|
14
|
-
initialize(context) {
|
|
15
|
-
const { leaves, contexts } = this.getLeaves(context);
|
|
16
|
-
this.leaves = leaves;
|
|
17
|
-
this.contexts = contexts;
|
|
18
|
-
this.leaves.forEach((leaf, index) => {
|
|
19
|
-
const context = getContext(index, this.contexts);
|
|
20
|
-
const viewType = getViewType(context, this.viewContext);
|
|
21
|
-
const view = createEmbeddedViewOrComponent(viewType, context, this.viewContext, this.viewContainerRef);
|
|
22
|
-
this.views.push(view);
|
|
23
|
-
this.contexts.push(context);
|
|
24
|
-
this.viewTypes.push(viewType);
|
|
25
|
-
});
|
|
26
|
-
mount(this.views, null, this.getOutletParent(), this.getOutletElement());
|
|
27
|
-
const newDiffers = this.viewContainerRef.injector.get(IterableDiffers);
|
|
28
|
-
this.differ = newDiffers.find(this.leaves).create(trackBy(this.viewContext));
|
|
29
|
-
this.differ.diff(this.leaves);
|
|
30
|
-
}
|
|
31
|
-
update(context) {
|
|
32
|
-
const { leaves, contexts } = this.getLeaves(context);
|
|
33
|
-
const outletParent = this.getOutletParent();
|
|
34
|
-
const diffResult = this.differ.diff(leaves);
|
|
35
|
-
if (diffResult) {
|
|
36
|
-
let firstRootNode = getRootNodes(this.views[0])[0];
|
|
37
|
-
const newContexts = [];
|
|
38
|
-
const newViewTypes = [];
|
|
39
|
-
const newViews = [];
|
|
40
|
-
diffResult.forEachItem(record => {
|
|
41
|
-
let context = getContext(record.currentIndex, contexts);
|
|
42
|
-
const viewType = getViewType(context, this.viewContext);
|
|
43
|
-
newViewTypes.push(viewType);
|
|
44
|
-
let view;
|
|
45
|
-
if (record.previousIndex === null) {
|
|
46
|
-
view = createEmbeddedViewOrComponent(viewType, context, this.viewContext, this.viewContainerRef);
|
|
47
|
-
newContexts.push(context);
|
|
48
|
-
newViews.push(view);
|
|
49
|
-
mountOnItemChange(record.currentIndex, record.item, newViews, null, outletParent, firstRootNode, this.viewContext);
|
|
50
|
-
}
|
|
51
|
-
else {
|
|
52
|
-
const previousView = this.views[record.previousIndex];
|
|
53
|
-
const previousViewType = this.viewTypes[record.previousIndex];
|
|
54
|
-
if (previousViewType !== viewType) {
|
|
55
|
-
view = createEmbeddedViewOrComponent(viewType, context, this.viewContext, this.viewContainerRef);
|
|
56
|
-
const firstRootNode = getRootNodes(previousView, null)[0];
|
|
57
|
-
const newRootNodes = getRootNodes(view, null);
|
|
58
|
-
firstRootNode.replaceWith(...newRootNodes);
|
|
59
|
-
previousView.destroy();
|
|
60
|
-
}
|
|
61
|
-
else {
|
|
62
|
-
view = previousView;
|
|
63
|
-
updateContext(previousView, context, this.viewContext);
|
|
64
|
-
}
|
|
65
|
-
newContexts.push(context);
|
|
66
|
-
newViews.push(view);
|
|
67
|
-
}
|
|
68
|
-
});
|
|
69
|
-
diffResult.forEachRemovedItem(record => {
|
|
70
|
-
const view = this.views[record.previousIndex];
|
|
71
|
-
view.destroy();
|
|
72
|
-
});
|
|
73
|
-
diffResult.forEachMovedItem(record => {
|
|
74
|
-
mountOnItemChange(record.currentIndex, record.item, newViews, null, outletParent, firstRootNode, this.viewContext);
|
|
75
|
-
});
|
|
76
|
-
this.viewTypes = newViewTypes;
|
|
77
|
-
this.views = newViews;
|
|
78
|
-
this.contexts = newContexts;
|
|
79
|
-
this.leaves = leaves;
|
|
80
|
-
}
|
|
81
|
-
}
|
|
82
|
-
getLeaves(context) {
|
|
83
|
-
const leaves = Text.decorations(context.text, context.decorations);
|
|
84
|
-
const contexts = leaves.map((leaf, index) => {
|
|
85
|
-
return {
|
|
86
|
-
leaf,
|
|
87
|
-
text: context.text,
|
|
88
|
-
parent: context.parent,
|
|
89
|
-
index,
|
|
90
|
-
isLast: context.isLast && index === leaves.length - 1
|
|
91
|
-
};
|
|
92
|
-
});
|
|
93
|
-
return { leaves, contexts };
|
|
94
|
-
}
|
|
95
|
-
}
|
|
96
|
-
export function getContext(index, leafContexts) {
|
|
97
|
-
return leafContexts[index];
|
|
98
|
-
}
|
|
99
|
-
export function getViewType(leafContext, viewContext) {
|
|
100
|
-
return (viewContext.renderLeaf && viewContext.renderLeaf(leafContext.leaf)) || viewContext.defaultLeaf;
|
|
101
|
-
}
|
|
102
|
-
export function trackBy(viewContext) {
|
|
103
|
-
return (index, node) => {
|
|
104
|
-
return index;
|
|
105
|
-
};
|
|
106
|
-
}
|
|
107
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"leaves-render.js","sourceRoot":"","sources":["../../../../packages/src/view/render/leaves-render.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,OAAO,CAAC;AAC7B,OAAO,EAAiD,eAAe,EAAoB,MAAM,eAAe,CAAC;AAGjH,OAAO,EAAE,6BAA6B,EAAE,YAAY,EAAE,KAAK,EAAE,iBAAiB,EAAE,aAAa,EAAE,MAAM,SAAS,CAAC;AAE/G,MAAM,OAAO,YAAY;IAOrB,YACY,WAA6B,EAC7B,gBAAkC,EAClC,eAAkC,EAClC,gBAAmC;QAHnC,gBAAW,GAAX,WAAW,CAAkB;QAC7B,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,oBAAe,GAAf,eAAe,CAAmB;QAClC,qBAAgB,GAAhB,gBAAgB,CAAmB;QATvC,UAAK,GAAiD,EAAE,CAAC;QACzD,aAAQ,GAAuB,EAAE,CAAC;QAClC,cAAS,GAAe,EAAE,CAAC;IAQhC,CAAC;IAEG,UAAU,CAAC,OAAyB;QACvC,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;QACrD,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE;YAChC,MAAM,OAAO,GAAG,UAAU,CAAC,KAAK,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;YACjD,MAAM,QAAQ,GAAG,WAAW,CAAC,OAAO,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;YACxD,MAAM,IAAI,GAAG,6BAA6B,CAAC,QAAQ,EAAE,OAAO,EAAE,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,gBAAgB,CAAC,CAAC;YACvG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YACtB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YAC5B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAClC,CAAC,CAAC,CAAC;QACH,KAAK,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,EAAE,IAAI,CAAC,eAAe,EAAE,EAAE,IAAI,CAAC,gBAAgB,EAAE,CAAC,CAAC;QACzE,MAAM,UAAU,GAAG,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,GAAG,CAAC,eAAe,CAAC,CAAC;QACvE,IAAI,CAAC,MAAM,GAAG,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC;QAC7E,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAClC,CAAC;IAEM,MAAM,CAAC,OAAyB;QACnC,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;QACrD,MAAM,YAAY,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;QAC5C,MAAM,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAC5C,IAAI,UAAU,EAAE;YACZ,IAAI,aAAa,GAAG,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YACnD,MAAM,WAAW,GAAG,EAAE,CAAC;YACvB,MAAM,YAAY,GAAG,EAAE,CAAC;YACxB,MAAM,QAAQ,GAAG,EAAE,CAAC;YACpB,UAAU,CAAC,WAAW,CAAC,MAAM,CAAC,EAAE;gBAC5B,IAAI,OAAO,GAAG,UAAU,CAAC,MAAM,CAAC,YAAY,EAAE,QAAQ,CAAC,CAAC;gBACxD,MAAM,QAAQ,GAAG,WAAW,CAAC,OAAO,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;gBACxD,YAAY,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;gBAC5B,IAAI,IAA8C,CAAC;gBACnD,IAAI,MAAM,CAAC,aAAa,KAAK,IAAI,EAAE;oBAC/B,IAAI,GAAG,6BAA6B,CAAC,QAAQ,EAAE,OAAO,EAAE,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,gBAAgB,CAAC,CAAC;oBACjG,WAAW,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;oBAC1B,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;oBACpB,iBAAiB,CAAC,MAAM,CAAC,YAAY,EAAE,MAAM,CAAC,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,YAAY,EAAE,aAAa,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;iBACtH;qBAAM;oBACH,MAAM,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;oBACtD,MAAM,gBAAgB,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;oBAC9D,IAAI,gBAAgB,KAAK,QAAQ,EAAE;wBAC/B,IAAI,GAAG,6BAA6B,CAAC,QAAQ,EAAE,OAAO,EAAE,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,gBAAgB,CAAC,CAAC;wBACjG,MAAM,aAAa,GAAG,YAAY,CAAC,YAAY,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;wBAC1D,MAAM,YAAY,GAAG,YAAY,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;wBAC9C,aAAa,CAAC,WAAW,CAAC,GAAG,YAAY,CAAC,CAAC;wBAC3C,YAAY,CAAC,OAAO,EAAE,CAAC;qBAC1B;yBAAM;wBACH,IAAI,GAAG,YAAY,CAAC;wBACpB,aAAa,CAAC,YAAY,EAAE,OAAO,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;qBAC1D;oBACD,WAAW,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;oBAC1B,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;iBACvB;YACL,CAAC,CAAC,CAAC;YACH,UAAU,CAAC,kBAAkB,CAAC,MAAM,CAAC,EAAE;gBACnC,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;gBAC9C,IAAI,CAAC,OAAO,EAAE,CAAC;YACnB,CAAC,CAAC,CAAC;YACH,UAAU,CAAC,gBAAgB,CAAC,MAAM,CAAC,EAAE;gBACjC,iBAAiB,CAAC,MAAM,CAAC,YAAY,EAAE,MAAM,CAAC,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,YAAY,EAAE,aAAa,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;YACvH,CAAC,CAAC,CAAC;YACH,IAAI,CAAC,SAAS,GAAG,YAAY,CAAC;YAC9B,IAAI,CAAC,KAAK,GAAG,QAAQ,CAAC;YACtB,IAAI,CAAC,QAAQ,GAAG,WAAW,CAAC;YAC5B,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;SACxB;IACL,CAAC;IAEO,SAAS,CAAC,OAAyB;QACvC,MAAM,MAAM,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,IAAI,EAAE,OAAO,CAAC,WAAW,CAAC,CAAC;QACnE,MAAM,QAAQ,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE;YACxC,OAAO;gBACH,IAAI;gBACJ,IAAI,EAAE,OAAO,CAAC,IAAI;gBAClB,MAAM,EAAE,OAAO,CAAC,MAAM;gBACtB,KAAK;gBACL,MAAM,EAAE,OAAO,CAAC,MAAM,IAAI,KAAK,KAAK,MAAM,CAAC,MAAM,GAAG,CAAC;aACxD,CAAC;QACN,CAAC,CAAC,CAAC;QACH,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,CAAC;IAChC,CAAC;CACJ;AAED,MAAM,UAAU,UAAU,CAAC,KAAa,EAAE,YAAgC;IACtE,OAAO,YAAY,CAAC,KAAK,CAAC,CAAC;AAC/B,CAAC;AAED,MAAM,UAAU,WAAW,CAAC,WAA6B,EAAE,WAA6B;IACpF,OAAO,CAAC,WAAW,CAAC,UAAU,IAAI,WAAW,CAAC,UAAU,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,IAAI,WAAW,CAAC,WAAW,CAAC;AAC3G,CAAC;AAED,MAAM,UAAU,OAAO,CAAC,WAA6B;IACjD,OAAO,CAAC,KAAK,EAAE,IAAI,EAAE,EAAE;QACnB,OAAO,KAAK,CAAC;IACjB,CAAC,CAAC;AACN,CAAC","sourcesContent":["import { Text } from 'slate';\nimport { ComponentRef, EmbeddedViewRef, IterableDiffer, IterableDiffers, ViewContainerRef } from '@angular/core';\nimport { ViewType } from '../../types/view';\nimport { SlateLeafContext, SlateTextContext, SlateViewContext } from '../context';\nimport { createEmbeddedViewOrComponent, getRootNodes, mount, mountOnItemChange, updateContext } from './utils';\n\nexport class LeavesRender {\n    private leaves: Text[];\n    private views: (EmbeddedViewRef<any> | ComponentRef<any>)[] = [];\n    private contexts: SlateLeafContext[] = [];\n    private viewTypes: ViewType[] = [];\n    private differ: IterableDiffer<any>;\n\n    constructor(\n        private viewContext: SlateViewContext,\n        private viewContainerRef: ViewContainerRef,\n        private getOutletParent: () => HTMLElement,\n        private getOutletElement: () => HTMLElement\n    ) {}\n\n    public initialize(context: SlateTextContext) {\n        const { leaves, contexts } = this.getLeaves(context);\n        this.leaves = leaves;\n        this.contexts = contexts;\n        this.leaves.forEach((leaf, index) => {\n            const context = getContext(index, this.contexts);\n            const viewType = getViewType(context, this.viewContext);\n            const view = createEmbeddedViewOrComponent(viewType, context, this.viewContext, this.viewContainerRef);\n            this.views.push(view);\n            this.contexts.push(context);\n            this.viewTypes.push(viewType);\n        });\n        mount(this.views, null, this.getOutletParent(), this.getOutletElement());\n        const newDiffers = this.viewContainerRef.injector.get(IterableDiffers);\n        this.differ = newDiffers.find(this.leaves).create(trackBy(this.viewContext));\n        this.differ.diff(this.leaves);\n    }\n\n    public update(context: SlateTextContext) {\n        const { leaves, contexts } = this.getLeaves(context);\n        const outletParent = this.getOutletParent();\n        const diffResult = this.differ.diff(leaves);\n        if (diffResult) {\n            let firstRootNode = getRootNodes(this.views[0])[0];\n            const newContexts = [];\n            const newViewTypes = [];\n            const newViews = [];\n            diffResult.forEachItem(record => {\n                let context = getContext(record.currentIndex, contexts);\n                const viewType = getViewType(context, this.viewContext);\n                newViewTypes.push(viewType);\n                let view: EmbeddedViewRef<any> | ComponentRef<any>;\n                if (record.previousIndex === null) {\n                    view = createEmbeddedViewOrComponent(viewType, context, this.viewContext, this.viewContainerRef);\n                    newContexts.push(context);\n                    newViews.push(view);\n                    mountOnItemChange(record.currentIndex, record.item, newViews, null, outletParent, firstRootNode, this.viewContext);\n                } else {\n                    const previousView = this.views[record.previousIndex];\n                    const previousViewType = this.viewTypes[record.previousIndex];\n                    if (previousViewType !== viewType) {\n                        view = createEmbeddedViewOrComponent(viewType, context, this.viewContext, this.viewContainerRef);\n                        const firstRootNode = getRootNodes(previousView, null)[0];\n                        const newRootNodes = getRootNodes(view, null);\n                        firstRootNode.replaceWith(...newRootNodes);\n                        previousView.destroy();\n                    } else {\n                        view = previousView;\n                        updateContext(previousView, context, this.viewContext);\n                    }\n                    newContexts.push(context);\n                    newViews.push(view);\n                }\n            });\n            diffResult.forEachRemovedItem(record => {\n                const view = this.views[record.previousIndex];\n                view.destroy();\n            });\n            diffResult.forEachMovedItem(record => {\n                mountOnItemChange(record.currentIndex, record.item, newViews, null, outletParent, firstRootNode, this.viewContext);\n            });\n            this.viewTypes = newViewTypes;\n            this.views = newViews;\n            this.contexts = newContexts;\n            this.leaves = leaves;\n        }\n    }\n\n    private getLeaves(context: SlateTextContext) {\n        const leaves = Text.decorations(context.text, context.decorations);\n        const contexts = leaves.map((leaf, index) => {\n            return {\n                leaf,\n                text: context.text,\n                parent: context.parent,\n                index,\n                isLast: context.isLast && index === leaves.length - 1\n            };\n        });\n        return { leaves, contexts };\n    }\n}\n\nexport function getContext(index: number, leafContexts: SlateLeafContext[]): SlateLeafContext {\n    return leafContexts[index];\n}\n\nexport function getViewType(leafContext: SlateLeafContext, viewContext: SlateViewContext) {\n    return (viewContext.renderLeaf && viewContext.renderLeaf(leafContext.leaf)) || viewContext.defaultLeaf;\n}\n\nexport function trackBy(viewContext: SlateViewContext) {\n    return (index, node) => {\n        return index;\n    };\n}\n"]}
|