UNPKG

@heroui/accordion

Version:

Collapse display a list of high-level options that can expand/collapse to reveal more information.

231 lines (228 loc) 7.21 kB
"use client"; // src/use-accordion-item.ts import { useProviderContext } from "@heroui/system"; import { useFocusRing } from "@react-aria/focus"; import { cn, accordionItem } from "@heroui/theme"; import { callAllHandlers, dataAttr, objectToDeps, chain, mergeProps } from "@heroui/shared-utils"; import { useDOMRef, filterDOMProps } from "@heroui/react-utils"; import { useReactAriaAccordionItem } from "@heroui/use-aria-accordion"; import { useCallback, useMemo } from "react"; import { useHover, usePress } from "@react-aria/interactions"; function useAccordionItem(props) { var _a, _b; const globalContext = useProviderContext(); const { ref, as, item, onFocusChange } = props; const { state, className, indicator, children, title, subtitle, startContent, motionProps, focusedKey, variant, isCompact = false, classNames: classNamesProp = {}, isDisabled: isDisabledProp = false, hideIndicator = false, disableAnimation = (_a = globalContext == null ? void 0 : globalContext.disableAnimation) != null ? _a : false, keepContentMounted = false, disableIndicatorAnimation = false, HeadingComponent = as || "h2", onPress, onPressStart, onPressEnd, onPressChange, onPressUp, onClick, ...otherProps } = props; const Component = as || "div"; const shouldFilterDOMProps = typeof Component === "string"; const domRef = useDOMRef(ref); const isDisabled = state.disabledKeys.has(item.key) || isDisabledProp; const isOpen = state.selectionManager.isSelected(item.key); const { buttonProps: buttonCompleteProps, regionProps } = useReactAriaAccordionItem( { item, isDisabled }, { ...state, focusedKey }, domRef ); const { onFocus: onFocusButton, onBlur: onBlurButton, ...buttonProps } = buttonCompleteProps; const { isFocused, isFocusVisible, focusProps } = useFocusRing({ autoFocus: (_b = item.props) == null ? void 0 : _b.autoFocus }); const { isHovered, hoverProps } = useHover({ isDisabled }); const { pressProps, isPressed } = usePress({ ref: domRef, isDisabled, onPress, onPressStart, onPressEnd, onPressChange, onPressUp }); const handleFocus = useCallback(() => { onFocusChange == null ? void 0 : onFocusChange(true, item.key); }, []); const handleBlur = useCallback(() => { onFocusChange == null ? void 0 : onFocusChange(false, item.key); }, []); const classNames = useMemo( () => ({ ...classNamesProp }), [objectToDeps(classNamesProp)] ); const slots = useMemo( () => accordionItem({ isCompact, isDisabled, hideIndicator, disableAnimation, disableIndicatorAnimation, variant }), [isCompact, isDisabled, hideIndicator, disableAnimation, disableIndicatorAnimation, variant] ); const baseStyles = cn(classNames == null ? void 0 : classNames.base, className); const getBaseProps = useCallback( (props2 = {}) => { return { "data-open": dataAttr(isOpen), "data-disabled": dataAttr(isDisabled), "data-slot": "base", className: slots.base({ class: baseStyles }), ...mergeProps( filterDOMProps(otherProps, { enabled: shouldFilterDOMProps }), props2 ) }; }, [baseStyles, shouldFilterDOMProps, otherProps, slots, item.props, isOpen, isDisabled] ); const getButtonProps = (props2 = {}) => { var _a2, _b2; return { ref: domRef, "data-open": dataAttr(isOpen), "data-focus": dataAttr(isFocused), "data-focus-visible": dataAttr(isFocusVisible), "data-disabled": dataAttr(isDisabled), "data-hover": dataAttr(isHovered), "data-pressed": dataAttr(isPressed), "data-slot": "trigger", className: slots.trigger({ class: classNames == null ? void 0 : classNames.trigger }), onFocus: callAllHandlers( handleFocus, onFocusButton, focusProps.onFocus, otherProps.onFocus, (_a2 = item.props) == null ? void 0 : _a2.onFocus ), onBlur: callAllHandlers( handleBlur, onBlurButton, focusProps.onBlur, otherProps.onBlur, (_b2 = item.props) == null ? void 0 : _b2.onBlur ), ...mergeProps(buttonProps, hoverProps, pressProps, props2, { onClick: chain(pressProps.onClick, onClick) }) }; }; const getContentProps = useCallback( (props2 = {}) => { return { "data-open": dataAttr(isOpen), "data-disabled": dataAttr(isDisabled), "data-slot": "content", className: slots.content({ class: classNames == null ? void 0 : classNames.content }), ...mergeProps(regionProps, props2) }; }, [slots, classNames, regionProps, isOpen, isDisabled, classNames == null ? void 0 : classNames.content] ); const getIndicatorProps = useCallback( (props2 = {}) => { return { "aria-hidden": dataAttr(true), "data-open": dataAttr(isOpen), "data-disabled": dataAttr(isDisabled), "data-slot": "indicator", className: slots.indicator({ class: classNames == null ? void 0 : classNames.indicator }), ...props2 }; }, [slots, classNames == null ? void 0 : classNames.indicator, isOpen, isDisabled, classNames == null ? void 0 : classNames.indicator] ); const getHeadingProps = useCallback( (props2 = {}) => { return { "data-open": dataAttr(isOpen), "data-disabled": dataAttr(isDisabled), "data-slot": "heading", className: slots.heading({ class: classNames == null ? void 0 : classNames.heading }), ...props2 }; }, [slots, classNames == null ? void 0 : classNames.heading, isOpen, isDisabled, classNames == null ? void 0 : classNames.heading] ); const getTitleProps = useCallback( (props2 = {}) => { return { "data-open": dataAttr(isOpen), "data-disabled": dataAttr(isDisabled), "data-slot": "title", className: slots.title({ class: classNames == null ? void 0 : classNames.title }), ...props2 }; }, [slots, classNames == null ? void 0 : classNames.title, isOpen, isDisabled, classNames == null ? void 0 : classNames.title] ); const getSubtitleProps = useCallback( (props2 = {}) => { return { "data-open": dataAttr(isOpen), "data-disabled": dataAttr(isDisabled), "data-slot": "subtitle", className: slots.subtitle({ class: classNames == null ? void 0 : classNames.subtitle }), ...props2 }; }, [slots, classNames, isOpen, isDisabled, classNames == null ? void 0 : classNames.subtitle] ); return { Component, HeadingComponent, item, slots, classNames, domRef, indicator, children, title, subtitle, startContent, isOpen, isDisabled, hideIndicator, keepContentMounted, disableAnimation, motionProps, getBaseProps, getHeadingProps, getButtonProps, getContentProps, getIndicatorProps, getTitleProps, getSubtitleProps }; } export { useAccordionItem };