@plait/mind 0.77.3 → 0.78.0-next.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (96) hide show
  1. package/fesm2022/plait-mind.mjs +2 -2
  2. package/fesm2022/plait-mind.mjs.map +1 -1
  3. package/package.json +1 -3
  4. package/esm2022/constants/abstract-node.mjs +0 -5
  5. package/esm2022/constants/default.mjs +0 -17
  6. package/esm2022/constants/index.mjs +0 -5
  7. package/esm2022/constants/node-style.mjs +0 -19
  8. package/esm2022/constants/node-topic-style.mjs +0 -7
  9. package/esm2022/constants/theme.mjs +0 -73
  10. package/esm2022/emoji/emoji-base.component.mjs +0 -6
  11. package/esm2022/emoji/index.mjs +0 -3
  12. package/esm2022/emoji/with-emoji.mjs +0 -8
  13. package/esm2022/generators/node-active.generator.mjs +0 -46
  14. package/esm2022/generators/node-collapse.generator.mjs +0 -108
  15. package/esm2022/generators/node-emojis.generator.mjs +0 -63
  16. package/esm2022/generators/node-plus.generator.mjs +0 -100
  17. package/esm2022/generators/node-shape.generator.mjs +0 -22
  18. package/esm2022/interfaces/element-data.mjs +0 -2
  19. package/esm2022/interfaces/element.mjs +0 -103
  20. package/esm2022/interfaces/index.mjs +0 -8
  21. package/esm2022/interfaces/layout.mjs +0 -19
  22. package/esm2022/interfaces/node.mjs +0 -14
  23. package/esm2022/interfaces/options.mjs +0 -2
  24. package/esm2022/interfaces/pointer.mjs +0 -5
  25. package/esm2022/interfaces/theme-color.mjs +0 -57
  26. package/esm2022/interfaces/types.mjs +0 -13
  27. package/esm2022/mind-node.component.mjs +0 -193
  28. package/esm2022/mind.component.mjs +0 -34
  29. package/esm2022/plait-mind.mjs +0 -5
  30. package/esm2022/plugins/with-abstract-resize.board.mjs +0 -12
  31. package/esm2022/plugins/with-abstract-resize.mjs +0 -112
  32. package/esm2022/plugins/with-mind-create.mjs +0 -104
  33. package/esm2022/plugins/with-mind-extend.mjs +0 -7
  34. package/esm2022/plugins/with-mind-fragment.mjs +0 -101
  35. package/esm2022/plugins/with-mind-hotkey.mjs +0 -62
  36. package/esm2022/plugins/with-mind.board.mjs +0 -2
  37. package/esm2022/plugins/with-mind.mjs +0 -148
  38. package/esm2022/plugins/with-node-dnd.mjs +0 -176
  39. package/esm2022/plugins/with-node-hover-hit-test.mjs +0 -23
  40. package/esm2022/plugins/with-node-image-resize.mjs +0 -46
  41. package/esm2022/plugins/with-node-image.mjs +0 -113
  42. package/esm2022/plugins/with-node-resize.mjs +0 -69
  43. package/esm2022/public-api.mjs +0 -16
  44. package/esm2022/queries/get-available-sublayouts-by-element.mjs +0 -23
  45. package/esm2022/queries/get-branch-layouts.mjs +0 -18
  46. package/esm2022/queries/get-correct-layout-by-element.mjs +0 -48
  47. package/esm2022/queries/get-layout-by-element.mjs +0 -18
  48. package/esm2022/queries/index.mjs +0 -11
  49. package/esm2022/transforms/abstract-node.mjs +0 -73
  50. package/esm2022/transforms/emoji.mjs +0 -41
  51. package/esm2022/transforms/image.mjs +0 -31
  52. package/esm2022/transforms/index.mjs +0 -30
  53. package/esm2022/transforms/layout.mjs +0 -19
  54. package/esm2022/transforms/node.mjs +0 -99
  55. package/esm2022/transforms/property.mjs +0 -34
  56. package/esm2022/utils/abstract/common.mjs +0 -170
  57. package/esm2022/utils/abstract/resize.mjs +0 -194
  58. package/esm2022/utils/clipboard.mjs +0 -108
  59. package/esm2022/utils/common.mjs +0 -26
  60. package/esm2022/utils/dnd/common.mjs +0 -59
  61. package/esm2022/utils/dnd/detector.mjs +0 -176
  62. package/esm2022/utils/draw/abstract-outline.mjs +0 -118
  63. package/esm2022/utils/draw/node-dnd.mjs +0 -164
  64. package/esm2022/utils/draw/node-link/abstract-link.mjs +0 -60
  65. package/esm2022/utils/draw/node-link/draw-link.mjs +0 -9
  66. package/esm2022/utils/draw/node-link/indented-link.mjs +0 -46
  67. package/esm2022/utils/draw/node-link/logic-link.mjs +0 -76
  68. package/esm2022/utils/draw/node-shape.mjs +0 -26
  69. package/esm2022/utils/index.mjs +0 -17
  70. package/esm2022/utils/layout.mjs +0 -105
  71. package/esm2022/utils/mind.mjs +0 -98
  72. package/esm2022/utils/node/adjust-node.mjs +0 -36
  73. package/esm2022/utils/node/common.mjs +0 -15
  74. package/esm2022/utils/node/create-node.mjs +0 -46
  75. package/esm2022/utils/node/dynamic-width.mjs +0 -14
  76. package/esm2022/utils/node/image.mjs +0 -15
  77. package/esm2022/utils/node/index.mjs +0 -6
  78. package/esm2022/utils/node/right-node-count.mjs +0 -45
  79. package/esm2022/utils/node-hover/extend.mjs +0 -50
  80. package/esm2022/utils/node-style/branch.mjs +0 -63
  81. package/esm2022/utils/node-style/common.mjs +0 -4
  82. package/esm2022/utils/node-style/index.mjs +0 -4
  83. package/esm2022/utils/node-style/shape.mjs +0 -37
  84. package/esm2022/utils/normalize.mjs +0 -40
  85. package/esm2022/utils/path.mjs +0 -12
  86. package/esm2022/utils/point-placement.mjs +0 -119
  87. package/esm2022/utils/position/emoji.mjs +0 -31
  88. package/esm2022/utils/position/image.mjs +0 -36
  89. package/esm2022/utils/position/index.mjs +0 -5
  90. package/esm2022/utils/position/node.mjs +0 -36
  91. package/esm2022/utils/position/topic.mjs +0 -16
  92. package/esm2022/utils/space/emoji.mjs +0 -20
  93. package/esm2022/utils/space/index.mjs +0 -4
  94. package/esm2022/utils/space/layout-options.mjs +0 -69
  95. package/esm2022/utils/space/node-space.mjs +0 -134
  96. package/esm2022/utils/weak-maps.mjs +0 -2
@@ -1,103 +0,0 @@
1
- import { isIndentedLayout } from '@plait/layouts';
2
- import { isNullOrUndefined, NODE_TO_PARENT, Path, PlaitBoard, PlaitNode } from '@plait/core';
3
- import { MindQueries } from '../queries';
4
- import { ELEMENT_TO_NODE } from '../utils';
5
- export const PlaitMind = {
6
- isMind: (value) => {
7
- return value.type === 'mindmap';
8
- }
9
- };
10
- export const MindElement = {
11
- hasLayout(value, layout) {
12
- const _layout = MindQueries.getLayoutByElement(value);
13
- return _layout === layout;
14
- },
15
- isIndentedLayout(value) {
16
- const _layout = MindQueries.getLayoutByElement(value);
17
- return isIndentedLayout(_layout);
18
- },
19
- isMindElement(board, element) {
20
- // Design error: The type of the element should be identified based on type.
21
- // Now it is very awkward whether it is dynamically calculated(query root node) or using other characteristic attributes(current).
22
- // Using dynamically calculated will cause more issue like pasting from clipboard, finding elements by id(isRecursion)
23
- if (element.data && element.data.topic && !isNullOrUndefined(element.width) && !isNullOrUndefined(element.height)) {
24
- return true;
25
- }
26
- else {
27
- return false;
28
- }
29
- },
30
- getParent(node) {
31
- if (PlaitMind.isMind(node)) {
32
- throw new Error('mind root node can not get parent');
33
- }
34
- const parent = NODE_TO_PARENT.get(node);
35
- return parent;
36
- },
37
- findParent(node) {
38
- if (PlaitMind.isMind(node)) {
39
- return undefined;
40
- }
41
- const parent = NODE_TO_PARENT.get(node);
42
- return parent;
43
- },
44
- getRoot(board, element) {
45
- const path = PlaitBoard.findPath(board, element);
46
- return PlaitNode.get(board, path.slice(0, 1));
47
- },
48
- getAncestors(board, element) {
49
- const path = PlaitBoard.findPath(board, element);
50
- const parents = [];
51
- for (const p of Path.ancestors(path, { reverse: true })) {
52
- const n = PlaitNode.get(board, p);
53
- if (n && !PlaitBoard.isBoard(n)) {
54
- parents.push(n);
55
- }
56
- }
57
- return parents;
58
- },
59
- getNode(element) {
60
- const node = ELEMENT_TO_NODE.get(element);
61
- if (!node) {
62
- throw new Error(`can not get node from ${JSON.stringify(element)}`);
63
- }
64
- return node;
65
- },
66
- findParentNode(element) {
67
- if (PlaitMind.isMind(element)) {
68
- return undefined;
69
- }
70
- const parent = MindElement.getParent(element);
71
- return MindElement.getNode(parent);
72
- },
73
- hasEmojis(element) {
74
- if (element.data.emojis) {
75
- return true;
76
- }
77
- else {
78
- return false;
79
- }
80
- },
81
- hasImage(element) {
82
- if (element.data.image) {
83
- return true;
84
- }
85
- else {
86
- return false;
87
- }
88
- },
89
- getEmojis(element) {
90
- return element.data.emojis;
91
- }
92
- };
93
- export var MindElementShape;
94
- (function (MindElementShape) {
95
- MindElementShape["roundRectangle"] = "round-rectangle";
96
- MindElementShape["underline"] = "underline";
97
- })(MindElementShape || (MindElementShape = {}));
98
- export var BranchShape;
99
- (function (BranchShape) {
100
- BranchShape["bight"] = "bight";
101
- BranchShape["polyline"] = "polyline";
102
- })(BranchShape || (BranchShape = {}));
103
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"element.js","sourceRoot":"","sources":["../../../../packages/mind/src/interfaces/element.ts"],"names":[],"mappings":"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","sourcesContent":["import { isIndentedLayout, MindLayoutType } from '@plait/layouts';\nimport { isNullOrUndefined, NODE_TO_PARENT, Path, PlaitBoard, PlaitElement, PlaitNode, Point } from '@plait/core';\nimport { MindQueries } from '../queries';\nimport { ELEMENT_TO_NODE } from '../utils';\nimport { BaseData, EmojiData, ImageData } from './element-data';\nimport { StrokeStyle } from '@plait/common';\n\nexport interface MindElement<T = BaseData> extends PlaitElement {\n    data: T;\n    children: MindElement[];\n    rightNodeCount?: number;\n    width: number;\n    manualWidth?: number;\n    height: number;\n    isRoot?: boolean;\n\n    // node style attributes\n    fill?: string;\n    strokeColor?: string;\n    strokeWidth?: number;\n    strokeStyle?: StrokeStyle;\n    shape?: MindElementShape;\n\n    // link style attributes\n    branchColor?: string;\n    branchWidth?: number;\n    branchShape?: BranchShape;\n\n    // layout\n    layout?: MindLayoutType;\n    isCollapsed?: boolean;\n\n    start?: number;\n    end?: number;\n}\n\nexport interface PlaitMind extends MindElement {\n    type: 'mindmap';\n    points: Point[];\n}\n\nexport const PlaitMind = {\n    isMind: (value: any): value is PlaitMind => {\n        return value.type === 'mindmap';\n    }\n};\n\nexport const MindElement = {\n    hasLayout(value: MindElement, layout: MindLayoutType) {\n        const _layout = MindQueries.getLayoutByElement(value);\n        return _layout === layout;\n    },\n    isIndentedLayout(value: MindElement) {\n        const _layout = MindQueries.getLayoutByElement(value) as MindLayoutType;\n        return isIndentedLayout(_layout);\n    },\n    isMindElement(board: PlaitBoard, element: PlaitElement): element is MindElement {\n        // Design error: The type of the element should be identified based on type.\n        // Now it is very awkward whether it is dynamically calculated(query root node) or using other characteristic attributes(current).\n        // Using dynamically calculated will cause more issue like pasting from clipboard, finding elements by id(isRecursion)\n        if (element.data && element.data.topic && !isNullOrUndefined(element.width) && !isNullOrUndefined(element.height)) {\n            return true;\n        } else {\n            return false;\n        }\n    },\n    getParent(node: MindElement) {\n        if (PlaitMind.isMind(node)) {\n            throw new Error('mind root node can not get parent');\n        }\n        const parent = NODE_TO_PARENT.get(node) as MindElement;\n        return parent;\n    },\n    findParent(node: MindElement) {\n        if (PlaitMind.isMind(node)) {\n            return undefined;\n        }\n        const parent = NODE_TO_PARENT.get(node) as MindElement;\n        return parent;\n    },\n    getRoot(board: PlaitBoard, element: MindElement) {\n        const path = PlaitBoard.findPath(board, element);\n        return PlaitNode.get(board, path.slice(0, 1)) as PlaitMind;\n    },\n    getAncestors(board: PlaitBoard, element: MindElement) {\n        const path = PlaitBoard.findPath(board, element);\n        const parents: PlaitElement[] = [];\n        for (const p of Path.ancestors(path, { reverse: true })) {\n            const n = PlaitNode.get(board, p);\n            if (n && !PlaitBoard.isBoard(n)) {\n                parents.push(n);\n            }\n        }\n        return parents;\n    },\n    getNode(element: MindElement) {\n        const node = ELEMENT_TO_NODE.get(element);\n        if (!node) {\n            throw new Error(`can not get node from ${JSON.stringify(element)}`);\n        }\n        return node;\n    },\n    findParentNode(element: MindElement) {\n        if (PlaitMind.isMind(element)) {\n            return undefined;\n        }\n        const parent = MindElement.getParent(element);\n        return MindElement.getNode(parent);\n    },\n    hasEmojis(element: MindElement): element is MindElement<EmojiData> {\n        if (element.data.emojis) {\n            return true;\n        } else {\n            return false;\n        }\n    },\n    hasImage(element: MindElement): element is MindElement<ImageData> {\n        if (element.data.image) {\n            return true;\n        } else {\n            return false;\n        }\n    },\n    getEmojis(element: MindElement<EmojiData>) {\n        return element.data.emojis;\n    }\n};\n\nexport enum MindElementShape {\n    roundRectangle = 'round-rectangle',\n    underline = 'underline'\n}\n\nexport enum BranchShape {\n    bight = 'bight',\n    polyline = 'polyline'\n}\n"]}
@@ -1,8 +0,0 @@
1
- export * from './element';
2
- export * from './element-data';
3
- export * from './node';
4
- export * from './layout';
5
- export * from './pointer';
6
- export * from './theme-color';
7
- export * from './options';
8
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9taW5kL3NyYy9pbnRlcmZhY2VzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsV0FBVyxDQUFDO0FBQzFCLGNBQWMsZ0JBQWdCLENBQUM7QUFDL0IsY0FBYyxRQUFRLENBQUM7QUFDdkIsY0FBYyxVQUFVLENBQUM7QUFDekIsY0FBYyxXQUFXLENBQUM7QUFDMUIsY0FBYyxlQUFlLENBQUM7QUFDOUIsY0FBYyxXQUFXLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2VsZW1lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9lbGVtZW50LWRhdGEnO1xuZXhwb3J0ICogZnJvbSAnLi9ub2RlJztcbmV4cG9ydCAqIGZyb20gJy4vbGF5b3V0JztcbmV4cG9ydCAqIGZyb20gJy4vcG9pbnRlcic7XG5leHBvcnQgKiBmcm9tICcuL3RoZW1lLWNvbG9yJztcbmV4cG9ydCAqIGZyb20gJy4vb3B0aW9ucyc7XG4iXX0=
@@ -1,19 +0,0 @@
1
- import { MindLayoutType } from '@plait/layouts';
2
- export var LayoutDirection;
3
- (function (LayoutDirection) {
4
- LayoutDirection["top"] = "top";
5
- LayoutDirection["right"] = "right";
6
- LayoutDirection["bottom"] = "bottom";
7
- LayoutDirection["left"] = "left";
8
- })(LayoutDirection || (LayoutDirection = {}));
9
- export const LayoutDirectionsMap = {
10
- [MindLayoutType.right]: [LayoutDirection.right],
11
- [MindLayoutType.left]: [LayoutDirection.left],
12
- [MindLayoutType.upward]: [LayoutDirection.top],
13
- [MindLayoutType.downward]: [LayoutDirection.bottom],
14
- [MindLayoutType.rightBottomIndented]: [LayoutDirection.right, LayoutDirection.bottom],
15
- [MindLayoutType.rightTopIndented]: [LayoutDirection.right, LayoutDirection.top],
16
- [MindLayoutType.leftBottomIndented]: [LayoutDirection.left, LayoutDirection.bottom],
17
- [MindLayoutType.leftTopIndented]: [LayoutDirection.left, LayoutDirection.top]
18
- };
19
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGF5b3V0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvbWluZC9zcmMvaW50ZXJmYWNlcy9sYXlvdXQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBRWhELE1BQU0sQ0FBTixJQUFZLGVBS1g7QUFMRCxXQUFZLGVBQWU7SUFDdkIsOEJBQWEsQ0FBQTtJQUNiLGtDQUFpQixDQUFBO0lBQ2pCLG9DQUFtQixDQUFBO0lBQ25CLGdDQUFlLENBQUE7QUFDbkIsQ0FBQyxFQUxXLGVBQWUsS0FBZixlQUFlLFFBSzFCO0FBRUQsTUFBTSxDQUFDLE1BQU0sbUJBQW1CLEdBQTJCO0lBQ3ZELENBQUMsY0FBYyxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsZUFBZSxDQUFDLEtBQUssQ0FBQztJQUMvQyxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUM7SUFDN0MsQ0FBQyxjQUFjLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQyxlQUFlLENBQUMsR0FBRyxDQUFDO0lBQzlDLENBQUMsY0FBYyxDQUFDLFFBQVEsQ0FBQyxFQUFFLENBQUMsZUFBZSxDQUFDLE1BQU0sQ0FBQztJQUNuRCxDQUFDLGNBQWMsQ0FBQyxtQkFBbUIsQ0FBQyxFQUFFLENBQUMsZUFBZSxDQUFDLEtBQUssRUFBRSxlQUFlLENBQUMsTUFBTSxDQUFDO0lBQ3JGLENBQUMsY0FBYyxDQUFDLGdCQUFnQixDQUFDLEVBQUUsQ0FBQyxlQUFlLENBQUMsS0FBSyxFQUFFLGVBQWUsQ0FBQyxHQUFHLENBQUM7SUFDL0UsQ0FBQyxjQUFjLENBQUMsa0JBQWtCLENBQUMsRUFBRSxDQUFDLGVBQWUsQ0FBQyxJQUFJLEVBQUUsZUFBZSxDQUFDLE1BQU0sQ0FBQztJQUNuRixDQUFDLGNBQWMsQ0FBQyxlQUFlLENBQUMsRUFBRSxDQUFDLGVBQWUsQ0FBQyxJQUFJLEVBQUUsZUFBZSxDQUFDLEdBQUcsQ0FBQztDQUNoRixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTWluZExheW91dFR5cGUgfSBmcm9tICdAcGxhaXQvbGF5b3V0cyc7XG5cbmV4cG9ydCBlbnVtIExheW91dERpcmVjdGlvbiB7XG4gICAgJ3RvcCcgPSAndG9wJyxcbiAgICAncmlnaHQnID0gJ3JpZ2h0JyxcbiAgICAnYm90dG9tJyA9ICdib3R0b20nLFxuICAgICdsZWZ0JyA9ICdsZWZ0J1xufVxuXG5leHBvcnQgY29uc3QgTGF5b3V0RGlyZWN0aW9uc01hcDogTGF5b3V0RGlyZWN0aW9uTWFwVHlwZSA9IHtcbiAgICBbTWluZExheW91dFR5cGUucmlnaHRdOiBbTGF5b3V0RGlyZWN0aW9uLnJpZ2h0XSxcbiAgICBbTWluZExheW91dFR5cGUubGVmdF06IFtMYXlvdXREaXJlY3Rpb24ubGVmdF0sXG4gICAgW01pbmRMYXlvdXRUeXBlLnVwd2FyZF06IFtMYXlvdXREaXJlY3Rpb24udG9wXSxcbiAgICBbTWluZExheW91dFR5cGUuZG93bndhcmRdOiBbTGF5b3V0RGlyZWN0aW9uLmJvdHRvbV0sXG4gICAgW01pbmRMYXlvdXRUeXBlLnJpZ2h0Qm90dG9tSW5kZW50ZWRdOiBbTGF5b3V0RGlyZWN0aW9uLnJpZ2h0LCBMYXlvdXREaXJlY3Rpb24uYm90dG9tXSxcbiAgICBbTWluZExheW91dFR5cGUucmlnaHRUb3BJbmRlbnRlZF06IFtMYXlvdXREaXJlY3Rpb24ucmlnaHQsIExheW91dERpcmVjdGlvbi50b3BdLFxuICAgIFtNaW5kTGF5b3V0VHlwZS5sZWZ0Qm90dG9tSW5kZW50ZWRdOiBbTGF5b3V0RGlyZWN0aW9uLmxlZnQsIExheW91dERpcmVjdGlvbi5ib3R0b21dLFxuICAgIFtNaW5kTGF5b3V0VHlwZS5sZWZ0VG9wSW5kZW50ZWRdOiBbTGF5b3V0RGlyZWN0aW9uLmxlZnQsIExheW91dERpcmVjdGlvbi50b3BdXG59O1xuXG5leHBvcnQgdHlwZSBMYXlvdXREaXJlY3Rpb25NYXBUeXBlID0geyBba2V5OiBzdHJpbmddOiBMYXlvdXREaXJlY3Rpb25bXSB9O1xuIl19
@@ -1,14 +0,0 @@
1
- export const MindNode = {
2
- get(root, path) {
3
- let node = root;
4
- for (let i = 0; i < path.length; i++) {
5
- const p = path[i];
6
- if (!node || !node.children || !node.children[p]) {
7
- throw new Error(`Cannot find a descendant at path [${path}]`);
8
- }
9
- node = node.children[p];
10
- }
11
- return node;
12
- }
13
- };
14
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9kZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL21pbmQvc3JjL2ludGVyZmFjZXMvbm9kZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFtQkEsTUFBTSxDQUFDLE1BQU0sUUFBUSxHQUFHO0lBQ3BCLEdBQUcsQ0FBQyxJQUFjLEVBQUUsSUFBVTtRQUMxQixJQUFJLElBQUksR0FBRyxJQUFJLENBQUM7UUFDaEIsS0FBSyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQyxFQUFFLEVBQUUsQ0FBQztZQUNuQyxNQUFNLENBQUMsR0FBRyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDbEIsSUFBSSxDQUFDLElBQUksSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUM7Z0JBQy9DLE1BQU0sSUFBSSxLQUFLLENBQUMscUNBQXFDLElBQUksR0FBRyxDQUFDLENBQUM7WUFDbEUsQ0FBQztZQUNELElBQUksR0FBRyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQzVCLENBQUM7UUFDRCxPQUFPLElBQUksQ0FBQztJQUNoQixDQUFDO0NBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE1pbmRMYXlvdXRUeXBlIH0gZnJvbSAnQHBsYWl0L2xheW91dHMnO1xuaW1wb3J0IHsgUGF0aCB9IGZyb20gJ0BwbGFpdC9jb3JlJztcbmltcG9ydCB7IE1pbmRFbGVtZW50IH0gZnJvbSAnLi9lbGVtZW50JztcblxuZXhwb3J0IGludGVyZmFjZSBNaW5kTm9kZSB7XG4gICAgZGVwdGg6IG51bWJlcjtcbiAgICB4OiBudW1iZXI7XG4gICAgeTogbnVtYmVyO1xuICAgIHdpZHRoOiBudW1iZXI7XG4gICAgaGVpZ2h0OiBudW1iZXI7XG4gICAgaEdhcDogbnVtYmVyO1xuICAgIHZHYXA6IG51bWJlcjtcbiAgICBjaGlsZHJlbjogTWluZE5vZGVbXTtcbiAgICBvcmlnaW46IE1pbmRFbGVtZW50O1xuICAgIHBhcmVudDogTWluZE5vZGU7XG4gICAgbGVmdDogYm9vbGVhbjtcbiAgICB1cDogYm9vbGVhbjtcbn1cblxuZXhwb3J0IGNvbnN0IE1pbmROb2RlID0ge1xuICAgIGdldChyb290OiBNaW5kTm9kZSwgcGF0aDogUGF0aCkge1xuICAgICAgICBsZXQgbm9kZSA9IHJvb3Q7XG4gICAgICAgIGZvciAobGV0IGkgPSAwOyBpIDwgcGF0aC5sZW5ndGg7IGkrKykge1xuICAgICAgICAgICAgY29uc3QgcCA9IHBhdGhbaV07XG4gICAgICAgICAgICBpZiAoIW5vZGUgfHwgIW5vZGUuY2hpbGRyZW4gfHwgIW5vZGUuY2hpbGRyZW5bcF0pIHtcbiAgICAgICAgICAgICAgICB0aHJvdyBuZXcgRXJyb3IoYENhbm5vdCBmaW5kIGEgZGVzY2VuZGFudCBhdCBwYXRoIFske3BhdGh9XWApO1xuICAgICAgICAgICAgfVxuICAgICAgICAgICAgbm9kZSA9IG5vZGUuY2hpbGRyZW5bcF07XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIG5vZGU7XG4gICAgfVxufTtcblxuZXhwb3J0IHR5cGUgRXh0ZW5kTGF5b3V0VHlwZSA9IEV4Y2x1ZGU8TWluZExheW91dFR5cGUsIE1pbmRMYXlvdXRUeXBlLnN0YW5kYXJkPjtcblxuZXhwb3J0IHR5cGUgQ29vcmRpbmF0ZVR5cGUgPSB7XG4gICAgc3RhcnRYOiBudW1iZXI7XG4gICAgc3RhcnRZOiBudW1iZXI7XG4gICAgZW5kWDogbnVtYmVyO1xuICAgIGVuZFk6IG51bWJlcjtcbn07XG5cbmV4cG9ydCB0eXBlIEV4dGVuZFVuZGVybGluZUNvb3JkaW5hdGVUeXBlID0ge1xuICAgIFtrZXkgaW4gRXh0ZW5kTGF5b3V0VHlwZV06IENvb3JkaW5hdGVUeXBlO1xufTtcblxuZXhwb3J0IHR5cGUgRGV0ZWN0UmVzdWx0ID0gJ3RvcCcgfCAnYm90dG9tJyB8ICdyaWdodCcgfCAnbGVmdCcgfCBudWxsO1xuXG5leHBvcnQgdHlwZSBSb290QmFzZURpcmVjdGlvbiA9ICdyaWdodCcgfCAnbGVmdCcgfCBudWxsO1xuIl19
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3B0aW9ucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL21pbmQvc3JjL2ludGVyZmFjZXMvb3B0aW9ucy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgV2l0aFBsdWdpbk9wdGlvbnMgfSBmcm9tICdAcGxhaXQvY29yZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgV2l0aE1pbmRPcHRpb25zIGV4dGVuZHMgV2l0aFBsdWdpbk9wdGlvbnMge1xuICAgIGVtb2ppUGFkZGluZzogbnVtYmVyO1xuICAgIHNwYWNlQmV0d2VlbkVtb2ppczogbnVtYmVyO1xufVxuIl19
@@ -1,5 +0,0 @@
1
- export var MindPointerType;
2
- (function (MindPointerType) {
3
- MindPointerType["mind"] = "mind";
4
- })(MindPointerType || (MindPointerType = {}));
5
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9pbnRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL21pbmQvc3JjL2ludGVyZmFjZXMvcG9pbnRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLENBQU4sSUFBWSxlQUVYO0FBRkQsV0FBWSxlQUFlO0lBQ3ZCLGdDQUFlLENBQUE7QUFDbkIsQ0FBQyxFQUZXLGVBQWUsS0FBZixlQUFlLFFBRTFCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGVudW0gTWluZFBvaW50ZXJUeXBlIHtcbiAgICAnbWluZCcgPSAnbWluZCdcbn1cbiJdfQ==
@@ -1,57 +0,0 @@
1
- import { DefaultThemeColor, StarryThemeColor, DarkThemeColor, ColorfulThemeColor, SoftThemeColor, RetroThemeColor, DEFAULT_COLOR } from '@plait/core';
2
- import { COLORFUL_BRANCH_COLORS, DARK_BRANCH_COLORS, DEFAULT_BRANCH_COLORS, RETRO_BRANCH_COLORS, SOFT_BRANCH_COLORS, STARRY_BRANCH_COLORS } from '../constants/theme';
3
- export const MindDefaultThemeColor = {
4
- ...DefaultThemeColor,
5
- branchColors: DEFAULT_BRANCH_COLORS,
6
- rootFill: '#f5f5f5',
7
- rootTextColor: DEFAULT_COLOR
8
- };
9
- export const MindColorfulThemeColor = {
10
- ...ColorfulThemeColor,
11
- branchColors: COLORFUL_BRANCH_COLORS,
12
- rootFill: DEFAULT_COLOR,
13
- rootTextColor: '#FFFFFF'
14
- };
15
- export const MindSoftThemeColor = {
16
- ...SoftThemeColor,
17
- branchColors: SOFT_BRANCH_COLORS,
18
- rootFill: '#FFFFFF',
19
- rootTextColor: DEFAULT_COLOR
20
- };
21
- export const MindRetroThemeColor = {
22
- ...RetroThemeColor,
23
- branchColors: RETRO_BRANCH_COLORS,
24
- rootFill: '#153D5D',
25
- rootTextColor: '#FFFFFF'
26
- };
27
- export const MindDarkThemeColor = {
28
- ...DarkThemeColor,
29
- branchColors: DARK_BRANCH_COLORS,
30
- rootFill: '#FFFFFF',
31
- rootTextColor: DEFAULT_COLOR
32
- };
33
- export const MindStarryThemeColor = {
34
- ...StarryThemeColor,
35
- branchColors: STARRY_BRANCH_COLORS,
36
- rootFill: '#FFFFFF',
37
- rootTextColor: DEFAULT_COLOR
38
- };
39
- export const MindThemeColors = [
40
- MindDefaultThemeColor,
41
- MindColorfulThemeColor,
42
- MindSoftThemeColor,
43
- MindRetroThemeColor,
44
- MindDarkThemeColor,
45
- MindStarryThemeColor
46
- ];
47
- export const MindThemeColor = {
48
- isMindThemeColor(value) {
49
- if (value.branchColors && value.rootFill && value.rootTextColor) {
50
- return true;
51
- }
52
- else {
53
- return false;
54
- }
55
- }
56
- };
57
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGhlbWUtY29sb3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9taW5kL3NyYy9pbnRlcmZhY2VzL3RoZW1lLWNvbG9yLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDSCxpQkFBaUIsRUFDakIsZ0JBQWdCLEVBR2hCLGNBQWMsRUFDZCxrQkFBa0IsRUFDbEIsY0FBYyxFQUNkLGVBQWUsRUFDZixhQUFhLEVBQ2hCLE1BQU0sYUFBYSxDQUFDO0FBQ3JCLE9BQU8sRUFDSCxzQkFBc0IsRUFDdEIsa0JBQWtCLEVBQ2xCLHFCQUFxQixFQUNyQixtQkFBbUIsRUFDbkIsa0JBQWtCLEVBQ2xCLG9CQUFvQixFQUN2QixNQUFNLG9CQUFvQixDQUFDO0FBUzVCLE1BQU0sQ0FBQyxNQUFNLHFCQUFxQixHQUFtQjtJQUNqRCxHQUFHLGlCQUFpQjtJQUNwQixZQUFZLEVBQUUscUJBQXFCO0lBQ25DLFFBQVEsRUFBRSxTQUFTO0lBQ25CLGFBQWEsRUFBRSxhQUFhO0NBQy9CLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxzQkFBc0IsR0FBbUI7SUFDbEQsR0FBRyxrQkFBa0I7SUFDckIsWUFBWSxFQUFFLHNCQUFzQjtJQUNwQyxRQUFRLEVBQUUsYUFBYTtJQUN2QixhQUFhLEVBQUUsU0FBUztDQUMzQixDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sa0JBQWtCLEdBQW1CO0lBQzlDLEdBQUcsY0FBYztJQUNqQixZQUFZLEVBQUUsa0JBQWtCO0lBQ2hDLFFBQVEsRUFBRSxTQUFTO0lBQ25CLGFBQWEsRUFBRSxhQUFhO0NBQy9CLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxtQkFBbUIsR0FBbUI7SUFDL0MsR0FBRyxlQUFlO0lBQ2xCLFlBQVksRUFBRSxtQkFBbUI7SUFDakMsUUFBUSxFQUFFLFNBQVM7SUFDbkIsYUFBYSxFQUFFLFNBQVM7Q0FDM0IsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLGtCQUFrQixHQUFtQjtJQUM5QyxHQUFHLGNBQWM7SUFDakIsWUFBWSxFQUFFLGtCQUFrQjtJQUNoQyxRQUFRLEVBQUUsU0FBUztJQUNuQixhQUFhLEVBQUUsYUFBYTtDQUMvQixDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sb0JBQW9CLEdBQW1CO0lBQ2hELEdBQUcsZ0JBQWdCO0lBQ25CLFlBQVksRUFBRSxvQkFBb0I7SUFDbEMsUUFBUSxFQUFFLFNBQVM7SUFDbkIsYUFBYSxFQUFFLGFBQWE7Q0FDL0IsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLGVBQWUsR0FBcUI7SUFDN0MscUJBQXFCO0lBQ3JCLHNCQUFzQjtJQUN0QixrQkFBa0I7SUFDbEIsbUJBQW1CO0lBQ25CLGtCQUFrQjtJQUNsQixvQkFBb0I7Q0FDdkIsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FBRztJQUMxQixnQkFBZ0IsQ0FBQyxLQUFVO1FBQ3ZCLElBQUksS0FBSyxDQUFDLFlBQVksSUFBSSxLQUFLLENBQUMsUUFBUSxJQUFJLEtBQUssQ0FBQyxhQUFhLEVBQUUsQ0FBQztZQUM5RCxPQUFPLElBQUksQ0FBQztRQUNoQixDQUFDO2FBQU0sQ0FBQztZQUNKLE9BQU8sS0FBSyxDQUFDO1FBQ2pCLENBQUM7SUFDTCxDQUFDO0NBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gICAgRGVmYXVsdFRoZW1lQ29sb3IsXG4gICAgU3RhcnJ5VGhlbWVDb2xvcixcbiAgICBUaGVtZUNvbG9yLFxuICAgIFRoZW1lQ29sb3JNb2RlLFxuICAgIERhcmtUaGVtZUNvbG9yLFxuICAgIENvbG9yZnVsVGhlbWVDb2xvcixcbiAgICBTb2Z0VGhlbWVDb2xvcixcbiAgICBSZXRyb1RoZW1lQ29sb3IsXG4gICAgREVGQVVMVF9DT0xPUlxufSBmcm9tICdAcGxhaXQvY29yZSc7XG5pbXBvcnQge1xuICAgIENPTE9SRlVMX0JSQU5DSF9DT0xPUlMsXG4gICAgREFSS19CUkFOQ0hfQ09MT1JTLFxuICAgIERFRkFVTFRfQlJBTkNIX0NPTE9SUyxcbiAgICBSRVRST19CUkFOQ0hfQ09MT1JTLFxuICAgIFNPRlRfQlJBTkNIX0NPTE9SUyxcbiAgICBTVEFSUllfQlJBTkNIX0NPTE9SU1xufSBmcm9tICcuLi9jb25zdGFudHMvdGhlbWUnO1xuXG5leHBvcnQgaW50ZXJmYWNlIE1pbmRUaGVtZUNvbG9yIGV4dGVuZHMgVGhlbWVDb2xvciB7XG4gICAgbW9kZTogVGhlbWVDb2xvck1vZGUgfCBzdHJpbmc7XG4gICAgYnJhbmNoQ29sb3JzOiBzdHJpbmdbXTtcbiAgICByb290RmlsbDogc3RyaW5nO1xuICAgIHJvb3RUZXh0Q29sb3I6IHN0cmluZztcbn1cblxuZXhwb3J0IGNvbnN0IE1pbmREZWZhdWx0VGhlbWVDb2xvcjogTWluZFRoZW1lQ29sb3IgPSB7XG4gICAgLi4uRGVmYXVsdFRoZW1lQ29sb3IsXG4gICAgYnJhbmNoQ29sb3JzOiBERUZBVUxUX0JSQU5DSF9DT0xPUlMsXG4gICAgcm9vdEZpbGw6ICcjZjVmNWY1JyxcbiAgICByb290VGV4dENvbG9yOiBERUZBVUxUX0NPTE9SXG59O1xuXG5leHBvcnQgY29uc3QgTWluZENvbG9yZnVsVGhlbWVDb2xvcjogTWluZFRoZW1lQ29sb3IgPSB7XG4gICAgLi4uQ29sb3JmdWxUaGVtZUNvbG9yLFxuICAgIGJyYW5jaENvbG9yczogQ09MT1JGVUxfQlJBTkNIX0NPTE9SUyxcbiAgICByb290RmlsbDogREVGQVVMVF9DT0xPUixcbiAgICByb290VGV4dENvbG9yOiAnI0ZGRkZGRidcbn07XG5cbmV4cG9ydCBjb25zdCBNaW5kU29mdFRoZW1lQ29sb3I6IE1pbmRUaGVtZUNvbG9yID0ge1xuICAgIC4uLlNvZnRUaGVtZUNvbG9yLFxuICAgIGJyYW5jaENvbG9yczogU09GVF9CUkFOQ0hfQ09MT1JTLFxuICAgIHJvb3RGaWxsOiAnI0ZGRkZGRicsXG4gICAgcm9vdFRleHRDb2xvcjogREVGQVVMVF9DT0xPUlxufTtcblxuZXhwb3J0IGNvbnN0IE1pbmRSZXRyb1RoZW1lQ29sb3I6IE1pbmRUaGVtZUNvbG9yID0ge1xuICAgIC4uLlJldHJvVGhlbWVDb2xvcixcbiAgICBicmFuY2hDb2xvcnM6IFJFVFJPX0JSQU5DSF9DT0xPUlMsXG4gICAgcm9vdEZpbGw6ICcjMTUzRDVEJyxcbiAgICByb290VGV4dENvbG9yOiAnI0ZGRkZGRidcbn07XG5cbmV4cG9ydCBjb25zdCBNaW5kRGFya1RoZW1lQ29sb3I6IE1pbmRUaGVtZUNvbG9yID0ge1xuICAgIC4uLkRhcmtUaGVtZUNvbG9yLFxuICAgIGJyYW5jaENvbG9yczogREFSS19CUkFOQ0hfQ09MT1JTLFxuICAgIHJvb3RGaWxsOiAnI0ZGRkZGRicsXG4gICAgcm9vdFRleHRDb2xvcjogREVGQVVMVF9DT0xPUlxufTtcblxuZXhwb3J0IGNvbnN0IE1pbmRTdGFycnlUaGVtZUNvbG9yOiBNaW5kVGhlbWVDb2xvciA9IHtcbiAgICAuLi5TdGFycnlUaGVtZUNvbG9yLFxuICAgIGJyYW5jaENvbG9yczogU1RBUlJZX0JSQU5DSF9DT0xPUlMsXG4gICAgcm9vdEZpbGw6ICcjRkZGRkZGJyxcbiAgICByb290VGV4dENvbG9yOiBERUZBVUxUX0NPTE9SXG59O1xuXG5leHBvcnQgY29uc3QgTWluZFRoZW1lQ29sb3JzOiBNaW5kVGhlbWVDb2xvcltdID0gW1xuICAgIE1pbmREZWZhdWx0VGhlbWVDb2xvcixcbiAgICBNaW5kQ29sb3JmdWxUaGVtZUNvbG9yLFxuICAgIE1pbmRTb2Z0VGhlbWVDb2xvcixcbiAgICBNaW5kUmV0cm9UaGVtZUNvbG9yLFxuICAgIE1pbmREYXJrVGhlbWVDb2xvcixcbiAgICBNaW5kU3RhcnJ5VGhlbWVDb2xvclxuXTtcblxuZXhwb3J0IGNvbnN0IE1pbmRUaGVtZUNvbG9yID0ge1xuICAgIGlzTWluZFRoZW1lQ29sb3IodmFsdWU6IGFueSk6IHZhbHVlIGlzIE1pbmRUaGVtZUNvbG9yIHtcbiAgICAgICAgaWYgKHZhbHVlLmJyYW5jaENvbG9ycyAmJiB2YWx1ZS5yb290RmlsbCAmJiB2YWx1ZS5yb290VGV4dENvbG9yKSB7XG4gICAgICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIHJldHVybiBmYWxzZTtcbiAgICAgICAgfVxuICAgIH1cbn07XG4iXX0=
@@ -1,13 +0,0 @@
1
- export var HorizontalPlacement;
2
- (function (HorizontalPlacement) {
3
- HorizontalPlacement["left"] = "left";
4
- HorizontalPlacement["center"] = "center";
5
- HorizontalPlacement["right"] = "right";
6
- })(HorizontalPlacement || (HorizontalPlacement = {}));
7
- export var VerticalPlacement;
8
- (function (VerticalPlacement) {
9
- VerticalPlacement["top"] = "top";
10
- VerticalPlacement["middle"] = "middle";
11
- VerticalPlacement["bottom"] = "bottom";
12
- })(VerticalPlacement || (VerticalPlacement = {}));
13
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9taW5kL3NyYy9pbnRlcmZhY2VzL3R5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBTixJQUFZLG1CQUlYO0FBSkQsV0FBWSxtQkFBbUI7SUFDM0Isb0NBQWEsQ0FBQTtJQUNiLHdDQUFpQixDQUFBO0lBQ2pCLHNDQUFlLENBQUE7QUFDbkIsQ0FBQyxFQUpXLG1CQUFtQixLQUFuQixtQkFBbUIsUUFJOUI7QUFFRCxNQUFNLENBQU4sSUFBWSxpQkFJWDtBQUpELFdBQVksaUJBQWlCO0lBQ3pCLGdDQUFXLENBQUE7SUFDWCxzQ0FBaUIsQ0FBQTtJQUNqQixzQ0FBaUIsQ0FBQTtBQUNyQixDQUFDLEVBSlcsaUJBQWlCLEtBQWpCLGlCQUFpQixRQUk1QiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBlbnVtIEhvcml6b250YWxQbGFjZW1lbnQge1xuICAgIGxlZnQgPSAnbGVmdCcsXG4gICAgY2VudGVyID0gJ2NlbnRlcicsXG4gICAgcmlnaHQgPSAncmlnaHQnXG59XG5cbmV4cG9ydCBlbnVtIFZlcnRpY2FsUGxhY2VtZW50IHtcbiAgICB0b3AgPSAndG9wJyxcbiAgICBtaWRkbGUgPSAnbWlkZGxlJyxcbiAgICBib3R0b20gPSAnYm90dG9tJ1xufVxuXG5leHBvcnQgdHlwZSBQb2ludFBsYWNlbWVudCA9IFtIb3Jpem9udGFsUGxhY2VtZW50LCBWZXJ0aWNhbFBsYWNlbWVudF07XG4iXX0=
@@ -1,193 +0,0 @@
1
- import { createG, PlaitBoard, NODE_TO_INDEX, RectangleClient } from '@plait/core';
2
- import { isHorizontalLayout, AbstractNode } from '@plait/layouts';
3
- import { MindElement, PlaitMind } from './interfaces/element';
4
- import { MindQueries } from './queries';
5
- import { ELEMENT_TO_NODE } from './utils/weak-maps';
6
- import { drawAbstractLink } from './utils/draw/node-link/abstract-link';
7
- import { NodeEmojisGenerator } from './generators/node-emojis.generator';
8
- import { MindTransforms } from './transforms';
9
- import { NodePlusGenerator } from './generators/node-plus.generator';
10
- import { drawLink } from './utils/draw/node-link/draw-link';
11
- import { getTopicRectangleByNode } from './utils/position/topic';
12
- import { NodeActiveGenerator } from './generators/node-active.generator';
13
- import { CollapseGenerator } from './generators/node-collapse.generator';
14
- import { NodeSpace } from './utils/space/node-space';
15
- import { NodeTopicThreshold } from './constants/node-topic-style';
16
- import { CommonElementFlavour, ImageGenerator, TextManage, WithTextPluginKey } from '@plait/common';
17
- import { NodeShapeGenerator } from './generators/node-shape.generator';
18
- import { getImageForeignRectangle } from './utils';
19
- export class MindNodeComponent extends CommonElementFlavour {
20
- get textManage() {
21
- return this.getRef().getTextManages()[0];
22
- }
23
- constructor() {
24
- super();
25
- this.shapeG = null;
26
- this.trackBy = (index, node) => {
27
- return node.origin.id;
28
- };
29
- }
30
- initializeGenerator() {
31
- this.nodeShapeGenerator = new NodeShapeGenerator(this.board);
32
- this.nodeEmojisGenerator = new NodeEmojisGenerator(this.board);
33
- this.activeGenerator = new NodeActiveGenerator(this.board);
34
- this.nodePlusGenerator = new NodePlusGenerator(this.board);
35
- this.collapseGenerator = new CollapseGenerator(this.board);
36
- this.imageGenerator = new ImageGenerator(this.board, {
37
- getRectangle: (element) => {
38
- return getImageForeignRectangle(this.board, element);
39
- },
40
- getImageItem: (element) => {
41
- return element.data.image;
42
- }
43
- });
44
- const plugins = (this.board.getPluginOptions(WithTextPluginKey) || {}).textPlugins;
45
- const textManage = new TextManage(this.board, {
46
- getRectangle: () => {
47
- const rect = getTopicRectangleByNode(this.board, this.node);
48
- return rect;
49
- },
50
- onChange: (data) => {
51
- const width = data.width;
52
- const height = data.height;
53
- if (data.newText) {
54
- MindTransforms.setTopic(this.board, this.element, data.newText, width, height);
55
- }
56
- else {
57
- MindTransforms.setTopicSize(this.board, this.element, width, height);
58
- }
59
- },
60
- getMaxWidth: () => {
61
- if (this.element.manualWidth) {
62
- return NodeSpace.getNodeDynamicWidth(this.board, this.element);
63
- }
64
- else {
65
- return Math.max(NodeSpace.getNodeDynamicWidth(this.board, this.element), NodeTopicThreshold.defaultTextMaxWidth);
66
- }
67
- },
68
- textPlugins: plugins || []
69
- });
70
- this.getRef().addGenerator(NodeActiveGenerator.key, this.activeGenerator);
71
- this.getRef().addGenerator(NodeEmojisGenerator.key, this.nodeEmojisGenerator);
72
- this.getRef().addGenerator(ImageGenerator.key, this.imageGenerator);
73
- this.getRef().initializeTextManage(textManage);
74
- this.getRef().updateActiveSection = () => {
75
- this.activeGenerator.processDrawing(this.element, PlaitBoard.getActiveHost(this.board), {
76
- selected: this.selected
77
- });
78
- };
79
- }
80
- initialize() {
81
- super.initialize();
82
- this.initializeGenerator();
83
- this.node = MindElement.getNode(this.element);
84
- this.index = NODE_TO_INDEX.get(this.element) || 0;
85
- this.roughSVG = PlaitBoard.getRoughSVG(this.board);
86
- this.nodeShapeGenerator.processDrawing(this.element, this.getElementG(), { node: this.node });
87
- this.drawLink();
88
- this.drawTopic();
89
- this.activeGenerator.processDrawing(this.element, PlaitBoard.getActiveHost(this.board), {
90
- selected: this.selected
91
- });
92
- this.drawEmojis();
93
- this.drawExtend();
94
- this.imageGenerator.processDrawing(this.element, this.getElementG());
95
- if (PlaitMind.isMind(this.context.parent)) {
96
- this.getElementG().classList.add('branch');
97
- }
98
- }
99
- onContextChanged(value, previous) {
100
- const newNode = MindElement.getNode(value.element);
101
- const isEqualNode = RectangleClient.isEqual(this.node, newNode);
102
- this.node = newNode;
103
- if (!isEqualNode || value.element !== previous.element || value.hasThemeChanged) {
104
- this.activeGenerator.processDrawing(this.element, PlaitBoard.getActiveHost(this.board), {
105
- selected: this.selected
106
- });
107
- this.nodeShapeGenerator.processDrawing(this.element, this.getElementG(), { node: this.node });
108
- this.drawLink();
109
- this.drawEmojis();
110
- this.drawExtend();
111
- if (!MindElement.hasImage(previous.element) && MindElement.hasImage(this.element)) {
112
- this.imageGenerator.processDrawing(this.element, this.getElementG());
113
- }
114
- if (MindElement.hasImage(previous.element) && MindElement.hasImage(this.element)) {
115
- this.imageGenerator.updateImage(this.getElementG(), previous.element, value.element);
116
- }
117
- if (MindElement.hasImage(previous.element) && !MindElement.hasImage(this.element)) {
118
- this.imageGenerator.destroy();
119
- }
120
- this.updateTopic();
121
- }
122
- else {
123
- const hasSameSelected = value.selected === previous.selected;
124
- const hasSameParent = value.parent === previous.parent;
125
- if (!hasSameSelected || value.selected) {
126
- this.activeGenerator.processDrawing(this.element, PlaitBoard.getActiveHost(this.board), {
127
- selected: this.selected
128
- });
129
- }
130
- if (!hasSameParent) {
131
- this.drawLink();
132
- }
133
- }
134
- }
135
- drawEmojis() {
136
- const g = this.nodeEmojisGenerator.drawEmojis(this.element);
137
- if (g) {
138
- this.getElementG().append(g);
139
- }
140
- }
141
- drawLink() {
142
- if (PlaitMind.isMind(this.element)) {
143
- return;
144
- }
145
- const parent = MindElement.getParent(this.element);
146
- const parentNode = MindElement.getNode(parent);
147
- if (this.linkG) {
148
- this.linkG.remove();
149
- }
150
- const layout = MindQueries.getLayoutByElement(parent);
151
- if (AbstractNode.isAbstract(this.node.origin)) {
152
- this.linkG = drawAbstractLink(this.board, this.node, isHorizontalLayout(layout));
153
- }
154
- else {
155
- this.linkG = drawLink(this.board, parentNode, this.node, isHorizontalLayout(layout));
156
- }
157
- this.getElementG().append(this.linkG);
158
- }
159
- drawExtend() {
160
- if (!this.extendG) {
161
- this.extendG = createG();
162
- this.extendG.classList.add('extend');
163
- this.getElementG().append(this.extendG);
164
- }
165
- if (this.element.isCollapsed) {
166
- this.getElementG().classList.add('collapsed');
167
- }
168
- else {
169
- this.getElementG().classList.remove('collapsed');
170
- }
171
- this.nodePlusGenerator.processDrawing(this.element, this.extendG);
172
- this.collapseGenerator.processDrawing(this.element, this.extendG);
173
- }
174
- drawTopic() {
175
- this.textManage.draw(this.element.data.topic);
176
- this.getElementG().append(this.textManage.g);
177
- }
178
- updateTopic() {
179
- this.textManage.updateText(this.element.data.topic);
180
- this.textManage.updateRectangle();
181
- }
182
- destroy() {
183
- super.destroy();
184
- this.nodeEmojisGenerator.destroy();
185
- this.imageGenerator.destroy();
186
- this.activeGenerator.destroy();
187
- if (ELEMENT_TO_NODE.get(this.element) === this.node) {
188
- ELEMENT_TO_NODE.delete(this.element);
189
- }
190
- this.getRef().destroyTextManage();
191
- }
192
- }
193
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mind-node.component.js","sourceRoot":"","sources":["../../../packages/mind/src/mind-node.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { createG, PlaitBoard, NODE_TO_INDEX, PlaitPluginElementContext, OnContextChanged, RectangleClient } from '@plait/core';\nimport { isHorizontalLayout, AbstractNode, MindLayoutType } from '@plait/layouts';\nimport { RoughSVG } from 'roughjs/bin/svg';\nimport { MindElement, PlaitMind } from './interfaces/element';\nimport { MindNode } from './interfaces/node';\nimport { MindQueries } from './queries';\nimport { ELEMENT_TO_NODE } from './utils/weak-maps';\nimport { drawAbstractLink } from './utils/draw/node-link/abstract-link';\nimport { NodeEmojisGenerator } from './generators/node-emojis.generator';\nimport { MindTransforms } from './transforms';\nimport { NodePlusGenerator } from './generators/node-plus.generator';\nimport { PlaitMindBoard } from './plugins/with-mind.board';\nimport { drawLink } from './utils/draw/node-link/draw-link';\nimport { getTopicRectangleByNode } from './utils/position/topic';\nimport { NodeActiveGenerator } from './generators/node-active.generator';\nimport { CollapseGenerator } from './generators/node-collapse.generator';\nimport { NodeSpace } from './utils/space/node-space';\nimport { NodeTopicThreshold } from './constants/node-topic-style';\nimport {\n    CommonElementFlavour,\n    ImageGenerator,\n    TextManage,\n    TextManageChangeData,\n    WithTextPluginKey,\n    WithTextPluginOptions\n} from '@plait/common';\nimport { NodeShapeGenerator } from './generators/node-shape.generator';\nimport { getImageForeignRectangle } from './utils';\nimport { ImageData } from './interfaces';\n\nexport class MindNodeComponent\n    extends CommonElementFlavour<MindElement, PlaitMindBoard>\n    implements OnContextChanged<MindElement, PlaitMindBoard>\n{\n    roughSVG!: RoughSVG;\n\n    node!: MindNode;\n\n    index!: number;\n\n    shapeG: SVGGElement | null = null;\n\n    linkG?: SVGGElement;\n\n    extendG?: SVGGElement;\n\n    nodeEmojisGenerator!: NodeEmojisGenerator;\n\n    nodeShapeGenerator!: NodeShapeGenerator;\n\n    nodePlusGenerator!: NodePlusGenerator;\n\n    imageGenerator!: ImageGenerator<MindElement<ImageData>>;\n\n    activeGenerator!: NodeActiveGenerator;\n\n    collapseGenerator!: CollapseGenerator;\n\n    get textManage() {\n        return this.getRef().getTextManages()[0];\n    }\n\n    constructor() {\n        super();\n    }\n\n    initializeGenerator() {\n        this.nodeShapeGenerator = new NodeShapeGenerator(this.board);\n        this.nodeEmojisGenerator = new NodeEmojisGenerator(this.board);\n        this.activeGenerator = new NodeActiveGenerator(this.board);\n        this.nodePlusGenerator = new NodePlusGenerator(this.board);\n        this.collapseGenerator = new CollapseGenerator(this.board);\n        this.imageGenerator = new ImageGenerator<MindElement<ImageData>>(this.board, {\n            getRectangle: (element: MindElement<ImageData>) => {\n                return getImageForeignRectangle(this.board as PlaitMindBoard, element);\n            },\n            getImageItem: (element: MindElement<ImageData>) => {\n                return element.data.image;\n            }\n        });\n        const plugins = (this.board.getPluginOptions<WithTextPluginOptions>(WithTextPluginKey) || {}).textPlugins;\n        const textManage = new TextManage(this.board, {\n            getRectangle: () => {\n                const rect = getTopicRectangleByNode(this.board, this.node);\n                return rect;\n            },\n            onChange: (data: TextManageChangeData) => {\n                const width = data.width;\n                const height = data.height;\n                if (data.newText) {\n                    MindTransforms.setTopic(this.board, this.element, data.newText as MindElement, width, height);\n                } else {\n                    MindTransforms.setTopicSize(this.board, this.element, width, height);\n                }\n            },\n            getMaxWidth: () => {\n                if (this.element.manualWidth) {\n                    return NodeSpace.getNodeDynamicWidth(this.board, this.element);\n                } else {\n                    return Math.max(NodeSpace.getNodeDynamicWidth(this.board, this.element), NodeTopicThreshold.defaultTextMaxWidth);\n                }\n            },\n            textPlugins: plugins || []\n        });\n        this.getRef().addGenerator(NodeActiveGenerator.key, this.activeGenerator);\n        this.getRef().addGenerator(NodeEmojisGenerator.key, this.nodeEmojisGenerator);\n        this.getRef().addGenerator(ImageGenerator.key, this.imageGenerator);\n        this.getRef().initializeTextManage(textManage);\n        this.getRef().updateActiveSection = () => {\n            this.activeGenerator.processDrawing(this.element, PlaitBoard.getActiveHost(this.board), {\n                selected: this.selected\n            });\n        };\n    }\n\n    initialize(): void {\n        super.initialize();\n        this.initializeGenerator();\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.nodeShapeGenerator.processDrawing(this.element, this.getElementG(), { node: this.node });\n        this.drawLink();\n        this.drawTopic();\n        this.activeGenerator.processDrawing(this.element, PlaitBoard.getActiveHost(this.board), {\n            selected: this.selected\n        });\n        this.drawEmojis();\n        this.drawExtend();\n        this.imageGenerator.processDrawing(this.element as MindElement<ImageData>, this.getElementG());\n        if (PlaitMind.isMind(this.context.parent)) {\n            this.getElementG().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        if (!isEqualNode || value.element !== previous.element || value.hasThemeChanged) {\n            this.activeGenerator.processDrawing(this.element, PlaitBoard.getActiveHost(this.board), {\n                selected: this.selected\n            });\n            this.nodeShapeGenerator.processDrawing(this.element, this.getElementG(), { node: this.node });\n            this.drawLink();\n            this.drawEmojis();\n            this.drawExtend();\n            if (!MindElement.hasImage(previous.element) && MindElement.hasImage(this.element)) {\n                this.imageGenerator.processDrawing(this.element, this.getElementG());\n            }\n            if (MindElement.hasImage(previous.element) && MindElement.hasImage(this.element)) {\n                this.imageGenerator.updateImage(\n                    this.getElementG(),\n                    previous.element as MindElement<ImageData>,\n                    value.element as MindElement<ImageData>\n                );\n            }\n            if (MindElement.hasImage(previous.element) && !MindElement.hasImage(this.element)) {\n                this.imageGenerator.destroy();\n            }\n            this.updateTopic();\n        } else {\n            const hasSameSelected = value.selected === previous.selected;\n            const hasSameParent = value.parent === previous.parent;\n            if (!hasSameSelected || value.selected) {\n                this.activeGenerator.processDrawing(this.element, PlaitBoard.getActiveHost(this.board), {\n                    selected: this.selected\n                });\n            }\n            if (!hasSameParent) {\n                this.drawLink();\n            }\n        }\n    }\n\n    drawEmojis() {\n        const g = this.nodeEmojisGenerator.drawEmojis(this.element);\n        if (g) {\n            this.getElementG().append(g);\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.getElementG().append(this.linkG);\n    }\n\n    drawExtend() {\n        if (!this.extendG) {\n            this.extendG = createG();\n            this.extendG.classList.add('extend');\n            this.getElementG().append(this.extendG);\n        }\n        if (this.element.isCollapsed) {\n            this.getElementG().classList.add('collapsed');\n        } else {\n            this.getElementG().classList.remove('collapsed');\n        }\n        this.nodePlusGenerator.processDrawing(this.element, this.extendG!);\n        this.collapseGenerator.processDrawing(this.element, this.extendG!);\n    }\n\n    drawTopic() {\n        this.textManage.draw(this.element.data.topic);\n        this.getElementG().append(this.textManage.g);\n    }\n\n    updateTopic() {\n        this.textManage.updateText(this.element.data.topic);\n        this.textManage.updateRectangle();\n    }\n\n    trackBy = (index: number, node: MindNode) => {\n        return node.origin.id;\n    };\n\n    destroy(): void {\n        super.destroy();\n        this.nodeEmojisGenerator.destroy();\n        this.imageGenerator.destroy();\n        this.activeGenerator.destroy();\n        if (ELEMENT_TO_NODE.get(this.element) === this.node) {\n            ELEMENT_TO_NODE.delete(this.element);\n        }\n        this.getRef().destroyTextManage();\n    }\n}\n"]}
@@ -1,34 +0,0 @@
1
- import { depthFirstRecursion } from '@plait/core';
2
- import { GlobalLayout } from '@plait/layouts';
3
- import { ELEMENT_TO_NODE } from './utils/weak-maps';
4
- import { MindNodeComponent } from './mind-node.component';
5
- import { getLayoutOptions } from './utils/space/layout-options';
6
- import { getDefaultLayout } from './utils/layout';
7
- export class PlaitMindComponent extends MindNodeComponent {
8
- initialize() {
9
- this.updateMindLayout();
10
- super.initialize();
11
- this.getElementG().classList.add('root');
12
- }
13
- beforeContextChange(value) {
14
- if (value.element !== this.element && this.initialized) {
15
- this.updateMindLayout(value.element);
16
- }
17
- }
18
- updateMindLayout(element = this.element) {
19
- const mindLayoutType = element.layout || getDefaultLayout();
20
- this.root = GlobalLayout.layout(element, getLayoutOptions(this.board), mindLayoutType);
21
- this.updateMindNodeLocation(element);
22
- }
23
- updateMindNodeLocation(element) {
24
- const { x, y, hGap, vGap } = this.root;
25
- const offsetX = x + hGap;
26
- const offsetY = y + vGap;
27
- depthFirstRecursion(this.root, (node) => {
28
- node.x = node.x - offsetX + element.points[0][0];
29
- node.y = node.y - offsetY + element.points[0][1];
30
- ELEMENT_TO_NODE.set(node.origin, node);
31
- });
32
- }
33
- }
34
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWluZC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9wYWNrYWdlcy9taW5kL3NyYy9taW5kLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxPQUFPLEVBQWtELG1CQUFtQixFQUFXLE1BQU0sYUFBYSxDQUFDO0FBQzNHLE9BQU8sRUFBRSxZQUFZLEVBQWMsTUFBTSxnQkFBZ0IsQ0FBQztBQUMxRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDcEQsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFDMUQsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDaEUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFFbEQsTUFBTSxPQUFPLGtCQUFtQixTQUFRLGlCQUFpQjtJQUdyRCxVQUFVO1FBQ04sSUFBSSxDQUFDLGdCQUFnQixFQUFFLENBQUM7UUFDeEIsS0FBSyxDQUFDLFVBQVUsRUFBRSxDQUFDO1FBQ25CLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQzdDLENBQUM7SUFFRCxtQkFBbUIsQ0FBQyxLQUEyQztRQUMzRCxJQUFJLEtBQUssQ0FBQyxPQUFPLEtBQUssSUFBSSxDQUFDLE9BQU8sSUFBSSxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7WUFDckQsSUFBSSxDQUFDLGdCQUFnQixDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUN6QyxDQUFDO0lBQ0wsQ0FBQztJQUVELGdCQUFnQixDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUMsT0FBTztRQUNuQyxNQUFNLGNBQWMsR0FBRyxPQUFPLENBQUMsTUFBTSxJQUFJLGdCQUFnQixFQUFFLENBQUM7UUFDNUQsSUFBSSxDQUFDLElBQUksR0FBRyxZQUFZLENBQUMsTUFBTSxDQUMzQixPQUFnQyxFQUNoQyxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLEVBQzVCLGNBQWMsQ0FDTSxDQUFDO1FBQ3pCLElBQUksQ0FBQyxzQkFBc0IsQ0FBQyxPQUFvQixDQUFDLENBQUM7SUFDdEQsQ0FBQztJQUVELHNCQUFzQixDQUFDLE9BQWtCO1FBQ3JDLE1BQU0sRUFBRSxDQUFDLEVBQUUsQ0FBQyxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDO1FBQ3ZDLE1BQU0sT0FBTyxHQUFHLENBQUMsR0FBRyxJQUFJLENBQUM7UUFDekIsTUFBTSxPQUFPLEdBQUcsQ0FBQyxHQUFHLElBQUksQ0FBQztRQUN6QixtQkFBbUIsQ0FBVyxJQUFJLENBQUMsSUFBSSxFQUFFLENBQUMsSUFBSSxFQUFFLEVBQUU7WUFDOUMsSUFBSSxDQUFDLENBQUMsR0FBRyxJQUFJLENBQUMsQ0FBQyxHQUFHLE9BQU8sR0FBRyxPQUFPLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQ2pELElBQUksQ0FBQyxDQUFDLEdBQUcsSUFBSSxDQUFDLENBQUMsR0FBRyxPQUFPLEdBQUcsT0FBTyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUNqRCxlQUFlLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsSUFBSSxDQUFDLENBQUM7UUFDM0MsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDO0NBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQbGFpdE1pbmQgfSBmcm9tICcuL2ludGVyZmFjZXMvZWxlbWVudCc7XG5pbXBvcnQgeyBNaW5kTm9kZSB9IGZyb20gJy4vaW50ZXJmYWNlcy9ub2RlJztcbmltcG9ydCB7IEJlZm9yZUNvbnRleHRDaGFuZ2UsIFBsYWl0UGx1Z2luRWxlbWVudENvbnRleHQsIGRlcHRoRmlyc3RSZWN1cnNpb24sIGlzRGVidWcgfSBmcm9tICdAcGxhaXQvY29yZSc7XG5pbXBvcnQgeyBHbG9iYWxMYXlvdXQsIE9yaWdpbk5vZGUgfSBmcm9tICdAcGxhaXQvbGF5b3V0cyc7XG5pbXBvcnQgeyBFTEVNRU5UX1RPX05PREUgfSBmcm9tICcuL3V0aWxzL3dlYWstbWFwcyc7XG5pbXBvcnQgeyBNaW5kTm9kZUNvbXBvbmVudCB9IGZyb20gJy4vbWluZC1ub2RlLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBnZXRMYXlvdXRPcHRpb25zIH0gZnJvbSAnLi91dGlscy9zcGFjZS9sYXlvdXQtb3B0aW9ucyc7XG5pbXBvcnQgeyBnZXREZWZhdWx0TGF5b3V0IH0gZnJvbSAnLi91dGlscy9sYXlvdXQnO1xuXG5leHBvcnQgY2xhc3MgUGxhaXRNaW5kQ29tcG9uZW50IGV4dGVuZHMgTWluZE5vZGVDb21wb25lbnQgaW1wbGVtZW50cyBCZWZvcmVDb250ZXh0Q2hhbmdlPFBsYWl0TWluZD4ge1xuICAgIHJvb3QhOiBNaW5kTm9kZTtcblxuICAgIGluaXRpYWxpemUoKTogdm9pZCB7XG4gICAgICAgIHRoaXMudXBkYXRlTWluZExheW91dCgpO1xuICAgICAgICBzdXBlci5pbml0aWFsaXplKCk7XG4gICAgICAgIHRoaXMuZ2V0RWxlbWVudEcoKS5jbGFzc0xpc3QuYWRkKCdyb290Jyk7XG4gICAgfVxuXG4gICAgYmVmb3JlQ29udGV4dENoYW5nZSh2YWx1ZTogUGxhaXRQbHVnaW5FbGVtZW50Q29udGV4dDxQbGFpdE1pbmQ+KSB7XG4gICAgICAgIGlmICh2YWx1ZS5lbGVtZW50ICE9PSB0aGlzLmVsZW1lbnQgJiYgdGhpcy5pbml0aWFsaXplZCkge1xuICAgICAgICAgICAgdGhpcy51cGRhdGVNaW5kTGF5b3V0KHZhbHVlLmVsZW1lbnQpO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgdXBkYXRlTWluZExheW91dChlbGVtZW50ID0gdGhpcy5lbGVtZW50KSB7XG4gICAgICAgIGNvbnN0IG1pbmRMYXlvdXRUeXBlID0gZWxlbWVudC5sYXlvdXQgfHwgZ2V0RGVmYXVsdExheW91dCgpO1xuICAgICAgICB0aGlzLnJvb3QgPSBHbG9iYWxMYXlvdXQubGF5b3V0KFxuICAgICAgICAgICAgZWxlbWVudCBhcyB1bmtub3duIGFzIE9yaWdpbk5vZGUsXG4gICAgICAgICAgICBnZXRMYXlvdXRPcHRpb25zKHRoaXMuYm9hcmQpLFxuICAgICAgICAgICAgbWluZExheW91dFR5cGVcbiAgICAgICAgKSBhcyB1bmtub3duIGFzIE1pbmROb2RlO1xuICAgICAgICB0aGlzLnVwZGF0ZU1pbmROb2RlTG9jYXRpb24oZWxlbWVudCBhcyBQbGFpdE1pbmQpO1xuICAgIH1cblxuICAgIHVwZGF0ZU1pbmROb2RlTG9jYXRpb24oZWxlbWVudDogUGxhaXRNaW5kKSB7XG4gICAgICAgIGNvbnN0IHsgeCwgeSwgaEdhcCwgdkdhcCB9ID0gdGhpcy5yb290O1xuICAgICAgICBjb25zdCBvZmZzZXRYID0geCArIGhHYXA7XG4gICAgICAgIGNvbnN0IG9mZnNldFkgPSB5ICsgdkdhcDtcbiAgICAgICAgZGVwdGhGaXJzdFJlY3Vyc2lvbjxNaW5kTm9kZT4odGhpcy5yb290LCAobm9kZSkgPT4ge1xuICAgICAgICAgICAgbm9kZS54ID0gbm9kZS54IC0gb2Zmc2V0WCArIGVsZW1lbnQucG9pbnRzWzBdWzBdO1xuICAgICAgICAgICAgbm9kZS55ID0gbm9kZS55IC0gb2Zmc2V0WSArIGVsZW1lbnQucG9pbnRzWzBdWzFdO1xuICAgICAgICAgICAgRUxFTUVOVF9UT19OT0RFLnNldChub2RlLm9yaWdpbiwgbm9kZSk7XG4gICAgICAgIH0pO1xuICAgIH1cbn1cbiJdfQ==
@@ -1,5 +0,0 @@
1
- /**
2
- * Generated bundle index. Do not edit.
3
- */
4
- export * from './public-api';
5
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGxhaXQtbWluZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3BhY2thZ2VzL21pbmQvc3JjL3BsYWl0LW1pbmQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcbiJdfQ==
@@ -1,12 +0,0 @@
1
- export var AbstractHandlePosition;
2
- (function (AbstractHandlePosition) {
3
- AbstractHandlePosition["start"] = "start";
4
- AbstractHandlePosition["end"] = "end";
5
- })(AbstractHandlePosition || (AbstractHandlePosition = {}));
6
- export var AbstractResizeState;
7
- (function (AbstractResizeState) {
8
- AbstractResizeState["start"] = "start";
9
- AbstractResizeState["resizing"] = "resizing";
10
- AbstractResizeState["end"] = "end";
11
- })(AbstractResizeState || (AbstractResizeState = {}));
12
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2l0aC1hYnN0cmFjdC1yZXNpemUuYm9hcmQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9taW5kL3NyYy9wbHVnaW5zL3dpdGgtYWJzdHJhY3QtcmVzaXplLmJvYXJkLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUlBLE1BQU0sQ0FBTixJQUFZLHNCQUdYO0FBSEQsV0FBWSxzQkFBc0I7SUFDOUIseUNBQWUsQ0FBQTtJQUNmLHFDQUFXLENBQUE7QUFDZixDQUFDLEVBSFcsc0JBQXNCLEtBQXRCLHNCQUFzQixRQUdqQztBQUVELE1BQU0sQ0FBTixJQUFZLG1CQUlYO0FBSkQsV0FBWSxtQkFBbUI7SUFDM0Isc0NBQWUsQ0FBQTtJQUNmLDRDQUFxQixDQUFBO0lBQ3JCLGtDQUFXLENBQUE7QUFDZixDQUFDLEVBSlcsbUJBQW1CLEtBQW5CLG1CQUFtQixRQUk5QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBsYWl0T3B0aW9uc0JvYXJkIH0gZnJvbSAnQHBsYWl0L2NvcmUnO1xuaW1wb3J0IHsgTWluZEVsZW1lbnQgfSBmcm9tICcuLi9pbnRlcmZhY2VzL2VsZW1lbnQnO1xuaW1wb3J0IHsgQWJzdHJhY3ROb2RlIH0gZnJvbSAnQHBsYWl0L2xheW91dHMnO1xuXG5leHBvcnQgZW51bSBBYnN0cmFjdEhhbmRsZVBvc2l0aW9uIHtcbiAgICBzdGFydCA9ICdzdGFydCcsXG4gICAgZW5kID0gJ2VuZCdcbn1cblxuZXhwb3J0IGVudW0gQWJzdHJhY3RSZXNpemVTdGF0ZSB7XG4gICAgc3RhcnQgPSAnc3RhcnQnLFxuICAgIHJlc2l6aW5nID0gJ3Jlc2l6aW5nJyxcbiAgICBlbmQgPSAnZW5kJ1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFBsYWl0QWJzdHJhY3RCb2FyZCBleHRlbmRzIFBsYWl0T3B0aW9uc0JvYXJkIHtcbiAgICBvbkFic3RyYWN0UmVzaXplPzogKHN0YXRlOiBBYnN0cmFjdFJlc2l6ZVN0YXRlKSA9PiB2b2lkO1xufVxuXG5leHBvcnQgdHlwZSBBYnN0cmFjdFJlZnMgPSBNYXA8TWluZEVsZW1lbnQsIFBpY2s8QWJzdHJhY3ROb2RlLCAnc3RhcnQnIHwgJ2VuZCc+PjtcbiJdfQ==