mirror of
https://github.com/ant-design/ant-design.git
synced 2025-01-18 06:03:38 +08:00
2010 lines
57 KiB
TypeScript
2010 lines
57 KiB
TypeScript
// originated by: bang88 <https://github.com/bang88>, Bruce Mitchener <https://github.com/waywardmonkeys/>
|
||
|
||
import * as React from 'react'
|
||
|
||
|
||
// Affix
|
||
interface AffixProps {
|
||
/**
|
||
* 距离窗口顶部达到指定偏移量后触发
|
||
*/
|
||
offsetTop?:number,
|
||
offsetBottom?:number,
|
||
style?:React.CSSProperties
|
||
}
|
||
/**
|
||
* # Affix
|
||
* 将页面元素钉在可视范围。
|
||
* ## 何时使用
|
||
* 当内容区域比较长,需要滚动页面时,这部分内容对应的操作或者导航需要在滚动范围内始终展现。常用于侧边菜单和按钮组合。
|
||
* 页面可视范围过小时,慎用此功能以免遮挡页面内容。
|
||
*/
|
||
export class Affix extends React.Component<AffixProps, {}> {
|
||
}
|
||
|
||
type AlertType = 'success' | 'info' | 'warning' | 'error'
|
||
|
||
// Alert
|
||
interface AlertProps {
|
||
/**
|
||
* 必选参数,指定警告提示的样式,有四种选择`success`、`info`、`warn`、`error`
|
||
*/
|
||
type:AlertType,
|
||
/**可选参数,默认不显示关闭按钮 */
|
||
closable?:boolean,
|
||
/**可选参数,自定义关闭按钮 */
|
||
closeText?:React.ReactNode,
|
||
/**必选参数,警告提示内容 */
|
||
message:React.ReactNode,
|
||
/**可选参数,警告提示的辅助性文字介绍 */
|
||
description?:React.ReactNode,
|
||
/** 固定状态改变时触发的回调函数 */
|
||
onChange?:(affixed: boolean) => void,
|
||
/**可选参数,关闭时触发的回调函数 */
|
||
onClose?:Function,
|
||
/**可选参数,是否显示辅助图标 */
|
||
showIcon?:boolean,
|
||
|
||
style?:React.CSSProperties
|
||
}
|
||
|
||
/**
|
||
* # Alert
|
||
* 警告提示,展现需要关注的信息。
|
||
|
||
* ## 何时使用
|
||
|
||
* - 当某个页面需要向用户显示警告的信息时。
|
||
* - 非浮层的静态展现形式,始终展现,不会自动消失,用户可以点击关闭。
|
||
* */
|
||
export class Alert extends React.Component<AlertProps, {}> {
|
||
}
|
||
|
||
|
||
interface BadgeProps {
|
||
/** 展示的数字,大于 overflowCount 时显示为 `${overflowCount}+`,为 0 时隐藏*/
|
||
count:number,
|
||
/** 展示封顶的数字值*/
|
||
overflowCount?:number,
|
||
/** 不展示数字,只有一个小红点*/
|
||
dot?:boolean,
|
||
|
||
style?:React.CSSProperties
|
||
}
|
||
// Badge
|
||
/**
|
||
* #Badge
|
||
*
|
||
* 图标右上角的圆形徽标数字。
|
||
|
||
* ## 何时使用
|
||
|
||
* 一般出现在通知图标或头像的右上角,用于显示需要处理的消息条数,通过醒目视觉形式吸引用户处理。
|
||
*
|
||
*/
|
||
export class Badge extends React.Component<BadgeProps, {}> {
|
||
}
|
||
|
||
type ButtonType = 'primary' | 'ghost' | 'dashed'
|
||
type ButtonShape = 'circle' | 'circle-outline'
|
||
type ButtonSize = 'small' | 'large'
|
||
// Button
|
||
interface ButtonProps {
|
||
/** 设置按钮类型,可选值为 `primary` `ghost` 或者不设 */
|
||
type?:ButtonType,
|
||
/** 设置 `button` 原生的 `type` 值,可选值请参考 HTML标准*/
|
||
htmlType?:string,
|
||
|
||
icon?:string,
|
||
/** 设置按钮形状,可选值为 `circle` `circle-outline` 或者不设*/
|
||
shape?:ButtonShape,
|
||
/** 设置按钮大小,可选值为 `small` `large` 或者不设*/
|
||
size?:ButtonSize,
|
||
/** `click` 事件的 handler*/
|
||
onClick?:React.FormEventHandler,
|
||
/** 设置按钮载入状态*/
|
||
loading?:boolean,
|
||
|
||
disabled?:boolean,
|
||
|
||
style?:React.CSSProperties
|
||
}
|
||
|
||
|
||
interface ButtonGroupProps {
|
||
/** 设置按钮大小,可选值为 `small` `large` 或者不设*/
|
||
size?:ButtonSize,
|
||
|
||
style?:React.CSSProperties
|
||
}
|
||
|
||
/**
|
||
可以将多个 `Button` 放入 `Button.Group` 的容器中。
|
||
|
||
通过设置 `size` 为 `large` `small` 分别把按钮组合设为大、小尺寸。若不设置 `size`,则尺寸为中。*/
|
||
declare class ButtonGroup extends React.Component<ButtonGroupProps, {}> {
|
||
}
|
||
|
||
/**
|
||
* #Button
|
||
按钮用于开始一个即时操作。
|
||
|
||
## 何时使用
|
||
|
||
标记了一个(或封装一组)操作命令,响应用户点击行为,触发相应的业务逻辑。*/
|
||
export class Button extends React.Component<ButtonProps, {}> {
|
||
static Group:typeof ButtonGroup
|
||
}
|
||
|
||
// Breadcrumb
|
||
|
||
interface BreadcrumbItemProps {
|
||
/** 链接,如不传则不可点击 */
|
||
href?:string
|
||
}
|
||
export class BreadcrumbItem extends React.Component<BreadcrumbItemProps, {}> {
|
||
}
|
||
|
||
interface BreadcrumbProps {
|
||
prefixCls?:string,
|
||
/** router 的路由栈信息 */
|
||
routes?:Array<React.ReactNode>,
|
||
/** 路由的参数*/
|
||
params?:Object,
|
||
/** 分隔符自定义*/
|
||
separator?:string | React.ReactNode,
|
||
linkRender?:(path:string, name:string) => React.ReactNode,
|
||
nameRender?:(name:string) => React.ReactNode
|
||
|
||
style?:React.CSSProperties
|
||
}
|
||
/**
|
||
* #Breadcrumb
|
||
显示当前页面在系统层级结构中的位置,并能向上返回。
|
||
|
||
## 何时使用
|
||
|
||
- 当系统拥有超过两级以上的层级结构时;
|
||
- 当需要告知用户“你在哪里”时;
|
||
- 当需要向上导航的功能时。*/
|
||
export class Breadcrumb extends React.Component<BreadcrumbProps, {}> {
|
||
static Item:typeof BreadcrumbItem
|
||
}
|
||
|
||
export interface GregorianCalendar {
|
||
getMonth():number,
|
||
getYear():number,
|
||
getDayOfMonth():string,
|
||
getHourOfDay():string,
|
||
getMinutes():number,
|
||
getSeconds():number,
|
||
getMilliSeconds():number,
|
||
getWeekOfYear():number,
|
||
getWeekOfMonth():number,
|
||
getDayOfYear():number,
|
||
getDayOfWeek():number,
|
||
getDayOfWeekInMonth():number,
|
||
getWeekYear():number,
|
||
getWeeksInWeekYear():number
|
||
}
|
||
|
||
type CalendarMode = 'month' | 'year';
|
||
|
||
// Calendar
|
||
interface CalendarProps {
|
||
/** 自定义渲染月单元格*/
|
||
monthCellRender?:(value:GregorianCalendar, locale:any) => React.ReactNode,
|
||
/** 自定义渲染日期单元格*/
|
||
dateCellRender?:(value:GregorianCalendar) => React.ReactNode,
|
||
/** 是否全屏显示*/
|
||
fullscreen?:boolean,
|
||
/** 国际化配置*/
|
||
locale?:Object,
|
||
prefixCls?:string,
|
||
className?:string,
|
||
/** 日期面板变化回调*/
|
||
onPanelChange?:(value:GregorianCalendar, mode:CalendarMode) => void,
|
||
/** 展示日期*/
|
||
value?:Date,
|
||
/** 默认展示日期*/
|
||
defaultValue?:Date,
|
||
/** 初始模式,`month/year`*/
|
||
mode?:CalendarMode,
|
||
|
||
style?:React.CSSProperties
|
||
}
|
||
/**
|
||
* #Calendar
|
||
按照日历形式展示数据的容器。
|
||
|
||
## 何时使用
|
||
|
||
当数据是日期或按照日期划分时,例如日程、课表、价格日历等,农历等。目前支持年/月切换。
|
||
*/
|
||
export class Calendar extends React.Component<CalendarProps, {}> {
|
||
}
|
||
|
||
type CarouselEffect = 'scrollx' | 'fade'
|
||
// Carousel
|
||
interface CarouselProps {
|
||
/** 动画效果函数,可取 scrollx, fade*/
|
||
effect?:CarouselEffect,
|
||
/** 是否显示面板指示点*/
|
||
dots?:boolean,
|
||
/** 垂直显示*/
|
||
vertical?:boolean,
|
||
/** 是否自动切换*/
|
||
autoplay?:boolean,
|
||
/** 动画效果*/
|
||
easing?:string,
|
||
/** 切换面板的回调*/
|
||
beforeChange?:(from:number, to:number) => void,
|
||
/** 切换面板的回调*/
|
||
afterChange?:(current:number) => void,
|
||
|
||
style?:React.CSSProperties
|
||
}
|
||
/**
|
||
* #Carousel
|
||
旋转木马,一组轮播的区域。
|
||
|
||
## 何时使用
|
||
|
||
- 当有一组平级的内容。
|
||
- 当内容空间不足时,可以用走马灯的形式进行收纳,进行轮播展现。
|
||
- 常用于一组图片或卡片轮播。
|
||
*/
|
||
export class Carousel extends React.Component<CarouselProps, {}> {
|
||
}
|
||
|
||
export interface CascaderOptionType {
|
||
value:string,
|
||
label:string,
|
||
disabled?:boolean,
|
||
children?:Array<CascaderOptionType>
|
||
}
|
||
|
||
type CascaderExpandTrigger = 'click' | 'hover'
|
||
// Cascader
|
||
interface CascaderProps {
|
||
/** 可选项数据源*/
|
||
options:Array<CascaderOptionType>,
|
||
/** 默认的选中项*/
|
||
defaultValue?:Array<CascaderOptionType>,
|
||
/** 指定选中项*/
|
||
value?:Array<CascaderOptionType>,
|
||
/** 选择完成后的回调*/
|
||
onChange?:(value:string, selectedOptions:CascaderOptionType) => void,
|
||
/** 选择后展示的渲染函数*/
|
||
displayRender?:(label:Array<string>) => React.ReactNode,
|
||
/** 自定义样式*/
|
||
style?:React.CSSProperties,
|
||
/** 自定义类名*/
|
||
className?:string,
|
||
/** 自定义浮层类名*/
|
||
popupClassName?:string,
|
||
/** 浮层预设位置:`bottomLeft` `bottomRight` `topLeft` `topRight` */
|
||
popupPlacement?:string,
|
||
/** 输入框占位文本*/
|
||
placeholder?:string,
|
||
/** 输入框大小,可选 `large` `default` `small` */
|
||
size?:string,
|
||
/** 禁用*/
|
||
disabled?:boolean,
|
||
/** 是否支持清除*/
|
||
allowClear?:boolean,
|
||
|
||
expandTrigger?:CascaderExpandTrigger,
|
||
|
||
changeOnSelect?:boolean
|
||
}
|
||
/**
|
||
* #Cascader
|
||
级联选择框。
|
||
|
||
|
||
## 何时使用
|
||
|
||
- 需要从一组相关联的数据集合进行选择,例如省市区,公司层级,事物分类等。
|
||
- 从一个较大的数据集合中进行选择时,用多级分类进行分隔,方便选择。
|
||
- 比起 Select 组件,可以在同一个浮层中完成选择,有较好的体验。*/
|
||
export class Cascader extends React.Component<CascaderProps, {}> {
|
||
}
|
||
|
||
// Checkbox
|
||
interface CheckboxProps {
|
||
/** 指定当前是否选中*/
|
||
checked?:boolean,
|
||
/** 初始是否选中*/
|
||
defaultChecked?:boolean,
|
||
/** 变化时回调函数*/
|
||
onChange?:React.FormEventHandler,
|
||
|
||
style?:React.CSSProperties
|
||
}
|
||
|
||
export interface CheckboxOptionType {
|
||
label:string,
|
||
value:string,
|
||
disabled?:boolean
|
||
}
|
||
|
||
interface CheckboxGroupProps {
|
||
/** 默认选中的选项*/
|
||
defaultValue?:Array<string>,
|
||
/** 指定选中的选项*/
|
||
value?:Array<string>,
|
||
/** 指定可选项*/
|
||
options?:Array<CheckboxOptionType> | Array<string>,
|
||
/** 变化时回调函数*/
|
||
onChange?:(checkedValue:Array<string>) => void,
|
||
|
||
disabled?:boolean,
|
||
|
||
style?:React.CSSProperties
|
||
}
|
||
/** Checkbox 组*/
|
||
declare class CheckboxGroup extends React.Component<CheckboxGroupProps, {}> {
|
||
}
|
||
/**
|
||
* #Checkbox
|
||
多选框。
|
||
|
||
## 何时使用
|
||
|
||
- 在一组可选项中进行多项选择时;
|
||
- 单独使用可以表示两种状态之间的切换,和 `switch` 类似。区别在于切换 `switch` 会直接触发状态改变,而 `checkbox` 一般用于状态标记,需要和提交操作配合。
|
||
*/
|
||
export class Checkbox extends React.Component<CheckboxProps, {}> {
|
||
static Group:typeof CheckboxGroup
|
||
}
|
||
|
||
// Collapse
|
||
|
||
interface CollapseProps {
|
||
/** 当前激活 tab 面板的 key*/
|
||
activeKey?:Array<string> | string,
|
||
/** 初始化选中面板的key */
|
||
defaultActiveKey?:Array<string>,
|
||
/** accordion 为 true 的时候,一次只可以打开一个面板 */
|
||
accordion?:boolean,
|
||
/** 切换面板的回调*/
|
||
onChange?:(key:string) => void,
|
||
|
||
style?:React.CSSProperties
|
||
}
|
||
|
||
interface CollapsePanelProps {
|
||
/** 对应 activeKey */
|
||
key:string,
|
||
/** 面板头内容*/
|
||
header:React.ReactNode,
|
||
|
||
style?:React.CSSProperties
|
||
}
|
||
|
||
declare class CollapsePanel extends React.Component<CollapsePanelProps, {}> {
|
||
}
|
||
/**
|
||
* #Collapse
|
||
可以折叠/展开的内容区域。
|
||
|
||
## 何时使用
|
||
|
||
- 对复杂区域进行分组和隐藏,保持页面的整洁。
|
||
- `手风琴` 是一种特殊的折叠面板,只允许单个内容区域展开。*/
|
||
export class Collapse extends React.Component<CollapseProps, {}> {
|
||
static Panel:typeof CollapsePanel
|
||
}
|
||
|
||
type DatePickerDateType = string | Date;
|
||
|
||
// DatePicker
|
||
interface DatePickerProps {
|
||
|
||
value?:DatePickerDateType,
|
||
defaultValue?:DatePickerDateType,
|
||
/** 展示的日期格式,配置参考 [GregorianCalendarFormat](https://github.com/yiminghe/gregorian-calendar-format)*/
|
||
format?:string,
|
||
/** 不可选择的日期*/
|
||
disabledDate?:Function,
|
||
/** 时间发生变化的回调,发生在用户选择时间时*/
|
||
onChange?:(date:Date, dateString:string) => void,
|
||
/** 禁用*/
|
||
disabled?:boolean,
|
||
style?:React.CSSProperties,
|
||
/** 格外的弹出日历样式*/
|
||
popupStyle?:React.CSSProperties,
|
||
/** 输入框大小,`large` 高度为 32px,`small` 为 22px,默认是 28px*/
|
||
size?:'large' | 'small',
|
||
/** 国际化配置*/
|
||
locale?:Object,
|
||
/** 增加时间选择功能*/
|
||
showTime?:boolean,
|
||
/** 点击确定按钮的回调*/
|
||
onOk?:(value:Date) => void,
|
||
/** 定义浮层的容器,默认为 body 上新建 div*/
|
||
getCalendarContainer?:Function
|
||
|
||
}
|
||
|
||
interface RangePickProps {
|
||
value?:Array<DatePickerDateType>,
|
||
defaultValue?:Array<DatePickerDateType>,
|
||
format?:string,
|
||
onChange?:(date:Array<Date>, dateString:Array<string>) => void,
|
||
style:React.CSSProperties,
|
||
showTime:boolean | Object
|
||
|
||
}
|
||
declare class RangePicker extends React.Component<RangePickProps, {}> {
|
||
}
|
||
|
||
interface MonthPickProps {
|
||
value?:DatePickerDateType,
|
||
defaultValue?:DatePickerDateType,
|
||
/** 展示的日期格式,配置参考 [GregorianCalendarFormat](https://github.com/yiminghe/gregorian-calendar-format)*/
|
||
format?:string,
|
||
/** 时间发生变化的回调,发生在用户选择时间时*/
|
||
onChange?:(date:Date) => void,
|
||
/** 禁用*/
|
||
disabled?:boolean,
|
||
style?:React.CSSProperties,
|
||
/** 格外的弹出日历样式*/
|
||
popupStyle?:React.CSSProperties,
|
||
/** 输入框大小,`large` 高度为 32px,`small` 为 22px,默认是 28px*/
|
||
size?:'large' | 'small',
|
||
/** 国际化配置*/
|
||
locale?:Object,
|
||
/** 定义浮层的容器,默认为 body 上新建 div*/
|
||
getCalendarContainer?:Function
|
||
}
|
||
declare class MonthPicker extends React.Component<MonthPickProps, {}> {
|
||
}
|
||
/**
|
||
* #DatePicker
|
||
输入或选择日期的控件。
|
||
|
||
## 何时使用
|
||
|
||
当用户需要输入一个日期,可以点击标准输入框,弹出日期面板进行选择。*/
|
||
export class DatePicker extends React.Component<DatePickerProps, {}> {
|
||
static RangePicker:typeof RangePicker
|
||
static MonthPicker:typeof MonthPicker
|
||
}
|
||
|
||
// Dropdown
|
||
|
||
interface DropdownProps {
|
||
/** 触发下拉的行为 ['click'] or ['hover']*/
|
||
trigger?:Array<string>,
|
||
/** 菜单节点*/
|
||
overlay:React.ReactNode,
|
||
|
||
style?:React.CSSProperties
|
||
}
|
||
|
||
interface DropdownButtonProps {
|
||
/** 按钮类型*/
|
||
type?:'primary' | 'ghost' | 'dash',
|
||
/** 点击左侧按钮的回调*/
|
||
onClick?:React.FormEventHandler,
|
||
/** 触发下拉的行为*/
|
||
trigger?:'click' | 'hover',
|
||
/** 菜单节点*/
|
||
overlay:React.ReactNode,
|
||
|
||
visible?:boolean,
|
||
|
||
onVisibleChange?:(visible:boolean) => void,
|
||
|
||
style?:React.CSSProperties
|
||
}
|
||
|
||
declare class DropdownButton extends React.Component<DropdownButtonProps, {}> {
|
||
}
|
||
/**
|
||
* #Dropdown
|
||
向下弹出的列表。
|
||
|
||
## 何时使用
|
||
|
||
当页面上的操作命令过多时,用此组件可以收纳操作元素。点击或移入触点,会出现一个下拉菜单。可在列表中进行选择,并执行相应的命令。
|
||
*/
|
||
export class Dropdown extends React.Component<DropdownProps, {}> {
|
||
static Button:typeof DropdownButton
|
||
}
|
||
|
||
export interface FormItemLabelColOption {
|
||
span:number,
|
||
offset:number
|
||
}
|
||
|
||
// Form
|
||
interface FormItemProps {
|
||
prefixCls?:string,
|
||
/** label 标签的文本*/
|
||
label?:string,
|
||
/** label 标签布局,通 `<Col>` 组件,设置 `span` `offset` 值,如 `{span: 3, offset: 12}`*/
|
||
labelCol?:FormItemLabelColOption,
|
||
/** 需要为输入控件设置布局样式时,使用该属性,用法同 labelCol*/
|
||
wrapperCol?:FormItemLabelColOption,
|
||
/** 提示信息,如不设置,则会根据校验规则自动生成 */
|
||
help?:string,
|
||
/** 额外的提示信息,和 help 类似,当需要错误信息和提示文案同时出现时,可以使用这个。*/
|
||
extra?:string,
|
||
/** 是否必填,如不设置,则会根据校验规则自动生成 */
|
||
validateStatus?:'success' | 'warning' | 'error' | 'validating',
|
||
/** 配合 validateStatus 属性使用,是否展示校验状态图标 */
|
||
hasFeedback?:boolean,
|
||
|
||
className?:string,
|
||
|
||
required?:boolean,
|
||
|
||
style?:React.CSSProperties
|
||
}
|
||
/**
|
||
表单一定会包含表单域,表单域可以是输入控件,标准表单域,标签,下拉菜单,文本域等。
|
||
|
||
这里我们分别封装了表单域 `<Form.Item />` 和输入控件 `<Input />`。*/
|
||
export class FormItem extends React.Component<FormItemProps, {}> {
|
||
}
|
||
|
||
interface FormComponentProps {
|
||
form:CreateFormOptions
|
||
}
|
||
export class FormComponent extends React.Component<FormComponentProps, {}> {
|
||
}
|
||
|
||
// function create
|
||
type CreateFormOptions = {
|
||
/** 获取一组输入控件的值,如不传入参数,则获取全部组件的值*/
|
||
getFieldsValue():(fieldNames?:Array<string>) => any
|
||
/** 获取一个输入控件的值*/
|
||
getFieldValue():(fieldName:string) => any
|
||
/** 设置一组输入控件的值*/
|
||
setFieldsValue():(obj:Object) => void
|
||
/** 设置一组输入控件的值*/
|
||
setFields():(obj:Object) => void
|
||
/** 校验并获取一组输入域的值与 Error*/
|
||
validateFields():(fieldNames?:Array<string>, options?:Object, callback?:(erros:any, values:any) => void) => any
|
||
/** 与 `validateFields` 相似,但校验完后,如果校验不通过的菜单域不在可见范围内,则自动滚动进可见范围 */
|
||
validateFieldsAndScroll():(fieldNames?:Array<string>, options?:Object, callback?:(erros:any, values:any) => void) => any
|
||
/** 获取某个输入控件的 Error */
|
||
getFieldError():(name:string) => Object
|
||
/** 判断一个输入控件是否在校验状态*/
|
||
isFieldValidating():(name:string) => Object
|
||
/**重置一组输入控件的值与状态,如不传入参数,则重置所有组件*/
|
||
resetFields():(names?:Array<string>) => void
|
||
|
||
getFieldsValue():(id:string, options:{
|
||
/** 子节点的值的属性,如 Checkbox 的是 'checked'*/
|
||
valuePropName?:string,
|
||
/** 子节点的初始值,类型、可选值均由子节点决定*/
|
||
initialValue?:any,
|
||
/** 收集子节点的值的时机*/
|
||
trigger?:string,
|
||
/** 校验子节点值的时机*/
|
||
validateTrigger?:string,
|
||
/** 校验规则,参见 [async-validator](https://github.com/yiminghe/async-validator) */
|
||
rules?:Array<any>,
|
||
/** 必填输入控件唯一标志*/
|
||
id?:string
|
||
}) => Array<any>
|
||
}
|
||
|
||
interface ComponentDecorator {
|
||
<T extends (typeof FormComponent)>(component:T):T;
|
||
}
|
||
interface FormProps {
|
||
prefixCls?:string,
|
||
/** 水平排列布局*/
|
||
horizontal?:boolean,
|
||
/** 行内排列布局*/
|
||
inline?:boolean,
|
||
/** 经 `Form.create()` 包装过的组件会自带 `this.props.form` 属性,直接传给 Form 即可*/
|
||
form?:Object,
|
||
/** 数据验证成功后回调事件*/
|
||
onSubmit?:React.FormEventHandler,
|
||
|
||
style?:React.CSSProperties
|
||
}
|
||
|
||
interface FormCreateOption {
|
||
/**
|
||
* 当 `Form.Item` 子节点的值发生改变时触发,可以把对应的值转存到 Redux store
|
||
*/
|
||
onFieldsChange?:(props:any, fields:Array<any>) => void,
|
||
/** 把 props 转为对应的值,可用于把 Redux store 中的值读出 */
|
||
mapPropsToFields?:(props:any) => void
|
||
}
|
||
/**
|
||
* #Form
|
||
具有数据收集、校验和提交功能的表单,包含复选框、单选框、输入框、下拉选择框等元素。
|
||
|
||
## 表单
|
||
|
||
我们为 `form` 提供了以下两种排列方式:
|
||
|
||
- 水平排列:可以实现 `label` 标签和表单控件的水平排列;
|
||
- 行内排列:使其表现为 `inline-block` 级别的控件。
|
||
*/
|
||
export class Form extends React.Component<FormProps, {}> {
|
||
static Item:typeof FormItem
|
||
|
||
static create(options?:FormCreateOption):ComponentDecorator
|
||
}
|
||
|
||
|
||
// Icon
|
||
interface IconProps {
|
||
/** 图标类型*/
|
||
type:string,
|
||
|
||
style?:React.CSSProperties
|
||
}
|
||
/**
|
||
* #Icon
|
||
有含义的矢量图形,每一个图标打倒一个敌人。
|
||
|
||
## 图标的命名规范
|
||
|
||
我们为每个图标赋予了语义化的命名,命名规则如下:
|
||
|
||
- 实心和描线图标保持同名,用 `-o` 来区分,比如 `question-circle`(实心) 和 `question-circle-o`(描线);
|
||
|
||
- 命名顺序:`[icon名]-[形状可选]-[描线与否]-[方向可选]`。
|
||
|
||
## 如何使用
|
||
|
||
使用 `<Icon />` 标签声明组件,指定图标对应的 type 属性,示例代码如下:
|
||
|
||
```html
|
||
<Icon type="link" />
|
||
```
|
||
|
||
最终会渲染为:
|
||
|
||
```html
|
||
<i class="anticon anticon-${type}"></i>
|
||
```*/
|
||
export class Icon extends React.Component<IconProps, {}> {
|
||
}
|
||
|
||
// Input
|
||
interface InputProps {
|
||
/** 【必须】声明 input 类型,同原生 input 标签的 type 属性*/
|
||
type?:string,
|
||
id?:string,
|
||
/** 控件大小,默认值为 default 。注:标准表单内的输入框大小限制为 large。 {'large','default','small'}*/
|
||
size?:string,
|
||
/** 是否禁用状态,默认为 false*/
|
||
disabled?:boolean,
|
||
value?:any,
|
||
/** 设置初始默认值*/
|
||
defaultValue?:any,
|
||
className?:string,
|
||
/** 带标签的 input,设置前置标签*/
|
||
addonBefore?:React.ReactNode,
|
||
/** 带标签的 input,设置后置标签*/
|
||
addonAfter?:React.ReactNode,
|
||
prefixCls?:string,
|
||
placeholder?:string,
|
||
onChange?:React.FormEventHandler,
|
||
style:React.CSSProperties
|
||
}
|
||
export class Input extends React.Component<InputProps, {}> {
|
||
}
|
||
|
||
// InputNumber
|
||
interface InputNumberProps {
|
||
/** 最小值*/
|
||
min:number,
|
||
/** 最大值*/
|
||
max:number,
|
||
/** 当前值*/
|
||
value?:number,
|
||
/** 每次改变步数*/
|
||
step?:number,
|
||
/** 初始值*/
|
||
defaultValue?:number,
|
||
/** 变化回调*/
|
||
onChange?:React.FormEventHandler,
|
||
/** 禁用*/
|
||
disabled?:boolean,
|
||
/** 输入框大小*/
|
||
size?:string,
|
||
|
||
style?:React.CSSProperties
|
||
|
||
}
|
||
/**
|
||
* #InputNumber
|
||
通过鼠标或键盘,输入范围内的数值。
|
||
|
||
## 何时使用
|
||
|
||
当需要获取标准数值时。*/
|
||
export class InputNumber extends React.Component<InputNumberProps, {}> {
|
||
}
|
||
|
||
|
||
// Layout
|
||
// Row
|
||
interface RowProps {
|
||
gutter?:number,
|
||
type?:'flex',
|
||
align?:'top' | 'middle' | 'bottom',
|
||
justify?:'start' | 'end' | 'center' | 'space-around' | 'space-between',
|
||
style?:React.CSSProperties,
|
||
className?:string,
|
||
}
|
||
export class Row extends React.Component<RowProps, {}> {
|
||
}
|
||
|
||
// Col
|
||
interface ColProps {
|
||
span?:number,
|
||
lg?: number,
|
||
md?:number,
|
||
sm?:number,
|
||
xs?:number,
|
||
order?:number,
|
||
offset?:string,
|
||
push?:string,
|
||
pull?:string,
|
||
className?:string,
|
||
style?:React.CSSProperties
|
||
}
|
||
/**
|
||
在多数业务情况下,Ant Design需要在设计区域内解决大量信息收纳的问题,因此在12栅格系统的基础上,我们将整个设计建议区域按照24等分的原则进行划分。
|
||
|
||
划分之后的信息区块我们称之为“盒子”。建议横向排列的盒子数量最多四个,最少一个。“盒子”在整个屏幕上占比见上图。设计部分基于盒子的单位定制盒子内部的排版规则,以保证视觉层面的舒适感。
|
||
|
||
## 概述
|
||
|
||
布局的栅格化系统,我们是基于行(row)和列(col)来定义信息区块的外部框架,以保证页面的每个区域能够稳健地排布起来。下面简单介绍一下它的工作原理:
|
||
|
||
* 通过`row`在水平方向建立一组`column`(简写col)
|
||
* 你的内容应当放置于`col`内,并且,只有`col`可以作为`row`的直接元素
|
||
* 栅格系统中的列是指1到24的值来表示其跨越的范围。例如,三个等宽的列可以使用`.col-8`来创建
|
||
* 如果一个`row`中的`col`总和超过24,那么多余的`col`会作为一个整体另起一行排列
|
||
|
||
## Flex 布局
|
||
|
||
我们的栅格化系统支持 Flex 布局,允许子元素在父节点内的水平对齐方式 - 居左、居中、居右、等宽排列、分散排列。子元素与子元素之间,支持顶部对齐、垂直居中对齐、底部对齐的方式。同时,支持使用 order 来定义元素的排列顺序。
|
||
|
||
Flex 布局是基于 24 栅格来定义每一个“盒子”的宽度,但排版则不拘泥于栅格。*/
|
||
export class Col extends React.Component<ColProps, {}> {
|
||
}
|
||
|
||
// Menu
|
||
interface MenuItemProps {
|
||
/**
|
||
* (是否禁用)
|
||
*
|
||
* @type {boolean}
|
||
*/
|
||
disabled?:boolean,
|
||
key?:string,
|
||
style?:React.CSSProperties
|
||
|
||
}
|
||
export class MenuItem extends React.Component<MenuItemProps, {}> {
|
||
}
|
||
|
||
interface MenuSubMenuProps {
|
||
disabled?:boolean,
|
||
key?:string,
|
||
/**
|
||
* (子菜单项值)
|
||
*
|
||
* @type {(string | React.ReactNode)}
|
||
*/
|
||
title:string | React.ReactNode,
|
||
/**
|
||
* (子菜单的菜单项)
|
||
*
|
||
* @type {(MenuItem | MenuSubMenu)}
|
||
*/
|
||
children?:Array<MenuItem | MenuSubMenu>,
|
||
|
||
onTitleClick?:Function,
|
||
|
||
style?:React.CSSProperties
|
||
}
|
||
export class MenuSubMenu extends React.Component<MenuSubMenuProps, {}> {
|
||
}
|
||
|
||
interface MenuItemGroupProps {
|
||
/**
|
||
* (分组标题)
|
||
*
|
||
* @type {(string | React.ReactNode)}
|
||
*/
|
||
title:string | React.ReactNode,
|
||
/**
|
||
* (分组的菜单项)
|
||
*
|
||
* @type {MenuItem}
|
||
*/
|
||
children?:Array<MenuItem | MenuSubMenu>,
|
||
|
||
style?:React.CSSProperties
|
||
}
|
||
export class MenuItemGroup extends React.Component<MenuItemGroupProps, {}> {
|
||
}
|
||
|
||
interface MenuProps {
|
||
id?: string,
|
||
/** 主题颜色*/
|
||
theme?:'light' | 'dark',
|
||
/** 菜单类型 enum: `vertical` `horizontal` `inline`*/
|
||
mode?:'vertical' | 'horizontal' | 'inline',
|
||
/** 当前选中的菜单项 key 数组*/
|
||
selectedKeys?:Array<string>,
|
||
/** 初始选中的菜单项 key 数组*/
|
||
defaultSelectedKeys?:Array<string>,
|
||
/** 当前展开的菜单项 key 数组*/
|
||
openKeys?:Array<string>,
|
||
/** 初始展开的菜单项 key 数组*/
|
||
defaultOpenKeys?:Array<string>,
|
||
|
||
onOpen?:Function,
|
||
|
||
onClose?:Function,
|
||
|
||
/**
|
||
* 被选中时调用
|
||
*
|
||
* @type {(item: any, key: string, selectedKeys: Array<string>) => void}
|
||
*/
|
||
onSelect?:(item:any, key:string, selectedKeys:Array<string>) => void,
|
||
/** 取消选中时调用*/
|
||
onDeselect?:(item:any, key:string, selectedKeys:Array<string>) => void,
|
||
/** 点击 menuitem 调用此函数*/
|
||
onClick?:(item:any, key:string) => void,
|
||
/** 根节点样式*/
|
||
style?:React.CSSProperties
|
||
}
|
||
/**
|
||
# Menu
|
||
为页面和功能提供导航的菜单列表。
|
||
|
||
## 何时使用
|
||
|
||
导航菜单是一个网站的灵魂,用户依赖导航在各个页面中进行跳转。一般分为顶部导航和侧边导航,顶部导航提供全局性的类目和功能,侧边导航提供多级结构来收纳和排列网站架构。
|
||
|
||
更多布局和导航的范例可以参考:[常用布局](/spec/layout)。*/
|
||
export class Menu extends React.Component<MenuProps, {}> {
|
||
static Item:typeof MenuItem
|
||
static SubMenu:typeof MenuSubMenu
|
||
static ItemGroup:typeof MenuItemGroup
|
||
static Divider:typeof React.Component
|
||
}
|
||
|
||
// Message
|
||
type MessageFunc = (/** 提示内容*/
|
||
content:string,
|
||
/** 自动关闭的延时*/
|
||
duration?:number) => void
|
||
/**
|
||
* #Message
|
||
全局展示操作反馈信息。
|
||
|
||
## 何时使用
|
||
|
||
- 可提供成功、警告和错误等反馈信息。
|
||
- 顶部居中显示并自动消失,是一种不打断用户操作的轻量级提示方式。*/
|
||
export const message:{
|
||
|
||
success:MessageFunc
|
||
error:MessageFunc
|
||
info:MessageFunc
|
||
loading:MessageFunc
|
||
config:(options:{
|
||
/**
|
||
* 消息距离顶部的位置
|
||
*
|
||
* @type {number}
|
||
*/
|
||
top:number,
|
||
duration?:number
|
||
}) => void
|
||
destroy:() => void
|
||
}
|
||
|
||
// Modal
|
||
type ModalFunc = (options:{
|
||
visible?:boolean,
|
||
title?:React.ReactNode | string,
|
||
content?:React.ReactNode | string,
|
||
onOk?:Function,
|
||
onCancel?:Function,
|
||
width?:string | number,
|
||
iconClassName?:string,
|
||
okText?:string,
|
||
cancelText?:string
|
||
}) => void
|
||
|
||
interface ModalProps {
|
||
/** 对话框是否可见*/
|
||
visible?:boolean,
|
||
/** 确定按钮 loading*/
|
||
confirmLoading?:boolean,
|
||
/** 标题*/
|
||
title?:React.ReactNode | string,
|
||
/** 是否显示右上角的关闭按钮*/
|
||
closable?:boolean,
|
||
/** 点击确定回调*/
|
||
onOk?:Function,
|
||
/** 点击遮罩层或右上角叉或取消按钮的回调*/
|
||
onCancel?:Function,
|
||
/** 宽度*/
|
||
width?:string | number,
|
||
/** 底部内容*/
|
||
footer?:React.ReactNode | string,
|
||
/** 确认按钮文字*/
|
||
okText?:string,
|
||
/** 取消按钮文字*/
|
||
cancelText?:string,
|
||
/** 点击蒙层是否允许关闭*/
|
||
maskClosable?:boolean,
|
||
|
||
style?:React.CSSProperties,
|
||
|
||
wrapClassName?:string
|
||
}
|
||
|
||
/**
|
||
# Modal
|
||
模态对话框。
|
||
|
||
## 何时使用
|
||
|
||
需要用户处理事务,又不希望跳转页面以致打断工作流程时,可以使用 `Modal` 在当前页面正中打开一个浮层,承载相应的操作。
|
||
|
||
另外当需要一个简洁的确认框询问用户时,可以使用精心封装好的 `ant.Modal.confirm()` 等方法。*/
|
||
export class Modal extends React.Component<ModalProps, {}> {
|
||
static info:ModalFunc
|
||
static success:ModalFunc
|
||
static error:ModalFunc
|
||
static confirm:ModalFunc
|
||
}
|
||
|
||
// Notification
|
||
type NotificationFunc = (config:{
|
||
/** 通知提醒标题,必选 */
|
||
message:React.ReactNode | string,
|
||
/** 通知提醒内容,必选*/
|
||
description:React.ReactNode | string,
|
||
/** 自定义关闭按钮*/
|
||
btn?:React.ReactNode | string,
|
||
/** 当前通知唯一标志*/
|
||
key?:string,
|
||
/** 点击默认关闭按钮时触发的回调函数*/
|
||
onClose?:Function,
|
||
/** 默认 4.5 秒后自动关闭,配置为 null 则不自动关闭*/
|
||
duration?:number
|
||
}) => void
|
||
/**
|
||
* #notification
|
||
全局展示通知提醒信息。
|
||
|
||
## 何时使用
|
||
|
||
在系统右上角显示通知提醒信息。经常用于以下情况:
|
||
|
||
- 较为复杂的通知内容。
|
||
- 带有交互的通知,给出用户下一步的行动点。
|
||
- 系统主动推送。*/
|
||
export const notification:{
|
||
success:NotificationFunc
|
||
error:NotificationFunc
|
||
info:NotificationFunc
|
||
warn:NotificationFunc
|
||
close:(key:string) => void
|
||
destroy:() => void
|
||
config:(options:{
|
||
/** 消息距离顶部的位置*/
|
||
top:number
|
||
}) => void
|
||
|
||
}
|
||
|
||
|
||
// Pagination
|
||
interface PaginationProps {
|
||
/** 当前页数*/
|
||
current?:number,
|
||
/** 默认的当前页数*/
|
||
defaultCurrent?:number,
|
||
/** 数据总数*/
|
||
total:number,
|
||
/** 初始的每页条数*/
|
||
defaultPageSize?:number,
|
||
/** 每页条数*/
|
||
pageSize?:number,
|
||
/** 页码改变的回调,参数是改变后的页码*/
|
||
onChange?:Function,
|
||
/** 是否可以改变 pageSize */
|
||
showSizeChanger?:boolean,
|
||
/** 指定每页可以显示多少条*/
|
||
pageSizeOptions?:Array<number>
|
||
/** pageSize 变化的回调 */
|
||
onShowSizeChange?:Function,
|
||
/** 是否可以快速跳转至某页*/
|
||
showQuickJumper?:boolean,
|
||
/** 当为「small」时,是小尺寸分页 */
|
||
size?:string,
|
||
/** 当添加该属性时,显示为简单分页*/
|
||
simple?:Object,
|
||
/** 用于显示总共有多少条数据*/
|
||
showTotal?:Function,
|
||
|
||
style?:React.CSSProperties
|
||
}
|
||
/**
|
||
* #Pagination
|
||
采用分页的形式分隔长列表,每次只加载一个页面。
|
||
|
||
## 何时使用
|
||
|
||
- 当加载/渲染所有数据将花费很多时间时;
|
||
- 可切换页码浏览数据。*/
|
||
export class Pagination extends React.Component<PaginationProps, {}> {
|
||
}
|
||
|
||
|
||
interface PopconfirmProps {
|
||
/**
|
||
* 气泡框位置,可选 `top/left/right/bottom`
|
||
*
|
||
* @type {(Placement | string)}
|
||
*/
|
||
placement?:'top' | 'left' | 'right' | 'bottom',
|
||
/** 确认框的描述*/
|
||
title?:string,
|
||
/** 点击确认的回调*/
|
||
onConfirm?:Function,
|
||
onCancel?:Function,
|
||
/** 显示隐藏的回调*/
|
||
onVisibleChange?:(visible:boolean) => void,
|
||
/** 确认按钮文字*/
|
||
okText?:string,
|
||
/** 取消按钮文字*/
|
||
cancelText?:string,
|
||
|
||
style?:React.CSSProperties
|
||
}
|
||
/**
|
||
* #Popconfirm
|
||
点击元素,弹出气泡式的确认框。
|
||
|
||
## 何时使用
|
||
|
||
目标元素的操作需要用户进一步的确认时,在目标元素附近弹出浮层提示,询问用户。
|
||
|
||
和 `confirm` 弹出的全屏居中模态对话框相比,交互形式更轻量。
|
||
*/
|
||
export class Popconfirm extends React.Component<PopconfirmProps, {}> {
|
||
}
|
||
|
||
type PopoverPlacement = 'top' | 'left' | 'right' | 'bottom' | 'topLeft' | 'topRight' | 'bottomLeft' | 'bottomRight' | 'leftTop' | 'leftBottom' | 'rightTop' | 'rightBottom'
|
||
type PropverTrigger = 'hover' | 'focus' | 'click'
|
||
|
||
interface PopoverProps {
|
||
/** 触发行为,可选 `hover/focus/click` */
|
||
trigger?:PropverTrigger,
|
||
/** 气泡框位置,可选 `top/left/right/bottom` `topLeft/topRight/bottomLeft/bottomRight` `leftTop/leftBottom/rightTop/rightBottom`*/
|
||
placement?:PopoverPlacement
|
||
/** 卡片标题*/
|
||
title?:React.ReactNode | string,
|
||
/** 卡片内容*/
|
||
overlayClassName?:string,
|
||
|
||
overlayStyle?:React.CSSProperties,
|
||
|
||
prefixCls?:string,
|
||
/** 用于手动控制浮层显隐*/
|
||
visible?:boolean,
|
||
/** 显示隐藏改变的回调*/
|
||
onVisibleChange?:Function,
|
||
|
||
getTooltipContainer?:Function,
|
||
|
||
content?:React.ReactNode,
|
||
|
||
style?:React.CSSProperties
|
||
}
|
||
/**
|
||
* #Popover
|
||
点击/鼠标移入元素,弹出气泡式的卡片浮层。
|
||
|
||
## 何时使用
|
||
|
||
当目标元素有进一步的描述和相关操作时,可以收纳到卡片中,根据用户的操作行为进行展现。
|
||
|
||
和 `Tooltip` 的区别是,用户可以对浮层上的元素进行操作,因此它可以承载更复杂的内容,比如链接或按钮等。
|
||
*/
|
||
export class Popover extends React.Component<PopoverProps, {}> {
|
||
}
|
||
|
||
// Progress
|
||
type ProgressStatus = 'success' | 'active' | 'exception'
|
||
type ProgressType = 'line' | 'circle'
|
||
|
||
interface ProgressProps {
|
||
type?:ProgressType,
|
||
percent?:number,
|
||
format?:(percent:number) => string,
|
||
status?:ProgressStatus,
|
||
showInfo?:boolean,
|
||
strokeWidth?:number,
|
||
width?:number,
|
||
style?:React.CSSProperties
|
||
}
|
||
/**
|
||
* #Progress
|
||
展示操作的当前进度。
|
||
|
||
## 何时使用
|
||
|
||
在操作需要较长时间才能完成时,为用户显示该操作的当前进度和状态。
|
||
|
||
* 当一个操作会打断当前界面,或者需要在后台运行,且耗时可能超过2秒时;
|
||
* 当需要显示一个操作完成的百分比时。*/
|
||
export class Progress extends React.Component<ProgressProps, {}> {
|
||
|
||
}
|
||
|
||
// Radio
|
||
type RadioGroupSize = 'large' | 'default' | 'small'
|
||
|
||
interface RadioGroupProps {
|
||
/** 选项变化时的回调函数*/
|
||
onChange?:React.FormEventHandler,
|
||
/** 用于设置当前选中的值*/
|
||
value?:string,
|
||
/** 默认选中的值*/
|
||
defaultValue?:string,
|
||
/** 大小,只对按钮样式生效*/
|
||
size?:RadioGroupSize,
|
||
|
||
style?:React.CSSProperties
|
||
}
|
||
export class RadioGroup extends React.Component<RadioGroupProps, {}> {
|
||
}
|
||
|
||
interface RadioProps {
|
||
/** 指定当前是否选中*/
|
||
checked?:boolean,
|
||
/** 初始是否选中*/
|
||
defaultChecked?:boolean,
|
||
/** 根据 value 进行比较,判断是否选中 */
|
||
value?:any,
|
||
|
||
style?:React.CSSProperties
|
||
}
|
||
/**
|
||
* #Radio
|
||
单选框。
|
||
|
||
## 何时使用
|
||
|
||
- 用于在多个备选项中选中单个状态。
|
||
- 和 Select 的区别是,Radio 所有选项默认可见,方便用户在比较中选择,因此选项不宜过多。
|
||
*/
|
||
export class Radio extends React.Component<RadioProps, {}> {
|
||
static Group:typeof RadioGroup
|
||
static Button:typeof RadioButton
|
||
}
|
||
|
||
interface RadioButtonProps {
|
||
value:string,
|
||
style?:React.CSSProperties
|
||
}
|
||
|
||
export class RadioButton extends React.Component<RadioButtonProps, {}> {
|
||
}
|
||
|
||
|
||
// Select
|
||
interface SelectOptionProps {
|
||
/** 是否禁用*/
|
||
disabled?:boolean,
|
||
/** 如果 react 需要你设置此项,此项值与 value 的值相同,然后可以省略 value 设置*/
|
||
key?:string,
|
||
/** 默认根据此属性值进行筛选*/
|
||
value:string
|
||
}
|
||
export class SelectOption extends React.Component<SelectOptionProps, {}> {
|
||
}
|
||
|
||
interface SelectOptGroupProps {
|
||
/** 组名*/
|
||
label:string | React.ReactNode,
|
||
key?:string
|
||
}
|
||
export class SelectOptGroup extends React.Component<SelectOptGroupProps, {}> {
|
||
}
|
||
|
||
interface SelectProps {
|
||
/** 指定当前选中的条目*/
|
||
value?:string | Array<any>,
|
||
/** 指定默认选中的条目*/
|
||
defaultValue?:string | Array<any>,
|
||
/** 支持多选*/
|
||
multiple?:boolean,
|
||
/** 支持清除, 单选模式有效*/
|
||
allowClear?:boolean,
|
||
/** 是否根据输入项进行筛选,可为一个函数,返回满足要求的 option 即可*/
|
||
filterOption?:boolean | Function,
|
||
/** 可以把随意输入的条目作为 tag,输入项不需要与下拉选项匹配*/
|
||
tags?:boolean,
|
||
/** 被选中时调用,参数为选中项的 value 值 */
|
||
onSelect?:(value:any, option:any) => void,
|
||
/** 取消选中时调用,参数为选中项的 option value 值,仅在 multiple 或 tags 模式下生效*/
|
||
onDeselect?:(value:any, option:any) => void,
|
||
/** 选中option,或input的value变化(combobox 模式下)时,调用此函数*/
|
||
onChange?:(value:any, label:any) => void,
|
||
/** 文本框值变化时回调*/
|
||
onSearch?:(value:string) => void,
|
||
/** 选择框默认文字*/
|
||
placeholder?:string,
|
||
/** 搜索框默认文字*/
|
||
searchPlaceholder?:string,
|
||
/** 当下拉列表为空时显示的内容*/
|
||
notFoundContent?:string,
|
||
/** 下拉菜单和选择器同宽*/
|
||
dropdownMatchSelectWidth?:boolean,
|
||
/** 搜索时过滤对应的 option 属性,如设置为 children 表示对内嵌内容进行搜索*/
|
||
optionFilterProp?:string,
|
||
/** 输入框自动提示模式*/
|
||
combobox?:SVGSymbolElement,
|
||
/** 选择框大小,可选 `large` `small` */
|
||
size?:string,
|
||
/** 在下拉中显示搜索框*/
|
||
showSearch?:boolean,
|
||
/** 是否禁用*/
|
||
disabled?:boolean,
|
||
style?:React.CSSProperties
|
||
}
|
||
/**
|
||
* #Select
|
||
类似 Select2 的选择器。
|
||
|
||
## 何时使用
|
||
|
||
弹出一个下拉菜单给用户选择操作,用于代替原生的选择器,或者需要一个更优雅的多选器时。*/
|
||
export class Select extends React.Component<SelectProps, {}> {
|
||
static Option:typeof SelectOption
|
||
static OptGroup:typeof SelectOptGroup
|
||
}
|
||
|
||
interface SliderMark {
|
||
[key:string]:any
|
||
}
|
||
|
||
// Slider
|
||
interface SliderProps {
|
||
/** 最小值*/
|
||
min?:number,
|
||
/** 最大值*/
|
||
max?:number,
|
||
/** 步长,取值必须大于 0,并且可被 (max - min) 整除。当 `marks` 不为空对象时,可以设置 `step` 为 `null`,此时 Slider 的可选值仅有 marks 标出来的部分。*/
|
||
step?:number,
|
||
/** 分段标记,key 的类型必须为 `Number` 且取值在闭区间 [min, max] 内*/
|
||
marks?:SliderMark,
|
||
/** 设置当前取值。当 `range` 为 `false` 时,使用 `Number`,否则用 `[Number, Number]`*/
|
||
value?:number | Array<number>,
|
||
/** 设置当前取值。当 `range` 为 `false` 时,使用 `Number`,否则用 `[Number, Number]`*/
|
||
defaultValue?:number | Array<number>,
|
||
/** `marks` 不为空对象时有效,值为 true 时表示值为包含关系,false 表示并列*/
|
||
included?:boolean,
|
||
/** 值为 `true` 时,滑块为禁用状态*/
|
||
disabled?:boolean,
|
||
/** 当 `range` 为 `true` 时,该属性可以设置是否允许两个滑块交换位置。*/
|
||
allowCross?:boolean,
|
||
/** 当 Slider 的值发生改变时,会触发 onChange 事件,并把改变后的值作为参数传入。*/
|
||
onChange?:Function,
|
||
/** 与 `onmouseup` 触发时机一致,把当前值作为参数传入。*/
|
||
onAfterChange?:Function,
|
||
/** Slider 会把当前值传给 `tipFormatter`,并在 Tooltip 中显示 `tipFormatter` 的返回值,若为 null,则隐藏 Tooltip。*/
|
||
tipFormatter?:Function | any,
|
||
range?:boolean,
|
||
|
||
style?:React.CSSProperties
|
||
}
|
||
/**
|
||
* #Slider
|
||
滑动型输入器,展示当前值和可选范围。
|
||
|
||
## 何时使用
|
||
|
||
当用户需要在数值区间/自定义区间内进行选择时,可为连续或离散值。*/
|
||
export class Slider extends React.Component<SliderProps, {}> {
|
||
}
|
||
|
||
// Spin
|
||
interface SpinProps {
|
||
/** spin组件中点的大小,可选值为 small default large*/
|
||
size?:'small' | 'default' | 'large',
|
||
/** 用于内嵌其他组件的模式,可以关闭 loading 效果*/
|
||
spinning?:boolean,
|
||
|
||
tip?:string,
|
||
|
||
style?:React.CSSProperties
|
||
}
|
||
/**
|
||
* #Spin
|
||
用于页面和区块的加载中状态。
|
||
|
||
## 何时使用
|
||
|
||
页面局部处于等待异步数据或正在渲染过程时,合适的加载动效会有效缓解用户的焦虑。
|
||
*/
|
||
export class Spin extends React.Component<SpinProps, {}> {
|
||
}
|
||
|
||
// Steps
|
||
type StepStatus = 'wait' | 'process' | 'finish' | 'error'
|
||
|
||
interface StepProps {
|
||
/** 可选参数,指定状态。当不配置该属性时,会使用父Steps元素的current来自动指定状态。*/
|
||
status?:StepStatus,
|
||
/** 必要参数,标题。*/
|
||
title:string | React.ReactNode,
|
||
/** 可选参数,步骤的详情描述。*/
|
||
description?:string | React.ReactNode,
|
||
/** 可选参数,步骤的Icon。如果不指定,则使用默认的样式。*/
|
||
icon?:string | React.ReactNode,
|
||
|
||
style?:React.CSSProperties
|
||
}
|
||
export class Step extends React.Component<StepProps, {}> {
|
||
}
|
||
|
||
interface StepsProps {
|
||
status?:StepStatus,
|
||
/** 可选参数,指定当前处理正在执行状态的步骤,从0开始记数。在子Step元素中,可以通过status属性覆盖状态。*/
|
||
current?:number,
|
||
/** 可选参数,指定大小(目前只支持普通和迷你两种大小)。 small, default */
|
||
size?:'default' | 'small',
|
||
/** 可选参数,指定步骤条方向(目前支持水平和竖直两种方向,默认水平方向)。*/
|
||
direction?:string,
|
||
/** 可选参数,指定步骤的详细描述文字的最大宽度。*/
|
||
maxDescriptionWidth?:number,
|
||
|
||
style?:React.CSSProperties
|
||
|
||
}
|
||
/**
|
||
* #Steps
|
||
引导用户按照流程完成任务的导航条。
|
||
|
||
## 何时使用
|
||
|
||
当任务复杂或者存在先后关系时,将其分解成一系列步骤,从而简化任务。*/
|
||
export class Steps extends React.Component<StepsProps, {}> {
|
||
static Step:typeof Step
|
||
}
|
||
|
||
// Switch
|
||
interface SwitchProps {
|
||
/** 指定当前是否选中*/
|
||
checked?:boolean,
|
||
/** 初始是否选中*/
|
||
defaultChecked?:boolean,
|
||
/** 变化时回调函数*/
|
||
onChange?:(checked:boolean) => void,
|
||
/** 选中时的内容*/
|
||
checkedChildren?:React.ReactNode,
|
||
/** 非选中时的内容*/
|
||
unCheckedChildren?:React.ReactNode,
|
||
/** 开关大小*/
|
||
size?:string,
|
||
|
||
style?:React.CSSProperties
|
||
}
|
||
/**
|
||
* #Switch
|
||
开关选择器。
|
||
|
||
## 何时使用
|
||
|
||
- 需要表示开关状态/两种状态之间的切换时;
|
||
- 和 `checkbox `的区别是,切换 `switch` 会直接触发状态改变,而 `checkbox` 一般用于状态标记,需要和提交操作配合。
|
||
*/
|
||
export class Switch extends React.Component<SwitchProps, {}> {
|
||
}
|
||
|
||
// Table
|
||
type RowSelectionType = 'checkbox' | 'radio'
|
||
|
||
type SelectedRowKeys = Array<any>
|
||
|
||
interface RowSelection {
|
||
type?:RowSelectionType,
|
||
selectedRowKeys?:SelectedRowKeys,
|
||
onChange?:(selectedRowKeys:SelectedRowKeys, selectedRows:any) => void,
|
||
getCheckboxProps?:(record:any) => void,
|
||
onSelect?:(record:any, selected:any, selectedRows:any) => void,
|
||
onSelectAll?:(rselectedecord:any, selectedRows:any, changeRows:any) => void,
|
||
style?:React.CSSProperties
|
||
}
|
||
|
||
type Columns = Array<Column>
|
||
interface Column {
|
||
/** React 需要的 key,建议设置*/
|
||
key:string | number,
|
||
/** 列头显示文字*/
|
||
title?:string | React.ReactNode,
|
||
/** 列数据在数据项中对应的 key*/
|
||
dataIndex?:string,
|
||
/** 生成复杂数据的渲染函数,参数分别为当前列的值,当前列数据,列索引,@return里面可以设置表格[行/列合并](#demo-colspan-rowspan)*/
|
||
render?:(text?:any, record?:any, index?:number) => React.ReactNode,
|
||
/** 表头的筛选菜单项*/
|
||
filters?:Array<any>,
|
||
/** 本地模式下,确定筛选的运行函数*/
|
||
onFilter?:Function,
|
||
/** 是否多选*/
|
||
filterMultiple?:boolean,
|
||
/** 排序函数,本地排序使用一个函数,需要服务端排序可设为 true */
|
||
sorter?:boolean | Function,
|
||
/** 表头列合并,设置为 0 时,不渲染*/
|
||
colSpan?:number,
|
||
/** 列宽度*/
|
||
width?:string | number,
|
||
/** 列的 className*/
|
||
className?:string,
|
||
|
||
fixed?:boolean | 'left' | 'right',
|
||
|
||
filteredValue?:Array<any>,
|
||
|
||
sortOrder?:boolean | 'ascend' | 'descend'
|
||
}
|
||
|
||
interface TableProps {
|
||
/** 列表项是否可选择*/
|
||
rowSelection?:RowSelection,
|
||
/** 分页器*/
|
||
pagination?:Object,
|
||
/** 正常或迷你类型 : `default` or `small` */
|
||
size?:string,
|
||
/** 数据数组*/
|
||
dataSource:Array<any>,
|
||
/** 表格列的配置描述*/
|
||
columns:Columns,
|
||
/** 表格行 key 的取值*/
|
||
rowKey?:(record:any, index:number) => string,
|
||
/** 额外的展开行*/
|
||
expandedRowRender?:Function,
|
||
/** 默认展开的行*/
|
||
defaultExpandedRowKeys?:Array<string>,
|
||
/** 分页、排序、筛选变化时触发*/
|
||
onChange?:(pagination:Object, filters:any, sorter:any) => void,
|
||
/** 页面是否加载中*/
|
||
loading?:boolean,
|
||
/** 默认文案设置,目前包括排序、过滤、空数据文案: `{ filterConfirm: '确定', filterReset: '重置', emptyText: '暂无数据' }` */
|
||
locale?:Object,
|
||
/** 展示树形数据时,每层缩进的宽度,以 px 为单位*/
|
||
indentSize?:number,
|
||
/** 处理行点击事件*/
|
||
onRowClick?:(record:any, index:number) => void,
|
||
/** 是否固定表头*/
|
||
useFixedHeader?:boolean,
|
||
/** 是否展示外边框和列边框*/
|
||
bordered?:boolean,
|
||
/** 是否显示表头*/
|
||
showHeader?:boolean,
|
||
/** 表格底部自定义渲染函数*/
|
||
footer?:(currentPageData:Object) => void,
|
||
|
||
style?:React.CSSProperties
|
||
}
|
||
/**
|
||
* #Table
|
||
展示行列数据。
|
||
|
||
## 何时使用
|
||
|
||
- 当有大量结构化的数据需要展现时;
|
||
- 当需要对数据进行排序、搜索、分页、自定义操作等复杂行为时。*/
|
||
export class Table extends React.Component<TableProps, {}> {
|
||
}
|
||
|
||
// Tabs
|
||
interface TabPaneProps {
|
||
/** 选项卡头显示文字*/
|
||
tab:React.ReactNode | string,
|
||
|
||
style?:React.CSSProperties
|
||
}
|
||
export class TabPane extends React.Component<TabPaneProps, {}> {
|
||
}
|
||
|
||
type TabsType = 'line' | 'card' | 'editable-card'
|
||
type TabsPosition = 'top' | 'right' | 'bottom' | 'left';
|
||
|
||
interface TabsProps extends React.Props<Tabs> {
|
||
/** 当前激活 tab 面板的 key */
|
||
activeKey?:string,
|
||
/** 初始化选中面板的 key,如果没有设置 activeKey*/
|
||
defaultActiveKey?:string,
|
||
/** 是否隐藏加号图标,在 `type="editable-card"` 时有效 */
|
||
hideAdd?: boolean,
|
||
/** 切换面板的回调*/
|
||
onChange?:(activeKey:string) => void,
|
||
/** tab 被点击的回调 */
|
||
onTabClick?:Function,
|
||
/** tab bar 上额外的元素 */
|
||
tabBarExtraContent?:React.ReactNode,
|
||
/** 页签的基本样式,可选 `line`、`card` `editable-card` 类型*/
|
||
type?:TabsType,
|
||
/** 页签位置,可选值有 `top` `right` `bottom` `left`*/
|
||
tabPosition?:TabsPosition,
|
||
/** 新增和删除页签的回调,在 `type="editable-card"` 时有效*/
|
||
onEdit?:(targetKey:string, action:any) => void,
|
||
|
||
style?:React.CSSProperties
|
||
}
|
||
/**
|
||
* #Tabs
|
||
选项卡切换组件。
|
||
|
||
## 何时使用
|
||
|
||
提供平级的区域将大块内容进行收纳和展现,保持界面整洁。
|
||
|
||
Ant Design 依次提供了三级选项卡,分别用于不同的场景。
|
||
|
||
- 卡片式的页签,提供可关闭的样式,常用于容器顶部。
|
||
- 标准线条式页签,用于容器内部的主功能切换,这是最常用的 Tabs。
|
||
- [RadioButton](/components/radio/#demo-radiobutton) 可作为更次级的页签来使用。*/
|
||
export class Tabs extends React.Component<TabsProps, {}> {
|
||
static TabPane:typeof TabPane
|
||
}
|
||
|
||
// Tag
|
||
interface TagProps {
|
||
/** 标签是否可以关闭*/
|
||
closable?:boolean,
|
||
/** 关闭时的回调*/
|
||
onClose?:Function,
|
||
/** 动画关闭后的回调*/
|
||
afterClose?:Function,
|
||
/** 标签的色彩*/
|
||
color?:string,
|
||
|
||
style?:React.CSSProperties
|
||
}
|
||
/**
|
||
* #Tag
|
||
进行标记和分类的小标签。
|
||
|
||
## 何时使用
|
||
|
||
- 用于标记事物的属性和维度。
|
||
- 进行分类。*/
|
||
export class Tag extends React.Component<TagProps, {}> {
|
||
}
|
||
|
||
// TimePicker
|
||
interface TimePickerProps {
|
||
/** 默认时间*/
|
||
value?:string | Date,
|
||
/** 初始默认时间*/
|
||
defaultValue?:string | Date,
|
||
/** 展示的时间格式 : "HH:mm:ss"、"HH:mm"、"mm:ss" */
|
||
format?:string,
|
||
/** 时间发生变化的回调*/
|
||
onChange?:(Date:Date) => void,
|
||
/** 禁用全部操作*/
|
||
disabled?:boolean,
|
||
/** 没有值的时候显示的内容*/
|
||
placeholder?:string,
|
||
/** 国际化配置*/
|
||
locale?:Object,
|
||
/** 隐藏禁止选择的选项*/
|
||
hideDisabledOptions?:boolean,
|
||
/** 禁止选择部分小时选项*/
|
||
disabledHours?:Function,
|
||
/** 禁止选择部分分钟选项*/
|
||
disabledMinutes?:Function,
|
||
/** 禁止选择部分秒选项*/
|
||
disabledSeconds?:Function,
|
||
|
||
style?:React.CSSProperties
|
||
}
|
||
/**
|
||
* #TimePicker
|
||
输入或选择时间的控件。
|
||
|
||
何时使用
|
||
--------
|
||
|
||
当用户需要输入一个时间,可以点击标准输入框,弹出时间面板进行选择。
|
||
*/
|
||
export class TimePicker extends React.Component<TimePickerProps, {}> {
|
||
}
|
||
|
||
// Timeline
|
||
interface TimeLineItemProps {
|
||
/** 指定圆圈颜色。*/
|
||
color?:string,
|
||
dot?:React.ReactNode,
|
||
style?:React.CSSProperties
|
||
}
|
||
export class TimeLineItem extends React.Component<TimeLineItemProps, {}> {
|
||
}
|
||
|
||
interface TimelineProps {
|
||
/** 指定最后一个幽灵节点是否存在或内容*/
|
||
pending?:boolean | React.ReactNode,
|
||
|
||
style?:React.CSSProperties
|
||
}
|
||
/**
|
||
* #Timeline
|
||
垂直展示的时间流信息。
|
||
|
||
## 何时使用
|
||
|
||
- 当有一系列信息需要从上至下按时间排列时;
|
||
- 需要有一条时间轴进行视觉上的串联时;*/
|
||
export class Timeline extends React.Component<TimelineProps, {}> {
|
||
static Item:typeof TimeLineItem
|
||
}
|
||
|
||
// Tooltip
|
||
interface TooltipProps {
|
||
/** 气泡框位置,可选 `top` `left` `right` `bottom` `topLeft` `topRight` `bottomLeft` `bottomRight` `leftTop` `leftBottom` `rightTop` `rightBottom`*/
|
||
placement?:PopoverPlacement,
|
||
/** 提示文字*/
|
||
title?:string | React.ReactNode,
|
||
|
||
style?:React.CSSProperties
|
||
}
|
||
/**
|
||
* #Tooltip
|
||
简单的文字提示气泡框。
|
||
|
||
## 何时使用
|
||
|
||
鼠标移入则显示提示,移出消失,气泡浮层不承载复杂文本和操作。
|
||
|
||
可用来代替系统默认的 `title` 提示,提供一个`按钮/文字/操作`的文案解释。*/
|
||
export class Tooltip extends React.Component<TooltipProps, {}> {
|
||
}
|
||
|
||
interface TransferItem {
|
||
key:number | string,
|
||
title:string,
|
||
description?:string,
|
||
chosen:boolean,
|
||
}
|
||
|
||
// Transfer
|
||
interface TransferProps {
|
||
/** 数据源*/
|
||
dataSource:Array<TransferItem>,
|
||
/** 每行数据渲染函数*/
|
||
render?:(record:TransferItem) => any,
|
||
/** 显示在右侧框数据的key集合*/
|
||
targetKeys:Array<string>,
|
||
/** 变化时回调函数*/
|
||
onChange?:(targetKeys:Array<TransferItem>, direction:string, moveKeys:any) => void,
|
||
/** 两个穿梭框的自定义样式*/
|
||
listStyle?:React.CSSProperties,
|
||
/** 自定义类*/
|
||
className?:string,
|
||
/** 标题集合,顺序从左至右*/
|
||
titles?:Array<string>,
|
||
/** 操作文案集合,顺序从上至下*/
|
||
operations?:Array<string>,
|
||
/** 是否显示搜索框*/
|
||
showSearch?:boolean,
|
||
/** 搜索框的默认值*/
|
||
searchPlaceholder?:string,
|
||
/** 当列表为空时显示的内容*/
|
||
notFoundContent?:React.ReactNode | string
|
||
/** 底部渲染函数*/
|
||
footer?:(props:any) => any,
|
||
|
||
style?:React.CSSProperties
|
||
}
|
||
/**
|
||
* #Transfer
|
||
双栏穿梭选择框。
|
||
|
||
## 何时使用
|
||
|
||
用直观的方式在两栏中移动元素,完成选择行为。
|
||
*/
|
||
export class Transfer extends React.Component<TransferProps, {}> {
|
||
}
|
||
|
||
|
||
// Tree
|
||
interface TreeNodeProps {
|
||
disabled?:boolean,
|
||
disableCheckbox?:boolean,
|
||
title?:string | React.ReactNode,
|
||
key?:string,
|
||
isLeaf?:boolean
|
||
}
|
||
export class TreeNode extends React.Component<TreeNodeProps, {}> {
|
||
}
|
||
|
||
interface TreeNodeEvent {
|
||
event:'check' | 'select',
|
||
node:TreeNode,
|
||
|
||
checked?:boolean,
|
||
checkedNodes?:Array<TreeNode>,
|
||
|
||
selected?:boolean,
|
||
selectedNodes?:Array<TreeNode>,
|
||
}
|
||
|
||
interface TreeNodeMouseEvent {
|
||
node:TreeNode,
|
||
event:React.MouseEventHandler,
|
||
}
|
||
|
||
interface TreeProps {
|
||
showLine?:boolean,
|
||
className?:string,
|
||
/** 是否支持多选*/
|
||
multiple?:boolean,
|
||
/**是否自动展开父节点 */
|
||
autoExpandParent?:boolean,
|
||
/**checkable状态下节点选择完全受控(父子节点选中状态不再关联)*/
|
||
checkStrictly?:boolean,
|
||
/** 是否支持选中*/
|
||
checkable?:boolean,
|
||
/** 默认展开所有树节点*/
|
||
defaultExpandAll?:boolean,
|
||
/** 默认展开指定的树节点*/
|
||
defaultExpandedKeys?:Array<string>,
|
||
/** (受控)展开指定的树节点*/
|
||
expandedKeys?:Array<string>,
|
||
/** (受控)选中复选框的树节点*/
|
||
checkedKeys?:Array<string>,
|
||
/** 默认选中复选框的树节点*/
|
||
defaultCheckedKeys?:Array<string>,
|
||
/** (受控)设置选中的树节点*/
|
||
selectedKeys?:Array<string>,
|
||
/** 默认选中的树节点*/
|
||
defaultSelectedKeys?:Array<string>,
|
||
/** 展开/收起节点时触发 */
|
||
onExpand?:(expandedKeys:Array<string>, {node: TreeNode, expanded: boolean}) => void | PromiseLike<any>,
|
||
/** 点击复选框触发*/
|
||
onCheck?:(checkedKeys:Array<string>, e:TreeNodeEvent) => void,
|
||
/** 点击树节点触发*/
|
||
onSelect?:(selectedKeys:Array<string>, e:TreeNodeEvent) => void,
|
||
/** filter some treeNodes as you need. it should return true */
|
||
filterTreeNode?:(node:TreeNode) => boolean,
|
||
/** 异步加载数据*/
|
||
loadData?:(node:TreeNode) => PromiseLike<any>,
|
||
/** 响应右键点击*/
|
||
onRightClick?:(options:TreeNodeMouseEvent) => void,
|
||
/** 设置节点可拖拽(IE>8)*/
|
||
draggable?:boolean,
|
||
/** 开始拖拽时调用*/
|
||
onDragStart?:(options:TreeNodeMouseEvent) => void,
|
||
/** dragenter 触发时调用*/
|
||
onDragEnter?:(options:TreeNodeMouseEvent) => void,
|
||
/** dragover 触发时调用 */
|
||
onDragOver?:(options:TreeNodeMouseEvent) => void,
|
||
/** dragleave 触发时调用*/
|
||
onDragLeave?:(options:TreeNodeMouseEvent) => void,
|
||
/** drop 触发时调用*/
|
||
onDrop?:(options:TreeNodeMouseEvent) => void,
|
||
|
||
style?:React.CSSProperties
|
||
}
|
||
/**
|
||
* #Tree
|
||
* 文件夹、组织架构、生物分类、国家地区等等,世间万物的大多数结构都是树形结构。使用`树控件`可以完整展现其中的层级关系,并具有展开收起选择等交互功能。
|
||
*/
|
||
export class Tree extends React.Component<TreeProps, {}> {
|
||
static TreeNode:typeof TreeNode
|
||
}
|
||
|
||
|
||
// TreeSelect
|
||
interface TreeSelectTreeNodeProps {
|
||
disabled?:boolean,
|
||
/** 此项必须设置(其值在整个树范围内唯一)*/
|
||
key:string,
|
||
/** 默认根据此属性值进行筛选*/
|
||
value?:string,
|
||
/** 树节点显示的内容*/
|
||
title?:React.ReactNode | string,
|
||
/** 是否是叶子节点*/
|
||
isLeaf?:boolean
|
||
}
|
||
export class TreeSelectTreeNode extends React.Component<TreeSelectTreeNodeProps, {}> {
|
||
}
|
||
|
||
interface TreeData {
|
||
key:string
|
||
value:string,
|
||
label:React.ReactNode,
|
||
children?:Array<TreeData>
|
||
}
|
||
|
||
interface TreeSelectProps {
|
||
style?:React.CSSProperties,
|
||
/** 指定当前选中的条目*/
|
||
value?:string | Array<any>,
|
||
/** 指定默认选中的条目*/
|
||
defaultValue?:string | Array<any>,
|
||
/** 支持多选*/
|
||
multiple?:boolean,
|
||
/** 可以把随意输入的条目作为 tag,输入项不需要与下拉选项匹配*/
|
||
tags?:boolean,
|
||
/** 被选中时调用,参数为选中项的 value 值*/
|
||
onSelect?:(value:any) => void,
|
||
/** 选中option,或input的value变化(combobox 模式下)时,调用此函数*/
|
||
onChange?:(value:any, label:any) => void,
|
||
/** 显示清除按钮*/
|
||
allowClear?:boolean,
|
||
/** 文本框值变化时回调*/
|
||
onSearch?:(value:any) => void,
|
||
/** 选择框默认文字*/
|
||
placeholder?:string,
|
||
/** 搜索框默认文字*/
|
||
searchPlaceholder?:string,
|
||
/** 下拉菜单的样式*/
|
||
dropdownStyle?:React.CSSProperties,
|
||
/** 下拉菜单和选择器同宽*/
|
||
dropdownMatchSelectWidth?:boolean,
|
||
/** 输入框自动提示模式*/
|
||
combobox?:boolean,
|
||
/** 选择框大小,可选 `large` `small`*/
|
||
size?:'large' | 'small',
|
||
/** 在下拉中显示搜索框*/
|
||
showSearch?:boolean,
|
||
/** 是否禁用*/
|
||
disabled?:boolean,
|
||
/** 默认展开所有树节点*/
|
||
treeDefaultExpandAll?:boolean,
|
||
/** 显示checkbox*/
|
||
treeCheckable?:boolean,
|
||
/** 是否根据输入项进行筛选,返回值true*/
|
||
filterTreeNode?:(treeNode:any) => boolean,
|
||
/** 输入项过滤对应的 treeNode 属性*/
|
||
treeNodeFilterProp?:string,
|
||
/** 作为显示的prop设置*/
|
||
treeNodeLabelProp?:string,
|
||
/** treeNodes数据,如果设置则不需要手动构造TreeNode节点(如果value在整个树范围内不唯一,需要设置`key`其值为整个树范围内的唯一id*/
|
||
treeData?:Array<TreeData>,
|
||
|
||
treeDataSimpleMode?:boolean,
|
||
/** 异步加载数据*/
|
||
loadData?:(node:any) => void,
|
||
|
||
showCheckedStrategy?:'SHOW_ALL' | 'SHOW_PARENT' | 'SHOW_CHILD'
|
||
|
||
}
|
||
/**
|
||
* #TreeSelect
|
||
树型选择控件。
|
||
|
||
## 何时使用
|
||
|
||
类似 Select 的选择控件,可选择的数据结构是一个树形结构时,可以使用 TreeSelect,例如公司层级、学科系统、分类目录等等。
|
||
*/
|
||
export class TreeSelect extends React.Component<TreeSelectProps, {}> {
|
||
static TreeNode:typeof TreeSelectTreeNode
|
||
}
|
||
|
||
|
||
type UploadFileStatus = 'error' | 'success' | 'done' | 'uploading' | 'removed'
|
||
|
||
export interface HttpRequestHeader {
|
||
[key:string]:string;
|
||
}
|
||
|
||
interface File {
|
||
uid:number,
|
||
size:number,
|
||
name:string,
|
||
lastModifiedDate?:Date,
|
||
url?:string,
|
||
status?:UploadFileStatus,
|
||
percent?:number,
|
||
}
|
||
|
||
interface UploadChangeParam {
|
||
file:File,
|
||
fileList:Array<File>,
|
||
event?:{ percent:number },
|
||
}
|
||
|
||
// Upload
|
||
interface UploadProps {
|
||
/** 可选参数, 上传的文件 */
|
||
name?:string,
|
||
|
||
defaultFileList?:Array<File>,
|
||
|
||
fileList?:Array<File>,
|
||
/** 必选参数, 上传的地址 */
|
||
action:string,
|
||
/** 可选参数, 上传所需参数 */
|
||
data?:Object,
|
||
/** 可选参数, 设置上传的请求头部,IE10 以上有效*/
|
||
headers?:HttpRequestHeader,
|
||
/** 可选参数, 是否展示 uploadList, 默认开启 */
|
||
showUploadList?:boolean,
|
||
/** 可选参数, 是否支持多选文件,`ie10+` 支持。开启后按住 ctrl 可选择多个文件。*/
|
||
multiple?:boolean,
|
||
/** 可选参数, 接受上传的文件类型, 详见 input accept Attribute */
|
||
accept?:string,
|
||
/** 可选参数, 上传文件之前的钩子,参数为上传的文件,若返回 `false` 或者 Promise 则停止上传。**注意:该方法不支持老 IE**。*/
|
||
beforeUpload?:(file:File) => boolean | PromiseLike<any>,
|
||
/** 可选参数, 上传文件改变时的状态,详见 onChange */
|
||
onChange?:(info:UploadChangeParam) => void,
|
||
/** 上传列表的内建样式,支持两种基本样式 `text` or `picture` */
|
||
listType?:'text' | 'picture',
|
||
/** 自定义类名*/
|
||
className?:string,
|
||
|
||
onPreview?:(file:File) => void,
|
||
|
||
onRemove?:(file:File) => void,
|
||
|
||
supportServerRender?:boolean,
|
||
|
||
style?:React.CSSProperties
|
||
}
|
||
/**
|
||
* #Upload
|
||
文件选择上传和拖拽上传控件。
|
||
|
||
## 何时使用
|
||
|
||
上传是将信息(网页、文字、图片、视频等)通过网页或者上传工具发布到远程服务器上的过程。
|
||
|
||
- 当需要上传一个或一些文件时。
|
||
- 当需要展现上传的进度时。
|
||
- 当需要使用拖拽交互时。*/
|
||
export class Upload extends React.Component<UploadProps, {}> {
|
||
}
|
||
|
||
interface RateProps {
|
||
count?:number,
|
||
value?:number,
|
||
defaultValue?:number,
|
||
onChange?:(value:number) => void,
|
||
allowHalf?:boolean,
|
||
disabled?:boolean,
|
||
style?:React.CSSProperties
|
||
}
|
||
export class Rate extends React.Component<RateProps, {}> {
|
||
}
|
||
|
||
interface CardProps {
|
||
title?:React.ReactNode,
|
||
extra?:React.ReactNode,
|
||
bordered?:boolean,
|
||
bodyStyle?:React.CSSProperties,
|
||
style?:React.CSSProperties,
|
||
loading?:boolean
|
||
}
|
||
export class Card extends React.Component<CardProps, {}> {
|
||
}
|
||
|
||
interface LocaleProviderProps {
|
||
locale?:any
|
||
}
|
||
export class LocaleProvider extends React.Component<LocaleProviderProps, {}> {
|
||
}
|