lucid-ui
Version:
A UI component library from AppNexus.
43 lines (42 loc) • 1.41 kB
JavaScript
/* eslint-disable comma-spacing */
import _ from 'lodash';
import React from 'react';
import createClass from 'create-react-class';
import { Bars, d3Scale, chartConstants } from '../../../index';
const width = 750;
const height = 400;
const data = [
{ x: 'one', y0: 1, y1: 2, y2: 3, y3: 5 },
{ x: 'two', y0: 2, y1: 3, y2: 4, y3: 6 },
{ x: 'three', y0: 2, y1: 4, y2: 5, y3: 6 },
{ x: 'four', y0: 3, y1: 6, y2: 7, y3: 7 },
{ x: 'five', y0: 4, y1: 8, y2: 9, y3: 8 },
{ x: 'six', y0: 11, y1: 8, y2: 9, y3: 5 },
];
const yFields = ['y0', 'y1', 'y2', 'y3'];
const yMax = _.max(_.reduce(yFields, (acc, field) => {
return acc.concat(_.map(data, field));
}, []));
const xScale = d3Scale
.scaleBand()
.domain(_.map(data, 'x'))
.range([0, width])
.round(true)
.paddingInner(0.1);
const yScale = d3Scale
.scaleLinear()
.domain([0, yMax])
.range([height, 0]);
const style = {
paddingTop: '9rem',
};
export default createClass({
render() {
return (React.createElement("div", { style: style },
React.createElement("svg", { width: width, height: height },
React.createElement(Bars, { data: data, xScale: xScale, yScale: yScale, yFields: yFields, colorMap: {
y0: chartConstants.COLOR_GOOD,
y2: chartConstants.COLOR_BAD,
}, hasToolTips: true }))));
},
});