UNPKG

@nex-ui/react

Version:

🎉 A beautiful, modern, and reliable React component library.

84 lines (80 loc) • 2.34 kB
"use client"; 'use strict'; 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;