xdesign-vue-next
Version:
XDesign Component for vue-next
28 lines (24 loc) • 766 B
JavaScript
/**
* xdesign v1.0.6
* (c) 2023 xdesign
* @license MIT
*/
import { getCurrentInstance, h, createVNode } from 'vue';
import isFunction from 'lodash/isFunction';
function useIcon() {
var instance = getCurrentInstance();
return function renderIconTNode(iconType, defaultIcons) {
var iconContent;
if (isFunction(instance.props[iconType])) {
iconContent = instance.props[iconType](h);
} else if (instance.slots[iconType]) {
iconContent = instance.slots[iconType] && instance.slots[iconType](null)[0];
} else if (defaultIcons) {
var Component = defaultIcons[instance.props.theme];
iconContent = createVNode(Component, null, null);
}
return iconContent;
};
}
export { useIcon };
//# sourceMappingURL=icon.js.map