@nex-ui/react
Version:
🎉 A beautiful, modern, and reliable React component library.
118 lines (114 loc) • 3.92 kB
JavaScript
"use client";
;
var jsxRuntime = require('react/jsx-runtime');
var react = require('react');
var hooks = require('@nex-ui/hooks');
var utils = require('@nex-ui/utils');
var AccordionContext = require('./AccordionContext.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 accordion = require('../../theme/recipes/accordion.cjs');
var getUtilityClass = require('../utils/getUtilityClass.cjs');
const useSlotClasses = (ownerState)=>{
const { prefix } = Context.useNexUI();
const { variant } = ownerState;
return react.useMemo(()=>{
const accordionRoot = `${prefix}-accordion`;
const slots = {
root: [
'root',
variant && `variant-${variant}`
]
};
return composeClasses.composeClasses(slots, getUtilityClass.getUtilityClass(accordionRoot));
}, [
prefix,
variant
]);
};
const Accordion = (inProps)=>{
const props = useDefaultProps.useDefaultProps({
name: 'Accordion',
props: inProps
});
const { children, indicator, motionProps, indicatorMotionProps, onExpandedKeysChange, hideIndicator = false, variant = 'underlined', multiple = false, disabled = false, disabledKeys = [], keepMounted = true, defaultExpandedKeys = [], expandedKeys: expandedKeysProps, ...remainingProps } = props;
const [expandedKeys, setExpandedKeys] = hooks.useControlledState(expandedKeysProps, defaultExpandedKeys, onExpandedKeysChange);
if (utils.__DEV__ && !multiple && expandedKeys.length > 1) {
console.warn('[Nex UI] Accordion: The multiple prop of the Accordion is set to false, but the number of currently expanded items exceeds 1. Please check and set the appropriate props.');
}
const ownerState = {
...props,
hideIndicator,
multiple,
disabled,
disabledKeys,
keepMounted,
defaultExpandedKeys,
expandedKeys,
variant
};
const classes = useSlotClasses(ownerState);
const style = useStyles.useStyles({
ownerState,
name: 'Accordion',
recipe: accordion.accordionRecipe
});
const [AccordionRoot, getAccordionRootProps] = useSlot.useSlot({
style,
ownerState,
elementType: 'div',
externalForwardedProps: remainingProps,
classNames: classes.root
});
const toggleExpandedKey = hooks.useEvent((key)=>{
if (expandedKeys.includes(key)) {
setExpandedKeys(utils.filter(expandedKeys, (k)=>k !== key));
} else {
if (multiple) {
setExpandedKeys([
...expandedKeys,
key
]);
return;
}
setExpandedKeys([
key
]);
}
});
const ctx = react.useMemo(()=>({
expandedKeys,
toggleExpandedKey,
motionProps,
disabledKeys,
disabled,
keepMounted,
hideIndicator,
indicator,
variant,
indicatorMotionProps
}), [
disabled,
disabledKeys,
expandedKeys,
hideIndicator,
indicator,
keepMounted,
motionProps,
toggleExpandedKey,
variant,
indicatorMotionProps
]);
return /*#__PURE__*/ jsxRuntime.jsx(AccordionContext.AccordionGroupProvider, {
value: ctx,
children: /*#__PURE__*/ jsxRuntime.jsx(AccordionRoot, {
...getAccordionRootProps(),
children: children
})
});
};
Accordion.displayName = 'Accordion';
exports.Accordion = Accordion;