@ant-design/agentic-ui 2.27.5 → 2.27.7
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/dist/Bubble/Bubble.js +7 -1
- package/dist/Components/effects/EffectPlayer.js +4 -5
- package/dist/History/components/HistoryItem.js +13 -30
- package/dist/History/components/LoadMoreComponent.js +3 -5
- package/dist/History/components/NewChatComponent.js +6 -10
- package/dist/History/menu.js +6 -12
- package/dist/MarkdownEditor/editor/Editor.js +5 -11
- package/dist/MarkdownEditor/editor/components/MediaErrorLink.d.ts +16 -0
- package/dist/MarkdownEditor/editor/components/MediaErrorLink.js +90 -0
- package/dist/MarkdownEditor/editor/elements/{Blockquote.d.ts → Blockquote/index.d.ts} +1 -1
- package/dist/MarkdownEditor/editor/elements/{Blockquote.js → Blockquote/index.js} +1 -1
- package/dist/MarkdownEditor/editor/elements/{FootnoteDefinition.d.ts → FootnoteDefinition/index.d.ts} +1 -1
- package/dist/MarkdownEditor/editor/elements/{FootnoteDefinition.js → FootnoteDefinition/index.js} +2 -2
- package/dist/MarkdownEditor/editor/elements/{FootnoteReference.d.ts → FootnoteReference/index.d.ts} +1 -1
- package/dist/MarkdownEditor/editor/elements/{FootnoteReference.js → FootnoteReference/index.js} +3 -3
- package/dist/MarkdownEditor/editor/elements/{Head.d.ts → Head/index.d.ts} +1 -1
- package/dist/MarkdownEditor/editor/elements/{Head.js → Head/index.js} +4 -4
- package/dist/MarkdownEditor/editor/elements/Image/index.d.ts +11 -10
- package/dist/MarkdownEditor/editor/elements/Image/index.js +55 -148
- package/dist/MarkdownEditor/editor/elements/{Media.d.ts → Media/index.d.ts} +1 -1
- package/dist/MarkdownEditor/editor/elements/{Media.js → Media/index.js} +36 -107
- package/dist/MarkdownEditor/editor/elements/Mermaid/index.d.ts +3 -0
- package/dist/MarkdownEditor/editor/elements/{Mermaid.js → Mermaid/index.js} +13 -28
- package/dist/MarkdownEditor/editor/elements/Mermaid/style.d.ts +10 -0
- package/dist/MarkdownEditor/editor/elements/Mermaid/style.js +144 -0
- package/dist/MarkdownEditor/editor/elements/{Paragraph.d.ts → Paragraph/index.d.ts} +1 -1
- package/dist/MarkdownEditor/editor/elements/{Paragraph.js → Paragraph/index.js} +4 -4
- package/dist/MarkdownEditor/editor/elements/{Schema.js → Schema/index.js} +3 -3
- package/dist/MarkdownInputField/AttachmentButton/AttachmentButtonPopover.js +8 -13
- package/dist/MarkdownInputField/MarkdownInputField.js +4 -7
- package/dist/Plugins/code/components/AceEditor.js +5 -14
- package/dist/Plugins/mermaid/Mermaid.d.ts +0 -7
- package/dist/Plugins/mermaid/Mermaid.js +4 -501
- package/dist/Plugins/mermaid/MermaidFallback.d.ts +5 -0
- package/dist/Plugins/mermaid/MermaidFallback.js +21 -0
- package/dist/Plugins/mermaid/MermaidRendererImpl.d.ts +9 -0
- package/dist/Plugins/mermaid/MermaidRendererImpl.js +39 -0
- package/dist/Plugins/mermaid/style.d.ts +10 -0
- package/dist/Plugins/mermaid/style.js +219 -0
- package/dist/Plugins/mermaid/types.d.ts +1 -0
- package/dist/Plugins/mermaid/types.js +1 -0
- package/dist/Plugins/mermaid/useMermaidRender.d.ts +8 -0
- package/dist/Plugins/mermaid/useMermaidRender.js +303 -0
- package/dist/Plugins/mermaid/utils.d.ts +14 -0
- package/dist/Plugins/mermaid/utils.js +223 -0
- package/dist/TaskList/index.js +4 -8
- package/dist/ToolUseBar/BarItem/Content.js +5 -6
- package/dist/ToolUseBar/BarItem/index.js +6 -14
- package/dist/ToolUseBar/index.js +6 -13
- package/dist/ToolUseBarThink/index.js +6 -11
- package/dist/Utils/debugUtils.d.ts +9 -0
- package/dist/Utils/debugUtils.js +42 -0
- package/dist/index.d.ts +1 -0
- package/package.json +1 -1
- package/dist/MarkdownEditor/editor/elements/Mermaid.d.ts +0 -3
- /package/dist/MarkdownEditor/editor/elements/{Break.d.ts → Break/index.d.ts} +0 -0
- /package/dist/MarkdownEditor/editor/elements/{Break.js → Break/index.js} +0 -0
- /package/dist/MarkdownEditor/editor/elements/{Code.d.ts → Code/index.d.ts} +0 -0
- /package/dist/MarkdownEditor/editor/elements/{Code.js → Code/index.js} +0 -0
- /package/dist/MarkdownEditor/editor/elements/{ErrorBoundary.d.ts → ErrorBoundary/index.d.ts} +0 -0
- /package/dist/MarkdownEditor/editor/elements/{ErrorBoundary.js → ErrorBoundary/index.js} +0 -0
- /package/dist/MarkdownEditor/editor/elements/{Hr.d.ts → Hr/index.d.ts} +0 -0
- /package/dist/MarkdownEditor/editor/elements/{Hr.js → Hr/index.js} +0 -0
- /package/dist/MarkdownEditor/editor/elements/{InlineKatex.d.ts → InlineKatex/index.d.ts} +0 -0
- /package/dist/MarkdownEditor/editor/elements/{InlineKatex.js → InlineKatex/index.js} +0 -0
- /package/dist/MarkdownEditor/editor/elements/{Katex.d.ts → Katex/index.d.ts} +0 -0
- /package/dist/MarkdownEditor/editor/elements/{Katex.js → Katex/index.js} +0 -0
- /package/dist/MarkdownEditor/editor/elements/{Schema.d.ts → Schema/index.d.ts} +0 -0
|
@@ -0,0 +1,219 @@
|
|
|
1
|
+
function _define_property(obj, key, value) {
|
|
2
|
+
if (key in obj) {
|
|
3
|
+
Object.defineProperty(obj, key, {
|
|
4
|
+
value: value,
|
|
5
|
+
enumerable: true,
|
|
6
|
+
configurable: true,
|
|
7
|
+
writable: true
|
|
8
|
+
});
|
|
9
|
+
} else {
|
|
10
|
+
obj[key] = value;
|
|
11
|
+
}
|
|
12
|
+
return obj;
|
|
13
|
+
}
|
|
14
|
+
function _object_spread(target) {
|
|
15
|
+
for(var i = 1; i < arguments.length; i++){
|
|
16
|
+
var source = arguments[i] != null ? arguments[i] : {};
|
|
17
|
+
var ownKeys = Object.keys(source);
|
|
18
|
+
if (typeof Object.getOwnPropertySymbols === "function") {
|
|
19
|
+
ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) {
|
|
20
|
+
return Object.getOwnPropertyDescriptor(source, sym).enumerable;
|
|
21
|
+
}));
|
|
22
|
+
}
|
|
23
|
+
ownKeys.forEach(function(key) {
|
|
24
|
+
_define_property(target, key, source[key]);
|
|
25
|
+
});
|
|
26
|
+
}
|
|
27
|
+
return target;
|
|
28
|
+
}
|
|
29
|
+
function ownKeys(object, enumerableOnly) {
|
|
30
|
+
var keys = Object.keys(object);
|
|
31
|
+
if (Object.getOwnPropertySymbols) {
|
|
32
|
+
var symbols = Object.getOwnPropertySymbols(object);
|
|
33
|
+
if (enumerableOnly) {
|
|
34
|
+
symbols = symbols.filter(function(sym) {
|
|
35
|
+
return Object.getOwnPropertyDescriptor(object, sym).enumerable;
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
keys.push.apply(keys, symbols);
|
|
39
|
+
}
|
|
40
|
+
return keys;
|
|
41
|
+
}
|
|
42
|
+
function _object_spread_props(target, source) {
|
|
43
|
+
source = source != null ? source : {};
|
|
44
|
+
if (Object.getOwnPropertyDescriptors) {
|
|
45
|
+
Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));
|
|
46
|
+
} else {
|
|
47
|
+
ownKeys(Object(source)).forEach(function(key) {
|
|
48
|
+
Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));
|
|
49
|
+
});
|
|
50
|
+
}
|
|
51
|
+
return target;
|
|
52
|
+
}
|
|
53
|
+
import { useEditorStyleRegister } from "../../Hooks/useStyle";
|
|
54
|
+
var genStyle = function(token) {
|
|
55
|
+
return _define_property({}, token.componentCls, {
|
|
56
|
+
// 主容器样式
|
|
57
|
+
marginBottom: '0.75em',
|
|
58
|
+
cursor: 'default',
|
|
59
|
+
userSelect: 'none',
|
|
60
|
+
padding: '0.75rem 0',
|
|
61
|
+
borderRadius: '1em',
|
|
62
|
+
display: 'flex',
|
|
63
|
+
justifyContent: 'center',
|
|
64
|
+
// 增加隔离:防止内容溢出影响其他元素
|
|
65
|
+
position: 'relative',
|
|
66
|
+
isolation: 'isolate',
|
|
67
|
+
contain: 'layout style paint',
|
|
68
|
+
overflow: 'hidden',
|
|
69
|
+
// 渲染容器样式
|
|
70
|
+
'& [data-mermaid-container="true"]': {
|
|
71
|
+
width: '100%',
|
|
72
|
+
maxWidth: '100%',
|
|
73
|
+
minHeight: '200px',
|
|
74
|
+
display: 'flex',
|
|
75
|
+
justifyContent: 'center',
|
|
76
|
+
// 增加隔离样式
|
|
77
|
+
position: 'relative',
|
|
78
|
+
isolation: 'isolate',
|
|
79
|
+
contain: 'layout style paint',
|
|
80
|
+
overflow: 'hidden',
|
|
81
|
+
// 防止 SVG 样式影响外部
|
|
82
|
+
// 添加过渡效果,使更新更平滑
|
|
83
|
+
transition: 'opacity 0.3s ease-in-out, min-height 0.2s ease-in-out'
|
|
84
|
+
},
|
|
85
|
+
// SVG 包装器样式(用于动态创建的 wrapper)
|
|
86
|
+
'& [data-mermaid-wrapper]': {
|
|
87
|
+
position: 'relative',
|
|
88
|
+
width: '100%',
|
|
89
|
+
maxWidth: '100%',
|
|
90
|
+
overflow: 'hidden',
|
|
91
|
+
isolation: 'isolate',
|
|
92
|
+
contain: 'layout style paint',
|
|
93
|
+
display: 'flex',
|
|
94
|
+
justifyContent: 'center',
|
|
95
|
+
alignItems: 'center',
|
|
96
|
+
minHeight: '200px'
|
|
97
|
+
},
|
|
98
|
+
// SVG 元素样式
|
|
99
|
+
'& [data-mermaid-svg="true"]': {
|
|
100
|
+
maxWidth: '100%',
|
|
101
|
+
height: 'auto',
|
|
102
|
+
overflow: 'hidden'
|
|
103
|
+
},
|
|
104
|
+
// SVG 内部元素样式
|
|
105
|
+
'& [data-mermaid-internal="true"]': {
|
|
106
|
+
},
|
|
107
|
+
// 加载状态样式
|
|
108
|
+
'&-loading': {
|
|
109
|
+
textAlign: 'center',
|
|
110
|
+
color: '#6B7280',
|
|
111
|
+
padding: '0.5rem',
|
|
112
|
+
position: 'relative',
|
|
113
|
+
zIndex: 1,
|
|
114
|
+
width: '100%',
|
|
115
|
+
display: 'flex',
|
|
116
|
+
justifyContent: 'center',
|
|
117
|
+
alignItems: 'center',
|
|
118
|
+
minHeight: '200px',
|
|
119
|
+
// Skeleton 样式优化
|
|
120
|
+
'& .ant-skeleton': {
|
|
121
|
+
width: '100%',
|
|
122
|
+
maxWidth: '800px'
|
|
123
|
+
},
|
|
124
|
+
'& .ant-skeleton-image': {
|
|
125
|
+
width: '100%',
|
|
126
|
+
minHeight: '200px',
|
|
127
|
+
borderRadius: '12px'
|
|
128
|
+
}
|
|
129
|
+
},
|
|
130
|
+
// 错误状态样式
|
|
131
|
+
'&-error': {
|
|
132
|
+
textAlign: 'center',
|
|
133
|
+
color: 'rgba(239, 68, 68, 0.8)',
|
|
134
|
+
padding: '0.5rem',
|
|
135
|
+
// 错误信息也增加隔离
|
|
136
|
+
position: 'relative',
|
|
137
|
+
zIndex: 1,
|
|
138
|
+
wordBreak: 'break-word',
|
|
139
|
+
maxWidth: '100%'
|
|
140
|
+
},
|
|
141
|
+
// 空状态样式
|
|
142
|
+
'&-empty': {
|
|
143
|
+
textAlign: 'center',
|
|
144
|
+
color: '#6B7280',
|
|
145
|
+
padding: '0.5rem',
|
|
146
|
+
position: 'relative',
|
|
147
|
+
zIndex: 1
|
|
148
|
+
},
|
|
149
|
+
// Fallback 组件样式
|
|
150
|
+
'&-fallback': {
|
|
151
|
+
marginBottom: '0.75em',
|
|
152
|
+
padding: '0.75rem 0',
|
|
153
|
+
display: 'flex',
|
|
154
|
+
justifyContent: 'center',
|
|
155
|
+
alignItems: 'center',
|
|
156
|
+
color: '#6B7280',
|
|
157
|
+
width: '100%',
|
|
158
|
+
minHeight: '200px',
|
|
159
|
+
// Skeleton 样式优化
|
|
160
|
+
'& .ant-skeleton': {
|
|
161
|
+
width: '100%',
|
|
162
|
+
maxWidth: '800px'
|
|
163
|
+
},
|
|
164
|
+
'& .ant-skeleton-image': {
|
|
165
|
+
width: '100%',
|
|
166
|
+
minHeight: '200px',
|
|
167
|
+
borderRadius: '12px'
|
|
168
|
+
}
|
|
169
|
+
},
|
|
170
|
+
// SVG 渲染优化样式
|
|
171
|
+
'& svg': {
|
|
172
|
+
// 节点样式
|
|
173
|
+
'& .node': {
|
|
174
|
+
'& rect, & circle, & ellipse, & polygon': {
|
|
175
|
+
stroke: '#333',
|
|
176
|
+
strokeWidth: '1px',
|
|
177
|
+
fill: '#fff'
|
|
178
|
+
}
|
|
179
|
+
},
|
|
180
|
+
// 强制设置所有文字样式
|
|
181
|
+
'& text': {
|
|
182
|
+
// 确保文字不会被裁剪
|
|
183
|
+
dominantBaseline: 'middle',
|
|
184
|
+
textAnchor: 'middle'
|
|
185
|
+
},
|
|
186
|
+
// 节点标签 - 更大的字体
|
|
187
|
+
'& .nodeLabel': {
|
|
188
|
+
fontWeight: 500,
|
|
189
|
+
fill: '#333 !important'
|
|
190
|
+
},
|
|
191
|
+
// 边标签 - 稍小一些但仍然清晰
|
|
192
|
+
'& .edgeLabel': {
|
|
193
|
+
fill: '#666 !important'
|
|
194
|
+
},
|
|
195
|
+
// 专门针对流程图的文字
|
|
196
|
+
'& .flowchart-label': {
|
|
197
|
+
fill: '#333 !important'
|
|
198
|
+
},
|
|
199
|
+
// 针对不同类型的标签
|
|
200
|
+
'& .label': {
|
|
201
|
+
fill: '#333 !important'
|
|
202
|
+
}
|
|
203
|
+
}
|
|
204
|
+
});
|
|
205
|
+
};
|
|
206
|
+
/**
|
|
207
|
+
* Mermaid 插件样式 Hook
|
|
208
|
+
* @param prefixCls - 样式类名前缀
|
|
209
|
+
* @returns 样式相关的 wrapSSR 和 hashId
|
|
210
|
+
*/ export function useStyle(prefixCls) {
|
|
211
|
+
return useEditorStyleRegister('agentic-plugin-mermaid', function(token) {
|
|
212
|
+
var editorToken = _object_spread_props(_object_spread({}, token), {
|
|
213
|
+
componentCls: ".".concat(prefixCls)
|
|
214
|
+
});
|
|
215
|
+
return [
|
|
216
|
+
genStyle(editorToken)
|
|
217
|
+
];
|
|
218
|
+
});
|
|
219
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export type MermaidApi = typeof import('mermaid').default;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { };
|
|
@@ -0,0 +1,303 @@
|
|
|
1
|
+
function _array_like_to_array(arr, len) {
|
|
2
|
+
if (len == null || len > arr.length) len = arr.length;
|
|
3
|
+
for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i];
|
|
4
|
+
return arr2;
|
|
5
|
+
}
|
|
6
|
+
function _array_with_holes(arr) {
|
|
7
|
+
if (Array.isArray(arr)) return arr;
|
|
8
|
+
}
|
|
9
|
+
function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
|
|
10
|
+
try {
|
|
11
|
+
var info = gen[key](arg);
|
|
12
|
+
var value = info.value;
|
|
13
|
+
} catch (error) {
|
|
14
|
+
reject(error);
|
|
15
|
+
return;
|
|
16
|
+
}
|
|
17
|
+
if (info.done) {
|
|
18
|
+
resolve(value);
|
|
19
|
+
} else {
|
|
20
|
+
Promise.resolve(value).then(_next, _throw);
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
function _async_to_generator(fn) {
|
|
24
|
+
return function() {
|
|
25
|
+
var self = this, args = arguments;
|
|
26
|
+
return new Promise(function(resolve, reject) {
|
|
27
|
+
var gen = fn.apply(self, args);
|
|
28
|
+
function _next(value) {
|
|
29
|
+
asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value);
|
|
30
|
+
}
|
|
31
|
+
function _throw(err) {
|
|
32
|
+
asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err);
|
|
33
|
+
}
|
|
34
|
+
_next(undefined);
|
|
35
|
+
});
|
|
36
|
+
};
|
|
37
|
+
}
|
|
38
|
+
function _iterable_to_array_limit(arr, i) {
|
|
39
|
+
var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"];
|
|
40
|
+
if (_i == null) return;
|
|
41
|
+
var _arr = [];
|
|
42
|
+
var _n = true;
|
|
43
|
+
var _d = false;
|
|
44
|
+
var _s, _e;
|
|
45
|
+
try {
|
|
46
|
+
for(_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true){
|
|
47
|
+
_arr.push(_s.value);
|
|
48
|
+
if (i && _arr.length === i) break;
|
|
49
|
+
}
|
|
50
|
+
} catch (err) {
|
|
51
|
+
_d = true;
|
|
52
|
+
_e = err;
|
|
53
|
+
} finally{
|
|
54
|
+
try {
|
|
55
|
+
if (!_n && _i["return"] != null) _i["return"]();
|
|
56
|
+
} finally{
|
|
57
|
+
if (_d) throw _e;
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
return _arr;
|
|
61
|
+
}
|
|
62
|
+
function _non_iterable_rest() {
|
|
63
|
+
throw new TypeError("Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
|
|
64
|
+
}
|
|
65
|
+
function _sliced_to_array(arr, i) {
|
|
66
|
+
return _array_with_holes(arr) || _iterable_to_array_limit(arr, i) || _unsupported_iterable_to_array(arr, i) || _non_iterable_rest();
|
|
67
|
+
}
|
|
68
|
+
function _unsupported_iterable_to_array(o, minLen) {
|
|
69
|
+
if (!o) return;
|
|
70
|
+
if (typeof o === "string") return _array_like_to_array(o, minLen);
|
|
71
|
+
var n = Object.prototype.toString.call(o).slice(8, -1);
|
|
72
|
+
if (n === "Object" && o.constructor) n = o.constructor.name;
|
|
73
|
+
if (n === "Map" || n === "Set") return Array.from(n);
|
|
74
|
+
if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array(o, minLen);
|
|
75
|
+
}
|
|
76
|
+
function _ts_generator(thisArg, body) {
|
|
77
|
+
var f, y, t, g, _ = {
|
|
78
|
+
label: 0,
|
|
79
|
+
sent: function() {
|
|
80
|
+
if (t[0] & 1) throw t[1];
|
|
81
|
+
return t[1];
|
|
82
|
+
},
|
|
83
|
+
trys: [],
|
|
84
|
+
ops: []
|
|
85
|
+
};
|
|
86
|
+
return g = {
|
|
87
|
+
next: verb(0),
|
|
88
|
+
"throw": verb(1),
|
|
89
|
+
"return": verb(2)
|
|
90
|
+
}, typeof Symbol === "function" && (g[Symbol.iterator] = function() {
|
|
91
|
+
return this;
|
|
92
|
+
}), g;
|
|
93
|
+
function verb(n) {
|
|
94
|
+
return function(v) {
|
|
95
|
+
return step([
|
|
96
|
+
n,
|
|
97
|
+
v
|
|
98
|
+
]);
|
|
99
|
+
};
|
|
100
|
+
}
|
|
101
|
+
function step(op) {
|
|
102
|
+
if (f) throw new TypeError("Generator is already executing.");
|
|
103
|
+
while(_)try {
|
|
104
|
+
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
|
|
105
|
+
if (y = 0, t) op = [
|
|
106
|
+
op[0] & 2,
|
|
107
|
+
t.value
|
|
108
|
+
];
|
|
109
|
+
switch(op[0]){
|
|
110
|
+
case 0:
|
|
111
|
+
case 1:
|
|
112
|
+
t = op;
|
|
113
|
+
break;
|
|
114
|
+
case 4:
|
|
115
|
+
_.label++;
|
|
116
|
+
return {
|
|
117
|
+
value: op[1],
|
|
118
|
+
done: false
|
|
119
|
+
};
|
|
120
|
+
case 5:
|
|
121
|
+
_.label++;
|
|
122
|
+
y = op[1];
|
|
123
|
+
op = [
|
|
124
|
+
0
|
|
125
|
+
];
|
|
126
|
+
continue;
|
|
127
|
+
case 7:
|
|
128
|
+
op = _.ops.pop();
|
|
129
|
+
_.trys.pop();
|
|
130
|
+
continue;
|
|
131
|
+
default:
|
|
132
|
+
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) {
|
|
133
|
+
_ = 0;
|
|
134
|
+
continue;
|
|
135
|
+
}
|
|
136
|
+
if (op[0] === 3 && (!t || op[1] > t[0] && op[1] < t[3])) {
|
|
137
|
+
_.label = op[1];
|
|
138
|
+
break;
|
|
139
|
+
}
|
|
140
|
+
if (op[0] === 6 && _.label < t[1]) {
|
|
141
|
+
_.label = t[1];
|
|
142
|
+
t = op;
|
|
143
|
+
break;
|
|
144
|
+
}
|
|
145
|
+
if (t && _.label < t[2]) {
|
|
146
|
+
_.label = t[2];
|
|
147
|
+
_.ops.push(op);
|
|
148
|
+
break;
|
|
149
|
+
}
|
|
150
|
+
if (t[2]) _.ops.pop();
|
|
151
|
+
_.trys.pop();
|
|
152
|
+
continue;
|
|
153
|
+
}
|
|
154
|
+
op = body.call(thisArg, _);
|
|
155
|
+
} catch (e) {
|
|
156
|
+
op = [
|
|
157
|
+
6,
|
|
158
|
+
e
|
|
159
|
+
];
|
|
160
|
+
y = 0;
|
|
161
|
+
} finally{
|
|
162
|
+
f = t = 0;
|
|
163
|
+
}
|
|
164
|
+
if (op[0] & 5) throw op[1];
|
|
165
|
+
return {
|
|
166
|
+
value: op[0] ? op[1] : void 0,
|
|
167
|
+
done: true
|
|
168
|
+
};
|
|
169
|
+
}
|
|
170
|
+
}
|
|
171
|
+
import React, { useEffect, useRef, useState } from "react";
|
|
172
|
+
import { cleanupTempElement, loadMermaid, renderSvgToContainer } from "./utils";
|
|
173
|
+
/**
|
|
174
|
+
* Mermaid 渲染 Hook
|
|
175
|
+
*/ export var useMermaidRender = function(code, divRef, id, isVisible) {
|
|
176
|
+
var timer = useRef(null);
|
|
177
|
+
var mermaidRef = useRef(null);
|
|
178
|
+
var renderedCodeRef = useRef('');
|
|
179
|
+
var _useState = _sliced_to_array(useState(''), 2), error = _useState[0], setError = _useState[1];
|
|
180
|
+
useEffect(function() {
|
|
181
|
+
if (!isVisible || renderedCodeRef.current === code) {
|
|
182
|
+
return;
|
|
183
|
+
}
|
|
184
|
+
if (timer.current) {
|
|
185
|
+
window.clearTimeout(timer.current);
|
|
186
|
+
}
|
|
187
|
+
if (!code) {
|
|
188
|
+
renderedCodeRef.current = '';
|
|
189
|
+
setError('');
|
|
190
|
+
if (divRef.current) {
|
|
191
|
+
divRef.current.innerHTML = '';
|
|
192
|
+
}
|
|
193
|
+
return;
|
|
194
|
+
}
|
|
195
|
+
var currentCode = code;
|
|
196
|
+
timer.current = window.setTimeout(/*#__PURE__*/ _async_to_generator(function() {
|
|
197
|
+
var _mermaidRef_current, api, _tmp, trimmedCode, svg, err;
|
|
198
|
+
return _ts_generator(this, function(_state) {
|
|
199
|
+
switch(_state.label){
|
|
200
|
+
case 0:
|
|
201
|
+
if (code !== currentCode) {
|
|
202
|
+
timer.current = null;
|
|
203
|
+
return [
|
|
204
|
+
2
|
|
205
|
+
];
|
|
206
|
+
}
|
|
207
|
+
_state.label = 1;
|
|
208
|
+
case 1:
|
|
209
|
+
_state.trys.push([
|
|
210
|
+
1,
|
|
211
|
+
6,
|
|
212
|
+
7,
|
|
213
|
+
8
|
|
214
|
+
]);
|
|
215
|
+
if (!((_mermaidRef_current = mermaidRef.current) !== null && _mermaidRef_current !== void 0)) return [
|
|
216
|
+
3,
|
|
217
|
+
2
|
|
218
|
+
];
|
|
219
|
+
_tmp = _mermaidRef_current;
|
|
220
|
+
return [
|
|
221
|
+
3,
|
|
222
|
+
4
|
|
223
|
+
];
|
|
224
|
+
case 2:
|
|
225
|
+
return [
|
|
226
|
+
4,
|
|
227
|
+
loadMermaid()
|
|
228
|
+
];
|
|
229
|
+
case 3:
|
|
230
|
+
_tmp = _state.sent();
|
|
231
|
+
_state.label = 4;
|
|
232
|
+
case 4:
|
|
233
|
+
api = _tmp;
|
|
234
|
+
mermaidRef.current = api;
|
|
235
|
+
trimmedCode = code.trim();
|
|
236
|
+
if (!trimmedCode) {
|
|
237
|
+
renderedCodeRef.current = '';
|
|
238
|
+
setError('');
|
|
239
|
+
if (divRef.current) {
|
|
240
|
+
divRef.current.innerHTML = '';
|
|
241
|
+
}
|
|
242
|
+
timer.current = null;
|
|
243
|
+
return [
|
|
244
|
+
2
|
|
245
|
+
];
|
|
246
|
+
}
|
|
247
|
+
return [
|
|
248
|
+
4,
|
|
249
|
+
api.render(id, trimmedCode)
|
|
250
|
+
];
|
|
251
|
+
case 5:
|
|
252
|
+
svg = _state.sent().svg;
|
|
253
|
+
if (divRef.current) {
|
|
254
|
+
renderSvgToContainer(svg, divRef.current);
|
|
255
|
+
}
|
|
256
|
+
renderedCodeRef.current = code;
|
|
257
|
+
setError('');
|
|
258
|
+
return [
|
|
259
|
+
3,
|
|
260
|
+
8
|
|
261
|
+
];
|
|
262
|
+
case 6:
|
|
263
|
+
err = _state.sent();
|
|
264
|
+
if (code === currentCode) {
|
|
265
|
+
setError(String(err));
|
|
266
|
+
renderedCodeRef.current = '';
|
|
267
|
+
if (divRef.current) {
|
|
268
|
+
divRef.current.innerHTML = '';
|
|
269
|
+
}
|
|
270
|
+
}
|
|
271
|
+
return [
|
|
272
|
+
3,
|
|
273
|
+
8
|
|
274
|
+
];
|
|
275
|
+
case 7:
|
|
276
|
+
cleanupTempElement(id);
|
|
277
|
+
timer.current = null;
|
|
278
|
+
return [
|
|
279
|
+
7
|
|
280
|
+
];
|
|
281
|
+
case 8:
|
|
282
|
+
return [
|
|
283
|
+
2
|
|
284
|
+
];
|
|
285
|
+
}
|
|
286
|
+
});
|
|
287
|
+
}), 500);
|
|
288
|
+
return function() {
|
|
289
|
+
if (timer.current) {
|
|
290
|
+
window.clearTimeout(timer.current);
|
|
291
|
+
timer.current = null;
|
|
292
|
+
}
|
|
293
|
+
};
|
|
294
|
+
}, [
|
|
295
|
+
code,
|
|
296
|
+
id,
|
|
297
|
+
isVisible
|
|
298
|
+
]);
|
|
299
|
+
return {
|
|
300
|
+
error: error,
|
|
301
|
+
renderedCode: renderedCodeRef.current
|
|
302
|
+
};
|
|
303
|
+
};
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import type { MermaidApi } from './types';
|
|
2
|
+
/**
|
|
3
|
+
* 加载 Mermaid 库
|
|
4
|
+
* 使用单例模式确保只加载一次,并初始化配置
|
|
5
|
+
*/
|
|
6
|
+
export declare const loadMermaid: () => Promise<MermaidApi>;
|
|
7
|
+
/**
|
|
8
|
+
* 渲染 SVG 到容器
|
|
9
|
+
*/
|
|
10
|
+
export declare const renderSvgToContainer: (svg: string, container: HTMLDivElement) => void;
|
|
11
|
+
/**
|
|
12
|
+
* 清理 Mermaid 生成的临时元素
|
|
13
|
+
*/
|
|
14
|
+
export declare const cleanupTempElement: (id: string) => void;
|