slate-angular 16.1.0-next → 16.1.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.
Files changed (39) hide show
  1. package/components/children/children.component.d.ts +1 -6
  2. package/components/editable/editable.component.d.ts +16 -5
  3. package/components/leaf/token.d.ts +4 -0
  4. package/components/leaves/leaves.component.d.ts +1 -14
  5. package/components/string/string.component.d.ts +8 -0
  6. package/components/text/token.d.ts +5 -0
  7. package/esm2022/components/children/children.component.mjs +5 -31
  8. package/esm2022/components/editable/editable.component.mjs +120 -37
  9. package/esm2022/components/element/default-element.component.mjs +3 -3
  10. package/esm2022/components/element/element.component.mjs +3 -3
  11. package/esm2022/components/leaf/token.mjs +3 -0
  12. package/esm2022/components/leaves/leaves.component.mjs +5 -50
  13. package/esm2022/components/string/string.component.mjs +16 -6
  14. package/esm2022/components/text/default-text.component.mjs +3 -3
  15. package/esm2022/components/text/token.mjs +4 -0
  16. package/esm2022/components/text/void-text.component.mjs +3 -3
  17. package/esm2022/module.mjs +1 -7
  18. package/esm2022/utils/throttle.mjs +18 -0
  19. package/esm2022/view/base.mjs +26 -9
  20. package/esm2022/view/container.mjs +2 -82
  21. package/esm2022/view/context.mjs +1 -1
  22. package/esm2022/view/render/leaves-render.mjs +105 -0
  23. package/esm2022/view/render/list-render.mjs +250 -0
  24. package/esm2022/view/render/utils.mjs +104 -0
  25. package/fesm2022/slate-angular.mjs +914 -702
  26. package/fesm2022/slate-angular.mjs.map +1 -1
  27. package/module.d.ts +6 -8
  28. package/package.json +1 -1
  29. package/utils/throttle.d.ts +2 -0
  30. package/view/base.d.ts +11 -2
  31. package/view/container.d.ts +3 -7
  32. package/view/context.d.ts +8 -2
  33. package/view/render/leaves-render.d.ts +20 -0
  34. package/view/render/list-render.d.ts +31 -0
  35. package/view/render/utils.d.ts +11 -0
  36. package/components/descendant/descendant.component.d.ts +0 -35
  37. package/components/leaf/leaf.component.d.ts +0 -16
  38. package/esm2022/components/descendant/descendant.component.mjs +0 -186
  39. package/esm2022/components/leaf/leaf.component.mjs +0 -38
@@ -0,0 +1,104 @@
1
+ import { ComponentRef } from '@angular/core';
2
+ import { isComponentType, isTemplateRef } from '../../utils/view';
3
+ export function createEmbeddedViewOrComponent(viewType, context, viewContext, viewContainerRef) {
4
+ if (isTemplateRef(viewType)) {
5
+ const embeddedViewContext = {
6
+ context,
7
+ viewContext
8
+ };
9
+ const embeddedViewRef = viewContainerRef.createEmbeddedView(viewType, embeddedViewContext);
10
+ embeddedViewRef.detectChanges();
11
+ return embeddedViewRef;
12
+ }
13
+ if (isComponentType(viewType)) {
14
+ const componentRef = viewContainerRef.createComponent(viewType, {
15
+ injector: viewContainerRef.injector
16
+ });
17
+ componentRef.instance.viewContext = viewContext;
18
+ componentRef.instance.context = context;
19
+ componentRef.changeDetectorRef.detectChanges();
20
+ return componentRef;
21
+ }
22
+ }
23
+ export function renderView(view) {
24
+ if (view instanceof ComponentRef) {
25
+ view.changeDetectorRef.detectChanges();
26
+ }
27
+ else {
28
+ view.detectChanges();
29
+ }
30
+ }
31
+ export function updateContext(view, newContext, viewContext) {
32
+ if (view instanceof ComponentRef) {
33
+ view.instance.context = newContext;
34
+ }
35
+ else {
36
+ const embeddedViewContext = {
37
+ context: newContext,
38
+ viewContext
39
+ };
40
+ view.context = embeddedViewContext;
41
+ view.detectChanges();
42
+ }
43
+ }
44
+ export function mount(views, blockCards, outletElement) {
45
+ if (views.length > 0) {
46
+ const result = [];
47
+ views.forEach((view, index) => {
48
+ const blockCard = blockCards ? blockCards[index] : undefined;
49
+ result.push(...getRootNodes(view, blockCard));
50
+ });
51
+ outletElement.append(...result);
52
+ }
53
+ }
54
+ export function getRootNodes(ref, blockCard) {
55
+ if (blockCard) {
56
+ return [blockCard.instance.nativeElement];
57
+ }
58
+ if (ref instanceof ComponentRef) {
59
+ ref.hostView.rootNodes.forEach(ele => {
60
+ if (!(ele instanceof HTMLElement)) {
61
+ ele.remove();
62
+ }
63
+ });
64
+ return [ref.instance.nativeElement];
65
+ }
66
+ else {
67
+ const result = [];
68
+ ref.rootNodes.forEach(rootNode => {
69
+ const isHTMLElement = rootNode instanceof HTMLElement;
70
+ if (isHTMLElement && result.every(item => !item.contains(rootNode))) {
71
+ result.push(rootNode);
72
+ }
73
+ if (!isHTMLElement) {
74
+ rootNode.remove();
75
+ }
76
+ });
77
+ return result;
78
+ }
79
+ }
80
+ export function mountOnItemChange(index, item, views, blockCards, outletElement, viewContext) {
81
+ const view = views[index];
82
+ let rootNodes = getRootNodes(view);
83
+ if (blockCards) {
84
+ const isBlockCard = viewContext.editor.isBlockCard(item);
85
+ if (isBlockCard) {
86
+ const blockCard = blockCards[index];
87
+ rootNodes = [blockCard.instance.nativeElement];
88
+ }
89
+ }
90
+ if (index === 0) {
91
+ outletElement.prepend(...rootNodes);
92
+ }
93
+ else {
94
+ const previousView = views[index - 1];
95
+ const blockCard = blockCards ? blockCards[index - 1] : null;
96
+ const previousRootNodes = getRootNodes(previousView, blockCard);
97
+ let previousRootNode = previousRootNodes[previousRootNodes.length - 1];
98
+ rootNodes.forEach(rootNode => {
99
+ previousRootNode.insertAdjacentElement('afterend', rootNode);
100
+ previousRootNode = rootNode;
101
+ });
102
+ }
103
+ }
104
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../packages/src/view/render/utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { Descendant } from 'slate';\nimport { ComponentRef, EmbeddedViewRef, ViewContainerRef } from '@angular/core';\nimport { ViewType } from '../../types/view';\nimport { isComponentType, isTemplateRef } from '../../utils/view';\nimport { SlateElementContext, SlateLeafContext, SlateTextContext, SlateViewContext } from '../context';\nimport { SlateBlockCard } from '../../components/block-card/block-card.component';\n\nexport function createEmbeddedViewOrComponent(\n    viewType: ViewType,\n    context: any,\n    viewContext: SlateViewContext,\n    viewContainerRef: ViewContainerRef\n) {\n    if (isTemplateRef(viewType)) {\n        const embeddedViewContext = {\n            context,\n            viewContext\n        };\n        const embeddedViewRef = viewContainerRef.createEmbeddedView<any>(viewType, embeddedViewContext);\n        embeddedViewRef.detectChanges();\n        return embeddedViewRef;\n    }\n    if (isComponentType(viewType)) {\n        const componentRef = viewContainerRef.createComponent(viewType, {\n            injector: viewContainerRef.injector\n        }) as ComponentRef<any>;\n        componentRef.instance.viewContext = viewContext;\n        componentRef.instance.context = context;\n        componentRef.changeDetectorRef.detectChanges();\n        return componentRef;\n    }\n}\n\nexport function renderView(view: EmbeddedViewRef<any> | ComponentRef<any>) {\n    if (view instanceof ComponentRef) {\n        view.changeDetectorRef.detectChanges();\n    } else {\n        view.detectChanges();\n    }\n}\n\nexport function updateContext(\n    view: EmbeddedViewRef<any> | ComponentRef<any>,\n    newContext: SlateElementContext | SlateTextContext | SlateLeafContext,\n    viewContext: SlateViewContext\n) {\n    if (view instanceof ComponentRef) {\n        view.instance.context = newContext;\n    } else {\n        const embeddedViewContext = {\n            context: newContext,\n            viewContext\n        };\n        view.context = embeddedViewContext;\n        view.detectChanges();\n    }\n}\n\nexport function mount(\n    views: (EmbeddedViewRef<any> | ComponentRef<any>)[],\n    blockCards: (ComponentRef<SlateBlockCard> | null)[] | null,\n    outletElement: HTMLElement\n) {\n    if (views.length > 0) {\n        const result = [];\n        views.forEach((view, index) => {\n            const blockCard = blockCards ? blockCards[index] : undefined;\n            result.push(...getRootNodes(view, blockCard));\n        });\n        outletElement.append(...result);\n    }\n}\n\nexport function getRootNodes(ref: EmbeddedViewRef<any> | ComponentRef<any>, blockCard?: ComponentRef<SlateBlockCard>): HTMLElement[] {\n    if (blockCard) {\n        return [blockCard.instance.nativeElement];\n    }\n    if (ref instanceof ComponentRef) {\n        ((ref.hostView as any).rootNodes as (HTMLElement | any)[]).forEach(ele => {\n            if (!(ele instanceof HTMLElement)) {\n                ele.remove();\n            }\n        });\n        return [ref.instance.nativeElement];\n    } else {\n        const result: HTMLElement[] = [];\n        ref.rootNodes.forEach(rootNode => {\n            const isHTMLElement = rootNode instanceof HTMLElement;\n            if (isHTMLElement && result.every(item => !item.contains(rootNode))) {\n                result.push(rootNode);\n            }\n            if (!isHTMLElement) {\n                rootNode.remove();\n            }\n        });\n        return result;\n    }\n}\n\nexport function mountOnItemChange(\n    index: number,\n    item: Descendant,\n    views: (EmbeddedViewRef<any> | ComponentRef<any>)[],\n    blockCards: (ComponentRef<SlateBlockCard> | null)[] | null,\n    outletElement: HTMLElement,\n    viewContext: SlateViewContext\n) {\n    const view = views[index];\n    let rootNodes = getRootNodes(view);\n    if (blockCards) {\n        const isBlockCard = viewContext.editor.isBlockCard(item);\n        if (isBlockCard) {\n            const blockCard = blockCards[index];\n            rootNodes = [blockCard.instance.nativeElement];\n        }\n    }\n    if (index === 0) {\n        outletElement.prepend(...rootNodes);\n    } else {\n        const previousView = views[index - 1];\n        const blockCard = blockCards ? blockCards[index - 1] : null;\n        const previousRootNodes = getRootNodes(previousView, blockCard);\n        let previousRootNode = previousRootNodes[previousRootNodes.length - 1];\n        rootNodes.forEach(rootNode => {\n            previousRootNode.insertAdjacentElement('afterend', rootNode);\n            previousRootNode = rootNode;\n        });\n    }\n}\n"]}