From f63aaf1ad93cd69abfe862bd710fe0d377fb3b4b Mon Sep 17 00:00:00 2001 From: Akihiko Kusanagi Date: Thu, 4 Apr 2019 22:55:30 +0800 Subject: [PATCH 1/2] Use the appropriate time format for auto tick generation --- src/scales/scale.time.js | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/src/scales/scale.time.js b/src/scales/scale.time.js index eebacacbff6..dd202c70f20 100644 --- a/src/scales/scale.time.js +++ b/src/scales/scale.time.js @@ -774,9 +774,12 @@ module.exports = Scale.extend({ */ getLabelCapacity: function(exampleTime) { var me = this; + var timeOpts = me.options.time; + var displayFormats = timeOpts.displayFormats; // pick the longest format (milliseconds) for guestimation - var format = me.options.time.displayFormats.millisecond; + var format = displayFormats[timeOpts.unit] || displayFormats.millisecond; + var exampleLabel = me.tickFormatFunction(exampleTime, 0, [], format); var tickLabelWidth = me.getLabelWidth(exampleLabel); var innerWidth = me.isHorizontal() ? me.width : me.height; From 49a791ef46a5ea1d89903ac81b633d88bfd9f630 Mon Sep 17 00:00:00 2001 From: Akihiko Kusanagi Date: Wed, 24 Apr 2019 16:58:57 +0800 Subject: [PATCH 2/2] Add a unit test --- test/specs/scale.time.tests.js | 22 +++++++++++++++++++++- 1 file changed, 21 insertions(+), 1 deletion(-) diff --git a/test/specs/scale.time.tests.js b/test/specs/scale.time.tests.js index d67b60cbb12..77b3cbf2b66 100755 --- a/test/specs/scale.time.tests.js +++ b/test/specs/scale.time.tests.js @@ -298,7 +298,7 @@ describe('Time scale tests', function() { expect(ticks).toEqual(['8PM', '9PM', '10PM', '11PM', '12AM', '1AM', '2AM', '3AM', '4AM', '5AM', '6AM', '7AM', '8AM', '9AM', '10AM', '11AM', '12PM', '1PM', '2PM', '3PM', '4PM', '5PM', '6PM', '7PM', '8PM', '9PM']); }); - it('build ticks honoring the minUnit', function() { + it('should build ticks honoring the minUnit', function() { var mockData = { labels: ['2015-01-01T20:00:00', '2015-01-02T21:00:00'], // days }; @@ -316,6 +316,26 @@ describe('Time scale tests', function() { expect(ticks).toEqual(['Jan 1', 'Jan 2', 'Jan 3']); }); + it('should build ticks based on the appropriate label capacity', function() { + var mockData = { + labels: [ + '2012-01-01', '2013-01-01', '2014-01-01', '2015-01-01', + '2016-01-01', '2017-01-01', '2018-01-01', '2019-01-01' + ] + }; + + var config = Chart.helpers.mergeIf({ + time: { + unit: 'year' + } + }, Chart.scaleService.getScaleDefaults('time')); + + var scale = createScale(mockData, config); + var ticks = getTicksLabels(scale); + + expect(ticks).toEqual(['2012', '2013', '2014', '2015', '2016', '2017', '2018', '2019']); + }); + it('should build ticks using the config diff', function() { var mockData = { labels: ['2015-01-01T20:00:00', '2015-02-02T21:00:00', '2015-02-21T01:00:00'], // days