add timeline

This commit is contained in:
zhujun24 2015-09-01 21:15:31 +08:00
parent f34ed22d1a
commit 018a62886d
9 changed files with 162 additions and 8 deletions

View File

@ -0,0 +1,21 @@
# 基本用法
- order: 0
基本的时间轴。
---
````jsx
var Timeline = antd.Timeline;
var Item = Timeline.Item;
var container = document.getElementById('components-timeline-demo-basic');
React.render(<Timeline>
<Timeline.Item>创建服务现场 2015-09-01</Timeline.Item>
<Timeline.Item>初步排除网络异常 2015-09-01</Timeline.Item>
<Timeline.Item>技术测试异常 2015-09-01</Timeline.Item>
<Timeline.Item>网络异常正在修复 2015-09-01</Timeline.Item>
</Timeline>
, container);
````

View File

@ -0,0 +1,20 @@
# 圆圈颜色
- order: 1
圆圈颜色。
---
````jsx
var Timeline = antd.Timeline;
var Item = Timeline.Item;
var container = document.getElementById('components-timeline-demo-color');
React.render(<Timeline>
<Timeline.Item color="green">创建服务现场 2015-09-01</Timeline.Item>
<Timeline.Item color="red">初步排除网络异常 2015-09-01</Timeline.Item>
<Timeline.Item>技术测试异常 2015-09-01</Timeline.Item>
</Timeline>
, container);
````

View File

@ -0,0 +1,20 @@
# 最后一个
- order: 2
在最后位置添加一个幽灵节点。
---
````jsx
var Timeline = antd.Timeline;
var Item = Timeline.Item;
var container = document.getElementById('components-timeline-demo-end');
React.render(<Timeline>
<Timeline.Item>创建服务现场 2015-09-01</Timeline.Item>
<Timeline.Item>初步排除网络异常 2015-09-01</Timeline.Item>
<Timeline.Item end={true}>技术测试异常 2015-09-01</Timeline.Item>
</Timeline>
, container);
````

View File

@ -1,35 +1,52 @@
import React from 'react';
let AntTimeline = React.createClass({
let Timeline = React.createClass({
getDefaultProps() {
return {
prefixCls: 'ant-timeline'
};
},
render() {
let children = this.props.children;
return (
<ul className={this.props.prefixCls}>
{this.props.children}
{React.Children.map(children, function (ele, idx) {
let np = {
timelineLast: idx === children.length - 1
};
return React.cloneElement(ele, np);
}, this)}
</ul>
);
}
});
AntTimeline.Item = React.createClass({
Timeline.Item = React.createClass({
getDefaultProps() {
return {
prefixCls: 'ant-timeline',
color: 'blue',
dashed: false
end: false
};
},
render() {
let props = this.props;
let prefixCls = props.prefixCls;
let color = props.color;
let end = props.end;
let endCls = end ? prefixCls + '-item-tail-end' : '';
let last = end ? <div className={prefixCls + '-item-head '+ prefixCls + '-item-head-end'}></div> : null;
let lastLineShow = (props.timelineLast && !end) ? 'none' : 'block';
return (
<li className={this.props.prefixCls + '-item'}>
{this.props.children}
<li className={prefixCls + '-item'}>
<div style={{display:lastLineShow}} className={prefixCls + '-item-tail ' + endCls}></div>
<div className={prefixCls + '-item-head '+ prefixCls + '-item-head-' + color}></div>
<div className={prefixCls + '-item-content'}>{props.children}</div>
{last}
</li>
);
}
});
export default AntTimeline;
export default Timeline;

View File

@ -12,3 +12,23 @@
- 当有一系列信息需要从上至下按时间排列时;
- 需要有一条时间轴进行视觉上的串联时;
## API
```jsx
<Timeline>
<Timeline.Item>创建服务现场 2015-09-01</Timeline.Item>
<Timeline.Item>初步排除网络异常 2015-09-01</Timeline.Item>
<Timeline.Item>技术测试异常 2015-09-01</Timeline.Item>
<Timeline.Item>网络异常正在修复 2015-09-01</Timeline.Item>
</Timeline>
```
### Timeline.Item
时间轴的每一个节点。
| 参数 | 说明 | 类型 | 可选值 |默认值 |
|-----------|------------------------------------------|------------|-------|--------|
| color | 指定圆圈颜色。 | string | blue, red, green | blue |
| end | 指定最后一个幽灵节点。 | boolean | 无 | false |

View File

@ -42,7 +42,8 @@ const antd = {
Tree: require('./components/tree'),
Upload: require('./components/upload'),
Badge: require('./components/badge'),
Menu: require('./components/menu')
Menu: require('./components/menu'),
Timeline: require('./components/timeline')
};
module.exports = antd;

View File

@ -33,3 +33,4 @@
@import "menu";
@import "affix";
@import "badge";
@import "timeline";

View File

@ -0,0 +1,54 @@
@import "../mixins/index";
@timeline-prefix-cls: ~"@{css-prefix}timeline";
@line-color: #e9e9e9;
.@{timeline-prefix-cls} {
&-item {
position: relative;
min-height: 50px;
&-tail {
position: absolute;
left: 5px;
z-index: 1;
height: 100%;
border-left: 2px solid @line-color;
&-end {
border-left: 2px dotted @line-color;
}
}
&-head {
position: relative;
z-index: 2;
width: 12px;
height: 12px;
background-color: #fff;
border-radius: 6px;
&-blue {
border: 2px solid @primary-color;
}
&-red {
border: 2px solid @error-color;
}
&-green {
border: 2px solid @success-color;
}
&-end{
position: absolute;
bottom: -12px;
border: 2px solid @line-color;
}
}
&-content {
position: relative;
top: -14px;
margin-left: 26px;
padding-bottom: 4px;
font-size: 12px;
}
}
}