import React, { ComponentType } from 'react';
import { GetResizeProps, SimpleTableProps } from './Props';
interface ScrollState<DataItem, Value> {
    columns: SimpleTableProps<DataItem, Value>['columns'];
    delta: number;
}
declare const _default: <DataItem, Value, Props extends SimpleTableProps<DataItem, Value>>(Table: React.ComponentType<Props>) => {
    new (props: GetResizeProps<Props, DataItem>): {
        componentDidUpdate(prevProps: GetResizeProps<Props, DataItem>): void;
        getWidth(): number | GetResizeProps<Props, DataItem>["width"] | undefined;
        handleResize(index: number, width: number, colgroup: number[]): void;
        render(): JSX.Element;
        context: any;
        setState<K extends keyof ScrollState<DataItem, Value>>(state: ScrollState<DataItem, Value> | ((prevState: Readonly<ScrollState<DataItem, Value>>, props: Readonly<GetResizeProps<Props, DataItem>>) => ScrollState<DataItem, Value> | Pick<ScrollState<DataItem, Value>, K> | null) | Pick<ScrollState<DataItem, Value>, K> | null, callback?: (() => void) | undefined): void;
        forceUpdate(callback?: (() => void) | undefined): void;
        readonly props: Readonly<GetResizeProps<Props, DataItem>> & Readonly<{
            children?: React.ReactNode;
        }>;
        state: Readonly<ScrollState<DataItem, Value>>;
        refs: {
            [key: string]: React.ReactInstance;
        };
        componentDidMount?(): void;
        shouldComponentUpdate?(nextProps: Readonly<GetResizeProps<Props, DataItem>>, nextState: Readonly<ScrollState<DataItem, Value>>, nextContext: any): boolean;
        componentWillUnmount?(): void;
        componentDidCatch?(error: Error, errorInfo: React.ErrorInfo): void;
        getSnapshotBeforeUpdate?(prevProps: Readonly<GetResizeProps<Props, DataItem>>, prevState: Readonly<ScrollState<DataItem, Value>>): any;
        componentWillMount?(): void;
        UNSAFE_componentWillMount?(): void;
        componentWillReceiveProps?(nextProps: Readonly<GetResizeProps<Props, DataItem>>, nextContext: any): void;
        UNSAFE_componentWillReceiveProps?(nextProps: Readonly<GetResizeProps<Props, DataItem>>, nextContext: any): void;
        componentWillUpdate?(nextProps: Readonly<GetResizeProps<Props, DataItem>>, nextState: Readonly<ScrollState<DataItem, Value>>, nextContext: any): void;
        UNSAFE_componentWillUpdate?(nextProps: Readonly<GetResizeProps<Props, DataItem>>, nextState: Readonly<ScrollState<DataItem, Value>>, nextContext: any): void;
    };
    contextType?: React.Context<any> | undefined;
};
export default _default;
