UNPKG

@nex-ui/react

Version:

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

118 lines (114 loc) • 3.92 kB
"use client"; 'use strict'; 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;