From 7b96d53622d84fa9e58ab9895ef1aaeae6a83e3e Mon Sep 17 00:00:00 2001 From: Aleksandr Telegin <99ff00@gmail.com> Date: Mon, 9 Mar 2020 14:06:25 +0000 Subject: [PATCH] Fix X-axis range update when data prop has changed --- src/charty.js | 30 +++++++++++++++++++----------- 1 file changed, 19 insertions(+), 11 deletions(-) diff --git a/src/charty.js b/src/charty.js index 1d8e0d2..2044b55 100644 --- a/src/charty.js +++ b/src/charty.js @@ -425,6 +425,15 @@ var Charty = (function () { X.min = AX[0] X.max = AX[AXL - 1] X.d = X.max - X.min + + if (V.globalStart !== X.min || V.globalEnd !== X.max) { + V.localStart = props.startX || 2 / 3 * X.d + X.min + V.localEnd = props.endX || X.max + V.globalStart = X.min + V.globalEnd = X.max + V.prevStepGridX = undefined + } + V.localMM = undefined V.globalMM = undefined @@ -452,13 +461,6 @@ var Charty = (function () { A['on' + i] = off ? 0 : 1 } - if (!restart) { - V.localStart = props.startX || 2 / 3 * X.d + X.min - V.localEnd = props.endX || X.max - V.globalStart = X.min - V.globalEnd = X.max - } - V.minBrushSize = X.d * UI.preview.minBrushSize / 100 V.seriesCount = AYL @@ -609,8 +611,7 @@ var Charty = (function () { if (TYPES.percentage) { localMin = 0 localMax = 100 - } - else if (TYPES.stacked || TYPES.bar || TYPES.percentage) { + } else if (TYPES.stacked || TYPES.bar || TYPES.percentage) { for (var i = 0, val; i < AYL; i++) { val = AY[i].max * A['on' + i] localMax = TYPES.stacked ? localMax + val : Math.max(localMax, val) @@ -682,8 +683,15 @@ var Charty = (function () { } function renderXText(prevStep, stepGridX, start, end, scaleX, y, p) { - var a = A['stepGridXA' + stepGridX] * UI.xAxis.textAlpha * p + var a = A['stepGridXA' + stepGridX] + if (a === undefined) { + a = 1 + } + + a = a * UI.xAxis.textAlpha * p + if (a === 0) return + start -= start % stepGridX ctx.fillStyle = UI.xAxis.textColor ctx.globalAlpha = a @@ -1247,7 +1255,7 @@ var Charty = (function () { for (var i = 0; i < AYL; i++) { var s = AY[i] prevMM = s[name + 'MM'] - if (s.min !== prevMM.min || s.d !== prevMM.d) { + if (prevMM && (s.min !== prevMM.min || s.d !== prevMM.d)) { animate(name + 'DY' + i, prevMM.d, s.d, ANIMATE_DURATION) animate(name + 'MinY' + i, prevMM.min, s.min, ANIMATE_DURATION) }