@plait/mind 0.18.0 → 0.20.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 (36) hide show
  1. package/base/base.drawer.d.ts +3 -3
  2. package/constants/index.d.ts +0 -1
  3. package/constants/node-style.d.ts +7 -3
  4. package/esm2020/base/base.drawer.mjs +1 -1
  5. package/esm2020/constants/index.mjs +1 -2
  6. package/esm2020/constants/node-style.mjs +5 -4
  7. package/esm2020/plugins/with-mind-hotkey.mjs +1 -1
  8. package/esm2020/plugins/with-mind.mjs +6 -12
  9. package/esm2020/plugins/with-node-dnd.mjs +3 -3
  10. package/esm2020/plugins/with-node-hover.mjs +3 -10
  11. package/esm2020/transforms/abstract-node.mjs +3 -3
  12. package/esm2020/transforms/node.mjs +8 -7
  13. package/esm2020/utils/clipboard.mjs +4 -4
  14. package/esm2020/utils/dnd/detector.mjs +3 -10
  15. package/esm2020/utils/draw/node-shape.mjs +3 -5
  16. package/esm2020/utils/mind.mjs +3 -3
  17. package/esm2020/utils/node/adjust-node.mjs +3 -3
  18. package/esm2020/utils/node-style/branch.mjs +3 -3
  19. package/esm2020/utils/node-style/shape.mjs +8 -1
  20. package/esm2020/utils/space/node-space.mjs +38 -4
  21. package/fesm2015/plait-mind.mjs +80 -62
  22. package/fesm2015/plait-mind.mjs.map +1 -1
  23. package/fesm2020/plait-mind.mjs +79 -61
  24. package/fesm2020/plait-mind.mjs.map +1 -1
  25. package/package.json +1 -1
  26. package/plugins/with-mind-hotkey.d.ts +2 -1
  27. package/plugins/with-mind.d.ts +1 -1
  28. package/transforms/index.d.ts +2 -2
  29. package/transforms/node.d.ts +3 -2
  30. package/utils/clipboard.d.ts +3 -2
  31. package/utils/mind.d.ts +3 -2
  32. package/utils/node/adjust-node.d.ts +2 -1
  33. package/utils/node-style/shape.d.ts +1 -0
  34. package/utils/space/node-space.d.ts +6 -0
  35. package/constants/node-rule.d.ts +0 -1
  36. package/esm2020/constants/node-rule.mjs +0 -2
@@ -1,8 +1,10 @@
1
+ import { DEFAULT_FONT_SIZE, MarkTypes, PlaitMarkEditor } from '@plait/text';
1
2
  import { BASE } from '../../constants/default';
2
3
  import { PlaitMind } from '../../interfaces/element';
3
4
  import { MindElement } from '../../interfaces/element';
4
5
  import { WithMindPluginKey } from '../../public-api';
5
6
  import { getEmojisWidthHeight } from './emoji';
7
+ import { ROOT_TOPIC_FONT_SIZE } from '../../constants/node-topic-style';
6
8
  const NodeDefaultSpace = {
7
9
  horizontal: {
8
10
  nodeAndText: BASE * 3,
@@ -41,15 +43,14 @@ const getSpaceEmojiAndText = (element) => {
41
43
  export const NodeSpace = {
42
44
  getNodeWidth(board, element) {
43
45
  const nodeAndText = getHorizontalSpaceBetweenNodeAndText(board, element);
44
- const imageWidth = MindElement.hasImage(element) ? element.data.image?.width : 0;
45
46
  if (MindElement.hasEmojis(element)) {
46
47
  return (NodeSpace.getEmojiLeftSpace(board, element) +
47
48
  getEmojisWidthHeight(board, element).width +
48
49
  getSpaceEmojiAndText(element) +
49
- Math.max(element.width, imageWidth) +
50
+ NodeSpace.getNodeResizableWidth(board, element) +
50
51
  nodeAndText);
51
52
  }
52
- return nodeAndText + Math.max(element.width, imageWidth) + nodeAndText;
53
+ return nodeAndText + NodeSpace.getNodeResizableWidth(board, element) + nodeAndText;
53
54
  },
54
55
  getNodeHeight(board, element) {
55
56
  const nodeAndText = getVerticalSpaceBetweenNodeAndText(element);
@@ -62,6 +63,26 @@ export const NodeSpace = {
62
63
  }
63
64
  return nodeAndText + element.height + nodeAndText;
64
65
  },
66
+ getNodeResizableWidth(board, element) {
67
+ const imageWidth = MindElement.hasImage(element) ? element.data.image?.width : 0;
68
+ return Math.max(element.width, imageWidth);
69
+ },
70
+ getNodeResizableMinWidth(board, element) {
71
+ const minTopicWidth = NodeSpace.getNodeTopicMinWidth(board, element);
72
+ if (MindElement.hasImage(element) && element.data.image.width > minTopicWidth) {
73
+ return element.data.image.width;
74
+ }
75
+ else {
76
+ return minTopicWidth;
77
+ }
78
+ },
79
+ getNodeTopicMinWidth(board, element, isRoot = false) {
80
+ const defaultFontSize = getNodeDefaultFontSize(isRoot);
81
+ const editor = MindElement.getTextEditor(element);
82
+ const marks = PlaitMarkEditor.getMarks(editor);
83
+ const fontSize = marks[MarkTypes.fontSize] || defaultFontSize;
84
+ return fontSize;
85
+ },
65
86
  getTextLeftSpace(board, element) {
66
87
  const nodeAndText = getHorizontalSpaceBetweenNodeAndText(board, element);
67
88
  if (MindElement.hasEmojis(element)) {
@@ -93,4 +114,17 @@ export const NodeSpace = {
93
114
  return nodeAndText;
94
115
  }
95
116
  };
96
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node-space.js","sourceRoot":"","sources":["../../../../../packages/mind/src/utils/space/node-space.ts"],"names":[],"mappings":"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","sourcesContent":["import { BASE } from '../../constants/default';\nimport { PlaitMind } from '../../interfaces/element';\nimport { MindElement } from '../../interfaces/element';\nimport { EmojiData } from '../../interfaces/element-data';\nimport { WithMindOptions } from '../../interfaces/options';\nimport { PlaitMindBoard } from '../../plugins/with-mind.board';\nimport { WithMindPluginKey } from '../../public-api';\nimport { getEmojisWidthHeight } from './emoji';\n\nconst NodeDefaultSpace = {\n    horizontal: {\n        nodeAndText: BASE * 3,\n        emojiAndText: BASE * 1.5\n    },\n    vertical: {\n        nodeAndText: BASE * 1.5,\n        nodeAndImage: BASE,\n        imageAndText: BASE * 1.5\n    }\n};\n\nconst RootDefaultSpace = {\n    horizontal: {\n        nodeAndText: BASE * 4,\n        emojiAndText: BASE * 2\n    },\n    vertical: {\n        nodeAndText: BASE * 2\n    }\n};\n\nconst getHorizontalSpaceBetweenNodeAndText = (board: PlaitMindBoard, element: MindElement) => {\n    const isMind = PlaitMind.isMind(element);\n    const nodeAndText = isMind ? RootDefaultSpace.horizontal.nodeAndText : NodeDefaultSpace.horizontal.nodeAndText;\n    return nodeAndText;\n};\n\nconst getVerticalSpaceBetweenNodeAndText = (element: MindElement) => {\n    const isMind = PlaitMind.isMind(element);\n    const nodeAndText = isMind ? RootDefaultSpace.vertical.nodeAndText : NodeDefaultSpace.vertical.nodeAndText;\n    return nodeAndText;\n};\n\nconst getSpaceEmojiAndText = (element: MindElement) => {\n    const isMind = PlaitMind.isMind(element);\n    const emojiAndText = isMind ? RootDefaultSpace.horizontal.emojiAndText : NodeDefaultSpace.horizontal.emojiAndText;\n    return emojiAndText;\n};\n\nexport const NodeSpace = {\n    getNodeWidth(board: PlaitMindBoard, element: MindElement) {\n        const nodeAndText = getHorizontalSpaceBetweenNodeAndText(board, element);\n        const imageWidth = MindElement.hasImage(element) ? element.data.image?.width : 0;\n        if (MindElement.hasEmojis(element)) {\n            return (\n                NodeSpace.getEmojiLeftSpace(board, element) +\n                getEmojisWidthHeight(board, element).width +\n                getSpaceEmojiAndText(element) +\n                Math.max(element.width, imageWidth) +\n                nodeAndText\n            );\n        }\n        return nodeAndText + Math.max(element.width, imageWidth) + nodeAndText;\n    },\n    getNodeHeight(board: PlaitMindBoard, element: MindElement) {\n        const nodeAndText = getVerticalSpaceBetweenNodeAndText(element);\n        if (MindElement.hasImage(element)) {\n            return (\n                NodeDefaultSpace.vertical.nodeAndImage +\n                element.data.image.height +\n                NodeDefaultSpace.vertical.imageAndText +\n                element.height +\n                nodeAndText\n            );\n        }\n        return nodeAndText + element.height + nodeAndText;\n    },\n    getTextLeftSpace(board: PlaitMindBoard, element: MindElement) {\n        const nodeAndText = getHorizontalSpaceBetweenNodeAndText(board, element);\n        if (MindElement.hasEmojis(element)) {\n            return NodeSpace.getEmojiLeftSpace(board, element) + getEmojisWidthHeight(board, element).width + getSpaceEmojiAndText(element);\n        } else {\n            return nodeAndText;\n        }\n    },\n    getTextTopSpace(element: MindElement) {\n        const nodeAndText = getVerticalSpaceBetweenNodeAndText(element);\n        if (MindElement.hasImage(element)) {\n            return element.data.image.height + NodeDefaultSpace.vertical.nodeAndImage + NodeDefaultSpace.vertical.imageAndText;\n        } else {\n            return nodeAndText;\n        }\n    },\n    getImageTopSpace(element: MindElement) {\n        return NodeDefaultSpace.vertical.nodeAndImage;\n    },\n    getEmojiLeftSpace(board: PlaitMindBoard, element: MindElement<EmojiData>) {\n        const options = board.getPluginOptions<WithMindOptions>(WithMindPluginKey);\n        const nodeAndText = getHorizontalSpaceBetweenNodeAndText(board, element);\n        return nodeAndText - options.emojiPadding;\n    },\n    getEmojiTopSpace(element: MindElement) {\n        const nodeAndText = getVerticalSpaceBetweenNodeAndText(element);\n        return nodeAndText;\n    }\n};\n"]}
117
+ export const getFontSizeBySlateElement = (text) => {
118
+ const defaultFontSize = DEFAULT_FONT_SIZE;
119
+ if (typeof text === 'string') {
120
+ return defaultFontSize;
121
+ }
122
+ const marks = PlaitMarkEditor.getMarksByElement(text);
123
+ const fontSize = marks[MarkTypes.fontSize] || defaultFontSize;
124
+ return fontSize;
125
+ };
126
+ export const getNodeDefaultFontSize = (isRoot = false) => {
127
+ const defaultFontSize = isRoot ? ROOT_TOPIC_FONT_SIZE : DEFAULT_FONT_SIZE;
128
+ return defaultFontSize;
129
+ };
130
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node-space.js","sourceRoot":"","sources":["../../../../../packages/mind/src/utils/space/node-space.ts"],"names":[],"mappings":"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","sourcesContent":["import { DEFAULT_FONT_SIZE, MarkTypes, PlaitMarkEditor } from '@plait/text';\nimport { BASE } from '../../constants/default';\nimport { PlaitMind } from '../../interfaces/element';\nimport { MindElement } from '../../interfaces/element';\nimport { EmojiData } from '../../interfaces/element-data';\nimport { WithMindOptions } from '../../interfaces/options';\nimport { PlaitMindBoard } from '../../plugins/with-mind.board';\nimport { WithMindPluginKey } from '../../public-api';\nimport { getEmojisWidthHeight } from './emoji';\nimport { Element } from 'slate';\nimport { ROOT_TOPIC_FONT_SIZE } from '../../constants/node-topic-style';\n\nconst NodeDefaultSpace = {\n    horizontal: {\n        nodeAndText: BASE * 3,\n        emojiAndText: BASE * 1.5\n    },\n    vertical: {\n        nodeAndText: BASE * 1.5,\n        nodeAndImage: BASE,\n        imageAndText: BASE * 1.5\n    }\n};\n\nconst RootDefaultSpace = {\n    horizontal: {\n        nodeAndText: BASE * 4,\n        emojiAndText: BASE * 2\n    },\n    vertical: {\n        nodeAndText: BASE * 2\n    }\n};\n\nconst getHorizontalSpaceBetweenNodeAndText = (board: PlaitMindBoard, element: MindElement) => {\n    const isMind = PlaitMind.isMind(element);\n    const nodeAndText = isMind ? RootDefaultSpace.horizontal.nodeAndText : NodeDefaultSpace.horizontal.nodeAndText;\n    return nodeAndText;\n};\n\nconst getVerticalSpaceBetweenNodeAndText = (element: MindElement) => {\n    const isMind = PlaitMind.isMind(element);\n    const nodeAndText = isMind ? RootDefaultSpace.vertical.nodeAndText : NodeDefaultSpace.vertical.nodeAndText;\n    return nodeAndText;\n};\n\nconst getSpaceEmojiAndText = (element: MindElement) => {\n    const isMind = PlaitMind.isMind(element);\n    const emojiAndText = isMind ? RootDefaultSpace.horizontal.emojiAndText : NodeDefaultSpace.horizontal.emojiAndText;\n    return emojiAndText;\n};\n\nexport const NodeSpace = {\n    getNodeWidth(board: PlaitMindBoard, element: MindElement) {\n        const nodeAndText = getHorizontalSpaceBetweenNodeAndText(board, element);\n        if (MindElement.hasEmojis(element)) {\n            return (\n                NodeSpace.getEmojiLeftSpace(board, element) +\n                getEmojisWidthHeight(board, element).width +\n                getSpaceEmojiAndText(element) +\n                NodeSpace.getNodeResizableWidth(board, element) +\n                nodeAndText\n            );\n        }\n        return nodeAndText + NodeSpace.getNodeResizableWidth(board, element) + nodeAndText;\n    },\n    getNodeHeight(board: PlaitMindBoard, element: MindElement) {\n        const nodeAndText = getVerticalSpaceBetweenNodeAndText(element);\n        if (MindElement.hasImage(element)) {\n            return (\n                NodeDefaultSpace.vertical.nodeAndImage +\n                element.data.image.height +\n                NodeDefaultSpace.vertical.imageAndText +\n                element.height +\n                nodeAndText\n            );\n        }\n        return nodeAndText + element.height + nodeAndText;\n    },\n    getNodeResizableWidth(board: PlaitMindBoard, element: MindElement) {\n        const imageWidth = MindElement.hasImage(element) ? element.data.image?.width : 0;\n        return Math.max(element.width, imageWidth);\n    },\n    getNodeResizableMinWidth(board: PlaitMindBoard, element: MindElement) {\n        const minTopicWidth = NodeSpace.getNodeTopicMinWidth(board, element);\n        if (MindElement.hasImage(element) && element.data.image.width > minTopicWidth) {\n            return element.data.image.width;\n        } else {\n            return minTopicWidth;\n        }\n    },\n    getNodeTopicMinWidth(board: PlaitMindBoard, element: MindElement, isRoot: boolean = false) {\n        const defaultFontSize = getNodeDefaultFontSize(isRoot);\n        const editor = MindElement.getTextEditor(element);\n        const marks = PlaitMarkEditor.getMarks(editor);\n        const fontSize = (marks[MarkTypes.fontSize] as number) || defaultFontSize;\n        return fontSize;\n    },\n    getTextLeftSpace(board: PlaitMindBoard, element: MindElement) {\n        const nodeAndText = getHorizontalSpaceBetweenNodeAndText(board, element);\n        if (MindElement.hasEmojis(element)) {\n            return NodeSpace.getEmojiLeftSpace(board, element) + getEmojisWidthHeight(board, element).width + getSpaceEmojiAndText(element);\n        } else {\n            return nodeAndText;\n        }\n    },\n    getTextTopSpace(element: MindElement) {\n        const nodeAndText = getVerticalSpaceBetweenNodeAndText(element);\n        if (MindElement.hasImage(element)) {\n            return element.data.image.height + NodeDefaultSpace.vertical.nodeAndImage + NodeDefaultSpace.vertical.imageAndText;\n        } else {\n            return nodeAndText;\n        }\n    },\n    getImageTopSpace(element: MindElement) {\n        return NodeDefaultSpace.vertical.nodeAndImage;\n    },\n    getEmojiLeftSpace(board: PlaitMindBoard, element: MindElement<EmojiData>) {\n        const options = board.getPluginOptions<WithMindOptions>(WithMindPluginKey);\n        const nodeAndText = getHorizontalSpaceBetweenNodeAndText(board, element);\n        return nodeAndText - options.emojiPadding;\n    },\n    getEmojiTopSpace(element: MindElement) {\n        const nodeAndText = getVerticalSpaceBetweenNodeAndText(element);\n        return nodeAndText;\n    }\n};\n\nexport const getFontSizeBySlateElement = (text: string | Element) => {\n    const defaultFontSize = DEFAULT_FONT_SIZE;\n    if (typeof text === 'string') {\n        return defaultFontSize;\n    }\n    const marks = PlaitMarkEditor.getMarksByElement(text);\n    const fontSize = (marks[MarkTypes.fontSize] as number) || defaultFontSize;\n    return fontSize;\n};\n\nexport const getNodeDefaultFontSize = (isRoot = false) => {\n    const defaultFontSize = isRoot ? ROOT_TOPIC_FONT_SIZE : DEFAULT_FONT_SIZE;\n    return defaultFontSize;\n};\n"]}
@@ -1,9 +1,9 @@
1
1
  import * as i0 from '@angular/core';
2
2
  import { Directive, Input, Component, ChangeDetectionStrategy, NgModule, NgZone, HostListener } from '@angular/core';
3
3
  import * as i2 from '@plait/core';
4
- import { DefaultThemeColor, ColorfulThemeColor, SoftThemeColor, RetroThemeColor, DarkThemeColor, StarryThemeColor, RectangleClient, PlaitElement, idCreator, isNullOrUndefined, Transforms, clearSelectedElement, addSelectedElement, PlaitNode, Path, PlaitBoard, depthFirstRecursion, drawLinearPath, drawBezierPath, createG, updateForeignObject, drawRoundRectangle, getRectangleByElements, getSelectedElements, NODE_TO_PARENT, distanceBetweenPointAndRectangle, createForeignObject, createText, PlaitPointerType, PlaitPluginElementComponent, NODE_TO_INDEX, PlaitModule, transformPoint, toPoint, getHitElements, distanceBetweenPointAndPoint, CLIP_BOARD_FORMAT_KEY, isMainPointer, BOARD_TO_HOST, PlaitPluginKey, throttleRAF, BoardTransforms, removeSelectedElement, PlaitHistoryBoard, hotkeys } from '@plait/core';
4
+ import { DefaultThemeColor, ColorfulThemeColor, SoftThemeColor, RetroThemeColor, DarkThemeColor, StarryThemeColor, RectangleClient, PlaitElement, idCreator, isNullOrUndefined, Transforms, clearSelectedElement, addSelectedElement, PlaitNode, Path, PlaitBoard, depthFirstRecursion, getIsRecursionFunc, drawLinearPath, drawBezierPath, createG, updateForeignObject, drawRoundRectangle, getRectangleByElements, getSelectedElements, NODE_TO_PARENT, distanceBetweenPointAndRectangle, createForeignObject, createText, PlaitPointerType, PlaitPluginElementComponent, NODE_TO_INDEX, PlaitModule, isMainPointer, transformPoint, toPoint, getHitElements, distanceBetweenPointAndPoint, CLIP_BOARD_FORMAT_KEY, BOARD_TO_HOST, PlaitPluginKey, throttleRAF, BoardTransforms, removeSelectedElement, PlaitHistoryBoard, hotkeys } from '@plait/core';
5
5
  import { MindLayoutType, isIndentedLayout, AbstractNode, getNonAbstractChildren, isStandardLayout, isLeftLayout, isRightLayout, isVerticalLogicLayout, isHorizontalLogicLayout, isTopLayout, isBottomLayout, isHorizontalLayout, getCorrectStartEnd, getAbstractLayout, ConnectingPosition, GlobalLayout } from '@plait/layouts';
6
- import { TEXT_DEFAULT_HEIGHT, buildText, getTextSize, TextManage, ExitOrigin, TextModule, getTextFromClipboard } from '@plait/text';
6
+ import { PlaitMarkEditor, MarkTypes, DEFAULT_FONT_SIZE, TEXT_DEFAULT_HEIGHT, buildText, getTextSize, TextManage, ExitOrigin, TextModule, getTextFromClipboard } from '@plait/text';
7
7
  import { fromEvent, Subject } from 'rxjs';
8
8
  import { Node, Path as Path$1 } from 'slate';
9
9
  import { isKeyHotkey } from 'is-hotkey';
@@ -180,6 +180,14 @@ function getEmojiFontSize(element) {
180
180
  }
181
181
  }
182
182
 
183
+ const TOPIC_COLOR = '#333';
184
+ const TOPIC_FONT_SIZE = 14;
185
+ const ROOT_TOPIC_FONT_SIZE = 18;
186
+ const ROOT_TOPIC_HEIGHT = 25;
187
+ const TOPIC_DEFAULT_MAX_WORD_COUNT = 34;
188
+ const DEFAULT_FONT_FAMILY = 'PingFangSC-Regular, "PingFang SC"';
189
+ const BRANCH_FONT_FAMILY = 'PingFangSC-Medium, "PingFang SC"';
190
+
183
191
  const NodeDefaultSpace = {
184
192
  horizontal: {
185
193
  nodeAndText: BASE * 3,
@@ -217,17 +225,15 @@ const getSpaceEmojiAndText = (element) => {
217
225
  };
218
226
  const NodeSpace = {
219
227
  getNodeWidth(board, element) {
220
- var _a;
221
228
  const nodeAndText = getHorizontalSpaceBetweenNodeAndText(board, element);
222
- const imageWidth = MindElement.hasImage(element) ? (_a = element.data.image) === null || _a === void 0 ? void 0 : _a.width : 0;
223
229
  if (MindElement.hasEmojis(element)) {
224
230
  return (NodeSpace.getEmojiLeftSpace(board, element) +
225
231
  getEmojisWidthHeight(board, element).width +
226
232
  getSpaceEmojiAndText(element) +
227
- Math.max(element.width, imageWidth) +
233
+ NodeSpace.getNodeResizableWidth(board, element) +
228
234
  nodeAndText);
229
235
  }
230
- return nodeAndText + Math.max(element.width, imageWidth) + nodeAndText;
236
+ return nodeAndText + NodeSpace.getNodeResizableWidth(board, element) + nodeAndText;
231
237
  },
232
238
  getNodeHeight(board, element) {
233
239
  const nodeAndText = getVerticalSpaceBetweenNodeAndText(element);
@@ -240,6 +246,27 @@ const NodeSpace = {
240
246
  }
241
247
  return nodeAndText + element.height + nodeAndText;
242
248
  },
249
+ getNodeResizableWidth(board, element) {
250
+ var _a;
251
+ const imageWidth = MindElement.hasImage(element) ? (_a = element.data.image) === null || _a === void 0 ? void 0 : _a.width : 0;
252
+ return Math.max(element.width, imageWidth);
253
+ },
254
+ getNodeResizableMinWidth(board, element) {
255
+ const minTopicWidth = NodeSpace.getNodeTopicMinWidth(board, element);
256
+ if (MindElement.hasImage(element) && element.data.image.width > minTopicWidth) {
257
+ return element.data.image.width;
258
+ }
259
+ else {
260
+ return minTopicWidth;
261
+ }
262
+ },
263
+ getNodeTopicMinWidth(board, element, isRoot = false) {
264
+ const defaultFontSize = getNodeDefaultFontSize(isRoot);
265
+ const editor = MindElement.getTextEditor(element);
266
+ const marks = PlaitMarkEditor.getMarks(editor);
267
+ const fontSize = marks[MarkTypes.fontSize] || defaultFontSize;
268
+ return fontSize;
269
+ },
243
270
  getTextLeftSpace(board, element) {
244
271
  const nodeAndText = getHorizontalSpaceBetweenNodeAndText(board, element);
245
272
  if (MindElement.hasEmojis(element)) {
@@ -271,6 +298,19 @@ const NodeSpace = {
271
298
  return nodeAndText;
272
299
  }
273
300
  };
301
+ const getFontSizeBySlateElement = (text) => {
302
+ const defaultFontSize = DEFAULT_FONT_SIZE;
303
+ if (typeof text === 'string') {
304
+ return defaultFontSize;
305
+ }
306
+ const marks = PlaitMarkEditor.getMarksByElement(text);
307
+ const fontSize = marks[MarkTypes.fontSize] || defaultFontSize;
308
+ return fontSize;
309
+ };
310
+ const getNodeDefaultFontSize = (isRoot = false) => {
311
+ const defaultFontSize = isRoot ? ROOT_TOPIC_FONT_SIZE : DEFAULT_FONT_SIZE;
312
+ return defaultFontSize;
313
+ };
274
314
 
275
315
  function getEmojiRectangle(board, element) {
276
316
  let { x, y } = getRectangleByNode(MindElement.getNode(element));
@@ -330,21 +370,11 @@ const isHitImage = (board, element, range) => {
330
370
  return RectangleClient.isHit(RectangleClient.toRectangleClient([range.anchor, range.focus]), client);
331
371
  };
332
372
 
333
- const NODE_MIN_WIDTH = 18;
334
-
335
373
  function editTopic(element) {
336
374
  const component = PlaitElement.getComponent(element);
337
375
  component === null || component === void 0 ? void 0 : component.editTopic();
338
376
  }
339
377
 
340
- const TOPIC_COLOR = '#333';
341
- const TOPIC_FONT_SIZE = 14;
342
- const ROOT_TOPIC_FONT_SIZE = 18;
343
- const ROOT_TOPIC_HEIGHT = 25;
344
- const TOPIC_DEFAULT_MAX_WORD_COUNT = 34;
345
- const DEFAULT_FONT_FAMILY = 'PingFangSC-Regular, "PingFang SC"';
346
- const BRANCH_FONT_FAMILY = 'PingFangSC-Medium, "PingFang SC"';
347
-
348
378
  const createEmptyMind = (point) => {
349
379
  const element = createMindElement('思维导图', 72, ROOT_TOPIC_HEIGHT, { layout: MindLayoutType.right });
350
380
  element.isRoot = true;
@@ -454,7 +484,7 @@ const insertMindElement = (board, inheritNode, path) => {
454
484
  });
455
485
  delete newNode.layout;
456
486
  }
457
- const newElement = createMindElement('', NODE_MIN_WIDTH, TEXT_DEFAULT_HEIGHT, newNode);
487
+ const newElement = createMindElement('', getNodeDefaultFontSize(), TEXT_DEFAULT_HEIGHT, newNode);
458
488
  Transforms.insertNode(board, newElement, path);
459
489
  clearSelectedElement(board);
460
490
  addSelectedElement(board, newElement);
@@ -620,21 +650,22 @@ const adjustNodeToRoot = (board, node) => {
620
650
  fontSize: ROOT_TOPIC_FONT_SIZE,
621
651
  fontFamily: BRANCH_FONT_FAMILY
622
652
  });
623
- newElement.width = Math.max(width, NODE_MIN_WIDTH);
653
+ newElement.width = Math.max(width, getNodeDefaultFontSize(true));
624
654
  newElement.height = height;
625
655
  return Object.assign(Object.assign({}, newElement), { layout: (_a = newElement.layout) !== null && _a !== void 0 ? _a : MindLayoutType.right, isRoot: true, type: 'mindmap' });
626
656
  };
627
657
 
628
658
  const DefaultAbstractNodeStyle = {
629
- branchColor: GRAY_COLOR,
630
- branchWidth: 2,
659
+ branch: { color: GRAY_COLOR, width: 2 },
631
660
  shape: {
632
661
  strokeColor: GRAY_COLOR,
633
662
  strokeWidth: 2
634
663
  }
635
664
  };
636
665
  const DefaultNodeStyle = {
637
- branchWidth: 3,
666
+ branch: {
667
+ width: 3
668
+ },
638
669
  shape: {
639
670
  rectangleRadius: 4,
640
671
  strokeWidth: 3,
@@ -835,13 +866,13 @@ const getAbstractBranchWidth = (board, element) => {
835
866
  if (!isNullOrUndefined(element.branchWidth)) {
836
867
  return element.branchWidth;
837
868
  }
838
- return DefaultAbstractNodeStyle.branchWidth;
869
+ return DefaultAbstractNodeStyle.branch.width;
839
870
  };
840
871
  const getAbstractBranchColor = (board, element) => {
841
872
  if (element.branchColor) {
842
873
  return element.branchColor;
843
874
  }
844
- return DefaultAbstractNodeStyle.branchColor;
875
+ return DefaultAbstractNodeStyle.branch.color;
845
876
  };
846
877
  const getNextBranchColor = (board, root) => {
847
878
  const index = root.children.length;
@@ -883,6 +914,13 @@ const getStrokeWidthByElement = (board, element) => {
883
914
  (AbstractNode.isAbstract(element) ? DefaultAbstractNodeStyle.shape.strokeWidth : DefaultNodeStyle.shape.strokeWidth);
884
915
  return strokeWidth;
885
916
  };
917
+ const getFillByElement = (board, element) => {
918
+ if (element.fill) {
919
+ return element.fill;
920
+ }
921
+ const defaultRootFill = getMindThemeColor(board).rootFill;
922
+ return element.isRoot ? defaultRootFill : DefaultNodeStyle.shape.fill;
923
+ };
886
924
  const getShapeByElement = (board, element) => {
887
925
  const shape = getAvailableProperty(board, element, 'shape');
888
926
  return shape || MindElementShape.roundRectangle;
@@ -1028,14 +1066,7 @@ const detectDropTarget = (board, detectPoint, dropTarget, activeElements) => {
1028
1066
  if (detectResult && isValid) {
1029
1067
  dropTarget = { target: node.origin, detectResult: detectResult[0] };
1030
1068
  }
1031
- }, node => {
1032
- if (PlaitBoard.isBoard(node) || board.isRecursion(node)) {
1033
- return true;
1034
- }
1035
- else {
1036
- return false;
1037
- }
1038
- });
1069
+ }, getIsRecursionFunc(board));
1039
1070
  return dropTarget;
1040
1071
  };
1041
1072
  const directionDetector = (targetNode, centerPoint) => {
@@ -1988,8 +2019,7 @@ function drawRoundRectangleByNode(board, node) {
1988
2019
  return drawRoundRectangleByElement(board, rectangle, node.origin);
1989
2020
  }
1990
2021
  function drawRoundRectangleByElement(board, nodeRectangle, element) {
1991
- const defaultRootFill = getMindThemeColor(board).rootFill;
1992
- const fill = element.fill ? element.fill : element.isRoot ? defaultRootFill : DefaultNodeStyle.shape.fill;
2022
+ const fill = getFillByElement(board, element);
1993
2023
  const stroke = getStrokeByMindElement(board, element);
1994
2024
  const strokeWidth = getStrokeWidthByElement(board, element);
1995
2025
  const nodeG = drawRoundRectangle(PlaitBoard.getRoughSVG(board), nodeRectangle.x, nodeRectangle.y, nodeRectangle.x + nodeRectangle.width, nodeRectangle.y + nodeRectangle.height, {
@@ -2170,8 +2200,8 @@ const setAbstractByElements = (board, groupParent, group) => {
2170
2200
  };
2171
2201
  const insertAbstractNode = (board, path, start, end) => {
2172
2202
  const mindElement = createMindElement('概要', 28, 20, {
2173
- strokeWidth: DefaultAbstractNodeStyle.branchWidth,
2174
- branchWidth: DefaultAbstractNodeStyle.branchWidth
2203
+ strokeWidth: DefaultAbstractNodeStyle.branch.width,
2204
+ branchWidth: DefaultAbstractNodeStyle.branch.width
2175
2205
  });
2176
2206
  mindElement.start = start;
2177
2207
  mindElement.end = end;
@@ -2205,19 +2235,20 @@ const correctLogicLayoutNode = (board, layout, path) => {
2205
2235
  }
2206
2236
  };
2207
2237
 
2208
- const normalizeWidthAndHeight = (board, width, height) => {
2209
- const newWidth = width < NODE_MIN_WIDTH * board.viewport.zoom ? NODE_MIN_WIDTH : width / board.viewport.zoom;
2238
+ const normalizeWidthAndHeight = (board, element, width, height) => {
2239
+ const minWidth = NodeSpace.getNodeTopicMinWidth(board, element, element.isRoot);
2240
+ const newWidth = width < minWidth * board.viewport.zoom ? minWidth : width / board.viewport.zoom;
2210
2241
  const newHeight = height / board.viewport.zoom;
2211
2242
  return { width: newWidth, height: newHeight };
2212
2243
  };
2213
2244
  const setTopic = (board, element, topic, width, height) => {
2214
- const newElement = Object.assign({ data: Object.assign(Object.assign({}, element.data), { topic }) }, normalizeWidthAndHeight(board, width, height));
2245
+ const newElement = Object.assign({ data: Object.assign(Object.assign({}, element.data), { topic }) }, normalizeWidthAndHeight(board, element, width, height));
2215
2246
  const path = PlaitBoard.findPath(board, element);
2216
2247
  Transforms.setNode(board, newElement, path);
2217
2248
  };
2218
2249
  const setTopicSize = (board, element, width, height) => {
2219
- const newElement = Object.assign({}, normalizeWidthAndHeight(board, width, height));
2220
- if (element.width !== newElement.width || element.height !== newElement.height) {
2250
+ const newElement = Object.assign({}, normalizeWidthAndHeight(board, element, width, height));
2251
+ if (Math.floor(element.width) !== Math.floor(newElement.width) || Math.floor(element.height) !== Math.floor(newElement.height)) {
2221
2252
  const path = PlaitBoard.findPath(board, element);
2222
2253
  Transforms.setNode(board, newElement, path);
2223
2254
  }
@@ -3106,7 +3137,7 @@ const withNodeDnd = (board) => {
3106
3137
  if (PlaitBoard.isReadonly(board) ||
3107
3138
  PlaitBoard.hasBeenTextEditing(board) ||
3108
3139
  !PlaitBoard.isPointer(board, PlaitPointerType.selection) ||
3109
- event.button === 2) {
3140
+ !isMainPointer(event)) {
3110
3141
  mousedown(event);
3111
3142
  return;
3112
3143
  }
@@ -3333,7 +3364,7 @@ const insertClipboardData = (board, elements, targetPoint) => {
3333
3364
  newElement = adjustRootToNode(board, newElement);
3334
3365
  const styles = PlaitMind.isMind(targetParent) ? { fontFamily: BRANCH_FONT_FAMILY } : { fontFamily: DEFAULT_FONT_FAMILY };
3335
3366
  const { width, height } = getTextSize(board, newElement.data.topic, TOPIC_DEFAULT_MAX_WORD_COUNT, styles);
3336
- newElement.width = Math.max(width, NODE_MIN_WIDTH);
3367
+ newElement.width = Math.max(width, getNodeDefaultFontSize());
3337
3368
  newElement.height = height;
3338
3369
  }
3339
3370
  // handle abstract start and end
@@ -3363,7 +3394,7 @@ const insertClipboardData = (board, elements, targetPoint) => {
3363
3394
  const insertClipboardText = (board, targetParent, text) => {
3364
3395
  const styles = PlaitMind.isMind(targetParent) ? { fontFamily: BRANCH_FONT_FAMILY } : { fontFamily: DEFAULT_FONT_FAMILY };
3365
3396
  const { width, height } = getTextSize(board, text, TOPIC_DEFAULT_MAX_WORD_COUNT, styles);
3366
- const newElement = createMindElement(text, width, height, {});
3397
+ const newElement = createMindElement(text, Math.max(width, getFontSizeBySlateElement(text)), height, {});
3367
3398
  Transforms.insertNode(board, newElement, findNewChildNodePath(board, targetParent));
3368
3399
  return;
3369
3400
  };
@@ -3711,14 +3742,7 @@ const withNodeHover = (board) => {
3711
3742
  if (isHitElement) {
3712
3743
  target = element;
3713
3744
  }
3714
- }, node => {
3715
- if (PlaitBoard.isBoard(node) || board.isRecursion(node)) {
3716
- return true;
3717
- }
3718
- else {
3719
- return false;
3720
- }
3721
- }, true);
3745
+ }, getIsRecursionFunc(board), true);
3722
3746
  if (hoveredMindElement && target && hoveredMindElement === target) {
3723
3747
  return;
3724
3748
  }
@@ -3801,8 +3825,9 @@ const withMindImage = (board) => {
3801
3825
  return board;
3802
3826
  };
3803
3827
 
3804
- const withMind = (board) => {
3805
- const { drawElement, dblclick, keydown, insertFragment, setFragment, deleteFragment, isHitSelection, getRectangle, isMovable, isRecursion } = board;
3828
+ const withMind = (baseBoard) => {
3829
+ const board = baseBoard;
3830
+ const { drawElement, dblclick, insertFragment, setFragment, deleteFragment, isHitSelection, getRectangle, isMovable, isRecursion } = board;
3806
3831
  board.drawElement = (context) => {
3807
3832
  if (PlaitMind.isMind(context.element)) {
3808
3833
  return PlaitMindComponent;
@@ -3859,14 +3884,7 @@ const withMind = (board) => {
3859
3884
  if (!PlaitBoard.hasBeenTextEditing(board) && isHitMindElement(board, point, node)) {
3860
3885
  editTopic(node);
3861
3886
  }
3862
- }, node => {
3863
- if (PlaitBoard.isBoard(node) || board.isRecursion(node)) {
3864
- return true;
3865
- }
3866
- else {
3867
- return false;
3868
- }
3869
- });
3887
+ }, getIsRecursionFunc(board));
3870
3888
  });
3871
3889
  if (PlaitBoard.hasBeenTextEditing(board)) {
3872
3890
  return;
@@ -3966,5 +3984,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.5", ngImpor
3966
3984
  * Generated bundle index. Do not edit.
3967
3985
  */
3968
3986
 
3969
- export { ABSTRACT_HANDLE_COLOR, ABSTRACT_HANDLE_LENGTH, ABSTRACT_HANDLE_MASK_WIDTH, ABSTRACT_INCLUDED_OUTLINE_OFFSET, AbstractHandlePosition, AbstractResizeState, BASE, BRANCH_FONT_FAMILY, BRANCH_WIDTH, BaseDrawer, BranchShape, DEFAULT_FONT_FAMILY, DefaultAbstractNodeStyle, DefaultNodeStyle, ELEMENT_TO_NODE, EXTEND_DIAMETER, EXTEND_OFFSET, GRAY_COLOR, INHERIT_ATTRIBUTE_KEYS, IS_DRAGGING, LayoutDirection, LayoutDirectionsMap, MindColorfulThemeColor, MindDarkThemeColor, MindDefaultThemeColor, MindElement, MindElementShape, MindEmojiBaseComponent, MindImageBaseComponent, MindModule, MindNode, MindNodeComponent, MindPointerType, MindQueries, MindRetroThemeColor, MindSoftThemeColor, MindStarryThemeColor, MindThemeColor, MindThemeColors, MindTransforms, NODE_MIN_WIDTH, PRIMARY_COLOR, PlaitMind, PlaitMindComponent, QUICK_INSERT_CIRCLE_COLOR, QUICK_INSERT_CIRCLE_OFFSET, QUICK_INSERT_INNER_CROSS_COLOR, ROOT_TOPIC_FONT_SIZE, ROOT_TOPIC_HEIGHT, STROKE_WIDTH, TOPIC_COLOR, TOPIC_DEFAULT_MAX_WORD_COUNT, TOPIC_FONT_SIZE, TRANSPARENT, WithMindPluginKey, addActiveOnDragOrigin, adjustAbstractToNode, adjustNodeToRoot, adjustRootToNode, canSetAbstract, copyNewNode, correctLayoutByDirection, createDefaultMind, createEmptyMind, createMindElement, deleteElementHandleAbstract, deleteElementsHandleRightNodeCount, detectDropTarget, directionCorrector, directionDetector, divideElementByParent, drawFakeDragNode, drawFakeDropNode, editTopic, extractNodesText, findLastChild, findLocationLeftIndex, getAbstractBranchColor, getAbstractBranchWidth, getAbstractHandleRectangle, getAllowedDirection, getAvailableSubLayoutsByLayoutDirections, getBehindAbstracts, getBranchColorByMindElement, getBranchDirectionsByLayouts, getBranchShapeByMindElement, getBranchWidthByMindElement, getChildrenCount, getCorrespondingAbstract, getDefaultBranchColor, getDefaultBranchColorByIndex, getDefaultLayout, getEmojiForeignRectangle, getEmojiRectangle, getFirstLevelElement, getHitAbstractHandle, getImageForeignRectangle, getInCorrectLayoutDirection, getLayoutDirection$1 as getLayoutDirection, getLayoutReverseDirection, getLocationScope, getMindThemeColor, getNextBranchColor, getOverallAbstracts, getPathByDropTarget, getRectangleByElement, getRectangleByNode, getRectangleByResizingLocation, getRelativeStartEndByAbstractRef, getRootLayout, getShapeByElement, getStrokeByMindElement, getStrokeWidthByElement, getTopicRectangleByElement, getTopicRectangleByNode, getValidAbstractRefs, handleTouchedAbstract, hasAfterDraw, hasPreviousOrNextOfDropPath, insertElementHandleAbstract, insertElementHandleRightNodeCount, insertMindElement, isChildElement, isChildOfAbstract, isChildRight, isChildUp, isCorrectLayout, isDragging, isDropStandardRight, isHitEmojis, isHitImage, isHitMindElement, isInRightBranchOfStandardLayout, isMixedLayout, isSetAbstract, isValidTarget, isVirtualKey, removeActiveOnDragOrigin, separateChildren, setIsDragging, withMind, withMindExtend };
3987
+ export { ABSTRACT_HANDLE_COLOR, ABSTRACT_HANDLE_LENGTH, ABSTRACT_HANDLE_MASK_WIDTH, ABSTRACT_INCLUDED_OUTLINE_OFFSET, AbstractHandlePosition, AbstractResizeState, BASE, BRANCH_FONT_FAMILY, BRANCH_WIDTH, BaseDrawer, BranchShape, DEFAULT_FONT_FAMILY, DefaultAbstractNodeStyle, DefaultNodeStyle, ELEMENT_TO_NODE, EXTEND_DIAMETER, EXTEND_OFFSET, GRAY_COLOR, INHERIT_ATTRIBUTE_KEYS, IS_DRAGGING, LayoutDirection, LayoutDirectionsMap, MindColorfulThemeColor, MindDarkThemeColor, MindDefaultThemeColor, MindElement, MindElementShape, MindEmojiBaseComponent, MindImageBaseComponent, MindModule, MindNode, MindNodeComponent, MindPointerType, MindQueries, MindRetroThemeColor, MindSoftThemeColor, MindStarryThemeColor, MindThemeColor, MindThemeColors, MindTransforms, PRIMARY_COLOR, PlaitMind, PlaitMindComponent, QUICK_INSERT_CIRCLE_COLOR, QUICK_INSERT_CIRCLE_OFFSET, QUICK_INSERT_INNER_CROSS_COLOR, ROOT_TOPIC_FONT_SIZE, ROOT_TOPIC_HEIGHT, STROKE_WIDTH, TOPIC_COLOR, TOPIC_DEFAULT_MAX_WORD_COUNT, TOPIC_FONT_SIZE, TRANSPARENT, WithMindPluginKey, addActiveOnDragOrigin, adjustAbstractToNode, adjustNodeToRoot, adjustRootToNode, canSetAbstract, copyNewNode, correctLayoutByDirection, createDefaultMind, createEmptyMind, createMindElement, deleteElementHandleAbstract, deleteElementsHandleRightNodeCount, detectDropTarget, directionCorrector, directionDetector, divideElementByParent, drawFakeDragNode, drawFakeDropNode, editTopic, extractNodesText, findLastChild, findLocationLeftIndex, getAbstractBranchColor, getAbstractBranchWidth, getAbstractHandleRectangle, getAllowedDirection, getAvailableSubLayoutsByLayoutDirections, getBehindAbstracts, getBranchColorByMindElement, getBranchDirectionsByLayouts, getBranchShapeByMindElement, getBranchWidthByMindElement, getChildrenCount, getCorrespondingAbstract, getDefaultBranchColor, getDefaultBranchColorByIndex, getDefaultLayout, getEmojiForeignRectangle, getEmojiRectangle, getFillByElement, getFirstLevelElement, getHitAbstractHandle, getImageForeignRectangle, getInCorrectLayoutDirection, getLayoutDirection$1 as getLayoutDirection, getLayoutReverseDirection, getLocationScope, getMindThemeColor, getNextBranchColor, getOverallAbstracts, getPathByDropTarget, getRectangleByElement, getRectangleByNode, getRectangleByResizingLocation, getRelativeStartEndByAbstractRef, getRootLayout, getShapeByElement, getStrokeByMindElement, getStrokeWidthByElement, getTopicRectangleByElement, getTopicRectangleByNode, getValidAbstractRefs, handleTouchedAbstract, hasAfterDraw, hasPreviousOrNextOfDropPath, insertElementHandleAbstract, insertElementHandleRightNodeCount, insertMindElement, isChildElement, isChildOfAbstract, isChildRight, isChildUp, isCorrectLayout, isDragging, isDropStandardRight, isHitEmojis, isHitImage, isHitMindElement, isInRightBranchOfStandardLayout, isMixedLayout, isSetAbstract, isValidTarget, isVirtualKey, removeActiveOnDragOrigin, separateChildren, setIsDragging, withMind, withMindExtend };
3970
3988
  //# sourceMappingURL=plait-mind.mjs.map