mirror of
https://github.com/ant-design/ant-design.git
synced 2025-01-21 08:29:18 +08:00
Merge branch 'master' of gitlab.alipay-inc.com:react-ui/ant-design
This commit is contained in:
commit
863ecbd6d4
45
.eslintrc
45
.eslintrc
@ -1,45 +0,0 @@
|
|||||||
{
|
|
||||||
"extends": ["eslint-config-airbnb"],
|
|
||||||
"env": {
|
|
||||||
"browser": true,
|
|
||||||
"node": true,
|
|
||||||
"mocha": true,
|
|
||||||
"jest": true,
|
|
||||||
"es6": true
|
|
||||||
},
|
|
||||||
"ecmaFeatures": {
|
|
||||||
"jsx": true,
|
|
||||||
"experimentalObjectRestSpread": true
|
|
||||||
},
|
|
||||||
"plugins": [
|
|
||||||
"markdown-antd",
|
|
||||||
"react",
|
|
||||||
"babel"
|
|
||||||
],
|
|
||||||
"rules": {
|
|
||||||
"constructor-super": 2,
|
|
||||||
"comma-dangle": 0,
|
|
||||||
"func-names": 0,
|
|
||||||
"guard-for-in": 0,
|
|
||||||
"one-var": [2, { "initialized": "never" }],
|
|
||||||
"prefer-const": 0,
|
|
||||||
"key-spacing": 0,
|
|
||||||
"no-eq-null": 0,
|
|
||||||
"no-else-return": 0,
|
|
||||||
"no-param-reassign": 0,
|
|
||||||
"no-this-before-super": 2,
|
|
||||||
"no-undef": 2,
|
|
||||||
"babel/object-shorthand": 0,
|
|
||||||
"react/jsx-no-duplicate-props": 2,
|
|
||||||
"react/sort-comp": 0,
|
|
||||||
"react/wrap-multilines": 0,
|
|
||||||
"react/no-multi-comp": 0,
|
|
||||||
"react/prop-types": 0,
|
|
||||||
"space-after-keywords": 0,
|
|
||||||
"space-before-blocks": 0,
|
|
||||||
"space-before-function-paren": 0,
|
|
||||||
"spaced-comment": 0,
|
|
||||||
"vars-on-top": 0,
|
|
||||||
"id-length": 0
|
|
||||||
}
|
|
||||||
}
|
|
39
.eslintrc.json
Normal file
39
.eslintrc.json
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
{
|
||||||
|
"extends": ["eslint-config-airbnb"],
|
||||||
|
"env": {
|
||||||
|
"browser": true,
|
||||||
|
"node": true,
|
||||||
|
"mocha": true,
|
||||||
|
"jest": true,
|
||||||
|
"es6": true
|
||||||
|
},
|
||||||
|
"parserOptions": {
|
||||||
|
"ecmaVersion": 6,
|
||||||
|
"ecmaFeatures": {
|
||||||
|
"jsx": true,
|
||||||
|
"experimentalObjectRestSpread": true
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"plugins": [
|
||||||
|
"markdown",
|
||||||
|
"react",
|
||||||
|
"babel"
|
||||||
|
],
|
||||||
|
"rules": {
|
||||||
|
"comma-dangle": 0,
|
||||||
|
"func-names": 0,
|
||||||
|
"prefer-const": 0,
|
||||||
|
"arrow-body-style": 0,
|
||||||
|
"react/sort-comp": 0,
|
||||||
|
"react/no-multi-comp": 0,
|
||||||
|
"react/prop-types": 0,
|
||||||
|
"react/prefer-es6-class": 0,
|
||||||
|
"react/prefer-stateless-function": 0,
|
||||||
|
"react/jsx-closing-bracket-location": 0,
|
||||||
|
"react/jsx-no-bind": 0,
|
||||||
|
"no-param-reassign": 0,
|
||||||
|
"no-return-assign": 0,
|
||||||
|
"max-len": 0,
|
||||||
|
"consistent-return": 0
|
||||||
|
}
|
||||||
|
}
|
56
.github/CONTRIBUTING.md
vendored
Normal file
56
.github/CONTRIBUTING.md
vendored
Normal file
@ -0,0 +1,56 @@
|
|||||||
|
# Contributing to Ant Design
|
||||||
|
|
||||||
|
The following is a set of guidelines for contributing to Ant Design. Please spend several minutes in reading these guidelines before you create an issue or pull request.
|
||||||
|
|
||||||
|
Anyway, these are just guidelines, not rules, use your best judgment and feel free to propose changes to this document in a pull request.
|
||||||
|
|
||||||
|
|
||||||
|
## Do your homework before asking a question
|
||||||
|
|
||||||
|
It's a great idea to read Eric Steven Raymond's [How To Ask Questions The Smart Way](http://www.catb.org/esr/faqs/smart-questions.html) twice before asking a question. But if you are busy now, I recommend to read [Don't post homework questions](http://www.catb.org/esr/faqs/smart-questions.html#homework) first.
|
||||||
|
|
||||||
|
The following guidelines are about *How to avoid Homework Questions*.
|
||||||
|
|
||||||
|
### 1. Read the documentation.
|
||||||
|
|
||||||
|
It sad but true that someone just glance(not read) [Ant Design's documentation](http://ant.design/). Please read the documentation closely. What's more, you can modify and run our demo with [CodePen](http://codepen.io/anon/pen/pgdXYp?editors=001). It's helpful to understand our documentation.
|
||||||
|
|
||||||
|
Tips: choose the corresponding documentation with versions selector which in the bottom-right corner.
|
||||||
|
|
||||||
|
### 2. Make sure that your question is about Ant Design, not React
|
||||||
|
|
||||||
|
Someone may think all of the questions that he/she meets in developing are about Ant Design, but it's not true. So, please read [React's documentaion](http://facebook.github.io/react/docs/getting-started.html) or just Google(not Baidu, seriously) your questions with keywork *React* first. If you are sure that your question is about Ant Design, go ahead.
|
||||||
|
|
||||||
|
### 3. Read the FAQ and search the issues list of Ant Design
|
||||||
|
|
||||||
|
Your questions may be asked and solved by others. So please spend several minutes on searching. Remember [DRY](https://en.wikipedia.org/wiki/Don%27t_repeat_yourself), both code and questions.
|
||||||
|
|
||||||
|
P.S.
|
||||||
|
|
||||||
|
1. [FAQ](https://github.com/ant-design/ant-design/wiki/FAQ)
|
||||||
|
1. [Issues list](https://github.com/ant-design/ant-design/issues)
|
||||||
|
|
||||||
|
## Close your issue if it's solved
|
||||||
|
|
||||||
|
It is a good habit which will save maintainers' time. Thank you!
|
||||||
|
|
||||||
|
## Providing a demo while reporting a bug
|
||||||
|
|
||||||
|
It would be helpful to provide a demo which can re-produce the bug 100%. Please fork this [CodePen](http://codepen.io/anon/pen/pgdXYp?editors=001) and re-produce the bug you met. Then, create an issue. The most important thing is: double check before claiming that you have found a bug.
|
||||||
|
|
||||||
|
|
||||||
|
## Tips about Feature Request
|
||||||
|
|
||||||
|
If you believe that Ant Design should provide some features, but it does not. You could create an issue to discuss. However, Ant Design is not Swiss Army Knife, there are some features which Ant Design will not support:
|
||||||
|
|
||||||
|
1. Request or operate data
|
||||||
|
|
||||||
|
|
||||||
|
## Tips about Pull Request
|
||||||
|
|
||||||
|
It's welcomed to pull request. And there are some tips about that:
|
||||||
|
|
||||||
|
1. It is a good habit to create a feature request issue to disscuss whether the feature is necessary before you implement it. However, it's unnecessary to create an issue to claim that you found a typo or improved the readability of documentaion, just create a pull request.
|
||||||
|
1. Run `npm run lint` and fix those errors before committing in order to keep consistent code style.
|
||||||
|
1. Rebase before creating a PR to keep commit history clear.
|
||||||
|
1. Add some descriptions and refer relative issues for you PR.
|
25
.github/ISSUE_TEMPLATE.md
vendored
Normal file
25
.github/ISSUE_TEMPLATE.md
vendored
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
If you want to ask a question, please read [some tips](https://github.com/ant-design/ant-design/blob/master/.github/CONTRIBUTING.md#do-your-homework-before-asking-a-question) first :-)
|
||||||
|
|
||||||
|
If you are going to report a bug, please answer the following questions, thank you!
|
||||||
|
|
||||||
|
## What you did
|
||||||
|
|
||||||
|
(e.g. I ate a hamburger)
|
||||||
|
|
||||||
|
## What you would like to happen
|
||||||
|
|
||||||
|
(e.g. I should be full)
|
||||||
|
|
||||||
|
## What actually happened
|
||||||
|
|
||||||
|
(e.g. But I am still hungry now T_T)
|
||||||
|
|
||||||
|
## Online demo
|
||||||
|
|
||||||
|
(e.g. http://codepen.io/anon/pen/pgdXYp?editors=001)
|
||||||
|
|
||||||
|
## Environment Information
|
||||||
|
|
||||||
|
- The version of antd(e.g. 0.12.0):
|
||||||
|
- Your operating system and it's version(e.g. OSX 10.11.0):
|
||||||
|
- Your browser and it's version(e.g. Chrome 48.0.0.0(64-bit)):
|
7
.github/PULL_REQUEST_TEMPLATE.md
vendored
Normal file
7
.github/PULL_REQUEST_TEMPLATE.md
vendored
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
First of all, thanks for your contribution! :-)
|
||||||
|
|
||||||
|
Please makes sure these boxes are checked before submitting your PR, thank you!
|
||||||
|
|
||||||
|
[ ] Run `npm run lint` and fix those errors before submitting in order to keep consistent code style.
|
||||||
|
[ ] Rebase before creating a PR to keep commit history clear.
|
||||||
|
[ ] Add some descriptions and refer relative issues for you PR.
|
2
.si.yml
2
.si.yml
@ -1,6 +1,6 @@
|
|||||||
before_deploy:
|
before_deploy:
|
||||||
- tnpm install && tnpm update
|
- tnpm install && tnpm update
|
||||||
- tnpm run just-deploy
|
- tnpm run site
|
||||||
options:
|
options:
|
||||||
branch: 'master'
|
branch: 'master'
|
||||||
dist: '_site'
|
dist: '_site'
|
||||||
|
@ -1,4 +1,7 @@
|
|||||||
|
sudo: false
|
||||||
|
|
||||||
language: node_js
|
language: node_js
|
||||||
|
|
||||||
node_js:
|
node_js:
|
||||||
- "4"
|
- "4"
|
||||||
|
- "5"
|
||||||
|
54
AUTHORS.txt
Normal file
54
AUTHORS.txt
Normal file
@ -0,0 +1,54 @@
|
|||||||
|
Benjy Cui <benjytrys@gmail.com>
|
||||||
|
Bozhao <yubz86@gmail.com>
|
||||||
|
Cam Song <neosoyn@gmail.com>
|
||||||
|
Cee Cirno <i@cee.moe>
|
||||||
|
Daqi Song <dqaria@gmail.com>
|
||||||
|
Emma <sima.zhang1990@gmail.com>
|
||||||
|
Eward Song <eward.song@gmail.com>
|
||||||
|
Guan Hao <raptium@gmail.com>
|
||||||
|
Haibin Yu <haibin.yu@oceanwing.com>
|
||||||
|
Hanai <ihanai1991@gmail.com>
|
||||||
|
James <james@schoolshape.com>
|
||||||
|
KgTong <kgtong1992@gmail.com>
|
||||||
|
Leon Shi <superRaytin@163.com>
|
||||||
|
MG12 <wuzhao.mail@gmail.com>
|
||||||
|
Neverland <chenjiahan@buaa.edu.cn>
|
||||||
|
Pyiner <lijiuyang1992@gmail.com>
|
||||||
|
RaoHai <surgesoft@gmail.com>
|
||||||
|
SimaQ <sima.zhang1990@gmail.com>
|
||||||
|
The Gitter Badger <badger@gitter.im>
|
||||||
|
Yuwei Ba <i@xiaoba.me>
|
||||||
|
Zap <a124116186@qq.com>
|
||||||
|
afc163 <afc163@gmail.com>
|
||||||
|
chencheng (云谦) <sorrycc@gmail.com>
|
||||||
|
elrrrrrrr <elrrrrrrr@gmail.com>
|
||||||
|
genie <genie88@163.com>
|
||||||
|
haoxin <coderhaoxin@outlook.com>
|
||||||
|
ioldfish <fish.wangl@gmail.com>
|
||||||
|
jiang <155259966@qq.com>
|
||||||
|
kasinooya <kasinooya@gmail.com>
|
||||||
|
leon.shi <superRaytin@163.com>
|
||||||
|
lgmcolin <gengmin.lgm@gmail.com>
|
||||||
|
lgmcolin <lgmcolin@gmail.com>
|
||||||
|
pizn <pizner@gmail.com>
|
||||||
|
popomore <sakura9515@gmail.com>
|
||||||
|
shelwin <wxfans@gmail.com>
|
||||||
|
shouyong <enlangs@163.com>
|
||||||
|
simaQ <sima.zhang1990@gmail.com>
|
||||||
|
sorrycc <sorrycc@gmail.com>
|
||||||
|
tom <caolvchong@gmail.com>
|
||||||
|
ustccjw <317713370@qq.com>
|
||||||
|
warmhug <hualei5280@gmail.com>
|
||||||
|
xiaoshuai <tangshuaiji@tangshuaijideMacBook-Pro.local>
|
||||||
|
yiminghe <yiminghe@gmail.com>
|
||||||
|
yubozhao <yubz86@gmail.com>
|
||||||
|
yuche <i@yuche.me>
|
||||||
|
zhangpc <zhangpc@tenxcloud.com>
|
||||||
|
zhujun24 <zhujun87654321@gmail.com>
|
||||||
|
zilong <jzlxiaohei@163.com>
|
||||||
|
zinkey <yaya@uloveit.com.cn>
|
||||||
|
低位 <zhujun87654321@gmail.com>
|
||||||
|
偏右 <afc163@gmail.com>
|
||||||
|
唐帅佶 <tangshuaiji@tangshuaijideMacBook-Pro.local>
|
||||||
|
白羊座小葛 <abeyuhang@gmail.com>
|
||||||
|
逸达 <dqaria@gmail.com>
|
271
CHANGELOG.md
271
CHANGELOG.md
@ -4,15 +4,209 @@
|
|||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
## 0.11.0 `2015-12-25`
|
## 0.12.8
|
||||||
|
|
||||||
- 移除默认加载的样式文件,样式现在需要独立加载。
|
`2016-03-06`
|
||||||
|
|
||||||
|
- 新增 `heart` `calculator` 图标。
|
||||||
|
- Table 补充了 `showHeader` 和 `footer` 属性。
|
||||||
|
- Modal 补充了 `maskClosable` 属性。
|
||||||
|
- 修正一个 Tag 和 Popover 配合使用的问题。[#1111](https://github.com/ant-design/ant-design/issues/1111)
|
||||||
|
- 将 TreeSelect 的 `treeDefaultExpandAll` 默认属性设为 false,并优化了性能。
|
||||||
|
- 修复 RadioGroup 无法垂直布局的问题。[#1119](https://github.com/ant-design/ant-design/issues/1119)
|
||||||
|
- 统一了 less 文件的部分变量。
|
||||||
|
- 修正部分组件的样式。
|
||||||
|
|
||||||
|
## 0.12.7
|
||||||
|
|
||||||
|
`2016-03-03`
|
||||||
|
|
||||||
|
- 修正 Table 的 `rowSelect.onSelectAll` 的第三个参数 `deselectedRows` 为 `changeRows`,记录每次变化的列。
|
||||||
|
|
||||||
|
## 0.12.6
|
||||||
|
|
||||||
|
`2016-03-02`
|
||||||
|
|
||||||
|
- 优化 Table 本地排序在 Chrome 下的稳定性问题。
|
||||||
|
- 修正 Pagination 的 pageSize 属性为受控属性,并补充了 `defaultPageSize` 属性。[#1087](https://github.com/ant-design/ant-design/issues/1087)
|
||||||
|
- 优化 Select 的 combobox 模式的交互体验。
|
||||||
|
- 升级 react-slick 依赖到 `0.11`,修复自动播放有时会失效的问题。[#1009](https://github.com/ant-design/ant-design/issues/1009)
|
||||||
|
- 修复 TreeSelect 的 allowClear 属性失效的问题。[#1084](https://github.com/ant-design/ant-design/issues/1084)
|
||||||
|
- 修复 Input 组件的 className 属性失效的问题。[#1103](https://github.com/ant-design/ant-design/issues/1103)
|
||||||
|
- 修复 Dropdown 的 onClick 属性失效的问题。[#1097](https://github.com/ant-design/ant-design/issues/1097)
|
||||||
|
- 修复多个 CheckboxGroup 选项互相影响的问题。[#1101](https://github.com/ant-design/ant-design/pull/1101)
|
||||||
|
- 修复 FormItem 的子元素为 `null` 时报错的问题。
|
||||||
|
- 修复 Table 组件的选择功能和展开功能配合使用的问题。[#1102](https://github.com/ant-design/ant-design/issues/1102)
|
||||||
|
- 增加了一个搜索框和提示功能结合的 [例子](http://ant.design/components/select/#demo-search-box)。
|
||||||
|
- 允许可编辑的 Tabs 删除最后一个页签。[#1071](https://github.com/ant-design/ant-design/issues/1071)
|
||||||
|
- Table 的 `rowSelect.onSelectAll` 补充了第三个参数 `deselectedRows`, `rowSelect.onChange` 补充了第二个参数 `selectedRows`。[#1105](https://github.com/ant-design/ant-design/issues/1105)
|
||||||
|
- 修正部分组件的样式。
|
||||||
|
|
||||||
|
## 0.12.5
|
||||||
|
|
||||||
|
`2016-02-25`
|
||||||
|
|
||||||
|
- Pagination 支持 `showTotal` 属性。[#1077](https://github.com/ant-design/ant-design/pull/1077)
|
||||||
|
- Cascader 添加 `allowClear` 属性,允许隐藏清除按钮。
|
||||||
|
- 补充了一个带图标的搜索建议框的例子。[#1067](https://github.com/ant-design/ant-design/issues/1067)
|
||||||
|
- 修复 Transfer 在不支持 Object.assign 的浏览器上报错的问题。
|
||||||
|
- 修复 Cascader 在 Safari 下错位的问题。[#1066](https://github.com/ant-design/ant-design/issues/1066)
|
||||||
|
- 移除对 Button 圆角的降级方案。
|
||||||
|
- 修复了部分组件样式的小问题。
|
||||||
|
|
||||||
|
## 0.12.4
|
||||||
|
|
||||||
|
`2016-02-22`
|
||||||
|
|
||||||
|
- Radio 的 value 支持更多类型。[#1043](https://github.com/ant-design/ant-design/pull/1043)
|
||||||
|
- 修复 Spin 组件的大小、居中等样式问题。
|
||||||
|
- FormItem 补充 extra 属性的文档。[#931](https://github.com/ant-design/ant-design/issues/931)
|
||||||
|
- 修复的 Table 下树形数据和选择框配合时的样式问题。
|
||||||
|
- 修复一个水平表单的错误提示的样式错位问题。[#1040](https://github.com/ant-design/ant-design/issues/1040)
|
||||||
|
- 添加了一个轻微的 Button 点击动效。
|
||||||
|
|
||||||
|
## 0.12.3
|
||||||
|
|
||||||
|
`2016-02-19`
|
||||||
|
|
||||||
|
- DatePicker 补充 allowClear 属性,支持单选的清空。
|
||||||
|
- 修复显示时间的 DatePicker 的清空按钮失效的问题。
|
||||||
|
- 优化 DatePicker 的 `确定` 按钮失效样式。
|
||||||
|
|
||||||
|
## 0.12.2
|
||||||
|
|
||||||
|
`2016-02-19`
|
||||||
|
|
||||||
|
- DatePicker 如果有 `确定` 按钮,现在只有点击 `确定` 按钮才会触发 onChange 事件。
|
||||||
|
- 修复带时间选择的 DatePicker 日期格式缺少时间部分的问题。[#1005](https://github.com/ant-design/ant-design/issues/1005)
|
||||||
|
- 修复 DatePicker 内输入框多余的时间展示的问题。[#953](https://github.com/ant-design/ant-design/issues/953)
|
||||||
|
- 升级依赖 react-slick 到 `0.10`。
|
||||||
|
- 支持表单校验错误时自动滚动到第一个错误项。[#993](https://github.com/ant-design/ant-design/issues/993)
|
||||||
|
- 优化了 Select 和 TreeSelect 多选禁用的样式。
|
||||||
|
- Upload 列表项支持链接展现形式。[#1013](https://github.com/ant-design/ant-design/issues/1013)
|
||||||
|
- 修复 Safari 下的样式警告信息。[#999](https://github.com/ant-design/ant-design/issues/999)
|
||||||
|
- Cascader 支持 popupPlacement 位置配置。
|
||||||
|
|
||||||
|
## 0.12.1
|
||||||
|
|
||||||
|
`2016-02-03`
|
||||||
|
|
||||||
|
- 依赖升级到 `rc-pagination@1.4`、`rc-menu@4.10`、`rc-form@0.12`。
|
||||||
|
- 修复 TreeSelect 的不可用样式。
|
||||||
|
- DatePicker 补充 `getCalendarContainer` 属性,用于解决问题 [#991](https://github.com/ant-design/ant-design/issues/991)。
|
||||||
|
- 修正 Modal `onCancel` 的参数为点击事件。[#980](https://github.com/ant-design/ant-design/issues/980)
|
||||||
|
- 修复一个 Tooltip 内嵌套 Popconfirm 的问题。[#977](https://github.com/ant-design/ant-design/issues/977)
|
||||||
|
- 修复 DatePicker 和 RangePicker 的 `onOk` 一直不可用的问题。
|
||||||
|
- 修复一个 Badge 的 count 无法切换的问题。[#983](https://github.com/ant-design/ant-design/issues/983)
|
||||||
|
|
||||||
|
## 0.12.0
|
||||||
|
|
||||||
|
`2016-02-01`
|
||||||
|
|
||||||
|
- 新增 [级联选择(Cascader)](http://ant.design/components/cascader/) 组件。
|
||||||
|
- 新增 [树选择控件(TreeSelect)](http://ant.design/components/tree-select/) 组件。
|
||||||
|
- Form 自身支持校验功能,废弃 Validation。[演示](http://ant.design/components/form/#demo-validate-basic)
|
||||||
|
- Tabs
|
||||||
|
- `activeKey` 修正为受控属性。
|
||||||
|
- 当前项现在会始终显示。[#815](https://github.com/ant-design/ant-design/issues/815)
|
||||||
|
- Modal 可以配置右上关闭按钮是否显示。
|
||||||
|
- Select
|
||||||
|
- 打开选项菜单时,自动滚动到选中项。
|
||||||
|
- `combobox` 模式时,可配置是否默认选中第一项。[rc-select#38](https://github.com/react-component/select/issues/38)
|
||||||
|
- Table
|
||||||
|
- filter 支持层级选择。
|
||||||
|
- 支持行点击事件 `onRowClick`。
|
||||||
|
- 支持多列的横向切换。[演示](http://ant.design/components/table/#demo-paging-columns)
|
||||||
|
- 更换 `dataSource` 和变换页面时不再默认清除选择数据,你可以用 `selectedRowKeys` 手动控制。`原来默认清除的行为会触发一个数据更新的死循环,而且难以实现跨页选择。`
|
||||||
|
- 支持固定表头。[演示](http://ant.design/components/table/#demo-fixed-header)
|
||||||
|
- Tag 去除 `href` 属性,默认标签名从 `a` 改为 `span`。
|
||||||
|
- Timeline 支持指定 pending 节点的内容。
|
||||||
|
- Tree
|
||||||
|
- 节点支持拖拽。
|
||||||
|
- 支持动态控制节点展开与否。[演示](http://ant.design/components/tree/#demo-basic-controlled)
|
||||||
|
- 可以监听节点展开/关闭事件 `onExpand`。
|
||||||
|
- `onCheck` `onSelect` 参数调整。
|
||||||
|
- `onDataLoaded` 改为 `loadData`。
|
||||||
|
- 新增 drag&drop 相关属性:
|
||||||
|
- `onDragStart`
|
||||||
|
- `onDragEnter`
|
||||||
|
- `onDragOver`
|
||||||
|
- `onDragLeave`
|
||||||
|
- `onDrop`
|
||||||
|
- 新增 TreeNode 节点属性:
|
||||||
|
- `disableCheckbox`
|
||||||
|
- `isLeaf`
|
||||||
|
- Transfer 给 `onChange` 增加参数。[#972](https://github.com/ant-design/ant-design/issues/972)
|
||||||
|
- DatePicker
|
||||||
|
- 修复 RangePicker 开始结束日期相同的 bug。[#822](https://github.com/ant-design/ant-design/issues/822)
|
||||||
|
- 修复 `format` 对浮层不生效问题。[#917](https://github.com/ant-design/ant-design/issues/917)
|
||||||
|
- TimePicker 修复一个 `value` 为 `null` 时没有进入受控模式的问题。
|
||||||
|
- Upload
|
||||||
|
- 可以用 `headers` 设置上传头部。
|
||||||
|
- 新增上传图片卡片样式。[演示](http://ant.design/components/upload/#demo-picture-card)
|
||||||
|
- Radio
|
||||||
|
- 更换 Radio.Button 的展现样式。
|
||||||
|
- 可以设置 Radio.Button 的大小。
|
||||||
|
- Progress
|
||||||
|
- `format` 属性现在支持自定义 function 的方式进行定义。[#893](https://github.com/ant-design/ant-design/issues/893)
|
||||||
|
- `format` 指定 string 和 React.Node 的方式被废弃。
|
||||||
|
- 支持 `style` 属性。[#895](https://github.com/ant-design/ant-design/issues/895)
|
||||||
|
- message && notification 现在可以销毁。
|
||||||
|
- Button
|
||||||
|
- 小号 Button 的圆角调整为 `4px`。
|
||||||
|
- 修复 Button.Group disabled 后的样式问题。[#926](https://github.com/ant-design/ant-design/issues/926)
|
||||||
|
- BreadCrumb
|
||||||
|
- 移除 `router` 属性,无需设置。
|
||||||
|
- 修复一个链接参数不对的问题。
|
||||||
|
|
||||||
|
## 0.11.3
|
||||||
|
|
||||||
|
`2016-01-19`
|
||||||
|
|
||||||
|
- 修复 TimePicker 受控模式点选即关闭面板的问题。[#818](https://github.com/ant-design/ant-design/issues/818)
|
||||||
|
- 修复一个两栏的 TimePicker 点击右边空白处无法关闭面板的问题。[#826](https://github.com/ant-design/ant-design/issues/826)
|
||||||
|
- 修复 Table `pagination.onChange` 指定无效的问题。[#824](https://github.com/ant-design/ant-design/issues/824)
|
||||||
|
- 修复 Transfer 搜索功能失效的问题。
|
||||||
|
- 修复 DatePicker 的 MonthPicker 样式错乱的问题。
|
||||||
|
- 修复 RangePicker 时区无法设置的问题。[#837](https://github.com/ant-design/ant-design/issues/837)
|
||||||
|
- 修复二维码图标,新增一个扫描图标。[#772](https://github.com/ant-design/ant-design/issues/772)
|
||||||
|
|
||||||
|
## 0.11.2
|
||||||
|
|
||||||
|
`2015-01-03`
|
||||||
|
|
||||||
|
- 新增了[贡献文档](https://github.com/ant-design/ant-design/blob/master/CONTRIBUTING.md)。
|
||||||
|
- 修复一个 DatePicker 中选择的国际化文案问题。[#771](https://github.com/ant-design/ant-design/issues/771)
|
||||||
|
- 增加了一个高级搜索类型表单的[演示](http://ant.design/components/form/#demo-advanced-search-form)。
|
||||||
|
- Dropdown 支持多级的下拉菜单。[演示](http://ant.design/components/dropdown/#demo-sub-menu)
|
||||||
|
- Table
|
||||||
|
- 新增 `rowSelection.onChange` 和 `rowSelection.selectedRowKeys`,完善选择功能。
|
||||||
|
- 更新 dataSource 时,选中项现在会被清空。
|
||||||
|
- 修复一个全选框和禁用的选择项配合的问题。
|
||||||
|
- 修复 `0.11.1`版本 menu 内嵌型菜单(inline)选中后关闭的问题。
|
||||||
|
- 修复 `0.11.1`版本对 React 版本要求太严的问题,对应的警告提示对于 `0.14.x` 将不再出现。
|
||||||
|
- 组件和文档的样式小调整。
|
||||||
|
|
||||||
|
## 0.11.1
|
||||||
|
|
||||||
|
`2015-12-29`
|
||||||
|
|
||||||
|
- 修复一个 Table 无法修改 pageSize 的问题。
|
||||||
|
- 修复一个 Table 子表格展开的对齐问题。
|
||||||
|
- 修复一个 Chrome 下部分图标左侧切边的问题。
|
||||||
|
- 修复搜索输入框在表单下使用的样式问题。[#762](https://github.com/ant-design/ant-design/issues/762)
|
||||||
|
|
||||||
|
## 0.11.0
|
||||||
|
|
||||||
|
`2015-12-28`
|
||||||
|
|
||||||
|
- **移除默认加载的样式文件,样式现在需要独立加载。**
|
||||||
- 按钮圆角调整为 `6px`。
|
- 按钮圆角调整为 `6px`。
|
||||||
- Modal、Popconfirm、Table、TimePicker 支持国际化配置。
|
- Modal、Popconfirm、Table、TimePicker 支持国际化配置。
|
||||||
- 新增虚线型按钮。
|
- 新增虚线型按钮。
|
||||||
- 新增 [通用搜索框](http://ant.design/components/form/#demo-search-input) 样式。
|
- 新增 [通用搜索框](http://ant.design/components/form/#demo-search-input) 样式。
|
||||||
- 新增图片上传列表样式[演示](http://ant.design/components/upload/#demo-picture-style)。
|
- 新增图片上传列表样式[演示](http://ant.design/components/upload/#demo-picture-style)。
|
||||||
- 部分设计资源开放 [下载](http://ant.design/spec/tools),包括 Axure 组件库和 Iconfont 字体打包文件。
|
- **部分设计资源开放 [下载](http://ant.design/spec/tools),包括 Axure 组件库和 Iconfont 字体打包文件。**
|
||||||
- 新增 [吊顶规范](http://ant.design/spec/layout/#demo-ceiling)。
|
- 新增 [吊顶规范](http://ant.design/spec/layout/#demo-ceiling)。
|
||||||
- 组件演示页面增加锚点。
|
- 组件演示页面增加锚点。
|
||||||
- 新增穿梭框 [Transfer](http://ant.design/components/transfer/) 组件。
|
- 新增穿梭框 [Transfer](http://ant.design/components/transfer/) 组件。
|
||||||
@ -76,11 +270,21 @@
|
|||||||
- 替换 `antd build` 为 [atool-build](https://github.com/ant-tool/atool-build),重构并改善了 webpack 配置的自定义方式。
|
- 替换 `antd build` 为 [atool-build](https://github.com/ant-tool/atool-build),重构并改善了 webpack 配置的自定义方式。
|
||||||
- 替换 `antd server` 为 [dora](https://github.com/dora-js/dora),一个完全插件化的开发服务器,支持[代理转发和数据 Mock](https://github.com/dora-js/dora-plugin-proxy)、[atool-build](https://github.com/dora-js/dora-plugin-atool-build)、[热替换](https://github.com/dora-js/dora-plugin-hmr)。
|
- 替换 `antd server` 为 [dora](https://github.com/dora-js/dora),一个完全插件化的开发服务器,支持[代理转发和数据 Mock](https://github.com/dora-js/dora-plugin-proxy)、[atool-build](https://github.com/dora-js/dora-plugin-atool-build)、[热替换](https://github.com/dora-js/dora-plugin-hmr)。
|
||||||
- 新增 babel 插件 [babel-plugin-antd](https://github.com/ant-design/babel-plugin-antd),转换 `import {Button} from 'antd'` 为 `import Button from 'antd/lib/button'`。
|
- 新增 babel 插件 [babel-plugin-antd](https://github.com/ant-design/babel-plugin-antd),转换 `import {Button} from 'antd'` 为 `import Button from 'antd/lib/button'`。
|
||||||
- 发布了 `antd-init@0.5.x`,支持以上改动。
|
- 发布了 `antd-init@0.6.x`,支持以上改动。
|
||||||
|
|
||||||
> - [0.11 升级指南](http://ant.design/docs/upgrade-notes#0-10-gt-0-11)
|
> [0.11 升级指南](http://ant.design/docs/react/upgrade-notes#0-10-gt-0-11)
|
||||||
|
|
||||||
## 0.10.4 `2015-11-30`
|
---
|
||||||
|
|
||||||
|
## 0.10.5
|
||||||
|
|
||||||
|
`2016-01-04`
|
||||||
|
|
||||||
|
- 修复 Table 更新 dataSource 后,选中项没有置空的问题。[#793](https://github.com/ant-design/ant-design/issues/793)
|
||||||
|
|
||||||
|
## 0.10.4
|
||||||
|
|
||||||
|
`2015-11-30`
|
||||||
|
|
||||||
- 将 media-match 加入默认的 polyfill 文件中。[5626974](https://github.com/ant-design/ant-design/commit/562697423b1139eb324c1dceb051c143f4870ed7)
|
- 将 media-match 加入默认的 polyfill 文件中。[5626974](https://github.com/ant-design/ant-design/commit/562697423b1139eb324c1dceb051c143f4870ed7)
|
||||||
- 修复了 [MonthPicker](http://ant.design/components/datepicker/#demo-month-picker) 报错问题,并增加了相关演示。
|
- 修复了 [MonthPicker](http://ant.design/components/datepicker/#demo-month-picker) 报错问题,并增加了相关演示。
|
||||||
@ -88,7 +292,9 @@
|
|||||||
- 修复今天是不可选日期时的一个展示问题。[#606](https://github.com/ant-design/ant-design/issues/606)
|
- 修复今天是不可选日期时的一个展示问题。[#606](https://github.com/ant-design/ant-design/issues/606)
|
||||||
|
|
||||||
|
|
||||||
## 0.10.3 `2015-11-26`
|
## 0.10.3
|
||||||
|
|
||||||
|
`2015-11-26`
|
||||||
|
|
||||||
- 和 0.9.x 保持一致默认引入 `antd/lib/index.css`(而非 less 文件),方便第三方引用。引用 less 文件进行变量配置的可自行 `import 'antd/style/index.less'`。[#593](https://github.com/ant-design/ant-design/issues/593)
|
- 和 0.9.x 保持一致默认引入 `antd/lib/index.css`(而非 less 文件),方便第三方引用。引用 less 文件进行变量配置的可自行 `import 'antd/style/index.less'`。[#593](https://github.com/ant-design/ant-design/issues/593)
|
||||||
- 升级 Pagination,增加 `defaultCurrent` 属性,修正原来的 `current` 为[完全受控属性](https://facebook.github.io/react/docs/forms.html#controlled-components)。
|
- 升级 Pagination,增加 `defaultCurrent` 属性,修正原来的 `current` 为[完全受控属性](https://facebook.github.io/react/docs/forms.html#controlled-components)。
|
||||||
@ -96,7 +302,9 @@
|
|||||||
- 对演示和样式代码增加了 lint 检查。
|
- 对演示和样式代码增加了 lint 检查。
|
||||||
|
|
||||||
|
|
||||||
## 0.10.2 `2015-11-25`
|
## 0.10.2
|
||||||
|
|
||||||
|
`2015-11-25`
|
||||||
|
|
||||||
- Slider 新增 `tipFormatter` 用于格式化 Tooltip 的内容。
|
- Slider 新增 `tipFormatter` 用于格式化 Tooltip 的内容。
|
||||||
- 优化 Badge 动画效果。
|
- 优化 Badge 动画效果。
|
||||||
@ -107,7 +315,9 @@
|
|||||||
- InputNumber 同时设置 `size` `className` 时会有冲突。
|
- InputNumber 同时设置 `size` `className` 时会有冲突。
|
||||||
|
|
||||||
|
|
||||||
## 0.10.1 `2015-11-20`
|
## 0.10.1
|
||||||
|
|
||||||
|
`2015-11-20`
|
||||||
|
|
||||||
- 修改内部组件的引用结构,方便工具优化。[#566](https://github.com/ant-design/ant-design/pull/566)
|
- 修改内部组件的引用结构,方便工具优化。[#566](https://github.com/ant-design/ant-design/pull/566)
|
||||||
- 移除了演示中没有使用过的 `antd.ButtonGroup`,依然用 `const ButtonGroup = Button.Group` 来使用。
|
- 移除了演示中没有使用过的 `antd.ButtonGroup`,依然用 `const ButtonGroup = Button.Group` 来使用。
|
||||||
@ -120,7 +330,9 @@
|
|||||||
- 修复 Datepicker 的 `style` 和 `calendarStyle` 属性失效的问题,并将 `calendarStyle` 更名为 `popupStyle`。
|
- 修复 Datepicker 的 `style` 和 `calendarStyle` 属性失效的问题,并将 `calendarStyle` 更名为 `popupStyle`。
|
||||||
|
|
||||||
|
|
||||||
## 0.10.0 `2015-11-20`
|
## 0.10.0
|
||||||
|
|
||||||
|
`2015-11-20`
|
||||||
|
|
||||||
- 全面兼容 `react@0.14.x`。
|
- 全面兼容 `react@0.14.x`。
|
||||||
- 新增 [时间选择 Timepicker](http://ant.design/components/timepicker/)、[日历 Calendar](http://ant.design/components/calendar/)、[加载中 Spin](http://ant.design/components/spin/) 组件。
|
- 新增 [时间选择 Timepicker](http://ant.design/components/timepicker/)、[日历 Calendar](http://ant.design/components/calendar/)、[加载中 Spin](http://ant.design/components/spin/) 组件。
|
||||||
@ -186,15 +398,20 @@
|
|||||||
> 备注:
|
> 备注:
|
||||||
>
|
>
|
||||||
> - [计划和推进 issue](https://github.com/ant-design/ant-design/issues/276)
|
> - [计划和推进 issue](https://github.com/ant-design/ant-design/issues/276)
|
||||||
> - [0.10 升级指南](http://ant.design/docs/upgrade-notes#0-0-gt-0-10)
|
> - [0.10 升级指南](http://010x.ant.design/docs/upgrade-to-0.10)
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
## 0.9.3 ~ 0.9.5 `2015-11-04`
|
## 0.9.3 ~ 0.9.5
|
||||||
|
|
||||||
|
`2015-11-04`
|
||||||
|
|
||||||
* 增加对 React 版本的检测提示机制,0.9.x 序列只能使用 `react@~0.13.3`。
|
* 增加对 React 版本的检测提示机制,0.9.x 序列只能使用 `react@~0.13.3`。
|
||||||
|
|
||||||
|
|
||||||
## 0.9.2 `2015-10-26`
|
## 0.9.2
|
||||||
|
|
||||||
|
`2015-10-26`
|
||||||
|
|
||||||
* Tooltip 的 title 为空时不展示浮层。[9b53117](https://github.com/ant-design/ant-design/commit/9b5311791e73270c7c16a602ac74dd59719a5f76)
|
* Tooltip 的 title 为空时不展示浮层。[9b53117](https://github.com/ant-design/ant-design/commit/9b5311791e73270c7c16a602ac74dd59719a5f76)
|
||||||
* 修复 Upload 文件列表链接的 target 属性。[340a170](https://github.com/ant-design/ant-design/commit/340a1702b6a7b065ac02d417c891e1886dfe470d)
|
* 修复 Upload 文件列表链接的 target 属性。[340a170](https://github.com/ant-design/ant-design/commit/340a1702b6a7b065ac02d417c891e1886dfe470d)
|
||||||
@ -202,7 +419,9 @@
|
|||||||
* 修复一些小的样式问题。
|
* 修复一些小的样式问题。
|
||||||
|
|
||||||
|
|
||||||
## 0.9.1 `2015-09-26`
|
## 0.9.1
|
||||||
|
|
||||||
|
`2015-09-26`
|
||||||
|
|
||||||
* 添加 Pagination pageSize 发生变化的回调。[#317](https://github.com/ant-design/ant-design/issues/317)
|
* 添加 Pagination pageSize 发生变化的回调。[#317](https://github.com/ant-design/ant-design/issues/317)
|
||||||
* 升级依赖 rc-upload 到 1.6.x,修复 IE8/9 下的兼容性问题。
|
* 升级依赖 rc-upload 到 1.6.x,修复 IE8/9 下的兼容性问题。
|
||||||
@ -221,7 +440,9 @@
|
|||||||
* 部分组件交互和视觉效果修正。
|
* 部分组件交互和视觉效果修正。
|
||||||
|
|
||||||
|
|
||||||
## 0.9.0 `2015-09-14`
|
## 0.9.0
|
||||||
|
|
||||||
|
`2015-09-14`
|
||||||
|
|
||||||
* 新增 [timeline](components/timeline/) 和 [badge](components/badge/) 组件。
|
* 新增 [timeline](components/timeline/) 和 [badge](components/badge/) 组件。
|
||||||
* 优化弹出层类组件的动画效果,使其更加流畅。
|
* 优化弹出层类组件的动画效果,使其更加流畅。
|
||||||
@ -260,7 +481,9 @@
|
|||||||
* 支持和 react-router 结合使用。
|
* 支持和 react-router 结合使用。
|
||||||
|
|
||||||
|
|
||||||
## 0.8.0 `2015-08-25`
|
## 0.8.0
|
||||||
|
|
||||||
|
`2015-08-25`
|
||||||
|
|
||||||
这个版本是第一个稳定版,组件经过三期迭代,基本到齐,并有大量改进和变化,不向下兼容。
|
这个版本是第一个稳定版,组件经过三期迭代,基本到齐,并有大量改进和变化,不向下兼容。
|
||||||
|
|
||||||
@ -272,12 +495,16 @@
|
|||||||
* 排查并修复 IE 和 safari 等浏览器的兼容问题。
|
* 排查并修复 IE 和 safari 等浏览器的兼容问题。
|
||||||
* 大量代码重构,演示代码补充,文档更新、以及样式上的优化。
|
* 大量代码重构,演示代码补充,文档更新、以及样式上的优化。
|
||||||
|
|
||||||
## 0.7.3 `2015-07-30`
|
## 0.7.3
|
||||||
|
|
||||||
|
`2015-07-30`
|
||||||
|
|
||||||
* 小幅重构了 Table 分页,修复了分页导致的数据不展示的问题。
|
* 小幅重构了 Table 分页,修复了分页导致的数据不展示的问题。
|
||||||
* 更新了部分文档。
|
* 更新了部分文档。
|
||||||
|
|
||||||
## 0.7.2 `2015-07-27`
|
## 0.7.2
|
||||||
|
|
||||||
|
`2015-07-27`
|
||||||
|
|
||||||
* 修复本地模式下 pagination 为 false 时数据无法显示的 [问题](https://github.com/ant-design/ant-design/commit/1954586665e59031eae5d2c8b2cdb08f83d64fcb)。
|
* 修复本地模式下 pagination 为 false 时数据无法显示的 [问题](https://github.com/ant-design/ant-design/commit/1954586665e59031eae5d2c8b2cdb08f83d64fcb)。
|
||||||
* 重构了 message 组件。
|
* 重构了 message 组件。
|
||||||
@ -285,14 +512,18 @@
|
|||||||
* 部分代码切换至 ES6 模式。
|
* 部分代码切换至 ES6 模式。
|
||||||
* 修正了部分组件的样式和演示,优化部分动画。
|
* 修正了部分组件的样式和演示,优化部分动画。
|
||||||
|
|
||||||
## 0.7.1 `2015-07-22`
|
## 0.7.1
|
||||||
|
|
||||||
|
`2015-07-22`
|
||||||
|
|
||||||
* 修复了 Table 组件的 pagination 为 false 时分页未消失的 [问题](https://github.com/ant-design/ant-design/commit/01a6c0f1e6707b72a54ef30d073d148a87b391a8)。
|
* 修复了 Table 组件的 pagination 为 false 时分页未消失的 [问题](https://github.com/ant-design/ant-design/commit/01a6c0f1e6707b72a54ef30d073d148a87b391a8)。
|
||||||
* select 组件[选中后默认显示标签内容](https://github.com/ant-design/ant-design/issues/50)(原来是显示 value)。
|
* select 组件[选中后默认显示标签内容](https://github.com/ant-design/ant-design/issues/50)(原来是显示 value)。
|
||||||
* 修正了部分组件的样式和演示。
|
* 修正了部分组件的样式和演示。
|
||||||
* 打包文件为 [umd 模式](https://github.com/ant-design/ant-design/commit/9b7b940cb417429d8fc57d83e252991b043d0f2f)。
|
* 打包文件为 [umd 模式](https://github.com/ant-design/ant-design/commit/9b7b940cb417429d8fc57d83e252991b043d0f2f)。
|
||||||
|
|
||||||
## 0.7.0 `2015-07-21`
|
## 0.7.0
|
||||||
|
|
||||||
|
`2015-07-21`
|
||||||
|
|
||||||
* 第一个公开版本,发布 `layout`、`iconfont`、`button`、`form`、`checkbox`、`radio`、`switch`、`slider`、`input-number`、`datepicker`、`select`、`tabs`、`steps`、`breadcrumb`、`collapse`、`pagination`、`modal`、`message`、`dropdown`、`popover`、`popconfirm`、`tooltip`、`progress`、`table` 等组件。
|
* 第一个公开版本,发布 `layout`、`iconfont`、`button`、`form`、`checkbox`、`radio`、`switch`、`slider`、`input-number`、`datepicker`、`select`、`tabs`、`steps`、`breadcrumb`、`collapse`、`pagination`、`modal`、`message`、`dropdown`、`popover`、`popconfirm`、`tooltip`、`progress`、`table` 等组件。
|
||||||
* 发布 [Ant Design 首页](http://ant.design/) 和入门文档。
|
* 发布 [Ant Design 首页](http://ant.design/) 和入门文档。
|
||||||
|
@ -4,7 +4,7 @@
|
|||||||
</a>
|
</a>
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
# Ant Design [![](https://img.shields.io/travis/ant-design/ant-design.svg?style=flat-square)](https://travis-ci.org/ant-design/ant-design) [![npm package](https://img.shields.io/npm/v/antd.svg?style=flat-square)](https://www.npmjs.org/package/antd) [![NPM downloads](http://img.shields.io/npm/dm/antd.svg?style=flat-square)](https://npmjs.org/package/antd) [![Join the chat at https://gitter.im/ant-design/ant-design](https://badges.gitter.im/Join%20Chat.svg)](https://gitter.im/ant-design/ant-design?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)
|
# Ant Design [![](https://img.shields.io/travis/ant-design/ant-design.svg?style=flat-square)](https://travis-ci.org/ant-design/ant-design) [![npm package](https://img.shields.io/npm/v/antd.svg?style=flat-square)](https://www.npmjs.org/package/antd) [![NPM downloads](http://img.shields.io/npm/dm/antd.svg?style=flat-square)](https://npmjs.org/package/antd) [![Dependency Status](https://david-dm.org/ant-design/ant-design.svg?style=flat-square)](https://david-dm.org/ant-design/ant-design) [![Join the chat at https://gitter.im/ant-design/ant-design](https://badges.gitter.im/Join%20Chat.svg)](https://gitter.im/ant-design/ant-design?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)
|
||||||
|
|
||||||
一套企业级的 UI 设计语言和 React 实现。
|
一套企业级的 UI 设计语言和 React 实现。
|
||||||
|
|
||||||
@ -41,12 +41,15 @@ import 'antd/lib/index.css'; // or 'antd/style/index.less'
|
|||||||
|
|
||||||
现代浏览器和 IE8 及以上。
|
现代浏览器和 IE8 及以上。
|
||||||
|
|
||||||
|
> [IE8 issues](https://github.com/xcatliu/react-ie8)
|
||||||
|
|
||||||
## 链接
|
## 链接
|
||||||
|
|
||||||
- [首页](http://ant.design/)
|
- [首页](http://ant.design/)
|
||||||
- [React UI 库](http://ant.design/docs/introduce)
|
- [React UI 库](http://ant.design/docs/react/introduce)
|
||||||
- [修改记录](CHANGELOG.md)
|
- [修改记录](CHANGELOG.md)
|
||||||
- [构建调试工具](https://github.com/ant-tool/xtool/)
|
- [开发脚手架](https://github.com/ant-design/antd-init/)
|
||||||
|
- [开发工具文档](http://ant-tool.github.io/)
|
||||||
- [React 组件](http://react-component.github.io/)
|
- [React 组件](http://react-component.github.io/)
|
||||||
- [React 代码规范](https://github.com/react-component/react-component.github.io/blob/master/docs/zh-cn/component-code-style.md)
|
- [React 代码规范](https://github.com/react-component/react-component.github.io/blob/master/docs/zh-cn/component-code-style.md)
|
||||||
- [组件设计原则](https://github.com/react-component/react-component.github.io/blob/master/docs/zh-cn/component-design.md)
|
- [组件设计原则](https://github.com/react-component/react-component.github.io/blob/master/docs/zh-cn/component-design.md)
|
||||||
|
13
README.md
13
README.md
@ -4,15 +4,15 @@
|
|||||||
</a>
|
</a>
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
# Ant Design [![](https://img.shields.io/travis/ant-design/ant-design.svg?style=flat-square)](https://travis-ci.org/ant-design/ant-design) [![npm package](https://img.shields.io/npm/v/antd.svg?style=flat-square)](https://www.npmjs.org/package/antd) [![NPM downloads](http://img.shields.io/npm/dm/antd.svg?style=flat-square)](https://npmjs.org/package/antd) [![Join the chat at https://gitter.im/ant-design/ant-design](https://badges.gitter.im/Join%20Chat.svg)](https://gitter.im/ant-design/ant-design?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)
|
# Ant Design [![](https://img.shields.io/travis/ant-design/ant-design.svg?style=flat-square)](https://travis-ci.org/ant-design/ant-design) [![npm package](https://img.shields.io/npm/v/antd.svg?style=flat-square)](https://www.npmjs.org/package/antd) [![NPM downloads](http://img.shields.io/npm/dm/antd.svg?style=flat-square)](https://npmjs.org/package/antd) [![Dependency Status](https://david-dm.org/ant-design/ant-design.svg?style=flat-square)](https://david-dm.org/ant-design/ant-design) [![Join the chat at https://gitter.im/ant-design/ant-design](https://badges.gitter.im/Join%20Chat.svg)](https://gitter.im/ant-design/ant-design?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)
|
||||||
|
|
||||||
An enterprise-class UI design language and React-based implementation.
|
An enterprise-class UI design language and React-based implementation.
|
||||||
|
|
||||||
## Features
|
## Features
|
||||||
|
|
||||||
- An enterprise-class graphical design language and framework for financial applications.
|
- An enterprise-class design language and high quality UI style.
|
||||||
- Rich library of UI components base on [React Component](http://react-component.github.io/badgeboard/).
|
- Rich library of UI components base on [React Component](http://react-component.github.io/badgeboard/).
|
||||||
- A npm + webpack + babel workflow, supporting ES2015.
|
- A npm + webpack + babel + dora [workflow](http://ant-tool.github.io/index.html).
|
||||||
|
|
||||||
## Install
|
## Install
|
||||||
|
|
||||||
@ -40,18 +40,21 @@ Use components on demand by writing as `import DatePicker from 'antd/lib/date-pi
|
|||||||
|
|
||||||
Normal browsers and Internet Explorer 8+.
|
Normal browsers and Internet Explorer 8+.
|
||||||
|
|
||||||
|
> [IE8 issues](https://github.com/xcatliu/react-ie8)
|
||||||
|
|
||||||
## Links
|
## Links
|
||||||
|
|
||||||
- [Home page](http://ant.design/)
|
- [Home page](http://ant.design/)
|
||||||
- [React UI library](http://ant.design/docs/introduce)
|
- [React UI library](http://ant.design/docs/react/introduce)
|
||||||
- [ChangeLog](CHANGELOG.md)
|
- [ChangeLog](CHANGELOG.md)
|
||||||
- [Build/Debug tools](https://github.com/ant-tool/xtool/)
|
- [Scaffold tool](https://github.com/ant-design/antd-init/)
|
||||||
|
- [Development tool](http://ant-tool.github.io/)
|
||||||
- [React components](http://react-component.github.io/)
|
- [React components](http://react-component.github.io/)
|
||||||
- [React style guide](https://github.com/react-component/react-component.github.io/blob/master/docs/zh-cn/component-code-style.md)
|
- [React style guide](https://github.com/react-component/react-component.github.io/blob/master/docs/zh-cn/component-code-style.md)
|
||||||
- [React component design guide](https://github.com/react-component/react-component.github.io/blob/master/docs/zh-cn/component-design.md)
|
- [React component design guide](https://github.com/react-component/react-component.github.io/blob/master/docs/zh-cn/component-design.md)
|
||||||
- [Developer Instruction](https://github.com/ant-design/ant-design/wiki/%E7%BD%91%E7%AB%99%E5%92%8C%E7%BB%84%E4%BB%B6%E5%BC%80%E5%8F%91%E8%AF%B4%E6%98%8E)
|
- [Developer Instruction](https://github.com/ant-design/ant-design/wiki/%E7%BD%91%E7%AB%99%E5%92%8C%E7%BB%84%E4%BB%B6%E5%BC%80%E5%8F%91%E8%AF%B4%E6%98%8E)
|
||||||
- [Versioning Release Note](https://github.com/ant-design/ant-design/wiki/%E7%89%88%E6%9C%AC%E5%8F%91%E5%B8%83%E6%B5%81%E7%A8%8B)
|
- [Versioning Release Note](https://github.com/ant-design/ant-design/wiki/%E7%89%88%E6%9C%AC%E5%8F%91%E5%B8%83%E6%B5%81%E7%A8%8B)
|
||||||
|
- [FAQ](https://github.com/ant-design/ant-design/wiki/FAQ)
|
||||||
|
|
||||||
|
|
||||||
## Contributing
|
## Contributing
|
||||||
|
@ -13,5 +13,5 @@ ReactDOM.render(
|
|||||||
<Affix>
|
<Affix>
|
||||||
<Button type="primary">固定在顶部</Button>
|
<Button type="primary">固定在顶部</Button>
|
||||||
</Affix>
|
</Affix>
|
||||||
, document.getElementById('components-affix-demo-basic'));
|
, mountNode);
|
||||||
````
|
````
|
||||||
|
@ -13,5 +13,5 @@ ReactDOM.render(
|
|||||||
<Affix offset={75}>
|
<Affix offset={75}>
|
||||||
<Button type="primary">固定在距离顶部 75px 的位置</Button>
|
<Button type="primary">固定在距离顶部 75px 的位置</Button>
|
||||||
</Affix>
|
</Affix>
|
||||||
, document.getElementById('components-affix-demo-offset'));
|
, mountNode);
|
||||||
````
|
````
|
||||||
|
@ -4,8 +4,8 @@ import rcUtil from 'rc-util';
|
|||||||
import classNames from 'classnames';
|
import classNames from 'classnames';
|
||||||
|
|
||||||
function getScroll(w, top) {
|
function getScroll(w, top) {
|
||||||
let ret = w['page' + (top ? 'Y' : 'X') + 'Offset'];
|
let ret = w[`page${top ? 'Y' : 'X'}Offset`];
|
||||||
let method = 'scroll' + (top ? 'Top' : 'Left');
|
let method = `scroll${top ? 'Top' : 'Left'}`;
|
||||||
if (typeof ret !== 'number') {
|
if (typeof ret !== 'number') {
|
||||||
let d = w.document;
|
let d = w.document;
|
||||||
// ie6,7,8 standard mode
|
// ie6,7,8 standard mode
|
||||||
|
@ -10,5 +10,5 @@
|
|||||||
import { Alert } from 'antd';
|
import { Alert } from 'antd';
|
||||||
|
|
||||||
ReactDOM.render(<Alert message="成功提示的文案" type="success" />
|
ReactDOM.render(<Alert message="成功提示的文案" type="success" />
|
||||||
, document.getElementById('components-alert-demo-basic'));
|
, mountNode);
|
||||||
````
|
````
|
||||||
|
@ -23,5 +23,5 @@ ReactDOM.render(<div>
|
|||||||
type="error"
|
type="error"
|
||||||
closable
|
closable
|
||||||
onClose={onClose} />
|
onClose={onClose} />
|
||||||
</div>, document.getElementById('components-alert-demo-closable'));
|
</div>, mountNode);
|
||||||
````
|
````
|
||||||
|
@ -11,5 +11,5 @@ import { Alert } from 'antd';
|
|||||||
|
|
||||||
ReactDOM.render(
|
ReactDOM.render(
|
||||||
<Alert message="消息提示的文案" type="info" closeText="不再提醒" />
|
<Alert message="消息提示的文案" type="info" closeText="不再提醒" />
|
||||||
, document.getElementById('components-alert-demo-close-text'));
|
, mountNode);
|
||||||
````
|
````
|
||||||
|
@ -24,5 +24,5 @@ ReactDOM.render(<div>
|
|||||||
message="错误提示的文案"
|
message="错误提示的文案"
|
||||||
description="错误提示的辅助性文字介绍错误提示的辅助性文字介绍错误提示的辅助性文字介绍错误提示的辅助性文字介绍错误提示的辅助性文字介绍错误提示的辅助性文字介绍"
|
description="错误提示的辅助性文字介绍错误提示的辅助性文字介绍错误提示的辅助性文字介绍错误提示的辅助性文字介绍错误提示的辅助性文字介绍错误提示的辅助性文字介绍"
|
||||||
type="error" />
|
type="error" />
|
||||||
</div>, document.getElementById('components-alert-demo-description'));
|
</div>, mountNode);
|
||||||
````
|
````
|
||||||
|
@ -32,5 +32,5 @@ ReactDOM.render(<div>
|
|||||||
description="错误提示的辅助性文字介绍错误提示的辅助性文字介绍错误提示的辅助性文字介绍错误提示的辅助性文字介绍错误提示的辅助性文字介绍错误提示的辅助性文字介绍"
|
description="错误提示的辅助性文字介绍错误提示的辅助性文字介绍错误提示的辅助性文字介绍错误提示的辅助性文字介绍错误提示的辅助性文字介绍错误提示的辅助性文字介绍"
|
||||||
type="error"
|
type="error"
|
||||||
showIcon />
|
showIcon />
|
||||||
</div>, document.getElementById('components-alert-demo-icon'));
|
</div>, mountNode);
|
||||||
````
|
````
|
||||||
|
@ -15,5 +15,5 @@ ReactDOM.render(<div>
|
|||||||
<Alert message="警告提示的文案" type="warn" />
|
<Alert message="警告提示的文案" type="warn" />
|
||||||
<Alert message="错误提示的文案" type="error" />
|
<Alert message="错误提示的文案" type="error" />
|
||||||
</div>,
|
</div>,
|
||||||
document.getElementById('components-alert-demo-style'));
|
mountNode);
|
||||||
````
|
````
|
||||||
|
@ -21,10 +21,10 @@ export default React.createClass({
|
|||||||
handleClose(e) {
|
handleClose(e) {
|
||||||
e.preventDefault();
|
e.preventDefault();
|
||||||
let dom = ReactDOM.findDOMNode(this);
|
let dom = ReactDOM.findDOMNode(this);
|
||||||
dom.style.height = dom.offsetHeight + 'px';
|
dom.style.height = `${dom.offsetHeight}px`;
|
||||||
// Magic code
|
// Magic code
|
||||||
// 重复一次后才能正确设置 height
|
// 重复一次后才能正确设置 height
|
||||||
dom.style.height = dom.offsetHeight + 'px';
|
dom.style.height = `${dom.offsetHeight}px`;
|
||||||
|
|
||||||
this.setState({
|
this.setState({
|
||||||
closing: false
|
closing: false
|
||||||
@ -67,10 +67,10 @@ export default React.createClass({
|
|||||||
|
|
||||||
let alertCls = classNames({
|
let alertCls = classNames({
|
||||||
[prefixCls]: true,
|
[prefixCls]: true,
|
||||||
[prefixCls + '-' + type]: true,
|
[`${prefixCls}-${type}`]: true,
|
||||||
[prefixCls + '-close']: !this.state.closing,
|
[`${prefixCls}-close`]: !this.state.closing,
|
||||||
[prefixCls + '-with-description']: !!description,
|
[`${prefixCls}-with-description`]: !!description,
|
||||||
[prefixCls + '-no-icon']: !showIcon,
|
[`${prefixCls}-no-icon`]: !showIcon,
|
||||||
});
|
});
|
||||||
|
|
||||||
// closeable when closeText is assigned
|
// closeable when closeText is assigned
|
||||||
@ -85,9 +85,9 @@ export default React.createClass({
|
|||||||
onEnd={this.animationEnd}>
|
onEnd={this.animationEnd}>
|
||||||
<div data-show={this.state.closing} className={alertCls}>
|
<div data-show={this.state.closing} className={alertCls}>
|
||||||
{showIcon ? <Icon className="ant-alert-icon" type={iconType} /> : null}
|
{showIcon ? <Icon className="ant-alert-icon" type={iconType} /> : null}
|
||||||
<span className={prefixCls + '-message'}>{message}</span>
|
<span className={`${prefixCls}-message`}>{message}</span>
|
||||||
<span className={prefixCls + '-description'}>{description}</span>
|
<span className={`${prefixCls}-description`}>{description}</span>
|
||||||
{closable ? <a onClick={this.handleClose} className={prefixCls + '-close-icon'}>
|
{closable ? <a onClick={this.handleClose} className={`${prefixCls}-close-icon`}>
|
||||||
{closeText || <Icon type="cross" />}
|
{closeText || <Icon type="cross" />}
|
||||||
</a> : null}
|
</a> : null}
|
||||||
</div>
|
</div>
|
||||||
|
@ -19,8 +19,8 @@
|
|||||||
|----------- |--------------------------------------------------------- | ---------- |-------|
|
|----------- |--------------------------------------------------------- | ---------- |-------|
|
||||||
| type | 必选参数,指定警告提示的样式,有四种选择`success`、`info`、`warn`、`error` | String | 无 |
|
| type | 必选参数,指定警告提示的样式,有四种选择`success`、`info`、`warn`、`error` | String | 无 |
|
||||||
| closable | 可选参数,默认不显示关闭按钮 | Boolean | 无 |
|
| closable | 可选参数,默认不显示关闭按钮 | Boolean | 无 |
|
||||||
| closeText | 可选参数,自定义关闭按钮 | String | 无 |
|
| closeText | 可选参数,自定义关闭按钮 | React.Node | 无 |
|
||||||
| message | 必选参数,警告提示内容 | String | 无 |
|
| message | 必选参数,警告提示内容 | React.Node | 无 |
|
||||||
| description | 可选参数,警告提示的辅助性文字介绍 | String | 无 |
|
| description | 可选参数,警告提示的辅助性文字介绍 | React.Node | 无 |
|
||||||
| onClose | 可选参数,关闭时触发的回调函数 | Function | 无 |
|
| onClose | 可选参数,关闭时触发的回调函数 | Function | 无 |
|
||||||
| showIcon | 可选参数,是否显示辅助图标 | Boolean | false |
|
| showIcon | 可选参数,是否显示辅助图标 | Boolean | false |
|
||||||
|
@ -26,21 +26,18 @@ class AntScrollNumber extends React.Component {
|
|||||||
if (this.state.count > this.lastCount) {
|
if (this.state.count > this.lastCount) {
|
||||||
if (currentDigit >= lastDigit) {
|
if (currentDigit >= lastDigit) {
|
||||||
return 10 + num;
|
return 10 + num;
|
||||||
} else {
|
}
|
||||||
return 20 + num;
|
return 20 + num;
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
if (currentDigit <= lastDigit) {
|
if (currentDigit <= lastDigit) {
|
||||||
return 10 + num;
|
return 10 + num;
|
||||||
} else {
|
}
|
||||||
return num;
|
return num;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
componentWillReceiveProps(nextProps) {
|
componentWillReceiveProps(nextProps) {
|
||||||
if ('count' in nextProps && nextProps.count) {
|
if ('count' in nextProps) {
|
||||||
if (this.lastCount === this.state.count) {
|
if (this.state.count === nextProps.count) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
this.lastCount = this.state.count;
|
this.lastCount = this.state.count;
|
||||||
@ -79,8 +76,8 @@ class AntScrollNumber extends React.Component {
|
|||||||
className: `${this.props.prefixCls}-only`,
|
className: `${this.props.prefixCls}-only`,
|
||||||
style: {
|
style: {
|
||||||
transition: removeTransition && 'none',
|
transition: removeTransition && 'none',
|
||||||
transform: 'translate3d(0, ' + (-position * height) + 'px, 0)',
|
transform: `translate3d(0, ${-position * height}px, 0)`,
|
||||||
height: height,
|
height,
|
||||||
},
|
},
|
||||||
key: i,
|
key: i,
|
||||||
}, this.renderNumberList());
|
}, this.renderNumberList());
|
||||||
@ -106,7 +103,7 @@ class AntScrollNumber extends React.Component {
|
|||||||
props,
|
props,
|
||||||
this.renderNumberElement()
|
this.renderNumberElement()
|
||||||
);
|
);
|
||||||
} else {
|
}
|
||||||
return createElement(
|
return createElement(
|
||||||
this.props.component,
|
this.props.component,
|
||||||
props,
|
props,
|
||||||
@ -114,13 +111,12 @@ class AntScrollNumber extends React.Component {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
AntScrollNumber.defaultProps = {
|
AntScrollNumber.defaultProps = {
|
||||||
prefixCls: 'ant-scroll-number',
|
prefixCls: 'ant-scroll-number',
|
||||||
count: null,
|
count: null,
|
||||||
component: 'sup',
|
component: 'sup',
|
||||||
onAnimated: function() {},
|
onAnimated() {},
|
||||||
height: 18,
|
height: 18,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -16,5 +16,5 @@ ReactDOM.render(<div>
|
|||||||
<Badge count={200}>
|
<Badge count={200}>
|
||||||
<a href="#" className="head-example"></a>
|
<a href="#" className="head-example"></a>
|
||||||
</Badge>
|
</Badge>
|
||||||
</div>, document.getElementById('components-badge-demo-99plus'));
|
</div>, mountNode);
|
||||||
````
|
````
|
||||||
|
@ -13,7 +13,7 @@ ReactDOM.render(
|
|||||||
<Badge count={5}>
|
<Badge count={5}>
|
||||||
<a href="#" className="head-example"></a>
|
<a href="#" className="head-example"></a>
|
||||||
</Badge>
|
</Badge>
|
||||||
, document.getElementById('components-badge-demo-basic'));
|
, mountNode);
|
||||||
````
|
````
|
||||||
|
|
||||||
````css
|
````css
|
||||||
|
@ -30,17 +30,12 @@ const Test = React.createClass({
|
|||||||
},
|
},
|
||||||
onClick() {
|
onClick() {
|
||||||
this.setState({
|
this.setState({
|
||||||
show: !this.state.show
|
show: !this.state.show,
|
||||||
});
|
|
||||||
},
|
|
||||||
onNumberClick() {
|
|
||||||
const count = this.state.count;
|
|
||||||
this.setState({
|
|
||||||
count: count ? 0 : 5
|
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
render() {
|
render() {
|
||||||
return <div>
|
return (
|
||||||
|
<div>
|
||||||
<Badge count={this.state.count}>
|
<Badge count={this.state.count}>
|
||||||
<a href="#" className="head-example"></a>
|
<a href="#" className="head-example"></a>
|
||||||
</Badge>
|
</Badge>
|
||||||
@ -48,12 +43,6 @@ const Test = React.createClass({
|
|||||||
<a href="#" className="head-example"></a>
|
<a href="#" className="head-example"></a>
|
||||||
</Badge>
|
</Badge>
|
||||||
<div style={{ marginTop: 10 }}>
|
<div style={{ marginTop: 10 }}>
|
||||||
<Button type="ghost" onClick={this.onNumberClick} style={{marginRight: 6}}>
|
|
||||||
切换数字显隐
|
|
||||||
</Button>
|
|
||||||
<Button type="ghost" onClick={this.onClick} style={{marginRight: 6}}>
|
|
||||||
切换红点显隐
|
|
||||||
</Button>
|
|
||||||
<ButtonGroup>
|
<ButtonGroup>
|
||||||
<Button type="ghost" onClick={this.decline}>
|
<Button type="ghost" onClick={this.decline}>
|
||||||
<Icon type="minus" />
|
<Icon type="minus" />
|
||||||
@ -62,12 +51,16 @@ const Test = React.createClass({
|
|||||||
<Icon type="plus" />
|
<Icon type="plus" />
|
||||||
</Button>
|
</Button>
|
||||||
</ButtonGroup>
|
</ButtonGroup>
|
||||||
|
<Button type="ghost" onClick={this.onClick} style={{ marginLeft: 8 }}>
|
||||||
|
切换红点显隐
|
||||||
|
</Button>
|
||||||
</div>
|
</div>
|
||||||
</div>;
|
</div>
|
||||||
|
);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
ReactDOM.render(
|
ReactDOM.render(
|
||||||
<Test />
|
<Test />
|
||||||
, document.getElementById('components-badge-demo-change'));
|
, mountNode);
|
||||||
````
|
````
|
||||||
|
@ -16,7 +16,7 @@ ReactDOM.render(<div>
|
|||||||
<Badge dot>
|
<Badge dot>
|
||||||
<a href="#">一个链接</a>
|
<a href="#">一个链接</a>
|
||||||
</Badge>
|
</Badge>
|
||||||
</div>, document.getElementById('components-badge-demo-dot'));
|
</div>, mountNode);
|
||||||
````
|
````
|
||||||
|
|
||||||
<style>
|
<style>
|
||||||
|
@ -15,5 +15,5 @@ ReactDOM.render(
|
|||||||
<span className="head-example"></span>
|
<span className="head-example"></span>
|
||||||
</Badge>
|
</Badge>
|
||||||
</a>
|
</a>
|
||||||
, document.getElementById('components-badge-demo-link'));
|
, mountNode);
|
||||||
````
|
````
|
||||||
|
@ -15,5 +15,5 @@ ReactDOM.render(<div>
|
|||||||
<Badge count={25} />
|
<Badge count={25} />
|
||||||
<Badge count={4} style={{ backgroundColor: '#fff', color: '#999', borderColor: '#d9d9d9' }} />
|
<Badge count={4} style={{ backgroundColor: '#fff', color: '#999', borderColor: '#d9d9d9' }} />
|
||||||
<Badge count={109} style={{ backgroundColor: '#87d068' }} />
|
<Badge count={109} style={{ backgroundColor: '#87d068' }} />
|
||||||
</div>, document.getElementById('components-badge-demo-no-wrapper'));
|
</div>, mountNode);
|
||||||
````
|
````
|
||||||
|
@ -16,5 +16,5 @@ ReactDOM.render(<div>
|
|||||||
<Badge count={1000} overflowCount={999}>
|
<Badge count={1000} overflowCount={999}>
|
||||||
<a href="#" className="head-example"></a>
|
<a href="#" className="head-example"></a>
|
||||||
</Badge>
|
</Badge>
|
||||||
</div>, document.getElementById('components-badge-demo-overflow'));
|
</div>, mountNode);
|
||||||
````
|
````
|
||||||
|
@ -4,10 +4,6 @@ import ScrollNumber from './ScrollNumber';
|
|||||||
import classNames from 'classnames';
|
import classNames from 'classnames';
|
||||||
|
|
||||||
class AntBadge extends React.Component {
|
class AntBadge extends React.Component {
|
||||||
constructor(props) {
|
|
||||||
super(props);
|
|
||||||
}
|
|
||||||
|
|
||||||
render() {
|
render() {
|
||||||
let { count, prefixCls, overflowCount, className, style, children } = this.props;
|
let { count, prefixCls, overflowCount, className, style, children } = this.props;
|
||||||
const dot = this.props.dot;
|
const dot = this.props.dot;
|
||||||
@ -33,7 +29,7 @@ class AntBadge extends React.Component {
|
|||||||
{children}
|
{children}
|
||||||
<Animate component=""
|
<Animate component=""
|
||||||
showProp="data-show"
|
showProp="data-show"
|
||||||
transitionName={prefixCls + '-zoom'}
|
transitionName={`${prefixCls}-zoom`}
|
||||||
transitionAppear>
|
transitionAppear>
|
||||||
{
|
{
|
||||||
hidden ? null :
|
hidden ? null :
|
||||||
|
@ -16,5 +16,5 @@ ReactDOM.render(
|
|||||||
<Breadcrumb.Item href="">应用列表</Breadcrumb.Item>
|
<Breadcrumb.Item href="">应用列表</Breadcrumb.Item>
|
||||||
<Breadcrumb.Item>某应用</Breadcrumb.Item>
|
<Breadcrumb.Item>某应用</Breadcrumb.Item>
|
||||||
</Breadcrumb>
|
</Breadcrumb>
|
||||||
, document.getElementById('components-breadcrumb-demo-basic'));
|
, mountNode);
|
||||||
````
|
````
|
||||||
|
@ -2,27 +2,34 @@
|
|||||||
|
|
||||||
- order: 2
|
- order: 2
|
||||||
|
|
||||||
和 `react-router@1.x` 进行结合使用。
|
和 `react-router@2.x` 进行结合使用。
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
````jsx
|
````jsx
|
||||||
const ReactRouter = require('react-router');
|
const ReactRouter = require('react-router');
|
||||||
let { Router, Route, Link } = ReactRouter;
|
let { Router, Route, Link, hashHistory } = ReactRouter;
|
||||||
import { Breadcrumb } from 'antd';
|
import { Breadcrumb } from 'antd';
|
||||||
|
|
||||||
const Apps = React.createClass({
|
const Apps = React.createClass({
|
||||||
render() {
|
render() {
|
||||||
return <ul className="app-list">
|
return (
|
||||||
<li><Link to="/apps/1">应用1</Link></li>
|
<ul className="app-list">
|
||||||
<li><Link to="/apps/2">应用2</Link></li>
|
<li>
|
||||||
</ul>;
|
<Link to="/apps/1">应用1</Link>:<Link to="/apps/1/detail">详情</Link>
|
||||||
|
</li>
|
||||||
|
<li>
|
||||||
|
<Link to="/apps/2">应用2</Link>:<Link to="/apps/2/detail">详情</Link>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
const Home = React.createClass({
|
const Home = React.createClass({
|
||||||
render() {
|
render() {
|
||||||
return (<div>
|
return (
|
||||||
|
<div>
|
||||||
<div className="demo-nav">
|
<div className="demo-nav">
|
||||||
<Link to="/">首页</Link>
|
<Link to="/">首页</Link>
|
||||||
<Link to="/apps">应用列表</Link>
|
<Link to="/apps">应用列表</Link>
|
||||||
@ -33,21 +40,26 @@ const Home = React.createClass({
|
|||||||
marginTop: 15,
|
marginTop: 15,
|
||||||
paddingBottom: 15,
|
paddingBottom: 15,
|
||||||
borderBottom: '1px dashed #ccc'
|
borderBottom: '1px dashed #ccc'
|
||||||
}}>点击上面的导航切换页面,面包屑在下面:</div>
|
}}>
|
||||||
<Breadcrumb {...this.props} router={ReactRouter} />
|
点击上面的导航切换页面,面包屑在下面:
|
||||||
</div>);
|
</div>
|
||||||
|
<Breadcrumb {...this.props} />
|
||||||
|
</div>
|
||||||
|
);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
ReactDOM.render((
|
ReactDOM.render(
|
||||||
<Router>
|
<Router history={hashHistory}>
|
||||||
<Route name="home" breadcrumbName="首页" path="/" component={Home}>
|
<Route name="home" breadcrumbName="首页" path="/" component={Home}>
|
||||||
<Route name="apps" breadcrumbName="应用列表" path="apps" component={Apps}>
|
<Route name="apps" breadcrumbName="应用列表" path="apps" component={Apps}>
|
||||||
<Route name="app" breadcrumbName="应用:id" path=":id" />
|
<Route name="app" breadcrumbName="应用:id" path=":id">
|
||||||
|
<Route name="detail" breadcrumbName="详情" path="detail" />
|
||||||
|
</Route>
|
||||||
</Route>
|
</Route>
|
||||||
</Route>
|
</Route>
|
||||||
</Router>
|
</Router>
|
||||||
), document.getElementById('components-breadcrumb-demo-router'));
|
, mountNode);
|
||||||
````
|
````
|
||||||
|
|
||||||
<style>
|
<style>
|
||||||
|
@ -16,5 +16,5 @@ ReactDOM.render(
|
|||||||
<Breadcrumb.Item href="">应用列表</Breadcrumb.Item>
|
<Breadcrumb.Item href="">应用列表</Breadcrumb.Item>
|
||||||
<Breadcrumb.Item>某应用</Breadcrumb.Item>
|
<Breadcrumb.Item>某应用</Breadcrumb.Item>
|
||||||
</Breadcrumb>
|
</Breadcrumb>
|
||||||
, document.getElementById('components-breadcrumb-demo-separator'));
|
, mountNode);
|
||||||
````
|
````
|
||||||
|
@ -22,6 +22,6 @@ ReactDOM.render(
|
|||||||
应用
|
应用
|
||||||
</Breadcrumb.Item>
|
</Breadcrumb.Item>
|
||||||
</Breadcrumb>
|
</Breadcrumb>
|
||||||
, document.getElementById('components-breadcrumb-demo-withicon'));
|
, mountNode);
|
||||||
````
|
````
|
||||||
|
|
||||||
|
@ -17,14 +17,16 @@ const BreadcrumbItem = React.createClass({
|
|||||||
},
|
},
|
||||||
render() {
|
render() {
|
||||||
const { prefixCls, separator, children } = this.props;
|
const { prefixCls, separator, children } = this.props;
|
||||||
let link = <a className={prefixCls + '-link'} {...this.props}>{children}</a>;
|
let link = <a className={`${prefixCls}-link`} {...this.props}>{children}</a>;
|
||||||
if (typeof this.props.href === 'undefined') {
|
if (typeof this.props.href === 'undefined') {
|
||||||
link = <span className={prefixCls + '-link'} {...this.props}>{children}</span>;
|
link = <span className={`${prefixCls}-link`} {...this.props}>{children}</span>;
|
||||||
}
|
}
|
||||||
return <span>
|
return (
|
||||||
|
<span>
|
||||||
{link}
|
{link}
|
||||||
<span className={prefixCls + '-separator'}>{separator}</span>
|
<span className={`${prefixCls}-separator`}>{separator}</span>
|
||||||
</span>;
|
</span>
|
||||||
|
);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -41,29 +43,35 @@ const Breadcrumb = React.createClass({
|
|||||||
React.PropTypes.string,
|
React.PropTypes.string,
|
||||||
React.PropTypes.element,
|
React.PropTypes.element,
|
||||||
]),
|
]),
|
||||||
router: React.PropTypes.object,
|
|
||||||
routes: React.PropTypes.array,
|
routes: React.PropTypes.array,
|
||||||
params: React.PropTypes.object
|
params: React.PropTypes.object,
|
||||||
},
|
},
|
||||||
render() {
|
render() {
|
||||||
let crumbs;
|
let crumbs;
|
||||||
const { separator, prefixCls, router, routes, params, children } = this.props;
|
const { separator, prefixCls, routes, params, children } = this.props;
|
||||||
const ReactRouter = router;
|
if (routes && routes.length > 0) {
|
||||||
if (routes && routes.length > 0 && ReactRouter) {
|
const paths = [];
|
||||||
let Link = ReactRouter.Link;
|
crumbs = routes.map((route, i) => {
|
||||||
crumbs = routes.map(function(route, i) {
|
|
||||||
if (!route.breadcrumbName) {
|
if (!route.breadcrumbName) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
const name = route.breadcrumbName.replace(/\:(.*)/g, function(replacement, key) {
|
const name = route.breadcrumbName.replace(/\:(.*)/g, (replacement, key) => {
|
||||||
return params[key] || replacement;
|
return params[key] || replacement;
|
||||||
});
|
});
|
||||||
|
|
||||||
let link;
|
let link;
|
||||||
const path = route.path.indexOf('/') === 0 ? route.path : ('/' + route.path);
|
let path = route.path.replace(/^\//, '');
|
||||||
|
Object.keys(params).forEach(key => {
|
||||||
|
path = path.replace(`:${key}`, params[key]);
|
||||||
|
});
|
||||||
|
if (path) {
|
||||||
|
paths.push(path);
|
||||||
|
}
|
||||||
|
|
||||||
if (i === routes.length - 1) {
|
if (i === routes.length - 1) {
|
||||||
link = <span>{name}</span>;
|
link = <span>{name}</span>;
|
||||||
} else {
|
} else {
|
||||||
link = <Link to={path} params={params}>{name}</Link>;
|
link = <a href={`#/${paths.join('/')}`}>{name}</a>;
|
||||||
}
|
}
|
||||||
return <BreadcrumbItem separator={separator} key={name}>{link}</BreadcrumbItem>;
|
return <BreadcrumbItem separator={separator} key={name}>{link}</BreadcrumbItem>;
|
||||||
});
|
});
|
||||||
|
@ -29,7 +29,6 @@
|
|||||||
|
|
||||||
| 参数 | 说明 | 类型 | 可选值 | 默认值 |
|
| 参数 | 说明 | 类型 | 可选值 | 默认值 |
|
||||||
|-----------|-----------------------------------|-------------------|---------|--------|
|
|-----------|-----------------------------------|-------------------|---------|--------|
|
||||||
| router | 可传入 react-router 的实例 | Object | | - |
|
|
||||||
| routes | router 的路由栈信息 | Array | | - |
|
| routes | router 的路由栈信息 | Array | | - |
|
||||||
| params | 路由的参数 | Object | | - |
|
| params | 路由的参数 | Object | | - |
|
||||||
| separator | 分隔符自定义 | String or Element | | '/' |
|
| separator | 分隔符自定义 | String or Element | | '/' |
|
||||||
|
@ -10,8 +10,8 @@ export default class ButtonGroup extends React.Component {
|
|||||||
// large => lg
|
// large => lg
|
||||||
// small => sm
|
// small => sm
|
||||||
const sizeCls = ({
|
const sizeCls = ({
|
||||||
'large': 'lg',
|
large: 'lg',
|
||||||
'small': 'sm'
|
small: 'sm',
|
||||||
})[size] || '';
|
})[size] || '';
|
||||||
|
|
||||||
const classes = classNames({
|
const classes = classNames({
|
||||||
|
@ -24,21 +24,30 @@ function insertSpace(child) {
|
|||||||
return child;
|
return child;
|
||||||
}
|
}
|
||||||
|
|
||||||
export default class Button extends React.Component {
|
function clearButton(button) {
|
||||||
componentDidMount() {
|
button.className = button.className.replace(`${prefix}clicked`, '');
|
||||||
if (window && window.PIE) {
|
|
||||||
window.PIE.attach(findDOMNode(this));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export default class Button extends React.Component {
|
||||||
|
handleClick(...args) {
|
||||||
|
// Add click effect
|
||||||
|
const buttonNode = findDOMNode(this);
|
||||||
|
clearButton(buttonNode);
|
||||||
|
setTimeout(() => buttonNode.className += ` ${prefix}clicked`, 10);
|
||||||
|
clearTimeout(this.timeout);
|
||||||
|
this.timeout = setTimeout(() => clearButton(buttonNode), 500);
|
||||||
|
|
||||||
|
this.props.onClick(...args);
|
||||||
}
|
}
|
||||||
render() {
|
render() {
|
||||||
const props = this.props;
|
const props = this.props;
|
||||||
const {type, shape, size, onClick, className, htmlType, children, ...others} = props;
|
const { type, shape, size, className, htmlType, children, ...others } = props;
|
||||||
|
|
||||||
// large => lg
|
// large => lg
|
||||||
// small => sm
|
// small => sm
|
||||||
const sizeCls = ({
|
const sizeCls = ({
|
||||||
'large': 'lg',
|
large: 'lg',
|
||||||
'small': 'sm'
|
small: 'sm',
|
||||||
})[size] || '';
|
})[size] || '';
|
||||||
|
|
||||||
const classes = classNames({
|
const classes = classNames({
|
||||||
@ -46,15 +55,20 @@ export default class Button extends React.Component {
|
|||||||
[prefix + type]: type,
|
[prefix + type]: type,
|
||||||
[prefix + shape]: shape,
|
[prefix + shape]: shape,
|
||||||
[prefix + sizeCls]: sizeCls,
|
[prefix + sizeCls]: sizeCls,
|
||||||
[prefix + 'loading']: ('loading' in props && props.loading !== false),
|
[`${prefix}loading`]: ('loading' in props && props.loading !== false),
|
||||||
[className]: className
|
[className]: className,
|
||||||
});
|
});
|
||||||
|
|
||||||
const kids = React.Children.map(children, insertSpace);
|
const kids = React.Children.map(children, insertSpace);
|
||||||
|
|
||||||
return <button {...others} type={htmlType || 'button'} className={classes} onClick={onClick}>
|
return (
|
||||||
|
<button {...others}
|
||||||
|
type={htmlType || 'button'}
|
||||||
|
className={classes}
|
||||||
|
onClick={this.handleClick.bind(this)}>
|
||||||
{kids}
|
{kids}
|
||||||
</button>;
|
</button>
|
||||||
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -19,7 +19,7 @@ ReactDOM.render(<div>
|
|||||||
<Button type="ghost">幽灵按钮</Button>
|
<Button type="ghost">幽灵按钮</Button>
|
||||||
<Button type="dashed">虚线按钮</Button>
|
<Button type="dashed">虚线按钮</Button>
|
||||||
</div>,
|
</div>,
|
||||||
document.getElementById('components-button-demo-basic'));
|
mountNode);
|
||||||
````
|
````
|
||||||
|
|
||||||
<style>
|
<style>
|
||||||
|
@ -19,9 +19,9 @@ ReactDOM.render(<div>
|
|||||||
<Button type="primary">取消</Button>
|
<Button type="primary">取消</Button>
|
||||||
</ButtonGroup>
|
</ButtonGroup>
|
||||||
<ButtonGroup>
|
<ButtonGroup>
|
||||||
<Button>左</Button>
|
<Button disabled>左</Button>
|
||||||
<Button>中</Button>
|
<Button disabled>中</Button>
|
||||||
<Button>右</Button>
|
<Button disabled>右</Button>
|
||||||
</ButtonGroup>
|
</ButtonGroup>
|
||||||
<ButtonGroup>
|
<ButtonGroup>
|
||||||
<Button type="primary">左</Button>
|
<Button type="primary">左</Button>
|
||||||
@ -79,7 +79,7 @@ ReactDOM.render(<div>
|
|||||||
<Button type="ghost">小</Button>
|
<Button type="ghost">小</Button>
|
||||||
</ButtonGroup>
|
</ButtonGroup>
|
||||||
</div>
|
</div>
|
||||||
, document.getElementById('components-button-demo-button-group'));
|
, mountNode);
|
||||||
````
|
````
|
||||||
|
|
||||||
<style>
|
<style>
|
||||||
|
@ -22,7 +22,7 @@ ReactDOM.render(<div>
|
|||||||
<Button type="dashed">虚线按钮</Button>
|
<Button type="dashed">虚线按钮</Button>
|
||||||
<Button type="dashed" disabled>虚线按钮(失效)</Button>
|
<Button type="dashed" disabled>虚线按钮(失效)</Button>
|
||||||
</div>
|
</div>
|
||||||
, document.getElementById('components-button-demo-disabled'));
|
, mountNode);
|
||||||
````
|
````
|
||||||
|
|
||||||
<style>
|
<style>
|
||||||
|
@ -46,7 +46,7 @@ ReactDOM.render(<div>
|
|||||||
<Icon type="search" />
|
<Icon type="search" />
|
||||||
</Button>
|
</Button>
|
||||||
</div>,
|
</div>,
|
||||||
document.getElementById('components-button-demo-icon'));
|
mountNode);
|
||||||
````
|
````
|
||||||
|
|
||||||
<style>
|
<style>
|
||||||
|
@ -23,7 +23,8 @@ const App = React.createClass({
|
|||||||
this.setState({ iconLoading: true });
|
this.setState({ iconLoading: true });
|
||||||
},
|
},
|
||||||
render() {
|
render() {
|
||||||
return <div>
|
return (
|
||||||
|
<div>
|
||||||
<Button type="primary" size="large" loading>
|
<Button type="primary" size="large" loading>
|
||||||
加载中
|
加载中
|
||||||
</Button>
|
</Button>
|
||||||
@ -40,11 +41,12 @@ const App = React.createClass({
|
|||||||
<Button type="primary" loading={this.state.iconLoading} onClick={this.enterIconLoading}>
|
<Button type="primary" loading={this.state.iconLoading} onClick={this.enterIconLoading}>
|
||||||
<Icon type="poweroff" />点击变加载
|
<Icon type="poweroff" />点击变加载
|
||||||
</Button>
|
</Button>
|
||||||
</div>;
|
</div>
|
||||||
|
);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
ReactDOM.render(<App />, document.getElementById('components-button-demo-loading'));
|
ReactDOM.render(<App />, mountNode);
|
||||||
````
|
````
|
||||||
|
|
||||||
<style>
|
<style>
|
||||||
|
@ -30,7 +30,7 @@ ReactDOM.render(<div>
|
|||||||
<Icon type="search" />
|
<Icon type="search" />
|
||||||
</Button>
|
</Button>
|
||||||
</div>
|
</div>
|
||||||
, document.getElementById('components-button-demo-shape'));
|
, mountNode);
|
||||||
````
|
````
|
||||||
|
|
||||||
<style>
|
<style>
|
||||||
|
@ -16,7 +16,7 @@ ReactDOM.render(<div>
|
|||||||
<Button type="primary">中号按钮(默认)</Button>
|
<Button type="primary">中号按钮(默认)</Button>
|
||||||
<Button type="primary" size="small">小号按钮</Button>
|
<Button type="primary" size="small">小号按钮</Button>
|
||||||
</div>
|
</div>
|
||||||
, document.getElementById('components-button-demo-size'));
|
, mountNode);
|
||||||
````
|
````
|
||||||
|
|
||||||
<style>
|
<style>
|
||||||
|
@ -21,25 +21,11 @@
|
|||||||
|
|
||||||
属性 | 说明 | 类型 | 默认值
|
属性 | 说明 | 类型 | 默认值
|
||||||
-----|-----|-----|------
|
-----|-----|-----|------
|
||||||
type | 设置按钮类型,可选值为 `primary` `ghost` 或者不设 | Enum | undefined
|
type | 设置按钮类型,可选值为 `primary` `ghost` 或者不设 | string | -
|
||||||
htmlType | 设置 `button` 原生的 `type` 值,可选值请参考 HTML标准 | Enum | `button`
|
htmlType | 设置 `button` 原生的 `type` 值,可选值请参考 HTML标准 | string | `button`
|
||||||
shape | 设置按钮形状,可选值为 `circle` `circle-outline` 或者不设 | Enum | undefined
|
shape | 设置按钮形状,可选值为 `circle` `circle-outline` 或者不设 | string | 无
|
||||||
size | 设置按钮大小,可选值为 `small` `large` 或者不设 | Enum | undefined
|
size | 设置按钮大小,可选值为 `small` `large` 或者不设 | string | `default`
|
||||||
loading | 设置按钮载入状态,存在为 `true`,不存在为 `false`,或直接设置值,如:`loading="true"` | Bool | false
|
loading | 设置按钮载入状态 | boolean | false
|
||||||
onClick | `click` 事件的 handler | Function | `function() {}`
|
onClick | `click` 事件的 handler | function | `function() {}`
|
||||||
|
|
||||||
- `<Button>Hello world!</Button>` 最终会被渲染为 `<button>Hello world!</button>`,并且除了上表中的属性,其它属性都会直接传到 `<button></button>`
|
- `<Button>Hello world!</Button>` 最终会被渲染为 `<button>Hello world!</button>`,并且除了上表中的属性,其它属性都会直接传到 `<button></button>`
|
||||||
|
|
||||||
|
|
||||||
### IE8 border radius support
|
|
||||||
|
|
||||||
Ant Design 视觉上采用渐进降级的方案,在 IE8 下圆角按钮将降级为直角。
|
|
||||||
如果强烈需要圆角按钮,我们提供了 [css3pie](http://css3pie.com/) 的兼容方案。
|
|
||||||
|
|
||||||
使用时只需在 html 头部加入以下代码即可。
|
|
||||||
|
|
||||||
```html
|
|
||||||
<!--[if IE 8]>
|
|
||||||
<script src="https://t.alipayobjects.com/images/rmsweb/T1q8JiXftaXXXXXXXX.js"></script>
|
|
||||||
<![endif]-->
|
|
||||||
```
|
|
||||||
|
@ -68,11 +68,8 @@ class Header extends Component {
|
|||||||
}
|
}
|
||||||
render() {
|
render() {
|
||||||
const { type, value, prefixCls, locale } = this.props;
|
const { type, value, prefixCls, locale } = this.props;
|
||||||
|
|
||||||
const yearSelect = this.getYearSelectElement(value.getYear());
|
const yearSelect = this.getYearSelectElement(value.getYear());
|
||||||
|
|
||||||
const monthSelect = type === 'date' ? this.getMonthSelectElement(value.getMonth()) : null;
|
const monthSelect = type === 'date' ? this.getMonthSelectElement(value.getMonth()) : null;
|
||||||
|
|
||||||
const typeSwitch = (
|
const typeSwitch = (
|
||||||
<Group onChange={this.onTypeChange.bind(this)} value={type}>
|
<Group onChange={this.onTypeChange.bind(this)} value={type}>
|
||||||
<Button value="date">{locale.month}</Button>
|
<Button value="date">{locale.month}</Button>
|
||||||
|
@ -15,5 +15,5 @@ function onPanelChange(value, mode) {
|
|||||||
|
|
||||||
ReactDOM.render(
|
ReactDOM.render(
|
||||||
<Calendar onPanelChange={onPanelChange} />
|
<Calendar onPanelChange={onPanelChange} />
|
||||||
, document.getElementById('components-calendar-demo-basic'));
|
, mountNode);
|
||||||
````
|
````
|
||||||
|
@ -17,5 +17,5 @@ ReactDOM.render(
|
|||||||
<div style={{ width: 290, border: '1px solid #d9d9d9', borderRadius: 4 }}>
|
<div style={{ width: 290, border: '1px solid #d9d9d9', borderRadius: 4 }}>
|
||||||
<Calendar fullscreen={false} onPanelChange={onPanelChange} />
|
<Calendar fullscreen={false} onPanelChange={onPanelChange} />
|
||||||
</div>
|
</div>
|
||||||
, document.getElementById('components-calendar-demo-card'));
|
, mountNode);
|
||||||
````
|
````
|
||||||
|
@ -20,5 +20,5 @@ function monthCellRender(value) {
|
|||||||
ReactDOM.render(
|
ReactDOM.render(
|
||||||
<Calendar defaultValue={new Date('2010-10-10')}
|
<Calendar defaultValue={new Date('2010-10-10')}
|
||||||
dateCellRender={dateCellRender} monthCellRender={monthCellRender} />
|
dateCellRender={dateCellRender} monthCellRender={monthCellRender} />
|
||||||
, document.getElementById('components-calendar-demo-custom-render'));
|
, mountNode);
|
||||||
````
|
````
|
||||||
|
@ -16,5 +16,5 @@ function onPanelChange(value, mode) {
|
|||||||
|
|
||||||
ReactDOM.render(
|
ReactDOM.render(
|
||||||
<Calendar onPanelChange={onPanelChange} locale={enUS} />
|
<Calendar onPanelChange={onPanelChange} locale={enUS} />
|
||||||
, document.getElementById('components-calendar-demo-locale'));
|
, mountNode);
|
||||||
````
|
````
|
||||||
|
@ -39,14 +39,18 @@ function getListData(value) {
|
|||||||
|
|
||||||
function dateCellRender(value) {
|
function dateCellRender(value) {
|
||||||
let listData = getListData(value);
|
let listData = getListData(value);
|
||||||
return <ul className="events">
|
return (
|
||||||
{listData.map((item, index) =>
|
<ul className="events">
|
||||||
|
{
|
||||||
|
listData.map((item, index) =>
|
||||||
<li key={index}>
|
<li key={index}>
|
||||||
<span className={`event-${item.type}`}>●</span>
|
<span className={`event-${item.type}`}>●</span>
|
||||||
{item.content}
|
{item.content}
|
||||||
</li>
|
</li>
|
||||||
)}
|
)
|
||||||
</ul>;
|
}
|
||||||
|
</ul>
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -66,7 +70,7 @@ function monthCellRender(value) {
|
|||||||
|
|
||||||
ReactDOM.render(
|
ReactDOM.render(
|
||||||
<Calendar dateCellRender={dateCellRender} monthCellRender={monthCellRender} />
|
<Calendar dateCellRender={dateCellRender} monthCellRender={monthCellRender} />
|
||||||
, document.getElementById('components-calendar-demo-notice-calendar'));
|
, mountNode);
|
||||||
````
|
````
|
||||||
|
|
||||||
|
|
||||||
|
@ -8,8 +8,8 @@ import Header from './Header';
|
|||||||
function noop() { return null; }
|
function noop() { return null; }
|
||||||
|
|
||||||
function zerofixed(v) {
|
function zerofixed(v) {
|
||||||
if (v < 10) return '0' + v;
|
if (v < 10) return `0${v}`;
|
||||||
return v + '';
|
return `${v}`;
|
||||||
}
|
}
|
||||||
|
|
||||||
class Calendar extends Component {
|
class Calendar extends Component {
|
||||||
@ -35,25 +35,29 @@ class Calendar extends Component {
|
|||||||
monthCellRender(value, locale) {
|
monthCellRender(value, locale) {
|
||||||
const prefixCls = this.props.prefixCls;
|
const prefixCls = this.props.prefixCls;
|
||||||
const month = value.getMonth();
|
const month = value.getMonth();
|
||||||
return <div className={`${prefixCls}-month`}>
|
return (
|
||||||
|
<div className={`${prefixCls}-month`}>
|
||||||
<div className={`${prefixCls}-value`}>
|
<div className={`${prefixCls}-value`}>
|
||||||
{locale.format.shortMonths[month]}
|
{locale.format.shortMonths[month]}
|
||||||
</div>
|
</div>
|
||||||
<div className={`${prefixCls}-content`}>
|
<div className={`${prefixCls}-content`}>
|
||||||
{this.props.monthCellRender(value)}
|
{this.props.monthCellRender(value)}
|
||||||
</div>
|
</div>
|
||||||
</div>;
|
</div>
|
||||||
|
);
|
||||||
}
|
}
|
||||||
dateCellRender(value) {
|
dateCellRender(value) {
|
||||||
const prefixCls = this.props.prefixCls;
|
const prefixCls = this.props.prefixCls;
|
||||||
return <div className={`${prefixCls}-date`}>
|
return (
|
||||||
|
<div className={`${prefixCls}-date`}>
|
||||||
<div className={`${prefixCls}-value`}>
|
<div className={`${prefixCls}-value`}>
|
||||||
{zerofixed(value.getDayOfMonth())}
|
{zerofixed(value.getDayOfMonth())}
|
||||||
</div>
|
</div>
|
||||||
<div className={`${prefixCls}-content`}>
|
<div className={`${prefixCls}-content`}>
|
||||||
{this.props.dateCellRender(value)}
|
{this.props.dateCellRender(value)}
|
||||||
</div>
|
</div>
|
||||||
</div>;
|
</div>
|
||||||
|
);
|
||||||
}
|
}
|
||||||
setValue(value) {
|
setValue(value) {
|
||||||
if (!('value' in this.props) && this.state.value !== value) {
|
if (!('value' in this.props) && this.state.value !== value) {
|
||||||
@ -76,7 +80,7 @@ class Calendar extends Component {
|
|||||||
|
|
||||||
let cls = className || '';
|
let cls = className || '';
|
||||||
if (fullscreen) {
|
if (fullscreen) {
|
||||||
cls += (' ' + prefixCls + '-fullscreen');
|
cls += (` ${prefixCls}-fullscreen`);
|
||||||
}
|
}
|
||||||
|
|
||||||
return (
|
return (
|
||||||
|
@ -16,6 +16,6 @@ ReactDOM.render(
|
|||||||
<div><h3>3</h3></div>
|
<div><h3>3</h3></div>
|
||||||
<div><h3>4</h3></div>
|
<div><h3>4</h3></div>
|
||||||
</Carousel>
|
</Carousel>
|
||||||
, document.getElementById('components-carousel-demo-autoplay'));
|
, mountNode);
|
||||||
````
|
````
|
||||||
|
|
||||||
|
@ -20,5 +20,5 @@ ReactDOM.render(
|
|||||||
<div><h3>3</h3></div>
|
<div><h3>3</h3></div>
|
||||||
<div><h3>4</h3></div>
|
<div><h3>4</h3></div>
|
||||||
</Carousel>
|
</Carousel>
|
||||||
, document.getElementById('components-carousel-demo-basic'));
|
, mountNode);
|
||||||
````
|
````
|
||||||
|
@ -16,6 +16,6 @@ ReactDOM.render(
|
|||||||
<div><h3>3</h3></div>
|
<div><h3>3</h3></div>
|
||||||
<div><h3>4</h3></div>
|
<div><h3>4</h3></div>
|
||||||
</Carousel>
|
</Carousel>
|
||||||
, document.getElementById('components-carousel-demo-fade'));
|
, mountNode);
|
||||||
````
|
````
|
||||||
|
|
||||||
|
@ -16,5 +16,5 @@ ReactDOM.render(
|
|||||||
<div><h3>3</h3></div>
|
<div><h3>3</h3></div>
|
||||||
<div><h3>4</h3></div>
|
<div><h3>4</h3></div>
|
||||||
</Carousel>
|
</Carousel>
|
||||||
, document.getElementById('components-carousel-demo-vertical'));
|
, mountNode);
|
||||||
````
|
````
|
||||||
|
@ -4,10 +4,10 @@ if (typeof window !== 'undefined') {
|
|||||||
const matchMediaPolyfill = function matchMediaPolyfill() {
|
const matchMediaPolyfill = function matchMediaPolyfill() {
|
||||||
return {
|
return {
|
||||||
matches: false,
|
matches: false,
|
||||||
addListener: function () {
|
addListener() {
|
||||||
|
},
|
||||||
|
removeListener() {
|
||||||
},
|
},
|
||||||
removeListener: function () {
|
|
||||||
}
|
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
window.matchMedia = window.matchMedia || matchMediaPolyfill;
|
window.matchMedia = window.matchMedia || matchMediaPolyfill;
|
||||||
@ -21,7 +21,7 @@ const AntCarousel = React.createClass({
|
|||||||
getDefaultProps() {
|
getDefaultProps() {
|
||||||
return {
|
return {
|
||||||
dots: true,
|
dots: true,
|
||||||
arrows: false
|
arrows: false,
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
render() {
|
render() {
|
||||||
@ -34,7 +34,7 @@ const AntCarousel = React.createClass({
|
|||||||
|
|
||||||
let className = 'ant-carousel';
|
let className = 'ant-carousel';
|
||||||
if (props.vertical) {
|
if (props.vertical) {
|
||||||
className = className + ' ant-carousel-vertical';
|
className = `${className} ant-carousel-vertical`;
|
||||||
}
|
}
|
||||||
|
|
||||||
return (
|
return (
|
||||||
|
43
components/cascader/demo/basic.md
Normal file
43
components/cascader/demo/basic.md
Normal file
@ -0,0 +1,43 @@
|
|||||||
|
# 基本
|
||||||
|
|
||||||
|
- order: 0
|
||||||
|
|
||||||
|
省市区级联。
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
````jsx
|
||||||
|
import { Cascader } from 'antd';
|
||||||
|
|
||||||
|
const options = [{
|
||||||
|
value: 'zhejiang',
|
||||||
|
label: '浙江',
|
||||||
|
children: [{
|
||||||
|
value: 'hangzhou',
|
||||||
|
label: '杭州',
|
||||||
|
children: [{
|
||||||
|
value: 'xihu',
|
||||||
|
label: '西湖',
|
||||||
|
}],
|
||||||
|
}],
|
||||||
|
}, {
|
||||||
|
value: 'jiangsu',
|
||||||
|
label: '江苏',
|
||||||
|
children: [{
|
||||||
|
value: 'nanjing',
|
||||||
|
label: '南京',
|
||||||
|
children: [{
|
||||||
|
value: 'zhonghuamen',
|
||||||
|
label: '中华门',
|
||||||
|
}],
|
||||||
|
}],
|
||||||
|
}];
|
||||||
|
|
||||||
|
function onChange(value) {
|
||||||
|
console.log(value);
|
||||||
|
}
|
||||||
|
|
||||||
|
ReactDOM.render(
|
||||||
|
<Cascader options={options} onChange={onChange} />
|
||||||
|
, mountNode);
|
||||||
|
````
|
43
components/cascader/demo/change-on-select.md
Normal file
43
components/cascader/demo/change-on-select.md
Normal file
@ -0,0 +1,43 @@
|
|||||||
|
# 选择即改变
|
||||||
|
|
||||||
|
- order: 5
|
||||||
|
|
||||||
|
这种交互允许只选中父级选项。
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
````jsx
|
||||||
|
import { Cascader } from 'antd';
|
||||||
|
|
||||||
|
const options = [{
|
||||||
|
value: 'zhejiang',
|
||||||
|
label: '浙江',
|
||||||
|
children: [{
|
||||||
|
value: 'hangzhou',
|
||||||
|
label: '杭州',
|
||||||
|
children: [{
|
||||||
|
value: 'xihu',
|
||||||
|
label: '西湖',
|
||||||
|
}],
|
||||||
|
}],
|
||||||
|
}, {
|
||||||
|
value: 'jiangsu',
|
||||||
|
label: '江苏',
|
||||||
|
children: [{
|
||||||
|
value: 'nanjing',
|
||||||
|
label: '南京',
|
||||||
|
children: [{
|
||||||
|
value: 'zhonghuamen',
|
||||||
|
label: '中华门',
|
||||||
|
}],
|
||||||
|
}],
|
||||||
|
}];
|
||||||
|
|
||||||
|
function onChange(value) {
|
||||||
|
console.log(value);
|
||||||
|
}
|
||||||
|
|
||||||
|
ReactDOM.render(
|
||||||
|
<Cascader options={options} onChange={onChange} changeOnSelect />
|
||||||
|
, mountNode);
|
||||||
|
````
|
53
components/cascader/demo/custom-trigger.md
Normal file
53
components/cascader/demo/custom-trigger.md
Normal file
@ -0,0 +1,53 @@
|
|||||||
|
# 可以自定义显示
|
||||||
|
|
||||||
|
- order: 1
|
||||||
|
|
||||||
|
切换按钮和结果分开。
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
````jsx
|
||||||
|
import { Cascader } from 'antd';
|
||||||
|
|
||||||
|
const options = [{
|
||||||
|
value: 'zhejiang',
|
||||||
|
label: '浙江',
|
||||||
|
children: [{
|
||||||
|
value: 'hangzhou',
|
||||||
|
label: '杭州',
|
||||||
|
}],
|
||||||
|
}, {
|
||||||
|
value: 'jiangsu',
|
||||||
|
label: '江苏',
|
||||||
|
children: [{
|
||||||
|
value: 'nanjing',
|
||||||
|
label: '南京',
|
||||||
|
}],
|
||||||
|
}];
|
||||||
|
|
||||||
|
const CitySwitcher = React.createClass({
|
||||||
|
getInitialState() {
|
||||||
|
return {
|
||||||
|
text: '未选择',
|
||||||
|
};
|
||||||
|
},
|
||||||
|
onChange(value, selectedOptions) {
|
||||||
|
this.setState({
|
||||||
|
text: selectedOptions.map(o => o.label).join(', '),
|
||||||
|
});
|
||||||
|
},
|
||||||
|
render() {
|
||||||
|
return (
|
||||||
|
<span>
|
||||||
|
{this.state.text}
|
||||||
|
|
||||||
|
<Cascader options={options} onChange={this.onChange}>
|
||||||
|
<a href="#">切换城市</a>
|
||||||
|
</Cascader>
|
||||||
|
</span>
|
||||||
|
);
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
|
ReactDOM.render(<CitySwitcher />, mountNode);
|
||||||
|
````
|
43
components/cascader/demo/default-value.md
Normal file
43
components/cascader/demo/default-value.md
Normal file
@ -0,0 +1,43 @@
|
|||||||
|
# 默认值
|
||||||
|
|
||||||
|
- order: 0
|
||||||
|
|
||||||
|
默认值通过数组的方式指定。
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
````jsx
|
||||||
|
import { Cascader } from 'antd';
|
||||||
|
|
||||||
|
const options = [{
|
||||||
|
value: 'zhejiang',
|
||||||
|
label: '浙江',
|
||||||
|
children: [{
|
||||||
|
value: 'hangzhou',
|
||||||
|
label: '杭州',
|
||||||
|
children: [{
|
||||||
|
value: 'xihu',
|
||||||
|
label: '西湖',
|
||||||
|
}],
|
||||||
|
}],
|
||||||
|
}, {
|
||||||
|
value: 'jiangsu',
|
||||||
|
label: '江苏',
|
||||||
|
children: [{
|
||||||
|
value: 'nanjing',
|
||||||
|
label: '南京',
|
||||||
|
children: [{
|
||||||
|
value: 'zhonghuamen',
|
||||||
|
label: '中华门',
|
||||||
|
}],
|
||||||
|
}],
|
||||||
|
}];
|
||||||
|
|
||||||
|
function onChange(value) {
|
||||||
|
console.log(value);
|
||||||
|
}
|
||||||
|
|
||||||
|
ReactDOM.render(
|
||||||
|
<Cascader defaultValue={['zhejiang', 'hangzhou', 'xihu']} options={options} onChange={onChange} />
|
||||||
|
, mountNode);
|
||||||
|
````
|
44
components/cascader/demo/disabled-option.md
Normal file
44
components/cascader/demo/disabled-option.md
Normal file
@ -0,0 +1,44 @@
|
|||||||
|
# 禁用选项
|
||||||
|
|
||||||
|
- order: 4
|
||||||
|
|
||||||
|
通过指定 options 里的 `disabled` 字段。
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
````jsx
|
||||||
|
import { Cascader } from 'antd';
|
||||||
|
|
||||||
|
const options = [{
|
||||||
|
value: 'zhejiang',
|
||||||
|
label: '浙江',
|
||||||
|
children: [{
|
||||||
|
value: 'hangzhou',
|
||||||
|
label: '杭州',
|
||||||
|
children: [{
|
||||||
|
value: 'xihu',
|
||||||
|
label: '西湖',
|
||||||
|
}],
|
||||||
|
}],
|
||||||
|
}, {
|
||||||
|
value: 'jiangsu',
|
||||||
|
label: '江苏',
|
||||||
|
disabled: true,
|
||||||
|
children: [{
|
||||||
|
value: 'nanjing',
|
||||||
|
label: '南京',
|
||||||
|
children: [{
|
||||||
|
value: 'zhonghuamen',
|
||||||
|
label: '中华门',
|
||||||
|
}],
|
||||||
|
}],
|
||||||
|
}];
|
||||||
|
|
||||||
|
function onChange(value) {
|
||||||
|
console.log(value);
|
||||||
|
}
|
||||||
|
|
||||||
|
ReactDOM.render(
|
||||||
|
<Cascader options={options} onChange={onChange} />
|
||||||
|
, mountNode);
|
||||||
|
````
|
49
components/cascader/demo/hover.md
Normal file
49
components/cascader/demo/hover.md
Normal file
@ -0,0 +1,49 @@
|
|||||||
|
# 移入展开
|
||||||
|
|
||||||
|
- order: 2
|
||||||
|
|
||||||
|
通过移入展开下级菜单,点击完成选择。
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
````jsx
|
||||||
|
import { Cascader } from 'antd';
|
||||||
|
|
||||||
|
const options = [{
|
||||||
|
value: 'zhejiang',
|
||||||
|
label: '浙江',
|
||||||
|
children: [{
|
||||||
|
value: 'hangzhou',
|
||||||
|
label: '杭州',
|
||||||
|
children: [{
|
||||||
|
value: 'xihu',
|
||||||
|
label: '西湖',
|
||||||
|
}],
|
||||||
|
}],
|
||||||
|
}, {
|
||||||
|
value: 'jiangsu',
|
||||||
|
label: '江苏',
|
||||||
|
children: [{
|
||||||
|
value: 'nanjing',
|
||||||
|
label: '南京',
|
||||||
|
children: [{
|
||||||
|
value: 'zhonghuamen',
|
||||||
|
label: '中华门',
|
||||||
|
}],
|
||||||
|
}],
|
||||||
|
}];
|
||||||
|
|
||||||
|
function onChange(value) {
|
||||||
|
console.log(value);
|
||||||
|
}
|
||||||
|
|
||||||
|
// 只展示最后一项
|
||||||
|
function displayRender(label) {
|
||||||
|
return label[label.length - 1];
|
||||||
|
}
|
||||||
|
|
||||||
|
ReactDOM.render(
|
||||||
|
<Cascader options={options} expandTrigger="hover"
|
||||||
|
displayRender={displayRender} onChange={onChange} />
|
||||||
|
, mountNode);
|
||||||
|
````
|
47
components/cascader/demo/size.md
Normal file
47
components/cascader/demo/size.md
Normal file
@ -0,0 +1,47 @@
|
|||||||
|
# 大小
|
||||||
|
|
||||||
|
- order: 7
|
||||||
|
|
||||||
|
不同大小的级联选择器。
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
````jsx
|
||||||
|
import { Cascader } from 'antd';
|
||||||
|
|
||||||
|
const options = [{
|
||||||
|
value: 'zhejiang',
|
||||||
|
label: '浙江',
|
||||||
|
children: [{
|
||||||
|
value: 'hangzhou',
|
||||||
|
label: '杭州',
|
||||||
|
children: [{
|
||||||
|
value: 'xihu',
|
||||||
|
label: '西湖',
|
||||||
|
}],
|
||||||
|
}],
|
||||||
|
}, {
|
||||||
|
value: 'jiangsu',
|
||||||
|
label: '江苏',
|
||||||
|
children: [{
|
||||||
|
value: 'nanjing',
|
||||||
|
label: '南京',
|
||||||
|
children: [{
|
||||||
|
value: 'zhonghuamen',
|
||||||
|
label: '中华门',
|
||||||
|
}],
|
||||||
|
}],
|
||||||
|
}];
|
||||||
|
|
||||||
|
function onChange(value) {
|
||||||
|
console.log(value);
|
||||||
|
}
|
||||||
|
|
||||||
|
ReactDOM.render(
|
||||||
|
<div>
|
||||||
|
<Cascader size="large" options={options} onChange={onChange} /><br /><br />
|
||||||
|
<Cascader options={options} onChange={onChange} /><br /><br />
|
||||||
|
<Cascader size="small" options={options} onChange={onChange} /><br /><br />
|
||||||
|
</div>
|
||||||
|
, mountNode);
|
||||||
|
````
|
118
components/cascader/index.jsx
Normal file
118
components/cascader/index.jsx
Normal file
@ -0,0 +1,118 @@
|
|||||||
|
import React from 'react';
|
||||||
|
import Cascader from 'rc-cascader';
|
||||||
|
import Input from '../input';
|
||||||
|
import Icon from '../icon';
|
||||||
|
import arrayTreeFilter from 'array-tree-filter';
|
||||||
|
import classNames from 'classnames';
|
||||||
|
|
||||||
|
class AntCascader extends React.Component {
|
||||||
|
constructor(props) {
|
||||||
|
super(props);
|
||||||
|
this.state = {
|
||||||
|
value: props.value || props.defaultValue || [],
|
||||||
|
popupVisible: false,
|
||||||
|
};
|
||||||
|
[
|
||||||
|
'handleChange',
|
||||||
|
'handlePopupVisibleChange',
|
||||||
|
'setValue',
|
||||||
|
'getLabel',
|
||||||
|
'clearSelection',
|
||||||
|
].forEach((method) => this[method] = this[method].bind(this));
|
||||||
|
}
|
||||||
|
componentWillReceiveProps(nextProps) {
|
||||||
|
if ('value' in nextProps) {
|
||||||
|
this.setState({ value: nextProps.value || [] });
|
||||||
|
}
|
||||||
|
}
|
||||||
|
handleChange(value, selectedOptions) {
|
||||||
|
this.setValue(value, selectedOptions);
|
||||||
|
}
|
||||||
|
handlePopupVisibleChange(popupVisible) {
|
||||||
|
this.setState({ popupVisible });
|
||||||
|
this.props.onPopupVisibleChange(popupVisible);
|
||||||
|
}
|
||||||
|
setValue(value, selectedOptions = []) {
|
||||||
|
if (!('value' in this.props)) {
|
||||||
|
this.setState({ value });
|
||||||
|
}
|
||||||
|
this.props.onChange(value, selectedOptions);
|
||||||
|
}
|
||||||
|
getLabel() {
|
||||||
|
const { options, displayRender } = this.props;
|
||||||
|
const label = arrayTreeFilter(options, (o, level) => o.value === this.state.value[level])
|
||||||
|
.map(o => o.label);
|
||||||
|
return displayRender(label);
|
||||||
|
}
|
||||||
|
clearSelection(e) {
|
||||||
|
e.preventDefault();
|
||||||
|
e.stopPropagation();
|
||||||
|
this.setValue([]);
|
||||||
|
this.setState({ popupVisible: false });
|
||||||
|
}
|
||||||
|
render() {
|
||||||
|
const { prefixCls, children, placeholder, size, disabled,
|
||||||
|
className, style, allowClear, ...otherProps } = this.props;
|
||||||
|
const sizeCls = classNames({
|
||||||
|
'ant-input-lg': size === 'large',
|
||||||
|
'ant-input-sm': size === 'small',
|
||||||
|
});
|
||||||
|
const clearIcon = (allowClear && !disabled && this.state.value.length > 0) ?
|
||||||
|
<Icon type="cross-circle"
|
||||||
|
className={`${prefixCls}-picker-clear`}
|
||||||
|
onClick={this.clearSelection} /> : null;
|
||||||
|
const arrowCls = classNames({
|
||||||
|
[`${prefixCls}-picker-arrow`]: true,
|
||||||
|
[`${prefixCls}-picker-arrow-expand`]: this.state.popupVisible,
|
||||||
|
});
|
||||||
|
const pickerCls = classNames({
|
||||||
|
[className]: !!className,
|
||||||
|
[`${prefixCls}-picker`]: true,
|
||||||
|
[`${prefixCls}-picker-disabled`]: disabled,
|
||||||
|
});
|
||||||
|
|
||||||
|
// Fix bug of https://github.com/facebook/react/pull/5004
|
||||||
|
delete otherProps.onChange;
|
||||||
|
|
||||||
|
return (
|
||||||
|
<Cascader {...this.props}
|
||||||
|
value={this.state.value}
|
||||||
|
popupVisible={this.state.popupVisible}
|
||||||
|
onPopupVisibleChange={this.handlePopupVisibleChange}
|
||||||
|
onChange={this.handleChange}>
|
||||||
|
{children ||
|
||||||
|
<span
|
||||||
|
style={style}
|
||||||
|
className={pickerCls}>
|
||||||
|
<Input {...otherProps}
|
||||||
|
placeholder={placeholder}
|
||||||
|
className={`${prefixCls}-input ant-input ${sizeCls}`}
|
||||||
|
style={{ width: '100%' }}
|
||||||
|
value={this.getLabel()}
|
||||||
|
disabled={disabled}
|
||||||
|
readOnly />
|
||||||
|
{clearIcon}
|
||||||
|
<Icon type="down" className={arrowCls} />
|
||||||
|
</span>
|
||||||
|
}
|
||||||
|
</Cascader>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
AntCascader.defaultProps = {
|
||||||
|
prefixCls: 'ant-cascader',
|
||||||
|
placeholder: '请选择',
|
||||||
|
transitionName: 'slide-up',
|
||||||
|
popupPlacement: 'bottomLeft',
|
||||||
|
onChange() {},
|
||||||
|
options: [],
|
||||||
|
displayRender(label) {
|
||||||
|
return label.join(' / ');
|
||||||
|
},
|
||||||
|
disabled: false,
|
||||||
|
allowClear: true,
|
||||||
|
onPopupVisibleChange() {},
|
||||||
|
};
|
||||||
|
|
||||||
|
export default AntCascader;
|
38
components/cascader/index.md
Normal file
38
components/cascader/index.md
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
# Cascader
|
||||||
|
|
||||||
|
- category: Components
|
||||||
|
- chinese: 级联选择
|
||||||
|
- type: 表单
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
级联选择框。
|
||||||
|
|
||||||
|
|
||||||
|
## 何时使用
|
||||||
|
|
||||||
|
- 需要从一组相关联的数据集合进行选择,例如省市区,公司层级,事物分类等。
|
||||||
|
- 从一个较大的数据集合中进行选择时,用多级分类进行分隔,方便选择。
|
||||||
|
- 比起 Select 组件,可以在同一个浮层中完成选择,有较好的体验。
|
||||||
|
|
||||||
|
## API
|
||||||
|
|
||||||
|
```html
|
||||||
|
<Cascader options={options} onChange={onChange} />
|
||||||
|
```
|
||||||
|
|
||||||
|
| 参数 | 说明 | 类型 | 默认值 |
|
||||||
|
|------|------|------|--------|
|
||||||
|
| options | 可选项数据源 | object | - |
|
||||||
|
| defaultValue | 默认的选中项 | array |[] |
|
||||||
|
| value | 指定选中项 | array | - |
|
||||||
|
| onChange | 选择完成后的回调 | `function(value, selectedOptions)` | - |
|
||||||
|
| displayRender | 选择后展示的渲染函数 | `function(label)`` | `function(label) { return label.join(' / ') }` |
|
||||||
|
| style | 自定义样式 | string | - |
|
||||||
|
| className | 自定义类名 | string | - |
|
||||||
|
| popupClassName | 自定义浮层类名 | string | - |
|
||||||
|
| popupPlacement | 浮层预设位置:`bottomLeft` `bottomRight` `topLeft` `topRight` | string | `bottomLeft` |
|
||||||
|
| placeholder | 输入框占位文本 | string | '请选择' |
|
||||||
|
| size | 输入框大小,可选 `large` `default` `small` | string | `default` |
|
||||||
|
| disabled | 禁用 | boolean | false |
|
||||||
|
| allowClear | 是否支持清除 | boolean | true |
|
@ -5,6 +5,7 @@ export default React.createClass({
|
|||||||
getDefaultProps() {
|
getDefaultProps() {
|
||||||
return {
|
return {
|
||||||
options: [],
|
options: [],
|
||||||
|
defaultValue: [],
|
||||||
onChange() {},
|
onChange() {},
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
@ -15,21 +16,25 @@ export default React.createClass({
|
|||||||
onChange: React.PropTypes.func,
|
onChange: React.PropTypes.func,
|
||||||
},
|
},
|
||||||
getInitialState() {
|
getInitialState() {
|
||||||
const { value, defaultValue } = this.props;
|
const props = this.props;
|
||||||
return {
|
let value;
|
||||||
value: value || defaultValue || [],
|
if ('value' in props) {
|
||||||
};
|
value = props.value;
|
||||||
|
} else if ('defaultValue' in props) {
|
||||||
|
value = props.defaultValue;
|
||||||
|
}
|
||||||
|
return { value };
|
||||||
},
|
},
|
||||||
componentWillReceiveProps(nextProps) {
|
componentWillReceiveProps(nextProps) {
|
||||||
if ('value' in nextProps) {
|
if ('value' in nextProps) {
|
||||||
this.setState({
|
this.setState({
|
||||||
value: nextProps.value,
|
value: nextProps.value || [],
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
toggleOption(option) {
|
toggleOption(option) {
|
||||||
const optionIndex = this.state.value.indexOf(option);
|
const optionIndex = this.state.value.indexOf(option);
|
||||||
const value = this.state.value;
|
const value = [...this.state.value];
|
||||||
if (optionIndex === - 1) {
|
if (optionIndex === - 1) {
|
||||||
value.push(option);
|
value.push(option);
|
||||||
} else {
|
} else {
|
||||||
@ -42,7 +47,8 @@ export default React.createClass({
|
|||||||
},
|
},
|
||||||
render() {
|
render() {
|
||||||
const options = this.props.options;
|
const options = this.props.options;
|
||||||
return <div className="ant-checkbox-group">
|
return (
|
||||||
|
<div className="ant-checkbox-group">
|
||||||
{
|
{
|
||||||
options.map(option =>
|
options.map(option =>
|
||||||
<label className="ant-checkbox-group-item" key={option}>
|
<label className="ant-checkbox-group-item" key={option}>
|
||||||
@ -53,6 +59,7 @@ export default React.createClass({
|
|||||||
</label>
|
</label>
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
</div>;
|
</div>
|
||||||
|
);
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
@ -10,11 +10,11 @@
|
|||||||
import { Checkbox } from 'antd';
|
import { Checkbox } from 'antd';
|
||||||
|
|
||||||
function onChange(e) {
|
function onChange(e) {
|
||||||
console.log('checked = ' + e.target.checked);
|
console.log(`checked = ${e.target.checked}`);
|
||||||
}
|
}
|
||||||
|
|
||||||
ReactDOM.render(<label>
|
ReactDOM.render(<label>
|
||||||
<Checkbox defaultChecked={false} onChange={onChange} />
|
<Checkbox defaultChecked={false} onChange={onChange} />
|
||||||
Checkbox
|
Checkbox
|
||||||
</label>, document.getElementById('components-checkbox-demo-basic'));
|
</label>, mountNode);
|
||||||
````
|
````
|
||||||
|
@ -17,9 +17,9 @@ const App = React.createClass({
|
|||||||
};
|
};
|
||||||
},
|
},
|
||||||
render() {
|
render() {
|
||||||
const label = (this.state.checked ? '选中' : '取消') + '-' +
|
const label = `${this.state.checked ? '选中' : '取消'}-${this.state.disabled ? '不可用' : '可用'}`;
|
||||||
(this.state.disabled ? '不可用' : '可用');
|
return (
|
||||||
return <div>
|
<div>
|
||||||
<p style={{ marginBottom: '20px' }}>
|
<p style={{ marginBottom: '20px' }}>
|
||||||
<label>
|
<label>
|
||||||
<Checkbox checked={this.state.checked}
|
<Checkbox checked={this.state.checked}
|
||||||
@ -39,7 +39,8 @@ const App = React.createClass({
|
|||||||
{!this.state.disabled ? '不可用' : '可用'}
|
{!this.state.disabled ? '不可用' : '可用'}
|
||||||
</Button>
|
</Button>
|
||||||
</p>
|
</p>
|
||||||
</div>;
|
</div>
|
||||||
|
);
|
||||||
},
|
},
|
||||||
toggleChecked() {
|
toggleChecked() {
|
||||||
this.setState({ checked: !this.state.checked });
|
this.setState({ checked: !this.state.checked });
|
||||||
@ -55,5 +56,5 @@ const App = React.createClass({
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
ReactDOM.render(<App />, document.getElementById('components-checkbox-demo-controller'));
|
ReactDOM.render(<App />, mountNode);
|
||||||
````
|
````
|
||||||
|
@ -13,5 +13,5 @@ ReactDOM.render(<div>
|
|||||||
<Checkbox defaultChecked={false} disabled />
|
<Checkbox defaultChecked={false} disabled />
|
||||||
<br />
|
<br />
|
||||||
<Checkbox defaultChecked disabled />
|
<Checkbox defaultChecked disabled />
|
||||||
</div>, document.getElementById('components-checkbox-demo-disable'));
|
</div>, mountNode);
|
||||||
````
|
````
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
|
|
||||||
- order: 3
|
- order: 3
|
||||||
|
|
||||||
方便的生成一个 Checkbox 组。
|
方便的从数组生成 Checkbox 组。若需要 label 和 value 分离请直接使用 Checkbox。
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
@ -16,5 +16,5 @@ function onChange(checkedValues) {
|
|||||||
|
|
||||||
ReactDOM.render(
|
ReactDOM.render(
|
||||||
<CheckboxGroup options={['Apple', 'Pear', 'Orange']} defaultValue={['Apple']} onChange={onChange} />
|
<CheckboxGroup options={['Apple', 'Pear', 'Orange']} defaultValue={['Apple']} onChange={onChange} />
|
||||||
, document.getElementById('components-checkbox-demo-group'));
|
, mountNode);
|
||||||
````
|
````
|
||||||
|
@ -10,8 +10,8 @@
|
|||||||
|
|
||||||
## 何时使用
|
## 何时使用
|
||||||
|
|
||||||
- 需要表示开关状态/两种状态之间的切换时;
|
- 在一组可选项中进行多项选择时;
|
||||||
- 和 `switch`的区别是,切换 `switch` 会直接触发状态改变,而 `checkbox` 一般用于状态标记,需要和提交操作配合。
|
- 单独使用可以表示两种状态之间的切换,和 `switch` 类似。区别在于切换 `switch` 会直接触发状态改变,而 `checkbox` 一般用于状态标记,需要和提交操作配合。
|
||||||
|
|
||||||
## API
|
## API
|
||||||
|
|
||||||
|
@ -18,15 +18,15 @@ const text = `
|
|||||||
|
|
||||||
ReactDOM.render(
|
ReactDOM.render(
|
||||||
<Collapse accordion>
|
<Collapse accordion>
|
||||||
<Panel header={`This is panel header 1`} key="1">
|
<Panel header={'This is panel header 1'} key="1">
|
||||||
<p>{text}</p>
|
<p>{text}</p>
|
||||||
</Panel>
|
</Panel>
|
||||||
<Panel header={`This is panel header 2`} key="2">
|
<Panel header={'This is panel header 2'} key="2">
|
||||||
<p>{text}</p>
|
<p>{text}</p>
|
||||||
</Panel>
|
</Panel>
|
||||||
<Panel header={`This is panel header 3`} key="3">
|
<Panel header={'This is panel header 3'} key="3">
|
||||||
<p>{text}</p>
|
<p>{text}</p>
|
||||||
</Panel>
|
</Panel>
|
||||||
</Collapse>
|
</Collapse>
|
||||||
, document.getElementById('components-collapse-demo-accordion'));
|
, mountNode);
|
||||||
````
|
````
|
||||||
|
@ -32,5 +32,5 @@ ReactDOM.render(
|
|||||||
<p>{text}</p>
|
<p>{text}</p>
|
||||||
</Panel>
|
</Panel>
|
||||||
</Collapse>
|
</Collapse>
|
||||||
, document.getElementById('components-collapse-demo-basic'));
|
, mountNode);
|
||||||
````
|
````
|
||||||
|
@ -22,19 +22,19 @@ const text = `
|
|||||||
|
|
||||||
ReactDOM.render(
|
ReactDOM.render(
|
||||||
<Collapse onChange={callback} accordion>
|
<Collapse onChange={callback} accordion>
|
||||||
<Panel header={`This is panel header 1`} key="1">
|
<Panel header={'This is panel header 1'} key="1">
|
||||||
<Collapse defaultActiveKey="1">
|
<Collapse defaultActiveKey="1">
|
||||||
<Panel header={`This is panel nest panel`} key="1">
|
<Panel header={'This is panel nest panel'} key="1">
|
||||||
<p>{text}</p>
|
<p>{text}</p>
|
||||||
</Panel>
|
</Panel>
|
||||||
</Collapse>
|
</Collapse>
|
||||||
</Panel>
|
</Panel>
|
||||||
<Panel header={`This is panel header 2`} key="2">
|
<Panel header={'This is panel header 2'} key="2">
|
||||||
<p>{text}</p>
|
<p>{text}</p>
|
||||||
</Panel>
|
</Panel>
|
||||||
<Panel header={`This is panel header 3`} key="3">
|
<Panel header={'This is panel header 3'} key="3">
|
||||||
<p>{text}</p>
|
<p>{text}</p>
|
||||||
</Panel>
|
</Panel>
|
||||||
</Collapse>
|
</Collapse>
|
||||||
, document.getElementById('components-collapse-demo-mix'));
|
, mountNode);
|
||||||
````
|
````
|
||||||
|
@ -1,6 +1,5 @@
|
|||||||
import Collapse from 'rc-collapse';
|
import Collapse from 'rc-collapse';
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
const prefixCls = 'ant-collapse';
|
|
||||||
|
|
||||||
class AntCollapse extends React.Component {
|
class AntCollapse extends React.Component {
|
||||||
render() {
|
render() {
|
||||||
@ -9,7 +8,7 @@ class AntCollapse extends React.Component {
|
|||||||
}
|
}
|
||||||
|
|
||||||
AntCollapse.defaultProps = {
|
AntCollapse.defaultProps = {
|
||||||
prefixCls: prefixCls
|
prefixCls: 'ant-collapse',
|
||||||
};
|
};
|
||||||
|
|
||||||
AntCollapse.Panel = Collapse.Panel;
|
AntCollapse.Panel = Collapse.Panel;
|
||||||
|
@ -14,10 +14,12 @@ function animate(node, show, transitionName, done) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Fix safari flash bug
|
// Fix safari flash bug
|
||||||
|
/*eslint-disable */
|
||||||
node.style.display = show ? 'block' : 'none';
|
node.style.display = show ? 'block' : 'none';
|
||||||
|
/*eslint-enable */
|
||||||
velocity(node, transitionName, {
|
velocity(node, transitionName, {
|
||||||
duration: 240,
|
duration: 240,
|
||||||
complete: complete,
|
complete,
|
||||||
easing: 'easeInOutQuad'
|
easing: 'easeInOutQuad'
|
||||||
});
|
});
|
||||||
return {
|
return {
|
||||||
|
@ -13,7 +13,7 @@ export default {
|
|||||||
|
|
||||||
getFormatter() {
|
getFormatter() {
|
||||||
const formats = this.formats = this.formats || {};
|
const formats = this.formats = this.formats || {};
|
||||||
const format = this.props.format;
|
let format = this.props.format;
|
||||||
if (formats[format]) {
|
if (formats[format]) {
|
||||||
return formats[format];
|
return formats[format];
|
||||||
}
|
}
|
||||||
@ -30,15 +30,14 @@ export default {
|
|||||||
date.setTime(+value);
|
date.setTime(+value);
|
||||||
return date;
|
return date;
|
||||||
}
|
}
|
||||||
} else if (value === null) {
|
|
||||||
return value;
|
|
||||||
}
|
}
|
||||||
return undefined;
|
return value;
|
||||||
},
|
},
|
||||||
|
|
||||||
// remove input readonly warning
|
// remove input readonly warning
|
||||||
handleInputChange() {
|
handleInputChange() {
|
||||||
},
|
},
|
||||||
|
|
||||||
toggleOpen(e) {
|
toggleOpen(e) {
|
||||||
this.setState({
|
this.setState({
|
||||||
open: e.open
|
open: e.open
|
||||||
|
@ -16,7 +16,9 @@ export default React.createClass({
|
|||||||
transitionName: 'slide-up',
|
transitionName: 'slide-up',
|
||||||
popupStyle: {},
|
popupStyle: {},
|
||||||
onChange() {
|
onChange() {
|
||||||
}, // onChange 可用于 Validator
|
},
|
||||||
|
onOk() {
|
||||||
|
},
|
||||||
locale: {},
|
locale: {},
|
||||||
align: {
|
align: {
|
||||||
offset: [0, -9],
|
offset: [0, -9],
|
||||||
@ -38,8 +40,9 @@ export default React.createClass({
|
|||||||
mixins: [PickerMixin],
|
mixins: [PickerMixin],
|
||||||
componentWillReceiveProps(nextProps) {
|
componentWillReceiveProps(nextProps) {
|
||||||
if ('value' in nextProps) {
|
if ('value' in nextProps) {
|
||||||
const start = this.parseDateFromValue(nextProps.value[0]);
|
const value = nextProps.value || [];
|
||||||
const end = this.parseDateFromValue(nextProps.value[1]);
|
const start = this.parseDateFromValue(value[0]);
|
||||||
|
const end = this.parseDateFromValue(value[1]);
|
||||||
this.setState({
|
this.setState({
|
||||||
value: [start, end]
|
value: [start, end]
|
||||||
});
|
});
|
||||||
@ -61,28 +64,55 @@ export default React.createClass({
|
|||||||
let defaultCalendarValue = new GregorianCalendar(locale);
|
let defaultCalendarValue = new GregorianCalendar(locale);
|
||||||
defaultCalendarValue.setTime(Date.now());
|
defaultCalendarValue.setTime(Date.now());
|
||||||
|
|
||||||
const {disabledDate, showTime, size, startPlaceholder, endPlaceholder,
|
const { disabledDate, showTime, size, startPlaceholder, endPlaceholder, getCalendarContainer,
|
||||||
transitionName, disabled, popupStyle, align, style} = this.props;
|
transitionName, disabled, popupStyle, align, style, onOk } = this.props;
|
||||||
const state = this.state;
|
const state = this.state;
|
||||||
|
|
||||||
const timePicker = showTime
|
let timePicker = null;
|
||||||
? <TimePicker prefixCls="ant-time-picker"
|
|
||||||
|
if (showTime) {
|
||||||
|
timePicker = (<TimePicker
|
||||||
|
prefixCls="ant-time-picker"
|
||||||
placeholder={locale.lang.timePlaceholder}
|
placeholder={locale.lang.timePlaceholder}
|
||||||
transitionName="slide-up" />
|
transitionName="slide-up" />);
|
||||||
: null;
|
}
|
||||||
|
|
||||||
const calendarClassName = classNames({
|
const calendarClassName = classNames({
|
||||||
['ant-calendar-time']: this.props.showTime,
|
['ant-calendar-time']: this.props.showTime,
|
||||||
});
|
});
|
||||||
|
|
||||||
const calendar = <RangeCalendar prefixCls="ant-calendar"
|
let pickerChangeHandler = {
|
||||||
|
onChange: this.handleChange,
|
||||||
|
};
|
||||||
|
|
||||||
|
let calendarHandler = {
|
||||||
|
onOk: this.handleChange,
|
||||||
|
};
|
||||||
|
|
||||||
|
if (timePicker) {
|
||||||
|
pickerChangeHandler.onChange = (value) => {
|
||||||
|
// Click clear button
|
||||||
|
if (value === null || value.length === 0) {
|
||||||
|
this.handleChange(value);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
} else {
|
||||||
|
calendarHandler = {};
|
||||||
|
}
|
||||||
|
|
||||||
|
const calendar = (
|
||||||
|
<RangeCalendar
|
||||||
|
prefixCls="ant-calendar"
|
||||||
className={calendarClassName}
|
className={calendarClassName}
|
||||||
timePicker={timePicker}
|
timePicker={timePicker}
|
||||||
disabledDate={disabledDate}
|
disabledDate={disabledDate}
|
||||||
dateInputPlaceholder={[startPlaceholder, endPlaceholder]}
|
dateInputPlaceholder={[startPlaceholder, endPlaceholder]}
|
||||||
locale={locale.lang}
|
locale={locale.lang}
|
||||||
defaultValue={defaultCalendarValue}
|
onOk={onOk}
|
||||||
showClear />;
|
defaultValue={[defaultCalendarValue, defaultCalendarValue]}
|
||||||
|
{...calendarHandler}
|
||||||
|
/>
|
||||||
|
);
|
||||||
|
|
||||||
const pickerClass = classNames({
|
const pickerClass = classNames({
|
||||||
'ant-calendar-picker': true,
|
'ant-calendar-picker': true,
|
||||||
@ -105,22 +135,26 @@ export default React.createClass({
|
|||||||
prefixCls="ant-calendar-picker-container"
|
prefixCls="ant-calendar-picker-container"
|
||||||
style={popupStyle}
|
style={popupStyle}
|
||||||
align={align}
|
align={align}
|
||||||
|
getCalendarContainer={getCalendarContainer}
|
||||||
onOpen={this.toggleOpen}
|
onOpen={this.toggleOpen}
|
||||||
onClose={this.toggleOpen}
|
onClose={this.toggleOpen}
|
||||||
onChange={this.handleChange}>
|
{...pickerChangeHandler}
|
||||||
|
>
|
||||||
{
|
{
|
||||||
({ value }) => {
|
({ value }) => {
|
||||||
const start = value[0];
|
const start = value[0];
|
||||||
const end = value[1];
|
const end = value[1];
|
||||||
return (
|
return (
|
||||||
<span className={pickerInputClass} disabled={disabled}>
|
<span className={pickerInputClass} disabled={disabled}>
|
||||||
<input disabled={disabled}
|
<input
|
||||||
|
disabled={disabled}
|
||||||
onChange={this.handleInputChange}
|
onChange={this.handleInputChange}
|
||||||
value={start && this.getFormatter().format(start)}
|
value={start && this.getFormatter().format(start)}
|
||||||
placeholder={startPlaceholder}
|
placeholder={startPlaceholder}
|
||||||
className="ant-calendar-range-picker-input" />
|
className="ant-calendar-range-picker-input" />
|
||||||
<span className="ant-calendar-range-picker-separator"> ~ </span>
|
<span className="ant-calendar-range-picker-separator"> ~ </span>
|
||||||
<input disabled={disabled}
|
<input
|
||||||
|
disabled={disabled}
|
||||||
onChange={this.handleInputChange}
|
onChange={this.handleInputChange}
|
||||||
value={end && this.getFormatter().format(end)}
|
value={end && this.getFormatter().format(end)}
|
||||||
placeholder={endPlaceholder}
|
placeholder={endPlaceholder}
|
||||||
|
@ -13,7 +13,5 @@ function onChange(value) {
|
|||||||
console.log(value);
|
console.log(value);
|
||||||
}
|
}
|
||||||
|
|
||||||
ReactDOM.render(
|
ReactDOM.render(<DatePicker onChange={onChange} />, mountNode);
|
||||||
<DatePicker onChange={onChange} />
|
|
||||||
, document.getElementById('components-date-picker-demo-basic'));
|
|
||||||
````
|
````
|
||||||
|
@ -18,5 +18,5 @@ const disabledDate = function(current) {
|
|||||||
|
|
||||||
ReactDOM.render(
|
ReactDOM.render(
|
||||||
<DatePicker disabledDate={disabledDate} />
|
<DatePicker disabledDate={disabledDate} />
|
||||||
, document.getElementById('components-date-picker-demo-disabled-date'));
|
, mountNode);
|
||||||
````
|
````
|
||||||
|
@ -11,5 +11,5 @@ import { DatePicker } from 'antd';
|
|||||||
|
|
||||||
ReactDOM.render(
|
ReactDOM.render(
|
||||||
<DatePicker defaultValue="2015-06-06" disabled />
|
<DatePicker defaultValue="2015-06-06" disabled />
|
||||||
, document.getElementById('components-date-picker-demo-disabled'));
|
, mountNode);
|
||||||
````
|
````
|
||||||
|
@ -11,5 +11,5 @@ import { DatePicker } from 'antd';
|
|||||||
|
|
||||||
ReactDOM.render(
|
ReactDOM.render(
|
||||||
<DatePicker defaultValue="2015/01/01" format="yyyy/MM/dd" />
|
<DatePicker defaultValue="2015/01/01" format="yyyy/MM/dd" />
|
||||||
, document.getElementById('components-date-picker-demo-formatter'));
|
, mountNode);
|
||||||
````
|
````
|
||||||
|
@ -26,6 +26,6 @@ const App = React.createClass({
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
ReactDOM.render(<App />, document.getElementById('components-date-picker-demo-locale'));
|
ReactDOM.render(<App />, mountNode);
|
||||||
````
|
````
|
||||||
|
|
||||||
|
@ -11,5 +11,5 @@ import { DatePicker } from 'antd';
|
|||||||
const MonthPicker = DatePicker.MonthPicker;
|
const MonthPicker = DatePicker.MonthPicker;
|
||||||
ReactDOM.render(
|
ReactDOM.render(
|
||||||
<MonthPicker defaultValue="2015-12" />
|
<MonthPicker defaultValue="2015-12" />
|
||||||
, document.getElementById('components-date-picker-demo-month-picker'));
|
, mountNode);
|
||||||
````
|
````
|
||||||
|
@ -16,6 +16,6 @@ function onChange(value) {
|
|||||||
ReactDOM.render(<div>
|
ReactDOM.render(<div>
|
||||||
<RangePicker style={{ width: 184 }} onChange={onChange} />
|
<RangePicker style={{ width: 184 }} onChange={onChange} />
|
||||||
<br />
|
<br />
|
||||||
<RangePicker showTime format="yyyy-MM-dd HH:mm:ss" onChange={onChange} />
|
<RangePicker showTime format="yyyy/MM/dd HH:mm:ss" onChange={onChange} />
|
||||||
</div>, document.getElementById('components-date-picker-demo-range'));
|
</div>, mountNode);
|
||||||
````
|
````
|
||||||
|
@ -15,5 +15,5 @@ ReactDOM.render(
|
|||||||
<DatePicker />
|
<DatePicker />
|
||||||
<DatePicker size="small" />
|
<DatePicker size="small" />
|
||||||
</div>
|
</div>
|
||||||
, document.getElementById('components-date-picker-demo-size'));
|
, mountNode);
|
||||||
````
|
````
|
||||||
|
@ -35,7 +35,8 @@ const DateRange = React.createClass({
|
|||||||
});
|
});
|
||||||
},
|
},
|
||||||
render() {
|
render() {
|
||||||
return <div>
|
return (
|
||||||
|
<div>
|
||||||
<DatePicker disabledDate={this.disabledStartDate}
|
<DatePicker disabledDate={this.disabledStartDate}
|
||||||
value={this.state.startValue}
|
value={this.state.startValue}
|
||||||
placeholder="开始日期"
|
placeholder="开始日期"
|
||||||
@ -44,11 +45,12 @@ const DateRange = React.createClass({
|
|||||||
value={this.state.endValue}
|
value={this.state.endValue}
|
||||||
placeholder="结束日期"
|
placeholder="结束日期"
|
||||||
onChange={this.onChange.bind(this, 'endValue')} />
|
onChange={this.onChange.bind(this, 'endValue')} />
|
||||||
</div>;
|
</div>
|
||||||
|
);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
ReactDOM.render(
|
ReactDOM.render(
|
||||||
<DateRange />
|
<DateRange />
|
||||||
, document.getElementById('components-date-picker-demo-start-end'));
|
, mountNode);
|
||||||
````
|
````
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
|
|
||||||
- order: 4
|
- order: 4
|
||||||
|
|
||||||
增加选择时间功能。
|
增加选择时间功能。不要修改时间的格式 `HH:mm:ss`。
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
@ -14,6 +14,6 @@ function onChange(value) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
ReactDOM.render(
|
ReactDOM.render(
|
||||||
<DatePicker showTime format="yyyy-MM-dd HH:mm:ss" onChange={onChange} style={{width: 160}} />
|
<DatePicker showTime format="yyyy-MM-dd HH:mm:ss" placeholder="请选择时间" onChange={onChange} style={{ width: 160 }} />
|
||||||
, document.getElementById('components-date-picker-demo-time'));
|
, mountNode);
|
||||||
````
|
````
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
- order: 4
|
- order: 4
|
||||||
- hidden: true
|
- hidden: true
|
||||||
|
|
||||||
和 [时间选择框](/components/timepicer) 配合使用。
|
和 [时间选择框](/components/time-picker) 配合使用。
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
@ -37,10 +37,12 @@ const DateTimePicker = React.createClass({
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
render() {
|
render() {
|
||||||
return <div>
|
return (
|
||||||
|
<div>
|
||||||
<DatePicker onChange={this.handleChange.bind(null, 'date')} />
|
<DatePicker onChange={this.handleChange.bind(null, 'date')} />
|
||||||
<TimePicker onChange={this.handleChange.bind(null, 'time')} />
|
<TimePicker onChange={this.handleChange.bind(null, 'time')} />
|
||||||
</div>;
|
</div>
|
||||||
|
);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -49,5 +51,5 @@ function onSelect(value) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
ReactDOM.render(<DateTimePicker onSelect={onSelect} />
|
ReactDOM.render(<DateTimePicker onSelect={onSelect} />
|
||||||
, document.getElementById('components-date-picker-demo-with-time-picker'));
|
, mountNode);
|
||||||
````
|
````
|
||||||
|
@ -17,12 +17,14 @@ function createPicker(TheCalendar, defaultFormat) {
|
|||||||
transitionName: 'slide-up',
|
transitionName: 'slide-up',
|
||||||
popupStyle: {},
|
popupStyle: {},
|
||||||
onChange() {
|
onChange() {
|
||||||
}, // onChange 可用于 Validator
|
},
|
||||||
|
onOk() {
|
||||||
|
},
|
||||||
locale: {},
|
locale: {},
|
||||||
align: {
|
align: {
|
||||||
offset: [0, -9],
|
offset: [0, -9],
|
||||||
},
|
},
|
||||||
open: false
|
open: false,
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
getInitialState() {
|
getInitialState() {
|
||||||
@ -56,27 +58,49 @@ function createPicker(TheCalendar, defaultFormat) {
|
|||||||
const placeholder = ('placeholder' in this.props)
|
const placeholder = ('placeholder' in this.props)
|
||||||
? this.props.placeholder : locale.lang.placeholder;
|
? this.props.placeholder : locale.lang.placeholder;
|
||||||
|
|
||||||
const timePicker = this.props.showTime
|
const timePicker = this.props.showTime ? (<TimePicker
|
||||||
? <TimePicker prefixCls="ant-time-picker"
|
prefixCls="ant-time-picker"
|
||||||
placeholder={locale.lang.timePlaceholder}
|
placeholder={locale.lang.timePlaceholder}
|
||||||
transitionName="slide-up" />
|
transitionName="slide-up" />)
|
||||||
: null;
|
: null;
|
||||||
|
|
||||||
|
const disabledTime = this.props.showTime ? this.props.disabledTime : null;
|
||||||
|
|
||||||
const calendarClassName = classNames({
|
const calendarClassName = classNames({
|
||||||
['ant-calendar-time']: this.props.showTime,
|
['ant-calendar-time']: this.props.showTime,
|
||||||
|
['ant-calendar-month']: MonthCalendar === TheCalendar,
|
||||||
});
|
});
|
||||||
|
|
||||||
|
let pickerChangeHandler = {
|
||||||
|
onChange: this.handleChange,
|
||||||
|
};
|
||||||
|
|
||||||
|
let calendarHandler = {
|
||||||
|
onOk: this.handleChange,
|
||||||
|
};
|
||||||
|
|
||||||
|
if (this.props.showTime) {
|
||||||
|
pickerChangeHandler.onChange = (value) => {
|
||||||
|
// Click clear button
|
||||||
|
if (value === null) {
|
||||||
|
this.handleChange(value);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
} else {
|
||||||
|
calendarHandler = {};
|
||||||
|
}
|
||||||
|
|
||||||
const calendar = (
|
const calendar = (
|
||||||
<TheCalendar
|
<TheCalendar
|
||||||
disabledDate={this.props.disabledDate}
|
disabledDate={this.props.disabledDate}
|
||||||
|
disabledTime={disabledTime}
|
||||||
locale={locale.lang}
|
locale={locale.lang}
|
||||||
timePicker={timePicker}
|
timePicker={timePicker}
|
||||||
defaultValue={defaultCalendarValue}
|
defaultValue={defaultCalendarValue}
|
||||||
dateInputPlaceholder={placeholder}
|
dateInputPlaceholder={placeholder}
|
||||||
prefixCls="ant-calendar"
|
prefixCls="ant-calendar"
|
||||||
className={calendarClassName}
|
className={calendarClassName}
|
||||||
showOk={this.props.showTime}
|
{...calendarHandler} />
|
||||||
showClear />
|
|
||||||
);
|
);
|
||||||
|
|
||||||
let sizeClass = '';
|
let sizeClass = '';
|
||||||
@ -90,8 +114,8 @@ function createPicker(TheCalendar, defaultFormat) {
|
|||||||
if (this.state.open) {
|
if (this.state.open) {
|
||||||
pickerClass += ' ant-calendar-picker-open';
|
pickerClass += ' ant-calendar-picker-open';
|
||||||
}
|
}
|
||||||
|
return (
|
||||||
return <span className={pickerClass}>
|
<span className={pickerClass}>
|
||||||
<DatePicker
|
<DatePicker
|
||||||
transitionName={this.props.transitionName}
|
transitionName={this.props.transitionName}
|
||||||
disabled={this.props.disabled}
|
disabled={this.props.disabled}
|
||||||
@ -100,26 +124,30 @@ function createPicker(TheCalendar, defaultFormat) {
|
|||||||
prefixCls="ant-calendar-picker-container"
|
prefixCls="ant-calendar-picker-container"
|
||||||
style={this.props.popupStyle}
|
style={this.props.popupStyle}
|
||||||
align={this.props.align}
|
align={this.props.align}
|
||||||
|
getCalendarContainer={this.props.getCalendarContainer}
|
||||||
onOpen={this.toggleOpen}
|
onOpen={this.toggleOpen}
|
||||||
onClose={this.toggleOpen}
|
onClose={this.toggleOpen}
|
||||||
onChange={this.handleChange}>
|
{...pickerChangeHandler}
|
||||||
|
>
|
||||||
{
|
{
|
||||||
({ value }) => {
|
({ value }) => {
|
||||||
return (
|
return (
|
||||||
<span>
|
<span>
|
||||||
<input disabled={this.props.disabled}
|
<input
|
||||||
|
disabled={this.props.disabled}
|
||||||
onChange={this.handleInputChange}
|
onChange={this.handleInputChange}
|
||||||
value={value && this.getFormatter().format(value)}
|
value={value && this.getFormatter().format(value)}
|
||||||
placeholder={placeholder}
|
placeholder={placeholder}
|
||||||
style={this.props.style}
|
style={this.props.style}
|
||||||
className={'ant-calendar-picker-input ant-input' + sizeClass}/>
|
className={`ant-calendar-picker-input ant-input${sizeClass}`} />
|
||||||
<span className="ant-calendar-picker-icon" />
|
<span className="ant-calendar-picker-icon" />
|
||||||
</span>
|
</span>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
</DatePicker>
|
</DatePicker>
|
||||||
</span>;
|
</span>
|
||||||
|
);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@ -25,9 +25,9 @@
|
|||||||
|
|
||||||
| 参数 | 说明 | 类型 | 默认值 |
|
| 参数 | 说明 | 类型 | 默认值 |
|
||||||
|--------------|----------------|----------|--------------|
|
|--------------|----------------|----------|--------------|
|
||||||
| value | 日期 | string | 无 |
|
| value | 日期 | string or Date | 无 |
|
||||||
| defaultValue | 默认日期 | string | 无 |
|
| defaultValue | 默认日期 | string or Date | 无 |
|
||||||
| format | 展示的日期格式 | string | "yyyy-MM-dd" |
|
| format | 展示的日期格式,配置参考 [GregorianCalendarFormat](https://github.com/yiminghe/gregorian-calendar-format) | string | "yyyy-MM-dd" |
|
||||||
| disabledDate | 不可选择的日期 | function | 无 |
|
| disabledDate | 不可选择的日期 | function | 无 |
|
||||||
| onChange | 时间发生变化的回调,发生在用户选择时间时 | function(Date value) | 无 |
|
| onChange | 时间发生变化的回调,发生在用户选择时间时 | function(Date value) | 无 |
|
||||||
| disabled | 禁用 | bool | false |
|
| disabled | 禁用 | bool | false |
|
||||||
@ -36,18 +36,19 @@
|
|||||||
| size | 输入框大小,`large` 高度为 32px,`small` 为 22px,默认是 28px | string | 无 |
|
| size | 输入框大小,`large` 高度为 32px,`small` 为 22px,默认是 28px | string | 无 |
|
||||||
| locale | 国际化配置 | object | [默认配置](https://github.com/ant-design/ant-design/issues/424) |
|
| locale | 国际化配置 | object | [默认配置](https://github.com/ant-design/ant-design/issues/424) |
|
||||||
| showTime | 增加时间选择功能 | bool | false |
|
| showTime | 增加时间选择功能 | bool | false |
|
||||||
| onOk | 点击确定按钮的回调 | function | 无 |
|
| onOk | 点击确定按钮的回调 | function(Date value) | 无 |
|
||||||
|
| getCalendarContainer | 定义浮层的容器,默认为 body 上新建 div | function(trigger) | 无 |
|
||||||
|
|
||||||
### RangePicker
|
### RangePicker
|
||||||
|
|
||||||
| 参数 | 说明 | 类型 | 默认值 |
|
| 参数 | 说明 | 类型 | 默认值 |
|
||||||
|--------------|----------------|----------|--------------|
|
|--------------|----------------|----------|--------------|
|
||||||
| value | 日期 | [string, string] | 无 |
|
| value | 日期 | [string/Date, string/Date] | 无 |
|
||||||
| defaultValue | 默认日期 | [string, string] | 无 |
|
| defaultValue | 默认日期 | [string/Date, string/Date] | 无 |
|
||||||
| format | 展示的日期格式 | string | "yyyy-MM-dd HH:mm:ss" |
|
| format | 展示的日期格式 | string | "yyyy-MM-dd HH:mm:ss" |
|
||||||
| onChange | 时间发生变化的回调,发生在用户选择时间时 | function([Date start, Date end]) | 无 |
|
| onChange | 时间发生变化的回调,发生在用户选择时间时 | function([Date start, Date end]) | 无 |
|
||||||
|
|
||||||
`disabled` `style` `popupStyle` `size` `locale` `showTime` `onOk` 属性与 DatePicker 的一致。
|
`disabled` `style` `popupStyle` `size` `locale` `showTime` `onOk` `getCalendarContainer` 属性与 DatePicker 的一致。
|
||||||
|
|
||||||
<style>
|
<style>
|
||||||
.code-box-demo .ant-calendar-picker {
|
.code-box-demo .ant-calendar-picker {
|
||||||
|
@ -5,7 +5,8 @@ import CalendarLocale from 'rc-calendar/lib/locale/en_US';
|
|||||||
// 统一合并为完整的 Locale
|
// 统一合并为完整的 Locale
|
||||||
let locale = objectAssign({}, GregorianCalendarLocale);
|
let locale = objectAssign({}, GregorianCalendarLocale);
|
||||||
locale.lang = objectAssign({
|
locale.lang = objectAssign({
|
||||||
placeholder: 'Select a date'
|
placeholder: 'Select date',
|
||||||
|
timePlaceholder: 'Select time',
|
||||||
}, CalendarLocale);
|
}, CalendarLocale);
|
||||||
|
|
||||||
// All settings at:
|
// All settings at:
|
||||||
|
@ -9,7 +9,8 @@
|
|||||||
````jsx
|
````jsx
|
||||||
import { Menu, Dropdown, Icon } from 'antd';
|
import { Menu, Dropdown, Icon } from 'antd';
|
||||||
|
|
||||||
const menu = <Menu>
|
const menu = (
|
||||||
|
<Menu>
|
||||||
<Menu.Item>
|
<Menu.Item>
|
||||||
<a target="_blank" href="http://www.alipay.com/">第一个菜单项</a>
|
<a target="_blank" href="http://www.alipay.com/">第一个菜单项</a>
|
||||||
</Menu.Item>
|
</Menu.Item>
|
||||||
@ -19,7 +20,8 @@ const menu = <Menu>
|
|||||||
<Menu.Item>
|
<Menu.Item>
|
||||||
<a target="_blank" href="http://www.tmall.com/">第三个菜单项</a>
|
<a target="_blank" href="http://www.tmall.com/">第三个菜单项</a>
|
||||||
</Menu.Item>
|
</Menu.Item>
|
||||||
</Menu>;
|
</Menu>
|
||||||
|
);
|
||||||
|
|
||||||
ReactDOM.render(
|
ReactDOM.render(
|
||||||
<Dropdown overlay={menu}>
|
<Dropdown overlay={menu}>
|
||||||
@ -27,5 +29,5 @@ ReactDOM.render(
|
|||||||
触发链接 <Icon type="down" />
|
触发链接 <Icon type="down" />
|
||||||
</a>
|
</a>
|
||||||
</Dropdown>
|
</Dropdown>
|
||||||
, document.getElementById('components-dropdown-demo-basic'));
|
, mountNode);
|
||||||
````
|
````
|
||||||
|
@ -10,21 +10,25 @@
|
|||||||
import { Menu, Dropdown } from 'antd';
|
import { Menu, Dropdown } from 'antd';
|
||||||
const DropdownButton = Dropdown.Button;
|
const DropdownButton = Dropdown.Button;
|
||||||
|
|
||||||
const menu = <Menu>
|
function handleButtonClick() {
|
||||||
<Menu.Item>
|
console.log('click button');
|
||||||
<a target="_blank" href="http://www.alipay.com/">第一个菜单项</a>
|
}
|
||||||
</Menu.Item>
|
|
||||||
<Menu.Item>
|
function handleMenuClick(e) {
|
||||||
<a target="_blank" href="http://www.taobao.com/">第二个菜单项</a>
|
console.log('click', e);
|
||||||
</Menu.Item>
|
}
|
||||||
<Menu.Item>
|
|
||||||
<a target="_blank" href="http://www.tmall.com/">第三个菜单项</a>
|
const menu = (
|
||||||
</Menu.Item>
|
<Menu onClick={handleMenuClick}>
|
||||||
</Menu>;
|
<Menu.Item key="1">第一个菜单项</Menu.Item>
|
||||||
|
<Menu.Item key="2">第二个菜单项</Menu.Item>
|
||||||
|
<Menu.Item key="3">第三个菜单项</Menu.Item>
|
||||||
|
</Menu>
|
||||||
|
);
|
||||||
|
|
||||||
ReactDOM.render(
|
ReactDOM.render(
|
||||||
<DropdownButton overlay={menu} type="primary">
|
<DropdownButton onClick={handleButtonClick} overlay={menu} type="primary">
|
||||||
某功能按钮
|
某功能按钮
|
||||||
</DropdownButton>
|
</DropdownButton>
|
||||||
, document.getElementById('components-dropdown-demo-dropdown-button'));
|
, mountNode);
|
||||||
````
|
````
|
||||||
|
@ -9,14 +9,16 @@
|
|||||||
````jsx
|
````jsx
|
||||||
import { Menu, Dropdown, Icon } from 'antd';
|
import { Menu, Dropdown, Icon } from 'antd';
|
||||||
const onClick = function ({ key }) {
|
const onClick = function ({ key }) {
|
||||||
console.log('点击了菜单' + key);
|
console.log(`点击了菜单${key}`);
|
||||||
};
|
};
|
||||||
|
|
||||||
const menu = <Menu onClick={onClick}>
|
const menu = (
|
||||||
|
<Menu onClick={onClick}>
|
||||||
<Menu.Item key="1">第一个菜单项</Menu.Item>
|
<Menu.Item key="1">第一个菜单项</Menu.Item>
|
||||||
<Menu.Item key="2">第二个菜单项</Menu.Item>
|
<Menu.Item key="2">第二个菜单项</Menu.Item>
|
||||||
<Menu.Item key="3">第三个菜单项</Menu.Item>
|
<Menu.Item key="3">第三个菜单项</Menu.Item>
|
||||||
</Menu>;
|
</Menu>
|
||||||
|
);
|
||||||
|
|
||||||
ReactDOM.render(
|
ReactDOM.render(
|
||||||
<Dropdown overlay={menu}>
|
<Dropdown overlay={menu}>
|
||||||
@ -24,5 +26,5 @@ ReactDOM.render(
|
|||||||
鼠标移入,点击菜单 <Icon type="down" />
|
鼠标移入,点击菜单 <Icon type="down" />
|
||||||
</a>
|
</a>
|
||||||
</Dropdown>
|
</Dropdown>
|
||||||
, document.getElementById('components-dropdown-demo-event'));
|
, mountNode);
|
||||||
````
|
````
|
||||||
|
@ -9,7 +9,8 @@
|
|||||||
````jsx
|
````jsx
|
||||||
import { Menu, Dropdown, Icon } from 'antd';
|
import { Menu, Dropdown, Icon } from 'antd';
|
||||||
|
|
||||||
const menu = <Menu>
|
const menu = (
|
||||||
|
<Menu>
|
||||||
<Menu.Item key="0">
|
<Menu.Item key="0">
|
||||||
<a target="_blank" href="http://www.alipay.com/">第一个菜单项</a>
|
<a target="_blank" href="http://www.alipay.com/">第一个菜单项</a>
|
||||||
</Menu.Item>
|
</Menu.Item>
|
||||||
@ -18,7 +19,8 @@ const menu = <Menu>
|
|||||||
</Menu.Item>
|
</Menu.Item>
|
||||||
<Menu.Divider />
|
<Menu.Divider />
|
||||||
<Menu.Item key="3" disabled>第三个菜单项(不可用)</Menu.Item>
|
<Menu.Item key="3" disabled>第三个菜单项(不可用)</Menu.Item>
|
||||||
</Menu>;
|
</Menu>
|
||||||
|
);
|
||||||
|
|
||||||
ReactDOM.render(
|
ReactDOM.render(
|
||||||
<Dropdown overlay={menu}>
|
<Dropdown overlay={menu}>
|
||||||
@ -26,5 +28,5 @@ ReactDOM.render(
|
|||||||
鼠标移入 <Icon type="down" />
|
鼠标移入 <Icon type="down" />
|
||||||
</a>
|
</a>
|
||||||
</Dropdown>
|
</Dropdown>
|
||||||
, document.getElementById('components-dropdown-demo-item'));
|
, mountNode);
|
||||||
````
|
````
|
||||||
|
31
components/dropdown/demo/sub-menu.md
Normal file
31
components/dropdown/demo/sub-menu.md
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
# 多级菜单
|
||||||
|
|
||||||
|
- order: 5
|
||||||
|
|
||||||
|
传入的菜单里有多个层级。
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
````jsx
|
||||||
|
import { Menu, Dropdown, Icon } from 'antd';
|
||||||
|
const SubMenu = Menu.SubMenu;
|
||||||
|
|
||||||
|
const menu = (
|
||||||
|
<Menu>
|
||||||
|
<Menu.Item>第一个菜单项</Menu.Item>
|
||||||
|
<Menu.Item>第二个菜单项</Menu.Item>
|
||||||
|
<SubMenu title="子菜单">
|
||||||
|
<Menu.Item>第三个菜单项</Menu.Item>
|
||||||
|
<Menu.Item>第四个菜单项</Menu.Item>
|
||||||
|
</SubMenu>
|
||||||
|
</Menu>
|
||||||
|
);
|
||||||
|
|
||||||
|
ReactDOM.render(
|
||||||
|
<Dropdown overlay={menu}>
|
||||||
|
<a className="ant-dropdown-link" href="#">
|
||||||
|
多级菜单 <Icon type="down" />
|
||||||
|
</a>
|
||||||
|
</Dropdown>
|
||||||
|
, mountNode);
|
||||||
|
````
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user