slate-angular 17.0.0 → 17.1.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 (57) hide show
  1. package/components/children/children-outlet.component.d.ts +9 -0
  2. package/components/children/children.component.d.ts +1 -6
  3. package/components/editable/editable.component.d.ts +15 -5
  4. package/components/leaf/token.d.ts +4 -0
  5. package/components/leaves/leaves.component.d.ts +1 -14
  6. package/components/string/default-string.component.d.ts +1 -1
  7. package/components/string/string.component.d.ts +8 -0
  8. package/components/text/token.d.ts +5 -0
  9. package/components/text/void-text.component.d.ts +0 -1
  10. package/esm2022/components/block-card/block-card.component.mjs +2 -2
  11. package/esm2022/components/children/children-outlet.component.mjs +22 -0
  12. package/esm2022/components/children/children.component.mjs +5 -33
  13. package/esm2022/components/editable/editable.component.mjs +141 -48
  14. package/esm2022/components/element/default-element.component.mjs +3 -3
  15. package/esm2022/components/element/element.component.mjs +3 -3
  16. package/esm2022/components/leaf/token.mjs +3 -0
  17. package/esm2022/components/leaves/leaves.component.mjs +5 -50
  18. package/esm2022/components/string/default-string.component.mjs +1 -1
  19. package/esm2022/components/string/string.component.mjs +16 -6
  20. package/esm2022/components/text/default-text.component.mjs +3 -3
  21. package/esm2022/components/text/token.mjs +4 -0
  22. package/esm2022/components/text/void-text.component.mjs +3 -7
  23. package/esm2022/module.mjs +7 -22
  24. package/esm2022/plugins/angular-editor.mjs +65 -20
  25. package/esm2022/plugins/with-angular.mjs +5 -4
  26. package/esm2022/public-api.mjs +3 -2
  27. package/esm2022/utils/constants.mjs +2 -0
  28. package/esm2022/utils/index.mjs +2 -1
  29. package/esm2022/utils/throttle.mjs +18 -0
  30. package/esm2022/view/base.mjs +71 -17
  31. package/esm2022/view/container.mjs +2 -82
  32. package/esm2022/view/context-change.mjs +13 -0
  33. package/esm2022/view/context.mjs +1 -1
  34. package/esm2022/view/render/leaves-render.mjs +107 -0
  35. package/esm2022/view/render/list-render.mjs +292 -0
  36. package/esm2022/view/render/utils.mjs +115 -0
  37. package/fesm2022/slate-angular.mjs +1159 -786
  38. package/fesm2022/slate-angular.mjs.map +1 -1
  39. package/module.d.ts +7 -8
  40. package/package.json +7 -7
  41. package/plugins/angular-editor.d.ts +16 -5
  42. package/public-api.d.ts +2 -1
  43. package/utils/constants.d.ts +1 -0
  44. package/utils/index.d.ts +1 -0
  45. package/utils/throttle.d.ts +2 -0
  46. package/view/base.d.ts +17 -4
  47. package/view/container.d.ts +3 -7
  48. package/view/{before-context-change.d.ts → context-change.d.ts} +4 -0
  49. package/view/context.d.ts +7 -2
  50. package/view/render/leaves-render.d.ts +21 -0
  51. package/view/render/list-render.d.ts +35 -0
  52. package/view/render/utils.d.ts +11 -0
  53. package/components/descendant/descendant.component.d.ts +0 -35
  54. package/components/leaf/leaf.component.d.ts +0 -16
  55. package/esm2022/components/descendant/descendant.component.mjs +0 -186
  56. package/esm2022/components/leaf/leaf.component.mjs +0 -38
  57. package/esm2022/view/before-context-change.mjs +0 -7
@@ -0,0 +1,115 @@
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 executeAfterViewInit(view) {
24
+ if (view instanceof ComponentRef && view.instance.afterViewInit) {
25
+ view.instance.afterViewInit();
26
+ }
27
+ }
28
+ export function updateContext(view, newContext, viewContext) {
29
+ if (view instanceof ComponentRef) {
30
+ view.instance.context = newContext;
31
+ }
32
+ else {
33
+ const embeddedViewContext = {
34
+ context: newContext,
35
+ viewContext
36
+ };
37
+ view.context = embeddedViewContext;
38
+ view.detectChanges();
39
+ }
40
+ }
41
+ export function mount(views, blockCards, outletParent, outletElement) {
42
+ if (views.length > 0) {
43
+ const fragment = document.createDocumentFragment();
44
+ views.forEach((view, index) => {
45
+ const blockCard = blockCards ? blockCards[index] : undefined;
46
+ fragment.append(...getRootNodes(view, blockCard));
47
+ });
48
+ if (outletElement) {
49
+ outletElement.parentElement.insertBefore(fragment, outletElement);
50
+ outletElement.remove();
51
+ }
52
+ else {
53
+ outletParent.prepend(fragment);
54
+ }
55
+ }
56
+ }
57
+ export function getRootNodes(ref, blockCard) {
58
+ if (blockCard) {
59
+ return [blockCard.instance.nativeElement];
60
+ }
61
+ if (ref instanceof ComponentRef) {
62
+ ref.hostView.rootNodes.forEach(ele => {
63
+ if (!(ele instanceof HTMLElement)) {
64
+ ele.remove();
65
+ }
66
+ });
67
+ return [ref.instance.nativeElement];
68
+ }
69
+ else {
70
+ const result = [];
71
+ ref.rootNodes.forEach(rootNode => {
72
+ const isHTMLElement = rootNode instanceof HTMLElement;
73
+ const isSlateNodeOfLeaf = isHTMLElement && (rootNode.hasAttribute('data-slate-node') || rootNode.hasAttribute('data-slate-leaf'));
74
+ if (isSlateNodeOfLeaf && result.every(item => !item.contains(rootNode))) {
75
+ result.push(rootNode);
76
+ }
77
+ if (!isHTMLElement) {
78
+ rootNode.remove();
79
+ }
80
+ });
81
+ return result;
82
+ }
83
+ }
84
+ export function mountOnItemChange(index, item, views, blockCards, outletParent, firstRootNode, viewContext) {
85
+ const view = views[index];
86
+ let rootNodes = getRootNodes(view);
87
+ if (blockCards) {
88
+ const isBlockCard = viewContext.editor.isBlockCard(item);
89
+ if (isBlockCard) {
90
+ const blockCard = blockCards[index];
91
+ rootNodes = [blockCard.instance.nativeElement];
92
+ }
93
+ }
94
+ if (index === 0) {
95
+ if (firstRootNode) {
96
+ rootNodes.forEach(rootNode => {
97
+ firstRootNode.insertAdjacentElement('beforebegin', rootNode);
98
+ });
99
+ }
100
+ else {
101
+ outletParent.prepend(...rootNodes);
102
+ }
103
+ }
104
+ else {
105
+ const previousView = views[index - 1];
106
+ const blockCard = blockCards ? blockCards[index - 1] : null;
107
+ const previousRootNodes = getRootNodes(previousView, blockCard);
108
+ let previousRootNode = previousRootNodes[previousRootNodes.length - 1];
109
+ rootNodes.forEach(rootNode => {
110
+ previousRootNode.insertAdjacentElement('afterend', rootNode);
111
+ previousRootNode = rootNode;
112
+ });
113
+ }
114
+ }
115
+ //# 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 executeAfterViewInit(view: EmbeddedViewRef<any> | ComponentRef<any>) {\n    if (view instanceof ComponentRef && view.instance.afterViewInit) {\n        view.instance.afterViewInit();\n    }\n}\n\nexport function updateContext(\n    view: EmbeddedViewRef<any> | ComponentRef<any>,\n    newContext: SlateElementContext | SlateTextContext | SlateLeafContext,\n    viewContext: SlateViewContext\n) {\n    if (view instanceof ComponentRef) {\n        view.instance.context = newContext;\n    } else {\n        const embeddedViewContext = {\n            context: newContext,\n            viewContext\n        };\n        view.context = embeddedViewContext;\n        view.detectChanges();\n    }\n}\n\nexport function mount(\n    views: (EmbeddedViewRef<any> | ComponentRef<any>)[],\n    blockCards: (ComponentRef<SlateBlockCard> | null)[] | null,\n    outletParent: HTMLElement,\n    outletElement: HTMLElement | null\n) {\n    if (views.length > 0) {\n        const fragment = document.createDocumentFragment();\n        views.forEach((view, index) => {\n            const blockCard = blockCards ? blockCards[index] : undefined;\n            fragment.append(...getRootNodes(view, blockCard));\n        });\n        if (outletElement) {\n            outletElement.parentElement.insertBefore(fragment, outletElement);\n            outletElement.remove();\n        } else {\n            outletParent.prepend(fragment);\n        }\n    }\n}\n\nexport function getRootNodes(ref: EmbeddedViewRef<any> | ComponentRef<any>, blockCard?: ComponentRef<SlateBlockCard>): HTMLElement[] {\n    if (blockCard) {\n        return [blockCard.instance.nativeElement];\n    }\n    if (ref instanceof ComponentRef) {\n        ((ref.hostView as any).rootNodes as (HTMLElement | any)[]).forEach(ele => {\n            if (!(ele instanceof HTMLElement)) {\n                ele.remove();\n            }\n        });\n        return [ref.instance.nativeElement];\n    } else {\n        const result: HTMLElement[] = [];\n        ref.rootNodes.forEach(rootNode => {\n            const isHTMLElement = rootNode instanceof HTMLElement;\n            const isSlateNodeOfLeaf =\n                isHTMLElement && (rootNode.hasAttribute('data-slate-node') || rootNode.hasAttribute('data-slate-leaf'));\n            if (isSlateNodeOfLeaf && result.every(item => !item.contains(rootNode))) {\n                result.push(rootNode);\n            }\n            if (!isHTMLElement) {\n                rootNode.remove();\n            }\n        });\n        return result;\n    }\n}\n\nexport function mountOnItemChange(\n    index: number,\n    item: Descendant,\n    views: (EmbeddedViewRef<any> | ComponentRef<any>)[],\n    blockCards: (ComponentRef<SlateBlockCard> | null)[] | null,\n    outletParent: HTMLElement,\n    firstRootNode: HTMLElement | null,\n    viewContext: SlateViewContext\n) {\n    const view = views[index];\n    let rootNodes = getRootNodes(view);\n    if (blockCards) {\n        const isBlockCard = viewContext.editor.isBlockCard(item);\n        if (isBlockCard) {\n            const blockCard = blockCards[index];\n            rootNodes = [blockCard.instance.nativeElement];\n        }\n    }\n    if (index === 0) {\n        if (firstRootNode) {\n            rootNodes.forEach(rootNode => {\n                firstRootNode.insertAdjacentElement('beforebegin', rootNode);\n            });\n        } else {\n            outletParent.prepend(...rootNodes);\n        }\n    } else {\n        const previousView = views[index - 1];\n        const blockCard = blockCards ? blockCards[index - 1] : null;\n        const previousRootNodes = getRootNodes(previousView, blockCard);\n        let previousRootNode = previousRootNodes[previousRootNodes.length - 1];\n        rootNodes.forEach(rootNode => {\n            previousRootNode.insertAdjacentElement('afterend', rootNode);\n            previousRootNode = rootNode;\n        });\n    }\n}\n"]}