UNPKG

@nex-ui/react

Version:

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

113 lines (109 loc) • 3.75 kB
'use strict'; var jsxRuntime = require('react/jsx-runtime'); var react = require('react'); var utils = require('@nex-ui/utils'); var AvatarGroupContext = require('./AvatarGroupContext.cjs'); var Avatar = require('./Avatar.cjs'); var useDefaultProps = require('../utils/useDefaultProps.cjs'); var useStyles = require('../utils/useStyles.cjs'); var useSlot = require('../utils/useSlot.cjs'); var Context = require('../provider/Context.cjs'); var composeClasses = require('../utils/composeClasses.cjs'); var avatar = require('../../theme/recipes/avatar.cjs'); var getUtilityClass = require('../utils/getUtilityClass.cjs'); const useSlotClasses = (ownerState)=>{ const { prefix } = Context.useNexUI(); const { classes } = ownerState; return react.useMemo(()=>{ const avatarGroupRoot = `${prefix}-avatar-group`; const slots = { root: [ 'root' ], surplus: [ 'surplus' ] }; return composeClasses.composeClasses(slots, getUtilityClass.getUtilityClass(avatarGroupRoot), classes); }, [ classes, prefix ]); }; const AvatarGroup = (inProps)=>{ const props = useDefaultProps.useDefaultProps({ name: 'AvatarGroup', props: inProps }); const { children, total, slotProps, spacing, renderSurplus, size = 'md', color = 'gray', outlined = false, radius = size, max: maxProp = 5, ...remainingProps } = props; const max = Math.max(1, maxProp); const ownerState = { ...props, size, color, outlined, radius, max }; const classes = useSlotClasses(ownerState); const style = useStyles.useStyles({ ownerState, name: 'AvatarGroup', recipe: avatar.avatarGroupRecipe }); const [AvatarGroupRoot, getAvatarGroupRootProps] = useSlot.useSlot({ style, ownerState, elementType: 'div', externalForwardedProps: remainingProps, classNames: classes.root, additionalProps: { style: { [`--avatar-group-spacing`]: spacing !== undefined ? `${spacing}px` : undefined } } }); const [AvatarSurplus, getAvatarSurplusProps] = useSlot.useSlot({ ownerState, elementType: Avatar.Avatar, externalSlotProps: slotProps?.surplus, classNames: classes.surplus, shouldForwardComponent: false }); const ctx = react.useMemo(()=>({ size, color, outlined, radius }), [ color, outlined, radius, size ]); const childrenLength = utils.isArray(children) ? children.length : 1; if (childrenLength === 1 && (total === undefined || total < 2)) { return children; } const lastAvatar = Math.min(childrenLength, max); const totalAvatars = total ?? childrenLength; const extraAvatars = Math.max(0, totalAvatars - lastAvatar); return /*#__PURE__*/ jsxRuntime.jsx(AvatarGroupRoot, { ...getAvatarGroupRootProps(), children: /*#__PURE__*/ jsxRuntime.jsxs(AvatarGroupContext.AvatarGroupProvider, { value: ctx, children: [ utils.isArray(children) ? children.slice(0, lastAvatar) : children, !!extraAvatars && (renderSurplus ? renderSurplus(extraAvatars) : /*#__PURE__*/ jsxRuntime.jsxs(AvatarSurplus, { ...getAvatarSurplusProps(), children: [ "+", extraAvatars ] })) ] }) }); }; AvatarGroup.displayName = 'AvatarGroup'; exports.AvatarGroup = AvatarGroup;