-
Notifications
You must be signed in to change notification settings - Fork 669
/
basicFunnel.jsx
98 lines (93 loc) · 2.46 KB
/
basicFunnel.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
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
import React from 'react';
import DataSet from '@antv/data-set';
import {
Chart,
Tooltip,
Interval,
Legend,
Annotation,
Coordinate
} from '../../src';
const { DataView } = DataSet;
const dv = new DataView().source([
{ action: '浏览网站', pv: 50000 },
{ action: '放入购物车', pv: 35000 },
{ action: '生成订单', pv: 25000 },
{ action: '支付订单', pv: 15000 },
{ action: '完成交易', pv: 8000 },
]);
dv.transform({
type: 'map',
callback(row) {
const newRow = Object.assign({}, row);
newRow.percent = row.pv / 50000;
return newRow;
},
});
function Demo() {
return (
<Chart
height={600}
data={dv.rows}
padding={[20, 120, 95]}
autoFit
>
<Tooltip
showTitle={false}
itemTpl="<li data-index={index} style="margin-bottom:4px;"><span style="background-color:{color};" class="g2-tooltip-marker"></span>{name}<br/><span style="padding-left: 16px">浏览人数:{pv}</span><br/><span style="padding-left: 16px">占比:{percent}</span><br/></li>"
/>
<Coordinate scale={[1, -1]} transpose type="rect" />
<Legend />
{dv.rows.map(obj => {
return (
<Annotation.Text
top
position={{
action: obj.action,
percent: "median"
}}
content={`${parseInt( obj.percent * 100, 10 )}%`}
style={{
fill: "#fff",
fontSize: "12",
textAlign: "center",
shadowBlur: 2,
shadowColor: "rgba(0, 0, 0, .45)"
}}
/>
);
})}
<Interval
position="action*percent"
adjust="symmetric"
shape="funnel"
color={[
"action",
["#0050B3", "#1890FF", "#40A9FF", "#69C0FF", "#BAE7FF"]
]}
tooltip={[
"action*pv*percent",
(action, pv, percent) => {
return {
name: action,
percent: `${parseInt(percent * 100, 10)}%`,
pv
};
}
]}
label={["action*pv",
(action, pv) => {
return {content: `${action } ${ pv}`};
},
{
offset: 35,
labeLine: {
lineWidth: 1,
stroke: "rgba(0, 0, 0, 0.15)"
}
}]}
/>
</Chart>
)
}
export default Demo;