import React, { PureComponent } from 'react'; import PropTypes from 'prop-types'; import { AccordionItemInternalProps, AccordionItemType, AccordionProps, AccordionSectionItemProps, AccordionState } from './Accordion.types'; export declare class Accordion extends PureComponent { static displayName: string; static propTypes: { dataHook: PropTypes.Requireable; multiple: PropTypes.Requireable; skin: PropTypes.Requireable; hideShadow: PropTypes.Requireable; size: PropTypes.Requireable; horizontalPadding: PropTypes.Requireable; transitionSpeed: PropTypes.Requireable; onAnimationEnter: PropTypes.Requireable<(...args: any[]) => any>; onAnimationExit: PropTypes.Requireable<(...args: any[]) => any>; items: PropTypes.Requireable any>; }> | null | undefined)[] | (PropTypes.InferProps<{ title: PropTypes.Requireable; subtitle: PropTypes.Requireable; icon: PropTypes.Requireable; children: PropTypes.Requireable; expandLabel: PropTypes.Requireable; collapseLabel: PropTypes.Requireable; showLabel: PropTypes.Requireable; buttonType: PropTypes.Requireable; disabled: PropTypes.Requireable; onToggle: PropTypes.Requireable<(...args: any[]) => any>; onMouseEnter: PropTypes.Requireable<(...args: any[]) => any>; onMouseleave: PropTypes.Requireable<(...args: any[]) => any>; open: PropTypes.Requireable; initiallyOpen: PropTypes.Requireable; }> | null | undefined)[] | null | undefined>>; }; _findOpenIndexes: (items?: AccordionItemType[], initial?: boolean) => number[]; static defaultProps: { items: never[]; multiple: boolean; skin: "standard"; horizontalPadding: "large"; hideShadow: boolean; transitionSpeed: string; size: string; }; constructor(props: AccordionProps); _compareOpenItems: (currentItems?: AccordionItemType[], prevItems?: AccordionItemType[]) => boolean; componentDidUpdate: (prevProps: AccordionProps) => void; _toggle: (index: number) => () => void; render(): React.JSX.Element; } export declare const accordionItemBuilder: (item: AccordionItemType) => { render: (uncontrolledProps: AccordionItemInternalProps, internalProps: AccordionSectionItemProps) => React.JSX.Element; key?: string | number; open?: boolean; initiallyOpen?: boolean; disabled?: boolean; title?: React.ReactNode; subtitle?: React.ReactNode; icon?: React.ReactNode; prefix?: React.ReactNode; suffix?: React.ReactNode; children?: React.ReactNode; expandLabel?: React.ReactNode; collapseLabel?: React.ReactNode; toggleIconPlacement?: "start" | "end"; className?: string; buttonType?: "node" | "button" | "textButton"; showLabel?: "always" | "hover"; onToggle?: React.MouseEventHandler; onMouseEnter?: React.MouseEventHandler; onMouseLeave?: React.MouseEventHandler; last?: boolean; hideShadow?: boolean; skin?: "light" | "standard" | "neutral"; size?: "small" | "medium" | "large" | "tiny"; onAnimationEnter?: () => void; onAnimationExit?: () => void; transitionSpeed?: "medium" | "slow" | "fast"; horizontalPadding?: "small" | "none" | "medium" | "large" | "tiny"; }; export declare const accordionSectionItemBuilder: (item: AccordionItemType) => { render: (uncontrolledProps: AccordionItemInternalProps, internalProps: AccordionSectionItemProps) => React.JSX.Element; key?: string | number; open?: boolean; initiallyOpen?: boolean; disabled?: boolean; title?: React.ReactNode; subtitle?: React.ReactNode; icon?: React.ReactNode; prefix?: React.ReactNode; suffix?: React.ReactNode; children?: React.ReactNode; expandLabel?: React.ReactNode; collapseLabel?: React.ReactNode; toggleIconPlacement?: "start" | "end"; className?: string; buttonType?: "node" | "button" | "textButton"; showLabel?: "always" | "hover"; onToggle?: React.MouseEventHandler; onMouseEnter?: React.MouseEventHandler; onMouseLeave?: React.MouseEventHandler; last?: boolean; hideShadow?: boolean; skin?: "light" | "standard" | "neutral"; size?: "small" | "medium" | "large" | "tiny"; onAnimationEnter?: () => void; onAnimationExit?: () => void; transitionSpeed?: "medium" | "slow" | "fast"; horizontalPadding?: "small" | "none" | "medium" | "large" | "tiny"; }; export default Accordion; //# sourceMappingURL=Accordion.d.ts.map