@nex-ui/react
Version:
🎉 A beautiful, modern, and reliable React component library.
106 lines (103 loc) • 3.34 kB
JavaScript
"use client";
import { jsx } from 'react/jsx-runtime';
import { useMemo } from 'react';
import { useControlledState, useEvent } from '@nex-ui/hooks';
import { __DEV__ } from '@nex-ui/utils';
import { AccordionGroupProvider } from './AccordionContext.mjs';
import { useDefaultProps } from '../utils/useDefaultProps.mjs';
import { useSlotClasses } from '../utils/useSlotClasses.mjs';
import { useStyles } from '../utils/useStyles.mjs';
import { useSlot } from '../utils/useSlot.mjs';
import { accordionRecipe } from '../../theme/recipes/accordion.mjs';
const slots = [
'root'
];
const Accordion = (inProps)=>{
const props = useDefaultProps({
name: 'Accordion',
props: inProps
});
const { children, indicator, motionProps, indicatorMotionProps, onExpandedKeysChange, hideIndicator = false, variant = 'underlined', multiple = false, disabled = false, disabledKeys = [], keepMounted = false, defaultExpandedKeys = [], expandedKeys: expandedKeysProps, ...remainingProps } = props;
const [expandedKeys, setExpandedKeys] = useControlledState(expandedKeysProps, defaultExpandedKeys, onExpandedKeysChange);
if (__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 slotClasses = useSlotClasses({
name: 'Accordion',
slots
});
const style = useStyles({
ownerState,
name: 'Accordion',
recipe: accordionRecipe
});
const [AccordionRoot, getAccordionRootProps] = useSlot({
style,
elementType: 'div',
externalForwardedProps: remainingProps,
classNames: slotClasses.root,
dataAttrs: {
variant,
multiple
}
});
const toggleExpandedKey = useEvent((key)=>{
if (expandedKeys.includes(key)) {
setExpandedKeys(expandedKeys.filter((k)=>k !== key));
} else {
if (multiple) {
setExpandedKeys([
...expandedKeys,
key
]);
return;
}
setExpandedKeys([
key
]);
}
});
const ctx = useMemo(()=>({
expandedKeys,
toggleExpandedKey,
motionProps,
disabledKeys,
disabled,
keepMounted,
hideIndicator,
indicator,
variant,
indicatorMotionProps
}), [
disabled,
disabledKeys,
expandedKeys,
hideIndicator,
indicator,
keepMounted,
motionProps,
toggleExpandedKey,
variant,
indicatorMotionProps
]);
return /*#__PURE__*/ jsx(AccordionGroupProvider, {
value: ctx,
children: /*#__PURE__*/ jsx(AccordionRoot, {
...getAccordionRootProps(),
children: children
})
});
};
Accordion.displayName = 'Accordion';
export { Accordion };