-
Notifications
You must be signed in to change notification settings - Fork 40
/
Copy pathline.jsx
73 lines (61 loc) · 1.25 KB
/
line.jsx
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
"use strict";
import {
default as React,
PropTypes,
Component,
} from 'react';
import D3Shape from 'd3-shape';
import CommonProps from '../commonProps';
import {series} from '../utils/series';
export default class Line extends Component {
constructor (props) {
super(props);
}
static defaultProps = {
interpolate: null,
lineClassName: 'react-d3-basic__line',
...CommonProps
}
_mkLine(dom) {
const {
lineClassName
} = this.props;
var dataset = series(this.props);
var that = this;
return (
<g>
{
dataset.map((line, i) => {
return (
<path
stroke={line.color}
fill="none"
className={`${lineClassName} line`}
d={that._setAxes(line.data)}
style={line.style}
key={i}/>
)
})
}
</g>
)
}
_setAxes (data) {
const {
xScaleSet,
yScaleSet
} = this.props;
var line = D3Shape.line()
.x((d) => { return xScaleSet(d.x) })
.y((d) => { return yScaleSet(d.y) })
return line.call(this, data);
}
render() {
var line = this._mkLine();
return (
<g>
{line}
</g>
);
}
}