playbook_ui 14.23.0.pre.rc.0 → 14.23.0.pre.rc.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/app/pb_kits/playbook/pb_advanced_table/Components/SubRowHeaderRow.tsx +32 -11
- data/app/pb_kits/playbook/pb_advanced_table/Hooks/useTableState.ts +2 -2
- data/app/pb_kits/playbook/pb_advanced_table/_advanced_table.scss +5 -0
- data/app/pb_kits/playbook/pb_advanced_table/_advanced_table.tsx +6 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_custom_sort.jsx +65 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_custom_sort.md +5 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_with_custom_header.jsx +69 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/_advanced_table_with_custom_header.md +1 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/example.yml +2 -0
- data/app/pb_kits/playbook/pb_advanced_table/docs/index.js +2 -0
- data/app/pb_kits/playbook/pb_badge/_badge.scss +5 -6
- data/app/pb_kits/playbook/pb_bar_graph/barGraphTheme.ts +106 -0
- data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_colors.jsx +33 -15
- data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_default.jsx +33 -15
- data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_height.jsx +52 -22
- data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_height.md +3 -0
- data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_horizontal.jsx +12 -16
- data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_legend.jsx +31 -15
- data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_legend_non_clickable.jsx +39 -16
- data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_legend_position.jsx +86 -38
- data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_negative_numbers.jsx +32 -15
- data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_secondary_y_axis.jsx +72 -22
- data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_secondary_y_axis.md +1 -1
- data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_spline.jsx +31 -15
- data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_stacked.jsx +37 -16
- data/app/pb_kits/playbook/pb_bar_graph/docs/_description.md +1 -3
- data/app/pb_kits/playbook/pb_bar_graph/docs/example.yml +1 -3
- data/app/pb_kits/playbook/pb_bar_graph/docs/index.js +0 -2
- data/app/pb_kits/playbook/pb_tooltip/docs/_tooltip_click_open.html.erb +14 -0
- data/app/pb_kits/playbook/pb_tooltip/docs/_tooltip_click_open_rails.md +1 -0
- data/app/pb_kits/playbook/pb_tooltip/docs/example.yml +1 -0
- data/app/pb_kits/playbook/pb_tooltip/index.js +59 -36
- data/app/pb_kits/playbook/pb_tooltip/tooltip.rb +9 -2
- data/dist/chunks/_bar_graph-DVfSt34a.js +1 -0
- data/dist/chunks/{_typeahead-B7FRYVtS.js → _typeahead-C2h5Gq3P.js} +3 -3
- data/dist/chunks/_weekday_stacked-XhCaqWUk.js +45 -0
- data/dist/chunks/{lib-Carqm8Ip.js → lib-C0HyLoRj.js} +1 -1
- data/dist/chunks/{pb_form_validation-DqRmTS8m.js → pb_form_validation-C3CDCB0e.js} +1 -1
- data/dist/chunks/vendor.js +1 -1
- data/dist/playbook-doc.js +1 -1
- data/dist/playbook-rails-react-bindings.js +1 -1
- data/dist/playbook-rails.js +1 -1
- data/dist/playbook.css +1 -1
- data/lib/playbook/version.rb +1 -1
- metadata +16 -11
- data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_custom.jsx +0 -72
- data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_custom.md +0 -6
- data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_pb_styles.jsx +0 -64
- data/app/pb_kits/playbook/pb_bar_graph/docs/_bar_graph_pb_styles.md +0 -1
- data/dist/chunks/_weekday_stacked-BNSy7Mo2.js +0 -45
- /data/app/pb_kits/playbook/pb_tooltip/docs/{_tooltip_click_open.md → _tooltip_click_open_react.md} +0 -0
@@ -1,39 +1,69 @@
|
|
1
1
|
import React from 'react'
|
2
|
+
import barGraphTheme from '../barGraphTheme';
|
3
|
+
import Highcharts from "highcharts";
|
4
|
+
import HighchartsReact from "highcharts-react-official";
|
2
5
|
|
3
|
-
import BarGraph from '../_bar_graph'
|
4
6
|
|
5
7
|
const chartData = [{
|
6
8
|
name: 'Number of Installations',
|
7
9
|
data: [1475, 200, 3000, 654, 656],
|
8
10
|
}]
|
9
11
|
|
10
|
-
const
|
12
|
+
const pixelHeightChartOptions = {
|
13
|
+
chart: {
|
14
|
+
height: "300"
|
15
|
+
},
|
16
|
+
series: chartData,
|
17
|
+
title: {
|
18
|
+
text: "Fixed Height (300px)",
|
19
|
+
},
|
20
|
+
xAxis: {
|
21
|
+
categories: ["Jan", "Feb", "Mar", "Apr", "May"],
|
22
|
+
},
|
23
|
+
yAxis: {
|
24
|
+
title: {
|
25
|
+
text: "Number of Employees",
|
26
|
+
},
|
27
|
+
},
|
28
|
+
};
|
29
|
+
|
30
|
+
const percentageHeightChartOptions = {
|
31
|
+
chart: {
|
32
|
+
height: "50%"
|
33
|
+
},
|
34
|
+
series: chartData,
|
35
|
+
title: {
|
36
|
+
text: "Percentage Height (50%)",
|
37
|
+
},
|
38
|
+
xAxis: {
|
39
|
+
categories: ["Jan", "Feb", "Mar", "Apr", "May"],
|
40
|
+
},
|
41
|
+
yAxis: {
|
42
|
+
title: {
|
43
|
+
text: "Number of Employees",
|
44
|
+
},
|
45
|
+
},
|
46
|
+
};
|
47
|
+
|
48
|
+
const pixelOptions = Highcharts.merge({}, barGraphTheme, pixelHeightChartOptions)
|
49
|
+
|
50
|
+
const percentageOptions = Highcharts.merge({}, barGraphTheme, percentageHeightChartOptions)
|
51
|
+
|
52
|
+
const BarGraphHeight = () => (
|
11
53
|
<div>
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
id="bar-fixed-height"
|
17
|
-
title="Fixed Height (300px)"
|
18
|
-
xAxisCategories={['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec']}
|
19
|
-
yAxisMin={0}
|
20
|
-
{...props}
|
21
|
-
/>
|
54
|
+
<HighchartsReact
|
55
|
+
highcharts={Highcharts}
|
56
|
+
options={pixelOptions}
|
57
|
+
/>
|
22
58
|
|
23
59
|
<br />
|
24
60
|
<br />
|
25
61
|
|
26
|
-
<
|
27
|
-
|
28
|
-
|
29
|
-
height="50%"
|
30
|
-
id="bar-percentage-height"
|
31
|
-
title="Percentage Height (50%)"
|
32
|
-
xAxisCategories={['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec']}
|
33
|
-
yAxisMin={0}
|
34
|
-
{...props}
|
62
|
+
<HighchartsReact
|
63
|
+
highcharts={Highcharts}
|
64
|
+
options={percentageOptions}
|
35
65
|
/>
|
36
66
|
</div>
|
37
67
|
)
|
38
68
|
|
39
|
-
export default
|
69
|
+
export default BarGraphHeight
|
@@ -0,0 +1,3 @@
|
|
1
|
+
By default, Highcharts have a height of 400px, but this can be customized. You can override the default by specifying either a percentage or a fixed pixel value.
|
2
|
+
|
3
|
+
Using a percentage maintains a consistent aspect ratio across different responsive sizes. For example, setting the height to 50% makes the chart’s height half of its width.
|
@@ -1,9 +1,10 @@
|
|
1
1
|
import React from 'react'
|
2
|
+
import barGraphTheme from '../barGraphTheme';
|
3
|
+
import Highcharts from "highcharts";
|
4
|
+
import HighchartsReact from "highcharts-react-official";
|
2
5
|
|
3
|
-
import BarGraph from '../_bar_graph'
|
4
6
|
|
5
|
-
|
6
|
-
const barGraphOptions = {
|
7
|
+
const chartOptions = {
|
7
8
|
chart: {
|
8
9
|
type: 'bar'
|
9
10
|
},
|
@@ -22,13 +23,8 @@ const barGraphOptions = {
|
|
22
23
|
lineWidth: 0
|
23
24
|
},
|
24
25
|
yAxis: {
|
25
|
-
min: 0,
|
26
26
|
title: {
|
27
|
-
text: '
|
28
|
-
align: 'high'
|
29
|
-
},
|
30
|
-
labels: {
|
31
|
-
overflow: 'justify'
|
27
|
+
text: '',
|
32
28
|
},
|
33
29
|
},
|
34
30
|
tooltip: {
|
@@ -51,16 +47,16 @@ const barGraphOptions = {
|
|
51
47
|
}, {
|
52
48
|
name: 'Year 2018',
|
53
49
|
data: [1276, 1007, 4561, 746]
|
54
|
-
}]
|
50
|
+
}],
|
55
51
|
}
|
56
52
|
|
57
|
-
const
|
53
|
+
const options = Highcharts.merge({}, barGraphTheme, chartOptions)
|
54
|
+
|
55
|
+
const BarGraphHorizontal = () => (
|
58
56
|
<div>
|
59
|
-
<
|
60
|
-
|
61
|
-
|
62
|
-
yAxisMin={0}
|
63
|
-
{...props}
|
57
|
+
<HighchartsReact
|
58
|
+
highcharts={Highcharts}
|
59
|
+
options={options}
|
64
60
|
/>
|
65
61
|
</div>
|
66
62
|
)
|
@@ -1,24 +1,40 @@
|
|
1
1
|
import React from 'react'
|
2
|
-
import
|
2
|
+
import barGraphTheme from '../barGraphTheme';
|
3
|
+
import Highcharts from "highcharts";
|
4
|
+
import HighchartsReact from "highcharts-react-official";
|
5
|
+
|
3
6
|
|
4
7
|
const chartData = [{
|
5
8
|
name: 'Number of Installations',
|
6
9
|
data: [1475, 200, 3000, 654, 656],
|
7
10
|
}]
|
8
11
|
|
9
|
-
const
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
12
|
+
const chartOptions = {
|
13
|
+
series: chartData,
|
14
|
+
title: {
|
15
|
+
text: 'Bar Graph with Legend',
|
16
|
+
},
|
17
|
+
xAxis: {
|
18
|
+
categories: ['Jan', 'Feb', 'Mar', 'Apr', 'May'],
|
19
|
+
},
|
20
|
+
yAxis: {
|
21
|
+
title: {
|
22
|
+
text: 'Number of Employees',
|
23
|
+
},
|
24
|
+
},
|
25
|
+
legend: { enabled: true },
|
26
|
+
}
|
23
27
|
|
28
|
+
const BarGraphLegend = () => {
|
29
|
+
const options = Highcharts.merge({}, barGraphTheme, chartOptions)
|
30
|
+
|
31
|
+
return (
|
32
|
+
<div>
|
33
|
+
<HighchartsReact
|
34
|
+
highcharts={Highcharts}
|
35
|
+
options={options}
|
36
|
+
/>
|
37
|
+
</div>
|
38
|
+
)
|
39
|
+
}
|
24
40
|
export default BarGraphLegend
|
@@ -1,25 +1,48 @@
|
|
1
1
|
import React from 'react'
|
2
|
-
import
|
2
|
+
import barGraphTheme from '../barGraphTheme';
|
3
|
+
import Highcharts from "highcharts";
|
4
|
+
import HighchartsReact from "highcharts-react-official";
|
5
|
+
|
3
6
|
|
4
7
|
const chartData = [{
|
5
8
|
name: 'Number of Installations',
|
6
9
|
data: [1475, 200, 3000, 654, 656],
|
7
10
|
}]
|
8
11
|
|
9
|
-
const
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
12
|
+
const chartOptions = {
|
13
|
+
title: {
|
14
|
+
text: 'Bar Graph with Legend Non Clickable',
|
15
|
+
},
|
16
|
+
xAxis: {
|
17
|
+
categories: ['Jan', 'Feb', 'Mar', 'Apr', 'May'],
|
18
|
+
},
|
19
|
+
yAxis: {
|
20
|
+
title: {
|
21
|
+
text: 'Number of Employees',
|
22
|
+
},
|
23
|
+
},
|
24
|
+
legend: {
|
25
|
+
enabled: true,
|
26
|
+
events: {
|
27
|
+
itemClick: function () {
|
28
|
+
return false;
|
29
|
+
}
|
30
|
+
}
|
31
|
+
},
|
32
|
+
series: chartData
|
33
|
+
}
|
34
|
+
|
35
|
+
const BarGraphLegendNonClickable = () => {
|
36
|
+
const options = Highcharts.merge({}, barGraphTheme, chartOptions)
|
37
|
+
|
38
|
+
return (
|
39
|
+
<div>
|
40
|
+
<HighchartsReact
|
41
|
+
highcharts={Highcharts}
|
42
|
+
options={options}
|
43
|
+
/>
|
44
|
+
</div>
|
45
|
+
)
|
46
|
+
}
|
24
47
|
|
25
48
|
export default BarGraphLegendNonClickable
|
@@ -1,8 +1,11 @@
|
|
1
1
|
import React from 'react'
|
2
|
+
import barGraphTheme from '../barGraphTheme';
|
3
|
+
import Highcharts from "highcharts";
|
4
|
+
import HighchartsReact from "highcharts-react-official";
|
2
5
|
|
3
|
-
import BarGraph from "../../pb_bar_graph/_bar_graph"
|
4
6
|
import Title from "../../pb_title/_title"
|
5
7
|
|
8
|
+
|
6
9
|
const chartData = [{
|
7
10
|
name: 'Installation',
|
8
11
|
data: [1475],
|
@@ -20,7 +23,76 @@ const chartData = [{
|
|
20
23
|
data: [1111],
|
21
24
|
}]
|
22
25
|
|
23
|
-
const
|
26
|
+
const alignChartOptions = {
|
27
|
+
series: chartData,
|
28
|
+
title: {
|
29
|
+
text: 'Alignment of Legend',
|
30
|
+
},
|
31
|
+
subtitle: {
|
32
|
+
text: 'Source: thesolarfoundation.com',
|
33
|
+
},
|
34
|
+
xAxis: {
|
35
|
+
categories: ['Jan'],
|
36
|
+
},
|
37
|
+
yAxis: {
|
38
|
+
title: {
|
39
|
+
text: 'Number of Employees',
|
40
|
+
},
|
41
|
+
},
|
42
|
+
legend: {
|
43
|
+
enabled: true,
|
44
|
+
verticalAlign: 'top',
|
45
|
+
align: 'right',
|
46
|
+
},
|
47
|
+
}
|
48
|
+
|
49
|
+
const layoutChartOptions = {
|
50
|
+
series: chartData,
|
51
|
+
title: {
|
52
|
+
text: 'Layout of Legend',
|
53
|
+
},
|
54
|
+
xAxis: {
|
55
|
+
categories: ['Jan'],
|
56
|
+
},
|
57
|
+
yAxis: {
|
58
|
+
title: {
|
59
|
+
text: 'Number of Employees',
|
60
|
+
},
|
61
|
+
},
|
62
|
+
legend: {
|
63
|
+
enabled: true,
|
64
|
+
layout: 'vertical',
|
65
|
+
},
|
66
|
+
}
|
67
|
+
|
68
|
+
const offsetChartOptions = {
|
69
|
+
series: chartData,
|
70
|
+
title: {
|
71
|
+
text: 'Offset of Legend',
|
72
|
+
},
|
73
|
+
xAxis: {
|
74
|
+
categories: ['Jan'],
|
75
|
+
},
|
76
|
+
yAxis: {
|
77
|
+
title: {
|
78
|
+
text: 'Number of Employees',
|
79
|
+
},
|
80
|
+
},
|
81
|
+
legend: {
|
82
|
+
enabled: true,
|
83
|
+
layout: 'vertical',
|
84
|
+
x: 100,
|
85
|
+
y: 10,
|
86
|
+
},
|
87
|
+
}
|
88
|
+
|
89
|
+
const BarGraphLegendPosition = () => {
|
90
|
+
const alignOptions = Highcharts.merge({}, barGraphTheme, alignChartOptions)
|
91
|
+
const layoutOptions = Highcharts.merge({}, barGraphTheme, layoutChartOptions)
|
92
|
+
const offsetOptions = Highcharts.merge({}, barGraphTheme, offsetChartOptions)
|
93
|
+
|
94
|
+
|
95
|
+
return (
|
24
96
|
<div>
|
25
97
|
<Title
|
26
98
|
paddingBottom="sm"
|
@@ -29,19 +101,11 @@ const BarGraphLegendPosition = (props) => (
|
|
29
101
|
tag="h4"
|
30
102
|
text="align | verticalAlign"
|
31
103
|
/>
|
32
|
-
<
|
33
|
-
|
34
|
-
|
35
|
-
chartData={chartData}
|
36
|
-
id="legend-position-bar"
|
37
|
-
legend
|
38
|
-
paddingBottom="sm"
|
39
|
-
title="Alignment of Legend"
|
40
|
-
verticalAlign="top"
|
41
|
-
xAxisCategories={['Jan']}
|
42
|
-
yAxisMin={0}
|
43
|
-
{...props}
|
104
|
+
<HighchartsReact
|
105
|
+
highcharts={Highcharts}
|
106
|
+
options={alignOptions}
|
44
107
|
/>
|
108
|
+
|
45
109
|
<Title
|
46
110
|
paddingBottom="sm"
|
47
111
|
paddingTop="sm"
|
@@ -49,19 +113,11 @@ const BarGraphLegendPosition = (props) => (
|
|
49
113
|
tag="h4"
|
50
114
|
text="layout"
|
51
115
|
/>
|
52
|
-
<
|
53
|
-
|
54
|
-
|
55
|
-
id="legend-position-bar-1"
|
56
|
-
layout="vertical"
|
57
|
-
legend
|
58
|
-
paddingBottom="sm"
|
59
|
-
paddingTop="sm"
|
60
|
-
title="Layout of Legend"
|
61
|
-
xAxisCategories={['Jan']}
|
62
|
-
yAxisMin={0}
|
63
|
-
{...props}
|
116
|
+
<HighchartsReact
|
117
|
+
highcharts={Highcharts}
|
118
|
+
options={layoutOptions}
|
64
119
|
/>
|
120
|
+
|
65
121
|
<Title
|
66
122
|
paddingBottom="sm"
|
67
123
|
paddingTop="sm"
|
@@ -69,20 +125,12 @@ const BarGraphLegendPosition = (props) => (
|
|
69
125
|
tag="h4"
|
70
126
|
text="x | y"
|
71
127
|
/>
|
72
|
-
<
|
73
|
-
|
74
|
-
|
75
|
-
id="legend-position-bar-2"
|
76
|
-
layout="vertical"
|
77
|
-
legend
|
78
|
-
title="Offset of Legend"
|
79
|
-
x={100}
|
80
|
-
xAxisCategories={['Jan']}
|
81
|
-
y={10}
|
82
|
-
yAxisMin={0}
|
83
|
-
{...props}
|
128
|
+
<HighchartsReact
|
129
|
+
highcharts={Highcharts}
|
130
|
+
options={offsetOptions}
|
84
131
|
/>
|
85
132
|
</div>
|
86
133
|
)
|
134
|
+
}
|
87
135
|
|
88
136
|
export default BarGraphLegendPosition
|
@@ -1,6 +1,8 @@
|
|
1
1
|
import React from 'react'
|
2
|
+
import barGraphTheme from '../barGraphTheme';
|
3
|
+
import Highcharts from "highcharts";
|
4
|
+
import HighchartsReact from "highcharts-react-official";
|
2
5
|
|
3
|
-
import BarGraph from '../_bar_graph'
|
4
6
|
|
5
7
|
const chartData = [{
|
6
8
|
name: 'Installation',
|
@@ -10,26 +12,41 @@ const chartData = [{
|
|
10
12
|
name: 'Manufacturing',
|
11
13
|
data: [1475, 200, 1000, 654, -656],
|
12
14
|
threshold: 0
|
13
|
-
},
|
15
|
+
},
|
14
16
|
{
|
15
17
|
name: 'Sales & Distribution',
|
16
18
|
data: [1270, 100, -1200, 554, 756],
|
17
19
|
threshold: 0
|
18
20
|
}]
|
19
21
|
|
22
|
+
const chartOptions = {
|
23
|
+
series: chartData,
|
24
|
+
title: {
|
25
|
+
text: "Bar Graph with Negative Numbers",
|
26
|
+
},
|
27
|
+
xAxis: {
|
28
|
+
categories: ["Jan", "Feb", "Mar", "Apr", "May"],
|
29
|
+
},
|
30
|
+
yAxis: {
|
31
|
+
title: {
|
32
|
+
text: "Number of Employees",
|
33
|
+
},
|
34
|
+
},
|
35
|
+
legend: { enabled: true },
|
36
|
+
};
|
20
37
|
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
38
|
+
|
39
|
+
const BarGraphStacked = () => {
|
40
|
+
const options = Highcharts.merge({}, barGraphTheme, chartOptions)
|
41
|
+
|
42
|
+
return(
|
43
|
+
<div>
|
44
|
+
<HighchartsReact
|
45
|
+
highcharts={Highcharts}
|
46
|
+
options={options}
|
47
|
+
/>
|
48
|
+
</div>
|
49
|
+
)
|
50
|
+
}
|
34
51
|
|
35
52
|
export default BarGraphStacked
|
@@ -1,6 +1,11 @@
|
|
1
1
|
import React from 'react'
|
2
|
+
import barGraphTheme from '../barGraphTheme';
|
3
|
+
import Highcharts from "highcharts"
|
4
|
+
import HighchartsReact from "highcharts-react-official"
|
2
5
|
|
3
|
-
|
6
|
+
|
7
|
+
import colors from '../../tokens/exports/_colors.module.scss'
|
8
|
+
import typography from '../../tokens/exports/_typography.module.scss'
|
4
9
|
|
5
10
|
const chartData = [{
|
6
11
|
name: 'Number of Installations',
|
@@ -13,24 +18,69 @@ const chartData = [{
|
|
13
18
|
yAxis: 1
|
14
19
|
}]
|
15
20
|
|
16
|
-
const
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
|
21
|
+
const chartOptions = {
|
22
|
+
series: chartData,
|
23
|
+
title: {
|
24
|
+
text: "Bar Graph with Secondary Y-axis",
|
25
|
+
},
|
26
|
+
xAxis: {
|
27
|
+
categories: ["Jan", "Feb", "Mar", "Apr", "May"],
|
28
|
+
},
|
29
|
+
yAxis: [{
|
30
|
+
labels: {
|
31
|
+
style: {
|
32
|
+
fontFamily: typography.font_family_base,
|
33
|
+
color: colors.text_lt_lighter,
|
34
|
+
fontWeight: typography.bold,
|
35
|
+
fontSize: typography.text_smaller,
|
36
|
+
},
|
37
|
+
},
|
38
|
+
title: {
|
39
|
+
text: "Number of Employees",
|
40
|
+
style: {
|
41
|
+
fontFamily: typography.font_family_base,
|
42
|
+
color: colors.text_lt_lighter,
|
43
|
+
fontWeight: typography.bold,
|
44
|
+
fontSize: typography.text_smaller,
|
45
|
+
},
|
46
|
+
},
|
47
|
+
}, {
|
48
|
+
labels: {
|
49
|
+
style: {
|
50
|
+
fontFamily: typography.font_family_base,
|
51
|
+
color: colors.text_lt_lighter,
|
52
|
+
fontWeight: typography.bold,
|
53
|
+
fontSize: typography.text_smaller,
|
54
|
+
},
|
55
|
+
},
|
56
|
+
title: {
|
57
|
+
text: "Percentage",
|
58
|
+
style: {
|
59
|
+
fontFamily: typography.font_family_base,
|
60
|
+
color: colors.text_lt_lighter,
|
61
|
+
fontWeight: typography.bold,
|
62
|
+
fontSize: typography.text_smaller,
|
63
|
+
},
|
64
|
+
},
|
65
|
+
|
66
|
+
opposite: true,
|
67
|
+
min: 0,
|
68
|
+
max: 100
|
69
|
+
}],
|
70
|
+
legend: { enabled: true },
|
71
|
+
}
|
72
|
+
|
73
|
+
const BarGraphSecondaryYAxis = () => {
|
74
|
+
const options = Highcharts.merge({}, barGraphTheme, chartOptions)
|
75
|
+
|
76
|
+
return (
|
77
|
+
<div>
|
78
|
+
<HighchartsReact
|
79
|
+
highcharts={Highcharts}
|
80
|
+
options={options}
|
81
|
+
/>
|
82
|
+
</div>
|
83
|
+
)
|
84
|
+
}
|
85
|
+
|
86
|
+
export default BarGraphSecondaryYAxis
|
@@ -1,3 +1,3 @@
|
|
1
|
-
Optionally add a second yAxis to support secondary datasets (e.x., a spline) by passing`
|
1
|
+
Optionally add a second yAxis to support secondary datasets (e.x., a spline) by passing `yAxis: 1` to the second node of your `chartData` array.
|
2
2
|
|
3
3
|
To customize the format and/or title of your secondary yAxis, pass your desired values as arrays through the `axisFormat` and `axisTitle` props, respectively.
|
@@ -1,6 +1,8 @@
|
|
1
1
|
import React from 'react'
|
2
|
+
import barGraphTheme from '../barGraphTheme';
|
3
|
+
import Highcharts from "highcharts";
|
4
|
+
import HighchartsReact from "highcharts-react-official";
|
2
5
|
|
3
|
-
import BarGraph from '../_bar_graph'
|
4
6
|
|
5
7
|
const chartData = [{
|
6
8
|
name: 'Number of Installations',
|
@@ -12,19 +14,33 @@ const chartData = [{
|
|
12
14
|
color: '#F9BB00',
|
13
15
|
}]
|
14
16
|
|
15
|
-
const
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
17
|
+
const chartOptions = {
|
18
|
+
series: chartData,
|
19
|
+
title: {
|
20
|
+
text: "Bar Graph with Spline",
|
21
|
+
},
|
22
|
+
xAxis: {
|
23
|
+
categories: ["Jan", "Feb", "Mar", "Apr", "May"],
|
24
|
+
},
|
25
|
+
yAxis: {
|
26
|
+
title: {
|
27
|
+
text: "Number of Employees",
|
28
|
+
},
|
29
|
+
},
|
30
|
+
legend: { enabled: true },
|
31
|
+
};
|
32
|
+
|
33
|
+
const BarGraphSpline = () => {
|
34
|
+
const options = Highcharts.merge({}, barGraphTheme, chartOptions)
|
35
|
+
|
36
|
+
return (
|
37
|
+
<div>
|
38
|
+
<HighchartsReact
|
39
|
+
highcharts={Highcharts}
|
40
|
+
options={options}
|
41
|
+
/>
|
42
|
+
</div>
|
43
|
+
)
|
44
|
+
}
|
29
45
|
|
30
46
|
export default BarGraphSpline
|