/// import { ClassNamesFn } from '../theme'; import React from 'react'; interface ContextMenuProps { className?: string; classPrefix: string; classnames: ClassNamesFn; container?: HTMLElement | null | (() => HTMLElement); } export declare type MenuItem = { label: string; icon?: string; disabled?: boolean; children?: Array; data?: any; className?: string; onSelect?: (data: any) => void; onHighlight?: (isHiglight: boolean, data: any) => void; }; export declare type MenuDivider = '|'; interface ContextMenuState { isOpened: boolean; menus: Array; x: number; y: number; align?: 'left' | 'right'; onClose?: () => void; } export declare class ContextMenu extends React.Component { static instance: any; static getInstance(): any; state: ContextMenuState; menuRef: React.RefObject; originInstance: this | null; componentWillMount(): void; componentDidMount(): void; componentWillUnmount(): void; openContextMenus(info: { x: number; y: number; }, menus: Array, onClose?: () => void): void; close(): void; handleOutClick(e: Event): void; handleClick(item: MenuItem): void; handleKeyDown(e: KeyboardEvent): void; handleMouseEnter(item: MenuItem): void; handleMouseLeave(item: MenuItem): void; handleEnter(menu: HTMLElement): void; handleSelfContextMenu(e: React.MouseEvent): void; renderMenus(menus: Array): JSX.Element[]; render(): JSX.Element; } export declare const ThemedContextMenu: { new (props: (Pick & import("../theme").ThemeOutterProps) | Readonly & import("../theme").ThemeOutterProps>): { render(): JSX.Element; context: any; setState(state: {} | ((prevState: Readonly<{}>, props: Readonly & import("../theme").ThemeOutterProps>) => {} | Pick<{}, K> | null) | Pick<{}, K> | null, callback?: (() => void) | undefined): void; forceUpdate(callback?: (() => void) | undefined): void; readonly props: Readonly & import("../theme").ThemeOutterProps> & Readonly<{ children?: React.ReactNode; }>; state: Readonly<{}>; refs: { [key: string]: React.ReactInstance; }; componentDidMount?(): void; shouldComponentUpdate?(nextProps: Readonly & import("../theme").ThemeOutterProps>, nextState: Readonly<{}>, nextContext: any): boolean; componentWillUnmount?(): void; componentDidCatch?(error: Error, errorInfo: React.ErrorInfo): void; getSnapshotBeforeUpdate?(prevProps: Readonly & import("../theme").ThemeOutterProps>, prevState: Readonly<{}>): any; componentDidUpdate?(prevProps: Readonly & import("../theme").ThemeOutterProps>, prevState: Readonly<{}>, snapshot?: any): void; componentWillMount?(): void; UNSAFE_componentWillMount?(): void; componentWillReceiveProps?(nextProps: Readonly & import("../theme").ThemeOutterProps>, nextContext: any): void; UNSAFE_componentWillReceiveProps?(nextProps: Readonly & import("../theme").ThemeOutterProps>, nextContext: any): void; componentWillUpdate?(nextProps: Readonly & import("../theme").ThemeOutterProps>, nextState: Readonly<{}>, nextContext: any): void; UNSAFE_componentWillUpdate?(nextProps: Readonly & import("../theme").ThemeOutterProps>, nextState: Readonly<{}>, nextContext: any): void; }; new (props: Pick & import("../theme").ThemeOutterProps, context: any): { render(): JSX.Element; context: any; setState(state: {} | ((prevState: Readonly<{}>, props: Readonly & import("../theme").ThemeOutterProps>) => {} | Pick<{}, K> | null) | Pick<{}, K> | null, callback?: (() => void) | undefined): void; forceUpdate(callback?: (() => void) | undefined): void; readonly props: Readonly & import("../theme").ThemeOutterProps> & Readonly<{ children?: React.ReactNode; }>; state: Readonly<{}>; refs: { [key: string]: React.ReactInstance; }; componentDidMount?(): void; shouldComponentUpdate?(nextProps: Readonly & import("../theme").ThemeOutterProps>, nextState: Readonly<{}>, nextContext: any): boolean; componentWillUnmount?(): void; componentDidCatch?(error: Error, errorInfo: React.ErrorInfo): void; getSnapshotBeforeUpdate?(prevProps: Readonly & import("../theme").ThemeOutterProps>, prevState: Readonly<{}>): any; componentDidUpdate?(prevProps: Readonly & import("../theme").ThemeOutterProps>, prevState: Readonly<{}>, snapshot?: any): void; componentWillMount?(): void; UNSAFE_componentWillMount?(): void; componentWillReceiveProps?(nextProps: Readonly & import("../theme").ThemeOutterProps>, nextContext: any): void; UNSAFE_componentWillReceiveProps?(nextProps: Readonly & import("../theme").ThemeOutterProps>, nextContext: any): void; componentWillUpdate?(nextProps: Readonly & import("../theme").ThemeOutterProps>, nextState: Readonly<{}>, nextContext: any): void; UNSAFE_componentWillUpdate?(nextProps: Readonly & import("../theme").ThemeOutterProps>, nextState: Readonly<{}>, nextContext: any): void; }; displayName: string; contextType: React.Context; ComposedComponent: typeof ContextMenu; } & import("hoist-non-react-statics").NonReactStatics & { ComposedComponent: typeof ContextMenu; }; export default ThemedContextMenu; export declare function openContextMenus(info: Event | { x: number; y: number; }, menus: Array, onClose?: () => void): any;