Skip to content

Description

Field.Number is the base component for receiving user input where the target data is of type number.

There is a corresponding Value.Number component.

When to use and not to use

Field.Number only allows the user to enter numbers (negative and positive) and decimal numbers.

If a number has the type of number, and can not start with a zero, this field may be considered.

But for e.g. a customer number, you rather use Field.String.

Internally, it is used by e.g. Field.Currency.

Autocomplete and autofill

Check out the Field.String docs about autocomplete.

Demos

Empty

Code Editor
<Field.Number
  onFocus={(value) => console.log('onFocus', value)}
  onBlur={(value) => console.log('onBlur', value)}
  onChange={(value) => console.log('onChange', value)}
/>

Placeholder

Code Editor
<Field.Number
  placeholder="Enter a number"
  onChange={(value) => console.log('onChange', value)}
/>

Label

Code Editor
<Field.Number
  label="Label text"
  onChange={(value) => console.log('onChange', value)}
/>

Label and value

Code Editor
<Field.Number
  value={420000.25}
  label="Label text"
  onChange={(value) => console.log('onChange', value)}
/>

Right aligned

Code Editor
<Field.Number
  rightAligned
  value={420000.25}
  label="Label text"
  onChange={(value) => console.log('onChange', value)}
/>

With help

Code Editor
<Field.Number
  value={12345}
  label="Label text"
  help={{
    title: 'Help is available',
    contents:
      'Here is what a team can do for you. . . . It allows you to help others do their best.',
  }}
  onChange={(value) => console.log('onChange', value)}
/>

Horizontal layout

Code Editor
<Field.Number
  value={420000}
  label="Label text"
  layout="horizontal"
  onChange={(value) => console.log('onChange', value)}
/>

Widths

Code Editor
<Field.Number
  label="Default width (property omitted)"
  value={123}
  onChange={(value) => console.log('onChange', value)}
/>
<Field.Number
  label="Small"
  value={123}
  width="small"
  onChange={(value) => console.log('onChange', value)}
/>
<Field.Number
  label="Medium"
  value={123}
  width="medium"
  onChange={(value) => console.log('onChange', value)}
/>
<Field.Number
  label="Large"
  value={123}
  width="large"
  onChange={(value) => console.log('onChange', value)}
/>
<Field.Number
  label="Stretch"
  value={123}
  width="stretch"
  onChange={(value) => console.log('onChange', value)}
/>

Disabled

Code Editor
<Field.Number
  value={135}
  label="Label text"
  onChange={(value) => console.log('onChange', value)}
  disabled
/>

Info

Useful information (?)
Code Editor
<Field.Number
  value={135}
  label="Label text"
  onChange={(value) => console.log('onChange', value)}
  info="Useful information (?)"
/>

Warning

I'm warning you...
Code Editor
<Field.Number
  value={135}
  label="Label text"
  onChange={(value) => console.log('onChange', value)}
  warning={new FormError("I'm warning you...")}
/>

Error

This is what is wrong...
Code Editor
<Field.Number
  value={135}
  label="Label text"
  onChange={(value) => console.log('onChange', value)}
  error={new FormError('This is what is wrong...')}
/>

Validation - Required

Code Editor
<Field.Number
  value={123}
  label="Remove and blur field"
  onChange={(value) => console.log('onChange', value)}
  required
/>

Validation - Minimum

Code Editor
<Field.Number
  value={300}
  label="Enter a number below 250 and blur to trigger error"
  onChange={(value) => console.log('onChange', value)}
  minimum={250}
/>

Validation - Maximum and custom error message

Code Editor
<Field.Number
  value={200}
  label="Enter a number above 250 and blur to trigger error"
  onChange={(value) => console.log('onChange', value)}
  maximum={250}
  errorMessages={{
    maximum: "You can't enter a number THAR large.. Max 250!",
  }}
/>