From 51ad0521dd3dcc3a898a6f92d13ea16cb3feefbc Mon Sep 17 00:00:00 2001 From: Jukka Kurkela Date: Sat, 15 Dec 2018 00:11:18 +0200 Subject: [PATCH 1/3] allow modifying ticks in afterBuildTickshttps://codepen.io/kurkle/pen/EGKWgM?editors=0010 --- docs/axes/README.md | 2 +- src/core/core.scale.js | 14 +++-- test/specs/core.scale.tests.js | 95 ++++++++++++++++++++++++++++++++++ 3 files changed, 107 insertions(+), 4 deletions(-) diff --git a/docs/axes/README.md b/docs/axes/README.md index 90b2525e79e..3eb5592147f 100644 --- a/docs/axes/README.md +++ b/docs/axes/README.md @@ -31,7 +31,7 @@ There are a number of config callbacks that can be used to change parameters in | `beforeDataLimits` | `axis` | Callback that runs before data limits are determined. | `afterDataLimits` | `axis` | Callback that runs after data limits are determined. | `beforeBuildTicks` | `axis` | Callback that runs before ticks are created. -| `afterBuildTicks` | `axis` | Callback that runs after ticks are created. Useful for filtering ticks. +| `afterBuildTicks` | `axis`, `ticks` | Callback that runs after ticks are created. Useful for filtering ticks (*Should return the filtered ticks*). | `beforeTickToLabelConversion` | `axis` | Callback that runs before ticks are converted into strings. | `afterTickToLabelConversion` | `axis` | Callback that runs after ticks are converted into strings. | `beforeCalculateTickRotation` | `axis` | Callback that runs before tick rotation is determined. diff --git a/src/core/core.scale.js b/src/core/core.scale.js index 690491fbc60..4718b2226d6 100644 --- a/src/core/core.scale.js +++ b/src/core/core.scale.js @@ -193,7 +193,8 @@ module.exports = Element.extend({ // we still support no return (`this.ticks` internally set by calling this method). ticks = me.buildTicks() || []; - me.afterBuildTicks(); + // Allow modification of ticks in callback. + ticks = me.afterBuildTicks(ticks) || ticks; me.beforeTickToLabelConversion(); @@ -287,8 +288,15 @@ module.exports = Element.extend({ helpers.callback(this.options.beforeBuildTicks, [this]); }, buildTicks: helpers.noop, - afterBuildTicks: function() { - helpers.callback(this.options.afterBuildTicks, [this]); + afterBuildTicks: function(ticks) { + var me = this; + // ticks is empty for old axis implementations here + if (ticks.length) { + return helpers.callback(me.options.afterBuildTicks, [me, ticks]); + } + // Support old implementatios (that modified `this.ticks` directly in buildTicks) + me.ticks = helpers.callback(me.options.afterBuildTicks, [me, me.ticks]) || me.ticks; + return ticks; }, beforeTickToLabelConversion: function() { diff --git a/test/specs/core.scale.tests.js b/test/specs/core.scale.tests.js index 3cbd0cbe6d0..130232caa1b 100644 --- a/test/specs/core.scale.tests.js +++ b/test/specs/core.scale.tests.js @@ -341,4 +341,99 @@ describe('Core.scale', function() { }); }); }); + + describe('afterBuildTicks', function() { + it('should allow filtering of ticks', function() { + var labels = ['tick1', 'tick2', 'tick3', 'tick4', 'tick5']; + var chart = window.acquireChart({ + type: 'line', + options: { + scales: { + xAxes: [{ + id: 'x', + type: 'category', + labels: labels, + afterBuildTicks: function(axis, ticks) { + return ticks.slice(1); + } + }] + } + } + }); + + var scale = chart.scales.x; + expect(scale.ticks).toEqual(labels.slice(1)); + }); + + it('should allow filtering of ticks (for new implementation of buildTicks)', function() { + var chart = window.acquireChart({ + type: 'line', + data: { + labels: ['2016', '2017', '2018'] + }, + options: { + scales: { + xAxes: [{ + id: 'x', + type: 'time', + time: { + parser: 'YYYY' + }, + ticks: { + source: 'labels' + }, + afterBuildTicks: function(axis, ticks) { + return ticks.slice(1); + } + }] + } + } + }); + + var scale = chart.scales.x; + expect(scale.ticks.length).toEqual(2); + }); + + it('should allow no return value from callback', function() { + var labels = ['tick1', 'tick2', 'tick3', 'tick4', 'tick5']; + var chart = window.acquireChart({ + type: 'line', + options: { + scales: { + xAxes: [{ + id: 'x', + type: 'category', + labels: labels, + afterBuildTicks: function() { } + }] + } + } + }); + + var scale = chart.scales.x; + expect(scale.ticks).toEqual(labels); + }); + + it('should allow empty ticks', function() { + var labels = ['tick1', 'tick2', 'tick3', 'tick4', 'tick5']; + var chart = window.acquireChart({ + type: 'line', + options: { + scales: { + xAxes: [{ + id: 'x', + type: 'category', + labels: labels, + afterBuildTicks: function() { + return []; + } + }] + } + } + }); + + var scale = chart.scales.x; + expect(scale.ticks.length).toBe(0); + }); + }); }); From 3abbaff8775fd7ba5836632be2ffaeae20f06179 Mon Sep 17 00:00:00 2001 From: Jukka Kurkela Date: Thu, 10 Jan 2019 19:49:19 +0200 Subject: [PATCH 2/3] Vertify ticks is an array and update docs --- docs/axes/README.md | 2 +- src/core/core.scale.js | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/docs/axes/README.md b/docs/axes/README.md index 3eb5592147f..ba408409e0c 100644 --- a/docs/axes/README.md +++ b/docs/axes/README.md @@ -31,7 +31,7 @@ There are a number of config callbacks that can be used to change parameters in | `beforeDataLimits` | `axis` | Callback that runs before data limits are determined. | `afterDataLimits` | `axis` | Callback that runs after data limits are determined. | `beforeBuildTicks` | `axis` | Callback that runs before ticks are created. -| `afterBuildTicks` | `axis`, `ticks` | Callback that runs after ticks are created. Useful for filtering ticks (*Should return the filtered ticks*). +| `afterBuildTicks` | `axis`, `ticks` | Callback that runs after ticks are created. Useful for filtering ticks. Should return the filtered ticks. | `beforeTickToLabelConversion` | `axis` | Callback that runs before ticks are converted into strings. | `afterTickToLabelConversion` | `axis` | Callback that runs after ticks are converted into strings. | `beforeCalculateTickRotation` | `axis` | Callback that runs before tick rotation is determined. diff --git a/src/core/core.scale.js b/src/core/core.scale.js index 4718b2226d6..1f6cdf01872 100644 --- a/src/core/core.scale.js +++ b/src/core/core.scale.js @@ -291,7 +291,7 @@ module.exports = Element.extend({ afterBuildTicks: function(ticks) { var me = this; // ticks is empty for old axis implementations here - if (ticks.length) { + if (helpers.isArray(ticks) && ticks.length) { return helpers.callback(me.options.afterBuildTicks, [me, ticks]); } // Support old implementatios (that modified `this.ticks` directly in buildTicks) From 12fc5e260780102e587b3c1f6c365f4bd0f5694b Mon Sep 17 00:00:00 2001 From: Jukka Kurkela Date: Thu, 10 Jan 2019 20:29:20 +0200 Subject: [PATCH 3/3] fix typo --- src/core/core.scale.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/core/core.scale.js b/src/core/core.scale.js index 1f6cdf01872..ee69178b267 100644 --- a/src/core/core.scale.js +++ b/src/core/core.scale.js @@ -294,7 +294,7 @@ module.exports = Element.extend({ if (helpers.isArray(ticks) && ticks.length) { return helpers.callback(me.options.afterBuildTicks, [me, ticks]); } - // Support old implementatios (that modified `this.ticks` directly in buildTicks) + // Support old implementations (that modified `this.ticks` directly in buildTicks) me.ticks = helpers.callback(me.options.afterBuildTicks, [me, me.ticks]) || me.ticks; return ticks; },