@plait/mind 0.22.0 → 0.23.1
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.
- package/esm2020/node.component.mjs +20 -17
- package/esm2020/plugins/with-abstract-resize.mjs +3 -1
- package/esm2020/plugins/with-node-image.mjs +1 -2
- package/esm2020/plugins/with-node-resize.mjs +10 -7
- package/esm2020/transforms/abstract-node.mjs +4 -2
- package/esm2020/transforms/emoji.mjs +3 -3
- package/esm2020/transforms/image.mjs +3 -1
- package/esm2020/utils/clipboard.mjs +5 -2
- package/esm2020/utils/node/adjust-node.mjs +3 -2
- package/fesm2015/plait-mind.mjs +38 -27
- package/fesm2015/plait-mind.mjs.map +1 -1
- package/fesm2020/plait-mind.mjs +41 -27
- package/fesm2020/plait-mind.mjs.map +1 -1
- package/node.component.d.ts +3 -2
- package/package.json +1 -1
- package/styles/styles.scss +5 -2
|
@@ -85,7 +85,10 @@ export const insertClipboardData = (board, elements, targetPoint) => {
|
|
|
85
85
|
if (item.isRoot) {
|
|
86
86
|
newElement = adjustRootToNode(board, newElement);
|
|
87
87
|
const styles = PlaitMind.isMind(targetParent) ? { fontFamily: BRANCH_FONT_FAMILY } : { fontFamily: DEFAULT_FONT_FAMILY };
|
|
88
|
-
const { width, height } = getTextSize(board, newElement.data.topic, TOPIC_DEFAULT_MAX_WORD_COUNT,
|
|
88
|
+
const { width, height } = getTextSize(board, newElement.data.topic, TOPIC_DEFAULT_MAX_WORD_COUNT, {
|
|
89
|
+
...styles,
|
|
90
|
+
width: newElement.manualWidth ? newElement.manualWidth : undefined
|
|
91
|
+
});
|
|
89
92
|
newElement.width = Math.max(width, getNodeDefaultFontSize());
|
|
90
93
|
newElement.height = height;
|
|
91
94
|
}
|
|
@@ -120,4 +123,4 @@ export const insertClipboardText = (board, targetParent, text) => {
|
|
|
120
123
|
Transforms.insertNode(board, newElement, findNewChildNodePath(board, targetParent));
|
|
121
124
|
return;
|
|
122
125
|
};
|
|
123
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"clipboard.js","sourceRoot":"","sources":["../../../../packages/mind/src/utils/clipboard.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    CLIP_BOARD_FORMAT_KEY,\n    getRectangleByElements,\n    getSelectedElements,\n    Path,\n    PlaitBoard,\n    PlaitElement,\n    Point,\n    Transforms\n} from '@plait/core';\nimport { MindElement, PlaitMind } from '../interfaces';\nimport { copyNewNode, extractNodesText } from './mind';\nimport { getRectangleByNode } from './position/node';\nimport { AbstractNode, getNonAbstractChildren } from '@plait/layouts';\nimport { getRelativeStartEndByAbstractRef, getOverallAbstracts, getValidAbstractRefs } from './abstract/common';\nimport { createMindElement } from './node/create-node';\nimport { adjustAbstractToNode, adjustNodeToRoot, adjustRootToNode } from './node/adjust-node';\nimport { Element, Node } from 'slate';\nimport { getTextSize, PlaitMarkEditor } from '@plait/text';\nimport { BRANCH_FONT_FAMILY, DEFAULT_FONT_FAMILY, TOPIC_DEFAULT_MAX_WORD_COUNT } from '../constants/node-topic-style';\nimport { findNewChildNodePath } from './path';\nimport { PlaitMindBoard } from '../plugins/with-mind.board';\nimport { getFontSizeBySlateElement, getNodeDefaultFontSize, NodeSpace } from './space/node-space';\n\nexport const buildClipboardData = (board: PlaitBoard, selectedElements: MindElement[]) => {\n    let result: MindElement[] = [];\n\n    // get overall abstract\n    const overallAbstracts = getOverallAbstracts(board, selectedElements) as MindElement[];\n    // get valid abstract refs\n    const validAbstractRefs = getValidAbstractRefs(board, [...selectedElements, ...overallAbstracts]);\n\n    // keep correct order\n    const newSelectedElements = selectedElements.filter(value => !validAbstractRefs.find(ref => ref.abstract === value));\n    newSelectedElements.push(...validAbstractRefs.map(value => value.abstract));\n\n    const selectedMindNodes = newSelectedElements.map(value => MindElement.getNode(value));\n    const nodesRectangle = getRectangleByElements(board, newSelectedElements, true);\n    newSelectedElements.forEach((element, index) => {\n        // handle relative location\n        const nodeRectangle = getRectangleByNode(selectedMindNodes[index]);\n        const points = [[nodeRectangle.x - nodesRectangle.x, nodeRectangle.y - nodesRectangle.y]] as Point[];\n\n        // handle invalid abstract\n        const abstractRef = validAbstractRefs.find(ref => ref.abstract === element);\n        if (AbstractNode.isAbstract(element) && abstractRef) {\n            const { start, end } = getRelativeStartEndByAbstractRef(abstractRef, newSelectedElements);\n            result.push({\n                ...element,\n                points,\n                start,\n                end\n            });\n        } else {\n            if (AbstractNode.isAbstract(element)) {\n                let newElement = { ...element, points } as MindElement;\n                delete newElement.start;\n                delete newElement.end;\n                result.push(newElement);\n            } else {\n                result.push({\n                    ...element,\n                    points: points\n                });\n            }\n        }\n    });\n    return result;\n};\n\nexport const setClipboardData = (data: DataTransfer | null, elements: MindElement[]) => {\n    const stringObj = JSON.stringify(elements);\n    const encoded = window.btoa(encodeURIComponent(stringObj));\n    const text = elements.reduce((string, currentNode) => {\n        return string + extractNodesText(currentNode);\n    }, '');\n    data?.setData(`application/${CLIP_BOARD_FORMAT_KEY}`, encoded);\n    data?.setData(`text/plain`, text);\n};\n\nexport const getDataFromClipboard = (data: DataTransfer | null) => {\n    const encoded = data?.getData(`application/${CLIP_BOARD_FORMAT_KEY}`);\n    let nodesData: PlaitElement[] = [];\n    if (encoded) {\n        const decoded = decodeURIComponent(window.atob(encoded));\n        nodesData = JSON.parse(decoded);\n    }\n    return nodesData;\n};\n\nexport const insertClipboardData = (board: PlaitMindBoard, elements: PlaitElement[], targetPoint: Point) => {\n    let newElement: MindElement, path: Path;\n    const selectedElements = getSelectedElements(board);\n    let newELements: PlaitElement[] = [];\n\n    const hasTargetParent = selectedElements.length === 1;\n    const targetParent = selectedElements[0];\n    const targetParentPath = targetParent && PlaitBoard.findPath(board, targetParent);\n    const nonAbstractChildrenLength = targetParent && getNonAbstractChildren(targetParent).length;\n\n    elements.forEach((item: PlaitElement, index: number) => {\n        newElement = copyNewNode(item as MindElement);\n\n        if (hasTargetParent) {\n            if (item.isRoot) {\n                newElement = adjustRootToNode(board, newElement);\n                const styles = PlaitMind.isMind(targetParent) ? { fontFamily: BRANCH_FONT_FAMILY } : { fontFamily: DEFAULT_FONT_FAMILY };\n                const { width, height } = getTextSize(board, newElement.data.topic, TOPIC_DEFAULT_MAX_WORD_COUNT, styles);\n                newElement.width = Math.max(width, getNodeDefaultFontSize());\n                newElement.height = height;\n            }\n            // handle abstract start and end\n            if (AbstractNode.isAbstract(newElement)) {\n                newElement.start = newElement.start + nonAbstractChildrenLength;\n                newElement.end = newElement.end + nonAbstractChildrenLength;\n            }\n            path = [...targetParentPath, nonAbstractChildrenLength + index];\n        } else {\n            const point: Point = [targetPoint[0] + item.points![0][0], targetPoint[1] + item.points![0][1]];\n            newElement.points = [point];\n\n            if (AbstractNode.isAbstract(item)) {\n                newElement = adjustAbstractToNode(newElement);\n            }\n\n            if (!item.isRoot) {\n                newElement = adjustNodeToRoot(board, newElement);\n            }\n\n            path = [board.children.length];\n        }\n        newELements.push(newElement);\n        Transforms.insertNode(board, newElement, path);\n        return;\n    });\n    Transforms.setSelectionWithTemporaryElements(board, newELements);\n};\n\nexport const insertClipboardText = (board: PlaitMindBoard, targetParent: PlaitElement, text: string | Element) => {\n    const styles = PlaitMind.isMind(targetParent) ? { fontFamily: BRANCH_FONT_FAMILY } : { fontFamily: DEFAULT_FONT_FAMILY };\n    const { width, height } = getTextSize(board, text, TOPIC_DEFAULT_MAX_WORD_COUNT, styles);\n    const newElement = createMindElement(text, Math.max(width, getFontSizeBySlateElement(text)), height, {});\n    Transforms.insertNode(board, newElement, findNewChildNodePath(board, targetParent));\n    return;\n};\n"]}
|
|
126
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"clipboard.js","sourceRoot":"","sources":["../../../../packages/mind/src/utils/clipboard.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    CLIP_BOARD_FORMAT_KEY,\n    getRectangleByElements,\n    getSelectedElements,\n    Path,\n    PlaitBoard,\n    PlaitElement,\n    Point,\n    Transforms\n} from '@plait/core';\nimport { MindElement, PlaitMind } from '../interfaces';\nimport { copyNewNode, extractNodesText } from './mind';\nimport { getRectangleByNode } from './position/node';\nimport { AbstractNode, getNonAbstractChildren } from '@plait/layouts';\nimport { getRelativeStartEndByAbstractRef, getOverallAbstracts, getValidAbstractRefs } from './abstract/common';\nimport { createMindElement } from './node/create-node';\nimport { adjustAbstractToNode, adjustNodeToRoot, adjustRootToNode } from './node/adjust-node';\nimport { Element, Node } from 'slate';\nimport { getTextSize, PlaitMarkEditor } from '@plait/text';\nimport { BRANCH_FONT_FAMILY, DEFAULT_FONT_FAMILY, TOPIC_DEFAULT_MAX_WORD_COUNT } from '../constants/node-topic-style';\nimport { findNewChildNodePath } from './path';\nimport { PlaitMindBoard } from '../plugins/with-mind.board';\nimport { getFontSizeBySlateElement, getNodeDefaultFontSize, NodeSpace } from './space/node-space';\n\nexport const buildClipboardData = (board: PlaitBoard, selectedElements: MindElement[]) => {\n    let result: MindElement[] = [];\n\n    // get overall abstract\n    const overallAbstracts = getOverallAbstracts(board, selectedElements) as MindElement[];\n    // get valid abstract refs\n    const validAbstractRefs = getValidAbstractRefs(board, [...selectedElements, ...overallAbstracts]);\n\n    // keep correct order\n    const newSelectedElements = selectedElements.filter(value => !validAbstractRefs.find(ref => ref.abstract === value));\n    newSelectedElements.push(...validAbstractRefs.map(value => value.abstract));\n\n    const selectedMindNodes = newSelectedElements.map(value => MindElement.getNode(value));\n    const nodesRectangle = getRectangleByElements(board, newSelectedElements, true);\n    newSelectedElements.forEach((element, index) => {\n        // handle relative location\n        const nodeRectangle = getRectangleByNode(selectedMindNodes[index]);\n        const points = [[nodeRectangle.x - nodesRectangle.x, nodeRectangle.y - nodesRectangle.y]] as Point[];\n\n        // handle invalid abstract\n        const abstractRef = validAbstractRefs.find(ref => ref.abstract === element);\n        if (AbstractNode.isAbstract(element) && abstractRef) {\n            const { start, end } = getRelativeStartEndByAbstractRef(abstractRef, newSelectedElements);\n            result.push({\n                ...element,\n                points,\n                start,\n                end\n            });\n        } else {\n            if (AbstractNode.isAbstract(element)) {\n                let newElement = { ...element, points } as MindElement;\n                delete newElement.start;\n                delete newElement.end;\n                result.push(newElement);\n            } else {\n                result.push({\n                    ...element,\n                    points: points\n                });\n            }\n        }\n    });\n    return result;\n};\n\nexport const setClipboardData = (data: DataTransfer | null, elements: MindElement[]) => {\n    const stringObj = JSON.stringify(elements);\n    const encoded = window.btoa(encodeURIComponent(stringObj));\n    const text = elements.reduce((string, currentNode) => {\n        return string + extractNodesText(currentNode);\n    }, '');\n    data?.setData(`application/${CLIP_BOARD_FORMAT_KEY}`, encoded);\n    data?.setData(`text/plain`, text);\n};\n\nexport const getDataFromClipboard = (data: DataTransfer | null) => {\n    const encoded = data?.getData(`application/${CLIP_BOARD_FORMAT_KEY}`);\n    let nodesData: PlaitElement[] = [];\n    if (encoded) {\n        const decoded = decodeURIComponent(window.atob(encoded));\n        nodesData = JSON.parse(decoded);\n    }\n    return nodesData;\n};\n\nexport const insertClipboardData = (board: PlaitMindBoard, elements: PlaitElement[], targetPoint: Point) => {\n    let newElement: MindElement, path: Path;\n    const selectedElements = getSelectedElements(board);\n    let newELements: PlaitElement[] = [];\n\n    const hasTargetParent = selectedElements.length === 1;\n    const targetParent = selectedElements[0];\n    const targetParentPath = targetParent && PlaitBoard.findPath(board, targetParent);\n    const nonAbstractChildrenLength = targetParent && getNonAbstractChildren(targetParent).length;\n\n    elements.forEach((item: PlaitElement, index: number) => {\n        newElement = copyNewNode(item as MindElement);\n\n        if (hasTargetParent) {\n            if (item.isRoot) {\n                newElement = adjustRootToNode(board, newElement);\n                const styles = PlaitMind.isMind(targetParent) ? { fontFamily: BRANCH_FONT_FAMILY } : { fontFamily: DEFAULT_FONT_FAMILY };\n                const { width, height } = getTextSize(board, newElement.data.topic, TOPIC_DEFAULT_MAX_WORD_COUNT, {\n                    ...styles,\n                    width: newElement.manualWidth ? newElement.manualWidth : undefined\n                });\n                newElement.width = Math.max(width, getNodeDefaultFontSize());\n                newElement.height = height;\n            }\n            // handle abstract start and end\n            if (AbstractNode.isAbstract(newElement)) {\n                newElement.start = newElement.start + nonAbstractChildrenLength;\n                newElement.end = newElement.end + nonAbstractChildrenLength;\n            }\n            path = [...targetParentPath, nonAbstractChildrenLength + index];\n        } else {\n            const point: Point = [targetPoint[0] + item.points![0][0], targetPoint[1] + item.points![0][1]];\n            newElement.points = [point];\n\n            if (AbstractNode.isAbstract(item)) {\n                newElement = adjustAbstractToNode(newElement);\n            }\n\n            if (!item.isRoot) {\n                newElement = adjustNodeToRoot(board, newElement);\n            }\n\n            path = [board.children.length];\n        }\n        newELements.push(newElement);\n        Transforms.insertNode(board, newElement, path);\n        return;\n    });\n    Transforms.setSelectionWithTemporaryElements(board, newELements);\n};\n\nexport const insertClipboardText = (board: PlaitMindBoard, targetParent: PlaitElement, text: string | Element) => {\n    const styles = PlaitMind.isMind(targetParent) ? { fontFamily: BRANCH_FONT_FAMILY } : { fontFamily: DEFAULT_FONT_FAMILY };\n    const { width, height } = getTextSize(board, text, TOPIC_DEFAULT_MAX_WORD_COUNT, styles);\n    const newElement = createMindElement(text, Math.max(width, getFontSizeBySlateElement(text)), height, {});\n    Transforms.insertNode(board, newElement, findNewChildNodePath(board, targetParent));\n    return;\n};\n"]}
|
|
@@ -31,7 +31,8 @@ export const adjustNodeToRoot = (board, node) => {
|
|
|
31
31
|
delete newElement?.isCollapsed;
|
|
32
32
|
const { width, height } = getTextSize(board, newElement.data.topic, TOPIC_DEFAULT_MAX_WORD_COUNT, {
|
|
33
33
|
fontSize: ROOT_TOPIC_FONT_SIZE,
|
|
34
|
-
fontFamily: BRANCH_FONT_FAMILY
|
|
34
|
+
fontFamily: BRANCH_FONT_FAMILY,
|
|
35
|
+
width: node.manualWidth ? node.manualWidth : undefined
|
|
35
36
|
});
|
|
36
37
|
newElement.width = Math.max(width, getNodeDefaultFontSize(true));
|
|
37
38
|
newElement.height = height;
|
|
@@ -42,4 +43,4 @@ export const adjustNodeToRoot = (board, node) => {
|
|
|
42
43
|
type: 'mindmap'
|
|
43
44
|
};
|
|
44
45
|
};
|
|
45
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
46
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWRqdXN0LW5vZGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9taW5kL3NyYy91dGlscy9ub2RlL2FkanVzdC1ub2RlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFDMUMsT0FBTyxFQUFFLElBQUksRUFBRSxNQUFNLE9BQU8sQ0FBQztBQUM3QixPQUFPLEVBQUUsa0JBQWtCLEVBQUUsb0JBQW9CLEVBQUUsNEJBQTRCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUMxSCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDaEQsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFHN0QsTUFBTSxDQUFDLE1BQU0sZ0JBQWdCLEdBQUcsQ0FBQyxLQUFpQixFQUFFLElBQWlCLEVBQUUsRUFBRTtJQUNyRSxNQUFNLE9BQU8sR0FBZ0IsRUFBRSxHQUFHLElBQUksRUFBRSxDQUFDO0lBQ3pDLE9BQU8sT0FBTyxDQUFDLE1BQU0sQ0FBQztJQUN0QixPQUFPLE9BQU8sQ0FBQyxjQUFjLENBQUM7SUFDOUIsT0FBTyxPQUFPLENBQUMsSUFBSSxDQUFDO0lBQ3BCLElBQUksT0FBTyxDQUFDLE1BQU0sS0FBSyxjQUFjLENBQUMsUUFBUSxFQUFFO1FBQzVDLE9BQU8sT0FBTyxDQUFDLE1BQU0sQ0FBQztLQUN6QjtJQUNELE9BQU8sT0FBTyxDQUFDO0FBQ25CLENBQUMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLG9CQUFvQixHQUFHLENBQUMsSUFBaUIsRUFBRSxFQUFFO0lBQ3RELE1BQU0sT0FBTyxHQUFnQixFQUFFLEdBQUcsSUFBSSxFQUFFLENBQUM7SUFDekMsT0FBTyxPQUFPLENBQUMsS0FBSyxDQUFDO0lBQ3JCLE9BQU8sT0FBTyxDQUFDLEdBQUcsQ0FBQztJQUVuQixPQUFPLE9BQU8sQ0FBQztBQUNuQixDQUFDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxnQkFBZ0IsR0FBRyxDQUFDLEtBQXFCLEVBQUUsSUFBaUIsRUFBZSxFQUFFO0lBQ3RGLE1BQU0sVUFBVSxHQUFHLEVBQUUsR0FBRyxJQUFJLEVBQUUsQ0FBQztJQUMvQixJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxFQUFFO1FBQ3JDLFVBQVUsQ0FBQyxJQUFJLENBQUMsS0FBSyxHQUFHLEVBQUUsUUFBUSxFQUFFLENBQUMsRUFBRSxJQUFJLEVBQUUsTUFBTSxFQUFFLENBQUMsRUFBRSxDQUFDO0tBQzVEO0lBRUQsT0FBTyxVQUFVLEVBQUUsV0FBVyxDQUFDO0lBQy9CLE9BQU8sVUFBVSxFQUFFLElBQUksQ0FBQztJQUN4QixPQUFPLFVBQVUsRUFBRSxLQUFLLENBQUM7SUFDekIsT0FBTyxVQUFVLEVBQUUsV0FBVyxDQUFDO0lBQy9CLE9BQU8sVUFBVSxFQUFFLFdBQVcsQ0FBQztJQUUvQixNQUFNLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxHQUFHLFdBQVcsQ0FBQyxLQUFLLEVBQUUsVUFBVSxDQUFDLElBQUksQ0FBQyxLQUFLLEVBQUUsNEJBQTRCLEVBQUU7UUFDOUYsUUFBUSxFQUFFLG9CQUFvQjtRQUM5QixVQUFVLEVBQUUsa0JBQWtCO1FBQzlCLEtBQUssRUFBRSxJQUFJLENBQUMsV0FBVyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLENBQUMsQ0FBQyxTQUFTO0tBQ3pELENBQUMsQ0FBQztJQUNILFVBQVUsQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxLQUFLLEVBQUUsc0JBQXNCLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztJQUNqRSxVQUFVLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQztJQUUzQixPQUFPO1FBQ0gsR0FBRyxVQUFVO1FBQ2IsTUFBTSxFQUFFLFVBQVUsQ0FBQyxNQUFNLElBQUksY0FBYyxDQUFDLEtBQUs7UUFDakQsTUFBTSxFQUFFLElBQUk7UUFDWixJQUFJLEVBQUUsU0FBUztLQUNsQixDQUFDO0FBQ04sQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGxhaXRCb2FyZCB9IGZyb20gJ0BwbGFpdC9jb3JlJztcbmltcG9ydCB7IE1pbmRFbGVtZW50IH0gZnJvbSAnLi4vLi4vaW50ZXJmYWNlcy9lbGVtZW50JztcbmltcG9ydCB7IGdldFRleHRTaXplIH0gZnJvbSAnQHBsYWl0L3RleHQnO1xuaW1wb3J0IHsgTm9kZSB9IGZyb20gJ3NsYXRlJztcbmltcG9ydCB7IEJSQU5DSF9GT05UX0ZBTUlMWSwgUk9PVF9UT1BJQ19GT05UX1NJWkUsIFRPUElDX0RFRkFVTFRfTUFYX1dPUkRfQ09VTlQgfSBmcm9tICcuLi8uLi9jb25zdGFudHMvbm9kZS10b3BpYy1zdHlsZSc7XG5pbXBvcnQgeyBNaW5kTGF5b3V0VHlwZSB9IGZyb20gJ0BwbGFpdC9sYXlvdXRzJztcbmltcG9ydCB7IGdldE5vZGVEZWZhdWx0Rm9udFNpemUgfSBmcm9tICcuLi9zcGFjZS9ub2RlLXNwYWNlJztcbmltcG9ydCB7IFBsYWl0TWluZEJvYXJkIH0gZnJvbSAnLi4vLi4vcGx1Z2lucy93aXRoLW1pbmQuYm9hcmQnO1xuXG5leHBvcnQgY29uc3QgYWRqdXN0Um9vdFRvTm9kZSA9IChib2FyZDogUGxhaXRCb2FyZCwgbm9kZTogTWluZEVsZW1lbnQpID0+IHtcbiAgICBjb25zdCBuZXdOb2RlOiBNaW5kRWxlbWVudCA9IHsgLi4ubm9kZSB9O1xuICAgIGRlbGV0ZSBuZXdOb2RlLmlzUm9vdDtcbiAgICBkZWxldGUgbmV3Tm9kZS5yaWdodE5vZGVDb3VudDtcbiAgICBkZWxldGUgbmV3Tm9kZS50eXBlO1xuICAgIGlmIChuZXdOb2RlLmxheW91dCA9PT0gTWluZExheW91dFR5cGUuc3RhbmRhcmQpIHtcbiAgICAgICAgZGVsZXRlIG5ld05vZGUubGF5b3V0O1xuICAgIH1cbiAgICByZXR1cm4gbmV3Tm9kZTtcbn07XG5cbmV4cG9ydCBjb25zdCBhZGp1c3RBYnN0cmFjdFRvTm9kZSA9IChub2RlOiBNaW5kRWxlbWVudCkgPT4ge1xuICAgIGNvbnN0IG5ld05vZGU6IE1pbmRFbGVtZW50ID0geyAuLi5ub2RlIH07XG4gICAgZGVsZXRlIG5ld05vZGUuc3RhcnQ7XG4gICAgZGVsZXRlIG5ld05vZGUuZW5kO1xuXG4gICAgcmV0dXJuIG5ld05vZGU7XG59O1xuXG5leHBvcnQgY29uc3QgYWRqdXN0Tm9kZVRvUm9vdCA9IChib2FyZDogUGxhaXRNaW5kQm9hcmQsIG5vZGU6IE1pbmRFbGVtZW50KTogTWluZEVsZW1lbnQgPT4ge1xuICAgIGNvbnN0IG5ld0VsZW1lbnQgPSB7IC4uLm5vZGUgfTtcbiAgICBpZiAoIU5vZGUuc3RyaW5nKG5ld0VsZW1lbnQuZGF0YS50b3BpYykpIHtcbiAgICAgICAgbmV3RWxlbWVudC5kYXRhLnRvcGljID0geyBjaGlsZHJlbjogW3sgdGV4dDogJ+aAnee7tOWvvOWbvicgfV0gfTtcbiAgICB9XG5cbiAgICBkZWxldGUgbmV3RWxlbWVudD8uc3Ryb2tlQ29sb3I7XG4gICAgZGVsZXRlIG5ld0VsZW1lbnQ/LmZpbGw7XG4gICAgZGVsZXRlIG5ld0VsZW1lbnQ/LnNoYXBlO1xuICAgIGRlbGV0ZSBuZXdFbGVtZW50Py5zdHJva2VXaWR0aDtcbiAgICBkZWxldGUgbmV3RWxlbWVudD8uaXNDb2xsYXBzZWQ7XG5cbiAgICBjb25zdCB7IHdpZHRoLCBoZWlnaHQgfSA9IGdldFRleHRTaXplKGJvYXJkLCBuZXdFbGVtZW50LmRhdGEudG9waWMsIFRPUElDX0RFRkFVTFRfTUFYX1dPUkRfQ09VTlQsIHtcbiAgICAgICAgZm9udFNpemU6IFJPT1RfVE9QSUNfRk9OVF9TSVpFLFxuICAgICAgICBmb250RmFtaWx5OiBCUkFOQ0hfRk9OVF9GQU1JTFksXG4gICAgICAgIHdpZHRoOiBub2RlLm1hbnVhbFdpZHRoID8gbm9kZS5tYW51YWxXaWR0aCA6IHVuZGVmaW5lZFxuICAgIH0pO1xuICAgIG5ld0VsZW1lbnQud2lkdGggPSBNYXRoLm1heCh3aWR0aCwgZ2V0Tm9kZURlZmF1bHRGb250U2l6ZSh0cnVlKSk7XG4gICAgbmV3RWxlbWVudC5oZWlnaHQgPSBoZWlnaHQ7XG5cbiAgICByZXR1cm4ge1xuICAgICAgICAuLi5uZXdFbGVtZW50LFxuICAgICAgICBsYXlvdXQ6IG5ld0VsZW1lbnQubGF5b3V0ID8/IE1pbmRMYXlvdXRUeXBlLnJpZ2h0LFxuICAgICAgICBpc1Jvb3Q6IHRydWUsXG4gICAgICAgIHR5cGU6ICdtaW5kbWFwJ1xuICAgIH07XG59O1xuIl19
|
package/fesm2015/plait-mind.mjs
CHANGED
|
@@ -663,7 +663,8 @@ const adjustNodeToRoot = (board, node) => {
|
|
|
663
663
|
newElement === null || newElement === void 0 ? true : delete newElement.isCollapsed;
|
|
664
664
|
const { width, height } = getTextSize(board, newElement.data.topic, TOPIC_DEFAULT_MAX_WORD_COUNT, {
|
|
665
665
|
fontSize: ROOT_TOPIC_FONT_SIZE,
|
|
666
|
-
fontFamily: BRANCH_FONT_FAMILY
|
|
666
|
+
fontFamily: BRANCH_FONT_FAMILY,
|
|
667
|
+
width: node.manualWidth ? node.manualWidth : undefined
|
|
667
668
|
});
|
|
668
669
|
newElement.width = Math.max(width, getNodeDefaultFontSize(true));
|
|
669
670
|
newElement.height = height;
|
|
@@ -2243,6 +2244,8 @@ const insertAbstractNode = (board, path, start, end) => {
|
|
|
2243
2244
|
mindElement.start = start;
|
|
2244
2245
|
mindElement.end = end;
|
|
2245
2246
|
Transforms.insertNode(board, mindElement, path);
|
|
2247
|
+
clearSelectedElement(board);
|
|
2248
|
+
addSelectedElement(board, mindElement);
|
|
2246
2249
|
};
|
|
2247
2250
|
|
|
2248
2251
|
const setLayout = (board, layout, path) => {
|
|
@@ -2346,7 +2349,7 @@ const addEmoji = (board, element, emojiItem) => {
|
|
|
2346
2349
|
const newEmojis = [...emojis];
|
|
2347
2350
|
newEmojis.push(emojiItem);
|
|
2348
2351
|
const newElement = {
|
|
2349
|
-
data: {
|
|
2352
|
+
data: Object.assign(Object.assign({}, element.data), { emojis: newEmojis })
|
|
2350
2353
|
};
|
|
2351
2354
|
const path = PlaitBoard.findPath(board, element);
|
|
2352
2355
|
Transforms.setNode(board, newElement, path);
|
|
@@ -2354,7 +2357,7 @@ const addEmoji = (board, element, emojiItem) => {
|
|
|
2354
2357
|
const removeEmoji = (board, element, emojiItem) => {
|
|
2355
2358
|
const emojis = element.data.emojis.filter(value => value !== emojiItem);
|
|
2356
2359
|
const newElement = {
|
|
2357
|
-
data: {
|
|
2360
|
+
data: Object.assign({}, element.data)
|
|
2358
2361
|
};
|
|
2359
2362
|
if (emojis.length > 0) {
|
|
2360
2363
|
newElement.data.emojis = emojis;
|
|
@@ -2378,6 +2381,7 @@ const replaceEmoji = (board, element, oldEmoji, newEmoji) => {
|
|
|
2378
2381
|
};
|
|
2379
2382
|
|
|
2380
2383
|
const removeImage = (board, element) => {
|
|
2384
|
+
setImageFocus(board, element, false);
|
|
2381
2385
|
const newElement = {
|
|
2382
2386
|
data: Object.assign({}, element.data)
|
|
2383
2387
|
};
|
|
@@ -2889,7 +2893,7 @@ class MindNodeComponent extends PlaitPluginElementComponent {
|
|
|
2889
2893
|
this.parentG = PlaitElement.getComponent(MindElement.getRoot(this.board, this.element)).rootG;
|
|
2890
2894
|
this.drawShape();
|
|
2891
2895
|
this.drawLink();
|
|
2892
|
-
this.
|
|
2896
|
+
this.drawTopic();
|
|
2893
2897
|
this.activeDrawer.draw(this.element, this.g, { selected: this.selected, isEditing: this.textManage.isEditing });
|
|
2894
2898
|
this.drawEmojis();
|
|
2895
2899
|
this.drawExtend();
|
|
@@ -2898,18 +2902,6 @@ class MindNodeComponent extends PlaitPluginElementComponent {
|
|
|
2898
2902
|
this.g.classList.add('branch');
|
|
2899
2903
|
}
|
|
2900
2904
|
}
|
|
2901
|
-
editTopic() {
|
|
2902
|
-
this.activeDrawer.draw(this.element, this.g, { selected: this.selected, isEditing: true });
|
|
2903
|
-
if (this.element.manualWidth) {
|
|
2904
|
-
const width = NodeSpace.getNodeResizableWidth(this.board, this.element);
|
|
2905
|
-
this.textManage.updateWidth(width);
|
|
2906
|
-
}
|
|
2907
|
-
this.textManage.edit((origin) => {
|
|
2908
|
-
if (origin === ExitOrigin.default) {
|
|
2909
|
-
this.activeDrawer.draw(this.element, this.g, { selected: this.selected, isEditing: false });
|
|
2910
|
-
}
|
|
2911
|
-
});
|
|
2912
|
-
}
|
|
2913
2905
|
onContextChanged(value, previous) {
|
|
2914
2906
|
const newNode = MindElement.getNode(value.element);
|
|
2915
2907
|
const isEqualNode = RectangleClient.isEqual(this.node, newNode);
|
|
@@ -2922,8 +2914,7 @@ class MindNodeComponent extends PlaitPluginElementComponent {
|
|
|
2922
2914
|
this.drawEmojis();
|
|
2923
2915
|
this.drawExtend();
|
|
2924
2916
|
this.imageDrawer.updateImage(this.g, previous.element, value.element);
|
|
2925
|
-
this.
|
|
2926
|
-
this.textManage.updateRectangle();
|
|
2917
|
+
this.updateTopic();
|
|
2927
2918
|
}
|
|
2928
2919
|
else {
|
|
2929
2920
|
const hasSameSelected = value.selected === previous.selected;
|
|
@@ -3002,9 +2993,25 @@ class MindNodeComponent extends PlaitPluginElementComponent {
|
|
|
3002
2993
|
this.extendG.remove();
|
|
3003
2994
|
}
|
|
3004
2995
|
}
|
|
3005
|
-
|
|
2996
|
+
drawTopic() {
|
|
3006
2997
|
this.textManage.draw(this.element.data.topic);
|
|
3007
2998
|
this.g.append(this.textManage.g);
|
|
2999
|
+
if (this.element.manualWidth) {
|
|
3000
|
+
const width = NodeSpace.getNodeResizableWidth(this.board, this.element);
|
|
3001
|
+
this.textManage.updateWidth(width);
|
|
3002
|
+
}
|
|
3003
|
+
}
|
|
3004
|
+
updateTopic() {
|
|
3005
|
+
this.textManage.updateText(this.element.data.topic);
|
|
3006
|
+
this.textManage.updateRectangle();
|
|
3007
|
+
}
|
|
3008
|
+
editTopic() {
|
|
3009
|
+
this.activeDrawer.draw(this.element, this.g, { selected: this.selected, isEditing: true });
|
|
3010
|
+
this.textManage.edit((origin) => {
|
|
3011
|
+
if (origin === ExitOrigin.default) {
|
|
3012
|
+
this.activeDrawer.draw(this.element, this.g, { selected: this.selected, isEditing: false });
|
|
3013
|
+
}
|
|
3014
|
+
});
|
|
3008
3015
|
}
|
|
3009
3016
|
ngOnDestroy() {
|
|
3010
3017
|
super.ngOnDestroy();
|
|
@@ -3408,7 +3415,7 @@ const insertClipboardData = (board, elements, targetPoint) => {
|
|
|
3408
3415
|
if (item.isRoot) {
|
|
3409
3416
|
newElement = adjustRootToNode(board, newElement);
|
|
3410
3417
|
const styles = PlaitMind.isMind(targetParent) ? { fontFamily: BRANCH_FONT_FAMILY } : { fontFamily: DEFAULT_FONT_FAMILY };
|
|
3411
|
-
const { width, height } = getTextSize(board, newElement.data.topic, TOPIC_DEFAULT_MAX_WORD_COUNT, styles);
|
|
3418
|
+
const { width, height } = getTextSize(board, newElement.data.topic, TOPIC_DEFAULT_MAX_WORD_COUNT, Object.assign(Object.assign({}, styles), { width: newElement.manualWidth ? newElement.manualWidth : undefined }));
|
|
3412
3419
|
newElement.width = Math.max(width, getNodeDefaultFontSize());
|
|
3413
3420
|
newElement.height = height;
|
|
3414
3421
|
}
|
|
@@ -3465,6 +3472,8 @@ const withAbstract = (board) => {
|
|
|
3465
3472
|
return abstractHandlePosition;
|
|
3466
3473
|
});
|
|
3467
3474
|
if (activeAbstractElement) {
|
|
3475
|
+
// prevent text from being selected
|
|
3476
|
+
event.preventDefault();
|
|
3468
3477
|
if (newBoard === null || newBoard === void 0 ? void 0 : newBoard.onAbstractResize) {
|
|
3469
3478
|
newBoard.onAbstractResize(AbstractResizeState.start);
|
|
3470
3479
|
}
|
|
@@ -3870,7 +3879,6 @@ const withNodeImage = (board) => {
|
|
|
3870
3879
|
const selectedImageElement = getSelectedImageElement(board);
|
|
3871
3880
|
if (!PlaitBoard.isReadonly(board) && selectedImageElement && (hotkeys.isDeleteBackward(event) || hotkeys.isDeleteForward(event))) {
|
|
3872
3881
|
addSelectedElement(board, selectedImageElement);
|
|
3873
|
-
setImageFocus(board, selectedImageElement, false);
|
|
3874
3882
|
MindTransforms.removeImage(board, selectedImageElement);
|
|
3875
3883
|
return;
|
|
3876
3884
|
}
|
|
@@ -3897,7 +3905,7 @@ const withNodeResize = (board) => {
|
|
|
3897
3905
|
let startPoint = null;
|
|
3898
3906
|
board.mousedown = (event) => {
|
|
3899
3907
|
if (targetElement) {
|
|
3900
|
-
startPoint =
|
|
3908
|
+
startPoint = [event.x, event.y];
|
|
3901
3909
|
// prevent text from being selected
|
|
3902
3910
|
event.preventDefault();
|
|
3903
3911
|
return;
|
|
@@ -3913,7 +3921,6 @@ const withNodeResize = (board) => {
|
|
|
3913
3921
|
const endPoint = transformPoint(board, toPoint(event.x, event.y, PlaitBoard.getHost(board)));
|
|
3914
3922
|
const distance = distanceBetweenPointAndPoint(startPoint[0], startPoint[1], endPoint[0], endPoint[1]);
|
|
3915
3923
|
if (distance > PRESS_AND_MOVE_BUFFER) {
|
|
3916
|
-
startPoint = endPoint;
|
|
3917
3924
|
addResizing(board, targetElement);
|
|
3918
3925
|
targetElementRef = {
|
|
3919
3926
|
minWidth: NodeSpace.getNodeResizableMinWidth(board, targetElement),
|
|
@@ -3926,17 +3933,21 @@ const withNodeResize = (board) => {
|
|
|
3926
3933
|
}
|
|
3927
3934
|
if (isMindNodeResizing(board) && startPoint && targetElementRef) {
|
|
3928
3935
|
throttleRAF(() => {
|
|
3929
|
-
|
|
3936
|
+
if (!startPoint) {
|
|
3937
|
+
return;
|
|
3938
|
+
}
|
|
3939
|
+
const endPoint = [event.x, event.y];
|
|
3930
3940
|
const offsetX = endPoint[0] - startPoint[0];
|
|
3931
|
-
|
|
3941
|
+
const zoom = board.viewport.zoom;
|
|
3942
|
+
let resizedWidth = targetElementRef.currentWidth + offsetX / zoom;
|
|
3932
3943
|
if (resizedWidth < targetElementRef.minWidth) {
|
|
3933
3944
|
resizedWidth = targetElementRef.minWidth;
|
|
3934
3945
|
}
|
|
3935
3946
|
const newTarget = PlaitNode.get(board, targetElementRef.path);
|
|
3936
3947
|
if (newTarget && NodeSpace.getNodeTopicMinWidth(board, newTarget) !== resizedWidth) {
|
|
3937
3948
|
targetElementRef.textManage.updateWidth(resizedWidth);
|
|
3938
|
-
const {
|
|
3939
|
-
MindTransforms.setNodeManualWidth(board, newTarget, resizedWidth, height);
|
|
3949
|
+
const { height } = targetElementRef.textManage.getSize();
|
|
3950
|
+
MindTransforms.setNodeManualWidth(board, newTarget, resizedWidth * zoom, height);
|
|
3940
3951
|
}
|
|
3941
3952
|
});
|
|
3942
3953
|
return;
|