From a65443adb636d525b6649dd23af1a76fb1590c08 Mon Sep 17 00:00:00 2001 From: Jonah <47046556+jwbonner@users.noreply.github.com> Date: Thu, 26 Dec 2024 22:35:47 -0500 Subject: [PATCH] Improve behavior of histogram step input Handle step down between orders of magnitude and properly enforce max bin count --- src/hub/controllers/StatisticsController.ts | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/src/hub/controllers/StatisticsController.ts b/src/hub/controllers/StatisticsController.ts index c90f9150..df3f9882 100644 --- a/src/hub/controllers/StatisticsController.ts +++ b/src/hub/controllers/StatisticsController.ts @@ -42,9 +42,9 @@ export default class StatisticsController implements TabController { [this.TIME_RANGE, this.RANGE_MIN, this.RANGE_MAX, this.STEP_SIZE].forEach((input) => input.addEventListener("change", () => (this.shouldUpdate = true)) ); - this.STEP_SIZE.addEventListener("change", () => { - this.updateHistogramInputs(); - }); + [this.RANGE_MIN, this.RANGE_MAX, this.STEP_SIZE].forEach((input) => + input.addEventListener("change", () => this.updateHistogramInputs()) + ); // Set initial values for histogram inputs this.RANGE_MIN.value = "0"; @@ -56,11 +56,11 @@ export default class StatisticsController implements TabController { /** Updates the step size for each histogram input. */ private updateHistogramInputs() { if (Number(this.STEP_SIZE.value) <= 0) { - this.STEP_SIZE.value = cleanFloat(Number(this.STEP_SIZE.step)).toString(); + this.STEP_SIZE.value = cleanFloat(Number(this.STEP_SIZE.step) * 0.9).toString(); } let range = Math.abs(Number(this.RANGE_MAX.value) - Number(this.RANGE_MIN.value)); if (range / Number(this.STEP_SIZE.value) > this.MAX_BINS) { - this.STEP_SIZE.value = cleanFloat(Math.ceil(range / this.MAX_BINS)).toString(); + this.STEP_SIZE.value = cleanFloat(range / this.MAX_BINS).toString(); } let step = Math.pow(10, Math.floor(Math.log10(Number(this.STEP_SIZE.value)))); this.STEP_SIZE.step = step.toString();