Urara-Blog/node_modules/.pnpm-store/v3/files/ce/d003e3e3d95bd1cadeee1f0fb2ae64ebcf0c17e86a4e0f055079133a28b636766d093a14cb274f114a39e1158e1d7f139c903857728d275f20146dbda436f9
2022-08-14 01:14:53 +08:00

56 lines
2 KiB
Text

'use strict';
Object.defineProperty(exports, '__esModule', { value: true });
const svg_build = require('../svg/build.cjs');
const iconSet_getIcon = require('../icon-set/get-icon.cjs');
const loader_utils = require('./utils.cjs');
const createDebugger = require('debug');
const customisations_index = require('../customisations/index.cjs');
require('../svg/size.cjs');
require('../icon/index.cjs');
require('../icon/merge.cjs');
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e["default"] : e; }
const createDebugger__default = /*#__PURE__*/_interopDefaultLegacy(createDebugger);
const debug = createDebugger__default("@iconify-loader:icon");
async function searchForIcon(iconSet, collection, ids, options) {
let iconData;
const { customize } = options?.customizations ?? {};
for (const id of ids) {
iconData = iconSet_getIcon.getIconData(iconSet, id, true);
if (iconData) {
debug(`${collection}:${id}`);
let defaultCustomizations = { ...customisations_index.defaults };
if (typeof customize === "function")
defaultCustomizations = customize(defaultCustomizations);
const {
attributes: { width, height, ...restAttributes },
body
} = svg_build.iconToSVG(iconData, defaultCustomizations);
const scale = options?.scale;
return await loader_utils.mergeIconProps(`<svg >${body}</svg>`, collection, id, options, () => {
return { ...restAttributes };
}, (props) => {
if (typeof props.width === "undefined" || props.width === null) {
if (typeof scale === "number") {
props.width = `${scale}em`;
} else {
props.width = width;
}
}
if (typeof props.height === "undefined" || props.height === null) {
if (typeof scale === "number") {
props.height = `${scale}em`;
} else {
props.height = height;
}
}
});
}
}
}
exports.searchForIcon = searchForIcon;