Skip to content

Commit

Permalink
Fix NumberInput widget not being reactive to changes to the unit (Gra…
Browse files Browse the repository at this point in the history
…phiteEditor#2080)

Svelte watch unit
  • Loading branch information
0HyperCube authored Oct 26, 2024
1 parent c27d8dc commit 9eeefaa
Showing 1 changed file with 6 additions and 6 deletions.
12 changes: 6 additions & 6 deletions frontend/src/components/widgets/inputs/NumberInput.svelte
Original file line number Diff line number Diff line change
Expand Up @@ -58,7 +58,7 @@
let self: FieldInput | undefined;
let inputRangeElement: HTMLInputElement | undefined;
let text = displayText(value);
let text = displayText(value, unit);
let editing = false;
// Stays in sync with a binding to the actual input range slider element.
let rangeSliderValue = value !== undefined ? value : 0;
Expand All @@ -78,7 +78,7 @@
// Track whether the Ctrl key is currently held down.
let ctrlKeyDown = false;
$: watchValue(value);
$: watchValue(value, unit);
$: sliderStepValue = isInteger ? (step === undefined ? 1 : step) : "any";
$: styles = {
Expand All @@ -104,7 +104,7 @@
// ===============================
// Called only when `value` is changed from outside this component.
function watchValue(value: number | undefined) {
function watchValue(value: number | undefined, unit: string) {
// Don't update if the slider is currently being dragged (we don't want the backend fighting with the user's drag)
if (rangeSliderClickDragState === "Dragging") return;
Expand All @@ -123,7 +123,7 @@
if (typeof min === "number") sanitized = Math.max(sanitized, min);
if (typeof max === "number") sanitized = Math.min(sanitized, max);
text = displayText(sanitized);
text = displayText(sanitized, unit);
}
// Called internally to update the value indirectly by informing the parent component of the new value,
Expand All @@ -143,7 +143,7 @@
rangeSliderValueAsRendered = newValueValidated;
}
text = displayText(newValueValidated);
text = displayText(newValueValidated, unit);
if (newValue !== undefined) dispatch("value", newValueValidated);
Expand All @@ -156,7 +156,7 @@
// ================
// Calculates the string to display when the field is not being edited.
function displayText(displayValue: number | undefined): string {
function displayText(displayValue: number | undefined, unit: string): string {
if (displayValue === undefined) return "-";
const roundingPower = 10 ** Math.max(displayDecimalPlaces, 0);
Expand Down

0 comments on commit 9eeefaa

Please sign in to comment.