ant-design/components/table/interface.tsx

286 lines
8.5 KiB
TypeScript
Raw Normal View History

2017-11-21 13:48:37 +08:00
import * as React from 'react';
import { SpinProps } from '../spin';
import { Store } from './createStore';
import { RadioChangeEvent } from '../radio';
import { CheckboxChangeEvent } from '../checkbox';
import { PaginationConfig } from '../pagination';
2019-08-05 18:38:10 +08:00
// eslint-disable-next-line import/prefer-default-export
export { PaginationConfig } from '../pagination';
2017-11-21 13:48:37 +08:00
2019-02-11 14:52:56 +08:00
export type CompareFn<T> = (a: T, b: T, sortOrder?: SortOrder) => number;
export type ColumnFilterItem = {
2019-02-15 11:15:43 +08:00
text: React.ReactNode;
2019-02-11 14:52:56 +08:00
value: string;
children?: ColumnFilterItem[];
};
2017-11-21 13:48:37 +08:00
2019-05-07 11:53:08 +08:00
export interface FilterDropdownProps {
prefixCls?: string;
setSelectedKeys?: (selectedKeys: string[]) => void;
selectedKeys?: string[];
confirm?: () => void;
clearFilters?: (selectedKeys: string[]) => void;
filters?: ColumnFilterItem[];
getPopupContainer?: (triggerNode: HTMLElement) => HTMLElement;
}
2017-11-21 13:48:37 +08:00
export interface ColumnProps<T> {
2018-12-07 16:17:45 +08:00
title?:
| React.ReactNode
2019-02-11 14:52:56 +08:00
| ((options: { filters: TableStateFilters; sortOrder?: SortOrder }) => React.ReactNode);
2017-11-21 13:48:37 +08:00
key?: React.Key;
dataIndex?: string; // Note: We can not use generic type here, since we need to support nested key, see #9393
2019-06-24 11:29:58 +08:00
render?: (text: any, record: T, index: number) => React.ReactNode;
align?: 'left' | 'right' | 'center';
2017-11-21 13:48:37 +08:00
filters?: ColumnFilterItem[];
2019-06-24 11:29:58 +08:00
onFilter?: (value: any, record: T) => boolean;
2017-11-21 13:48:37 +08:00
filterMultiple?: boolean;
2019-05-07 11:53:08 +08:00
filterDropdown?: React.ReactNode | ((props: FilterDropdownProps) => React.ReactNode);
2017-11-21 13:48:37 +08:00
filterDropdownVisible?: boolean;
onFilterDropdownVisibleChange?: (visible: boolean) => void;
sorter?: boolean | CompareFn<T>;
defaultSortOrder?: SortOrder;
2017-11-21 13:48:37 +08:00
colSpan?: number;
width?: string | number;
className?: string;
fixed?: boolean | ('left' | 'right');
filterIcon?: React.ReactNode | ((filtered: boolean) => React.ReactNode);
2019-06-24 11:29:58 +08:00
filteredValue?: any[];
2019-01-15 21:02:43 +08:00
sortOrder?: SortOrder | boolean;
2017-11-21 13:48:37 +08:00
children?: ColumnProps<T>[];
onCellClick?: (record: T, event: Event) => void;
onCell?: (record: T, rowIndex: number) => TableEventListeners;
onHeaderCell?: (props: ColumnProps<T>) => TableEventListeners;
sortDirections?: SortOrder[];
2017-11-21 13:48:37 +08:00
}
export interface AdditionalCellProps {
onClick?: React.MouseEventHandler<HTMLElement>;
[name: string]: any;
}
2017-11-21 13:48:37 +08:00
export interface TableComponents {
table?: React.ReactType;
2017-11-21 13:48:37 +08:00
header?: {
wrapper?: React.ReactType;
row?: React.ReactType;
cell?: React.ReactType;
2017-11-21 13:48:37 +08:00
};
body?: {
wrapper?: React.ReactType;
row?: React.ReactType;
cell?: React.ReactType;
2017-11-21 13:48:37 +08:00
};
}
export interface TableLocale {
filterTitle?: string;
filterConfirm?: React.ReactNode;
filterReset?: React.ReactNode;
emptyText?: React.ReactNode | (() => React.ReactNode);
selectAll?: React.ReactNode;
selectInvert?: React.ReactNode;
2018-09-17 17:57:01 +08:00
sortTitle?: string;
expand?: string;
collapse?: string;
2017-11-21 13:48:37 +08:00
}
export type RowSelectionType = 'checkbox' | 'radio';
2018-12-07 16:17:45 +08:00
export type SelectionSelectFn<T> = (
record: T,
selected: boolean,
selectedRows: Object[],
nativeEvent: Event,
) => void;
2017-11-21 13:48:37 +08:00
export type TableSelectWay = 'onSelect' | 'onSelectMultiple' | 'onSelectAll' | 'onSelectInvert';
2018-05-07 12:32:26 +08:00
2017-11-21 13:48:37 +08:00
export interface TableRowSelection<T> {
type?: RowSelectionType;
selectedRowKeys?: string[] | number[];
2018-12-21 16:32:48 +08:00
onChange?: (selectedRowKeys: string[] | number[], selectedRows: T[]) => void;
2017-11-21 13:48:37 +08:00
getCheckboxProps?: (record: T) => Object;
onSelect?: SelectionSelectFn<T>;
2018-12-21 16:32:48 +08:00
onSelectMultiple?: (selected: boolean, selectedRows: T[], changeRows: T[]) => void;
onSelectAll?: (selected: boolean, selectedRows: T[], changeRows: T[]) => void;
onSelectInvert?: (selectedRowKeys: string[] | number[]) => void;
2017-11-21 13:48:37 +08:00
selections?: SelectionItem[] | boolean;
hideDefaultSelections?: boolean;
fixed?: boolean;
columnWidth?: string | number;
selectWay?: TableSelectWay;
columnTitle?: string | React.ReactNode;
2017-11-21 13:48:37 +08:00
}
export type SortOrder = 'descend' | 'ascend';
export interface SorterResult<T> {
column: ColumnProps<T>;
order: SortOrder;
field: string;
columnKey: string;
}
export type TableSize = 'default' | 'middle' | 'small';
export interface ExpandIconProps<T> {
prefixCls: string;
expanded: boolean;
record: T;
needIndentSpaced: boolean;
expandable: boolean;
onExpand: (record: T, event?: React.MouseEvent) => void;
}
export interface TableCurrentDataSource<T> {
currentDataSource: T[];
}
export interface TableEventListeners {
onClick?: (arg: React.SyntheticEvent) => void;
onDoubleClick?: (arg: React.SyntheticEvent) => void;
onContextMenu?: (arg: React.SyntheticEvent) => void;
onMouseEnter?: (arg: React.SyntheticEvent) => void;
onMouseLeave?: (arg: React.SyntheticEvent) => void;
[name: string]: any; // https://github.com/ant-design/ant-design/issues/17245#issuecomment-504807714
}
2017-11-21 13:48:37 +08:00
export interface TableProps<T> {
prefixCls?: string;
dropdownPrefixCls?: string;
rowSelection?: TableRowSelection<T>;
pagination?: PaginationConfig | false;
size?: TableSize;
2017-11-21 13:48:37 +08:00
dataSource?: T[];
components?: TableComponents;
columns?: ColumnProps<T>[];
rowKey?: string | ((record: T, index: number) => string);
rowClassName?: (record: T, index: number) => string;
2018-12-07 16:17:45 +08:00
expandedRowRender?: (
record: T,
index: number,
indent: number,
expanded: boolean,
) => React.ReactNode;
2017-12-08 15:36:32 +08:00
defaultExpandAllRows?: boolean;
2017-11-21 13:48:37 +08:00
defaultExpandedRowKeys?: string[] | number[];
expandedRowKeys?: string[] | number[];
expandIcon?: (props: ExpandIconProps<T>) => React.ReactNode;
2017-11-21 13:48:37 +08:00
expandIconAsCell?: boolean;
expandIconColumnIndex?: number;
2017-12-08 15:36:32 +08:00
expandRowByClick?: boolean;
2017-11-21 13:48:37 +08:00
onExpandedRowsChange?: (expandedRowKeys: string[] | number[]) => void;
onExpand?: (expanded: boolean, record: T) => void;
onChange?: (
pagination: PaginationConfig,
filters: Record<keyof T, string[]>,
sorter: SorterResult<T>,
extra: TableCurrentDataSource<T>,
) => void;
2017-11-21 13:48:37 +08:00
loading?: boolean | SpinProps;
locale?: TableLocale;
2017-11-21 13:48:37 +08:00
indentSize?: number;
onRowClick?: (record: T, index: number, event: Event) => void;
onRow?: (record: T, index: number) => TableEventListeners;
onHeaderRow?: (columns: ColumnProps<T>[]) => TableEventListeners;
2017-11-21 13:48:37 +08:00
useFixedHeader?: boolean;
bordered?: boolean;
showHeader?: boolean;
footer?: (currentPageData: Object[]) => React.ReactNode;
title?: (currentPageData: Object[]) => React.ReactNode;
2018-12-07 16:17:45 +08:00
scroll?: { x?: boolean | number | string; y?: boolean | number | string };
2017-11-21 13:48:37 +08:00
childrenColumnName?: string;
bodyStyle?: React.CSSProperties;
className?: string;
style?: React.CSSProperties;
children?: React.ReactNode;
2019-01-08 17:27:41 +08:00
sortDirections?: SortOrder[];
getPopupContainer?: (triggerNode: HTMLElement) => HTMLElement;
2017-11-21 13:48:37 +08:00
}
export interface TableStateFilters {
[key: string]: string[];
}
export interface TableState<T> {
pagination: PaginationConfig;
2017-11-21 13:48:37 +08:00
filters: TableStateFilters;
sortColumn: ColumnProps<T> | null;
sortOrder?: SortOrder;
pivot?: number;
2017-11-21 13:48:37 +08:00
}
export type SelectionItemSelectFn = (key: string[]) => void;
2019-04-28 11:47:22 +08:00
type GetPopupContainer = (triggerNode?: HTMLElement) => HTMLElement;
2017-11-21 13:48:37 +08:00
export interface SelectionItem {
key: string;
text: React.ReactNode;
onSelect: SelectionItemSelectFn;
}
export interface SelectionCheckboxAllProps<T> {
store: Store;
locale: TableLocale;
2017-11-21 13:48:37 +08:00
disabled: boolean;
getCheckboxPropsByItem: (item: T, index: number) => { defaultChecked: boolean };
getRecordKey: (record: T, index?: number) => string;
2017-11-21 13:48:37 +08:00
data: T[];
prefixCls: string | undefined;
2019-06-24 11:29:58 +08:00
onSelect: (key: string, index: number, selectFunc: any) => void;
2017-11-21 13:48:37 +08:00
hideDefaultSelections?: boolean;
selections?: SelectionItem[] | boolean;
getPopupContainer?: GetPopupContainer;
2017-11-21 13:48:37 +08:00
}
export interface SelectionCheckboxAllState {
checked?: boolean;
indeterminate?: boolean;
2017-11-21 13:48:37 +08:00
}
export interface SelectionBoxProps {
store: Store;
type?: RowSelectionType;
defaultSelection: string[];
rowIndex: string;
name?: string;
2017-11-21 13:48:37 +08:00
disabled?: boolean;
onChange: (e: RadioChangeEvent | CheckboxChangeEvent) => void;
2017-11-21 13:48:37 +08:00
}
export interface SelectionBoxState {
checked?: boolean;
}
2018-05-07 12:32:26 +08:00
export interface SelectionInfo<T> {
selectWay: TableSelectWay;
record?: T;
checked?: boolean;
changeRowKeys?: React.Key[];
nativeEvent?: Event;
}
2017-11-21 13:48:37 +08:00
export interface FilterMenuProps<T> {
locale: TableLocale;
selectedKeys: string[];
column: ColumnProps<T>;
2019-06-24 11:29:58 +08:00
confirmFilter: (column: ColumnProps<T>, selectedKeys: string[]) => any;
2017-11-21 13:48:37 +08:00
prefixCls: string;
dropdownPrefixCls: string;
getPopupContainer?: GetPopupContainer;
2017-11-21 13:48:37 +08:00
}
export interface FilterMenuState<T> {
2017-11-21 13:48:37 +08:00
selectedKeys: string[];
valueKeys: { [name: string]: string };
keyPathOfSelectedItem: { [key: string]: string };
2017-11-21 13:48:37 +08:00
visible?: boolean;
prevProps: FilterMenuProps<T>;
2017-11-21 13:48:37 +08:00
}
export type PrepareParamsArgumentsReturn<T> = [
any,
string[],
Object,
{
2018-12-07 16:17:45 +08:00
currentDataSource: T[];
},
];