/*
 * 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/>.
 */

/// <reference types="react" />
import { DrawerProps } from '@mui/material';
import { CSSObject as CSSProperties } from 'tss-react';
export type ResizeableDrawerClassKey =
  | 'root'
  | 'drawerBody'
  | 'drawerPaper'
  | 'drawerPaperLeft'
  | 'drawerPaperRight'
  | 'drawerPaperBelowToolbar'
  | 'resizeHandle'
  | 'resizeHandleActive'
  | 'resizeHandleLeft'
  | 'resizeHandleRight'
  | 'resizingOverlay';
export type ResizeableDrawerStyles = Partial<Record<ResizeableDrawerClassKey, CSSProperties>>;
interface ResizeableDrawerProps extends DrawerProps {
  open: boolean;
  width: number;
  maxWidth?: number;
  belowToolbar?: boolean;
  classes?: DrawerProps['classes'] & Partial<Record<ResizeableDrawerClassKey, string>>;
  styles?: ResizeableDrawerStyles;
  onWidthChange?(width: number): void;
}
export declare function ResizeableDrawer(props: ResizeableDrawerProps): JSX.Element;
export default ResizeableDrawer;
