slate-angular 16.1.0-next.9 → 17.0.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.
Files changed (65) hide show
  1. package/components/children/children.component.d.ts +6 -1
  2. package/components/descendant/descendant.component.d.ts +35 -0
  3. package/components/editable/editable.component.d.ts +5 -15
  4. package/components/leaf/leaf.component.d.ts +16 -0
  5. package/components/leaves/leaves.component.d.ts +14 -1
  6. package/components/string/default-string.component.d.ts +1 -1
  7. package/components/string/string.component.d.ts +0 -8
  8. package/esm2022/components/block-card/block-card.component.mjs +6 -6
  9. package/esm2022/components/children/children.component.mjs +35 -7
  10. package/esm2022/components/descendant/descendant.component.mjs +186 -0
  11. package/esm2022/components/editable/editable.component.mjs +40 -131
  12. package/esm2022/components/element/default-element.component.mjs +5 -5
  13. package/esm2022/components/element/element.component.mjs +5 -5
  14. package/esm2022/components/leaf/default-leaf.component.mjs +3 -3
  15. package/esm2022/components/leaf/leaf.component.mjs +38 -0
  16. package/esm2022/components/leaves/leaves.component.mjs +52 -7
  17. package/esm2022/components/string/default-string.component.mjs +5 -5
  18. package/esm2022/components/string/string.component.mjs +10 -20
  19. package/esm2022/components/string/template.component.mjs +3 -3
  20. package/esm2022/components/text/default-text.component.mjs +5 -5
  21. package/esm2022/components/text/void-text.component.mjs +5 -5
  22. package/esm2022/custom-event/BeforeInputEventPlugin.mjs +1 -1
  23. package/esm2022/custom-event/FallbackCompositionState.mjs +1 -1
  24. package/esm2022/module.mjs +26 -11
  25. package/esm2022/plugins/angular-editor.mjs +7 -28
  26. package/esm2022/plugins/with-angular.mjs +4 -4
  27. package/esm2022/public-api.mjs +2 -3
  28. package/esm2022/utils/dom.mjs +1 -1
  29. package/esm2022/utils/hotkeys.mjs +1 -1
  30. package/esm2022/utils/index.mjs +1 -2
  31. package/esm2022/utils/lines.mjs +1 -1
  32. package/esm2022/utils/range-list.mjs +1 -1
  33. package/esm2022/utils/restore-dom.mjs +1 -1
  34. package/esm2022/view/base.mjs +28 -62
  35. package/esm2022/view/before-context-change.mjs +7 -0
  36. package/esm2022/view/container-item.mjs +5 -5
  37. package/esm2022/view/container.mjs +86 -6
  38. package/esm2022/view/context.mjs +1 -1
  39. package/fesm2022/slate-angular.mjs +788 -1079
  40. package/fesm2022/slate-angular.mjs.map +1 -1
  41. package/module.d.ts +8 -7
  42. package/package.json +5 -5
  43. package/public-api.d.ts +1 -2
  44. package/utils/index.d.ts +0 -1
  45. package/view/base.d.ts +4 -15
  46. package/view/{context-change.d.ts → before-context-change.d.ts} +0 -4
  47. package/view/container.d.ts +7 -3
  48. package/view/context.d.ts +2 -6
  49. package/components/children/children-outlet.component.d.ts +0 -9
  50. package/components/leaf/token.d.ts +0 -4
  51. package/components/text/token.d.ts +0 -5
  52. package/esm2022/components/children/children-outlet.component.mjs +0 -22
  53. package/esm2022/components/leaf/token.mjs +0 -3
  54. package/esm2022/components/text/token.mjs +0 -4
  55. package/esm2022/utils/constants.mjs +0 -2
  56. package/esm2022/utils/throttle.mjs +0 -18
  57. package/esm2022/view/context-change.mjs +0 -13
  58. package/esm2022/view/render/leaves-render.mjs +0 -107
  59. package/esm2022/view/render/list-render.mjs +0 -252
  60. package/esm2022/view/render/utils.mjs +0 -117
  61. package/utils/constants.d.ts +0 -1
  62. package/utils/throttle.d.ts +0 -2
  63. package/view/render/leaves-render.d.ts +0 -21
  64. package/view/render/list-render.d.ts +0 -32
  65. 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<any> {
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, ViewContainerRef } from '@angular/core';
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 { ComponentType, ViewType } from '../../types/view';
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
- viewContainerRef: ViewContainerRef;
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
- forceRender(): void;
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<any> {
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,16 +19,15 @@ export class SlateBlockCard {
18
19
  }
19
20
  initializeCenter(rootNodes) {
20
21
  this.centerRootNodes = rootNodes;
21
- this.append();
22
22
  }
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
- 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" }); }
23
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: SlateBlockCard, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
24
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.4", 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" }); }
25
25
  }
26
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: SlateBlockCard, decorators: [{
26
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: SlateBlockCard, decorators: [{
27
27
  type: Component,
28
28
  args: [{ selector: 'slate-block-card, [slateBlockCard]', standalone: true, 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" }]
29
- }], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { centerContianer: [{
29
+ }], ctorParameters: () => [{ type: i0.ElementRef }], propDecorators: { centerContianer: [{
30
30
  type: ViewChild,
31
31
  args: ['centerContianer', { static: true }]
32
32
  }] } });
33
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmxvY2stY2FyZC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9zcmMvY29tcG9uZW50cy9ibG9jay1jYXJkL2Jsb2NrLWNhcmQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vcGFja2FnZXMvc3JjL2NvbXBvbmVudHMvYmxvY2stY2FyZC9ibG9jay1jYXJkLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQXNCLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFPekUsTUFBTSxPQUFPLGNBQWM7SUFNdkIsSUFBSSxhQUFhO1FBQ2IsT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDLGFBQWEsQ0FBQztJQUN6QyxDQUFDO0lBRUQsSUFBSSxzQkFBc0I7UUFDdEIsT0FBTyxJQUFJLENBQUMsZUFBZSxDQUFDLGFBQTRCLENBQUM7SUFDN0QsQ0FBQztJQUVELFlBQW9CLFVBQXNCO1FBQXRCLGVBQVUsR0FBVixVQUFVLENBQVk7SUFBRyxDQUFDO0lBRTlDLFFBQVE7UUFDSixJQUFJLENBQUMsYUFBYSxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsa0JBQWtCLENBQUMsQ0FBQztJQUN6RCxDQUFDO0lBRUQsTUFBTTtRQUNGLElBQUksQ0FBQyxlQUFlLENBQUMsT0FBTyxDQUN4QixRQUFRLENBQUMsRUFBRSxDQUFDLENBQUMsSUFBSSxDQUFDLHNCQUFzQixDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQUMsSUFBSSxJQUFJLENBQUMsc0JBQXNCLENBQUMsV0FBVyxDQUFDLFFBQVEsQ0FBQyxDQUNuSCxDQUFDO0lBQ04sQ0FBQztJQUVELGdCQUFnQixDQUFDLFNBQXdCO1FBQ3JDLElBQUksQ0FBQyxlQUFlLEdBQUcsU0FBUyxDQUFDO1FBQ2pDLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQztJQUNsQixDQUFDOzhHQTdCUSxjQUFjO2tHQUFkLGNBQWMsZ09DUDNCLHNOQUdBOzsyRkRJYSxjQUFjO2tCQUwxQixTQUFTOytCQUNJLG9DQUFvQyxjQUVsQyxJQUFJO2lHQUloQixlQUFlO3NCQURkLFNBQVM7dUJBQUMsaUJBQWlCLEVBQUUsRUFBRSxNQUFNLEVBQUUsSUFBSSxFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFbGVtZW50UmVmLCBPbkluaXQsIFZpZXdDaGlsZCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ3NsYXRlLWJsb2NrLWNhcmQsIFtzbGF0ZUJsb2NrQ2FyZF0nLFxuICAgIHRlbXBsYXRlVXJsOiAnYmxvY2stY2FyZC5jb21wb25lbnQuaHRtbCcsXG4gICAgc3RhbmRhbG9uZTogdHJ1ZVxufSlcbmV4cG9ydCBjbGFzcyBTbGF0ZUJsb2NrQ2FyZCBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gICAgQFZpZXdDaGlsZCgnY2VudGVyQ29udGlhbmVyJywgeyBzdGF0aWM6IHRydWUgfSlcbiAgICBjZW50ZXJDb250aWFuZXI6IEVsZW1lbnRSZWY7XG5cbiAgICBjZW50ZXJSb290Tm9kZXM6IEhUTUxFbGVtZW50W107XG5cbiAgICBnZXQgbmF0aXZlRWxlbWVudCgpIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50O1xuICAgIH1cblxuICAgIGdldCBjZW50ZXJDb250YWluZXJFbGVtZW50KCkge1xuICAgICAgICByZXR1cm4gdGhpcy5jZW50ZXJDb250aWFuZXIubmF0aXZlRWxlbWVudCBhcyBIVE1MRWxlbWVudDtcbiAgICB9XG5cbiAgICBjb25zdHJ1Y3Rvcihwcml2YXRlIGVsZW1lbnRSZWY6IEVsZW1lbnRSZWYpIHt9XG5cbiAgICBuZ09uSW5pdCgpIHtcbiAgICAgICAgdGhpcy5uYXRpdmVFbGVtZW50LmNsYXNzTGlzdC5hZGQoYHNsYXRlLWJsb2NrLWNhcmRgKTtcbiAgICB9XG5cbiAgICBhcHBlbmQoKSB7XG4gICAgICAgIHRoaXMuY2VudGVyUm9vdE5vZGVzLmZvckVhY2goXG4gICAgICAgICAgICByb290Tm9kZSA9PiAhdGhpcy5jZW50ZXJDb250YWluZXJFbGVtZW50LmNvbnRhaW5zKHJvb3ROb2RlKSAmJiB0aGlzLmNlbnRlckNvbnRhaW5lckVsZW1lbnQuYXBwZW5kQ2hpbGQocm9vdE5vZGUpXG4gICAgICAgICk7XG4gICAgfVxuXG4gICAgaW5pdGlhbGl6ZUNlbnRlcihyb290Tm9kZXM6IEhUTUxFbGVtZW50W10pIHtcbiAgICAgICAgdGhpcy5jZW50ZXJSb290Tm9kZXMgPSByb290Tm9kZXM7XG4gICAgICAgIHRoaXMuYXBwZW5kKCk7XG4gICAgfVxufVxuIiwiPHNwYW4gY2FyZC10YXJnZXQ9XCJjYXJkLWxlZnRcIiBjbGFzcz1cImNhcmQtbGVmdFwiPnt7ICdcXHVGRUZGJyB9fTwvc3Bhbj5cbjxkaXYgY2FyZC10YXJnZXQ9XCJjYXJkLWNlbnRlclwiICNjZW50ZXJDb250aWFuZXI+PC9kaXY+XG48c3BhbiBjYXJkLXRhcmdldD1cImNhcmQtcmlnaHRcIiBjbGFzcz1cImNhcmQtcmlnaHRcIj57eyAnXFx1RkVGRicgfX08L3NwYW4+XG4iXX0=
33
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmxvY2stY2FyZC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9zcmMvY29tcG9uZW50cy9ibG9jay1jYXJkL2Jsb2NrLWNhcmQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vcGFja2FnZXMvc3JjL2NvbXBvbmVudHMvYmxvY2stY2FyZC9ibG9jay1jYXJkLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQXNCLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFPekUsTUFBTSxPQUFPLGNBQWM7SUFNdkIsSUFBSSxhQUFhO1FBQ2IsT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDLGFBQWEsQ0FBQztJQUN6QyxDQUFDO0lBRUQsSUFBSSxzQkFBc0I7UUFDdEIsT0FBTyxJQUFJLENBQUMsZUFBZSxDQUFDLGFBQTRCLENBQUM7SUFDN0QsQ0FBQztJQUVELFlBQW9CLFVBQXNCO1FBQXRCLGVBQVUsR0FBVixVQUFVLENBQVk7SUFBRyxDQUFDO0lBRTlDLFFBQVE7UUFDSixJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7UUFDZCxJQUFJLENBQUMsYUFBYSxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsa0JBQWtCLENBQUMsQ0FBQztJQUN6RCxDQUFDO0lBRUQsTUFBTTtRQUNGLElBQUksQ0FBQyxlQUFlLENBQUMsT0FBTyxDQUN4QixRQUFRLENBQUMsRUFBRSxDQUFDLENBQUMsSUFBSSxDQUFDLHNCQUFzQixDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQUMsSUFBSSxJQUFJLENBQUMsc0JBQXNCLENBQUMsV0FBVyxDQUFDLFFBQVEsQ0FBQyxDQUNuSCxDQUFDO0lBQ04sQ0FBQztJQUVELGdCQUFnQixDQUFDLFNBQXdCO1FBQ3JDLElBQUksQ0FBQyxlQUFlLEdBQUcsU0FBUyxDQUFDO0lBQ3JDLENBQUM7OEdBN0JRLGNBQWM7a0dBQWQsY0FBYyxnT0NQM0Isc05BR0E7OzJGRElhLGNBQWM7a0JBTDFCLFNBQVM7K0JBQ0ksb0NBQW9DLGNBRWxDLElBQUk7K0VBSWhCLGVBQWU7c0JBRGQsU0FBUzt1QkFBQyxpQkFBaUIsRUFBRSxFQUFFLE1BQU0sRUFBRSxJQUFJLEVBQUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEVsZW1lbnRSZWYsIE9uSW5pdCwgVmlld0NoaWxkIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnc2xhdGUtYmxvY2stY2FyZCwgW3NsYXRlQmxvY2tDYXJkXScsXG4gICAgdGVtcGxhdGVVcmw6ICdibG9jay1jYXJkLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdGFuZGFsb25lOiB0cnVlXG59KVxuZXhwb3J0IGNsYXNzIFNsYXRlQmxvY2tDYXJkIGltcGxlbWVudHMgT25Jbml0IHtcbiAgICBAVmlld0NoaWxkKCdjZW50ZXJDb250aWFuZXInLCB7IHN0YXRpYzogdHJ1ZSB9KVxuICAgIGNlbnRlckNvbnRpYW5lcjogRWxlbWVudFJlZjtcblxuICAgIGNlbnRlclJvb3ROb2RlczogSFRNTEVsZW1lbnRbXTtcblxuICAgIGdldCBuYXRpdmVFbGVtZW50KCkge1xuICAgICAgICByZXR1cm4gdGhpcy5lbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQ7XG4gICAgfVxuXG4gICAgZ2V0IGNlbnRlckNvbnRhaW5lckVsZW1lbnQoKSB7XG4gICAgICAgIHJldHVybiB0aGlzLmNlbnRlckNvbnRpYW5lci5uYXRpdmVFbGVtZW50IGFzIEhUTUxFbGVtZW50O1xuICAgIH1cblxuICAgIGNvbnN0cnVjdG9yKHByaXZhdGUgZWxlbWVudFJlZjogRWxlbWVudFJlZikge31cblxuICAgIG5nT25Jbml0KCkge1xuICAgICAgICB0aGlzLmFwcGVuZCgpO1xuICAgICAgICB0aGlzLm5hdGl2ZUVsZW1lbnQuY2xhc3NMaXN0LmFkZChgc2xhdGUtYmxvY2stY2FyZGApO1xuICAgIH1cblxuICAgIGFwcGVuZCgpIHtcbiAgICAgICAgdGhpcy5jZW50ZXJSb290Tm9kZXMuZm9yRWFjaChcbiAgICAgICAgICAgIHJvb3ROb2RlID0+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 {
5
- 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" }, usesInheritance: true, ngImport: i0, template: ``, isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
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() { }
15
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.4", ngImport: i0, type: SlateChildren, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
16
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.4", 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
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: SlateChildren, decorators: [{
25
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", 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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hpbGRyZW4uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvc3JjL2NvbXBvbmVudHMvY2hpbGRyZW4vY2hpbGRyZW4uY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRzFFLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQzs7QUFTckQsTUFBTSxPQUFPLGFBQWMsU0FBUSxhQUFrQjs4R0FBeEMsYUFBYTtrR0FBYixhQUFhLG1MQUpaLEVBQUU7OzJGQUlILGFBQWE7a0JBTnpCLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLGdCQUFnQjtvQkFDMUIsUUFBUSxFQUFFLEVBQUU7b0JBQ1osZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07b0JBQy9DLFVBQVUsRUFBRSxJQUFJO2lCQUNuQjs4QkFFWSxRQUFRO3NCQUFoQixLQUFLO2dCQUVHLE9BQU87c0JBQWYsS0FBSztnQkFFRyxXQUFXO3NCQUFuQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IERlc2NlbmRhbnQgfSBmcm9tICdzbGF0ZSc7XG5pbXBvcnQgeyBTbGF0ZUNoaWxkcmVuQ29udGV4dCwgU2xhdGVWaWV3Q29udGV4dCB9IGZyb20gJy4uLy4uL3ZpZXcvY29udGV4dCc7XG5pbXBvcnQgeyBWaWV3Q29udGFpbmVyIH0gZnJvbSAnLi4vLi4vdmlldy9jb250YWluZXInO1xuaW1wb3J0IHsgTmdGb3IgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ3NsYXRlLWNoaWxkcmVuJyxcbiAgICB0ZW1wbGF0ZTogYGAsXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gICAgc3RhbmRhbG9uZTogdHJ1ZVxufSlcbmV4cG9ydCBjbGFzcyBTbGF0ZUNoaWxkcmVuIGV4dGVuZHMgVmlld0NvbnRhaW5lcjxhbnk+IHtcbiAgICBASW5wdXQoKSBjaGlsZHJlbjogRGVzY2VuZGFudFtdO1xuXG4gICAgQElucHV0KCkgY29udGV4dDogU2xhdGVDaGlsZHJlbkNvbnRleHQ7XG5cbiAgICBASW5wdXQoKSB2aWV3Q29udGV4dDogU2xhdGVWaWV3Q29udGV4dDtcbn1cbiJdfQ==
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: "17.2.4", 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: "17.2.4", 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: "17.2.4", 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: () => [{ 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":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,MAAM,EAAE,KAAK,EAAuC,MAAM,eAAe,CAAC;AACvH,OAAO,EAAE,cAAc,EAAE,MAAM,oCAAoC,CAAC;AACpE,OAAO,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAC;AAC9D,OAAO,EAAc,MAAM,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC;AAE3D,OAAO,EAAE,aAAa,EAAE,MAAM,8BAA8B,CAAC;AAC7D,OAAO,EAAE,aAAa,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAEtE,OAAO,EAAE,gBAAgB,EAAE,MAAM,gCAAgC,CAAC;AAClE,OAAO,EAAE,aAAa,EAAE,MAAM,6BAA6B,CAAC;AAC5D,OAAO,EAAE,yBAAyB,EAAE,MAAM,aAAa,CAAC;AAExD,OAAO,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAC7C,OAAO,EAAE,qCAAqC,EAAE,MAAM,4CAA4C,CAAC;;AAQnG,MAAM,OAAO,eACT,SAAQ,iBAAmG;IAW3G,IAAI,SAAS;QACT,IAAI,IAAI,CAAC,qBAAqB,EAAE,CAAC;YAC7B,OAAO,CAAC,IAAI,CAAC,qBAAqB,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC;QAC/D,CAAC;QACD,OAAO,KAAK,CAAC,YAAY,EAAE,CAAC;IAChC,CAAC;IAED,IAAI,WAAW;QACX,OAAO,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,WAAW,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IAChE,CAAC;IAED,YACc,gBAAkC,EAErC,2BAAgE;QAEvE,KAAK,CAAC,gBAAgB,CAAC,CAAC;QAJd,qBAAgB,GAAhB,gBAAgB,CAAkB;QAErC,gCAA2B,GAA3B,2BAA2B,CAAqC;IAG3E,CAAC;IAED,QAAQ;QACJ,aAAa,CAAC,GAAG,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;QAC/C,cAAc,CAAC,GAAG,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;QACzD,IAAI,CAAC,UAAU,EAAE,CAAC;QAClB,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;YACnB,IAAI,CAAC,eAAe,EAAE,CAAC;QAC3B,CAAC;IACL,CAAC;IAED,WAAW;QACP,KAAK,CAAC,WAAW,EAAE,CAAC;QACpB,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC5B,CAAC;IAED,WAAW;QACP,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;YACpB,OAAO;QACX,CAAC;QACD,aAAa,CAAC,GAAG,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;QAC/C,cAAc,CAAC,GAAG,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;QACzD,IAAI,CAAC,UAAU,EAAE,CAAC;QAClB,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;YACnB,IAAI,CAAC,eAAe,EAAE,CAAC;QAC3B,CAAC;IACL,CAAC;IAED,gBAAgB;QACZ,IAAI,IAAI,CAAC,qBAAqB,EAAE,CAAC;YAC7B,IAAI,CAAC,qBAAqB,CAAC,OAAO,EAAE,CAAC;YACrC,IAAI,CAAC,qBAAqB,GAAG,IAAI,CAAC;QACtC,CAAC;IACL,CAAC;IAED,eAAe;QACX,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC;QACjC,IAAI,CAAC,qBAAqB,GAAG,IAAI,CAAC,gBAAgB,CAAC,eAAe,CAAiB,cAAc,CAAC,CAAC;QACnG,IAAI,CAAC,qBAAqB,CAAC,QAAQ,CAAC,gBAAgB,CAAC,SAAS,CAAC,CAAC;IACpE,CAAC;IAED,eAAe;QACX,IAAI,IAAI,CAAC,qBAAqB,EAAE,CAAC;YAC7B,OAAO;QACX,CAAC;QACD,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC;QACjC,IAAI,CAAC,eAAe,EAAE,CAAC;QACvB,MAAM,aAAa,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC;QACnC,aAAa,CAAC,WAAW,CAAC,IAAI,CAAC,qBAAqB,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC;IACjF,CAAC;IAED,gBAAgB;QACZ,MAAM,IAAI,GAAG,aAAa,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;QAClF,MAAM,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAClC,IAAI,CAAC;YACD,MAAM,KAAK,GAAG,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;YACvD,MAAM,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,SAAS,IAAI,KAAK,CAAC,YAAY,CAAC,KAAK,EAAE,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;YACxF,MAAM,EAAE,GAAG,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC,CAAC,CAAC;YACvD,KAAK,MAAM,GAAG,IAAI,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,CAAC;gBACzC,MAAM,CAAC,GAAG,KAAK,CAAC,YAAY,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;gBACzC,IAAI,CAAC,EAAE,CAAC;oBACJ,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;gBACf,CAAC;YACL,CAAC;YACD,OAAO,EAAE,SAAS,EAAE,GAAG,EAAE,WAAW,EAAE,EAAE,EAAE,CAAC;QAC/C,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACb,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,OAAO,CAAC;gBAC5B,IAAI,EAAE,cAAc,CAAC,kBAAkB;gBACvC,WAAW,EAAE,KAAK;aACrB,CAAC,CAAC;YACH,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,WAAW,EAAE,EAAE,EAAE,CAAC;QAChD,CAAC;IACL,CAAC;IAED,UAAU;QACN,IAAI,OAAO,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC;YACrC,MAAM,eAAe,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;YAChD,MAAM,GAAG,GAAG,aAAa,CAAC,OAAO,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;YAC5E,MAAM,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YACnE,MAAM,MAAM,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YAC/D,MAAM,cAAc,GAAwB;gBACxC,OAAO,EAAE,IAAI,CAAC,UAAU;gBACxB,GAAG,eAAe;gBAClB,UAAU,EAAE;oBACR,iBAAiB,EAAE,SAAS;oBAC5B,gBAAgB,EAAE,GAAG,CAAC,EAAE;iBAC3B;gBACD,QAAQ,EAAE,IAAI,CAAC,OAAO,CAAC,QAAQ;gBAC/B,QAAQ,EAAE,IAAI,CAAC,OAAO,CAAC,QAAQ;aAClC,CAAC;YACF,IAAI,QAAQ,EAAE,CAAC;gBACX,cAAc,CAAC,UAAU,CAAC,mBAAmB,CAAC,GAAG,IAAI,CAAC;YAC1D,CAAC;YACD,IAAI,MAAM,EAAE,CAAC;gBACT,cAAc,CAAC,UAAU,CAAC,iBAAiB,CAAC,GAAG,IAAI,CAAC;gBACpD,cAAc,CAAC,UAAU,CAAC,eAAe,GAAG,KAAK,CAAC;YACtD,CAAC;YACD,OAAO,cAAc,CAAC;QAC1B,CAAC;aAAM,CAAC;YACJ,MAAM,eAAe,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;YAChD,MAAM,WAAW,GAAG,aAAa,CAAC,WAAW,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;YAC5F,MAAM,WAAW,GAAqB;gBAClC,WAAW,EAAE,eAAe,CAAC,WAAW;gBACxC,MAAM,EAAE,WAAW,IAAI,IAAI,CAAC,KAAK,KAAK,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC;gBAC7E,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,MAAiB;gBACtC,IAAI,EAAE,IAAI,CAAC,UAAU;aACxB,CAAC;YACF,OAAO,WAAW,CAAC;QACvB,CAAC;IACL,CAAC;IAED,WAAW;QACP,IAAI,OAAO,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC;YACrC,OAAO,CAAC,IAAI,CAAC,WAAW,CAAC,aAAa,IAAI,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,IAAI,IAAI,CAAC,2BAA2B,CAAC;QACnI,CAAC;aAAM,CAAC;YACJ,MAAM,MAAM,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,MAAiB,CAAC,CAAC;YAC9E,OAAO,MAAM;gBACT,CAAC,CAAC,aAAa;gBACf,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,UAAU,IAAI,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,IAAI,gBAAgB,CAAC;QAC5G,CAAC;IACL,CAAC;IAED,sBAAsB,CAAC,IAAyB,EAAE,IAAyB;QACvE,OAAO,CACH,IAAI,CAAC,OAAO,KAAK,IAAI,CAAC,OAAO;YAC7B,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,gBAAgB,IAAI,IAAI,CAAC,QAAQ,KAAK,IAAI,CAAC,QAAQ,CAAC;YACvE,IAAI,CAAC,QAAQ,KAAK,IAAI,CAAC,QAAQ;YAC/B,yBAAyB,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,WAAW,CAAC;YAC7D,CAAC,IAAI,CAAC,SAAS,KAAK,IAAI,CAAC,SAAS,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,IAAI,CAAC,CAAC,IAAI,CAAC,SAAS,IAAI,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAChI,CAAC;IACN,CAAC;IAED,mBAAmB,CAAC,IAAsB,EAAE,IAAsB;QAC9D,OAAO,CACH,IAAI,CAAC,MAAM,KAAK,IAAI,CAAC,MAAM;YAC3B,IAAI,CAAC,MAAM,KAAK,IAAI,CAAC,MAAM;YAC3B,IAAI,CAAC,IAAI,KAAK,IAAI,CAAC,IAAI;YACvB,yBAAyB,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,WAAW,CAAC,CAChE,CAAC;IACN,CAAC;IAED,eAAe,CAAC,IAA4C,EAAE,IAA4C;QACtG,IAAI,OAAO,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC;YACrC,OAAO,IAAI,CAAC,sBAAsB,CAAC,IAA2B,EAAE,IAA2B,CAAC,CAAC;QACjG,CAAC;aAAM,CAAC;YACJ,OAAO,IAAI,CAAC,mBAAmB,CAAC,IAAwB,EAAE,IAAwB,CAAC,CAAC;QACxF,CAAC;IACL,CAAC;8GAhLQ,eAAe,kDAyBZ,qCAAqC;kGAzBxC,eAAe,8NAJd,EAAE;;2FAIH,eAAe;kBAN3B,SAAS;mBAAC;oBACP,QAAQ,EAAE,kBAAkB;oBAC5B,QAAQ,EAAE,EAAE;oBACZ,eAAe,EAAE,uBAAuB,CAAC,MAAM;oBAC/C,UAAU,EAAE,IAAI;iBACnB;;0BA0BQ,MAAM;2BAAC,qCAAqC;yCArBxC,UAAU;sBAAlB,KAAK;gBAEG,OAAO;sBAAf,KAAK;gBAEG,WAAW;sBAAnB,KAAK;gBAEG,KAAK;sBAAb,KAAK","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"]}