@gluestack-ui/accordion
Version:
A universal headless accordion component for React Native, Next.js & React
28 lines (27 loc) • 1.13 kB
JSX
import React, { forwardRef, useMemo } from 'react';
import { AccordionContext } from './Context';
import { useAccordion } from '@react-native-aria/accordion';
import { useControlledState } from '@react-stately/utils';
export const Accordion = (StyledAccordion) => forwardRef(({ type = 'single', isCollapsible = true, isDisabled = false, value, defaultValue = [], onValueChange, children, ...props }, ref) => {
const [selectedValues, setSelectedValues] = useControlledState(value, defaultValue, (incomingValue) => {
onValueChange && onValueChange(incomingValue);
});
const { state } = useAccordion({
type,
isCollapsible,
selectedValues,
setSelectedValues,
});
const contextValue = useMemo(() => {
return {
state,
isDisabledAccordion: isDisabled,
selectedValues,
};
}, [state, isDisabled, selectedValues]);
return (<AccordionContext.Provider value={contextValue}>
<StyledAccordion ref={ref} {...props}>
{children}
</StyledAccordion>
</AccordionContext.Provider>);
});