From 447ca40a7f8baa2ec55f3388e02cabcfe8cbfadc Mon Sep 17 00:00:00 2001 From: jcopperfield <33193571+jcopperfield@users.noreply.github.com> Date: Tue, 14 Nov 2017 10:33:36 +0100 Subject: [PATCH] Correctly handle stacked groups when not adjacent (#4937) Only the dataset index was used for indexing the stack --- src/controllers/controller.bar.js | 33 +++++++++++++++++++++++++------ 1 file changed, 27 insertions(+), 6 deletions(-) diff --git a/src/controllers/controller.bar.js b/src/controllers/controller.bar.js index ae4aee45d17..b811c6f05b1 100644 --- a/src/controllers/controller.bar.js +++ b/src/controllers/controller.bar.js @@ -201,10 +201,12 @@ module.exports = function(Chart) { }, /** - * Returns the effective number of stacks based on groups and bar visibility. + * Returns the stacks based on groups and bar visibility. + * @param {Number} [last] - The dataset index + * @returns {Array} The stack list * @private */ - getStackCount: function(last) { + _getStacks: function(last) { var me = this; var chart = me.chart; var scale = me.getIndexScale(); @@ -223,15 +225,33 @@ module.exports = function(Chart) { } } - return stacks.length; + return stacks; + }, + + /** + * Returns the effective number of stacks based on groups and bar visibility. + * @private + */ + getStackCount: function() { + return this._getStacks().length; }, /** * Returns the stack index for the given dataset based on groups and bar visibility. + * @param {Number} [datasetIndex] - The dataset index + * @param {String} [name] - The stack name to find + * @returns {Number} The stack index * @private */ - getStackIndex: function(datasetIndex) { - return this.getStackCount(datasetIndex) - 1; + getStackIndex: function(datasetIndex, name) { + var stacks = this._getStacks(datasetIndex); + var index = (name !== undefined) + ? stacks.indexOf(name) + : -1; // indexOf returns -1 if element is not present + + return (index === -1) + ? stacks.length - 1 + : index; }, /** @@ -312,7 +332,8 @@ module.exports = function(Chart) { calculateBarIndexPixels: function(datasetIndex, index, ruler) { var me = this; var options = ruler.scale.options; - var stackIndex = me.getStackIndex(datasetIndex); + var meta = me.getMeta(); + var stackIndex = me.getStackIndex(datasetIndex, meta.stack); var pixels = ruler.pixels; var base = pixels[index]; var length = pixels.length;