import * as React from 'react'; import { css } from '@patternfly/react-styles'; import { Button, ButtonVariant } from '../Button'; import { Tooltip } from '../Tooltip'; import styles from '@patternfly/react-styles/css/components/DualListSelector/dual-list-selector'; /** Renders an individual control button for moving selected options between each * dual list selector pane. */ export interface DualListSelectorControlProps extends Omit, 'onClick'> { /** Content to be rendered in the dual list selector control. */ children?: React.ReactNode; /** @hide forwarded ref */ innerRef?: React.Ref; /** Flag indicating the control is disabled. */ isDisabled?: boolean; /** Additional classes applied to the dual list selector control. */ className?: string; /** Callback fired when dual list selector control is selected. */ onClick?: (event: React.MouseEvent) => void; /** Accessible label for the dual list selector control. */ 'aria-label'?: string; /** Content to be displayed in a tooltip on hover of control. */ tooltipContent?: React.ReactNode; /** Additional tooltip properties passed to the tooltip. */ tooltipProps?: any; } export const DualListSelectorControlBase: React.FunctionComponent = ({ innerRef, children = null, className, 'aria-label': ariaLabel, isDisabled = true, onClick = () => {}, tooltipContent, tooltipProps = {} as any, ...props }: DualListSelectorControlProps) => { const privateRef = React.useRef(null); const ref = innerRef || privateRef; return (
{tooltipContent && }
); }; DualListSelectorControlBase.displayName = 'DualListSelectorControlBase'; export const DualListSelectorControl = React.forwardRef((props: DualListSelectorControlProps, ref: React.Ref) => ( )); DualListSelectorControl.displayName = 'DualListSelectorControl';