From afe0d25dd30a3a51c9e92991edb5498dd7652d64 Mon Sep 17 00:00:00 2001 From: Alexandre Rousseau Date: Sat, 28 Sep 2024 21:16:17 +0200 Subject: [PATCH] fix(ui): support initial empty value for slider When importing a slider, the initial value is `''`, which throws an error like `TypeError: "".toFixed is not a function`. I just handle this edge case. --- src/ui/src/components/core/base/BaseInputRange.vue | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/src/ui/src/components/core/base/BaseInputRange.vue b/src/ui/src/components/core/base/BaseInputRange.vue index 580080c37..9b7741bb5 100644 --- a/src/ui/src/components/core/base/BaseInputRange.vue +++ b/src/ui/src/components/core/base/BaseInputRange.vue @@ -65,8 +65,10 @@ const thumbRadius = 9; const thumb = ref(); const slider = ref(); -const precision = computed(() => Math.ceil(-Math.log10(props.step))); -const displayValue = computed(() => model.value.toFixed(precision.value)); +const precision = computed(() => String(props.step).split(".")[1]?.length ?? 0); +const displayValue = computed(() => + Number(model.value).toFixed(precision.value), +); const progress = computed(() => { if (typeof model.value !== "number") return 50; @@ -215,6 +217,8 @@ function handleMouseDown(initialEvent: MouseEvent) { justify-content: center; padding: 0 4px; transform: translateX(-50%); + + min-width: 12px; } .BaseInputRange__popover::after {