import React from "react"; import { Button, ButtonProps } from "../../../button"; import { cl, composeEventHandlers } from "../../../utils/helpers"; import { useControllableState } from "../../../utils/hooks"; type DataToolbarToggleButtonProps = Omit< ButtonProps, "variant" | "size" | "data-color" | "children" > & Required> & { /** * Indicates whether the toggle button is pressed or not. * @default false */ isPressed?: boolean; /** * Default uncontrolled pressed state. * @default false */ defaultPressed?: boolean; /** * Callback for new pressed state. */ onPressChange?: (isPressed: boolean) => void; }; const DataToolbarToggleButton = React.forwardRef< HTMLButtonElement, DataToolbarToggleButtonProps >( ( { className, isPressed, defaultPressed = false, onPressChange, onClick, ...props }, ref, ) => { const [pressed, setPressed] = useControllableState({ defaultValue: defaultPressed, value: isPressed, onChange: onPressChange, }); return (