devextreme
Version:
HTML5 JavaScript Component Suite for Responsive Web Development
176 lines (172 loc) • 6.41 kB
JavaScript
/**
* DevExtreme (esm/viz/series/stacked_series.js)
* Version: 21.1.4
* Build date: Mon Jun 21 2021
*
* Copyright (c) 2012 - 2021 Developer Express Inc. ALL RIGHTS RESERVED
* Read about DevExtreme licensing here: https://js.devexpress.com/Licensing/
*/
import {
noop as _noop
} from "../../core/utils/common";
import {
extend as _extend
} from "../../core/utils/extend";
import {
each
} from "../../core/utils/iterator";
import {
chart as areaSeries
} from "./area_series";
var chartAreaSeries = areaSeries.area;
import {
chart as _chart,
polar as _polar
} from "./bar_series";
var chartBarSeries = _chart.bar;
import {
chart as lineSeries
} from "./line_series";
import {
map
} from "../core/utils";
import {
clone
} from "../../core/utils/object";
var baseStackedSeries = {
_calculateErrorBars: _noop,
_updateOptions: function(options) {
this._stackName = "axis_" + (options.axis || "default")
}
};
var chart = {};
var polar = {};
chart.stackedline = _extend({}, lineSeries.line, baseStackedSeries, {});
chart.stackedspline = _extend({}, lineSeries.spline, baseStackedSeries, {});
chart.fullstackedline = _extend({}, lineSeries.line, baseStackedSeries, {
getValueRangeInitialValue: areaSeries.area.getValueRangeInitialValue
});
chart.fullstackedspline = _extend({}, lineSeries.spline, baseStackedSeries, {
getValueRangeInitialValue: areaSeries.area.getValueRangeInitialValue
});
var stackedBar = chart.stackedbar = _extend({}, chartBarSeries, baseStackedSeries, {
_updateOptions: function(options) {
baseStackedSeries._updateOptions.call(this, options);
this._stackName = this._stackName + "_stack_" + (options.stack || "default")
}
});
chart.fullstackedbar = _extend({}, chartBarSeries, baseStackedSeries, {
_updateOptions: stackedBar._updateOptions
});
function clonePoint(point, value, minValue, position) {
point = clone(point);
point.value = value;
point.minValue = minValue;
point.translate();
point.argument = point.argument + position;
return point
}
function preparePointsForStackedAreaSegment(points) {
var i = 0;
var p;
var result = [];
var array;
var len = points.length;
while (i < len) {
p = points[i];
array = [p];
if (p.leftHole) {
array = [clonePoint(p, p.leftHole, p.minLeftHole, "left"), p]
}
if (p.rightHole) {
array.push(clonePoint(p, p.rightHole, p.minRightHole, "right"))
}
result.push(array);
i++
}
return [].concat.apply([], result)
}
chart.stackedarea = _extend({}, chartAreaSeries, baseStackedSeries, {
_prepareSegment: function(points, rotated) {
return chartAreaSeries._prepareSegment.call(this, preparePointsForStackedAreaSegment(points), rotated)
},
_appendInGroup: function() {
this._group.append(this._extGroups.seriesGroup).toBackground()
}
});
function getPointsByArgFromPrevSeries(prevSeries, argument) {
var result;
while (!result && prevSeries) {
result = prevSeries._segmentByArg && prevSeries._segmentByArg[argument];
prevSeries = prevSeries._prevSeries
}
return result
}
chart.stackedsplinearea = _extend({}, areaSeries.splinearea, baseStackedSeries, {
_prepareSegment: function(points, rotated) {
var that = this;
var areaSegment;
points = preparePointsForStackedAreaSegment(points);
if (!this._prevSeries || 1 === points.length) {
areaSegment = areaSeries.splinearea._prepareSegment.call(this, points, rotated)
} else {
var forwardPoints = lineSeries.spline._calculateBezierPoints(points, rotated);
var backwardPoints = map(points, (function(p) {
var point = p.getCoords(true);
point.argument = p.argument;
return point
}));
var prevSeriesForwardPoints = [];
var pointByArg = {};
var i = 0;
var len = that._prevSeries._segments.length;
while (i < len) {
prevSeriesForwardPoints = prevSeriesForwardPoints.concat(that._prevSeries._segments[i].line);
i++
}
each(prevSeriesForwardPoints, (function(_, p) {
if (null !== p.argument) {
var argument = p.argument.valueOf();
if (!pointByArg[argument]) {
pointByArg[argument] = [p]
} else {
pointByArg[argument].push(p)
}
}
}));
that._prevSeries._segmentByArg = pointByArg;
backwardPoints = lineSeries.spline._calculateBezierPoints(backwardPoints, rotated);
each(backwardPoints, (function(i, p) {
var argument = p.argument.valueOf();
var prevSeriesPoints;
if (i % 3 === 0) {
prevSeriesPoints = pointByArg[argument] || getPointsByArgFromPrevSeries(that._prevSeries, argument);
if (prevSeriesPoints) {
backwardPoints[i - 1] && prevSeriesPoints[0] && (backwardPoints[i - 1] = prevSeriesPoints[0]);
backwardPoints[i + 1] && (backwardPoints[i + 1] = prevSeriesPoints[2] || p)
}
}
}));
areaSegment = {
line: forwardPoints,
area: forwardPoints.concat(backwardPoints.reverse())
};
that._areaPointsToSplineAreaPoints(areaSegment.area)
}
return areaSegment
},
_appendInGroup: chart.stackedarea._appendInGroup
});
chart.fullstackedarea = _extend({}, chartAreaSeries, baseStackedSeries, {
_prepareSegment: chart.stackedarea._prepareSegment,
_appendInGroup: chart.stackedarea._appendInGroup
});
chart.fullstackedsplinearea = _extend({}, areaSeries.splinearea, baseStackedSeries, {
_prepareSegment: chart.stackedsplinearea._prepareSegment,
_appendInGroup: chart.stackedarea._appendInGroup
});
polar.stackedbar = _extend({}, _polar.bar, baseStackedSeries, {});
export {
chart,
polar
};