function renderBarChart(inputData,dom_element_to_append_to,yaxisLabel, colorScheme){ var margin = {top: 40, right: 40, bottom: 150, left: 90}, width = 800 - margin.left - margin.right, height = 500 - margin.top - margin.bottom; var formatPercent = d3.format(".0%"); var x = d3.scale.ordinal().rangeRoundBands([0, width], .05); var y = d3.scale.linear().range([height, 0]); var color = d3.scale.ordinal() .range(colorScheme); var xAxis = d3.svg.axis() .scale(x) .orient("bottom") var yAxis = d3.svg.axis() .scale(y) .orient("left") .ticks(10); var svg = d3.select(dom_element_to_append_to).append("svg") .attr("width", width + margin.left + margin.right) .attr("height", height + margin.top + margin.bottom) .append("g") .attr("transform", "translate(" + margin.left + "," + margin.top + ")"); inputData.forEach(function(d) { d.label = d.label; d.value = +d.value; }); x.domain(inputData.map(function(d) { return d.label; })); y.domain([0, d3.max(inputData, function(d) { return +d.value; })]); svg.append("g") .attr("class", "y axis") .call(yAxis) .append("text") .attr("transform", "rotate(-90)") .attr("y", -5) .attr("dy", "1.71em") .attr("dx", ".29em") .style("text-anchor", "end") .text(yaxisLabel); svg.append("g") .attr("class", "x axis") .call(xAxis) .attr("transform", "translate(" + 0 + "," + height + ")") svg.selectAll("bar") .data(inputData) .enter().append("rect") .attr("class", "bar") .attr("x", function(d) { return x(d.label); }) .attr("width", x.rangeBand()) .attr("y", function(d) { return y(d.value); }) .attr("height", function(d) { return height - y(d.value); }) .attr('fill', function(d, i) { return color(d.label); }); var tooltip = d3.select(dom_element_to_append_to) .append('div') .attr('class', 'tooltip'); tooltip.append('div') .attr('class', 'label'); tooltip.append('div') .attr('class', 'value'); svg.selectAll(".bar") .on('mouseover', function(d) { tooltip.select('.label').html(" Label: " + d.label + ""); tooltip.select('.value').html(" Value: " + d.value + ""); tooltip.style('display', 'block'); tooltip.style('opacity',2); }) .on('mousemove', function(d) { tooltip.style('top', (d3.event.layerY + 10) + 'px') .style('left', (d3.event.layerX - 25) + 'px'); }) .on('mouseout', function(d) { tooltip.style('display', 'none'); tooltip.style('opacity',0); }); }