/*
 * Copyright (C) 2007-2022 Crafter Software Corporation. All Rights Reserved.
 *
 * This program is free software: you can redistribute it and/or modify
 * it under the terms of the GNU Lesser General Public License version 3 as published by
 * the Free Software Foundation.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public License
 * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 */

import { ButtonTypeMap } from '@mui/material/Button';
import React, { ReactNode } from 'react';
import { IconButtonProps } from '@mui/material/IconButton';
import { SvgIconTypeMap } from '@mui/material/SvgIcon';
import { OverridableComponent } from '@mui/material/OverridableComponent';
import { FullSxRecord, PartialSxRecord } from '../../models/CustomRecord';
export type ConfirmDropdownClassKey = 'button' | 'menuPaper' | 'helperText';
export type ConfirmDropdownFullSx = FullSxRecord<ConfirmDropdownClassKey>;
export type ConfirmDropdownPartialSx = PartialSxRecord<ConfirmDropdownClassKey>;
interface ConfirmDropdownProps {
  text?: ReactNode;
  cancelText: ReactNode;
  confirmText: ReactNode;
  confirmHelperText?: ReactNode;
  disabled?: boolean;
  buttonVariant?: ButtonTypeMap['props']['variant'];
  classes?: Partial<Record<ConfirmDropdownClassKey, string>>;
  sx?: ConfirmDropdownPartialSx;
  size?: IconButtonProps['size'];
  icon?: OverridableComponent<SvgIconTypeMap>;
  iconColor?: IconButtonProps['color'];
  iconTooltip?: React.ReactNode;
  onConfirm(): any;
  onCancel?(): any;
}
export declare function ConfirmDropdown(props: ConfirmDropdownProps): React.JSX.Element;
export default ConfirmDropdown;
