mirror of
https://github.com/Sevichecc/Urara-Blog.git
synced 2025-05-03 14:59:29 +08:00
29 lines
1.1 KiB
Text
29 lines
1.1 KiB
Text
import createDebugger from 'debug';
|
|
import { mergeIconProps } from './utils.mjs';
|
|
import { trimSVG } from '../svg/trim.mjs';
|
|
|
|
const debug = createDebugger("@iconify-loader:custom");
|
|
async function getCustomIcon(custom, collection, icon, options) {
|
|
let result;
|
|
debug(`${collection}:${icon}`);
|
|
if (typeof custom === "function") {
|
|
result = await custom(icon);
|
|
} else {
|
|
const inline = custom[icon];
|
|
result = typeof inline === "function" ? await inline() : inline;
|
|
}
|
|
if (result) {
|
|
const cleanupIdx = result.indexOf("<svg");
|
|
if (cleanupIdx > 0)
|
|
result = result.slice(cleanupIdx);
|
|
const { transform } = options?.customizations ?? {};
|
|
result = typeof transform === "function" ? await transform(result, collection, icon) : result;
|
|
if (!result.startsWith("<svg")) {
|
|
console.warn(`Custom icon "${icon}" in "${collection}" is not a valid SVG`);
|
|
return result;
|
|
}
|
|
return await mergeIconProps(options?.customizations?.trimCustomSvg === true ? trimSVG(result) : result, collection, icon, options, void 0);
|
|
}
|
|
}
|
|
|
|
export { getCustomIcon };
|