import * as React from 'react'; import { Key, RenderExpandIcon, TableStore, Cell, FixedType, GetRowKey, RenderRows, ExpandedRowRender } from './interface'; import ColumnManager from './ColumnManager'; export declare type RenderTableRows = (renderRows: RenderRows, rows: React.ReactElement[], record: ValueType, index: number, indent: number, fixed: FixedType, parentKey: Key, ancestorKeys: Key[]) => void; export declare type ExpandChangeEventHandler = (expanded: boolean, record: ValueType, event: React.MouseEvent, rowKey: Key, destroy: boolean) => void; export declare type RenderExpandIndentCell = (rows: Cell[][], fixed: FixedType) => void; export declare type ExpandEventHandler = (expanded: boolean, record: ValueType) => void; export interface ExpandableTableProps { expandIconAsCell?: boolean; expandedRowKeys?: Key[]; expandedRowClassName?: (record: ValueType, index: number, indent: number) => string; defaultExpandAllRows?: boolean; defaultExpandedRowKeys?: Key[]; expandIconColumnIndex?: number; expandedRowRender?: ExpandedRowRender; expandIcon?: RenderExpandIcon; childrenColumnName?: string; indentSize?: number; onExpand?: ExpandEventHandler; onExpandedRowsChange?: (expandedKeys: Key[]) => void; columnManager: ColumnManager; store: TableStore; prefixCls: string; data?: ValueType[]; children: (info: { props: ExpandableTableProps; needIndentSpaced: boolean; renderRows: RenderTableRows; handleExpandChange: ExpandChangeEventHandler; renderExpandIndentCell: RenderExpandIndentCell; }) => React.ReactNode; getRowKey: GetRowKey; } declare const _default: any; export default _default;