@plait/mind 0.27.0-next.1 → 0.27.0-next.2

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 (106) hide show
  1. package/base/emoji-base.component.d.ts +1 -1
  2. package/base/image-base.component.d.ts +1 -1
  3. package/constants/node-topic-style.d.ts +3 -0
  4. package/{esm2020 → esm2022}/base/emoji-base.component.mjs +4 -4
  5. package/esm2022/base/image-base.component.mjs +75 -0
  6. package/{esm2020 → esm2022}/constants/node-topic-style.mjs +4 -1
  7. package/esm2022/interfaces/element-data.mjs +2 -0
  8. package/{esm2020 → esm2022}/mind.component.mjs +6 -6
  9. package/{esm2020 → esm2022}/mind.module.mjs +5 -5
  10. package/esm2022/node.component.mjs +251 -0
  11. package/{fesm2020 → fesm2022}/plait-mind.mjs +33 -24
  12. package/fesm2022/plait-mind.mjs.map +1 -0
  13. package/interfaces/element-data.d.ts +2 -2
  14. package/package.json +7 -13
  15. package/utils/abstract/common.d.ts +2 -2
  16. package/esm2020/base/image-base.component.mjs +0 -72
  17. package/esm2020/interfaces/element-data.mjs +0 -2
  18. package/esm2020/node.component.mjs +0 -248
  19. package/fesm2015/plait-mind.mjs +0 -4382
  20. package/fesm2015/plait-mind.mjs.map +0 -1
  21. package/fesm2020/plait-mind.mjs.map +0 -1
  22. /package/{esm2020 → esm2022}/base/base.drawer.mjs +0 -0
  23. /package/{esm2020 → esm2022}/base/index.mjs +0 -0
  24. /package/{esm2020 → esm2022}/constants/abstract-node.mjs +0 -0
  25. /package/{esm2020 → esm2022}/constants/default.mjs +0 -0
  26. /package/{esm2020 → esm2022}/constants/image.mjs +0 -0
  27. /package/{esm2020 → esm2022}/constants/index.mjs +0 -0
  28. /package/{esm2020 → esm2022}/constants/node-style.mjs +0 -0
  29. /package/{esm2020 → esm2022}/constants/theme.mjs +0 -0
  30. /package/{esm2020 → esm2022}/drawer/node-active.drawer.mjs +0 -0
  31. /package/{esm2020 → esm2022}/drawer/node-collapse.drawer.mjs +0 -0
  32. /package/{esm2020 → esm2022}/drawer/node-emojis.drawer.mjs +0 -0
  33. /package/{esm2020 → esm2022}/drawer/node-image.drawer.mjs +0 -0
  34. /package/{esm2020 → esm2022}/drawer/node-insert.drawer.mjs +0 -0
  35. /package/{esm2020 → esm2022}/interfaces/element.mjs +0 -0
  36. /package/{esm2020 → esm2022}/interfaces/index.mjs +0 -0
  37. /package/{esm2020 → esm2022}/interfaces/layout.mjs +0 -0
  38. /package/{esm2020 → esm2022}/interfaces/node.mjs +0 -0
  39. /package/{esm2020 → esm2022}/interfaces/options.mjs +0 -0
  40. /package/{esm2020 → esm2022}/interfaces/pointer.mjs +0 -0
  41. /package/{esm2020 → esm2022}/interfaces/theme-color.mjs +0 -0
  42. /package/{esm2020 → esm2022}/interfaces/types.mjs +0 -0
  43. /package/{esm2020 → esm2022}/plait-mind.mjs +0 -0
  44. /package/{esm2020 → esm2022}/plugins/with-abstract-resize.board.mjs +0 -0
  45. /package/{esm2020 → esm2022}/plugins/with-abstract-resize.mjs +0 -0
  46. /package/{esm2020 → esm2022}/plugins/with-mind-create.mjs +0 -0
  47. /package/{esm2020 → esm2022}/plugins/with-mind-extend.mjs +0 -0
  48. /package/{esm2020 → esm2022}/plugins/with-mind-hotkey.mjs +0 -0
  49. /package/{esm2020 → esm2022}/plugins/with-mind.board.mjs +0 -0
  50. /package/{esm2020 → esm2022}/plugins/with-mind.mjs +0 -0
  51. /package/{esm2020 → esm2022}/plugins/with-node-dnd.mjs +0 -0
  52. /package/{esm2020 → esm2022}/plugins/with-node-hover-detect.mjs +0 -0
  53. /package/{esm2020 → esm2022}/plugins/with-node-image-resize.mjs +0 -0
  54. /package/{esm2020 → esm2022}/plugins/with-node-image.mjs +0 -0
  55. /package/{esm2020 → esm2022}/plugins/with-node-resize.mjs +0 -0
  56. /package/{esm2020 → esm2022}/public-api.mjs +0 -0
  57. /package/{esm2020 → esm2022}/queries/get-available-sublayouts-by-element.mjs +0 -0
  58. /package/{esm2020 → esm2022}/queries/get-branch-layouts.mjs +0 -0
  59. /package/{esm2020 → esm2022}/queries/get-correct-layout-by-element.mjs +0 -0
  60. /package/{esm2020 → esm2022}/queries/get-layout-by-element.mjs +0 -0
  61. /package/{esm2020 → esm2022}/queries/index.mjs +0 -0
  62. /package/{esm2020 → esm2022}/transforms/abstract-node.mjs +0 -0
  63. /package/{esm2020 → esm2022}/transforms/emoji.mjs +0 -0
  64. /package/{esm2020 → esm2022}/transforms/image.mjs +0 -0
  65. /package/{esm2020 → esm2022}/transforms/index.mjs +0 -0
  66. /package/{esm2020 → esm2022}/transforms/layout.mjs +0 -0
  67. /package/{esm2020 → esm2022}/transforms/node.mjs +0 -0
  68. /package/{esm2020 → esm2022}/utils/abstract/common.mjs +0 -0
  69. /package/{esm2020 → esm2022}/utils/abstract/resize.mjs +0 -0
  70. /package/{esm2020 → esm2022}/utils/clipboard.mjs +0 -0
  71. /package/{esm2020 → esm2022}/utils/dnd/common.mjs +0 -0
  72. /package/{esm2020 → esm2022}/utils/dnd/detector.mjs +0 -0
  73. /package/{esm2020 → esm2022}/utils/draw/abstract-outline.mjs +0 -0
  74. /package/{esm2020 → esm2022}/utils/draw/node-dnd.mjs +0 -0
  75. /package/{esm2020 → esm2022}/utils/draw/node-link/abstract-link.mjs +0 -0
  76. /package/{esm2020 → esm2022}/utils/draw/node-link/draw-link.mjs +0 -0
  77. /package/{esm2020 → esm2022}/utils/draw/node-link/indented-link.mjs +0 -0
  78. /package/{esm2020 → esm2022}/utils/draw/node-link/logic-link.mjs +0 -0
  79. /package/{esm2020 → esm2022}/utils/draw/node-shape.mjs +0 -0
  80. /package/{esm2020 → esm2022}/utils/index.mjs +0 -0
  81. /package/{esm2020 → esm2022}/utils/layout.mjs +0 -0
  82. /package/{esm2020 → esm2022}/utils/mind.mjs +0 -0
  83. /package/{esm2020 → esm2022}/utils/node/adjust-node.mjs +0 -0
  84. /package/{esm2020 → esm2022}/utils/node/common.mjs +0 -0
  85. /package/{esm2020 → esm2022}/utils/node/create-node.mjs +0 -0
  86. /package/{esm2020 → esm2022}/utils/node/dynamic-width.mjs +0 -0
  87. /package/{esm2020 → esm2022}/utils/node/image.mjs +0 -0
  88. /package/{esm2020 → esm2022}/utils/node/index.mjs +0 -0
  89. /package/{esm2020 → esm2022}/utils/node/right-node-count.mjs +0 -0
  90. /package/{esm2020 → esm2022}/utils/node-hover/extend.mjs +0 -0
  91. /package/{esm2020 → esm2022}/utils/node-style/branch.mjs +0 -0
  92. /package/{esm2020 → esm2022}/utils/node-style/common.mjs +0 -0
  93. /package/{esm2020 → esm2022}/utils/node-style/index.mjs +0 -0
  94. /package/{esm2020 → esm2022}/utils/node-style/shape.mjs +0 -0
  95. /package/{esm2020 → esm2022}/utils/path.mjs +0 -0
  96. /package/{esm2020 → esm2022}/utils/point-placement.mjs +0 -0
  97. /package/{esm2020 → esm2022}/utils/position/emoji.mjs +0 -0
  98. /package/{esm2020 → esm2022}/utils/position/image.mjs +0 -0
  99. /package/{esm2020 → esm2022}/utils/position/index.mjs +0 -0
  100. /package/{esm2020 → esm2022}/utils/position/node.mjs +0 -0
  101. /package/{esm2020 → esm2022}/utils/position/topic.mjs +0 -0
  102. /package/{esm2020 → esm2022}/utils/space/emoji.mjs +0 -0
  103. /package/{esm2020 → esm2022}/utils/space/index.mjs +0 -0
  104. /package/{esm2020 → esm2022}/utils/space/layout-options.mjs +0 -0
  105. /package/{esm2020 → esm2022}/utils/space/node-space.mjs +0 -0
  106. /package/{esm2020 → esm2022}/utils/weak-maps.mjs +0 -0
@@ -1,4 +1,4 @@
1
- import { Element } from 'slate';
1
+ import { ParagraphElement } from '@plait/text';
2
2
  export interface EmojiItem {
3
3
  name: string;
4
4
  }
@@ -8,7 +8,7 @@ export interface ImageItem {
8
8
  height: number;
9
9
  }
10
10
  export interface BaseData {
11
- topic: Element;
11
+ topic: ParagraphElement;
12
12
  emojis?: EmojiItem[];
13
13
  image?: ImageItem;
14
14
  }
package/package.json CHANGED
@@ -1,18 +1,14 @@
1
1
  {
2
2
  "name": "@plait/mind",
3
- "version": "0.27.0-next.1",
3
+ "version": "0.27.0-next.2",
4
4
  "peerDependencies": {
5
- "@angular/common": "^15.2.2",
6
- "@angular/core": "^15.2.2"
5
+ "@angular/common": "^16.0.0",
6
+ "@angular/core": "^16.0.0"
7
7
  },
8
8
  "dependencies": {
9
9
  "tslib": "^2.3.0"
10
10
  },
11
- "module": "fesm2015/plait-mind.mjs",
12
- "es2020": "fesm2020/plait-mind.mjs",
13
- "esm2020": "esm2020/plait-mind.mjs",
14
- "fesm2020": "fesm2020/plait-mind.mjs",
15
- "fesm2015": "fesm2015/plait-mind.mjs",
11
+ "module": "fesm2022/plait-mind.mjs",
16
12
  "typings": "index.d.ts",
17
13
  "exports": {
18
14
  "./package.json": {
@@ -20,11 +16,9 @@
20
16
  },
21
17
  ".": {
22
18
  "types": "./index.d.ts",
23
- "esm2020": "./esm2020/plait-mind.mjs",
24
- "es2020": "./fesm2020/plait-mind.mjs",
25
- "es2015": "./fesm2015/plait-mind.mjs",
26
- "node": "./fesm2015/plait-mind.mjs",
27
- "default": "./fesm2020/plait-mind.mjs"
19
+ "esm2022": "./esm2022/plait-mind.mjs",
20
+ "esm": "./esm2022/plait-mind.mjs",
21
+ "default": "./fesm2022/plait-mind.mjs"
28
22
  }
29
23
  },
30
24
  "sideEffects": false
@@ -25,6 +25,6 @@ export declare function getRelativeStartEndByAbstractRef(abstractRef: AbstractRe
25
25
  start: number;
26
26
  end: number;
27
27
  };
28
- export declare const insertElementHandleAbstract: (board: PlaitBoard, path: Path, step?: number, isExtendPreviousNode?: boolean, effectedAbstracts?: Map<MindElement<import("@plait/mind").BaseData>, Pick<AbstractNode, "end" | "start">>) => Map<MindElement<import("@plait/mind").BaseData>, Pick<AbstractNode, "end" | "start">>;
29
- export declare const deleteElementHandleAbstract: (board: PlaitBoard, deletableElements: MindElement[], effectedAbstracts?: Map<MindElement<import("@plait/mind").BaseData>, Pick<AbstractNode, "end" | "start">>) => Map<MindElement<import("@plait/mind").BaseData>, Pick<AbstractNode, "end" | "start">>;
28
+ export declare const insertElementHandleAbstract: (board: PlaitBoard, path: Path, step?: number, isExtendPreviousNode?: boolean, effectedAbstracts?: Map<MindElement<import("@plait/mind").BaseData>, Pick<AbstractNode, "start" | "end">>) => Map<MindElement<import("@plait/mind").BaseData>, Pick<AbstractNode, "start" | "end">>;
29
+ export declare const deleteElementHandleAbstract: (board: PlaitBoard, deletableElements: MindElement[], effectedAbstracts?: Map<MindElement<import("@plait/mind").BaseData>, Pick<AbstractNode, "start" | "end">>) => Map<MindElement<import("@plait/mind").BaseData>, Pick<AbstractNode, "start" | "end">>;
30
30
  export declare const isChildOfAbstract: (board: PlaitBoard, element: MindElement) => boolean;
@@ -1,72 +0,0 @@
1
- import { Directive, Input } from '@angular/core';
2
- import { PlaitElement } from '@plait/core';
3
- import { ActiveGenerator } from '@plait/common';
4
- import { getImageForeignRectangle } from '../utils/position/image';
5
- import * as i0 from "@angular/core";
6
- export class MindImageBaseComponent {
7
- set imageItem(value) {
8
- this.afterImageItemChange(this._imageItem, value);
9
- this._imageItem = value;
10
- this.drawFocus();
11
- }
12
- get imageItem() {
13
- return this._imageItem;
14
- }
15
- set isFocus(value) {
16
- this._isFocus = value;
17
- this.drawFocus();
18
- }
19
- get isFocus() {
20
- return this._isFocus;
21
- }
22
- get nativeElement() {
23
- return this.elementRef.nativeElement;
24
- }
25
- constructor(elementRef, cdr) {
26
- this.elementRef = elementRef;
27
- this.cdr = cdr;
28
- this.initialized = false;
29
- }
30
- ngOnInit() {
31
- this.activeGenerator = new ActiveGenerator(this.board, {
32
- activeStrokeWidth: 1,
33
- getRectangle: (element) => {
34
- return getImageForeignRectangle(this.board, this.element);
35
- },
36
- getStrokeWidthByElement: () => {
37
- return 0;
38
- }
39
- });
40
- this.initialized = true;
41
- }
42
- drawFocus() {
43
- if (this.initialized) {
44
- const com = PlaitElement.getComponent(this.element);
45
- this.activeGenerator.draw(this.element, com.g, { selected: this._isFocus });
46
- }
47
- }
48
- ngOnDestroy() {
49
- if (this.activeGenerator) {
50
- this.activeGenerator.destroy();
51
- }
52
- }
53
- }
54
- MindImageBaseComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: MindImageBaseComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Directive });
55
- MindImageBaseComponent.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.5", type: MindImageBaseComponent, inputs: { imageItem: "imageItem", board: "board", element: "element", isFocus: "isFocus" }, host: { classAttribute: "mind-node-image" }, ngImport: i0 });
56
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: MindImageBaseComponent, decorators: [{
57
- type: Directive,
58
- args: [{
59
- host: {
60
- class: 'mind-node-image'
61
- }
62
- }]
63
- }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { imageItem: [{
64
- type: Input
65
- }], board: [{
66
- type: Input
67
- }], element: [{
68
- type: Input
69
- }], isFocus: [{
70
- type: Input
71
- }] } });
72
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW1hZ2UtYmFzZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9taW5kL3NyYy9iYXNlL2ltYWdlLWJhc2UuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBcUIsU0FBUyxFQUFjLEtBQUssRUFBcUIsTUFBTSxlQUFlLENBQUM7QUFFbkcsT0FBTyxFQUFjLFlBQVksRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUV2RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2hELE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLHlCQUF5QixDQUFDOztBQVFuRSxNQUFNLE9BQWdCLHNCQUFzQjtJQU94QyxJQUNJLFNBQVMsQ0FBQyxLQUFnQjtRQUMxQixJQUFJLENBQUMsb0JBQW9CLENBQUMsSUFBSSxDQUFDLFVBQVUsRUFBRSxLQUFLLENBQUMsQ0FBQztRQUNsRCxJQUFJLENBQUMsVUFBVSxHQUFHLEtBQUssQ0FBQztRQUN4QixJQUFJLENBQUMsU0FBUyxFQUFFLENBQUM7SUFDckIsQ0FBQztJQUVELElBQUksU0FBUztRQUNULE9BQU8sSUFBSSxDQUFDLFVBQVUsQ0FBQztJQUMzQixDQUFDO0lBUUQsSUFDSSxPQUFPLENBQUMsS0FBYztRQUN0QixJQUFJLENBQUMsUUFBUSxHQUFHLEtBQUssQ0FBQztRQUN0QixJQUFJLENBQUMsU0FBUyxFQUFFLENBQUM7SUFDckIsQ0FBQztJQUVELElBQUksT0FBTztRQUNQLE9BQU8sSUFBSSxDQUFDLFFBQVEsQ0FBQztJQUN6QixDQUFDO0lBRUQsSUFBSSxhQUFhO1FBQ2IsT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDLGFBQWEsQ0FBQztJQUN6QyxDQUFDO0lBSUQsWUFBc0IsVUFBbUMsRUFBUyxHQUFzQjtRQUFsRSxlQUFVLEdBQVYsVUFBVSxDQUF5QjtRQUFTLFFBQUcsR0FBSCxHQUFHLENBQW1CO1FBckN4RixnQkFBVyxHQUFHLEtBQUssQ0FBQztJQXFDdUUsQ0FBQztJQUU1RixRQUFRO1FBQ0osSUFBSSxDQUFDLGVBQWUsR0FBRyxJQUFJLGVBQWUsQ0FBYyxJQUFJLENBQUMsS0FBSyxFQUFFO1lBQ2hFLGlCQUFpQixFQUFFLENBQUM7WUFDcEIsWUFBWSxFQUFFLENBQUMsT0FBb0IsRUFBRSxFQUFFO2dCQUNuQyxPQUFPLHdCQUF3QixDQUFDLElBQUksQ0FBQyxLQUF1QixFQUFFLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQztZQUNoRixDQUFDO1lBQ0QsdUJBQXVCLEVBQUUsR0FBRyxFQUFFO2dCQUMxQixPQUFPLENBQUMsQ0FBQztZQUNiLENBQUM7U0FDSixDQUFDLENBQUM7UUFDSCxJQUFJLENBQUMsV0FBVyxHQUFHLElBQUksQ0FBQztJQUM1QixDQUFDO0lBRUQsU0FBUztRQUNMLElBQUksSUFBSSxDQUFDLFdBQVcsRUFBRTtZQUNsQixNQUFNLEdBQUcsR0FBRyxZQUFZLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQztZQUNwRCxJQUFJLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFLEdBQUcsQ0FBQyxDQUFDLEVBQUUsRUFBRSxRQUFRLEVBQUUsSUFBSSxDQUFDLFFBQVEsRUFBRSxDQUFDLENBQUM7U0FDL0U7SUFDTCxDQUFDO0lBRUQsV0FBVztRQUNQLElBQUksSUFBSSxDQUFDLGVBQWUsRUFBRTtZQUN0QixJQUFJLENBQUMsZUFBZSxDQUFDLE9BQU8sRUFBRSxDQUFDO1NBQ2xDO0lBQ0wsQ0FBQzs7bUhBbEVpQixzQkFBc0I7dUdBQXRCLHNCQUFzQjsyRkFBdEIsc0JBQXNCO2tCQUwzQyxTQUFTO21CQUFDO29CQUNQLElBQUksRUFBRTt3QkFDRixLQUFLLEVBQUUsaUJBQWlCO3FCQUMzQjtpQkFDSjtpSUFTTyxTQUFTO3NCQURaLEtBQUs7Z0JBWU4sS0FBSztzQkFESixLQUFLO2dCQUlOLE9BQU87c0JBRE4sS0FBSztnQkFJRixPQUFPO3NCQURWLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3RvclJlZiwgRGlyZWN0aXZlLCBFbGVtZW50UmVmLCBJbnB1dCwgT25EZXN0cm95LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEltYWdlSXRlbSwgSW1hZ2VEYXRhIH0gZnJvbSAnLi4vaW50ZXJmYWNlcy9lbGVtZW50LWRhdGEnO1xuaW1wb3J0IHsgUGxhaXRCb2FyZCwgUGxhaXRFbGVtZW50IH0gZnJvbSAnQHBsYWl0L2NvcmUnO1xuaW1wb3J0IHsgTWluZEVsZW1lbnQgfSBmcm9tICcuLi9pbnRlcmZhY2VzJztcbmltcG9ydCB7IEFjdGl2ZUdlbmVyYXRvciB9IGZyb20gJ0BwbGFpdC9jb21tb24nO1xuaW1wb3J0IHsgZ2V0SW1hZ2VGb3JlaWduUmVjdGFuZ2xlIH0gZnJvbSAnLi4vdXRpbHMvcG9zaXRpb24vaW1hZ2UnO1xuaW1wb3J0IHsgUGxhaXRNaW5kQm9hcmQgfSBmcm9tICcuLi9wbHVnaW5zL3dpdGgtbWluZC5ib2FyZCc7XG5cbkBEaXJlY3RpdmUoe1xuICAgIGhvc3Q6IHtcbiAgICAgICAgY2xhc3M6ICdtaW5kLW5vZGUtaW1hZ2UnXG4gICAgfVxufSlcbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBNaW5kSW1hZ2VCYXNlQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0LCBPbkRlc3Ryb3kge1xuICAgIF9pbWFnZUl0ZW0hOiBJbWFnZUl0ZW07XG4gICAgX2lzRm9jdXMhOiBib29sZWFuO1xuICAgIGluaXRpYWxpemVkID0gZmFsc2U7XG5cbiAgICBhY3RpdmVHZW5lcmF0b3IhOiBBY3RpdmVHZW5lcmF0b3I8TWluZEVsZW1lbnQ+O1xuXG4gICAgQElucHV0KClcbiAgICBzZXQgaW1hZ2VJdGVtKHZhbHVlOiBJbWFnZUl0ZW0pIHtcbiAgICAgICAgdGhpcy5hZnRlckltYWdlSXRlbUNoYW5nZSh0aGlzLl9pbWFnZUl0ZW0sIHZhbHVlKTtcbiAgICAgICAgdGhpcy5faW1hZ2VJdGVtID0gdmFsdWU7XG4gICAgICAgIHRoaXMuZHJhd0ZvY3VzKCk7XG4gICAgfVxuXG4gICAgZ2V0IGltYWdlSXRlbSgpIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuX2ltYWdlSXRlbTtcbiAgICB9XG5cbiAgICBASW5wdXQoKVxuICAgIGJvYXJkITogUGxhaXRCb2FyZDtcblxuICAgIEBJbnB1dCgpXG4gICAgZWxlbWVudCE6IE1pbmRFbGVtZW50PEltYWdlRGF0YT47XG5cbiAgICBASW5wdXQoKVxuICAgIHNldCBpc0ZvY3VzKHZhbHVlOiBib29sZWFuKSB7XG4gICAgICAgIHRoaXMuX2lzRm9jdXMgPSB2YWx1ZTtcbiAgICAgICAgdGhpcy5kcmF3Rm9jdXMoKTtcbiAgICB9XG5cbiAgICBnZXQgaXNGb2N1cygpIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuX2lzRm9jdXM7XG4gICAgfVxuXG4gICAgZ2V0IG5hdGl2ZUVsZW1lbnQoKSB7XG4gICAgICAgIHJldHVybiB0aGlzLmVsZW1lbnRSZWYubmF0aXZlRWxlbWVudDtcbiAgICB9XG5cbiAgICBhYnN0cmFjdCBhZnRlckltYWdlSXRlbUNoYW5nZShwcmV2aW91czogSW1hZ2VJdGVtLCBjdXJyZW50OiBJbWFnZUl0ZW0pOiB2b2lkO1xuXG4gICAgY29uc3RydWN0b3IocHJvdGVjdGVkIGVsZW1lbnRSZWY6IEVsZW1lbnRSZWY8SFRNTEVsZW1lbnQ+LCBwdWJsaWMgY2RyOiBDaGFuZ2VEZXRlY3RvclJlZikge31cblxuICAgIG5nT25Jbml0KCk6IHZvaWQge1xuICAgICAgICB0aGlzLmFjdGl2ZUdlbmVyYXRvciA9IG5ldyBBY3RpdmVHZW5lcmF0b3I8TWluZEVsZW1lbnQ+KHRoaXMuYm9hcmQsIHtcbiAgICAgICAgICAgIGFjdGl2ZVN0cm9rZVdpZHRoOiAxLFxuICAgICAgICAgICAgZ2V0UmVjdGFuZ2xlOiAoZWxlbWVudDogTWluZEVsZW1lbnQpID0+IHtcbiAgICAgICAgICAgICAgICByZXR1cm4gZ2V0SW1hZ2VGb3JlaWduUmVjdGFuZ2xlKHRoaXMuYm9hcmQgYXMgUGxhaXRNaW5kQm9hcmQsIHRoaXMuZWxlbWVudCk7XG4gICAgICAgICAgICB9LFxuICAgICAgICAgICAgZ2V0U3Ryb2tlV2lkdGhCeUVsZW1lbnQ6ICgpID0+IHtcbiAgICAgICAgICAgICAgICByZXR1cm4gMDtcbiAgICAgICAgICAgIH1cbiAgICAgICAgfSk7XG4gICAgICAgIHRoaXMuaW5pdGlhbGl6ZWQgPSB0cnVlO1xuICAgIH1cblxuICAgIGRyYXdGb2N1cygpIHtcbiAgICAgICAgaWYgKHRoaXMuaW5pdGlhbGl6ZWQpIHtcbiAgICAgICAgICAgIGNvbnN0IGNvbSA9IFBsYWl0RWxlbWVudC5nZXRDb21wb25lbnQodGhpcy5lbGVtZW50KTtcbiAgICAgICAgICAgIHRoaXMuYWN0aXZlR2VuZXJhdG9yLmRyYXcodGhpcy5lbGVtZW50LCBjb20uZywgeyBzZWxlY3RlZDogdGhpcy5faXNGb2N1cyB9KTtcbiAgICAgICAgfVxuICAgIH1cbiAgICBcbiAgICBuZ09uRGVzdHJveSgpOiB2b2lkIHtcbiAgICAgICAgaWYgKHRoaXMuYWN0aXZlR2VuZXJhdG9yKSB7XG4gICAgICAgICAgICB0aGlzLmFjdGl2ZUdlbmVyYXRvci5kZXN0cm95KCk7XG4gICAgICAgIH1cbiAgICB9XG59XG4iXX0=
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxlbWVudC1kYXRhLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvbWluZC9zcmMvaW50ZXJmYWNlcy9lbGVtZW50LWRhdGEudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEVsZW1lbnQgfSBmcm9tICdzbGF0ZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgRW1vamlJdGVtIHtcbiAgICBuYW1lOiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgSW1hZ2VJdGVtIHtcbiAgICB1cmw6IHN0cmluZztcbiAgICB3aWR0aDogbnVtYmVyO1xuICAgIGhlaWdodDogbnVtYmVyO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEJhc2VEYXRhIHtcbiAgICB0b3BpYzogRWxlbWVudDtcbiAgICBlbW9qaXM/OiBFbW9qaUl0ZW1bXTtcbiAgICBpbWFnZT86IEltYWdlSXRlbTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBFbW9qaURhdGEgZXh0ZW5kcyBCYXNlRGF0YSB7XG4gICAgZW1vamlzOiBFbW9qaUl0ZW1bXTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBJbWFnZURhdGEgZXh0ZW5kcyBCYXNlRGF0YSB7XG4gICAgaW1hZ2U6IEltYWdlSXRlbTtcbn1cbiJdfQ==
@@ -1,248 +0,0 @@
1
- import { ChangeDetectionStrategy, Component } from '@angular/core';
2
- import { createG, PlaitBoard, PlaitPluginElementComponent, PlaitElement, NODE_TO_INDEX, RectangleClient } from '@plait/core';
3
- import { isHorizontalLayout, AbstractNode } from '@plait/layouts';
4
- import { TextManage, ExitOrigin } from '@plait/text';
5
- import { Subject } from 'rxjs';
6
- import { drawRoundRectangleByNode } from './utils/draw/node-shape';
7
- import { MindElement, PlaitMind } from './interfaces/element';
8
- import { MindQueries } from './queries';
9
- import { getShapeByElement } from './utils/node-style/shape';
10
- import { ELEMENT_TO_NODE } from './utils/weak-maps';
11
- import { drawAbstractLink } from './utils/draw/node-link/abstract-link';
12
- import { NodeEmojisDrawer } from './drawer/node-emojis.drawer';
13
- import { MindTransforms } from './transforms';
14
- import { MindElementShape } from './interfaces';
15
- import { NodeInsertDrawer } from './drawer/node-insert.drawer';
16
- import { drawLink } from './utils/draw/node-link/draw-link';
17
- import { getTopicRectangleByNode } from './utils/position/topic';
18
- import { NodeActiveDrawer } from './drawer/node-active.drawer';
19
- import { CollapseDrawer } from './drawer/node-collapse.drawer';
20
- import { WithMindPluginKey } from './constants/default';
21
- import { NodeImageDrawer } from './drawer/node-image.drawer';
22
- import { NodeSpace } from './utils/space/node-space';
23
- import { ROOT_TOPIC_FONT_SIZE, TOPIC_DEFAULT_MAX_WORD_COUNT, TOPIC_FONT_SIZE } from './constants/node-topic-style';
24
- import * as i0 from "@angular/core";
25
- import * as i1 from "@angular/common";
26
- import * as i2 from "@plait/core";
27
- // 1. When the text at the end has an italic attribute, the text is partially covered
28
- // 2. There will be some differences in the width measured by different browsers
29
- const WIDTH_BUFFER = 4;
30
- export class MindNodeComponent extends PlaitPluginElementComponent {
31
- constructor(viewContainerRef, cdr) {
32
- super(cdr);
33
- this.viewContainerRef = viewContainerRef;
34
- this.cdr = cdr;
35
- this.shapeG = null;
36
- this.destroy$ = new Subject();
37
- this.trackBy = (index, node) => {
38
- return node.origin.id;
39
- };
40
- }
41
- initializeDrawer() {
42
- this.nodeEmojisDrawer = new NodeEmojisDrawer(this.board, this.viewContainerRef);
43
- this.nodeInsertDrawer = new NodeInsertDrawer(this.board);
44
- this.activeDrawer = new NodeActiveDrawer(this.board);
45
- this.collapseDrawer = new CollapseDrawer(this.board);
46
- this.imageDrawer = new NodeImageDrawer(this.board, this.viewContainerRef);
47
- const plugins = this.board.getPluginOptions(WithMindPluginKey).textPlugins;
48
- this.textManage = new TextManage(this.board, this.viewContainerRef, {
49
- getRectangle: () => {
50
- const rect = getTopicRectangleByNode(this.board, this.node);
51
- return rect;
52
- },
53
- onValueChangeHandle: (textManageRef) => {
54
- const width = textManageRef.width;
55
- const height = textManageRef.height;
56
- if (textManageRef.newValue) {
57
- MindTransforms.setTopic(this.board, this.element, textManageRef.newValue, width, height);
58
- }
59
- else {
60
- MindTransforms.setTopicSize(this.board, this.element, width, height);
61
- }
62
- },
63
- textPlugins: plugins
64
- });
65
- }
66
- ngOnInit() {
67
- super.ngOnInit();
68
- this.initializeDrawer();
69
- this.node = MindElement.getNode(this.element);
70
- this.index = NODE_TO_INDEX.get(this.element) || 0;
71
- this.roughSVG = PlaitBoard.getRoughSVG(this.board);
72
- this.parentG = PlaitElement.getComponent(MindElement.getRoot(this.board, this.element)).rootG;
73
- this.drawShape();
74
- this.drawLink();
75
- this.drawTopic();
76
- this.activeDrawer.draw(this.element, this.g, { selected: this.selected, isEditing: this.textManage.isEditing });
77
- this.drawEmojis();
78
- this.drawExtend();
79
- this.imageDrawer.drawImage(this.g, this.element);
80
- if (PlaitMind.isMind(this.context.parent)) {
81
- this.g.classList.add('branch');
82
- }
83
- }
84
- onContextChanged(value, previous) {
85
- const newNode = MindElement.getNode(value.element);
86
- const isEqualNode = RectangleClient.isEqual(this.node, newNode);
87
- this.node = newNode;
88
- const isChangeTheme = this.board.operations.find(op => op.type === 'set_theme');
89
- if (!isEqualNode || value.element !== previous.element || isChangeTheme) {
90
- this.activeDrawer.draw(this.element, this.g, { selected: this.selected, isEditing: this.textManage.isEditing });
91
- this.drawShape();
92
- this.drawLink();
93
- this.drawEmojis();
94
- this.drawExtend();
95
- this.imageDrawer.updateImage(this.g, previous.element, value.element);
96
- this.updateTopic();
97
- }
98
- else {
99
- const hasSameSelected = value.selected === previous.selected;
100
- const hasSameParent = value.parent === previous.parent;
101
- if (!hasSameSelected) {
102
- this.activeDrawer.draw(this.element, this.g, { selected: this.selected, isEditing: this.textManage.isEditing });
103
- }
104
- if (!hasSameParent) {
105
- this.drawLink();
106
- }
107
- }
108
- }
109
- drawEmojis() {
110
- const g = this.nodeEmojisDrawer.drawEmojis(this.element);
111
- if (g) {
112
- this.g.append(g);
113
- }
114
- }
115
- drawShape() {
116
- this.destroyShape();
117
- const shape = getShapeByElement(this.board, this.node.origin);
118
- switch (shape) {
119
- case MindElementShape.roundRectangle:
120
- this.shapeG = drawRoundRectangleByNode(this.board, this.node);
121
- this.g.prepend(this.shapeG);
122
- break;
123
- default:
124
- break;
125
- }
126
- }
127
- destroyShape() {
128
- if (this.shapeG) {
129
- this.shapeG.remove();
130
- this.shapeG = null;
131
- }
132
- }
133
- drawLink() {
134
- if (PlaitMind.isMind(this.element)) {
135
- return;
136
- }
137
- const parent = MindElement.getParent(this.element);
138
- const parentNode = MindElement.getNode(parent);
139
- if (this.linkG) {
140
- this.linkG.remove();
141
- }
142
- const layout = MindQueries.getLayoutByElement(parent);
143
- if (AbstractNode.isAbstract(this.node.origin)) {
144
- this.linkG = drawAbstractLink(this.board, this.node, isHorizontalLayout(layout));
145
- }
146
- else {
147
- this.linkG = drawLink(this.board, parentNode, this.node, isHorizontalLayout(layout));
148
- }
149
- this.g.append(this.linkG);
150
- }
151
- destroyLine() {
152
- if (this.linkG) {
153
- this.linkG.remove();
154
- }
155
- }
156
- drawExtend() {
157
- this.destroyExtend();
158
- this.extendG = createG();
159
- this.extendG.classList.add('extend');
160
- this.g.append(this.extendG);
161
- if (this.element.isCollapsed) {
162
- this.g.classList.add('collapsed');
163
- }
164
- else {
165
- this.g.classList.remove('collapsed');
166
- }
167
- this.nodeInsertDrawer.draw(this.element, this.extendG);
168
- this.collapseDrawer.draw(this.element, this.extendG);
169
- }
170
- destroyExtend() {
171
- if (this.extendG) {
172
- this.extendG.remove();
173
- }
174
- }
175
- drawTopic() {
176
- this.textManage.draw(this.element.data.topic);
177
- this.g.append(this.textManage.g);
178
- if (this.element.manualWidth) {
179
- const width = NodeSpace.getNodeDynamicWidth(this.board, this.element);
180
- this.textManage.updateWidth(width);
181
- }
182
- }
183
- updateTopic() {
184
- this.textManage.updateText(this.element.data.topic);
185
- this.textManage.updateRectangle();
186
- if (this.element.manualWidth) {
187
- const width = NodeSpace.getNodeDynamicWidth(this.board, this.element);
188
- this.textManage.updateWidth(width);
189
- }
190
- }
191
- editTopic() {
192
- this.activeDrawer.draw(this.element, this.g, { selected: this.selected, isEditing: true });
193
- // update text max-width when image width greater than topic default max width to cover node topic default max width style
194
- const defaultMaxWidth = TOPIC_DEFAULT_MAX_WORD_COUNT * (PlaitMind.isMind(this.element) ? ROOT_TOPIC_FONT_SIZE : TOPIC_FONT_SIZE);
195
- let hasMaxWidth = false;
196
- if (!this.element.manualWidth && MindElement.hasImage(this.element) && this.element.data.image.width > defaultMaxWidth) {
197
- const width = NodeSpace.getNodeDynamicWidth(this.board, this.element);
198
- this.textManage.updateWidth(width);
199
- hasMaxWidth = true;
200
- }
201
- this.textManage.edit((origin) => {
202
- if (origin === ExitOrigin.default) {
203
- this.activeDrawer.draw(this.element, this.g, { selected: this.selected, isEditing: false });
204
- }
205
- if (hasMaxWidth) {
206
- this.textManage.updateWidth(0);
207
- }
208
- });
209
- }
210
- ngOnDestroy() {
211
- super.ngOnDestroy();
212
- this.textManage.destroy();
213
- this.nodeEmojisDrawer.destroy();
214
- this.imageDrawer.destroy();
215
- this.destroy$.next();
216
- this.destroy$.complete();
217
- if (ELEMENT_TO_NODE.get(this.element) === this.node) {
218
- ELEMENT_TO_NODE.delete(this.element);
219
- }
220
- }
221
- }
222
- MindNodeComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: MindNodeComponent, deps: [{ token: i0.ViewContainerRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
223
- MindNodeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.5", type: MindNodeComponent, selector: "plait-mind-node", usesInheritance: true, ngImport: i0, template: `
224
- <plait-children
225
- *ngIf="!element.isCollapsed"
226
- [board]="board"
227
- [parent]="element"
228
- [effect]="effect"
229
- [parentG]="parentG"
230
- ></plait-children>
231
- `, isInline: true, dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.PlaitChildrenElement, selector: "plait-children", inputs: ["board", "parent", "effect", "parentG"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
232
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: MindNodeComponent, decorators: [{
233
- type: Component,
234
- args: [{
235
- selector: 'plait-mind-node',
236
- template: `
237
- <plait-children
238
- *ngIf="!element.isCollapsed"
239
- [board]="board"
240
- [parent]="element"
241
- [effect]="effect"
242
- [parentG]="parentG"
243
- ></plait-children>
244
- `,
245
- changeDetection: ChangeDetectionStrategy.OnPush
246
- }]
247
- }], ctorParameters: function () { return [{ type: i0.ViewContainerRef }, { type: i0.ChangeDetectorRef }]; } });
248
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node.component.js","sourceRoot":"","sources":["../../../packages/mind/src/node.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, OnDestroy, OnInit, ViewContainerRef } from '@angular/core';\nimport {\n    createG,\n    PlaitBoard,\n    PlaitPluginElementComponent,\n    PlaitElement,\n    NODE_TO_INDEX,\n    PlaitPluginElementContext,\n    OnContextChanged,\n    RectangleClient,\n    Point\n} from '@plait/core';\nimport { isHorizontalLayout, AbstractNode, MindLayoutType } from '@plait/layouts';\nimport { TextManageRef, TextManage, ExitOrigin } from '@plait/text';\nimport { RoughSVG } from 'roughjs/bin/svg';\nimport { Subject } from 'rxjs';\nimport { drawRoundRectangleByNode } from './utils/draw/node-shape';\nimport { MindElement, PlaitMind } from './interfaces/element';\nimport { MindNode } from './interfaces/node';\nimport { MindQueries } from './queries';\nimport { isHitMindElement } from './utils/position/node';\nimport { getShapeByElement } from './utils/node-style/shape';\nimport { ELEMENT_TO_NODE } from './utils/weak-maps';\nimport { drawAbstractLink } from './utils/draw/node-link/abstract-link';\nimport { NodeEmojisDrawer } from './drawer/node-emojis.drawer';\nimport { MindTransforms } from './transforms';\nimport { MindElementShape } from './interfaces';\nimport { NodeInsertDrawer } from './drawer/node-insert.drawer';\nimport { PlaitMindBoard } from './plugins/with-mind.board';\nimport { drawLink } from './utils/draw/node-link/draw-link';\nimport { getTopicRectangleByNode } from './utils/position/topic';\nimport { NodeActiveDrawer } from './drawer/node-active.drawer';\nimport { CollapseDrawer } from './drawer/node-collapse.drawer';\nimport { WithMindOptions } from './interfaces/options';\nimport { WithMindPluginKey } from './constants/default';\nimport { NodeImageDrawer } from './drawer/node-image.drawer';\nimport { NodeSpace } from './utils/space/node-space';\nimport { ROOT_TOPIC_FONT_SIZE, TOPIC_DEFAULT_MAX_WORD_COUNT, TOPIC_FONT_SIZE } from './constants/node-topic-style';\n\n// 1. When the text at the end has an italic attribute, the text is partially covered\n// 2. There will be some differences in the width measured by different browsers\nconst WIDTH_BUFFER = 4;\n\n@Component({\n    selector: 'plait-mind-node',\n    template: `\n        <plait-children\n            *ngIf=\"!element.isCollapsed\"\n            [board]=\"board\"\n            [parent]=\"element\"\n            [effect]=\"effect\"\n            [parentG]=\"parentG\"\n        ></plait-children>\n    `,\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class MindNodeComponent extends PlaitPluginElementComponent<MindElement, PlaitMindBoard>\n    implements OnInit, OnDestroy, OnContextChanged<MindElement, PlaitMindBoard> {\n    roughSVG!: RoughSVG;\n\n    node!: MindNode;\n\n    index!: number;\n\n    parentG!: SVGGElement;\n\n    shapeG: SVGGElement | null = null;\n\n    linkG?: SVGGElement;\n\n    extendG?: SVGGElement;\n\n    destroy$ = new Subject<void>();\n\n    nodeEmojisDrawer!: NodeEmojisDrawer;\n\n    nodeInsertDrawer!: NodeInsertDrawer;\n\n    imageDrawer!: NodeImageDrawer;\n\n    textManage!: TextManage;\n\n    activeDrawer!: NodeActiveDrawer;\n\n    collapseDrawer!: CollapseDrawer;\n\n    constructor(private viewContainerRef: ViewContainerRef, protected cdr: ChangeDetectorRef) {\n        super(cdr);\n    }\n\n    initializeDrawer() {\n        this.nodeEmojisDrawer = new NodeEmojisDrawer(this.board, this.viewContainerRef);\n        this.nodeInsertDrawer = new NodeInsertDrawer(this.board);\n        this.activeDrawer = new NodeActiveDrawer(this.board);\n        this.collapseDrawer = new CollapseDrawer(this.board);\n        this.imageDrawer = new NodeImageDrawer(this.board, this.viewContainerRef);\n        const plugins = this.board.getPluginOptions<WithMindOptions>(WithMindPluginKey).textPlugins;\n\n        this.textManage = new TextManage(this.board, this.viewContainerRef, {\n            getRectangle: () => {\n                const rect = getTopicRectangleByNode(this.board, this.node);\n                return rect;\n            },\n            onValueChangeHandle: (textManageRef: TextManageRef) => {\n                const width = textManageRef.width;\n                const height = textManageRef.height;\n                if (textManageRef.newValue) {\n                    MindTransforms.setTopic(this.board, this.element, textManageRef.newValue as MindElement, width, height);\n                } else {\n                    MindTransforms.setTopicSize(this.board, this.element, width, height);\n                }\n            },\n            textPlugins: plugins\n        });\n    }\n\n    ngOnInit(): void {\n        super.ngOnInit();\n        this.initializeDrawer();\n        this.node = MindElement.getNode(this.element);\n        this.index = NODE_TO_INDEX.get(this.element) || 0;\n        this.roughSVG = PlaitBoard.getRoughSVG(this.board);\n        this.parentG = PlaitElement.getComponent(MindElement.getRoot(this.board, this.element)).rootG as SVGGElement;\n        this.drawShape();\n        this.drawLink();\n        this.drawTopic();\n        this.activeDrawer.draw(this.element, this.g, { selected: this.selected, isEditing: this.textManage.isEditing });\n        this.drawEmojis();\n        this.drawExtend();\n        this.imageDrawer.drawImage(this.g, this.element);\n        if (PlaitMind.isMind(this.context.parent)) {\n            this.g.classList.add('branch');\n        }\n    }\n\n    onContextChanged(\n        value: PlaitPluginElementContext<MindElement, PlaitMindBoard>,\n        previous: PlaitPluginElementContext<MindElement, PlaitMindBoard>\n    ) {\n        const newNode = MindElement.getNode(value.element);\n        const isEqualNode = RectangleClient.isEqual(this.node, newNode);\n        this.node = newNode;\n\n        const isChangeTheme = this.board.operations.find(op => op.type === 'set_theme');\n\n        if (!isEqualNode || value.element !== previous.element || isChangeTheme) {\n            this.activeDrawer.draw(this.element, this.g, { selected: this.selected, isEditing: this.textManage.isEditing });\n            this.drawShape();\n            this.drawLink();\n            this.drawEmojis();\n            this.drawExtend();\n            this.imageDrawer.updateImage(this.g, previous.element, value.element);\n            this.updateTopic();\n        } else {\n            const hasSameSelected = value.selected === previous.selected;\n            const hasSameParent = value.parent === previous.parent;\n            if (!hasSameSelected) {\n                this.activeDrawer.draw(this.element, this.g, { selected: this.selected, isEditing: this.textManage.isEditing });\n            }\n            if (!hasSameParent) {\n                this.drawLink();\n            }\n        }\n    }\n\n    drawEmojis() {\n        const g = this.nodeEmojisDrawer.drawEmojis(this.element);\n        if (g) {\n            this.g.append(g);\n        }\n    }\n\n    drawShape() {\n        this.destroyShape();\n        const shape = getShapeByElement(this.board, this.node.origin) as MindElementShape;\n        switch (shape) {\n            case MindElementShape.roundRectangle:\n                this.shapeG = drawRoundRectangleByNode(this.board, this.node as MindNode);\n                this.g.prepend(this.shapeG);\n                break;\n            default:\n                break;\n        }\n    }\n\n    destroyShape() {\n        if (this.shapeG) {\n            this.shapeG.remove();\n            this.shapeG = null;\n        }\n    }\n\n    drawLink() {\n        if (PlaitMind.isMind(this.element)) {\n            return;\n        }\n\n        const parent = MindElement.getParent(this.element);\n        const parentNode = MindElement.getNode(parent);\n\n        if (this.linkG) {\n            this.linkG.remove();\n        }\n\n        const layout = MindQueries.getLayoutByElement(parent) as MindLayoutType;\n        if (AbstractNode.isAbstract(this.node.origin)) {\n            this.linkG = drawAbstractLink(this.board, this.node, isHorizontalLayout(layout));\n        } else {\n            this.linkG = drawLink(this.board, parentNode, this.node, isHorizontalLayout(layout));\n        }\n        this.g.append(this.linkG);\n    }\n\n    destroyLine() {\n        if (this.linkG) {\n            this.linkG.remove();\n        }\n    }\n\n    drawExtend() {\n        this.destroyExtend();\n\n        this.extendG = createG();\n        this.extendG.classList.add('extend');\n        this.g.append(this.extendG);\n\n        if (this.element.isCollapsed) {\n            this.g.classList.add('collapsed');\n        } else {\n            this.g.classList.remove('collapsed');\n        }\n\n        this.nodeInsertDrawer.draw(this.element, this.extendG!);\n        this.collapseDrawer.draw(this.element, this.extendG!);\n    }\n\n    destroyExtend() {\n        if (this.extendG) {\n            this.extendG.remove();\n        }\n    }\n\n    drawTopic() {\n        this.textManage.draw(this.element.data.topic);\n        this.g.append(this.textManage.g);\n        if (this.element.manualWidth) {\n            const width = NodeSpace.getNodeDynamicWidth(this.board, this.element);\n            this.textManage.updateWidth(width);\n        }\n    }\n\n    updateTopic() {\n        this.textManage.updateText(this.element.data.topic);\n        this.textManage.updateRectangle();\n        if (this.element.manualWidth) {\n            const width = NodeSpace.getNodeDynamicWidth(this.board, this.element);\n            this.textManage.updateWidth(width);\n        }\n    }\n\n    editTopic() {\n        this.activeDrawer.draw(this.element, this.g, { selected: this.selected, isEditing: true });\n        // update text max-width when image width greater than topic default max width to cover node topic default max width style\n        const defaultMaxWidth = TOPIC_DEFAULT_MAX_WORD_COUNT * (PlaitMind.isMind(this.element) ? ROOT_TOPIC_FONT_SIZE : TOPIC_FONT_SIZE);\n        let hasMaxWidth = false;\n        if (!this.element.manualWidth && MindElement.hasImage(this.element) && this.element.data.image.width > defaultMaxWidth) {\n            const width = NodeSpace.getNodeDynamicWidth(this.board, this.element);\n            this.textManage.updateWidth(width);\n            hasMaxWidth = true;\n        }\n        this.textManage.edit((origin: ExitOrigin) => {\n            if (origin === ExitOrigin.default) {\n                this.activeDrawer.draw(this.element, this.g, { selected: this.selected, isEditing: false });\n            }\n            if (hasMaxWidth) {\n                this.textManage.updateWidth(0);\n            }\n        });\n    }\n\n    trackBy = (index: number, node: MindNode) => {\n        return node.origin.id;\n    };\n\n    ngOnDestroy(): void {\n        super.ngOnDestroy();\n        this.textManage.destroy();\n        this.nodeEmojisDrawer.destroy();\n        this.imageDrawer.destroy();\n        this.destroy$.next();\n        this.destroy$.complete();\n        if (ELEMENT_TO_NODE.get(this.element) === this.node) {\n            ELEMENT_TO_NODE.delete(this.element);\n        }\n    }\n}\n"]}