@nex-ui/react
Version:
🎉 A beautiful, modern, and reliable React component library.
113 lines (109 loc) • 3.75 kB
JavaScript
'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;