import { CSSProperties, FunctionComponent, Key, ReactElement, ReactNode } from 'react';
import DataSet, { Group } from '../data-set/DataSet';
import Record from '../data-set/Record';
import { FormFieldProps, HighlightRenderer, Renderer, RenderProps } from '../field/FormField';
import { ElementProps } from '../core/ViewComponent';
import { ColumnAlign, ColumnLock, TableColumnTooltip } from './enum';
import { ShowHelp } from '../field/enum';
import { Commands, TableGroup } from './Table';
import TableStore from './TableStore';
import { AggregationTreeProps } from './AggregationTree';
export declare function defaultAggregationRenderer({ text }: {
    text: any;
}): any;
export declare type onCellProps = {
    dataSet: DataSet;
    record: Record;
    column: ColumnProps;
};
export declare type commandProps = {
    dataSet: DataSet;
    record: Record;
    aggregation?: boolean;
};
export interface ColumnRenderProps extends RenderProps {
    aggregation?: boolean;
    headerGroup?: Group;
    rowGroup?: Group;
    aggregationTree?: ReactElement<AggregationTreeProps>[];
}
export interface FooterHookOptions {
    dataSet: DataSet;
    name?: string | undefined;
    aggregationTree?: ReactElement<AggregationTreeProps>[];
}
export interface HeaderHookOptions extends FooterHookOptions {
    title?: string | undefined;
    aggregation?: boolean | undefined;
    group?: Group | undefined;
}
export interface ColumnPropsBase extends ElementProps {
    /**
     * 列对照的字段名
     */
    name?: string;
    /**
     * 列宽
     * 不推荐给所有列设置宽度，而是给某一列不设置宽度达到自动宽度的效果
     */
    width?: number;
    /**
     * 默认列宽
     * 只在出横向滚动条时起作用
     */
    defaultWidth?: number;
    /**
     * 最小列宽
     */
    minWidth?: number;
    /**
     * 列头文字，优先级高于 header， 便于列头文字通过 header 钩子渲染的情况下可编辑
     */
    title?: string;
    /**
     * 列头
     */
    header?: ReactNode | ((dataSet: DataSet | HeaderHookOptions, name?: string, title?: string, aggregation?: boolean) => ReactNode);
    /**
     * 列脚
     */
    footer?: ReactNode | ((dataSet: DataSet | FooterHookOptions, name?: string) => ReactNode);
    /**
     * 单元格渲染回调
     */
    renderer?: Renderer<ColumnRenderProps>;
    /**
     * 编辑器
     */
    editor?: ReactElement<FormFieldProps> | ((record: Record, name?: string) => ReactElement<FormFieldProps> | boolean) | boolean;
    /**
     * 是否锁定
     * 可选值： false | true | 'left' | 'right'
     * @default false
     */
    lock?: ColumnLock | boolean | undefined;
    /**
     * 文字对齐方式
     * 可选值： 'left' | 'center' | 'right'
     */
    align?: ColumnAlign;
    /**
     * 是否可调整宽度
     * @default true
     */
    resizable?: boolean;
    /**
     * 是否可编辑标题
     */
    titleEditable?: boolean;
    /**
     * 是否可排序
     * @default false
     */
    sortable?: boolean;
    /**
     * 是否可隐藏，设为false时不会出现在列过滤选项中
     * @default true
     */
    hideable?: boolean;
    /**
     * 列头内链样式
     */
    headerStyle?: CSSProperties;
    /**
     * 列头样式名
     */
    headerClassName?: string;
    /**
     * 列脚内链样式
     */
    footerStyle?: CSSProperties;
    /**
     * 列脚样式名
     */
    footerClassName?: string;
    /**
     * 列头提示信息
     */
    help?: string;
    /**
     * 显示提示信息的方式
     *
     */
    showHelp?: ShowHelp;
    /**
     * 用tooltip显示单元格内容
     * 可选值：`none` `always` `overflow`
     */
    tooltip?: TableColumnTooltip;
    /**
     * 设置单元格属性
     * @param {onCellProps} props
     * @return {Object} 单元格属性
     */
    onCell?: (props: onCellProps) => object;
    /**
     * 行操作按钮
     * 可选值：`edit` `delete` 或 自定义按钮
     * 给内置按钮加属性：command={[['edit', { color: 'red' }], ...]}
     */
    command?: Commands[] | ((props: commandProps) => Commands[]);
    /**
     * 列排序，若无设置则按列数组顺序
     */
    sort?: number;
    /**
     * 是否聚合
     */
    aggregation?: boolean | undefined;
    /**
     * 聚合显示条目数量上限，超过限制的条目可通过展开按钮来显示
     * @default 4
     */
    aggregationLimit?: number;
    /**
     * 默认展开聚合列的展开按钮
     */
    aggregationLimitDefaultExpanded?: boolean | ((record: Record) => boolean);
    /**
     * 默认展开指定的聚合列树节点
     */
    aggregationDefaultExpandedKeys?: Key[];
    /**
     * 默认展开所有聚合列树节点
     */
    aggregationDefaultExpandAll?: boolean;
    /**
     * 聚合单元格中的列索引
     */
    aggregationTreeIndex?: number;
    /**
     * 在聚合列下是否隐藏
     */
    hiddenInAggregation?: boolean | ((record: Record) => boolean);
    /**
     * 高亮渲染器
     */
    highlightRenderer?: HighlightRenderer;
}
export interface ColumnProps extends ColumnPropsBase {
    children?: ColumnProps[];
    __tableGroup?: TableGroup;
    __group?: Group;
    __originalKey?: Key;
}
export interface ColumnPropsInner extends ColumnPropsBase {
    children?: ReactElement<ColumnProps>[] | ReactElement<ColumnProps>;
}
export interface IColumn extends FunctionComponent<ColumnPropsInner> {
    __PRO_TABLE_COLUMN?: boolean;
}
export declare const ColumnDefaultProps: ColumnPropsBase;
declare const Column: IColumn;
export default Column;
export declare function minColumnWidth(col: ColumnProps, store: TableStore): number;
export declare function columnWidth(col: ColumnProps, store: TableStore): number;
