@plait/mind 0.27.0-next.0 → 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 (115) hide show
  1. package/base/emoji-base.component.d.ts +1 -1
  2. package/base/image-base.component.d.ts +4 -3
  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/esm2022/plugins/with-mind-hotkey.mjs +109 -0
  12. package/esm2022/plugins/with-node-image-resize.mjs +48 -0
  13. package/esm2022/utils/index.mjs +15 -0
  14. package/esm2022/utils/position/image.mjs +36 -0
  15. package/{fesm2020 → fesm2022}/plait-mind.mjs +45 -56
  16. package/fesm2022/plait-mind.mjs.map +1 -0
  17. package/interfaces/element-data.d.ts +2 -2
  18. package/package.json +7 -13
  19. package/plugins/with-mind-hotkey.d.ts +0 -4
  20. package/utils/abstract/common.d.ts +2 -2
  21. package/utils/index.d.ts +0 -1
  22. package/utils/position/image.d.ts +1 -1
  23. package/esm2020/base/image-base.component.mjs +0 -67
  24. package/esm2020/interfaces/element-data.mjs +0 -2
  25. package/esm2020/node.component.mjs +0 -248
  26. package/esm2020/plugins/with-mind-hotkey.mjs +0 -122
  27. package/esm2020/plugins/with-node-image-resize.mjs +0 -48
  28. package/esm2020/utils/index.mjs +0 -16
  29. package/esm2020/utils/is-virtual-key.mjs +0 -13
  30. package/esm2020/utils/position/image.mjs +0 -36
  31. package/fesm2015/plait-mind.mjs +0 -4402
  32. package/fesm2015/plait-mind.mjs.map +0 -1
  33. package/fesm2020/plait-mind.mjs.map +0 -1
  34. package/utils/is-virtual-key.d.ts +0 -1
  35. /package/{esm2020 → esm2022}/base/base.drawer.mjs +0 -0
  36. /package/{esm2020 → esm2022}/base/index.mjs +0 -0
  37. /package/{esm2020 → esm2022}/constants/abstract-node.mjs +0 -0
  38. /package/{esm2020 → esm2022}/constants/default.mjs +0 -0
  39. /package/{esm2020 → esm2022}/constants/image.mjs +0 -0
  40. /package/{esm2020 → esm2022}/constants/index.mjs +0 -0
  41. /package/{esm2020 → esm2022}/constants/node-style.mjs +0 -0
  42. /package/{esm2020 → esm2022}/constants/theme.mjs +0 -0
  43. /package/{esm2020 → esm2022}/drawer/node-active.drawer.mjs +0 -0
  44. /package/{esm2020 → esm2022}/drawer/node-collapse.drawer.mjs +0 -0
  45. /package/{esm2020 → esm2022}/drawer/node-emojis.drawer.mjs +0 -0
  46. /package/{esm2020 → esm2022}/drawer/node-image.drawer.mjs +0 -0
  47. /package/{esm2020 → esm2022}/drawer/node-insert.drawer.mjs +0 -0
  48. /package/{esm2020 → esm2022}/interfaces/element.mjs +0 -0
  49. /package/{esm2020 → esm2022}/interfaces/index.mjs +0 -0
  50. /package/{esm2020 → esm2022}/interfaces/layout.mjs +0 -0
  51. /package/{esm2020 → esm2022}/interfaces/node.mjs +0 -0
  52. /package/{esm2020 → esm2022}/interfaces/options.mjs +0 -0
  53. /package/{esm2020 → esm2022}/interfaces/pointer.mjs +0 -0
  54. /package/{esm2020 → esm2022}/interfaces/theme-color.mjs +0 -0
  55. /package/{esm2020 → esm2022}/interfaces/types.mjs +0 -0
  56. /package/{esm2020 → esm2022}/plait-mind.mjs +0 -0
  57. /package/{esm2020 → esm2022}/plugins/with-abstract-resize.board.mjs +0 -0
  58. /package/{esm2020 → esm2022}/plugins/with-abstract-resize.mjs +0 -0
  59. /package/{esm2020 → esm2022}/plugins/with-mind-create.mjs +0 -0
  60. /package/{esm2020 → esm2022}/plugins/with-mind-extend.mjs +0 -0
  61. /package/{esm2020 → esm2022}/plugins/with-mind.board.mjs +0 -0
  62. /package/{esm2020 → esm2022}/plugins/with-mind.mjs +0 -0
  63. /package/{esm2020 → esm2022}/plugins/with-node-dnd.mjs +0 -0
  64. /package/{esm2020 → esm2022}/plugins/with-node-hover-detect.mjs +0 -0
  65. /package/{esm2020 → esm2022}/plugins/with-node-image.mjs +0 -0
  66. /package/{esm2020 → esm2022}/plugins/with-node-resize.mjs +0 -0
  67. /package/{esm2020 → esm2022}/public-api.mjs +0 -0
  68. /package/{esm2020 → esm2022}/queries/get-available-sublayouts-by-element.mjs +0 -0
  69. /package/{esm2020 → esm2022}/queries/get-branch-layouts.mjs +0 -0
  70. /package/{esm2020 → esm2022}/queries/get-correct-layout-by-element.mjs +0 -0
  71. /package/{esm2020 → esm2022}/queries/get-layout-by-element.mjs +0 -0
  72. /package/{esm2020 → esm2022}/queries/index.mjs +0 -0
  73. /package/{esm2020 → esm2022}/transforms/abstract-node.mjs +0 -0
  74. /package/{esm2020 → esm2022}/transforms/emoji.mjs +0 -0
  75. /package/{esm2020 → esm2022}/transforms/image.mjs +0 -0
  76. /package/{esm2020 → esm2022}/transforms/index.mjs +0 -0
  77. /package/{esm2020 → esm2022}/transforms/layout.mjs +0 -0
  78. /package/{esm2020 → esm2022}/transforms/node.mjs +0 -0
  79. /package/{esm2020 → esm2022}/utils/abstract/common.mjs +0 -0
  80. /package/{esm2020 → esm2022}/utils/abstract/resize.mjs +0 -0
  81. /package/{esm2020 → esm2022}/utils/clipboard.mjs +0 -0
  82. /package/{esm2020 → esm2022}/utils/dnd/common.mjs +0 -0
  83. /package/{esm2020 → esm2022}/utils/dnd/detector.mjs +0 -0
  84. /package/{esm2020 → esm2022}/utils/draw/abstract-outline.mjs +0 -0
  85. /package/{esm2020 → esm2022}/utils/draw/node-dnd.mjs +0 -0
  86. /package/{esm2020 → esm2022}/utils/draw/node-link/abstract-link.mjs +0 -0
  87. /package/{esm2020 → esm2022}/utils/draw/node-link/draw-link.mjs +0 -0
  88. /package/{esm2020 → esm2022}/utils/draw/node-link/indented-link.mjs +0 -0
  89. /package/{esm2020 → esm2022}/utils/draw/node-link/logic-link.mjs +0 -0
  90. /package/{esm2020 → esm2022}/utils/draw/node-shape.mjs +0 -0
  91. /package/{esm2020 → esm2022}/utils/layout.mjs +0 -0
  92. /package/{esm2020 → esm2022}/utils/mind.mjs +0 -0
  93. /package/{esm2020 → esm2022}/utils/node/adjust-node.mjs +0 -0
  94. /package/{esm2020 → esm2022}/utils/node/common.mjs +0 -0
  95. /package/{esm2020 → esm2022}/utils/node/create-node.mjs +0 -0
  96. /package/{esm2020 → esm2022}/utils/node/dynamic-width.mjs +0 -0
  97. /package/{esm2020 → esm2022}/utils/node/image.mjs +0 -0
  98. /package/{esm2020 → esm2022}/utils/node/index.mjs +0 -0
  99. /package/{esm2020 → esm2022}/utils/node/right-node-count.mjs +0 -0
  100. /package/{esm2020 → esm2022}/utils/node-hover/extend.mjs +0 -0
  101. /package/{esm2020 → esm2022}/utils/node-style/branch.mjs +0 -0
  102. /package/{esm2020 → esm2022}/utils/node-style/common.mjs +0 -0
  103. /package/{esm2020 → esm2022}/utils/node-style/index.mjs +0 -0
  104. /package/{esm2020 → esm2022}/utils/node-style/shape.mjs +0 -0
  105. /package/{esm2020 → esm2022}/utils/path.mjs +0 -0
  106. /package/{esm2020 → esm2022}/utils/point-placement.mjs +0 -0
  107. /package/{esm2020 → esm2022}/utils/position/emoji.mjs +0 -0
  108. /package/{esm2020 → esm2022}/utils/position/index.mjs +0 -0
  109. /package/{esm2020 → esm2022}/utils/position/node.mjs +0 -0
  110. /package/{esm2020 → esm2022}/utils/position/topic.mjs +0 -0
  111. /package/{esm2020 → esm2022}/utils/space/emoji.mjs +0 -0
  112. /package/{esm2020 → esm2022}/utils/space/index.mjs +0 -0
  113. /package/{esm2020 → esm2022}/utils/space/layout-options.mjs +0 -0
  114. /package/{esm2020 → esm2022}/utils/space/node-space.mjs +0 -0
  115. /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.0",
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
@@ -3,7 +3,3 @@ import { MindElement } from '../interfaces';
3
3
  import { PlaitMindBoard } from './with-mind.board';
4
4
  export declare const withMindHotkey: (baseBoard: PlaitBoard) => PlaitBoard & PlaitMindBoard;
5
5
  export declare const getNextSelectedElement: (board: PlaitBoard, firstLevelElements: MindElement[]) => MindElement<import("../interfaces").BaseData> | undefined;
6
- export declare const isExpandHotkey: (event: KeyboardEvent) => boolean;
7
- export declare const isTabHotkey: (event: KeyboardEvent) => boolean;
8
- export declare const isEnterHotkey: (event: KeyboardEvent) => boolean;
9
- export declare const isSpaceHotkey: (event: KeyboardEvent) => boolean;
@@ -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;
package/utils/index.d.ts CHANGED
@@ -4,7 +4,6 @@ export * from './mind';
4
4
  export * from './layout';
5
5
  export * from './node';
6
6
  export * from './node-style';
7
- export * from './is-virtual-key';
8
7
  export * from './dnd/common';
9
8
  export * from './dnd/detector';
10
9
  export * from './draw/node-dnd';
@@ -11,6 +11,6 @@ export declare const getHitImageResizeHandleDirection: (board: PlaitBoard, eleme
11
11
  width: number;
12
12
  height: number;
13
13
  };
14
- direction: import("@plait/common").ResizeDirection;
14
+ handle: import("@plait/common").ResizeHandle;
15
15
  cursorClass: import("@plait/common").ResizeCursorClass;
16
16
  } | undefined;
@@ -1,67 +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
- }
49
- 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 });
50
- 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 });
51
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.5", ngImport: i0, type: MindImageBaseComponent, decorators: [{
52
- type: Directive,
53
- args: [{
54
- host: {
55
- class: 'mind-node-image'
56
- }
57
- }]
58
- }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { imageItem: [{
59
- type: Input
60
- }], board: [{
61
- type: Input
62
- }], element: [{
63
- type: Input
64
- }], isFocus: [{
65
- type: Input
66
- }] } });
67
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW1hZ2UtYmFzZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9taW5kL3NyYy9iYXNlL2ltYWdlLWJhc2UuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBcUIsU0FBUyxFQUFjLEtBQUssRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUV4RixPQUFPLEVBQWMsWUFBWSxFQUFFLE1BQU0sYUFBYSxDQUFDO0FBRXZELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDaEQsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0seUJBQXlCLENBQUM7O0FBUW5FLE1BQU0sT0FBZ0Isc0JBQXNCO0lBT3hDLElBQ0ksU0FBUyxDQUFDLEtBQWdCO1FBQzFCLElBQUksQ0FBQyxvQkFBb0IsQ0FBQyxJQUFJLENBQUMsVUFBVSxFQUFFLEtBQUssQ0FBQyxDQUFDO1FBQ2xELElBQUksQ0FBQyxVQUFVLEdBQUcsS0FBSyxDQUFDO1FBQ3hCLElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQztJQUNyQixDQUFDO0lBRUQsSUFBSSxTQUFTO1FBQ1QsT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDO0lBQzNCLENBQUM7SUFRRCxJQUNJLE9BQU8sQ0FBQyxLQUFjO1FBQ3RCLElBQUksQ0FBQyxRQUFRLEdBQUcsS0FBSyxDQUFDO1FBQ3RCLElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQztJQUNyQixDQUFDO0lBRUQsSUFBSSxPQUFPO1FBQ1AsT0FBTyxJQUFJLENBQUMsUUFBUSxDQUFDO0lBQ3pCLENBQUM7SUFFRCxJQUFJLGFBQWE7UUFDYixPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMsYUFBYSxDQUFDO0lBQ3pDLENBQUM7SUFJRCxZQUFzQixVQUFtQyxFQUFTLEdBQXNCO1FBQWxFLGVBQVUsR0FBVixVQUFVLENBQXlCO1FBQVMsUUFBRyxHQUFILEdBQUcsQ0FBbUI7UUFyQ3hGLGdCQUFXLEdBQUcsS0FBSyxDQUFDO0lBcUN1RSxDQUFDO0lBRTVGLFFBQVE7UUFDSixJQUFJLENBQUMsZUFBZSxHQUFHLElBQUksZUFBZSxDQUFjLElBQUksQ0FBQyxLQUFLLEVBQUU7WUFDaEUsaUJBQWlCLEVBQUUsQ0FBQztZQUNwQixZQUFZLEVBQUUsQ0FBQyxPQUFvQixFQUFFLEVBQUU7Z0JBQ25DLE9BQU8sd0JBQXdCLENBQUMsSUFBSSxDQUFDLEtBQXVCLEVBQUUsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO1lBQ2hGLENBQUM7WUFDRCx1QkFBdUIsRUFBRSxHQUFHLEVBQUU7Z0JBQzFCLE9BQU8sQ0FBQyxDQUFDO1lBQ2IsQ0FBQztTQUNKLENBQUMsQ0FBQztRQUNILElBQUksQ0FBQyxXQUFXLEdBQUcsSUFBSSxDQUFDO0lBQzVCLENBQUM7SUFFRCxTQUFTO1FBQ0wsSUFBSSxJQUFJLENBQUMsV0FBVyxFQUFFO1lBQ2xCLE1BQU0sR0FBRyxHQUFHLFlBQVksQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO1lBQ3BELElBQUksQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsR0FBRyxDQUFDLENBQUMsRUFBRSxFQUFFLFFBQVEsRUFBRSxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUMsQ0FBQztTQUMvRTtJQUNMLENBQUM7O21IQTVEaUIsc0JBQXNCO3VHQUF0QixzQkFBc0I7MkZBQXRCLHNCQUFzQjtrQkFMM0MsU0FBUzttQkFBQztvQkFDUCxJQUFJLEVBQUU7d0JBQ0YsS0FBSyxFQUFFLGlCQUFpQjtxQkFDM0I7aUJBQ0o7aUlBU08sU0FBUztzQkFEWixLQUFLO2dCQVlOLEtBQUs7c0JBREosS0FBSztnQkFJTixPQUFPO3NCQUROLEtBQUs7Z0JBSUYsT0FBTztzQkFEVixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0b3JSZWYsIERpcmVjdGl2ZSwgRWxlbWVudFJlZiwgSW5wdXQsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgSW1hZ2VJdGVtLCBJbWFnZURhdGEgfSBmcm9tICcuLi9pbnRlcmZhY2VzL2VsZW1lbnQtZGF0YSc7XG5pbXBvcnQgeyBQbGFpdEJvYXJkLCBQbGFpdEVsZW1lbnQgfSBmcm9tICdAcGxhaXQvY29yZSc7XG5pbXBvcnQgeyBNaW5kRWxlbWVudCB9IGZyb20gJy4uL2ludGVyZmFjZXMnO1xuaW1wb3J0IHsgQWN0aXZlR2VuZXJhdG9yIH0gZnJvbSAnQHBsYWl0L2NvbW1vbic7XG5pbXBvcnQgeyBnZXRJbWFnZUZvcmVpZ25SZWN0YW5nbGUgfSBmcm9tICcuLi91dGlscy9wb3NpdGlvbi9pbWFnZSc7XG5pbXBvcnQgeyBQbGFpdE1pbmRCb2FyZCB9IGZyb20gJy4uL3BsdWdpbnMvd2l0aC1taW5kLmJvYXJkJztcblxuQERpcmVjdGl2ZSh7XG4gICAgaG9zdDoge1xuICAgICAgICBjbGFzczogJ21pbmQtbm9kZS1pbWFnZSdcbiAgICB9XG59KVxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIE1pbmRJbWFnZUJhc2VDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICAgIF9pbWFnZUl0ZW0hOiBJbWFnZUl0ZW07XG4gICAgX2lzRm9jdXMhOiBib29sZWFuO1xuICAgIGluaXRpYWxpemVkID0gZmFsc2U7XG5cbiAgICBhY3RpdmVHZW5lcmF0b3IhOiBBY3RpdmVHZW5lcmF0b3I8TWluZEVsZW1lbnQ+O1xuXG4gICAgQElucHV0KClcbiAgICBzZXQgaW1hZ2VJdGVtKHZhbHVlOiBJbWFnZUl0ZW0pIHtcbiAgICAgICAgdGhpcy5hZnRlckltYWdlSXRlbUNoYW5nZSh0aGlzLl9pbWFnZUl0ZW0sIHZhbHVlKTtcbiAgICAgICAgdGhpcy5faW1hZ2VJdGVtID0gdmFsdWU7XG4gICAgICAgIHRoaXMuZHJhd0ZvY3VzKCk7XG4gICAgfVxuXG4gICAgZ2V0IGltYWdlSXRlbSgpIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuX2ltYWdlSXRlbTtcbiAgICB9XG5cbiAgICBASW5wdXQoKVxuICAgIGJvYXJkITogUGxhaXRCb2FyZDtcblxuICAgIEBJbnB1dCgpXG4gICAgZWxlbWVudCE6IE1pbmRFbGVtZW50PEltYWdlRGF0YT47XG5cbiAgICBASW5wdXQoKVxuICAgIHNldCBpc0ZvY3VzKHZhbHVlOiBib29sZWFuKSB7XG4gICAgICAgIHRoaXMuX2lzRm9jdXMgPSB2YWx1ZTtcbiAgICAgICAgdGhpcy5kcmF3Rm9jdXMoKTtcbiAgICB9XG5cbiAgICBnZXQgaXNGb2N1cygpIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuX2lzRm9jdXM7XG4gICAgfVxuXG4gICAgZ2V0IG5hdGl2ZUVsZW1lbnQoKSB7XG4gICAgICAgIHJldHVybiB0aGlzLmVsZW1lbnRSZWYubmF0aXZlRWxlbWVudDtcbiAgICB9XG5cbiAgICBhYnN0cmFjdCBhZnRlckltYWdlSXRlbUNoYW5nZShwcmV2aW91czogSW1hZ2VJdGVtLCBjdXJyZW50OiBJbWFnZUl0ZW0pOiB2b2lkO1xuXG4gICAgY29uc3RydWN0b3IocHJvdGVjdGVkIGVsZW1lbnRSZWY6IEVsZW1lbnRSZWY8SFRNTEVsZW1lbnQ+LCBwdWJsaWMgY2RyOiBDaGFuZ2VEZXRlY3RvclJlZikge31cblxuICAgIG5nT25Jbml0KCk6IHZvaWQge1xuICAgICAgICB0aGlzLmFjdGl2ZUdlbmVyYXRvciA9IG5ldyBBY3RpdmVHZW5lcmF0b3I8TWluZEVsZW1lbnQ+KHRoaXMuYm9hcmQsIHtcbiAgICAgICAgICAgIGFjdGl2ZVN0cm9rZVdpZHRoOiAxLFxuICAgICAgICAgICAgZ2V0UmVjdGFuZ2xlOiAoZWxlbWVudDogTWluZEVsZW1lbnQpID0+IHtcbiAgICAgICAgICAgICAgICByZXR1cm4gZ2V0SW1hZ2VGb3JlaWduUmVjdGFuZ2xlKHRoaXMuYm9hcmQgYXMgUGxhaXRNaW5kQm9hcmQsIHRoaXMuZWxlbWVudCk7XG4gICAgICAgICAgICB9LFxuICAgICAgICAgICAgZ2V0U3Ryb2tlV2lkdGhCeUVsZW1lbnQ6ICgpID0+IHtcbiAgICAgICAgICAgICAgICByZXR1cm4gMDtcbiAgICAgICAgICAgIH1cbiAgICAgICAgfSk7XG4gICAgICAgIHRoaXMuaW5pdGlhbGl6ZWQgPSB0cnVlO1xuICAgIH1cblxuICAgIGRyYXdGb2N1cygpIHtcbiAgICAgICAgaWYgKHRoaXMuaW5pdGlhbGl6ZWQpIHtcbiAgICAgICAgICAgIGNvbnN0IGNvbSA9IFBsYWl0RWxlbWVudC5nZXRDb21wb25lbnQodGhpcy5lbGVtZW50KTtcbiAgICAgICAgICAgIHRoaXMuYWN0aXZlR2VuZXJhdG9yLmRyYXcodGhpcy5lbGVtZW50LCBjb20uZywgeyBzZWxlY3RlZDogdGhpcy5faXNGb2N1cyB9KTtcbiAgICAgICAgfVxuICAgIH1cbn1cbiJdfQ==
@@ -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"]}
@@ -1,122 +0,0 @@
1
- import { Path, PlaitBoard, PlaitHistoryBoard, PlaitNode, Transforms, addSelectedElement, getSelectedElements, removeSelectedElement } from '@plait/core';
2
- import { MindElement, PlaitMind } from '../interfaces';
3
- import { isKeyHotkey } from 'is-hotkey';
4
- import { AbstractNode } from '@plait/layouts';
5
- import { getFirstLevelElement, insertMindElement } from '../utils/mind';
6
- import { findNewChildNodePath, findNewSiblingNodePath } from '../utils/path';
7
- import { deleteElementsHandleRightNodeCount, insertElementHandleRightNodeCount, isInRightBranchOfStandardLayout } from '../utils/node/right-node-count';
8
- import { MindTransforms } from '../transforms';
9
- import { deleteElementHandleAbstract, insertElementHandleAbstract } from '../utils/abstract/common';
10
- import { isVirtualKey } from '../utils/is-virtual-key';
11
- import { editTopic, getSelectedMindElements } from '../utils/node/common';
12
- export const withMindHotkey = (baseBoard) => {
13
- const board = baseBoard;
14
- const { keydown, deleteFragment } = board;
15
- board.keydown = (event) => {
16
- const selectedElements = getSelectedElements(board);
17
- const isSingleSelection = selectedElements.length === 1;
18
- const isSingleMindElement = selectedElements.length === 1 && MindElement.isMindElement(board, selectedElements[0]);
19
- const targetElement = selectedElements[0];
20
- if (isExpandHotkey(event) && isSingleMindElement && !PlaitMind.isMind(targetElement)) {
21
- if (targetElement.children && targetElement.children.length > 0) {
22
- Transforms.setNode(board, { isCollapsed: targetElement.isCollapsed ? false : true }, PlaitBoard.findPath(board, targetElement));
23
- return;
24
- }
25
- }
26
- if (!PlaitBoard.isReadonly(board)) {
27
- if (isTabHotkey(event) && isSingleMindElement) {
28
- event.preventDefault();
29
- removeSelectedElement(board, targetElement);
30
- const targetElementPath = PlaitBoard.findPath(board, targetElement);
31
- if (targetElement.isCollapsed) {
32
- const newElement = { isCollapsed: false };
33
- PlaitHistoryBoard.withoutSaving(board, () => {
34
- Transforms.setNode(board, newElement, targetElementPath);
35
- });
36
- }
37
- insertMindElement(board, targetElement, findNewChildNodePath(board, targetElement));
38
- return;
39
- }
40
- if (isEnterHotkey(event) &&
41
- isSingleMindElement &&
42
- !PlaitMind.isMind(targetElement) &&
43
- !AbstractNode.isAbstract(targetElement)) {
44
- const targetElementPath = PlaitBoard.findPath(board, targetElement);
45
- if (isInRightBranchOfStandardLayout(targetElement)) {
46
- const refs = insertElementHandleRightNodeCount(board, targetElementPath.slice(0, 1), 1);
47
- MindTransforms.setRightNodeCountByRefs(board, refs);
48
- }
49
- const abstractRefs = insertElementHandleAbstract(board, Path.next(targetElementPath));
50
- MindTransforms.setAbstractsByRefs(board, abstractRefs);
51
- insertMindElement(board, targetElement, findNewSiblingNodePath(board, targetElement));
52
- return;
53
- }
54
- if (!isVirtualKey(event) && !isSpaceHotkey(event) && isSingleSelection) {
55
- event.preventDefault();
56
- editTopic(targetElement);
57
- return;
58
- }
59
- }
60
- keydown(event);
61
- };
62
- board.deleteFragment = (data) => {
63
- const targetMindElements = getSelectedMindElements(board);
64
- if (targetMindElements.length) {
65
- const firstLevelElements = getFirstLevelElement(targetMindElements).reverse();
66
- const abstractRefs = deleteElementHandleAbstract(board, firstLevelElements);
67
- MindTransforms.setAbstractsByRefs(board, abstractRefs);
68
- const refs = deleteElementsHandleRightNodeCount(board, targetMindElements);
69
- MindTransforms.setRightNodeCountByRefs(board, refs);
70
- MindTransforms.removeElements(board, targetMindElements);
71
- const nextSelected = getNextSelectedElement(board, firstLevelElements);
72
- if (nextSelected) {
73
- addSelectedElement(board, nextSelected);
74
- }
75
- }
76
- deleteFragment(data);
77
- };
78
- return board;
79
- };
80
- export const getNextSelectedElement = (board, firstLevelElements) => {
81
- let activeElement;
82
- const firstLevelElement = firstLevelElements[0];
83
- const firstLevelElementPath = PlaitBoard.findPath(board, firstLevelElement);
84
- let nextSelectedPath = firstLevelElementPath;
85
- if (Path.hasPrevious(firstLevelElementPath)) {
86
- nextSelectedPath = Path.previous(firstLevelElementPath);
87
- }
88
- if (AbstractNode.isAbstract(firstLevelElement)) {
89
- const parent = MindElement.getParent(firstLevelElement);
90
- if (!firstLevelElements.includes(parent.children[firstLevelElement.start])) {
91
- activeElement = parent.children[firstLevelElement.start];
92
- }
93
- }
94
- try {
95
- if (!activeElement) {
96
- activeElement = PlaitNode.get(board, nextSelectedPath);
97
- }
98
- }
99
- catch (error) { }
100
- const firstElement = firstLevelElements[0];
101
- const firstElementParent = MindElement.findParent(firstElement);
102
- const hasSameParent = firstLevelElements.every(element => {
103
- return MindElement.findParent(element) === firstElementParent;
104
- });
105
- if (firstElementParent && hasSameParent && !activeElement) {
106
- activeElement = firstElementParent;
107
- }
108
- return activeElement;
109
- };
110
- export const isExpandHotkey = (event) => {
111
- return isKeyHotkey('mod+/', event);
112
- };
113
- export const isTabHotkey = (event) => {
114
- return event.key === 'Tab';
115
- };
116
- export const isEnterHotkey = (event) => {
117
- return event.key === 'Enter';
118
- };
119
- export const isSpaceHotkey = (event) => {
120
- return event.code === 'Space';
121
- };
122
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-mind-hotkey.js","sourceRoot":"","sources":["../../../../packages/mind/src/plugins/with-mind-hotkey.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Path,\n    PlaitBoard,\n    PlaitHistoryBoard,\n    PlaitNode,\n    Transforms,\n    addSelectedElement,\n    getSelectedElements,\n    hotkeys,\n    removeSelectedElement\n} from '@plait/core';\nimport { MindElement, PlaitMind } from '../interfaces';\nimport { isKeyHotkey } from 'is-hotkey';\nimport { AbstractNode } from '@plait/layouts';\nimport { getFirstLevelElement, insertMindElement } from '../utils/mind';\nimport { findNewChildNodePath, findNewSiblingNodePath } from '../utils/path';\nimport {\n    deleteElementsHandleRightNodeCount,\n    insertElementHandleRightNodeCount,\n    isInRightBranchOfStandardLayout\n} from '../utils/node/right-node-count';\nimport { MindTransforms } from '../transforms';\nimport { deleteElementHandleAbstract, insertElementHandleAbstract } from '../utils/abstract/common';\nimport { isVirtualKey } from '../utils/is-virtual-key';\nimport { editTopic, getSelectedMindElements } from '../utils/node/common';\nimport { PlaitMindBoard } from './with-mind.board';\n\nexport const withMindHotkey = (baseBoard: PlaitBoard) => {\n    const board = baseBoard as PlaitBoard & PlaitMindBoard;\n    const { keydown, deleteFragment } = board;\n\n    board.keydown = (event: KeyboardEvent) => {\n        const selectedElements = getSelectedElements(board);\n        const isSingleSelection = selectedElements.length === 1;\n        const isSingleMindElement = selectedElements.length === 1 && MindElement.isMindElement(board, selectedElements[0]);\n        const targetElement = selectedElements[0] as MindElement;\n\n        if (isExpandHotkey(event) && isSingleMindElement && !PlaitMind.isMind(targetElement)) {\n            if (targetElement.children && targetElement.children.length > 0) {\n                Transforms.setNode(\n                    board,\n                    { isCollapsed: targetElement.isCollapsed ? false : true },\n                    PlaitBoard.findPath(board, targetElement)\n                );\n                return;\n            }\n        }\n\n        if (!PlaitBoard.isReadonly(board)) {\n            if (isTabHotkey(event) && isSingleMindElement) {\n                event.preventDefault();\n                removeSelectedElement(board, targetElement);\n                const targetElementPath = PlaitBoard.findPath(board, targetElement);\n                if (targetElement.isCollapsed) {\n                    const newElement: Partial<MindElement> = { isCollapsed: false };\n                    PlaitHistoryBoard.withoutSaving(board, () => {\n                        Transforms.setNode(board, newElement, targetElementPath);\n                    });\n                }\n                insertMindElement(board, targetElement, findNewChildNodePath(board, targetElement));\n                return;\n            }\n\n            if (\n                isEnterHotkey(event) &&\n                isSingleMindElement &&\n                !PlaitMind.isMind(targetElement) &&\n                !AbstractNode.isAbstract(targetElement)\n            ) {\n                const targetElementPath = PlaitBoard.findPath(board, targetElement);\n                if (isInRightBranchOfStandardLayout(targetElement)) {\n                    const refs = insertElementHandleRightNodeCount(board, targetElementPath.slice(0, 1), 1);\n                    MindTransforms.setRightNodeCountByRefs(board, refs);\n                }\n                const abstractRefs = insertElementHandleAbstract(board, Path.next(targetElementPath));\n                MindTransforms.setAbstractsByRefs(board, abstractRefs);\n                insertMindElement(board, targetElement, findNewSiblingNodePath(board, targetElement));\n                return;\n            }\n\n            if (!isVirtualKey(event) && !isSpaceHotkey(event) && isSingleSelection) {\n                event.preventDefault();\n                editTopic(targetElement);\n                return;\n            }\n        }\n\n        keydown(event);\n    };\n\n    board.deleteFragment = (data: DataTransfer | null) => {\n        const targetMindElements = getSelectedMindElements(board);\n        if (targetMindElements.length) {\n            const firstLevelElements = getFirstLevelElement(targetMindElements).reverse();\n            const abstractRefs = deleteElementHandleAbstract(board, firstLevelElements);\n            MindTransforms.setAbstractsByRefs(board, abstractRefs);\n\n            const refs = deleteElementsHandleRightNodeCount(board, targetMindElements);\n            MindTransforms.setRightNodeCountByRefs(board, refs);\n\n            MindTransforms.removeElements(board, targetMindElements);\n\n            const nextSelected = getNextSelectedElement(board, firstLevelElements);\n            if (nextSelected) {\n                addSelectedElement(board, nextSelected);\n            }\n        }\n        deleteFragment(data);\n    };\n\n    return board;\n};\n\nexport const getNextSelectedElement = (board: PlaitBoard, firstLevelElements: MindElement[]) => {\n    let activeElement: MindElement | undefined;\n    const firstLevelElement = firstLevelElements[0];\n    const firstLevelElementPath = PlaitBoard.findPath(board, firstLevelElement);\n\n    let nextSelectedPath = firstLevelElementPath;\n    if (Path.hasPrevious(firstLevelElementPath)) {\n        nextSelectedPath = Path.previous(firstLevelElementPath);\n    }\n\n    if (AbstractNode.isAbstract(firstLevelElement)) {\n        const parent = MindElement.getParent(firstLevelElement);\n        if (!firstLevelElements.includes(parent.children[firstLevelElement.start])) {\n            activeElement = parent.children[firstLevelElement.start];\n        }\n    }\n\n    try {\n        if (!activeElement) {\n            activeElement = PlaitNode.get<MindElement>(board, nextSelectedPath);\n        }\n    } catch (error) {}\n\n    const firstElement = firstLevelElements[0];\n    const firstElementParent = MindElement.findParent(firstElement);\n    const hasSameParent = firstLevelElements.every(element => {\n        return MindElement.findParent(element) === firstElementParent;\n    });\n    if (firstElementParent && hasSameParent && !activeElement) {\n        activeElement = firstElementParent;\n    }\n    return activeElement;\n};\n\nexport const isExpandHotkey = (event: KeyboardEvent) => {\n    return isKeyHotkey('mod+/', event);\n};\n\nexport const isTabHotkey = (event: KeyboardEvent) => {\n    return event.key === 'Tab';\n};\n\nexport const isEnterHotkey = (event: KeyboardEvent) => {\n    return event.key === 'Enter';\n};\n\nexport const isSpaceHotkey = (event: KeyboardEvent) => {\n    return event.code === 'Space';\n};\n"]}