@opentiny/fluent-editor 4.0.0-beta.1 → 4.0.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.
- package/es/config/i18n/en-us.es.js +0 -2
- package/es/config/i18n/en-us.es.js.map +1 -1
- package/es/config/i18n/zh-cn.es.js +0 -2
- package/es/config/i18n/zh-cn.es.js.map +1 -1
- package/es/fluent-editor.es.js +0 -6
- package/es/fluent-editor.es.js.map +1 -1
- package/es/index.es.js +0 -4
- package/es/index.es.js.map +1 -1
- package/es/modules/index.es.js +0 -4
- package/es/modules/index.es.js.map +1 -1
- package/es/modules/shortcut-key/index.es.js +0 -16
- package/es/modules/shortcut-key/index.es.js.map +1 -1
- package/es/ui/icons.config.es.js +0 -4
- package/es/ui/icons.config.es.js.map +1 -1
- package/es/ui/icons.es.js +2 -4
- package/es/ui/icons.es.js.map +1 -1
- package/lib/config/i18n/en-us.cjs.js +0 -2
- package/lib/config/i18n/en-us.cjs.js.map +1 -1
- package/lib/config/i18n/zh-cn.cjs.js +0 -2
- package/lib/config/i18n/zh-cn.cjs.js.map +1 -1
- package/lib/fluent-editor.cjs.js +2 -8
- package/lib/fluent-editor.cjs.js.map +1 -1
- package/lib/index.cjs.js +5 -9
- package/lib/index.cjs.js.map +1 -1
- package/lib/modules/index.cjs.js +5 -9
- package/lib/modules/index.cjs.js.map +1 -1
- package/lib/modules/shortcut-key/index.cjs.js +0 -16
- package/lib/modules/shortcut-key/index.cjs.js.map +1 -1
- package/lib/ui/icons.cjs.js +1 -3
- package/lib/ui/icons.cjs.js.map +1 -1
- package/lib/ui/icons.config.cjs.js +0 -4
- package/lib/ui/icons.config.cjs.js.map +1 -1
- package/package.json +1 -3
- package/types/config/i18n/en-us.d.ts +0 -2
- package/types/config/i18n/zh-cn.d.ts +0 -2
- package/types/config/types/editor-modules.interface.d.ts +0 -4
- package/types/modules/index.d.ts +0 -2
- package/types/ui/icons.config.d.ts +0 -2
- package/es/modules/ai/constants.es.js +0 -50
- package/es/modules/ai/constants.es.js.map +0 -1
- package/es/modules/ai/icons.es.js +0 -319
- package/es/modules/ai/icons.es.js.map +0 -1
- package/es/modules/ai/index.es.js +0 -670
- package/es/modules/ai/index.es.js.map +0 -1
- package/es/modules/flow-chart/config-utils.es.js +0 -102
- package/es/modules/flow-chart/config-utils.es.js.map +0 -1
- package/es/modules/flow-chart/formats/flow-chart-blot.es.js +0 -369
- package/es/modules/flow-chart/formats/flow-chart-blot.es.js.map +0 -1
- package/es/modules/flow-chart/i18n/en-us.es.js +0 -30
- package/es/modules/flow-chart/i18n/en-us.es.js.map +0 -1
- package/es/modules/flow-chart/i18n/index.es.js +0 -12
- package/es/modules/flow-chart/i18n/index.es.js.map +0 -1
- package/es/modules/flow-chart/i18n/zh-cn.es.js +0 -30
- package/es/modules/flow-chart/i18n/zh-cn.es.js.map +0 -1
- package/es/modules/flow-chart/icons.es.js +0 -27
- package/es/modules/flow-chart/icons.es.js.map +0 -1
- package/es/modules/flow-chart/index.es.js +0 -45
- package/es/modules/flow-chart/index.es.js.map +0 -1
- package/es/modules/flow-chart/modules/context-menu.es.js +0 -184
- package/es/modules/flow-chart/modules/context-menu.es.js.map +0 -1
- package/es/modules/flow-chart/modules/control-panel.es.js +0 -286
- package/es/modules/flow-chart/modules/control-panel.es.js.map +0 -1
- package/es/modules/flow-chart/modules/custom-resize-action.es.js +0 -150
- package/es/modules/flow-chart/modules/custom-resize-action.es.js.map +0 -1
- package/es/modules/mind-map/config-utils.es.js +0 -108
- package/es/modules/mind-map/config-utils.es.js.map +0 -1
- package/es/modules/mind-map/formats/mind-map-blot.es.js +0 -356
- package/es/modules/mind-map/formats/mind-map-blot.es.js.map +0 -1
- package/es/modules/mind-map/i18n/en-us.es.js +0 -29
- package/es/modules/mind-map/i18n/en-us.es.js.map +0 -1
- package/es/modules/mind-map/i18n/index.es.js +0 -12
- package/es/modules/mind-map/i18n/index.es.js.map +0 -1
- package/es/modules/mind-map/i18n/zh-cn.es.js +0 -29
- package/es/modules/mind-map/i18n/zh-cn.es.js.map +0 -1
- package/es/modules/mind-map/icons.es.js +0 -45
- package/es/modules/mind-map/icons.es.js.map +0 -1
- package/es/modules/mind-map/index.es.js +0 -56
- package/es/modules/mind-map/index.es.js.map +0 -1
- package/es/modules/mind-map/modules/context-menu.es.js +0 -128
- package/es/modules/mind-map/modules/context-menu.es.js.map +0 -1
- package/es/modules/mind-map/modules/control-panel.es.js +0 -425
- package/es/modules/mind-map/modules/control-panel.es.js.map +0 -1
- package/es/modules/mind-map/modules/custom-resize-action.es.js +0 -161
- package/es/modules/mind-map/modules/custom-resize-action.es.js.map +0 -1
- package/flow-chart.css +0 -185
- package/lib/modules/ai/constants.cjs.js +0 -50
- package/lib/modules/ai/constants.cjs.js.map +0 -1
- package/lib/modules/ai/icons.cjs.js +0 -319
- package/lib/modules/ai/icons.cjs.js.map +0 -1
- package/lib/modules/ai/index.cjs.js +0 -670
- package/lib/modules/ai/index.cjs.js.map +0 -1
- package/lib/modules/flow-chart/config-utils.cjs.js +0 -102
- package/lib/modules/flow-chart/config-utils.cjs.js.map +0 -1
- package/lib/modules/flow-chart/formats/flow-chart-blot.cjs.js +0 -369
- package/lib/modules/flow-chart/formats/flow-chart-blot.cjs.js.map +0 -1
- package/lib/modules/flow-chart/i18n/en-us.cjs.js +0 -30
- package/lib/modules/flow-chart/i18n/en-us.cjs.js.map +0 -1
- package/lib/modules/flow-chart/i18n/index.cjs.js +0 -12
- package/lib/modules/flow-chart/i18n/index.cjs.js.map +0 -1
- package/lib/modules/flow-chart/i18n/zh-cn.cjs.js +0 -30
- package/lib/modules/flow-chart/i18n/zh-cn.cjs.js.map +0 -1
- package/lib/modules/flow-chart/icons.cjs.js +0 -27
- package/lib/modules/flow-chart/icons.cjs.js.map +0 -1
- package/lib/modules/flow-chart/index.cjs.js +0 -45
- package/lib/modules/flow-chart/index.cjs.js.map +0 -1
- package/lib/modules/flow-chart/modules/context-menu.cjs.js +0 -184
- package/lib/modules/flow-chart/modules/context-menu.cjs.js.map +0 -1
- package/lib/modules/flow-chart/modules/control-panel.cjs.js +0 -286
- package/lib/modules/flow-chart/modules/control-panel.cjs.js.map +0 -1
- package/lib/modules/flow-chart/modules/custom-resize-action.cjs.js +0 -150
- package/lib/modules/flow-chart/modules/custom-resize-action.cjs.js.map +0 -1
- package/lib/modules/mind-map/config-utils.cjs.js +0 -108
- package/lib/modules/mind-map/config-utils.cjs.js.map +0 -1
- package/lib/modules/mind-map/formats/mind-map-blot.cjs.js +0 -356
- package/lib/modules/mind-map/formats/mind-map-blot.cjs.js.map +0 -1
- package/lib/modules/mind-map/i18n/en-us.cjs.js +0 -29
- package/lib/modules/mind-map/i18n/en-us.cjs.js.map +0 -1
- package/lib/modules/mind-map/i18n/index.cjs.js +0 -12
- package/lib/modules/mind-map/i18n/index.cjs.js.map +0 -1
- package/lib/modules/mind-map/i18n/zh-cn.cjs.js +0 -29
- package/lib/modules/mind-map/i18n/zh-cn.cjs.js.map +0 -1
- package/lib/modules/mind-map/icons.cjs.js +0 -45
- package/lib/modules/mind-map/icons.cjs.js.map +0 -1
- package/lib/modules/mind-map/index.cjs.js +0 -56
- package/lib/modules/mind-map/index.cjs.js.map +0 -1
- package/lib/modules/mind-map/modules/context-menu.cjs.js +0 -128
- package/lib/modules/mind-map/modules/context-menu.cjs.js.map +0 -1
- package/lib/modules/mind-map/modules/control-panel.cjs.js +0 -425
- package/lib/modules/mind-map/modules/control-panel.cjs.js.map +0 -1
- package/lib/modules/mind-map/modules/custom-resize-action.cjs.js +0 -161
- package/lib/modules/mind-map/modules/custom-resize-action.cjs.js.map +0 -1
- package/mind-map.css +0 -224
- package/types/modules/ai/constants.d.ts +0 -30
- package/types/modules/ai/icons.d.ts +0 -21
- package/types/modules/ai/index.d.ts +0 -96
- package/types/modules/ai/types.d.ts +0 -16
- package/types/modules/flow-chart/config-utils.d.ts +0 -10
- package/types/modules/flow-chart/formats/flow-chart-blot.d.ts +0 -43
- package/types/modules/flow-chart/i18n/en-us.d.ts +0 -26
- package/types/modules/flow-chart/i18n/index.d.ts +0 -1
- package/types/modules/flow-chart/i18n/zh-cn.d.ts +0 -26
- package/types/modules/flow-chart/icons.d.ts +0 -12
- package/types/modules/flow-chart/index.d.ts +0 -10
- package/types/modules/flow-chart/modules/context-menu.d.ts +0 -3
- package/types/modules/flow-chart/modules/control-panel.d.ts +0 -3
- package/types/modules/flow-chart/modules/custom-resize-action.d.ts +0 -22
- package/types/modules/flow-chart/options.d.ts +0 -29
- package/types/modules/mind-map/config-utils.d.ts +0 -12
- package/types/modules/mind-map/formats/mind-map-blot.d.ts +0 -44
- package/types/modules/mind-map/i18n/en-us.d.ts +0 -25
- package/types/modules/mind-map/i18n/index.d.ts +0 -1
- package/types/modules/mind-map/i18n/zh-cn.d.ts +0 -25
- package/types/modules/mind-map/icons.d.ts +0 -21
- package/types/modules/mind-map/index.d.ts +0 -10
- package/types/modules/mind-map/modules/context-menu.d.ts +0 -3
- package/types/modules/mind-map/modules/control-panel.d.ts +0 -3
- package/types/modules/mind-map/modules/custom-resize-action.d.ts +0 -23
- package/types/modules/mind-map/options.d.ts +0 -27
|
@@ -1,356 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __defProp = Object.defineProperty;
|
|
3
|
-
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
4
|
-
var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
|
|
5
|
-
Object.defineProperties(exports, { __esModule: { value: true }, [Symbol.toStringTag]: { value: "Module" } });
|
|
6
|
-
const Quill = require("quill");
|
|
7
|
-
const configUtils = require("../config-utils.cjs.js");
|
|
8
|
-
const icons = require("../icons.cjs.js");
|
|
9
|
-
const contextMenu = require("../modules/context-menu.cjs.js");
|
|
10
|
-
const controlPanel = require("../modules/control-panel.cjs.js");
|
|
11
|
-
const customResizeAction = require("../modules/custom-resize-action.cjs.js");
|
|
12
|
-
;/* empty css */
|
|
13
|
-
const BlockEmbed = Quill.import("blots/embed");
|
|
14
|
-
const _MindMapPlaceholderBlot = class _MindMapPlaceholderBlot extends BlockEmbed {
|
|
15
|
-
constructor(scroll, domNode) {
|
|
16
|
-
super(scroll, domNode);
|
|
17
|
-
__publicField(this, "quill", null);
|
|
18
|
-
__publicField(this, "mindMap", null);
|
|
19
|
-
__publicField(this, "data");
|
|
20
|
-
__publicField(this, "zoomCount", 0);
|
|
21
|
-
__publicField(this, "contextMenu", null);
|
|
22
|
-
__publicField(this, "currentNode", null);
|
|
23
|
-
__publicField(this, "width", 100);
|
|
24
|
-
__publicField(this, "height", 500);
|
|
25
|
-
__publicField(this, "parentObserver", null);
|
|
26
|
-
__publicField(this, "nextPObserver", null);
|
|
27
|
-
const data = _MindMapPlaceholderBlot.value(domNode);
|
|
28
|
-
this.width = data.width || 100;
|
|
29
|
-
this.height = data.height || 500;
|
|
30
|
-
this.domNode.style.width = `${this.width}${data.width ? "px" : "%"}`;
|
|
31
|
-
this.domNode.style.height = `${this.height}px`;
|
|
32
|
-
this.domNode.style.maxWidth = "100%";
|
|
33
|
-
this.domNode.style.border = "1px solid #e8e8e8";
|
|
34
|
-
this.domNode.setAttribute("contenteditable", "false");
|
|
35
|
-
this.data = _MindMapPlaceholderBlot.value(domNode);
|
|
36
|
-
this.initMindMap();
|
|
37
|
-
}
|
|
38
|
-
static value(domNode) {
|
|
39
|
-
const dataStr = JSON.parse(domNode.getAttribute("data-mind-map"));
|
|
40
|
-
const value = dataStr;
|
|
41
|
-
if (domNode.hasAttribute("width")) {
|
|
42
|
-
value.width = Number.parseInt(domNode.getAttribute("width"), 10);
|
|
43
|
-
}
|
|
44
|
-
if (domNode.hasAttribute("height")) {
|
|
45
|
-
value.height = Number.parseInt(domNode.getAttribute("height"), 10);
|
|
46
|
-
}
|
|
47
|
-
return dataStr;
|
|
48
|
-
}
|
|
49
|
-
static create(value) {
|
|
50
|
-
const node = super.create();
|
|
51
|
-
if (value) {
|
|
52
|
-
node.setAttribute("data-mind-map", JSON.stringify(value));
|
|
53
|
-
}
|
|
54
|
-
if (value.width) {
|
|
55
|
-
node.setAttribute("width", String(value.width));
|
|
56
|
-
node.style.width = `${value.width}%`;
|
|
57
|
-
}
|
|
58
|
-
if (value.height) {
|
|
59
|
-
node.setAttribute("height", String(value.height));
|
|
60
|
-
node.style.height = `${value.height}px`;
|
|
61
|
-
}
|
|
62
|
-
node.setAttribute("contenteditable", "false");
|
|
63
|
-
return node;
|
|
64
|
-
}
|
|
65
|
-
static findQuill(el) {
|
|
66
|
-
let cur = el;
|
|
67
|
-
while (cur) {
|
|
68
|
-
const q = cur.__quillInstance;
|
|
69
|
-
if (q) return q;
|
|
70
|
-
cur = cur.parentElement;
|
|
71
|
-
}
|
|
72
|
-
return null;
|
|
73
|
-
}
|
|
74
|
-
attach() {
|
|
75
|
-
super.attach();
|
|
76
|
-
this.quill = _MindMapPlaceholderBlot.findQuill(this.domNode);
|
|
77
|
-
}
|
|
78
|
-
initMindMap() {
|
|
79
|
-
if (this.domNode.isConnected) {
|
|
80
|
-
this.insertMindMapEditor();
|
|
81
|
-
} else {
|
|
82
|
-
const observer = new MutationObserver(() => {
|
|
83
|
-
if (this.domNode.isConnected) {
|
|
84
|
-
this.insertMindMapEditor();
|
|
85
|
-
observer.disconnect();
|
|
86
|
-
}
|
|
87
|
-
});
|
|
88
|
-
observer.observe(document.body, { childList: true, subtree: true });
|
|
89
|
-
}
|
|
90
|
-
}
|
|
91
|
-
insertMindMapEditor() {
|
|
92
|
-
this.domNode.style.width = `${this.width}${this.data.width ? "px" : "%"}`;
|
|
93
|
-
this.domNode.style.height = `${this.height}px`;
|
|
94
|
-
while (this.domNode.firstChild) {
|
|
95
|
-
this.domNode.removeChild(this.domNode.firstChild);
|
|
96
|
-
}
|
|
97
|
-
this.updateAlignmentStyle();
|
|
98
|
-
this.observeParentAlignment();
|
|
99
|
-
const { backgroundConfig, resizeConfig, lineConfig, themeConfig, deps } = configUtils.getAllConfigs(this.quill);
|
|
100
|
-
const { SimpleMindMap, Themes, Drag, Export } = deps || window;
|
|
101
|
-
Themes.init(SimpleMindMap);
|
|
102
|
-
SimpleMindMap.usePlugin(Drag).usePlugin(Export);
|
|
103
|
-
this.mindMap = new SimpleMindMap({
|
|
104
|
-
el: this.domNode,
|
|
105
|
-
mousewheelAction: "zoom",
|
|
106
|
-
disableMouseWheelZoom: true,
|
|
107
|
-
layout: this.data.layout,
|
|
108
|
-
theme: themeConfig,
|
|
109
|
-
data: this.data.root ? this.data.root : this.data
|
|
110
|
-
});
|
|
111
|
-
const styleConfig = { ...backgroundConfig };
|
|
112
|
-
if (lineConfig && typeof lineConfig === "object") {
|
|
113
|
-
Object.assign(styleConfig, lineConfig);
|
|
114
|
-
}
|
|
115
|
-
this.mindMap.setThemeConfig(styleConfig);
|
|
116
|
-
const handleScroll = () => {
|
|
117
|
-
if (this.mindMap && this.domNode && this.domNode.isConnected) {
|
|
118
|
-
this.mindMap.getElRectInfo();
|
|
119
|
-
}
|
|
120
|
-
};
|
|
121
|
-
window.addEventListener("scroll", handleScroll, { passive: true });
|
|
122
|
-
this.domNode.addEventListener("remove", () => {
|
|
123
|
-
window.removeEventListener("scroll", handleScroll);
|
|
124
|
-
});
|
|
125
|
-
if (resizeConfig) {
|
|
126
|
-
new customResizeAction.MindMapResizeAction(this);
|
|
127
|
-
}
|
|
128
|
-
controlPanel.createControlPanel(this, this.quill);
|
|
129
|
-
contextMenu.initContextMenu(this, this.quill);
|
|
130
|
-
this.observeOwnParentChange();
|
|
131
|
-
this.observeNextPElement();
|
|
132
|
-
this.addMouseHoverEvents();
|
|
133
|
-
this.mindMap.on("node_tree_render_end", () => {
|
|
134
|
-
this.data = this.mindMap.getData({});
|
|
135
|
-
this.domNode.setAttribute("data-mind-map", JSON.stringify(this.data));
|
|
136
|
-
});
|
|
137
|
-
this.mindMap.on("node_dblclick", this.handleNodeDblClick.bind(this));
|
|
138
|
-
this.domNode.addEventListener("click", (e) => {
|
|
139
|
-
if (this.quill) {
|
|
140
|
-
this.mindMap.getElRectInfo();
|
|
141
|
-
const mindMapBlot = Quill.find(this.domNode);
|
|
142
|
-
const index = this.quill.getIndex(mindMapBlot);
|
|
143
|
-
if (index && typeof index === "number") {
|
|
144
|
-
this.quill.setSelection(index + 1, 0);
|
|
145
|
-
}
|
|
146
|
-
}
|
|
147
|
-
});
|
|
148
|
-
}
|
|
149
|
-
addMouseHoverEvents() {
|
|
150
|
-
this.domNode.addEventListener("mouseenter", () => {
|
|
151
|
-
this.showControlPanel();
|
|
152
|
-
});
|
|
153
|
-
this.domNode.addEventListener("mouseleave", () => {
|
|
154
|
-
this.mindMap.execCommand("CLEAR_ACTIVE_NODE");
|
|
155
|
-
this.hideControlPanel();
|
|
156
|
-
});
|
|
157
|
-
}
|
|
158
|
-
getControlElements() {
|
|
159
|
-
const leftUpControl = this.domNode.querySelector(".ql-mind-map-left-up-control");
|
|
160
|
-
const control = this.domNode.querySelector(".ql-mind-map-control");
|
|
161
|
-
const panelStatusIcon = this.domNode.querySelector('[data-control-type="panel-status"]');
|
|
162
|
-
return { leftUpControl, control, panelStatusIcon };
|
|
163
|
-
}
|
|
164
|
-
showControlPanel() {
|
|
165
|
-
const { leftUpControl, control, panelStatusIcon } = this.getControlElements();
|
|
166
|
-
if (!leftUpControl || !control) return;
|
|
167
|
-
leftUpControl.style.display = "inline-flex";
|
|
168
|
-
control.style.display = "flex";
|
|
169
|
-
if (panelStatusIcon) {
|
|
170
|
-
const iconElement = panelStatusIcon.querySelector("i") || panelStatusIcon;
|
|
171
|
-
iconElement.innerHTML = icons.expandIcon;
|
|
172
|
-
}
|
|
173
|
-
}
|
|
174
|
-
hideControlPanel() {
|
|
175
|
-
const { leftUpControl, control, panelStatusIcon } = this.getControlElements();
|
|
176
|
-
if (!leftUpControl || !control) return;
|
|
177
|
-
leftUpControl.style.display = "none";
|
|
178
|
-
control.style.display = "none";
|
|
179
|
-
if (panelStatusIcon) {
|
|
180
|
-
const iconElement = panelStatusIcon.querySelector("i") || panelStatusIcon;
|
|
181
|
-
iconElement.innerHTML = icons.contractIcon;
|
|
182
|
-
}
|
|
183
|
-
}
|
|
184
|
-
// 监听父元素变化
|
|
185
|
-
observeOwnParentChange() {
|
|
186
|
-
let currentParent = this.domNode.parentElement;
|
|
187
|
-
const observer = new MutationObserver(() => {
|
|
188
|
-
if (this.domNode.parentElement !== currentParent) {
|
|
189
|
-
currentParent = this.domNode.parentElement;
|
|
190
|
-
this.observeParentAlignment();
|
|
191
|
-
}
|
|
192
|
-
});
|
|
193
|
-
observer.observe(document.body, {
|
|
194
|
-
attributes: false,
|
|
195
|
-
childList: true,
|
|
196
|
-
subtree: true
|
|
197
|
-
});
|
|
198
|
-
}
|
|
199
|
-
// 监听父元素对齐变化
|
|
200
|
-
observeParentAlignment() {
|
|
201
|
-
if (this.parentObserver) {
|
|
202
|
-
this.parentObserver.disconnect();
|
|
203
|
-
}
|
|
204
|
-
const observer = new MutationObserver((mutations) => {
|
|
205
|
-
mutations.forEach((mutation) => {
|
|
206
|
-
if (mutation.attributeName === "class") {
|
|
207
|
-
this.updateAlignmentStyle();
|
|
208
|
-
}
|
|
209
|
-
});
|
|
210
|
-
});
|
|
211
|
-
this.parentObserver = observer;
|
|
212
|
-
const parent = this.domNode.parentElement;
|
|
213
|
-
if (parent) {
|
|
214
|
-
observer.observe(parent, {
|
|
215
|
-
attributes: true,
|
|
216
|
-
attributeFilter: ["class"]
|
|
217
|
-
});
|
|
218
|
-
this.updateAlignmentStyle();
|
|
219
|
-
}
|
|
220
|
-
}
|
|
221
|
-
// 更新对齐样式
|
|
222
|
-
updateAlignmentStyle() {
|
|
223
|
-
const parent = this.domNode.parentElement;
|
|
224
|
-
if (!parent) return;
|
|
225
|
-
this.domNode.style.margin = "";
|
|
226
|
-
this.domNode.style.display = "block";
|
|
227
|
-
if (parent.classList.contains("ql-align-center")) {
|
|
228
|
-
this.domNode.style.margin = "0 auto";
|
|
229
|
-
} else if (parent.classList.contains("ql-align-right")) {
|
|
230
|
-
this.domNode.style.marginLeft = "auto";
|
|
231
|
-
this.domNode.style.marginRight = "0";
|
|
232
|
-
} else {
|
|
233
|
-
this.domNode.style.marginLeft = "0";
|
|
234
|
-
this.domNode.style.marginRight = "auto";
|
|
235
|
-
}
|
|
236
|
-
}
|
|
237
|
-
observeNextPElement() {
|
|
238
|
-
if (this.nextPObserver) {
|
|
239
|
-
this.nextPObserver.disconnect();
|
|
240
|
-
}
|
|
241
|
-
const parentElement = this.domNode.parentElement;
|
|
242
|
-
if (!parentElement) {
|
|
243
|
-
return;
|
|
244
|
-
}
|
|
245
|
-
const trackedParentElement = parentElement;
|
|
246
|
-
const parentElementId = parentElement.getAttribute("id") || `mind-map-parent-${Date.now()}`;
|
|
247
|
-
parentElement.setAttribute("id", parentElementId);
|
|
248
|
-
const observer = new MutationObserver(() => {
|
|
249
|
-
if (!document.contains(trackedParentElement)) {
|
|
250
|
-
const elementById = document.getElementById(parentElementId);
|
|
251
|
-
if (!elementById) {
|
|
252
|
-
this.remove();
|
|
253
|
-
observer.disconnect();
|
|
254
|
-
}
|
|
255
|
-
}
|
|
256
|
-
});
|
|
257
|
-
observer.observe(document.body, {
|
|
258
|
-
childList: true,
|
|
259
|
-
subtree: true
|
|
260
|
-
});
|
|
261
|
-
this.nextPObserver = observer;
|
|
262
|
-
}
|
|
263
|
-
handleNodeDblClick(node, e) {
|
|
264
|
-
if (node && node.uid && e) {
|
|
265
|
-
this.currentNode = node;
|
|
266
|
-
this.createEditInput(node, e);
|
|
267
|
-
}
|
|
268
|
-
}
|
|
269
|
-
// 创建编辑输入框
|
|
270
|
-
createEditInput(node, e) {
|
|
271
|
-
const input = document.createElement("textarea");
|
|
272
|
-
input.className = "ql-mind-map-edit-input";
|
|
273
|
-
input.value = node.nodeData.data.text || "";
|
|
274
|
-
const autoResize = () => {
|
|
275
|
-
input.style.height = "auto";
|
|
276
|
-
input.style.height = `${input.scrollHeight}px`;
|
|
277
|
-
};
|
|
278
|
-
Object.assign(input.style, {
|
|
279
|
-
position: "absolute",
|
|
280
|
-
boxSizing: "border-box",
|
|
281
|
-
width: "100px",
|
|
282
|
-
height: "35px",
|
|
283
|
-
padding: "5px",
|
|
284
|
-
lineHeight: "1.2",
|
|
285
|
-
fontFamily: "微软雅黑",
|
|
286
|
-
fontSize: "16px",
|
|
287
|
-
whiteSpace: "pre",
|
|
288
|
-
textAlign: "center",
|
|
289
|
-
background: "#fff",
|
|
290
|
-
border: "1px solid #edefed",
|
|
291
|
-
borderRadius: "3px",
|
|
292
|
-
outline: "none",
|
|
293
|
-
transform: "translate(-50%, -50%)",
|
|
294
|
-
resize: "none",
|
|
295
|
-
zIndex: "1000",
|
|
296
|
-
left: `${e.pageX ? e.pageX : 100}px`,
|
|
297
|
-
top: `${e.pageY ? e.pageY : 100}px`,
|
|
298
|
-
overflow: "hidden"
|
|
299
|
-
});
|
|
300
|
-
document.body.appendChild(input);
|
|
301
|
-
autoResize();
|
|
302
|
-
input.addEventListener("keydown", (event) => {
|
|
303
|
-
if (event.key === "Enter" && event.shiftKey) {
|
|
304
|
-
autoResize();
|
|
305
|
-
}
|
|
306
|
-
});
|
|
307
|
-
input.focus();
|
|
308
|
-
const currentNode = node;
|
|
309
|
-
const handleDrawClick = () => {
|
|
310
|
-
this.updateNodeText(input.value, currentNode);
|
|
311
|
-
input.remove();
|
|
312
|
-
this.mindMap.off("draw_click", handleDrawClick);
|
|
313
|
-
};
|
|
314
|
-
this.mindMap.on("draw_click", handleDrawClick);
|
|
315
|
-
input.addEventListener("keydown", (event) => {
|
|
316
|
-
if (event.key === "Enter" && !event.shiftKey) {
|
|
317
|
-
event.preventDefault();
|
|
318
|
-
this.updateNodeText(input.value, currentNode);
|
|
319
|
-
input.remove();
|
|
320
|
-
this.mindMap.off("draw_click", handleDrawClick);
|
|
321
|
-
}
|
|
322
|
-
});
|
|
323
|
-
}
|
|
324
|
-
updateNodeText(text, node) {
|
|
325
|
-
if (node && this.mindMap) {
|
|
326
|
-
node.setText(text);
|
|
327
|
-
const editWraps = document.querySelectorAll(".smm-node-edit-wrap");
|
|
328
|
-
editWraps.forEach((editWrap) => {
|
|
329
|
-
const input = editWrap.querySelector("input, textarea");
|
|
330
|
-
if (input) {
|
|
331
|
-
input.value = text;
|
|
332
|
-
} else {
|
|
333
|
-
editWrap.textContent = text;
|
|
334
|
-
}
|
|
335
|
-
});
|
|
336
|
-
this.data = this.mindMap.getData({});
|
|
337
|
-
this.domNode.setAttribute("data-mind-map", JSON.stringify(this.data));
|
|
338
|
-
}
|
|
339
|
-
}
|
|
340
|
-
format(name, value) {
|
|
341
|
-
}
|
|
342
|
-
remove() {
|
|
343
|
-
this.mindMap.destroy();
|
|
344
|
-
if (this.nextPObserver) {
|
|
345
|
-
this.nextPObserver.disconnect();
|
|
346
|
-
this.nextPObserver = null;
|
|
347
|
-
}
|
|
348
|
-
super.remove();
|
|
349
|
-
}
|
|
350
|
-
};
|
|
351
|
-
__publicField(_MindMapPlaceholderBlot, "blotName", "mind-map");
|
|
352
|
-
__publicField(_MindMapPlaceholderBlot, "tagName", "div");
|
|
353
|
-
__publicField(_MindMapPlaceholderBlot, "className", "ql-mind-map-item");
|
|
354
|
-
let MindMapPlaceholderBlot = _MindMapPlaceholderBlot;
|
|
355
|
-
exports.default = MindMapPlaceholderBlot;
|
|
356
|
-
//# sourceMappingURL=mind-map-blot.cjs.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"mind-map-blot.cjs.js","sources":["../../../../../src/modules/mind-map/formats/mind-map-blot.ts"],"sourcesContent":["import type { Root } from 'parchment'\nimport type { BlockEmbed as TypeBlockEmbed } from 'quill/blots/block'\nimport type FluentEditor from '../../../core/fluent-editor'\nimport Quill from 'quill'\nimport { getAllConfigs } from '../config-utils'\nimport { contractIcon, expandIcon } from '../icons'\nimport { initContextMenu } from '../modules/context-menu'\nimport { createControlPanel } from '../modules/control-panel'\nimport { MindMapResizeAction } from '../modules/custom-resize-action'\nimport '../style/mind-map.scss'\n\nconst BlockEmbed = Quill.import('blots/embed') as typeof TypeBlockEmbed\n\nclass MindMapPlaceholderBlot extends BlockEmbed {\n static blotName = 'mind-map'\n static tagName = 'div'\n static className = 'ql-mind-map-item'\n quill: Quill | null = null\n mindMap: any | null = null\n data: any\n zoomCount = 0\n contextMenu: HTMLElement | null = null\n currentNode: any = null\n width: number = 100\n height: number = 500\n parentObserver: MutationObserver | null = null\n nextPObserver: MutationObserver | null = null\n\n constructor(scroll: Root, domNode: HTMLElement) {\n super(scroll, domNode)\n const data = MindMapPlaceholderBlot.value(domNode)\n this.width = data.width || 100\n this.height = data.height || 500\n this.domNode.style.width = `${this.width}${data.width ? 'px' : '%'}`\n this.domNode.style.height = `${this.height}px`\n this.domNode.style.maxWidth = '100%'\n this.domNode.style.border = '1px solid #e8e8e8'\n this.domNode.setAttribute('contenteditable', 'false')\n this.data = MindMapPlaceholderBlot.value(domNode)\n this.initMindMap()\n }\n\n static value(domNode: HTMLElement): any {\n const dataStr = JSON.parse(domNode.getAttribute('data-mind-map'))\n const value = dataStr\n if (domNode.hasAttribute('width')) {\n value.width = Number.parseInt(domNode.getAttribute('width'), 10)\n }\n if (domNode.hasAttribute('height')) {\n value.height = Number.parseInt(domNode.getAttribute('height'), 10)\n }\n return dataStr\n }\n\n static create(value: any): HTMLElement {\n const node = super.create() as HTMLElement\n if (value) {\n node.setAttribute('data-mind-map', JSON.stringify(value))\n }\n if (value.width) {\n node.setAttribute('width', String(value.width))\n node.style.width = `${value.width}%`\n }\n if (value.height) {\n node.setAttribute('height', String(value.height))\n node.style.height = `${value.height}px`\n }\n node.setAttribute('contenteditable', 'false')\n return node\n }\n\n private static findQuill(el: HTMLElement): Quill | null {\n let cur: HTMLElement | null = el\n while (cur) {\n const q = (cur as any).__quillInstance\n if (q) return q\n cur = cur.parentElement\n }\n return null\n }\n\n attach() {\n super.attach()\n this.quill = MindMapPlaceholderBlot.findQuill(this.domNode)\n }\n\n initMindMap(): void {\n if (this.domNode.isConnected) {\n this.insertMindMapEditor()\n }\n else {\n const observer = new MutationObserver(() => {\n if (this.domNode.isConnected) {\n this.insertMindMapEditor()\n observer.disconnect()\n }\n })\n observer.observe(document.body, { childList: true, subtree: true })\n }\n }\n\n insertMindMapEditor(): void {\n this.domNode.style.width = `${this.width}${this.data.width ? 'px' : '%'}`\n this.domNode.style.height = `${this.height}px`\n while (this.domNode.firstChild) {\n this.domNode.removeChild(this.domNode.firstChild)\n }\n this.updateAlignmentStyle()\n this.observeParentAlignment()\n const { backgroundConfig, resizeConfig, lineConfig, themeConfig, deps } = getAllConfigs(this.quill)\n const { SimpleMindMap, Themes, Drag, Export } = deps || window as any\n Themes.init(SimpleMindMap)\n SimpleMindMap.usePlugin(Drag).usePlugin(Export)\n this.mindMap = new SimpleMindMap ({\n el: this.domNode,\n mousewheelAction: 'zoom',\n disableMouseWheelZoom: true,\n layout: this.data.layout,\n theme: themeConfig,\n data: this.data.root ? this.data.root : this.data,\n } as any)\n\n const styleConfig = { ...backgroundConfig }\n if (lineConfig && typeof lineConfig === 'object') {\n Object.assign(styleConfig, lineConfig)\n }\n\n this.mindMap.setThemeConfig(styleConfig)\n\n const handleScroll = () => {\n if (this.mindMap && this.domNode && this.domNode.isConnected) {\n this.mindMap.getElRectInfo()\n }\n }\n\n window.addEventListener('scroll', handleScroll, { passive: true })\n\n this.domNode.addEventListener('remove', () => {\n window.removeEventListener('scroll', handleScroll)\n })\n\n if (resizeConfig) {\n new MindMapResizeAction(this)\n }\n createControlPanel(this, this.quill as FluentEditor) // 创建控制面板\n initContextMenu(this, this.quill as FluentEditor) // 初始化右键菜单\n this.observeOwnParentChange()\n this.observeNextPElement()\n this.addMouseHoverEvents()\n this.mindMap.on('node_tree_render_end', () => {\n this.data = this.mindMap.getData({})\n this.domNode.setAttribute('data-mind-map', JSON.stringify(this.data))\n })\n this.mindMap.on('node_dblclick', this.handleNodeDblClick.bind(this))\n this.domNode.addEventListener('click', (e) => {\n if (this.quill) {\n this.mindMap.getElRectInfo()\n const mindMapBlot = Quill.find(this.domNode)\n const index = this.quill.getIndex(mindMapBlot as MindMapPlaceholderBlot)\n if (index && typeof index === 'number') {\n this.quill.setSelection(index + 1, 0)\n }\n }\n })\n }\n\n addMouseHoverEvents(): void {\n this.domNode.addEventListener('mouseenter', () => {\n this.showControlPanel()\n })\n\n this.domNode.addEventListener('mouseleave', () => {\n this.mindMap.execCommand('CLEAR_ACTIVE_NODE')\n this.hideControlPanel()\n })\n }\n\n getControlElements(): { leftUpControl: HTMLElement | null, control: HTMLElement | null, panelStatusIcon: HTMLElement | null } {\n const leftUpControl = this.domNode.querySelector('.ql-mind-map-left-up-control') as HTMLElement | null\n const control = this.domNode.querySelector('.ql-mind-map-control') as HTMLElement | null\n const panelStatusIcon = this.domNode.querySelector('[data-control-type=\"panel-status\"]') as HTMLElement | null\n return { leftUpControl, control, panelStatusIcon }\n }\n\n showControlPanel(): void {\n const { leftUpControl, control, panelStatusIcon } = this.getControlElements()\n if (!leftUpControl || !control) return\n\n leftUpControl.style.display = 'inline-flex'\n control.style.display = 'flex'\n if (panelStatusIcon) {\n const iconElement = panelStatusIcon.querySelector('i') || panelStatusIcon\n iconElement.innerHTML = expandIcon\n }\n }\n\n hideControlPanel(): void {\n const { leftUpControl, control, panelStatusIcon } = this.getControlElements()\n if (!leftUpControl || !control) return\n\n leftUpControl.style.display = 'none'\n control.style.display = 'none'\n if (panelStatusIcon) {\n const iconElement = panelStatusIcon.querySelector('i') || panelStatusIcon\n iconElement.innerHTML = contractIcon\n }\n }\n\n // 监听父元素变化\n observeOwnParentChange(): void {\n let currentParent = this.domNode.parentElement\n const observer = new MutationObserver(() => {\n if (this.domNode.parentElement !== currentParent) {\n currentParent = this.domNode.parentElement\n this.observeParentAlignment()\n }\n })\n\n observer.observe(document.body, {\n attributes: false,\n childList: true,\n subtree: true,\n })\n }\n\n // 监听父元素对齐变化\n observeParentAlignment(): void {\n if (this.parentObserver) {\n this.parentObserver.disconnect()\n }\n\n const observer = new MutationObserver((mutations) => {\n mutations.forEach((mutation) => {\n if (mutation.attributeName === 'class') {\n this.updateAlignmentStyle()\n }\n })\n })\n\n this.parentObserver = observer\n\n const parent = this.domNode.parentElement\n if (parent) {\n observer.observe(parent, {\n attributes: true,\n attributeFilter: ['class'],\n })\n this.updateAlignmentStyle()\n }\n }\n\n // 更新对齐样式\n updateAlignmentStyle(): void {\n const parent = this.domNode.parentElement\n if (!parent) return\n\n this.domNode.style.margin = ''\n this.domNode.style.display = 'block'\n\n if (parent.classList.contains('ql-align-center')) {\n this.domNode.style.margin = '0 auto'\n }\n else if (parent.classList.contains('ql-align-right')) {\n this.domNode.style.marginLeft = 'auto'\n this.domNode.style.marginRight = '0'\n }\n else {\n this.domNode.style.marginLeft = '0'\n this.domNode.style.marginRight = 'auto'\n }\n }\n\n observeNextPElement(): void {\n if (this.nextPObserver) {\n this.nextPObserver.disconnect()\n }\n const parentElement = this.domNode.parentElement\n if (!parentElement) {\n return\n }\n const trackedParentElement = parentElement\n const parentElementId = parentElement.getAttribute('id') || `mind-map-parent-${Date.now()}`\n parentElement.setAttribute('id', parentElementId)\n const observer = new MutationObserver(() => {\n if (!document.contains(trackedParentElement)) {\n const elementById = document.getElementById(parentElementId)\n if (!elementById) {\n this.remove()\n observer.disconnect()\n }\n }\n })\n observer.observe(document.body, {\n childList: true,\n subtree: true,\n })\n this.nextPObserver = observer\n }\n\n handleNodeDblClick(node: any, e: any) {\n if (node && node.uid && e) {\n this.currentNode = node\n this.createEditInput(node, e)\n }\n }\n\n // 创建编辑输入框\n createEditInput(node: any, e: any) {\n const input = document.createElement('textarea')\n input.className = 'ql-mind-map-edit-input'\n input.value = node.nodeData.data.text || ''\n const autoResize = () => {\n input.style.height = 'auto'\n input.style.height = `${input.scrollHeight}px`\n }\n Object.assign(input.style, {\n position: 'absolute',\n boxSizing: 'border-box',\n width: '100px',\n height: '35px',\n padding: '5px',\n lineHeight: '1.2',\n fontFamily: '微软雅黑',\n fontSize: '16px',\n whiteSpace: 'pre',\n textAlign: 'center',\n background: '#fff',\n border: '1px solid #edefed',\n borderRadius: '3px',\n outline: 'none',\n transform: 'translate(-50%, -50%)',\n resize: 'none',\n zIndex: '1000',\n left: `${e.pageX ? e.pageX : 100}px`,\n top: `${e.pageY ? e.pageY : 100}px`,\n overflow: 'hidden',\n })\n\n document.body.appendChild(input)\n autoResize()\n input.addEventListener('keydown', (event) => {\n if (event.key === 'Enter' && event.shiftKey) {\n autoResize()\n }\n })\n input.focus()\n\n const currentNode = node\n const handleDrawClick = () => {\n this.updateNodeText(input.value, currentNode)\n input.remove()\n this.mindMap.off('draw_click', handleDrawClick)\n }\n\n this.mindMap.on('draw_click', handleDrawClick)\n\n input.addEventListener('keydown', (event) => {\n if (event.key === 'Enter' && !event.shiftKey) {\n event.preventDefault()\n this.updateNodeText(input.value, currentNode)\n input.remove()\n this.mindMap.off('draw_click', handleDrawClick)\n }\n })\n }\n\n updateNodeText(text: string, node: any) {\n if (node && this.mindMap) {\n node.setText(text)\n const editWraps = document.querySelectorAll('.smm-node-edit-wrap')\n editWraps.forEach((editWrap) => {\n const input = editWrap.querySelector('input, textarea')\n if (input) {\n (input as HTMLInputElement | HTMLTextAreaElement).value = text\n }\n else {\n editWrap.textContent = text\n }\n })\n this.data = this.mindMap.getData({})\n this.domNode.setAttribute('data-mind-map', JSON.stringify(this.data))\n }\n }\n\n format(name: string, value: any) {\n }\n\n remove() {\n this.mindMap.destroy()\n if (this.nextPObserver) {\n this.nextPObserver.disconnect()\n this.nextPObserver = null\n }\n super.remove()\n }\n}\n\nexport default MindMapPlaceholderBlot\n"],"names":["getAllConfigs","MindMapResizeAction","createControlPanel","initContextMenu","expandIcon","contractIcon"],"mappings":"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"}
|
|
@@ -1,29 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
3
|
-
const MIND_MAP_EN_US = {
|
|
4
|
-
"mindMap.controlPanel.zoomOutTitle": "Zoom Out View",
|
|
5
|
-
"mindMap.controlPanel.zoomInTitle": "Zoom In View",
|
|
6
|
-
"mindMap.controlPanel.fitTitle": "Fit View Size",
|
|
7
|
-
"mindMap.controlPanel.backTitle": "Step Back",
|
|
8
|
-
"mindMap.controlPanel.forwardTitle": "Step Forward",
|
|
9
|
-
"mindMap.controlPanel.inserChildNodeTitle": "Insert Child Node",
|
|
10
|
-
"mindMap.controlPanel.inserNodeTitle": "Insert Sibling Node",
|
|
11
|
-
"mindMap.controlPanel.inserParentNodeTitle": "Insert Parent Node",
|
|
12
|
-
"mindMap.controlPanel.removeNodeTitle": "Delete Current Node",
|
|
13
|
-
"mindMap.controlPanel.setLayoutTitle": "Set Layout",
|
|
14
|
-
"mindMap.layout.logicalStructure": "Logical Structure",
|
|
15
|
-
"mindMap.layout.catalogOrganization": "Catalog Organization",
|
|
16
|
-
"mindMap.layout.mindMap": "Mind Map",
|
|
17
|
-
"mindMap.layout.organizationStructure": "Organization Structure",
|
|
18
|
-
"mindMap.layout.timeline": "Timeline",
|
|
19
|
-
"mindMap.layout.fishbone": "Fishbone Diagram",
|
|
20
|
-
"mindMap.contextMenu.copy": "Copy",
|
|
21
|
-
"mindMap.contextMenu.cut": "Cut",
|
|
22
|
-
"mindMap.contextMenu.paste": "Paste",
|
|
23
|
-
"mindMap.contextMenu.deleteContent": "Delete",
|
|
24
|
-
"mindMap.controlPanel.panelStatusTitle": "Panel Status",
|
|
25
|
-
"mindMap.controlPanel.screenTypeTitle": "Screen Type",
|
|
26
|
-
"mindMap.controlPanel.insertIconTitle": "Insert Icon"
|
|
27
|
-
};
|
|
28
|
-
exports.MIND_MAP_EN_US = MIND_MAP_EN_US;
|
|
29
|
-
//# sourceMappingURL=en-us.cjs.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"en-us.cjs.js","sources":["../../../../../src/modules/mind-map/i18n/en-us.ts"],"sourcesContent":["export const MIND_MAP_EN_US = {\n 'mindMap.controlPanel.zoomOutTitle': 'Zoom Out View',\n 'mindMap.controlPanel.zoomInTitle': 'Zoom In View',\n 'mindMap.controlPanel.fitTitle': 'Fit View Size',\n 'mindMap.controlPanel.backTitle': 'Step Back',\n 'mindMap.controlPanel.forwardTitle': 'Step Forward',\n 'mindMap.controlPanel.inserChildNodeTitle': 'Insert Child Node',\n 'mindMap.controlPanel.inserNodeTitle': 'Insert Sibling Node',\n 'mindMap.controlPanel.inserParentNodeTitle': 'Insert Parent Node',\n 'mindMap.controlPanel.removeNodeTitle': 'Delete Current Node',\n 'mindMap.controlPanel.setLayoutTitle': 'Set Layout',\n 'mindMap.layout.logicalStructure': 'Logical Structure',\n 'mindMap.layout.catalogOrganization': 'Catalog Organization',\n 'mindMap.layout.mindMap': 'Mind Map',\n 'mindMap.layout.organizationStructure': 'Organization Structure',\n 'mindMap.layout.timeline': 'Timeline',\n 'mindMap.layout.fishbone': 'Fishbone Diagram',\n 'mindMap.contextMenu.copy': 'Copy',\n 'mindMap.contextMenu.cut': 'Cut',\n 'mindMap.contextMenu.paste': 'Paste',\n 'mindMap.contextMenu.deleteContent': 'Delete',\n 'mindMap.controlPanel.panelStatusTitle': 'Panel Status',\n 'mindMap.controlPanel.screenTypeTitle': 'Screen Type',\n 'mindMap.controlPanel.insertIconTitle': 'Insert Icon',\n}\n"],"names":[],"mappings":";;AAAO,MAAM,iBAAiB;AAAA,EAC5B,qCAAqC;AAAA,EACrC,oCAAoC;AAAA,EACpC,iCAAiC;AAAA,EACjC,kCAAkC;AAAA,EAClC,qCAAqC;AAAA,EACrC,4CAA4C;AAAA,EAC5C,uCAAuC;AAAA,EACvC,6CAA6C;AAAA,EAC7C,wCAAwC;AAAA,EACxC,uCAAuC;AAAA,EACvC,mCAAmC;AAAA,EACnC,sCAAsC;AAAA,EACtC,0BAA0B;AAAA,EAC1B,wCAAwC;AAAA,EACxC,2BAA2B;AAAA,EAC3B,2BAA2B;AAAA,EAC3B,4BAA4B;AAAA,EAC5B,2BAA2B;AAAA,EAC3B,6BAA6B;AAAA,EAC7B,qCAAqC;AAAA,EACrC,yCAAyC;AAAA,EACzC,wCAAwC;AAAA,EACxC,wCAAwC;AAC1C;;"}
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
3
|
-
const enUs = require("./en-us.cjs.js");
|
|
4
|
-
const zhCn = require("./zh-cn.cjs.js");
|
|
5
|
-
function registerMindMapI18N(I18N) {
|
|
6
|
-
I18N.register({
|
|
7
|
-
"en-US": enUs.MIND_MAP_EN_US,
|
|
8
|
-
"zh-CN": zhCn.MIND_MAP_ZH_CN
|
|
9
|
-
}, false);
|
|
10
|
-
}
|
|
11
|
-
exports.registerMindMapI18N = registerMindMapI18N;
|
|
12
|
-
//# sourceMappingURL=index.cjs.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.cjs.js","sources":["../../../../../src/modules/mind-map/i18n/index.ts"],"sourcesContent":["import { MIND_MAP_EN_US } from './en-us'\nimport { MIND_MAP_ZH_CN } from './zh-cn'\n\nexport function registerMindMapI18N(I18N: any) {\n I18N.register({\n 'en-US': MIND_MAP_EN_US,\n 'zh-CN': MIND_MAP_ZH_CN,\n }, false)\n}\n"],"names":["MIND_MAP_EN_US","MIND_MAP_ZH_CN"],"mappings":";;;;AAGO,SAAS,oBAAoB,MAAW;AAC7C,OAAK,SAAS;AAAA,IACZ,SAASA,KAAAA;AAAAA,IACT,SAASC,KAAAA;AAAAA,EAAA,GACR,KAAK;AACV;;"}
|
|
@@ -1,29 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
3
|
-
const MIND_MAP_ZH_CN = {
|
|
4
|
-
"mindMap.controlPanel.zoomOutTitle": "缩小视图",
|
|
5
|
-
"mindMap.controlPanel.zoomInTitle": "放大视图",
|
|
6
|
-
"mindMap.controlPanel.fitTitle": "适应视图大小",
|
|
7
|
-
"mindMap.controlPanel.backTitle": "后退一步",
|
|
8
|
-
"mindMap.controlPanel.forwardTitle": "前进一步",
|
|
9
|
-
"mindMap.controlPanel.inserChildNodeTitle": "插入子节点",
|
|
10
|
-
"mindMap.controlPanel.inserNodeTitle": "插入同级节点",
|
|
11
|
-
"mindMap.controlPanel.inserParentNodeTitle": "插入父节点",
|
|
12
|
-
"mindMap.controlPanel.removeNodeTitle": "删除当前节点",
|
|
13
|
-
"mindMap.controlPanel.setLayoutTitle": "设置布局",
|
|
14
|
-
"mindMap.layout.logicalStructure": "逻辑结构",
|
|
15
|
-
"mindMap.layout.catalogOrganization": "目录组织",
|
|
16
|
-
"mindMap.layout.mindMap": "思维导图",
|
|
17
|
-
"mindMap.layout.organizationStructure": "组织结构",
|
|
18
|
-
"mindMap.layout.timeline": "时间轴",
|
|
19
|
-
"mindMap.layout.fishbone": "鱼骨图",
|
|
20
|
-
"mindMap.contextMenu.copy": "复制",
|
|
21
|
-
"mindMap.contextMenu.cut": "剪切",
|
|
22
|
-
"mindMap.contextMenu.paste": "粘贴",
|
|
23
|
-
"mindMap.contextMenu.deleteContent": "删除",
|
|
24
|
-
"mindMap.controlPanel.panelStatusTitle": "面板状态",
|
|
25
|
-
"mindMap.controlPanel.screenTypeTitle": "屏幕类型",
|
|
26
|
-
"mindMap.controlPanel.insertIconTitle": "插入图标"
|
|
27
|
-
};
|
|
28
|
-
exports.MIND_MAP_ZH_CN = MIND_MAP_ZH_CN;
|
|
29
|
-
//# sourceMappingURL=zh-cn.cjs.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"zh-cn.cjs.js","sources":["../../../../../src/modules/mind-map/i18n/zh-cn.ts"],"sourcesContent":["export const MIND_MAP_ZH_CN = {\n 'mindMap.controlPanel.zoomOutTitle': '缩小视图',\n 'mindMap.controlPanel.zoomInTitle': '放大视图',\n 'mindMap.controlPanel.fitTitle': '适应视图大小',\n 'mindMap.controlPanel.backTitle': '后退一步',\n 'mindMap.controlPanel.forwardTitle': '前进一步',\n 'mindMap.controlPanel.inserChildNodeTitle': '插入子节点',\n 'mindMap.controlPanel.inserNodeTitle': '插入同级节点',\n 'mindMap.controlPanel.inserParentNodeTitle': '插入父节点',\n 'mindMap.controlPanel.removeNodeTitle': '删除当前节点',\n 'mindMap.controlPanel.setLayoutTitle': '设置布局',\n 'mindMap.layout.logicalStructure': '逻辑结构',\n 'mindMap.layout.catalogOrganization': '目录组织',\n 'mindMap.layout.mindMap': '思维导图',\n 'mindMap.layout.organizationStructure': '组织结构',\n 'mindMap.layout.timeline': '时间轴',\n 'mindMap.layout.fishbone': '鱼骨图',\n 'mindMap.contextMenu.copy': '复制',\n 'mindMap.contextMenu.cut': '剪切',\n 'mindMap.contextMenu.paste': '粘贴',\n 'mindMap.contextMenu.deleteContent': '删除',\n 'mindMap.controlPanel.panelStatusTitle': '面板状态',\n 'mindMap.controlPanel.screenTypeTitle': '屏幕类型',\n 'mindMap.controlPanel.insertIconTitle': '插入图标',\n}\n"],"names":[],"mappings":";;AAAO,MAAM,iBAAiB;AAAA,EAC5B,qCAAqC;AAAA,EACrC,oCAAoC;AAAA,EACpC,iCAAiC;AAAA,EACjC,kCAAkC;AAAA,EAClC,qCAAqC;AAAA,EACrC,4CAA4C;AAAA,EAC5C,uCAAuC;AAAA,EACvC,6CAA6C;AAAA,EAC7C,wCAAwC;AAAA,EACxC,uCAAuC;AAAA,EACvC,mCAAmC;AAAA,EACnC,sCAAsC;AAAA,EACtC,0BAA0B;AAAA,EAC1B,wCAAwC;AAAA,EACxC,2BAA2B;AAAA,EAC3B,2BAA2B;AAAA,EAC3B,4BAA4B;AAAA,EAC5B,2BAA2B;AAAA,EAC3B,6BAA6B;AAAA,EAC7B,qCAAqC;AAAA,EACrC,yCAAyC;AAAA,EACzC,wCAAwC;AAAA,EACxC,wCAAwC;AAC1C;;"}
|