Skip to content

Commit

Permalink
fix(NumberInput): disable rounding decimal to integer without passed …
Browse files Browse the repository at this point in the history
…step (#2037)
  • Loading branch information
DaryaLari authored Jan 14, 2025
1 parent 970d10a commit 3a6a6bc
Show file tree
Hide file tree
Showing 3 changed files with 16 additions and 4 deletions.
4 changes: 2 additions & 2 deletions src/components/lab/NumberInput/NumberInput.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -89,7 +89,7 @@ export const NumberInput = React.forwardRef<HTMLSpanElement, NumberInputProps>(f
min: externalMin,
max: externalMax,
shiftMultiplier: externalShiftMultiplier = 10,
step: externalStep = 1,
step: externalStep,
size = 'm',
view = 'normal',
disabled,
Expand Down Expand Up @@ -136,7 +136,7 @@ export const NumberInput = React.forwardRef<HTMLSpanElement, NumberInputProps>(f
});
}, [value]);

const clamp = true;
const clamp = !(allowDecimal && !externalStep);

const safeValue = value ?? 0;

Expand Down
12 changes: 12 additions & 0 deletions src/components/lab/NumberInput/__tests__/NumberInput.test.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -223,6 +223,18 @@ describe('NumberInput input', () => {

expect(handleUpdate).toHaveBeenLastCalledWith(6);
});
it('does not clamp decimal without defined step on blur', async () => {
const handleUpdate = jest.fn();
render(<NumberInput value={7.123} allowDecimal onUpdate={handleUpdate} />);
const input = getInput();

act(() => {
input.focus();
input.blur();
});

expect(getInput()).toHaveValue('7.123');
});
it('swaps min/max if max < min', async () => {
const handleUpdate = jest.fn();
render(<NumberInput min={1000} max={-1} value={100000000} onUpdate={handleUpdate} />);
Expand Down
4 changes: 2 additions & 2 deletions src/components/lab/NumberInput/utils.ts
Original file line number Diff line number Diff line change
Expand Up @@ -59,7 +59,7 @@ function roundIfNecessary(value: number, allowDecimal: boolean) {
interface VariablesProps {
min: number | undefined;
max: number | undefined;
step: number;
step: number | undefined;
shiftMultiplier: number;
value: number | null | undefined;
defaultValue: number | null | undefined;
Expand All @@ -76,7 +76,7 @@ export function getInternalState(props: VariablesProps): {
const {
min: externalMin,
max: externalMax,
step: externalStep,
step: externalStep = 1,
shiftMultiplier: externalShiftMultiplier,
value: externalValue,
allowDecimal,
Expand Down

0 comments on commit 3a6a6bc

Please sign in to comment.