@agentscope-ai/design 1.0.29 → 1.0.30-beta.1770629540335
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/lib/components/commonComponents/Empty/svg/Illustrate.d.ts +2 -0
- package/lib/components/commonComponents/Empty/svg/Illustrate.js +116 -134
- package/llms/all.llms.txt +4146 -208
- package/llms/components/commonComponents/HelpIcon/index.zh-CN.llms.txt +6 -0
- package/llms/index.llms.txt +51 -3
- package/package.json +1 -1
|
@@ -1,174 +1,156 @@
|
|
|
1
1
|
function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
|
|
2
2
|
function _regeneratorRuntime() { "use strict"; /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/facebook/regenerator/blob/main/LICENSE */ _regeneratorRuntime = function _regeneratorRuntime() { return e; }; var t, e = {}, r = Object.prototype, n = r.hasOwnProperty, o = Object.defineProperty || function (t, e, r) { t[e] = r.value; }, i = "function" == typeof Symbol ? Symbol : {}, a = i.iterator || "@@iterator", c = i.asyncIterator || "@@asyncIterator", u = i.toStringTag || "@@toStringTag"; function define(t, e, r) { return Object.defineProperty(t, e, { value: r, enumerable: !0, configurable: !0, writable: !0 }), t[e]; } try { define({}, ""); } catch (t) { define = function define(t, e, r) { return t[e] = r; }; } function wrap(t, e, r, n) { var i = e && e.prototype instanceof Generator ? e : Generator, a = Object.create(i.prototype), c = new Context(n || []); return o(a, "_invoke", { value: makeInvokeMethod(t, r, c) }), a; } function tryCatch(t, e, r) { try { return { type: "normal", arg: t.call(e, r) }; } catch (t) { return { type: "throw", arg: t }; } } e.wrap = wrap; var h = "suspendedStart", l = "suspendedYield", f = "executing", s = "completed", y = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} var p = {}; define(p, a, function () { return this; }); var d = Object.getPrototypeOf, v = d && d(d(values([]))); v && v !== r && n.call(v, a) && (p = v); var g = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(p); function defineIteratorMethods(t) { ["next", "throw", "return"].forEach(function (e) { define(t, e, function (t) { return this._invoke(e, t); }); }); } function AsyncIterator(t, e) { function invoke(r, o, i, a) { var c = tryCatch(t[r], t, o); if ("throw" !== c.type) { var u = c.arg, h = u.value; return h && "object" == _typeof(h) && n.call(h, "__await") ? e.resolve(h.__await).then(function (t) { invoke("next", t, i, a); }, function (t) { invoke("throw", t, i, a); }) : e.resolve(h).then(function (t) { u.value = t, i(u); }, function (t) { return invoke("throw", t, i, a); }); } a(c.arg); } var r; o(this, "_invoke", { value: function value(t, n) { function callInvokeWithMethodAndArg() { return new e(function (e, r) { invoke(t, n, e, r); }); } return r = r ? r.then(callInvokeWithMethodAndArg, callInvokeWithMethodAndArg) : callInvokeWithMethodAndArg(); } }); } function makeInvokeMethod(e, r, n) { var o = h; return function (i, a) { if (o === f) throw new Error("Generator is already running"); if (o === s) { if ("throw" === i) throw a; return { value: t, done: !0 }; } for (n.method = i, n.arg = a;;) { var c = n.delegate; if (c) { var u = maybeInvokeDelegate(c, n); if (u) { if (u === y) continue; return u; } } if ("next" === n.method) n.sent = n._sent = n.arg;else if ("throw" === n.method) { if (o === h) throw o = s, n.arg; n.dispatchException(n.arg); } else "return" === n.method && n.abrupt("return", n.arg); o = f; var p = tryCatch(e, r, n); if ("normal" === p.type) { if (o = n.done ? s : l, p.arg === y) continue; return { value: p.arg, done: n.done }; } "throw" === p.type && (o = s, n.method = "throw", n.arg = p.arg); } }; } function maybeInvokeDelegate(e, r) { var n = r.method, o = e.iterator[n]; if (o === t) return r.delegate = null, "throw" === n && e.iterator.return && (r.method = "return", r.arg = t, maybeInvokeDelegate(e, r), "throw" === r.method) || "return" !== n && (r.method = "throw", r.arg = new TypeError("The iterator does not provide a '" + n + "' method")), y; var i = tryCatch(o, e.iterator, r.arg); if ("throw" === i.type) return r.method = "throw", r.arg = i.arg, r.delegate = null, y; var a = i.arg; return a ? a.done ? (r[e.resultName] = a.value, r.next = e.nextLoc, "return" !== r.method && (r.method = "next", r.arg = t), r.delegate = null, y) : a : (r.method = "throw", r.arg = new TypeError("iterator result is not an object"), r.delegate = null, y); } function pushTryEntry(t) { var e = { tryLoc: t[0] }; 1 in t && (e.catchLoc = t[1]), 2 in t && (e.finallyLoc = t[2], e.afterLoc = t[3]), this.tryEntries.push(e); } function resetTryEntry(t) { var e = t.completion || {}; e.type = "normal", delete e.arg, t.completion = e; } function Context(t) { this.tryEntries = [{ tryLoc: "root" }], t.forEach(pushTryEntry, this), this.reset(!0); } function values(e) { if (e || "" === e) { var r = e[a]; if (r) return r.call(e); if ("function" == typeof e.next) return e; if (!isNaN(e.length)) { var o = -1, i = function next() { for (; ++o < e.length;) if (n.call(e, o)) return next.value = e[o], next.done = !1, next; return next.value = t, next.done = !0, next; }; return i.next = i; } } throw new TypeError(_typeof(e) + " is not iterable"); } return GeneratorFunction.prototype = GeneratorFunctionPrototype, o(g, "constructor", { value: GeneratorFunctionPrototype, configurable: !0 }), o(GeneratorFunctionPrototype, "constructor", { value: GeneratorFunction, configurable: !0 }), GeneratorFunction.displayName = define(GeneratorFunctionPrototype, u, "GeneratorFunction"), e.isGeneratorFunction = function (t) { var e = "function" == typeof t && t.constructor; return !!e && (e === GeneratorFunction || "GeneratorFunction" === (e.displayName || e.name)); }, e.mark = function (t) { return Object.setPrototypeOf ? Object.setPrototypeOf(t, GeneratorFunctionPrototype) : (t.__proto__ = GeneratorFunctionPrototype, define(t, u, "GeneratorFunction")), t.prototype = Object.create(g), t; }, e.awrap = function (t) { return { __await: t }; }, defineIteratorMethods(AsyncIterator.prototype), define(AsyncIterator.prototype, c, function () { return this; }), e.AsyncIterator = AsyncIterator, e.async = function (t, r, n, o, i) { void 0 === i && (i = Promise); var a = new AsyncIterator(wrap(t, r, n, o), i); return e.isGeneratorFunction(r) ? a : a.next().then(function (t) { return t.done ? t.value : a.next(); }); }, defineIteratorMethods(g), define(g, u, "Generator"), define(g, a, function () { return this; }), define(g, "toString", function () { return "[object Generator]"; }), e.keys = function (t) { var e = Object(t), r = []; for (var n in e) r.push(n); return r.reverse(), function next() { for (; r.length;) { var t = r.pop(); if (t in e) return next.value = t, next.done = !1, next; } return next.done = !0, next; }; }, e.values = values, Context.prototype = { constructor: Context, reset: function reset(e) { if (this.prev = 0, this.next = 0, this.sent = this._sent = t, this.done = !1, this.delegate = null, this.method = "next", this.arg = t, this.tryEntries.forEach(resetTryEntry), !e) for (var r in this) "t" === r.charAt(0) && n.call(this, r) && !isNaN(+r.slice(1)) && (this[r] = t); }, stop: function stop() { this.done = !0; var t = this.tryEntries[0].completion; if ("throw" === t.type) throw t.arg; return this.rval; }, dispatchException: function dispatchException(e) { if (this.done) throw e; var r = this; function handle(n, o) { return a.type = "throw", a.arg = e, r.next = n, o && (r.method = "next", r.arg = t), !!o; } for (var o = this.tryEntries.length - 1; o >= 0; --o) { var i = this.tryEntries[o], a = i.completion; if ("root" === i.tryLoc) return handle("end"); if (i.tryLoc <= this.prev) { var c = n.call(i, "catchLoc"), u = n.call(i, "finallyLoc"); if (c && u) { if (this.prev < i.catchLoc) return handle(i.catchLoc, !0); if (this.prev < i.finallyLoc) return handle(i.finallyLoc); } else if (c) { if (this.prev < i.catchLoc) return handle(i.catchLoc, !0); } else { if (!u) throw new Error("try statement without catch or finally"); if (this.prev < i.finallyLoc) return handle(i.finallyLoc); } } } }, abrupt: function abrupt(t, e) { for (var r = this.tryEntries.length - 1; r >= 0; --r) { var o = this.tryEntries[r]; if (o.tryLoc <= this.prev && n.call(o, "finallyLoc") && this.prev < o.finallyLoc) { var i = o; break; } } i && ("break" === t || "continue" === t) && i.tryLoc <= e && e <= i.finallyLoc && (i = null); var a = i ? i.completion : {}; return a.type = t, a.arg = e, i ? (this.method = "next", this.next = i.finallyLoc, y) : this.complete(a); }, complete: function complete(t, e) { if ("throw" === t.type) throw t.arg; return "break" === t.type || "continue" === t.type ? this.next = t.arg : "return" === t.type ? (this.rval = this.arg = t.arg, this.method = "return", this.next = "end") : "normal" === t.type && e && (this.next = e), y; }, finish: function finish(t) { for (var e = this.tryEntries.length - 1; e >= 0; --e) { var r = this.tryEntries[e]; if (r.finallyLoc === t) return this.complete(r.completion, r.afterLoc), resetTryEntry(r), y; } }, catch: function _catch(t) { for (var e = this.tryEntries.length - 1; e >= 0; --e) { var r = this.tryEntries[e]; if (r.tryLoc === t) { var n = r.completion; if ("throw" === n.type) { var o = n.arg; resetTryEntry(r); } return o; } } throw new Error("illegal catch attempt"); }, delegateYield: function delegateYield(e, r, n) { return this.delegate = { iterator: values(e), resultName: r, nextLoc: n }, "next" === this.method && (this.arg = t), y; } }, e; }
|
|
3
|
-
function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } }
|
|
4
|
-
function _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err); } _next(undefined); }); }; }
|
|
5
3
|
function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
|
|
6
4
|
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
7
5
|
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
|
8
6
|
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
|
|
9
7
|
function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
|
|
10
8
|
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
|
|
11
|
-
|
|
12
|
-
|
|
9
|
+
function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { Promise.resolve(value).then(_next, _throw); } }
|
|
10
|
+
function _asyncToGenerator(fn) { return function () { var self = this, args = arguments; return new Promise(function (resolve, reject) { var gen = fn.apply(self, args); function _next(value) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value); } function _throw(err) { asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err); } _next(undefined); }); }; }
|
|
11
|
+
import { useEffect, useRef, useState } from 'react';
|
|
13
12
|
import { jsx as _jsx } from "react/jsx-runtime";
|
|
14
|
-
var SVG_NS = 'http://www.w3.org/2000/svg';
|
|
15
|
-
var XLINK_NS = 'http://www.w3.org/1999/xlink';
|
|
16
|
-
|
|
17
|
-
// 避免多实例并发注入时互相覆盖:用任务 Map 去重同一个 svgId 的加载
|
|
18
|
-
var svgSymbolTasks = new Map();
|
|
19
|
-
var svgContainer = null;
|
|
20
|
-
if (typeof document !== 'undefined') {
|
|
21
|
-
svgContainer = document.querySelector('#empty-svg-container');
|
|
22
|
-
}
|
|
23
13
|
function escapeRegExp(str) {
|
|
24
14
|
return str.replace(/[.*+?^${}()|[\]\\]/g, '\\$&');
|
|
25
15
|
}
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
16
|
+
|
|
17
|
+
/** 模块级缓存:svgUrl -> 原始 SVG 文本,避免重复网络请求 */
|
|
18
|
+
var svgRawCache = new Map();
|
|
19
|
+
/** 模块级请求去重:svgUrl -> Promise,避免并发重复请求 */
|
|
20
|
+
var svgFetchTasks = new Map();
|
|
21
|
+
|
|
22
|
+
/**
|
|
23
|
+
* 获取 SVG 原始文本,带缓存和请求去重
|
|
24
|
+
*/
|
|
25
|
+
function fetchSvgText(_x) {
|
|
26
|
+
return _fetchSvgText.apply(this, arguments);
|
|
30
27
|
}
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
28
|
+
/**
|
|
29
|
+
* 将原始 SVG 文本中的颜色替换为 CSS 变量
|
|
30
|
+
*/
|
|
31
|
+
function _fetchSvgText() {
|
|
32
|
+
_fetchSvgText = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee2(url) {
|
|
33
|
+
var cached, existing, task;
|
|
34
|
+
return _regeneratorRuntime().wrap(function _callee2$(_context2) {
|
|
35
|
+
while (1) switch (_context2.prev = _context2.next) {
|
|
36
|
+
case 0:
|
|
37
|
+
cached = svgRawCache.get(url);
|
|
38
|
+
if (!(cached !== undefined)) {
|
|
39
|
+
_context2.next = 3;
|
|
40
|
+
break;
|
|
41
|
+
}
|
|
42
|
+
return _context2.abrupt("return", cached);
|
|
43
|
+
case 3:
|
|
44
|
+
existing = svgFetchTasks.get(url);
|
|
45
|
+
if (!existing) {
|
|
46
|
+
_context2.next = 6;
|
|
47
|
+
break;
|
|
48
|
+
}
|
|
49
|
+
return _context2.abrupt("return", existing);
|
|
50
|
+
case 6:
|
|
51
|
+
task = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee() {
|
|
52
|
+
var res, text;
|
|
53
|
+
return _regeneratorRuntime().wrap(function _callee$(_context) {
|
|
54
|
+
while (1) switch (_context.prev = _context.next) {
|
|
55
|
+
case 0:
|
|
56
|
+
_context.next = 2;
|
|
57
|
+
return fetch(url);
|
|
58
|
+
case 2:
|
|
59
|
+
res = _context.sent;
|
|
60
|
+
if (res.ok) {
|
|
61
|
+
_context.next = 5;
|
|
62
|
+
break;
|
|
63
|
+
}
|
|
64
|
+
throw new Error("HTTP ".concat(res.status));
|
|
65
|
+
case 5:
|
|
66
|
+
_context.next = 7;
|
|
67
|
+
return res.text();
|
|
68
|
+
case 7:
|
|
69
|
+
text = _context.sent;
|
|
70
|
+
svgRawCache.set(url, text);
|
|
71
|
+
return _context.abrupt("return", text);
|
|
72
|
+
case 10:
|
|
73
|
+
case "end":
|
|
74
|
+
return _context.stop();
|
|
75
|
+
}
|
|
76
|
+
}, _callee);
|
|
77
|
+
}))().finally(function () {
|
|
78
|
+
svgFetchTasks.delete(url);
|
|
79
|
+
});
|
|
80
|
+
svgFetchTasks.set(url, task);
|
|
81
|
+
return _context2.abrupt("return", task);
|
|
82
|
+
case 9:
|
|
83
|
+
case "end":
|
|
84
|
+
return _context2.stop();
|
|
85
|
+
}
|
|
86
|
+
}, _callee2);
|
|
87
|
+
}));
|
|
88
|
+
return _fetchSvgText.apply(this, arguments);
|
|
44
89
|
}
|
|
45
|
-
function
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
symbol.id = svgId;
|
|
52
|
-
symbol.setAttribute('data-loaded', 'false');
|
|
53
|
-
svgContainer.appendChild(symbol);
|
|
54
|
-
return symbol;
|
|
90
|
+
function replaceSvgColors(raw, tokenMap) {
|
|
91
|
+
var result = raw;
|
|
92
|
+
Object.keys(tokenMap).forEach(function (key) {
|
|
93
|
+
result = result.replace(new RegExp(escapeRegExp(key), 'g'), tokenMap[key]);
|
|
94
|
+
});
|
|
95
|
+
return result;
|
|
55
96
|
}
|
|
56
97
|
export default function Illustrate(props) {
|
|
57
|
-
var _useToken = useToken(),
|
|
58
|
-
_useToken2 = _slicedToArray(_useToken, 5),
|
|
59
|
-
cssVar = _useToken2[4];
|
|
60
98
|
var svgUrl = props.svgUrl,
|
|
61
99
|
_props$tokenMap = props.tokenMap,
|
|
62
100
|
tokenMap = _props$tokenMap === void 0 ? {} : _props$tokenMap,
|
|
63
101
|
className = props.className,
|
|
64
102
|
size = props.size;
|
|
65
103
|
var isSvg = svgUrl.includes('.svg');
|
|
66
|
-
var _useState = useState(
|
|
104
|
+
var _useState = useState(function () {
|
|
105
|
+
return svgRawCache.get(svgUrl) || '';
|
|
106
|
+
}),
|
|
67
107
|
_useState2 = _slicedToArray(_useState, 2),
|
|
68
|
-
|
|
69
|
-
|
|
108
|
+
rawSvg = _useState2[0],
|
|
109
|
+
setRawSvg = _useState2[1];
|
|
110
|
+
var mountedRef = useRef(true);
|
|
70
111
|
useEffect(function () {
|
|
71
|
-
|
|
112
|
+
mountedRef.current = true;
|
|
113
|
+
return function () {
|
|
114
|
+
mountedRef.current = false;
|
|
115
|
+
};
|
|
72
116
|
}, []);
|
|
73
117
|
useEffect(function () {
|
|
74
|
-
if (
|
|
75
|
-
svgContainer.classList.forEach(function (key) {
|
|
76
|
-
return svgContainer.classList.remove(key);
|
|
77
|
-
});
|
|
78
|
-
svgContainer.classList.add(cssVar.key);
|
|
79
|
-
}
|
|
80
|
-
}, [cssVar === null || cssVar === void 0 ? void 0 : cssVar.key]);
|
|
81
|
-
useEffect(function () {
|
|
82
|
-
if (!isSvg) {
|
|
83
|
-
return;
|
|
84
|
-
}
|
|
85
|
-
ensureSvgContainer();
|
|
86
|
-
if (!svgContainer) return;
|
|
87
|
-
var svgId = toBase64Url(svgUrl);
|
|
88
|
-
setSvgString("<svg width=\"100%\" height=\"100%\"><use href=\"#".concat(svgId, "\" xlink:href=\"#").concat(svgId, "\"></use></svg>"));
|
|
89
|
-
var symbol = ensureSymbol(svgId);
|
|
90
|
-
if (!symbol) return;
|
|
91
|
-
|
|
92
|
-
// 已经加载过,直接复用
|
|
93
|
-
if (symbol.getAttribute('data-loaded') === 'true') return;
|
|
118
|
+
if (!isSvg) return;
|
|
94
119
|
|
|
95
|
-
//
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
while (1) switch (_context.prev = _context.next) {
|
|
101
|
-
case 0:
|
|
102
|
-
_context.prev = 0;
|
|
103
|
-
_context.next = 3;
|
|
104
|
-
return fetch(svgUrl);
|
|
105
|
-
case 3:
|
|
106
|
-
res = _context.sent;
|
|
107
|
-
if (res.ok) {
|
|
108
|
-
_context.next = 6;
|
|
109
|
-
break;
|
|
110
|
-
}
|
|
111
|
-
throw new Error("HTTP ".concat(res.status));
|
|
112
|
-
case 6:
|
|
113
|
-
_context.next = 8;
|
|
114
|
-
return res.text();
|
|
115
|
-
case 8:
|
|
116
|
-
raw = _context.sent;
|
|
117
|
-
str = raw;
|
|
118
|
-
Object.keys(tokenMap).forEach(function (key) {
|
|
119
|
-
str = str.replace(new RegExp(escapeRegExp(key), 'g'), tokenMap[key]);
|
|
120
|
-
});
|
|
121
|
-
|
|
122
|
-
// 提取 viewBox
|
|
123
|
-
viewBoxMatch = str.match(/viewBox="([^"]*)"/);
|
|
124
|
-
viewBox = viewBoxMatch ? viewBoxMatch[1] : ''; // 只保留 <svg> 内部内容
|
|
125
|
-
symbolContentStr = str.replace(/<svg[^>]*>/, '');
|
|
126
|
-
symbolContentStr = symbolContentStr.replace(/<\/svg>/, '');
|
|
127
|
-
if (viewBox) {
|
|
128
|
-
symbol.setAttribute('viewBox', viewBox);
|
|
129
|
-
}
|
|
130
|
-
|
|
131
|
-
// 使用 DOM API 写入,避免 innerHTML 触发 svgContainer 重建
|
|
132
|
-
symbol.innerHTML = symbolContentStr;
|
|
133
|
-
symbol.setAttribute('data-loaded', 'true');
|
|
134
|
-
symbol.removeAttribute('data-error');
|
|
135
|
-
_context.next = 27;
|
|
136
|
-
break;
|
|
137
|
-
case 21:
|
|
138
|
-
_context.prev = 21;
|
|
139
|
-
_context.t0 = _context["catch"](0);
|
|
140
|
-
// 失败时保证不会进入“空壳已存在但永远不再加载”的状态
|
|
141
|
-
symbol.setAttribute('data-loaded', 'false');
|
|
142
|
-
symbol.setAttribute('data-error', 'true');
|
|
143
|
-
symbol.innerHTML = '';
|
|
144
|
-
// eslint-disable-next-line no-console
|
|
145
|
-
console.warn('[SparkDesign][Empty][Illustrate] load svg failed:', svgUrl, _context.t0);
|
|
146
|
-
case 27:
|
|
147
|
-
case "end":
|
|
148
|
-
return _context.stop();
|
|
149
|
-
}
|
|
150
|
-
}, _callee, null, [[0, 21]]);
|
|
151
|
-
}))().finally(function () {
|
|
152
|
-
svgSymbolTasks.delete(svgId);
|
|
153
|
-
});
|
|
154
|
-
svgSymbolTasks.set(svgId, task);
|
|
120
|
+
// 如果缓存中已有,直接使用
|
|
121
|
+
var cached = svgRawCache.get(svgUrl);
|
|
122
|
+
if (cached) {
|
|
123
|
+
setRawSvg(cached);
|
|
124
|
+
return;
|
|
155
125
|
}
|
|
126
|
+
fetchSvgText(svgUrl).then(function (text) {
|
|
127
|
+
if (mountedRef.current) {
|
|
128
|
+
setRawSvg(text);
|
|
129
|
+
}
|
|
130
|
+
}).catch(function (err) {
|
|
131
|
+
// eslint-disable-next-line no-console
|
|
132
|
+
console.warn('[SparkDesign][Empty][Illustrate] load svg failed:', svgUrl, err);
|
|
133
|
+
});
|
|
156
134
|
}, [svgUrl]);
|
|
157
|
-
if (isSvg) {
|
|
158
|
-
return /*#__PURE__*/_jsx("
|
|
135
|
+
if (!isSvg) {
|
|
136
|
+
return /*#__PURE__*/_jsx("img", {
|
|
137
|
+
src: svgUrl,
|
|
159
138
|
className: className,
|
|
160
|
-
dangerouslySetInnerHTML: {
|
|
161
|
-
__html: svgString
|
|
162
|
-
},
|
|
163
139
|
style: {
|
|
164
140
|
width: size,
|
|
165
141
|
height: size
|
|
166
142
|
}
|
|
167
143
|
});
|
|
168
144
|
}
|
|
169
|
-
|
|
170
|
-
|
|
145
|
+
if (!rawSvg) return null;
|
|
146
|
+
|
|
147
|
+
// 每次渲染时根据当前 tokenMap 做颜色替换
|
|
148
|
+
var svgString = replaceSvgColors(rawSvg, tokenMap);
|
|
149
|
+
return /*#__PURE__*/_jsx("div", {
|
|
171
150
|
className: className,
|
|
151
|
+
dangerouslySetInnerHTML: {
|
|
152
|
+
__html: svgString
|
|
153
|
+
},
|
|
172
154
|
style: {
|
|
173
155
|
width: size,
|
|
174
156
|
height: size
|