@nex-ui/react
Version:
🎉 A beautiful, modern, and reliable React component library.
84 lines (80 loc) • 2.34 kB
JavaScript
"use client";
;
var jsxRuntime = require('react/jsx-runtime');
var react = require('react');
var utils = require('@nex-ui/utils');
var Context = require('../provider/Context.cjs');
var useDefaultProps = require('../utils/useDefaultProps.cjs');
var useStyles = require('../utils/useStyles.cjs');
var useSlot = require('../utils/useSlot.cjs');
var composeClasses = require('../utils/composeClasses.cjs');
var icon = require('../../theme/recipes/icon.cjs');
var getUtilityClass = require('../utils/getUtilityClass.cjs');
const useSlotClasses = (ownerState)=>{
const { prefix } = Context.useNexUI();
const { spin, size } = ownerState;
return react.useMemo(()=>{
const iconRoot = `${prefix}-icon`;
const slots = {
root: [
'root',
spin && `spin`,
size && `size-${size}`
]
};
return composeClasses.composeClasses(slots, getUtilityClass.getUtilityClass(iconRoot));
}, [
prefix,
size,
spin
]);
};
const Icon = (inProps)=>{
const props = useDefaultProps.useDefaultProps({
name: 'Icon',
props: inProps
});
const { as, color, focusable = false, spin = false, size = 'md', width = '1em', height = '1em', ...remainingProps } = props;
if (utils.__DEV__ && !as) {
console.warn('[Nex UI] Icon: Please pass the "as" property.');
}
const ownerState = {
...props,
color,
as,
spin,
size,
width,
height
};
const style = useStyles.useStyles({
ownerState,
name: 'Icon',
recipe: icon.iconRecipe
});
const classes = useSlotClasses(ownerState);
const [IconRoot, getIconRootProps] = useSlot.useSlot({
style,
ownerState,
elementType: 'svg',
externalForwardedProps: remainingProps,
classNames: classes.root,
a11y: {
focusable,
'aria-hidden': props['aria-hidden'] ?? true
},
additionalProps: {
as,
sx: {
color,
width,
height
}
}
});
return /*#__PURE__*/ jsxRuntime.jsx(IconRoot, {
...getIconRootProps()
});
};
Icon.displayName = 'Icon';
exports.Icon = Icon;