slate-angular 16.1.0-next.9 → 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 -129
- 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 +7 -28
- 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 +748 -1039
- 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 +2 -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/constants.mjs +0 -2
- 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 -252
- package/esm2022/view/render/utils.mjs +0 -117
- package/utils/constants.d.ts +0 -1
- 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,11 +1,16 @@
|
|
|
1
|
+
import { OnInit, QueryList } from '@angular/core';
|
|
2
|
+
import { SlateDescendant } from '../descendant/descendant.component';
|
|
1
3
|
import { Descendant } from 'slate';
|
|
2
4
|
import { SlateChildrenContext, SlateViewContext } from '../../view/context';
|
|
3
5
|
import { ViewContainer } from '../../view/container';
|
|
4
6
|
import * as i0 from "@angular/core";
|
|
5
|
-
export declare class SlateChildren extends ViewContainer<
|
|
7
|
+
export declare class SlateChildren extends ViewContainer<SlateDescendant> implements OnInit {
|
|
6
8
|
children: Descendant[];
|
|
7
9
|
context: SlateChildrenContext;
|
|
8
10
|
viewContext: SlateViewContext;
|
|
11
|
+
childrenComponent: QueryList<SlateDescendant>;
|
|
12
|
+
ngOnInit(): void;
|
|
13
|
+
trackBy: (index: any, node: any) => any;
|
|
9
14
|
static ɵfac: i0.ɵɵFactoryDeclaration<SlateChildren, never>;
|
|
10
15
|
static ɵcmp: i0.ɵɵComponentDeclaration<SlateChildren, "slate-children", never, { "children": { "alias": "children"; "required": false; }; "context": { "alias": "context"; "required": false; }; "viewContext": { "alias": "viewContext"; "required": false; }; }, {}, never, never, true, never>;
|
|
11
16
|
}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { OnChanges, OnInit, ViewContainerRef } from '@angular/core';
|
|
2
|
+
import { ViewContainerItem } from '../../view/container-item';
|
|
3
|
+
import { Descendant, Range } from 'slate';
|
|
4
|
+
import { SlateChildrenContext, SlateElementContext, SlateTextContext, SlateViewContext } from '../../view/context';
|
|
5
|
+
import { BaseElementComponent, BaseTextComponent } from '../../view/base';
|
|
6
|
+
import { ComponentType, ViewType } from '../../types/view';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
export declare class SlateDescendant extends ViewContainerItem<SlateElementContext | SlateTextContext, BaseElementComponent | BaseTextComponent> implements OnInit, OnChanges {
|
|
9
|
+
protected viewContainerRef: ViewContainerRef;
|
|
10
|
+
defaultElementComponentType: ComponentType<BaseElementComponent>;
|
|
11
|
+
descendant: Descendant;
|
|
12
|
+
context: SlateChildrenContext;
|
|
13
|
+
viewContext: SlateViewContext;
|
|
14
|
+
index: number;
|
|
15
|
+
get rootNodes(): HTMLElement[];
|
|
16
|
+
get isBlockCard(): boolean;
|
|
17
|
+
constructor(viewContainerRef: ViewContainerRef, defaultElementComponentType: ComponentType<BaseElementComponent>);
|
|
18
|
+
ngOnInit(): void;
|
|
19
|
+
destroyView(): void;
|
|
20
|
+
ngOnChanges(): void;
|
|
21
|
+
destroyBlockCard(): void;
|
|
22
|
+
createBlockCard(): void;
|
|
23
|
+
updateBlockCard(): void;
|
|
24
|
+
getCommonContext(): {
|
|
25
|
+
selection: Range;
|
|
26
|
+
decorations: Range[];
|
|
27
|
+
};
|
|
28
|
+
getContext(): SlateElementContext | SlateTextContext;
|
|
29
|
+
getViewType(): ViewType;
|
|
30
|
+
memoizedElementContext(prev: SlateElementContext, next: SlateElementContext): boolean;
|
|
31
|
+
memoizedTextContext(prev: SlateTextContext, next: SlateTextContext): boolean;
|
|
32
|
+
memoizedContext(prev: SlateElementContext | SlateTextContext, next: SlateElementContext | SlateTextContext): boolean;
|
|
33
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<SlateDescendant, never>;
|
|
34
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<SlateDescendant, "slate-descendant", never, { "descendant": { "alias": "descendant"; "required": false; }; "context": { "alias": "context"; "required": false; }; "viewContext": { "alias": "viewContext"; "required": false; }; "index": { "alias": "index"; "required": false; }; }, {}, never, never, true, never>;
|
|
35
|
+
}
|
|
@@ -1,13 +1,11 @@
|
|
|
1
|
-
import { OnInit, Renderer2, ElementRef, OnDestroy, ChangeDetectorRef, NgZone, Injector, OnChanges, SimpleChanges, AfterViewChecked, DoCheck
|
|
1
|
+
import { OnInit, Renderer2, ElementRef, OnDestroy, ChangeDetectorRef, NgZone, Injector, OnChanges, SimpleChanges, AfterViewChecked, DoCheck } from '@angular/core';
|
|
2
2
|
import { Text as SlateText, Element, Editor, Range, NodeEntry } from 'slate';
|
|
3
3
|
import { AngularEditor } from '../../plugins/angular-editor';
|
|
4
4
|
import { DOMElement, DOMNode, DOMRange } from '../../utils/dom';
|
|
5
5
|
import { SlateStringTemplate } from '../string/template.component';
|
|
6
6
|
import { SlateChildrenContext, SlateViewContext } from '../../view/context';
|
|
7
|
-
import {
|
|
7
|
+
import { ViewType } from '../../types/view';
|
|
8
8
|
import { SlatePlaceholder } from '../../types/feature';
|
|
9
|
-
import { BaseElementComponent, BaseLeafComponent, BaseTextComponent } from '../../view/base';
|
|
10
|
-
import { ListRender } from '../../view/render/list-render';
|
|
11
9
|
import * as i0 from "@angular/core";
|
|
12
10
|
export declare class SlateEditable implements OnInit, OnChanges, OnDestroy, AfterViewChecked, DoCheck {
|
|
13
11
|
elementRef: ElementRef;
|
|
@@ -15,10 +13,6 @@ export declare class SlateEditable implements OnInit, OnChanges, OnDestroy, Afte
|
|
|
15
13
|
cdr: ChangeDetectorRef;
|
|
16
14
|
private ngZone;
|
|
17
15
|
private injector;
|
|
18
|
-
defaultElement: ComponentType<BaseElementComponent>;
|
|
19
|
-
defaultText: ComponentType<BaseTextComponent>;
|
|
20
|
-
defaultVoidText: ComponentType<BaseTextComponent>;
|
|
21
|
-
defaultLeaf: ComponentType<BaseLeafComponent>;
|
|
22
16
|
viewContext: SlateViewContext;
|
|
23
17
|
context: SlateChildrenContext;
|
|
24
18
|
private destroy$;
|
|
@@ -65,10 +59,7 @@ export declare class SlateEditable implements OnInit, OnChanges, OnDestroy, Afte
|
|
|
65
59
|
get hasBeforeInputSupport(): boolean;
|
|
66
60
|
templateComponent: SlateStringTemplate;
|
|
67
61
|
templateElementRef: ElementRef<any>;
|
|
68
|
-
|
|
69
|
-
getOutletParent: () => any;
|
|
70
|
-
listRender: ListRender;
|
|
71
|
-
constructor(elementRef: ElementRef, renderer2: Renderer2, cdr: ChangeDetectorRef, ngZone: NgZone, injector: Injector, defaultElement: ComponentType<BaseElementComponent>, defaultText: ComponentType<BaseTextComponent>, defaultVoidText: ComponentType<BaseTextComponent>, defaultLeaf: ComponentType<BaseLeafComponent>);
|
|
62
|
+
constructor(elementRef: ElementRef, renderer2: Renderer2, cdr: ChangeDetectorRef, ngZone: NgZone, injector: Injector);
|
|
72
63
|
ngOnInit(): void;
|
|
73
64
|
ngOnChanges(simpleChanges: SimpleChanges): void;
|
|
74
65
|
registerOnChange(fn: any): void;
|
|
@@ -79,11 +70,10 @@ export declare class SlateEditable implements OnInit, OnChanges, OnDestroy, Afte
|
|
|
79
70
|
onChange(): void;
|
|
80
71
|
ngAfterViewChecked(): void;
|
|
81
72
|
ngDoCheck(): void;
|
|
82
|
-
|
|
83
|
-
render(): void;
|
|
84
|
-
updateContext(): boolean;
|
|
73
|
+
forceFlush(): void;
|
|
85
74
|
initializeContext(): void;
|
|
86
75
|
initializeViewContext(): void;
|
|
76
|
+
detectContext(): void;
|
|
87
77
|
composePlaceholderDecorate(editor: Editor): SlatePlaceholder[];
|
|
88
78
|
generateDecorations(): import("slate").BaseRange[];
|
|
89
79
|
private addEventListener;
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { OnChanges, OnInit, SimpleChanges } from '@angular/core';
|
|
2
|
+
import { ViewContainerItem } from '../../view/container-item';
|
|
3
|
+
import { SlateLeafContext } from '../../view/context';
|
|
4
|
+
import { BaseLeafComponent } from '../../view/base';
|
|
5
|
+
import { ViewType } from '../../types/view';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
export declare class SlateLeaf extends ViewContainerItem<SlateLeafContext, BaseLeafComponent> implements OnInit, OnChanges {
|
|
8
|
+
context: SlateLeafContext;
|
|
9
|
+
ngOnInit(): void;
|
|
10
|
+
getContext(): SlateLeafContext;
|
|
11
|
+
getViewType(): ViewType;
|
|
12
|
+
memoizedContext(prev: SlateLeafContext, next: SlateLeafContext): boolean;
|
|
13
|
+
ngOnChanges(simpleChanges: SimpleChanges): void;
|
|
14
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<SlateLeaf, never>;
|
|
15
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<SlateLeaf, "slate-leaf", never, { "context": { "alias": "context"; "required": false; }; }, {}, never, never, true, never>;
|
|
16
|
+
}
|
|
@@ -1,12 +1,25 @@
|
|
|
1
|
+
import { AfterViewInit, OnChanges, OnInit, QueryList, SimpleChanges } from '@angular/core';
|
|
1
2
|
import { Text } from 'slate';
|
|
2
3
|
import { SlateLeafContext, SlateTextContext } from '../../view/context';
|
|
3
4
|
import { ViewContainer } from '../../view/container';
|
|
5
|
+
import { SlateLeaf } from '../leaf/leaf.component';
|
|
4
6
|
import * as i0 from "@angular/core";
|
|
5
|
-
export declare class SlateLeaves extends ViewContainer<
|
|
7
|
+
export declare class SlateLeaves extends ViewContainer<SlateLeaf> implements OnInit, AfterViewInit, OnChanges {
|
|
6
8
|
initialized: boolean;
|
|
7
9
|
leafContexts: SlateLeafContext[];
|
|
8
10
|
leaves: Text[];
|
|
9
11
|
context: SlateTextContext;
|
|
12
|
+
childrenComponent: QueryList<SlateLeaf>;
|
|
13
|
+
ngOnInit(): void;
|
|
14
|
+
getLeafContexts(): {
|
|
15
|
+
leaf: import("slate").BaseText;
|
|
16
|
+
text: import("slate").BaseText;
|
|
17
|
+
parent: import("slate").BaseElement;
|
|
18
|
+
index: number;
|
|
19
|
+
isLast: boolean;
|
|
20
|
+
}[];
|
|
21
|
+
ngOnChanges(simpleChanges: SimpleChanges): void;
|
|
22
|
+
trackBy(index: any, item: any): any;
|
|
10
23
|
static ɵfac: i0.ɵɵFactoryDeclaration<SlateLeaves, never>;
|
|
11
24
|
static ɵcmp: i0.ɵɵComponentDeclaration<SlateLeaves, "slate-leaves", never, { "context": { "alias": "context"; "required": false; }; }, {}, never, never, true, never>;
|
|
12
25
|
}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { OnInit, ElementRef, ChangeDetectorRef } from '@angular/core';
|
|
2
2
|
import { SlateStringContext } from '../../view/context';
|
|
3
3
|
import { BaseComponent } from '../../view/base';
|
|
4
|
-
import { BeforeContextChange } from '../../view/context-change';
|
|
4
|
+
import { BeforeContextChange } from '../../view/before-context-change';
|
|
5
5
|
import { DOMElement } from '../../utils/dom';
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
7
7
|
export declare class SlateDefaultString extends BaseComponent<SlateStringContext> implements OnInit, BeforeContextChange<SlateStringContext> {
|
|
@@ -22,11 +22,3 @@ export declare class SlateString extends ViewContainerItem<SlateStringContext> i
|
|
|
22
22
|
static ɵfac: i0.ɵɵFactoryDeclaration<SlateString, never>;
|
|
23
23
|
static ɵcmp: i0.ɵɵComponentDeclaration<SlateString, "span[slateString]", never, { "context": { "alias": "context"; "required": false; }; }, {}, never, never, true, never>;
|
|
24
24
|
}
|
|
25
|
-
/**
|
|
26
|
-
* TODO: remove when bump slate
|
|
27
|
-
* copy from slate
|
|
28
|
-
* @param editor
|
|
29
|
-
* @param element
|
|
30
|
-
* @returns
|
|
31
|
-
*/
|
|
32
|
-
export declare const isEmpty: (editor: any, element: any) => boolean;
|
|
@@ -11,6 +11,7 @@ export class SlateBlockCard {
|
|
|
11
11
|
this.elementRef = elementRef;
|
|
12
12
|
}
|
|
13
13
|
ngOnInit() {
|
|
14
|
+
this.append();
|
|
14
15
|
this.nativeElement.classList.add(`slate-block-card`);
|
|
15
16
|
}
|
|
16
17
|
append() {
|
|
@@ -18,7 +19,6 @@ export class SlateBlockCard {
|
|
|
18
19
|
}
|
|
19
20
|
initializeCenter(rootNodes) {
|
|
20
21
|
this.centerRootNodes = rootNodes;
|
|
21
|
-
this.append();
|
|
22
22
|
}
|
|
23
23
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: SlateBlockCard, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
24
24
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.1", type: SlateBlockCard, isStandalone: true, selector: "slate-block-card, [slateBlockCard]", viewQueries: [{ propertyName: "centerContianer", first: true, predicate: ["centerContianer"], descendants: true, static: true }], ngImport: i0, template: "<span card-target=\"card-left\" class=\"card-left\">{{ '\\uFEFF' }}</span>\n<div card-target=\"card-center\" #centerContianer></div>\n<span card-target=\"card-right\" class=\"card-right\">{{ '\\uFEFF' }}</span>\n" }); }
|
|
@@ -30,4 +30,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.1", ngImpor
|
|
|
30
30
|
type: ViewChild,
|
|
31
31
|
args: ['centerContianer', { static: true }]
|
|
32
32
|
}] } });
|
|
33
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
33
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmxvY2stY2FyZC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9zcmMvY29tcG9uZW50cy9ibG9jay1jYXJkL2Jsb2NrLWNhcmQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vcGFja2FnZXMvc3JjL2NvbXBvbmVudHMvYmxvY2stY2FyZC9ibG9jay1jYXJkLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQXNCLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFPekUsTUFBTSxPQUFPLGNBQWM7SUFNdkIsSUFBSSxhQUFhO1FBQ2IsT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDLGFBQWEsQ0FBQztJQUN6QyxDQUFDO0lBRUQsSUFBSSxzQkFBc0I7UUFDdEIsT0FBTyxJQUFJLENBQUMsZUFBZSxDQUFDLGFBQTRCLENBQUM7SUFDN0QsQ0FBQztJQUVELFlBQW9CLFVBQXNCO1FBQXRCLGVBQVUsR0FBVixVQUFVLENBQVk7SUFBRyxDQUFDO0lBRTlDLFFBQVE7UUFDSixJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7UUFDZCxJQUFJLENBQUMsYUFBYSxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsa0JBQWtCLENBQUMsQ0FBQztJQUN6RCxDQUFDO0lBRUQsTUFBTTtRQUNGLElBQUksQ0FBQyxlQUFlLENBQUMsT0FBTyxDQUN4QixRQUFRLENBQUMsRUFBRSxDQUFDLENBQUMsSUFBSSxDQUFDLHNCQUFzQixDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQUMsSUFBSSxJQUFJLENBQUMsc0JBQXNCLENBQUMsV0FBVyxDQUFDLFFBQVEsQ0FBQyxDQUNuSCxDQUFDO0lBQ04sQ0FBQztJQUVELGdCQUFnQixDQUFDLFNBQXdCO1FBQ3JDLElBQUksQ0FBQyxlQUFlLEdBQUcsU0FBUyxDQUFDO0lBQ3JDLENBQUM7OEdBN0JRLGNBQWM7a0dBQWQsY0FBYyxnT0NQM0Isc05BR0E7OzJGRElhLGNBQWM7a0JBTDFCLFNBQVM7K0JBQ0ksb0NBQW9DLGNBRWxDLElBQUk7aUdBSWhCLGVBQWU7c0JBRGQsU0FBUzt1QkFBQyxpQkFBaUIsRUFBRSxFQUFFLE1BQU0sRUFBRSxJQUFJLEVBQUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEVsZW1lbnRSZWYsIE9uSW5pdCwgVmlld0NoaWxkIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnc2xhdGUtYmxvY2stY2FyZCwgW3NsYXRlQmxvY2tDYXJkXScsXG4gICAgdGVtcGxhdGVVcmw6ICdibG9jay1jYXJkLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdGFuZGFsb25lOiB0cnVlXG59KVxuZXhwb3J0IGNsYXNzIFNsYXRlQmxvY2tDYXJkIGltcGxlbWVudHMgT25Jbml0IHtcbiAgICBAVmlld0NoaWxkKCdjZW50ZXJDb250aWFuZXInLCB7IHN0YXRpYzogdHJ1ZSB9KVxuICAgIGNlbnRlckNvbnRpYW5lcjogRWxlbWVudFJlZjtcblxuICAgIGNlbnRlclJvb3ROb2RlczogSFRNTEVsZW1lbnRbXTtcblxuICAgIGdldCBuYXRpdmVFbGVtZW50KCkge1xuICAgICAgICByZXR1cm4gdGhpcy5lbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQ7XG4gICAgfVxuXG4gICAgZ2V0IGNlbnRlckNvbnRhaW5lckVsZW1lbnQoKSB7XG4gICAgICAgIHJldHVybiB0aGlzLmNlbnRlckNvbnRpYW5lci5uYXRpdmVFbGVtZW50IGFzIEhUTUxFbGVtZW50O1xuICAgIH1cblxuICAgIGNvbnN0cnVjdG9yKHByaXZhdGUgZWxlbWVudFJlZjogRWxlbWVudFJlZikge31cblxuICAgIG5nT25Jbml0KCkge1xuICAgICAgICB0aGlzLmFwcGVuZCgpO1xuICAgICAgICB0aGlzLm5hdGl2ZUVsZW1lbnQuY2xhc3NMaXN0LmFkZChgc2xhdGUtYmxvY2stY2FyZGApO1xuICAgIH1cblxuICAgIGFwcGVuZCgpIHtcbiAgICAgICAgdGhpcy5jZW50ZXJSb290Tm9kZXMuZm9yRWFjaChcbiAgICAgICAgICAgIHJvb3ROb2RlID0+ICF0aGlzLmNlbnRlckNvbnRhaW5lckVsZW1lbnQuY29udGFpbnMocm9vdE5vZGUpICYmIHRoaXMuY2VudGVyQ29udGFpbmVyRWxlbWVudC5hcHBlbmRDaGlsZChyb290Tm9kZSlcbiAgICAgICAgKTtcbiAgICB9XG5cbiAgICBpbml0aWFsaXplQ2VudGVyKHJvb3ROb2RlczogSFRNTEVsZW1lbnRbXSkge1xuICAgICAgICB0aGlzLmNlbnRlclJvb3ROb2RlcyA9IHJvb3ROb2RlcztcbiAgICB9XG59XG4iLCI8c3BhbiBjYXJkLXRhcmdldD1cImNhcmQtbGVmdFwiIGNsYXNzPVwiY2FyZC1sZWZ0XCI+e3sgJ1xcdUZFRkYnIH19PC9zcGFuPlxuPGRpdiBjYXJkLXRhcmdldD1cImNhcmQtY2VudGVyXCIgI2NlbnRlckNvbnRpYW5lcj48L2Rpdj5cbjxzcGFuIGNhcmQtdGFyZ2V0PVwiY2FyZC1yaWdodFwiIGNsYXNzPVwiY2FyZC1yaWdodFwiPnt7ICdcXHVGRUZGJyB9fTwvc3Bhbj5cbiJdfQ==
|
|
@@ -1,17 +1,42 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
|
|
1
|
+
import { ChangeDetectionStrategy, Component, Input, ViewChildren } from '@angular/core';
|
|
2
|
+
import { SlateDescendant } from '../descendant/descendant.component';
|
|
3
|
+
import { AngularEditor } from '../../plugins/angular-editor';
|
|
2
4
|
import { ViewContainer } from '../../view/container';
|
|
5
|
+
import { NgFor } from '@angular/common';
|
|
3
6
|
import * as i0 from "@angular/core";
|
|
4
7
|
export class SlateChildren extends ViewContainer {
|
|
8
|
+
constructor() {
|
|
9
|
+
super(...arguments);
|
|
10
|
+
this.trackBy = (index, node) => {
|
|
11
|
+
return this.viewContext.trackBy(node) || AngularEditor.findKey(this.viewContext.editor, node);
|
|
12
|
+
};
|
|
13
|
+
}
|
|
14
|
+
ngOnInit() { }
|
|
5
15
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: SlateChildren, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
6
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.1", type: SlateChildren, isStandalone: true, selector: "slate-children", inputs: { children: "children", context: "context", viewContext: "viewContext" },
|
|
16
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.1", type: SlateChildren, isStandalone: true, selector: "slate-children", inputs: { children: "children", context: "context", viewContext: "viewContext" }, viewQueries: [{ propertyName: "childrenComponent", predicate: SlateDescendant, descendants: true, read: SlateDescendant }], usesInheritance: true, ngImport: i0, template: `<slate-descendant
|
|
17
|
+
[descendant]="descendant"
|
|
18
|
+
[context]="context"
|
|
19
|
+
[viewContext]="viewContext"
|
|
20
|
+
[viewContext]="viewContext"
|
|
21
|
+
[index]="index"
|
|
22
|
+
*ngFor="let descendant of children; let index = index; trackBy: trackBy"
|
|
23
|
+
></slate-descendant>`, isInline: true, dependencies: [{ kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: SlateDescendant, selector: "slate-descendant", inputs: ["descendant", "context", "viewContext", "index"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
7
24
|
}
|
|
8
25
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: SlateChildren, decorators: [{
|
|
9
26
|
type: Component,
|
|
10
27
|
args: [{
|
|
11
28
|
selector: 'slate-children',
|
|
12
|
-
template:
|
|
29
|
+
template: `<slate-descendant
|
|
30
|
+
[descendant]="descendant"
|
|
31
|
+
[context]="context"
|
|
32
|
+
[viewContext]="viewContext"
|
|
33
|
+
[viewContext]="viewContext"
|
|
34
|
+
[index]="index"
|
|
35
|
+
*ngFor="let descendant of children; let index = index; trackBy: trackBy"
|
|
36
|
+
></slate-descendant>`,
|
|
13
37
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
14
|
-
standalone: true
|
|
38
|
+
standalone: true,
|
|
39
|
+
imports: [NgFor, SlateDescendant]
|
|
15
40
|
}]
|
|
16
41
|
}], propDecorators: { children: [{
|
|
17
42
|
type: Input
|
|
@@ -19,5 +44,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.1", ngImpor
|
|
|
19
44
|
type: Input
|
|
20
45
|
}], viewContext: [{
|
|
21
46
|
type: Input
|
|
47
|
+
}], childrenComponent: [{
|
|
48
|
+
type: ViewChildren,
|
|
49
|
+
args: [SlateDescendant, { read: SlateDescendant }]
|
|
22
50
|
}] } });
|
|
23
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
51
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hpbGRyZW4uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvc3JjL2NvbXBvbmVudHMvY2hpbGRyZW4vY2hpbGRyZW4uY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFxQixZQUFZLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDM0csT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLG9DQUFvQyxDQUFDO0FBRXJFLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUU3RCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDckQsT0FBTyxFQUFFLEtBQUssRUFBRSxNQUFNLGlCQUFpQixDQUFDOztBQWdCeEMsTUFBTSxPQUFPLGFBQWMsU0FBUSxhQUE4QjtJQWRqRTs7UUEwQkksWUFBTyxHQUFHLENBQUMsS0FBSyxFQUFFLElBQUksRUFBRSxFQUFFO1lBQ3RCLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksYUFBYSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUMsQ0FBQztRQUNsRyxDQUFDLENBQUM7S0FDTDtJQUxHLFFBQVEsS0FBSSxDQUFDOzhHQVZKLGFBQWE7a0dBQWIsYUFBYSxrTUFPUixlQUFlLDJCQUFVLGVBQWUsb0RBbkI1Qzs7Ozs7Ozt5QkFPVyw0REFHWCxLQUFLLG1IQUFFLGVBQWU7OzJGQUV2QixhQUFhO2tCQWR6QixTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSxnQkFBZ0I7b0JBQzFCLFFBQVEsRUFBRTs7Ozs7Ozt5QkFPVztvQkFDckIsZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07b0JBQy9DLFVBQVUsRUFBRSxJQUFJO29CQUNoQixPQUFPLEVBQUUsQ0FBQyxLQUFLLEVBQUUsZUFBZSxDQUFDO2lCQUNwQzs4QkFFWSxRQUFRO3NCQUFoQixLQUFLO2dCQUVHLE9BQU87c0JBQWYsS0FBSztnQkFFRyxXQUFXO3NCQUFuQixLQUFLO2dCQUdOLGlCQUFpQjtzQkFEaEIsWUFBWTt1QkFBQyxlQUFlLEVBQUUsRUFBRSxJQUFJLEVBQUUsZUFBZSxFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgSW5wdXQsIE9uSW5pdCwgUXVlcnlMaXN0LCBWaWV3Q2hpbGRyZW4gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFNsYXRlRGVzY2VuZGFudCB9IGZyb20gJy4uL2Rlc2NlbmRhbnQvZGVzY2VuZGFudC5jb21wb25lbnQnO1xuaW1wb3J0IHsgRGVzY2VuZGFudCB9IGZyb20gJ3NsYXRlJztcbmltcG9ydCB7IEFuZ3VsYXJFZGl0b3IgfSBmcm9tICcuLi8uLi9wbHVnaW5zL2FuZ3VsYXItZWRpdG9yJztcbmltcG9ydCB7IFNsYXRlQ2hpbGRyZW5Db250ZXh0LCBTbGF0ZVZpZXdDb250ZXh0IH0gZnJvbSAnLi4vLi4vdmlldy9jb250ZXh0JztcbmltcG9ydCB7IFZpZXdDb250YWluZXIgfSBmcm9tICcuLi8uLi92aWV3L2NvbnRhaW5lcic7XG5pbXBvcnQgeyBOZ0ZvciB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnc2xhdGUtY2hpbGRyZW4nLFxuICAgIHRlbXBsYXRlOiBgPHNsYXRlLWRlc2NlbmRhbnRcbiAgICAgICAgW2Rlc2NlbmRhbnRdPVwiZGVzY2VuZGFudFwiXG4gICAgICAgIFtjb250ZXh0XT1cImNvbnRleHRcIlxuICAgICAgICBbdmlld0NvbnRleHRdPVwidmlld0NvbnRleHRcIlxuICAgICAgICBbdmlld0NvbnRleHRdPVwidmlld0NvbnRleHRcIlxuICAgICAgICBbaW5kZXhdPVwiaW5kZXhcIlxuICAgICAgICAqbmdGb3I9XCJsZXQgZGVzY2VuZGFudCBvZiBjaGlsZHJlbjsgbGV0IGluZGV4ID0gaW5kZXg7IHRyYWNrQnk6IHRyYWNrQnlcIlxuICAgID48L3NsYXRlLWRlc2NlbmRhbnQ+YCxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIGltcG9ydHM6IFtOZ0ZvciwgU2xhdGVEZXNjZW5kYW50XVxufSlcbmV4cG9ydCBjbGFzcyBTbGF0ZUNoaWxkcmVuIGV4dGVuZHMgVmlld0NvbnRhaW5lcjxTbGF0ZURlc2NlbmRhbnQ+IGltcGxlbWVudHMgT25Jbml0IHtcbiAgICBASW5wdXQoKSBjaGlsZHJlbjogRGVzY2VuZGFudFtdO1xuXG4gICAgQElucHV0KCkgY29udGV4dDogU2xhdGVDaGlsZHJlbkNvbnRleHQ7XG5cbiAgICBASW5wdXQoKSB2aWV3Q29udGV4dDogU2xhdGVWaWV3Q29udGV4dDtcblxuICAgIEBWaWV3Q2hpbGRyZW4oU2xhdGVEZXNjZW5kYW50LCB7IHJlYWQ6IFNsYXRlRGVzY2VuZGFudCB9KVxuICAgIGNoaWxkcmVuQ29tcG9uZW50OiBRdWVyeUxpc3Q8U2xhdGVEZXNjZW5kYW50PjtcblxuICAgIG5nT25Jbml0KCkge31cblxuICAgIHRyYWNrQnkgPSAoaW5kZXgsIG5vZGUpID0+IHtcbiAgICAgICAgcmV0dXJuIHRoaXMudmlld0NvbnRleHQudHJhY2tCeShub2RlKSB8fCBBbmd1bGFyRWRpdG9yLmZpbmRLZXkodGhpcy52aWV3Q29udGV4dC5lZGl0b3IsIG5vZGUpO1xuICAgIH07XG59XG4iXX0=
|
|
@@ -0,0 +1,186 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, Inject, Input } from '@angular/core';
|
|
2
|
+
import { SlateBlockCard } from '../block-card/block-card.component';
|
|
3
|
+
import { ViewContainerItem } from '../../view/container-item';
|
|
4
|
+
import { Editor, Range, Element } from 'slate';
|
|
5
|
+
import { AngularEditor } from '../../plugins/angular-editor';
|
|
6
|
+
import { NODE_TO_INDEX, NODE_TO_PARENT } from '../../utils/weak-maps';
|
|
7
|
+
import { SlateDefaultText } from '../text/default-text.component';
|
|
8
|
+
import { SlateVoidText } from '../text/void-text.component';
|
|
9
|
+
import { isDecoratorRangeListEqual } from '../../utils';
|
|
10
|
+
import { SlateErrorCode } from '../../types';
|
|
11
|
+
import { SLATE_DEFAULT_ELEMENT_COMPONENT_TOKEN } from '../element/default-element.component.token';
|
|
12
|
+
import * as i0 from "@angular/core";
|
|
13
|
+
export class SlateDescendant extends ViewContainerItem {
|
|
14
|
+
get rootNodes() {
|
|
15
|
+
if (this.blockCardComponentRef) {
|
|
16
|
+
return [this.blockCardComponentRef.instance.nativeElement];
|
|
17
|
+
}
|
|
18
|
+
return super.getRootNodes();
|
|
19
|
+
}
|
|
20
|
+
get isBlockCard() {
|
|
21
|
+
return this.viewContext.editor.isBlockCard(this.descendant);
|
|
22
|
+
}
|
|
23
|
+
constructor(viewContainerRef, defaultElementComponentType) {
|
|
24
|
+
super(viewContainerRef);
|
|
25
|
+
this.viewContainerRef = viewContainerRef;
|
|
26
|
+
this.defaultElementComponentType = defaultElementComponentType;
|
|
27
|
+
}
|
|
28
|
+
ngOnInit() {
|
|
29
|
+
NODE_TO_INDEX.set(this.descendant, this.index);
|
|
30
|
+
NODE_TO_PARENT.set(this.descendant, this.context.parent);
|
|
31
|
+
this.createView();
|
|
32
|
+
if (this.isBlockCard) {
|
|
33
|
+
this.createBlockCard();
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
destroyView() {
|
|
37
|
+
super.destroyView();
|
|
38
|
+
this.destroyBlockCard();
|
|
39
|
+
}
|
|
40
|
+
ngOnChanges() {
|
|
41
|
+
if (!this.initialized) {
|
|
42
|
+
return;
|
|
43
|
+
}
|
|
44
|
+
NODE_TO_INDEX.set(this.descendant, this.index);
|
|
45
|
+
NODE_TO_PARENT.set(this.descendant, this.context.parent);
|
|
46
|
+
this.updateView();
|
|
47
|
+
if (this.isBlockCard) {
|
|
48
|
+
this.updateBlockCard();
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
destroyBlockCard() {
|
|
52
|
+
if (this.blockCardComponentRef) {
|
|
53
|
+
this.blockCardComponentRef.destroy();
|
|
54
|
+
this.blockCardComponentRef = null;
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
createBlockCard() {
|
|
58
|
+
const rootNodes = this.rootNodes;
|
|
59
|
+
this.blockCardComponentRef = this.viewContainerRef.createComponent(SlateBlockCard);
|
|
60
|
+
this.blockCardComponentRef.instance.initializeCenter(rootNodes);
|
|
61
|
+
}
|
|
62
|
+
updateBlockCard() {
|
|
63
|
+
if (this.blockCardComponentRef) {
|
|
64
|
+
return;
|
|
65
|
+
}
|
|
66
|
+
const rootNodes = this.rootNodes;
|
|
67
|
+
this.createBlockCard();
|
|
68
|
+
const firstRootNode = rootNodes[0];
|
|
69
|
+
firstRootNode.replaceWith(this.blockCardComponentRef.instance.nativeElement);
|
|
70
|
+
}
|
|
71
|
+
getCommonContext() {
|
|
72
|
+
const path = AngularEditor.findPath(this.viewContext.editor, this.context.parent);
|
|
73
|
+
const p = path.concat(this.index);
|
|
74
|
+
try {
|
|
75
|
+
const range = Editor.range(this.viewContext.editor, p);
|
|
76
|
+
const sel = this.context.selection && Range.intersection(range, this.context.selection);
|
|
77
|
+
const ds = this.context.decorate([this.descendant, p]);
|
|
78
|
+
for (const dec of this.context.decorations) {
|
|
79
|
+
const d = Range.intersection(dec, range);
|
|
80
|
+
if (d) {
|
|
81
|
+
ds.push(d);
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
return { selection: sel, decorations: ds };
|
|
85
|
+
}
|
|
86
|
+
catch (error) {
|
|
87
|
+
this.viewContext.editor.onError({
|
|
88
|
+
code: SlateErrorCode.GetStartPointError,
|
|
89
|
+
nativeError: error
|
|
90
|
+
});
|
|
91
|
+
return { selection: null, decorations: [] };
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
getContext() {
|
|
95
|
+
if (Element.isElement(this.descendant)) {
|
|
96
|
+
const computedContext = this.getCommonContext();
|
|
97
|
+
const key = AngularEditor.findKey(this.viewContext.editor, this.descendant);
|
|
98
|
+
const isInline = this.viewContext.editor.isInline(this.descendant);
|
|
99
|
+
const isVoid = this.viewContext.editor.isVoid(this.descendant);
|
|
100
|
+
const elementContext = {
|
|
101
|
+
element: this.descendant,
|
|
102
|
+
...computedContext,
|
|
103
|
+
attributes: {
|
|
104
|
+
'data-slate-node': 'element',
|
|
105
|
+
'data-slate-key': key.id
|
|
106
|
+
},
|
|
107
|
+
decorate: this.context.decorate,
|
|
108
|
+
readonly: this.context.readonly
|
|
109
|
+
};
|
|
110
|
+
if (isInline) {
|
|
111
|
+
elementContext.attributes['data-slate-inline'] = true;
|
|
112
|
+
}
|
|
113
|
+
if (isVoid) {
|
|
114
|
+
elementContext.attributes['data-slate-void'] = true;
|
|
115
|
+
elementContext.attributes.contenteditable = false;
|
|
116
|
+
}
|
|
117
|
+
return elementContext;
|
|
118
|
+
}
|
|
119
|
+
else {
|
|
120
|
+
const computedContext = this.getCommonContext();
|
|
121
|
+
const isLeafBlock = AngularEditor.isLeafBlock(this.viewContext.editor, this.context.parent);
|
|
122
|
+
const textContext = {
|
|
123
|
+
decorations: computedContext.decorations,
|
|
124
|
+
isLast: isLeafBlock && this.index === this.context.parent.children.length - 1,
|
|
125
|
+
parent: this.context.parent,
|
|
126
|
+
text: this.descendant
|
|
127
|
+
};
|
|
128
|
+
return textContext;
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
getViewType() {
|
|
132
|
+
if (Element.isElement(this.descendant)) {
|
|
133
|
+
return (this.viewContext.renderElement && this.viewContext.renderElement(this.descendant)) || this.defaultElementComponentType;
|
|
134
|
+
}
|
|
135
|
+
else {
|
|
136
|
+
const isVoid = this.viewContext.editor.isVoid(this.context.parent);
|
|
137
|
+
return isVoid
|
|
138
|
+
? SlateVoidText
|
|
139
|
+
: (this.viewContext.renderText && this.viewContext.renderText(this.descendant)) || SlateDefaultText;
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
memoizedElementContext(prev, next) {
|
|
143
|
+
return (prev.element === next.element &&
|
|
144
|
+
(!this.viewContext.isStrictDecorate || prev.decorate === next.decorate) &&
|
|
145
|
+
prev.readonly === next.readonly &&
|
|
146
|
+
isDecoratorRangeListEqual(prev.decorations, next.decorations) &&
|
|
147
|
+
(prev.selection === next.selection || (!!prev.selection && !!next.selection && Range.equals(prev.selection, next.selection))));
|
|
148
|
+
}
|
|
149
|
+
memoizedTextContext(prev, next) {
|
|
150
|
+
return (next.parent === prev.parent &&
|
|
151
|
+
next.isLast === prev.isLast &&
|
|
152
|
+
next.text === prev.text &&
|
|
153
|
+
isDecoratorRangeListEqual(next.decorations, prev.decorations));
|
|
154
|
+
}
|
|
155
|
+
memoizedContext(prev, next) {
|
|
156
|
+
if (Element.isElement(this.descendant)) {
|
|
157
|
+
return this.memoizedElementContext(prev, next);
|
|
158
|
+
}
|
|
159
|
+
else {
|
|
160
|
+
return this.memoizedTextContext(prev, next);
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: SlateDescendant, deps: [{ token: i0.ViewContainerRef }, { token: SLATE_DEFAULT_ELEMENT_COMPONENT_TOKEN }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
164
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.1", type: SlateDescendant, isStandalone: true, selector: "slate-descendant", inputs: { descendant: "descendant", context: "context", viewContext: "viewContext", index: "index" }, usesInheritance: true, usesOnChanges: true, ngImport: i0, template: '', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
165
|
+
}
|
|
166
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: SlateDescendant, decorators: [{
|
|
167
|
+
type: Component,
|
|
168
|
+
args: [{
|
|
169
|
+
selector: 'slate-descendant',
|
|
170
|
+
template: '',
|
|
171
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
172
|
+
standalone: true
|
|
173
|
+
}]
|
|
174
|
+
}], ctorParameters: function () { return [{ type: i0.ViewContainerRef }, { type: undefined, decorators: [{
|
|
175
|
+
type: Inject,
|
|
176
|
+
args: [SLATE_DEFAULT_ELEMENT_COMPONENT_TOKEN]
|
|
177
|
+
}] }]; }, propDecorators: { descendant: [{
|
|
178
|
+
type: Input
|
|
179
|
+
}], context: [{
|
|
180
|
+
type: Input
|
|
181
|
+
}], viewContext: [{
|
|
182
|
+
type: Input
|
|
183
|
+
}], index: [{
|
|
184
|
+
type: Input
|
|
185
|
+
}] } });
|
|
186
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"descendant.component.js","sourceRoot":"","sources":["../../../../packages/src/components/descendant/descendant.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, Inject, Input, OnChanges, OnInit, ViewContainerRef } from '@angular/core';\nimport { SlateBlockCard } from '../block-card/block-card.component';\nimport { ViewContainerItem } from '../../view/container-item';\nimport { Descendant, Editor, Range, Element } from 'slate';\nimport { SlateChildrenContext, SlateElementContext, SlateTextContext, SlateViewContext } from '../../view/context';\nimport { AngularEditor } from '../../plugins/angular-editor';\nimport { NODE_TO_INDEX, NODE_TO_PARENT } from '../../utils/weak-maps';\nimport { BaseElementComponent, BaseTextComponent } from '../../view/base';\nimport { SlateDefaultText } from '../text/default-text.component';\nimport { SlateVoidText } from '../text/void-text.component';\nimport { isDecoratorRangeListEqual } from '../../utils';\nimport { ComponentType, ViewType } from '../../types/view';\nimport { SlateErrorCode } from '../../types';\nimport { SLATE_DEFAULT_ELEMENT_COMPONENT_TOKEN } from '../element/default-element.component.token';\n\n@Component({\n    selector: 'slate-descendant',\n    template: '',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    standalone: true\n})\nexport class SlateDescendant\n    extends ViewContainerItem<SlateElementContext | SlateTextContext, BaseElementComponent | BaseTextComponent>\n    implements OnInit, OnChanges\n{\n    @Input() descendant: Descendant;\n\n    @Input() context: SlateChildrenContext;\n\n    @Input() viewContext: SlateViewContext;\n\n    @Input() index: number;\n\n    get rootNodes(): HTMLElement[] {\n        if (this.blockCardComponentRef) {\n            return [this.blockCardComponentRef.instance.nativeElement];\n        }\n        return super.getRootNodes();\n    }\n\n    get isBlockCard() {\n        return this.viewContext.editor.isBlockCard(this.descendant);\n    }\n\n    constructor(\n        protected viewContainerRef: ViewContainerRef,\n        @Inject(SLATE_DEFAULT_ELEMENT_COMPONENT_TOKEN)\n        public defaultElementComponentType: ComponentType<BaseElementComponent>\n    ) {\n        super(viewContainerRef);\n    }\n\n    ngOnInit() {\n        NODE_TO_INDEX.set(this.descendant, this.index);\n        NODE_TO_PARENT.set(this.descendant, this.context.parent);\n        this.createView();\n        if (this.isBlockCard) {\n            this.createBlockCard();\n        }\n    }\n\n    destroyView() {\n        super.destroyView();\n        this.destroyBlockCard();\n    }\n\n    ngOnChanges() {\n        if (!this.initialized) {\n            return;\n        }\n        NODE_TO_INDEX.set(this.descendant, this.index);\n        NODE_TO_PARENT.set(this.descendant, this.context.parent);\n        this.updateView();\n        if (this.isBlockCard) {\n            this.updateBlockCard();\n        }\n    }\n\n    destroyBlockCard() {\n        if (this.blockCardComponentRef) {\n            this.blockCardComponentRef.destroy();\n            this.blockCardComponentRef = null;\n        }\n    }\n\n    createBlockCard() {\n        const rootNodes = this.rootNodes;\n        this.blockCardComponentRef = this.viewContainerRef.createComponent<SlateBlockCard>(SlateBlockCard);\n        this.blockCardComponentRef.instance.initializeCenter(rootNodes);\n    }\n\n    updateBlockCard() {\n        if (this.blockCardComponentRef) {\n            return;\n        }\n        const rootNodes = this.rootNodes;\n        this.createBlockCard();\n        const firstRootNode = rootNodes[0];\n        firstRootNode.replaceWith(this.blockCardComponentRef.instance.nativeElement);\n    }\n\n    getCommonContext(): { selection: Range; decorations: Range[] } {\n        const path = AngularEditor.findPath(this.viewContext.editor, this.context.parent);\n        const p = path.concat(this.index);\n        try {\n            const range = Editor.range(this.viewContext.editor, p);\n            const sel = this.context.selection && Range.intersection(range, this.context.selection);\n            const ds = this.context.decorate([this.descendant, p]);\n            for (const dec of this.context.decorations) {\n                const d = Range.intersection(dec, range);\n                if (d) {\n                    ds.push(d);\n                }\n            }\n            return { selection: sel, decorations: ds };\n        } catch (error) {\n            this.viewContext.editor.onError({\n                code: SlateErrorCode.GetStartPointError,\n                nativeError: error\n            });\n            return { selection: null, decorations: [] };\n        }\n    }\n\n    getContext(): SlateElementContext | SlateTextContext {\n        if (Element.isElement(this.descendant)) {\n            const computedContext = this.getCommonContext();\n            const key = AngularEditor.findKey(this.viewContext.editor, this.descendant);\n            const isInline = this.viewContext.editor.isInline(this.descendant);\n            const isVoid = this.viewContext.editor.isVoid(this.descendant);\n            const elementContext: SlateElementContext = {\n                element: this.descendant,\n                ...computedContext,\n                attributes: {\n                    'data-slate-node': 'element',\n                    'data-slate-key': key.id\n                },\n                decorate: this.context.decorate,\n                readonly: this.context.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 = this.getCommonContext();\n            const isLeafBlock = AngularEditor.isLeafBlock(this.viewContext.editor, this.context.parent);\n            const textContext: SlateTextContext = {\n                decorations: computedContext.decorations,\n                isLast: isLeafBlock && this.index === this.context.parent.children.length - 1,\n                parent: this.context.parent as Element,\n                text: this.descendant\n            };\n            return textContext;\n        }\n    }\n\n    getViewType(): ViewType {\n        if (Element.isElement(this.descendant)) {\n            return (this.viewContext.renderElement && this.viewContext.renderElement(this.descendant)) || this.defaultElementComponentType;\n        } else {\n            const isVoid = this.viewContext.editor.isVoid(this.context.parent as Element);\n            return isVoid\n                ? SlateVoidText\n                : (this.viewContext.renderText && this.viewContext.renderText(this.descendant)) || SlateDefaultText;\n        }\n    }\n\n    memoizedElementContext(prev: SlateElementContext, next: SlateElementContext) {\n        return (\n            prev.element === next.element &&\n            (!this.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\n    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\n    memoizedContext(prev: SlateElementContext | SlateTextContext, next: SlateElementContext | SlateTextContext): boolean {\n        if (Element.isElement(this.descendant)) {\n            return this.memoizedElementContext(prev as SlateElementContext, next as SlateElementContext);\n        } else {\n            return this.memoizedTextContext(prev as SlateTextContext, next as SlateTextContext);\n        }\n    }\n}\n"]}
|