Recharts BarChartStackedBySign - возможно ли показывать один и тот же объект по обе стороны от оси Y - PullRequest
0 голосов
/ 21 ноября 2018

В BarChartStackedBySign of Recharts я хочу сравнить данные объекты для текущего и предыдущего года, представляя их на гистограмме.

Проблема в том, что перекарты обрабатывают их как разные сущности, если они предоставлены двумя разными объектами.

В общей скрипте мы видим, что каждый фрукт представлен два раза на оси x, я хочукаждый фрукт появляется только один раз на оси x, а данные за текущий год отображаются на оси + y, а данные за предыдущий год по оси -y.

Скриптовая ссылка - https://jsfiddle.net/59ugdj1t/

const {BarChart, Bar, ReferenceLine, XAxis, YAxis, CartesianGrid, Tooltip, Legend} = Recharts;

// Data for current year
const data1 = [
      {name: 'Apple', men: 4000, women: 2400},
      {name: 'Orange', men: 2000, women: 2000},
      {name: 'Kiwi', men: 1000, women: 1400},
];

// Data for previous year
const data2 = [
      {name: 'Apple', men: -3000, women: -2000},
      {name: 'Orange', men: -1000, women: -1000},
      {name: 'Kiwi', men: -2000, women: -400},
];

const data = data1.concat(data2);

const SimpleBarChart = React.createClass({
    render () {
    return (
        <BarChart width={600} height={300} data={data} stackOffset="sign"
            margin={{top: 5, right: 30, left: 20, bottom: 5}}>
       <CartesianGrid strokeDasharray="3 3"/>
       <XAxis dataKey="name"/>
       <YAxis/>
       <Tooltip/>
       <Legend />
       <ReferenceLine y={0} stroke='#000'/>
       <Bar dataKey="men" fill="#8884d8" stackId="stack" />
       <Bar dataKey="women" fill="#82ca9d" stackId="stack" />
      </BarChart>
    );
  }
})

ReactDOM.render(
  <SimpleBarChart />,
  document.getElementById('container')
);
...