Skip to content

Commit

Permalink
[TSVB] Add option to stack globally or within series (elastic#31417)
Browse files Browse the repository at this point in the history
* Add a check for the same series metric

* Replace logic to the nodejs side

* Add 'Stack within series' option
  • Loading branch information
sulemanof authored Feb 26, 2019
1 parent a382b49 commit 7559941
Show file tree
Hide file tree
Showing 3 changed files with 60 additions and 1 deletion.
Original file line number Diff line number Diff line change
Expand Up @@ -62,6 +62,13 @@ const TimeseriesConfig = injectI18n(function (props) {
const stackedOptions = [
{ label: intl.formatMessage({ id: 'tsvb.timeSeries.noneLabel', defaultMessage: 'None' }), value: 'none' },
{ label: intl.formatMessage({ id: 'tsvb.timeSeries.stackedLabel', defaultMessage: 'Stacked' }), value: 'stacked' },
{
label: intl.formatMessage({
id: 'tsvb.timeSeries.stackedWithinSeriesLabel',
defaultMessage: 'Stacked within series'
}),
value: 'stacked_within_series'
},
{ label: intl.formatMessage({ id: 'tsvb.timeSeries.percentLabel', defaultMessage: 'Percent' }), value: 'percent' }
];
const selectedStackedOption = stackedOptions.find(option => {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,45 @@ import getDefaultDecoration from '../../helpers/get_default_decoration';

describe('getDefaultDecoration', () => {

describe('stack option', () => {

it('should set a stack option to false', () => {
const series = {
id: 'test_id'
};
expect(getDefaultDecoration(series))
.to.have.property('stack', false);

series.stacked = 'none';
expect(getDefaultDecoration(series))
.to.have.property('stack', false);
});

it('should set a stack option to true', () => {
const series = {
stacked: 'stacked',
id: 'test_id'
};

expect(getDefaultDecoration(series))
.to.have.property('stack', true);

series.stacked = 'percent';
expect(getDefaultDecoration(series))
.to.have.property('stack', true);
});

it('should set a stack option to be series id', () => {
const series = {
stacked: 'stacked_within_series',
id: 'test_id'
};

expect(getDefaultDecoration(series))
.to.have.property('stack', series.id);
});
});

describe('lines', () => {
it('return decoration for lines', () => {
const series = {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -20,8 +20,21 @@
export default series => {
const pointSize = series.point_size != null ? Number(series.point_size) : Number(series.line_width);
const showPoints = series.chart_type === 'line' && pointSize !== 0;
let stack;
switch (series.stacked) {
case 'stacked':
case 'percent':
stack = true;
break;
case 'stacked_within_series':
stack = series.id;
break;
default:
stack = false;
}

return {
stack: series.stacked && series.stacked !== 'none' || false,
stack,
lines: {
show: series.chart_type === 'line' && series.line_width !== 0,
fill: Number(series.fill),
Expand Down

0 comments on commit 7559941

Please sign in to comment.