Skip to content

Commit

Permalink
Provide a rectangle getArea implementation for horizontal bars (#6027)
Browse files Browse the repository at this point in the history
  • Loading branch information
etimberg authored and simonbrunel committed Feb 4, 2019
1 parent 93d5ac9 commit 945d91a
Show file tree
Hide file tree
Showing 2 changed files with 22 additions and 2 deletions.
5 changes: 4 additions & 1 deletion src/elements/element.rectangle.js
Original file line number Diff line number Diff line change
Expand Up @@ -206,7 +206,10 @@ module.exports = Element.extend({

getArea: function() {
var vm = this._view;
return vm.width * Math.abs(vm.y - vm.base);

return isVertical(this)
? vm.width * Math.abs(vm.y - vm.base)
: vm.height * Math.abs(vm.x - vm.base);
},

tooltipPosition: function() {
Expand Down
19 changes: 18 additions & 1 deletion test/specs/element.rectangle.tests.js
Original file line number Diff line number Diff line change
Expand Up @@ -132,7 +132,7 @@ describe('Rectangle element tests', function() {
});
});

it ('should get the correct area', function() {
it ('should get the correct vertical area', function() {
var rectangle = new Chart.elements.Rectangle({
_datasetIndex: 2,
_index: 1
Expand All @@ -149,6 +149,23 @@ describe('Rectangle element tests', function() {
expect(rectangle.getArea()).toEqual(60);
});

it ('should get the correct horizontal area', function() {
var rectangle = new Chart.elements.Rectangle({
_datasetIndex: 2,
_index: 1
});

// Attach a view object as if we were the controller
rectangle._view = {
base: 0,
height: 4,
x: 10,
y: 15
};

expect(rectangle.getArea()).toEqual(40);
});

it ('should get the center', function() {
var rectangle = new Chart.elements.Rectangle({
_datasetIndex: 2,
Expand Down

0 comments on commit 945d91a

Please sign in to comment.