.shadow {
text-align: center !important;
border: 1px solid rgba(0, 0, 0, 0.05) !important;
box-shadow: 0 6px 14px 0 rgba(33, 35, 68, 0.09) !important;
}
#chart-container {
width: 100%;
height: 450px;
}
.control-wrapper {
text-align: center !important;
}
#control-wrapper-abs {
display: none;
}
#control-wrapper-rel {
display: block;
}
#option-label {
font-weight: 600;
color: black;
display: inline;
}
#option-controller {
width: 250px;
margin-top: 5px;
box-sizing: border-box;
box-shadow: 0 2px 4px 0 rgba(62, 57, 107, 0.05);
background-image: none;
overflow: hidden;
position: relative;
background-clip: padding-box;
background-color: #ffffff;
border: 1px solid #dadae4;
border-radius: 0.5rem;
color: #434456;
font-size: 15px;
line-height: 1.5;
padding: 1rem 1.5rem;
transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
-moz-appearance: none;
-webkit-appearance: none;
appearance: none;
background: url()
95%/12px no-repeat #fff;
padding-right: 20px;
text-transform: none;
}
#option-controller:focus {
outline: none;
}
#radioDiv1 {
display: inline;
padding: 10px;
}
#control-parent-msg {
display: inline;
padding: 10px;
}
#legendXPosition,
#legendYPosition {
background-color: #ffffff;
border: 1px solid #dadae4;
border-radius: 0.5rem;
box-sizing: border-box;
box-shadow: 0 2px 4px 0 rgba(62, 57, 107, 0.05);
margin: 20px;
padding-left: 2px;
}
const dataSource = {
chart: {
caption: "US Population Distribution by Gender",
subCaption: "State wise Male vs Female",
theme: "fusion",
showValues: "0",
numberSuffix: "%",
legendPosition: "bottom",
plottooltext:
"<b>Group : $seriesName</b>{br}Category: $label{br}Value: $dataValue</div>"
},
categories: [
{
category: [
{
label: "North Dakota"
},
{
label: "Alabama"
},
{
label: "Alaska"
},
{
label: "Florida"
},
{
label: "California"
}
]
}
],
dataset: [
{
seriesname: "Male",
data: [
{
value: "52"
},
{
value: "48"
},
{
value: "51"
},
{
value: "48"
},
{
value: "50"
}
]
},
{
seriesname: "Female",
data: [
{
value: "48"
},
{
value: "52"
},
{
value: "49"
},
{
value: "52"
},
{
value: "50"
}
]
}
]
};
FusionCharts.ready(function() {
var myChart = new FusionCharts({
type: "mscolumn2d",
renderAt: "chart-container",
id: "demoChart",
width: "100%",
height: "100%",
dataFormat: "json",
dataSource: dataSource
}).render();
const chartObj = FusionCharts.items["demoChart"];
document.getElementById("radio2").addEventListener("click", function() {
document.getElementById("control-wrapper-rel").style.display = "none";
document.getElementById("control-wrapper-abs").style.display = "block";
chartObj.setChartAttribute("legendPosition", "absolute");
chartObj.setChartAttribute("legendXPosition", 100);
chartObj.setChartAttribute("legendYPosition", 10);
});
document.getElementById("radio1").addEventListener("click", function() {
document.getElementById("control-wrapper-rel").style.display = "block";
document.getElementById("control-wrapper-abs").style.display = "none";
chartObj.setChartAttribute("legendPosition", "bottom");
});
document
.getElementById("legendXPosition")
.addEventListener("input", function(evt) {
chartObj.setChartAttribute("legendXPosition", this.value);
});
document
.getElementById("legendYPosition")
.addEventListener("input", function(evt) {
chartObj.setChartAttribute("legendYPosition", this.value);
});
document.getElementById("option-controller").onchange = changeEventHandler;
function changeEventHandler(event) {
switch (parseInt(event.target.value)) {
case 0:
chartObj.setChartAttribute("legendPosition", "bottom");
break;
case 1:
chartObj.setChartAttribute("legendPosition", "right");
break;
case 2:
chartObj.setChartAttribute("legendPosition", "top");
break;
case 3:
chartObj.setChartAttribute("legendPosition", "left");
break;
case 4:
chartObj.setChartAttribute("legendPosition", "top-left");
break;
case 5:
chartObj.setChartAttribute("legendPosition", "top-right");
break;
case 6:
chartObj.setChartAttribute("legendPosition", "bottom-left");
break;
case 7:
chartObj.setChartAttribute("legendPosition", "bottom-right");
break;
case 8:
chartObj.setChartAttribute("legendPosition", "left-top");
break;
case 9:
chartObj.setChartAttribute("legendPosition", "left-bottom");
break;
case 10:
chartObj.setChartAttribute("legendPosition", "right-top");
break;
case 11:
chartObj.setChartAttribute("legendPosition", "right-bottom");
break;
default:
console.log("Unexpected Input");
break;
}
}
});