@flatbiz/antd 5.2.6 → 5.2.8
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/content-CXmBn9B0.js +297 -0
- package/dist/content-CXmBn9B0.js.map +1 -0
- package/dist/content-DnpCk2LR.js +556 -0
- package/dist/content-DnpCk2LR.js.map +1 -0
- package/dist/{drag-DUY7Olcc.js → drag-D3i6_WRS.js} +2 -2
- package/dist/{drag-DUY7Olcc.js.map → drag-D3i6_WRS.js.map} +1 -1
- package/dist/drag-editable-table/index.css +1 -1
- package/dist/drag-editable-table/index.d.ts +3 -0
- package/dist/drag-editable-table/index.js +3 -4
- package/dist/editable-table/index.css +1 -1
- package/dist/editable-table/index.d.ts +3 -0
- package/dist/editable-table/index.js +2 -3
- package/dist/{editable-table-DYR12TJM.js → editable-table-BaKnBuHT.js} +2 -2
- package/dist/{editable-table-DYR12TJM.js.map → editable-table-BaKnBuHT.js.map} +1 -1
- package/dist/index.d.ts +46 -3
- package/dist/index.js +7 -4
- package/dist/index.js.map +1 -1
- package/dist/markdown-editor/index.css +1 -0
- package/dist/markdown-editor/index.d.ts +7 -2
- package/dist/markdown-editor/index.js +53 -2
- package/dist/markdown-editor/index.js.map +1 -1
- package/dist/pre-defined-class-name/index.css +1 -1
- package/dist/upload-multi-type/index.css +1 -0
- package/dist/upload-multi-type/index.d.ts +37 -0
- package/dist/upload-multi-type/index.js +44 -0
- package/dist/upload-multi-type/index.js.map +1 -0
- package/dist/upload-wrapper/index.css +1 -1
- package/dist/upload-wrapper/index.d.ts +4 -1
- package/dist/upload-wrapper/index.js +1 -2
- package/dist/{upload-wrapper-BovR_RV6.js → upload-wrapper-DmZglNR4.js} +29 -13
- package/dist/upload-wrapper-DmZglNR4.js.map +1 -0
- package/package.json +5 -1
- package/dist/content-DQTZHavT.js +0 -404
- package/dist/content-DQTZHavT.js.map +0 -1
- package/dist/upload-wrapper-BovR_RV6.js.map +0 -1
package/dist/content-DQTZHavT.js
DELETED
|
@@ -1,404 +0,0 @@
|
|
|
1
|
-
/*! @flatjs/forge MIT @flatbiz/antd */
|
|
2
|
-
|
|
3
|
-
import { _ as _objectWithoutProperties, a as _slicedToArray, b as _objectSpread2 } from './_rollupPluginBabelHelpers-BspM60Sw.js';
|
|
4
|
-
import _CloseCircleFilled from '@ant-design/icons/es/icons/CloseCircleFilled.js';
|
|
5
|
-
import { useState, useEffect, useRef, useMemo } from 'react';
|
|
6
|
-
import { Button, message, Spin } from 'antd';
|
|
7
|
-
import { getUuid, openNewWindow, loadScripts, loadStyles } from '@flatbiz/utils';
|
|
8
|
-
import { classNames } from '@dimjs/utils/class-names/class-names';
|
|
9
|
-
import { useSize } from 'ahooks';
|
|
10
|
-
import { getCodeString } from 'rehype-rewrite';
|
|
11
|
-
import { jsxs, jsx } from 'react/jsx-runtime';
|
|
12
|
-
|
|
13
|
-
var _excluded = ["value", "onChange", "onUploadImage", "readonly", "darkMode", "className", "style", "readonlyHeightAuto", "height"],
|
|
14
|
-
_excluded2 = ["children", "className"];
|
|
15
|
-
// import MDEditor from '@uiw/react-md-editor';
|
|
16
|
-
|
|
17
|
-
var ReactMdEditor = function ReactMdEditor(props) {
|
|
18
|
-
var value = props.value,
|
|
19
|
-
onChange = props.onChange,
|
|
20
|
-
onUploadImage = props.onUploadImage,
|
|
21
|
-
readonly = props.readonly,
|
|
22
|
-
darkMode = props.darkMode,
|
|
23
|
-
className = props.className,
|
|
24
|
-
style = props.style,
|
|
25
|
-
readonlyHeightAuto = props.readonlyHeightAuto,
|
|
26
|
-
height = props.height,
|
|
27
|
-
restProps = _objectWithoutProperties(props, _excluded);
|
|
28
|
-
var _useState = useState(value),
|
|
29
|
-
_useState2 = _slicedToArray(_useState, 2),
|
|
30
|
-
innerValue = _useState2[0],
|
|
31
|
-
setInnerValue = _useState2[1];
|
|
32
|
-
var readonlyHeightAutoFt = readonlyHeightAuto !== null && readonlyHeightAuto !== void 0 ? readonlyHeightAuto : true;
|
|
33
|
-
useEffect(function () {
|
|
34
|
-
setInnerValue(props.value);
|
|
35
|
-
}, [props.value]);
|
|
36
|
-
|
|
37
|
-
// 编辑器实例引用(用于操作内容)
|
|
38
|
-
var editorRef = useRef(null);
|
|
39
|
-
// 隐藏的文件选择器ref
|
|
40
|
-
var fileInputRef = useRef(null);
|
|
41
|
-
|
|
42
|
-
// 触发文件选择框
|
|
43
|
-
var handleImageClick = function handleImageClick() {
|
|
44
|
-
var _fileInputRef$current;
|
|
45
|
-
(_fileInputRef$current = fileInputRef.current) === null || _fileInputRef$current === void 0 || _fileInputRef$current.click();
|
|
46
|
-
};
|
|
47
|
-
var onInnerChange = function onInnerChange(value) {
|
|
48
|
-
setInnerValue(value);
|
|
49
|
-
onChange === null || onChange === void 0 || onChange(value);
|
|
50
|
-
};
|
|
51
|
-
|
|
52
|
-
// 处理图片选择(核心:读取图片并插入)
|
|
53
|
-
var handleFileChange = function handleFileChange(e) {
|
|
54
|
-
return new Promise(function ($return, $error) {
|
|
55
|
-
var _e$target$files, file, imageUrl, imageMarkdown, _editorRef$current, textarea, cursorPosition, newContent;
|
|
56
|
-
file = (_e$target$files = e.target.files) === null || _e$target$files === void 0 ? void 0 : _e$target$files[0];
|
|
57
|
-
if (!file) return $return();
|
|
58
|
-
|
|
59
|
-
// 只允许图片类型
|
|
60
|
-
if (!file.type.startsWith('image/')) {
|
|
61
|
-
alert('请选择图片文件(jpg/png/gif等)');
|
|
62
|
-
return $return();
|
|
63
|
-
}
|
|
64
|
-
var $Try_1_Post = function () {
|
|
65
|
-
try {
|
|
66
|
-
return $return();
|
|
67
|
-
} catch ($boundEx) {
|
|
68
|
-
return $error($boundEx);
|
|
69
|
-
}
|
|
70
|
-
};
|
|
71
|
-
var $Try_1_Catch = function (error) {
|
|
72
|
-
try {
|
|
73
|
-
message.error((error === null || error === void 0 ? void 0 : error['']) || '图片上传失败');
|
|
74
|
-
return $Try_1_Post();
|
|
75
|
-
} catch ($boundEx) {
|
|
76
|
-
return $error($boundEx);
|
|
77
|
-
}
|
|
78
|
-
};
|
|
79
|
-
try {
|
|
80
|
-
return Promise.resolve(onUploadImage === null || onUploadImage === void 0 ? void 0 : onUploadImage(file)).then(function ($await_5) {
|
|
81
|
-
try {
|
|
82
|
-
imageUrl = $await_5;
|
|
83
|
-
imageMarkdown = "\n\n");
|
|
84
|
-
// 将图片Markdown插入到编辑器光标位置
|
|
85
|
-
if (editorRef.current) {
|
|
86
|
-
textarea = (_editorRef$current = editorRef.current) === null || _editorRef$current === void 0 ? void 0 : _editorRef$current['textarea'];
|
|
87
|
-
cursorPosition = textarea.selectionStart;
|
|
88
|
-
newContent = (innerValue === null || innerValue === void 0 ? void 0 : innerValue.slice(0, cursorPosition)) + imageMarkdown + (innerValue === null || innerValue === void 0 ? void 0 : innerValue.slice(cursorPosition));
|
|
89
|
-
onInnerChange(newContent);
|
|
90
|
-
// 清空文件选择框,避免重复选择同一文件无响应
|
|
91
|
-
e.target.value = '';
|
|
92
|
-
}
|
|
93
|
-
return $Try_1_Post();
|
|
94
|
-
} catch ($boundEx) {
|
|
95
|
-
return $Try_1_Catch($boundEx);
|
|
96
|
-
}
|
|
97
|
-
}, $Try_1_Catch);
|
|
98
|
-
} catch (error) {
|
|
99
|
-
$Try_1_Catch(error);
|
|
100
|
-
}
|
|
101
|
-
});
|
|
102
|
-
};
|
|
103
|
-
var Code = function Code(_ref) {
|
|
104
|
-
var _ref$children = _ref.children,
|
|
105
|
-
children = _ref$children === void 0 ? [] : _ref$children,
|
|
106
|
-
className = _ref.className,
|
|
107
|
-
props = _objectWithoutProperties(_ref, _excluded2);
|
|
108
|
-
var demoid = useRef(getUuid());
|
|
109
|
-
var _useState3 = useState(''),
|
|
110
|
-
_useState4 = _slicedToArray(_useState3, 2),
|
|
111
|
-
svgContent = _useState4[0],
|
|
112
|
-
setSvgContent = _useState4[1];
|
|
113
|
-
var renderAbortRef = useRef(false);
|
|
114
|
-
var isMermaid = className && /^language-mermaid/.test(className.toLocaleLowerCase());
|
|
115
|
-
var code = children ? getCodeString(props.node.children) : children[0] || '';
|
|
116
|
-
useEffect(function () {
|
|
117
|
-
if (isMermaid && code) {
|
|
118
|
-
// 标记之前的渲染为已取消
|
|
119
|
-
renderAbortRef.current = true;
|
|
120
|
-
|
|
121
|
-
// 重置取消标志
|
|
122
|
-
renderAbortRef.current = false;
|
|
123
|
-
|
|
124
|
-
// 生成新的唯一 ID
|
|
125
|
-
var currentId = getUuid();
|
|
126
|
-
demoid.current = currentId;
|
|
127
|
-
|
|
128
|
-
// 创建一个临时的隐藏容器用于 Mermaid 渲染
|
|
129
|
-
var tempContainer = document.createElement('div');
|
|
130
|
-
tempContainer.style.position = 'absolute';
|
|
131
|
-
tempContainer.style.visibility = 'hidden';
|
|
132
|
-
tempContainer.style.width = '0';
|
|
133
|
-
tempContainer.style.height = '0';
|
|
134
|
-
tempContainer.style.top = '-9999px';
|
|
135
|
-
tempContainer.style.left = '-9999px';
|
|
136
|
-
tempContainer.id = currentId;
|
|
137
|
-
document.body.appendChild(tempContainer);
|
|
138
|
-
|
|
139
|
-
// 使用 requestAnimationFrame 确保在正确的时机渲染
|
|
140
|
-
var frameId = requestAnimationFrame(function () {
|
|
141
|
-
if (renderAbortRef.current) {
|
|
142
|
-
// 清理临时容器
|
|
143
|
-
try {
|
|
144
|
-
if (tempContainer.parentNode) {
|
|
145
|
-
document.body.removeChild(tempContainer);
|
|
146
|
-
}
|
|
147
|
-
} catch (_unused) {
|
|
148
|
-
// 忽略清理错误
|
|
149
|
-
}
|
|
150
|
-
return;
|
|
151
|
-
}
|
|
152
|
-
var mermaid = window['mermaid'];
|
|
153
|
-
// 在临时容器中渲染
|
|
154
|
-
mermaid.render(currentId, code).then(function (_ref2) {
|
|
155
|
-
var svg = _ref2.svg;
|
|
156
|
-
// 检查是否已被取消
|
|
157
|
-
if (renderAbortRef.current) {
|
|
158
|
-
return;
|
|
159
|
-
}
|
|
160
|
-
|
|
161
|
-
// 使用 React state 更新 SVG 内容,而不是直接操作 DOM
|
|
162
|
-
setSvgContent(svg);
|
|
163
|
-
}).catch(function (error) {
|
|
164
|
-
if (!renderAbortRef.current) {
|
|
165
|
-
console.log('Mermaid render error:', error);
|
|
166
|
-
setSvgContent('');
|
|
167
|
-
}
|
|
168
|
-
}).finally(function () {
|
|
169
|
-
// 清理临时容器
|
|
170
|
-
try {
|
|
171
|
-
if (tempContainer.parentNode) {
|
|
172
|
-
document.body.removeChild(tempContainer);
|
|
173
|
-
}
|
|
174
|
-
} catch (_unused2) {
|
|
175
|
-
// 忽略清理错误
|
|
176
|
-
}
|
|
177
|
-
});
|
|
178
|
-
});
|
|
179
|
-
|
|
180
|
-
// 清理函数:取消正在进行的渲染
|
|
181
|
-
return function () {
|
|
182
|
-
renderAbortRef.current = true;
|
|
183
|
-
cancelAnimationFrame(frameId);
|
|
184
|
-
|
|
185
|
-
// 清理临时容器
|
|
186
|
-
try {
|
|
187
|
-
if (tempContainer.parentNode) {
|
|
188
|
-
document.body.removeChild(tempContainer);
|
|
189
|
-
}
|
|
190
|
-
} catch (_unused3) {
|
|
191
|
-
// 忽略清理错误
|
|
192
|
-
}
|
|
193
|
-
};
|
|
194
|
-
} else {
|
|
195
|
-
setSvgContent('');
|
|
196
|
-
}
|
|
197
|
-
return undefined;
|
|
198
|
-
}, [isMermaid, code]);
|
|
199
|
-
if (isMermaid) {
|
|
200
|
-
return /*#__PURE__*/jsx("code", {
|
|
201
|
-
className: className,
|
|
202
|
-
"data-name": "mermaid",
|
|
203
|
-
dangerouslySetInnerHTML: {
|
|
204
|
-
__html: svgContent
|
|
205
|
-
}
|
|
206
|
-
});
|
|
207
|
-
}
|
|
208
|
-
return /*#__PURE__*/jsx("code", {
|
|
209
|
-
className: className,
|
|
210
|
-
children: children
|
|
211
|
-
});
|
|
212
|
-
};
|
|
213
|
-
var imageUploadCommand = {
|
|
214
|
-
name: 'imageUpload',
|
|
215
|
-
keyCommand: 'imageUpload',
|
|
216
|
-
render: function render() {
|
|
217
|
-
return /*#__PURE__*/jsx(Button, {
|
|
218
|
-
type: "default",
|
|
219
|
-
size: "small",
|
|
220
|
-
style: {
|
|
221
|
-
fontSize: 12
|
|
222
|
-
},
|
|
223
|
-
onClick: handleImageClick,
|
|
224
|
-
children: "\u4E0A\u4F20\u56FE\u7247"
|
|
225
|
-
}, "imageUpload");
|
|
226
|
-
}
|
|
227
|
-
};
|
|
228
|
-
// 支持 mermaid 语法
|
|
229
|
-
var mermaidCommand = {
|
|
230
|
-
name: 'mermaid',
|
|
231
|
-
keyCommand: 'mermaid',
|
|
232
|
-
render: function render() {
|
|
233
|
-
return /*#__PURE__*/jsx(Button, {
|
|
234
|
-
type: "default",
|
|
235
|
-
size: "small",
|
|
236
|
-
style: {
|
|
237
|
-
fontSize: 12
|
|
238
|
-
},
|
|
239
|
-
onClick: function onClick() {
|
|
240
|
-
openNewWindow('https://docs.min2k.com/zh/mermaid/syntax/pie.html');
|
|
241
|
-
},
|
|
242
|
-
children: "\u652F\u6301Mermaid\u56FE\u5F62"
|
|
243
|
-
}, "mermaid");
|
|
244
|
-
}
|
|
245
|
-
};
|
|
246
|
-
var MDEditor = window['@uiw/react-md-editor'].default;
|
|
247
|
-
var commands = window['@uiw/react-md-editor'].commands;
|
|
248
|
-
var extraCommands = [];
|
|
249
|
-
if (onUploadImage && !readonly) {
|
|
250
|
-
extraCommands = [imageUploadCommand, commands.divider, mermaidCommand, commands.divider, commands.fullscreen];
|
|
251
|
-
} else {
|
|
252
|
-
extraCommands = [mermaidCommand, commands.divider, commands.fullscreen];
|
|
253
|
-
}
|
|
254
|
-
var preview = readonly ? 'preview' : 'live';
|
|
255
|
-
var dataColorMode = darkMode ? 'dark' : 'light';
|
|
256
|
-
var commandsFt = useMemo(function () {
|
|
257
|
-
if (readonly) return [];
|
|
258
|
-
return undefined;
|
|
259
|
-
}, [readonly]);
|
|
260
|
-
var id = useMemo(function () {
|
|
261
|
-
return getUuid();
|
|
262
|
-
}, []);
|
|
263
|
-
var wmdeMarkdownSize = useSize(function () {
|
|
264
|
-
return document.querySelector("#".concat(id, " .wmde-markdown"));
|
|
265
|
-
});
|
|
266
|
-
var autoHeight = useMemo(function () {
|
|
267
|
-
return readonly && readonlyHeightAutoFt;
|
|
268
|
-
}, [readonly, readonlyHeightAutoFt]);
|
|
269
|
-
var heightFt = useMemo(function () {
|
|
270
|
-
if (autoHeight) {
|
|
271
|
-
var _wmdeMarkdownSize$hei;
|
|
272
|
-
return ((_wmdeMarkdownSize$hei = wmdeMarkdownSize === null || wmdeMarkdownSize === void 0 ? void 0 : wmdeMarkdownSize.height) !== null && _wmdeMarkdownSize$hei !== void 0 ? _wmdeMarkdownSize$hei : 0) + 60;
|
|
273
|
-
}
|
|
274
|
-
return height;
|
|
275
|
-
}, [autoHeight, wmdeMarkdownSize === null || wmdeMarkdownSize === void 0 ? void 0 : wmdeMarkdownSize.height, height]);
|
|
276
|
-
var visibleDragbarFt = useMemo(function () {
|
|
277
|
-
if (autoHeight) return false;
|
|
278
|
-
return restProps.visibleDragbar;
|
|
279
|
-
}, [autoHeight, restProps.visibleDragbar]);
|
|
280
|
-
return /*#__PURE__*/jsxs("div", {
|
|
281
|
-
style: _objectSpread2({
|
|
282
|
-
padding: '2px'
|
|
283
|
-
}, style),
|
|
284
|
-
className: classNames('v-markdown-editor', className),
|
|
285
|
-
id: id,
|
|
286
|
-
children: [/*#__PURE__*/jsx(MDEditor, _objectSpread2(_objectSpread2({
|
|
287
|
-
highlightEnable: true
|
|
288
|
-
}, restProps), {}, {
|
|
289
|
-
height: heightFt,
|
|
290
|
-
ref: editorRef,
|
|
291
|
-
value: innerValue,
|
|
292
|
-
preview: preview,
|
|
293
|
-
onChange: onInnerChange,
|
|
294
|
-
visibleDragbar: visibleDragbarFt,
|
|
295
|
-
"data-color-mode": dataColorMode,
|
|
296
|
-
extraCommands: extraCommands,
|
|
297
|
-
commands: commandsFt,
|
|
298
|
-
previewOptions: {
|
|
299
|
-
components: {
|
|
300
|
-
code: Code
|
|
301
|
-
}
|
|
302
|
-
}
|
|
303
|
-
})), /*#__PURE__*/jsx("input", {
|
|
304
|
-
type: "file",
|
|
305
|
-
ref: fileInputRef,
|
|
306
|
-
accept: "image/*" // 只允许选择图片
|
|
307
|
-
,
|
|
308
|
-
onChange: handleFileChange,
|
|
309
|
-
style: {
|
|
310
|
-
display: 'none'
|
|
311
|
-
}
|
|
312
|
-
})]
|
|
313
|
-
});
|
|
314
|
-
};
|
|
315
|
-
|
|
316
|
-
/**
|
|
317
|
-
* markdown编辑器
|
|
318
|
-
* ```
|
|
319
|
-
* 1. 使用@uiw/react-md-editor组件
|
|
320
|
-
* 2. 动态加载 mermaid.js 和 mdeditor.js 和 mdeditor.css
|
|
321
|
-
* //oss.ly.com/newpay/cdn/react-md-editor/mermaid.11.12.0.min.js
|
|
322
|
-
* //oss.ly.com/newpay/cdn/react-md-editor/4.0.11/mdeditor.min.js
|
|
323
|
-
* //oss.ly.com/newpay/cdn/react-md-editor/4.0.11/mdeditor.min.css
|
|
324
|
-
* ```
|
|
325
|
-
*/
|
|
326
|
-
var MarkdownEditor = function MarkdownEditor(props) {
|
|
327
|
-
var _useState = useState(false),
|
|
328
|
-
_useState2 = _slicedToArray(_useState, 2),
|
|
329
|
-
renderFlag = _useState2[0],
|
|
330
|
-
setRenderFlag = _useState2[1];
|
|
331
|
-
var _useState3 = useState(null),
|
|
332
|
-
_useState4 = _slicedToArray(_useState3, 2),
|
|
333
|
-
errorMsg = _useState4[0],
|
|
334
|
-
setErrorMsg = _useState4[1];
|
|
335
|
-
useEffect(function () {
|
|
336
|
-
Promise.all([loadScripts({
|
|
337
|
-
scriptUrls: ['//oss.ly.com/newpay/cdn/react-md-editor/mermaid.11.12.0.min.js', '//oss.ly.com/newpay/cdn/react-md-editor/4.0.11/mdeditor.min.js'],
|
|
338
|
-
checkFn: function checkFn() {
|
|
339
|
-
var isLoaded = window['@uiw/react-md-editor'] && window['mermaid'];
|
|
340
|
-
return isLoaded;
|
|
341
|
-
},
|
|
342
|
-
intervalMs: 20
|
|
343
|
-
}), loadStyles({
|
|
344
|
-
styleUrls: ['//oss.ly.com/newpay/cdn/react-md-editor/4.0.11/mdeditor.min.css']
|
|
345
|
-
})]).then(function () {
|
|
346
|
-
setRenderFlag(true);
|
|
347
|
-
}).catch(function (error) {
|
|
348
|
-
console.error(error);
|
|
349
|
-
setRenderFlag(true);
|
|
350
|
-
setErrorMsg((error === null || error === void 0 ? void 0 : error.message) || 'Markdown编辑器加载失败');
|
|
351
|
-
});
|
|
352
|
-
}, []);
|
|
353
|
-
if (!renderFlag) {
|
|
354
|
-
return /*#__PURE__*/jsx(Spin, {
|
|
355
|
-
tip: /*#__PURE__*/jsx("div", {
|
|
356
|
-
style: {
|
|
357
|
-
marginTop: 10
|
|
358
|
-
},
|
|
359
|
-
children: "Markdown\u7F16\u8F91\u5668\u52A0\u8F7D\u4E2D"
|
|
360
|
-
}),
|
|
361
|
-
size: "large",
|
|
362
|
-
children: /*#__PURE__*/jsx("div", {
|
|
363
|
-
style: {
|
|
364
|
-
padding: 50,
|
|
365
|
-
background: 'rgba(0, 0, 0, 0.05)',
|
|
366
|
-
borderRadius: 4
|
|
367
|
-
}
|
|
368
|
-
})
|
|
369
|
-
});
|
|
370
|
-
}
|
|
371
|
-
if (errorMsg) {
|
|
372
|
-
return /*#__PURE__*/jsxs("div", {
|
|
373
|
-
style: {
|
|
374
|
-
textAlign: 'center',
|
|
375
|
-
padding: 20,
|
|
376
|
-
background: '#fff'
|
|
377
|
-
},
|
|
378
|
-
children: [/*#__PURE__*/jsx(_CloseCircleFilled, {
|
|
379
|
-
style: {
|
|
380
|
-
color: '#f00',
|
|
381
|
-
fontSize: 30
|
|
382
|
-
}
|
|
383
|
-
}), /*#__PURE__*/jsx("div", {
|
|
384
|
-
style: {
|
|
385
|
-
color: '#f00',
|
|
386
|
-
marginTop: 10,
|
|
387
|
-
fontSize: 16
|
|
388
|
-
},
|
|
389
|
-
children: "Markdown\u7F16\u8F91\u5668\u52A0\u8F7D\u5931\u8D25"
|
|
390
|
-
}), /*#__PURE__*/jsx("div", {
|
|
391
|
-
style: {
|
|
392
|
-
color: '#898989',
|
|
393
|
-
marginTop: 5,
|
|
394
|
-
fontSize: 12
|
|
395
|
-
},
|
|
396
|
-
children: errorMsg
|
|
397
|
-
})]
|
|
398
|
-
});
|
|
399
|
-
}
|
|
400
|
-
return /*#__PURE__*/jsx(ReactMdEditor, _objectSpread2({}, props));
|
|
401
|
-
};
|
|
402
|
-
|
|
403
|
-
export { MarkdownEditor as M };
|
|
404
|
-
//# sourceMappingURL=content-DQTZHavT.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"content-DQTZHavT.js","sources":["@flatbiz/antd/src/markdown-editor/editor.tsx","@flatbiz/antd/src/markdown-editor/content.tsx"],"sourcesContent":["import { useEffect, useMemo, useRef, useState } from 'react';\nimport { useSize } from 'ahooks';\nimport { Button, message } from 'antd';\nimport { getCodeString } from 'rehype-rewrite';\nimport { classNames } from '@dimjs/utils';\nimport { getUuid, openNewWindow } from '@flatbiz/utils';\nimport type { MarkdownEditorProps } from './type.js';\n// import MDEditor from '@uiw/react-md-editor';\n\nexport const ReactMdEditor = (props: MarkdownEditorProps) => {\n const {\n value,\n onChange,\n onUploadImage,\n readonly,\n darkMode,\n className,\n style,\n readonlyHeightAuto,\n height,\n ...restProps\n } = props;\n const [innerValue, setInnerValue] = useState<string | undefined>(value);\n\n const readonlyHeightAutoFt = readonlyHeightAuto ?? true;\n\n useEffect(() => {\n setInnerValue(props.value);\n }, [props.value]);\n\n // 编辑器实例引用(用于操作内容)\n const editorRef = useRef(null);\n // 隐藏的文件选择器ref\n const fileInputRef = useRef<HTMLInputElement>(null);\n\n // 触发文件选择框\n const handleImageClick = () => {\n fileInputRef.current?.click();\n };\n\n const onInnerChange = (value?: string) => {\n setInnerValue(value);\n onChange?.(value);\n };\n\n // 处理图片选择(核心:读取图片并插入)\n const handleFileChange = async (e) => {\n const file = e.target.files?.[0];\n if (!file) return;\n\n // 只允许图片类型\n if (!file.type.startsWith('image/')) {\n alert('请选择图片文件(jpg/png/gif等)');\n return;\n }\n try {\n const imageUrl = await onUploadImage?.(file);\n const imageMarkdown = `\\n\\n`;\n // 将图片Markdown插入到编辑器光标位置\n if (editorRef.current) {\n const textarea = editorRef.current?.['textarea'] as HTMLTextAreaElement;\n const cursorPosition = textarea.selectionStart;\n const newContent =\n innerValue?.slice(0, cursorPosition) +\n imageMarkdown +\n innerValue?.slice(cursorPosition);\n onInnerChange(newContent);\n // 清空文件选择框,避免重复选择同一文件无响应\n e.target.value = '';\n }\n } catch (error) {\n message.error(error?.[''] || '图片上传失败');\n }\n };\n\n const Code = ({ children = [], className, ...props }: any) => {\n const demoid = useRef(getUuid());\n const [svgContent, setSvgContent] = useState<string>('');\n const renderAbortRef = useRef<boolean>(false);\n const isMermaid =\n className && /^language-mermaid/.test(className.toLocaleLowerCase());\n const code = children\n ? getCodeString(props.node.children)\n : children[0] || '';\n\n useEffect(() => {\n if (isMermaid && code) {\n // 标记之前的渲染为已取消\n renderAbortRef.current = true;\n\n // 重置取消标志\n renderAbortRef.current = false;\n\n // 生成新的唯一 ID\n const currentId = getUuid();\n demoid.current = currentId;\n\n // 创建一个临时的隐藏容器用于 Mermaid 渲染\n const tempContainer = document.createElement('div');\n tempContainer.style.position = 'absolute';\n tempContainer.style.visibility = 'hidden';\n tempContainer.style.width = '0';\n tempContainer.style.height = '0';\n tempContainer.style.top = '-9999px';\n tempContainer.style.left = '-9999px';\n tempContainer.id = currentId;\n document.body.appendChild(tempContainer);\n\n // 使用 requestAnimationFrame 确保在正确的时机渲染\n const frameId = requestAnimationFrame(() => {\n if (renderAbortRef.current) {\n // 清理临时容器\n try {\n if (tempContainer.parentNode) {\n document.body.removeChild(tempContainer);\n }\n } catch {\n // 忽略清理错误\n }\n return;\n }\n const mermaid = window['mermaid'];\n // 在临时容器中渲染\n mermaid\n .render(currentId, code)\n .then(({ svg }) => {\n // 检查是否已被取消\n if (renderAbortRef.current) {\n return;\n }\n\n // 使用 React state 更新 SVG 内容,而不是直接操作 DOM\n setSvgContent(svg);\n })\n .catch((error) => {\n if (!renderAbortRef.current) {\n console.log('Mermaid render error:', error);\n setSvgContent('');\n }\n })\n .finally(() => {\n // 清理临时容器\n try {\n if (tempContainer.parentNode) {\n document.body.removeChild(tempContainer);\n }\n } catch {\n // 忽略清理错误\n }\n });\n });\n\n // 清理函数:取消正在进行的渲染\n return () => {\n renderAbortRef.current = true;\n cancelAnimationFrame(frameId);\n\n // 清理临时容器\n try {\n if (tempContainer.parentNode) {\n document.body.removeChild(tempContainer);\n }\n } catch {\n // 忽略清理错误\n }\n };\n } else {\n setSvgContent('');\n }\n\n return undefined;\n }, [isMermaid, code]);\n\n if (isMermaid) {\n return (\n <code\n className={className}\n data-name=\"mermaid\"\n dangerouslySetInnerHTML={{ __html: svgContent }}\n />\n );\n }\n return <code className={className}>{children}</code>;\n };\n\n const imageUploadCommand = {\n name: 'imageUpload',\n keyCommand: 'imageUpload',\n render: () => {\n return (\n <Button\n key=\"imageUpload\"\n type=\"default\"\n size=\"small\"\n style={{ fontSize: 12 }}\n onClick={handleImageClick}\n >\n 上传图片\n </Button>\n );\n },\n };\n // 支持 mermaid 语法\n const mermaidCommand = {\n name: 'mermaid',\n keyCommand: 'mermaid',\n render: () => {\n return (\n <Button\n type=\"default\"\n key=\"mermaid\"\n size=\"small\"\n style={{ fontSize: 12 }}\n onClick={() => {\n openNewWindow('https://docs.min2k.com/zh/mermaid/syntax/pie.html');\n }}\n >\n 支持Mermaid图形\n </Button>\n );\n },\n };\n\n const MDEditor = window['@uiw/react-md-editor'].default;\n const commands = window['@uiw/react-md-editor'].commands;\n\n let extraCommands: any[] = [];\n\n if (onUploadImage && !readonly) {\n extraCommands = [\n imageUploadCommand,\n commands.divider,\n mermaidCommand,\n commands.divider,\n commands.fullscreen,\n ];\n } else {\n extraCommands = [mermaidCommand, commands.divider, commands.fullscreen];\n }\n\n const preview = readonly ? 'preview' : 'live';\n\n const dataColorMode = darkMode ? 'dark' : 'light';\n\n const commandsFt = useMemo(() => {\n if (readonly) return [];\n return undefined;\n }, [readonly]);\n\n const id = useMemo(() => {\n return getUuid();\n }, []);\n\n const wmdeMarkdownSize = useSize(() =>\n document.querySelector(`#${id} .wmde-markdown`)\n );\n\n const autoHeight = useMemo(() => {\n return readonly && readonlyHeightAutoFt;\n }, [readonly, readonlyHeightAutoFt]);\n\n const heightFt = useMemo(() => {\n if (autoHeight) {\n return (wmdeMarkdownSize?.height ?? 0) + 60;\n }\n return height;\n }, [autoHeight, wmdeMarkdownSize?.height, height]);\n\n const visibleDragbarFt = useMemo(() => {\n if (autoHeight) return false;\n return restProps.visibleDragbar;\n }, [autoHeight, restProps.visibleDragbar]);\n return (\n <div\n style={{ padding: '2px', ...style }}\n className={classNames('v-markdown-editor', className)}\n id={id}\n >\n <MDEditor\n highlightEnable={true}\n {...restProps}\n height={heightFt}\n ref={editorRef}\n value={innerValue}\n preview={preview}\n onChange={onInnerChange}\n visibleDragbar={visibleDragbarFt}\n data-color-mode={dataColorMode}\n extraCommands={extraCommands}\n commands={commandsFt}\n previewOptions={{\n components: {\n code: Code,\n },\n }}\n />\n {/* 隐藏的文件选择输入框 */}\n <input\n type=\"file\"\n ref={fileInputRef}\n accept=\"image/*\" // 只允许选择图片\n onChange={handleFileChange}\n style={{ display: 'none' }}\n />\n </div>\n );\n};\n","import { useEffect, useState } from 'react';\nimport { Spin } from 'antd';\nimport { CloseCircleFilled } from '@ant-design/icons';\nimport { loadScripts, loadStyles } from '@flatbiz/utils';\nimport { ReactMdEditor } from './editor.jsx';\nimport type { MarkdownEditorProps } from './type.js';\n\n/**\n * markdown编辑器\n * ```\n * 1. 使用@uiw/react-md-editor组件\n * 2. 动态加载 mermaid.js 和 mdeditor.js 和 mdeditor.css\n * //oss.ly.com/newpay/cdn/react-md-editor/mermaid.11.12.0.min.js\n * //oss.ly.com/newpay/cdn/react-md-editor/4.0.11/mdeditor.min.js\n * //oss.ly.com/newpay/cdn/react-md-editor/4.0.11/mdeditor.min.css\n * ```\n */\nexport const MarkdownEditor = (props: MarkdownEditorProps) => {\n const [renderFlag, setRenderFlag] = useState(false);\n const [errorMsg, setErrorMsg] = useState<string | null>(null);\n\n useEffect(() => {\n Promise.all([\n loadScripts({\n scriptUrls: [\n '//oss.ly.com/newpay/cdn/react-md-editor/mermaid.11.12.0.min.js',\n '//oss.ly.com/newpay/cdn/react-md-editor/4.0.11/mdeditor.min.js',\n ],\n checkFn: () => {\n const isLoaded = window['@uiw/react-md-editor'] && window['mermaid'];\n return isLoaded;\n },\n intervalMs: 20,\n }),\n loadStyles({\n styleUrls: [\n '//oss.ly.com/newpay/cdn/react-md-editor/4.0.11/mdeditor.min.css',\n ],\n }),\n ])\n .then(() => {\n setRenderFlag(true);\n })\n .catch((error) => {\n console.error(error);\n setRenderFlag(true);\n setErrorMsg(error?.message || 'Markdown编辑器加载失败');\n });\n }, []);\n\n if (!renderFlag) {\n return (\n <Spin\n tip={<div style={{ marginTop: 10 }}>Markdown编辑器加载中</div>}\n size=\"large\"\n >\n <div\n style={{\n padding: 50,\n background: 'rgba(0, 0, 0, 0.05)',\n borderRadius: 4,\n }}\n />\n </Spin>\n );\n }\n\n if (errorMsg) {\n return (\n <div style={{ textAlign: 'center', padding: 20, background: '#fff' }}>\n <CloseCircleFilled style={{ color: '#f00', fontSize: 30 }} />\n <div style={{ color: '#f00', marginTop: 10, fontSize: 16 }}>\n Markdown编辑器加载失败\n </div>\n <div style={{ color: '#898989', marginTop: 5, fontSize: 12 }}>\n {errorMsg}\n </div>\n </div>\n );\n }\n\n return <ReactMdEditor {...props} />;\n};\n"],"names":["ReactMdEditor","props","value","onChange","onUploadImage","readonly","darkMode","className","style","readonlyHeightAuto","height","restProps","_objectWithoutProperties","_excluded","_useState","useState","_useState2","_slicedToArray","innerValue","setInnerValue","readonlyHeightAutoFt","useEffect","editorRef","useRef","fileInputRef","handleImageClick","_fileInputRef$current","current","click","onInnerChange","handleFileChange","e","Promise","$return","$error","_e$target$files","file","imageUrl","imageMarkdown","_editorRef$current","textarea","cursorPosition","newContent","target","files","type","startsWith","alert","$Try_1_Post","$boundEx","$Try_1_Catch","error","message","resolve","then","$await_5","concat","selectionStart","slice","Code","_ref","_ref$children","children","_excluded2","demoid","getUuid","_useState3","_useState4","svgContent","setSvgContent","renderAbortRef","isMermaid","test","toLocaleLowerCase","code","getCodeString","node","currentId","tempContainer","document","createElement","position","visibility","width","top","left","id","body","appendChild","frameId","requestAnimationFrame","parentNode","removeChild","_unused","mermaid","window","render","_ref2","svg","catch","console","log","finally","_unused2","cancelAnimationFrame","_unused3","undefined","_jsx","dangerouslySetInnerHTML","__html","imageUploadCommand","name","keyCommand","Button","size","fontSize","onClick","mermaidCommand","openNewWindow","MDEditor","default","commands","extraCommands","divider","fullscreen","preview","dataColorMode","commandsFt","useMemo","wmdeMarkdownSize","useSize","querySelector","autoHeight","heightFt","_wmdeMarkdownSize$hei","visibleDragbarFt","visibleDragbar","_jsxs","_objectSpread","padding","_classNames","highlightEnable","ref","previewOptions","components","accept","display","MarkdownEditor","renderFlag","setRenderFlag","errorMsg","setErrorMsg","all","loadScripts","scriptUrls","checkFn","isLoaded","intervalMs","loadStyles","styleUrls","Spin","tip","marginTop","background","borderRadius","textAlign","_CloseCircleFilled","color"],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"upload-wrapper-BovR_RV6.js","sources":["@flatbiz/antd/src/upload-wrapper/utils.ts","@flatbiz/antd/src/upload-wrapper/upload-wrapper.tsx"],"sourcesContent":["export const getBase64 = (file): Promise<string> =>\n new Promise((resolve, reject) => {\n const reader = new FileReader();\n reader.readAsDataURL(file);\n reader.onload = () => resolve(reader.result as string);\n reader.onerror = (error) => reject(error);\n });\n","import type { ReactElement, ReactNode } from 'react';\nimport { cloneElement, Fragment, useMemo, useState } from 'react';\nimport { flushSync } from 'react-dom';\nimport { useMemoizedFn } from 'ahooks';\nimport type { UploadFile, UploadProps } from 'antd';\nimport { Button, Image, message, Upload } from 'antd';\nimport type { UploadChangeParam } from 'antd/lib/upload/index.js';\nimport type { UploadListType } from 'antd/lib/upload/interface.js';\nimport { PlusOutlined } from '@ant-design/icons';\nimport { isPlainObject } from '@dimjs/lang';\nimport { classNames, extend } from '@dimjs/utils';\nimport type { TAny, TPlainObject } from '@flatbiz/utils';\nimport { isUndefinedOrNull, openNewWindow, toArray } from '@flatbiz/utils';\nimport { ButtonWrapper } from '../button-wrapper/index.js';\nimport { fbaHooks } from '../fba-hooks/index.js';\nimport { getBase64 } from './utils.js';\nimport './style.less';\n\nexport type UploadWrapperFileItem = {\n uid: string;\n name: string;\n url?: string;\n};\n\nexport type UploadWrapperProps<T extends TPlainObject = TPlainObject> = {\n value?: T[] | T;\n onChange?: (value?: T[]) => void;\n onUploadError?: (message?: string) => void;\n onUploadChange?: (info: UploadChangeParam<UploadFile>) => void;\n /**\n * 属性取值映射\n */\n fieldNames?: {\n uid: string;\n name?: string;\n url?: string;\n /** 文件大小 */\n size?: string | number;\n };\n /**\n * 接口响应数据适配器,如果配置了fieldNames,适配器返回值会再进过fieldNames转换\n */\n onRequestResultAdapter?: (respData: TAny) => TPlainObject;\n /** 操作触发显示文本 */\n triggerText?: string;\n /** 超过maxCount 隐藏上传入口 */\n limitHidden?: boolean;\n /**\n * 自动提交,默认:true\n * ```\n * 1. 自定义beforeUpload配置后 autoSubmit 失效\n * ```\n */\n autoSubmit?: boolean;\n /** 图片预览开关, 重写 onPreview 方法后失效 */\n imagePreviewSwitch?: boolean;\n /** 图片预览文件类型,默认:['png', 'jpg', 'jpeg', 'gif', 'heic', 'heif'] */\n imagePreviewAccept?: string[];\n /**\n * 配置文件额外操作\n * ```\n * 额外操作超过两项后,listType为 picture-card、picture-circle 时会出现显示异常,需要自行修改覆盖样式\n * ```\n */\n extraOperate?: {\n icon: ReactElement;\n onClick: (file: UploadFile, fileList: UploadFile[], e) => void;\n }[];\n} & Omit<UploadProps, 'onChange' | 'fileList'>;\n\n/**\n * 文件上传\n * ```\n * demo: https://fex.qa.tcshuke.com/docs/admin/main/file/upload\n * 1. 可通过配置children替换默认上传触发布局\n * 2. 接口返回结构:\n * formData上传接口返回值\n * {\n * code: '0000',\n * data: {\n * uid: '唯一值,可使用fileKey值'\n * name: '文件名称'\n * url: '预览地址'\n * }\n * }\n * 3. 如果接口返回的不是上面的字段名称,可通过fieldNames配置接口返回字段名称映射\n *\n * 4. 最佳使用方式,与Form结合使用\n * <Form.Item name=\"attachmentList\" label=\"附件\">\n * <UploadWrapper action={uploadUrl} />\n * </Form.Item>\n *\n * 5. 回填数据结构\n * [{\n * uid: '唯一值',\n * name(非必填): 'image.png',\n * url: 'https://zos.alipayobjects.com/rmsportal/jkjgkEfvpUPVyRjUImniVslZfWPnJuuZ.png',\n * }]\n * 1. 其中 uid、name、url 可为其他命名,通过 fieldNames 进行映射即可,\n * 2. 其他需要的字段可在对象中添加 responseData 对象\n * 例如:\n * [{\n * uid: '唯一值',\n * name(非必填): 'image.png',\n * url: 'https://zos.alipayobjects.com/rmsportal/jkjgkEfvpUPVyRjUImniVslZfWPnJuuZ.png',\n * responseData: { 'xx':'xxx' }\n * }]\n * ```\n *\n */\nexport const UploadWrapper = (props: UploadWrapperProps) => {\n const {\n onChange,\n onUploadError,\n value,\n triggerText,\n limitHidden,\n autoSubmit,\n imagePreviewSwitch,\n imagePreviewAccept,\n extraOperate,\n ...otherProps\n } = props;\n const imagePreviewAcceptFt = isUndefinedOrNull(imagePreviewAccept)\n ? ['png', 'jpg', 'jpeg', 'gif', 'heic', 'heif']\n : imagePreviewAccept;\n const [previewImage, setPreviewImage] = useState<string>();\n const [uploadList, setUploadList] = useState<UploadWrapperFileItem[]>();\n const fieldNames = extend(\n {\n uid: 'uid',\n name: 'name',\n url: 'url',\n size: 'size',\n },\n props.fieldNames\n );\n\n const valueList = useMemo(\n () => (isUndefinedOrNull(value) ? undefined : toArray<TPlainObject>(value)),\n [value]\n );\n\n fbaHooks.useEffectCustom(() => {\n const errorList =\n uploadList?.filter((item) => item['status'] === 'error') || [];\n let newList = [] as TAny[];\n valueList?.forEach((item) => {\n // 判断item 为 File类型\n if (item['lastModified']) {\n newList.push(item);\n } else {\n newList.push({\n uid: item[fieldNames.uid],\n name: item[fieldNames.name],\n url: item[fieldNames.url],\n size: item[fieldNames.size],\n responseData: item['responseData'],\n status: 'done',\n isOriginal: true,\n });\n }\n });\n if (errorList.length > 0) {\n const newErrorList = errorList.map((item) => {\n return {\n uid: item.uid,\n name: item.name,\n status: 'error',\n isOriginal: true,\n response: item['response'],\n };\n }) as TAny[];\n newList = newList.concat(newErrorList);\n }\n setUploadList(newList);\n }, [fieldNames.name, fieldNames.uid, fieldNames.url, valueList]);\n\n const handleResponse = (fileList: UploadFile<TAny>[]) => {\n const newFileList: TAny[] = [];\n let hasError = false;\n fileList.forEach((item) => {\n if (item['isOriginal']) {\n if (item['status'] !== 'error') {\n const target: TPlainObject = {\n [fieldNames.uid]: item.uid,\n [fieldNames.name]: item.name,\n [fieldNames.url]: item.url,\n };\n if (!isUndefinedOrNull(item.size)) {\n target[fieldNames.size] = item.size;\n }\n if (item['responseData']) {\n target.responseData = item['responseData'];\n }\n newFileList.push(target);\n }\n } else if (isPlainObject(item.response)) {\n if (item.response.code === '0000') {\n const respData = item.response.data;\n const result = (props.onRequestResultAdapter?.(respData) ||\n respData) as TPlainObject;\n const target: TPlainObject = {\n [fieldNames.uid]: result[fieldNames.uid] || item.uid,\n [fieldNames.name]: result[fieldNames.name] || item.name,\n [fieldNames.url]: result[fieldNames.url],\n };\n if (!isUndefinedOrNull(result[fieldNames.size])) {\n target[fieldNames.size] = result[fieldNames.size];\n }\n newFileList.push({\n ...target,\n responseData: respData,\n });\n } else {\n const errorMsg = item.response.message || '上传失败';\n hasError = true;\n item.status = 'error';\n item.response = item.response.message || '上传失败';\n if (onUploadError) {\n onUploadError?.(errorMsg);\n } else {\n void message.error('上传操作失败...');\n }\n }\n }\n });\n if (hasError) {\n setUploadList([...fileList] as UploadWrapperFileItem[]);\n }\n onChange?.(newFileList);\n };\n\n const onUploadChange = useMemoizedFn((info) => {\n const fileList = info.fileList as TPlainObject[];\n if (info.file.status === 'done') {\n const newFileList = [...info.fileList];\n const donwList = newFileList.filter(\n (item) => item.status === 'done' || item['isOriginal']\n );\n\n const allDone = donwList.length === newFileList.length;\n if (allDone) {\n handleResponse(newFileList);\n }\n flushSync(() => setUploadList(newFileList));\n return;\n } else if (info.file.status === 'removed') {\n const uid = info.file.uid;\n const targetList = valueList !== undefined ? [...valueList] : [];\n const targetIndex = targetList.findIndex((item) => {\n const tempUid = item[fieldNames.uid] || item.uid;\n return tempUid === uid;\n });\n if (targetIndex >= 0) {\n targetList.splice(targetIndex, 1);\n }\n onChange?.(targetList);\n } else if (info.file.status === 'error') {\n if (onUploadError) {\n onUploadError();\n } else {\n void message.error('上传操作失败...');\n }\n }\n // https://github.com/ant-design/ant-design/issues/2423\n setUploadList([...fileList] as UploadWrapperFileItem[]);\n props.onUploadChange?.(info);\n });\n\n const hiddenEmtry = useMemo(() => {\n if (otherProps.maxCount === undefined || !limitHidden) return false;\n if (otherProps.maxCount === 0) return true;\n if (uploadList && uploadList.length >= otherProps.maxCount) return true;\n return false;\n }, [limitHidden, otherProps.maxCount, uploadList]);\n\n const beforeUpload = (_file, fileList) => {\n if (autoSubmit === false) {\n const maxCount = otherProps.maxCount;\n let mergeList = [...(valueList || []), ...fileList];\n let uploadListMerge = [...(uploadList || []), ...fileList];\n if (maxCount !== undefined && maxCount !== null) {\n if (mergeList.length > maxCount) {\n mergeList = mergeList.slice(mergeList.length - maxCount);\n uploadListMerge = uploadListMerge.slice(\n uploadListMerge.length - maxCount\n );\n }\n }\n setUploadList(uploadListMerge);\n props.onChange?.(mergeList);\n return false;\n }\n return true;\n };\n\n const handlePreview = async (file: UploadFile) => {\n const name = (file.name || '') as string;\n const extension = name.slice(name.lastIndexOf('.') + 1);\n const acceptTarget = imagePreviewAcceptFt?.find((item) => {\n return item.toLocaleLowerCase() === extension.toLocaleLowerCase();\n });\n if (acceptTarget) {\n if (!file.url && !file.preview) {\n file.preview = await getBase64(file.originFileObj);\n }\n setPreviewImage(file.url || (file.preview as string));\n } else {\n openNewWindow(file.url as string);\n }\n };\n\n return (\n <Fragment>\n <Upload\n beforeUpload={beforeUpload}\n onPreview={imagePreviewSwitch ? handlePreview : undefined}\n showUploadList\n itemRender={(originNode, file, fileList) => {\n if (!extraOperate || !extraOperate.length) return originNode;\n const countSign = `${otherProps.disabled ? 1 : 2}-${extraOperate.length}`;\n return (\n <div\n className={classNames(\n 'v-upload-list-item-actions-wrapper',\n `v-upload-list-item-extra-actions-${countSign}`\n )}\n style={{ height: '100%' }}\n >\n {cloneElement(originNode, {\n children: [\n originNode.props.children,\n <div\n key=\"extra-actions\"\n className=\"v-upload-list-item-extra-actions\"\n >\n {extraOperate.map((item, index) => {\n return (\n <ButtonWrapper\n key={index}\n size=\"small\"\n type=\"text\"\n icon={item.icon}\n onClick={item.onClick.bind(null, file, fileList)}\n />\n );\n })}\n </div>,\n ].filter(Boolean),\n })}\n </div>\n );\n }}\n {...otherProps}\n onChange={onUploadChange}\n fileList={uploadList}\n className={classNames('v-upload-wrapper', otherProps.className)}\n >\n {otherProps.disabled || hiddenEmtry ? null : (\n <UploadTrigger\n triggerText={triggerText}\n listType={otherProps.listType}\n >\n {props.children}\n </UploadTrigger>\n )}\n </Upload>\n {previewImage ? (\n <Image\n wrapperStyle={{ display: 'none' }}\n preview={{\n visible: !!previewImage,\n onVisibleChange: () => setPreviewImage(undefined),\n afterOpenChange: (visible) => !visible && setPreviewImage(''),\n }}\n src={previewImage}\n />\n ) : null}\n </Fragment>\n );\n};\n\nconst UploadTrigger = (props: {\n listType?: UploadListType;\n children?: ReactNode | ReactNode[];\n triggerText?: string;\n}) => {\n if (props.children) return <Fragment>{props.children}</Fragment>;\n if (props.listType === 'picture-card') {\n return (\n <div>\n <PlusOutlined />\n <div style={{ marginTop: 8 }}>{props.triggerText || '上传图片'}</div>\n </div>\n );\n }\n if (props.listType === 'picture') {\n return (\n <Button type=\"primary\" ghost>\n {props.triggerText || '选择图片上传'}\n </Button>\n );\n }\n return (\n <Button type=\"primary\" ghost>\n {props.triggerText || '选择文件上传'}\n </Button>\n );\n};\n"],"names":["getBase64","file","Promise","resolve","reject","reader","FileReader","readAsDataURL","onload","result","onerror","error","UploadWrapper","props","onChange","onUploadError","value","triggerText","limitHidden","autoSubmit","imagePreviewSwitch","imagePreviewAccept","extraOperate","otherProps","_objectWithoutProperties","_excluded","imagePreviewAcceptFt","isUndefinedOrNull","_useState","useState","_useState2","_slicedToArray","previewImage","setPreviewImage","_useState3","_useState4","uploadList","setUploadList","fieldNames","_extend","uid","name","url","size","valueList","useMemo","undefined","toArray","fbaHooks","useEffectCustom","errorList","filter","item","newList","forEach","push","responseData","status","isOriginal","length","newErrorList","map","response","concat","handleResponse","fileList","newFileList","hasError","target","_defineProperty","_isPlainObject","code","_props$onRequestResul","respData","data","onRequestResultAdapter","call","_objectSpread","errorMsg","message","_toConsumableArray","onUploadChange","useMemoizedFn","info","_props$onUploadChange","donwList","allDone","flushSync","targetList","targetIndex","findIndex","tempUid","splice","hiddenEmtry","maxCount","beforeUpload","_file","_props$onChange","mergeList","uploadListMerge","slice","handlePreview","$return","$error","extension","acceptTarget","lastIndexOf","find","toLocaleLowerCase","preview","originFileObj","then","$await_3","$If_2","$boundEx","bind","$If_1","openNewWindow","_jsxs","Fragment","children","_jsx","Upload","onPreview","showUploadList","itemRender","originNode","countSign","disabled","className","_classNames","style","height","cloneElement","index","ButtonWrapper","type","icon","onClick","Boolean","UploadTrigger","listType","Image","wrapperStyle","display","visible","onVisibleChange","afterOpenChange","src","_PlusOutlined","marginTop","Button","ghost"],"mappings":"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"}
|