Skip to content

Description

Field.Select is a component for selecting between options using a dropdown or similar user experiences.

Demos

Dropdown variant (default)

Empty

<Field.Selection
onFocus={(value) => console.log('onFocus', value)}
onBlur={(value) => console.log('onBlur', value)}
onChange={(value) => console.log('onChange', value)}
>
<Field.Option value="foo" title="Foo!" />
<Field.Option value="bar" title="Baar!" />
</Field.Selection>

Placeholder

<Field.Selection
placeholder="Select something...."
onChange={(value) => console.log('onChange', value)}
>
<Field.Option value="foo" title="Foo!" />
<Field.Option value="bar" title="Baar!" />
</Field.Selection>

Label

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

Option selected

<Field.Selection
value="bar"
onChange={(value) => console.log('onChange', value)}
>
<Field.Option value="foo" title="Foo!" />
<Field.Option value="bar" title="Baar!" />
</Field.Selection>

Label and option selected

<Field.Selection
value="bar"
label="Label text"
onChange={(value) => console.log('onChange', value)}
>
<Field.Option value="foo" title="Foo!" />
<Field.Option value="bar" title="Baar!" />
</Field.Selection>

With clear Button

Clear button might in the future be an icon like in <Input>, but until that is available in <Dropdown>, it is done using an empty option at the top of the selection list.

VALUE: bar
const Example = () => {
const [value, setValue] = React.useState('bar')
const handleChange = React.useCallback(
(value) => {
console.log('onChange', value)
setValue(value)
},
[setValue],
)
return (
<>
<Field.Selection
value={value}
label="Label text"
onChange={handleChange}
clear
>
<Field.Option value="foo" title="Foo!" />
<Field.Option value="bar" title="Baar!" />
</Field.Selection>
<pre>VALUE: {value === undefined ? <em>undefined</em> : value}</pre>
</>
)
}
render(<Example />)

With help

<Field.Selection
value="bar"
label="Label text"
help={{
title: 'Help is available',
contents:
'Somewhere along the way, we must learn that there is nothing greater than to do something for others.',
}}
onChange={(value) => console.log('onChange', value)}
>
<Field.Option value="foo" title="Foo!" />
<Field.Option value="bar" title="Baar!" />
</Field.Selection>

Horizontal layout

<Field.Selection
value="bar"
label="Label text"
layout="horizontal"
onChange={(value) => console.log('onChange', value)}
>
<Field.Option value="foo" title="Foo!" />
<Field.Option value="bar" title="Baar!" />
</Field.Selection>

Widths

<Field.Selection
label="Default width (property omitted)"
value="bar"
onChange={(value) => console.log('onChange', value)}
>
<Field.Option value="foo" title="Foo!" />
<Field.Option value="bar" title="Baar!" />
</Field.Selection>
<Field.Selection
label="Small"
value="bar"
width="small"
onChange={(value) => console.log('onChange', value)}
>
<Field.Option value="foo" title="Foo!" />
<Field.Option value="bar" title="Baar!" />
</Field.Selection>
<Field.Selection
label="Medium"
value="bar"
width="medium"
onChange={(value) => console.log('onChange', value)}
>
<Field.Option value="foo" title="Foo!" />
<Field.Option value="bar" title="Baar!" />
</Field.Selection>
<Field.Selection
label="Large"
value="bar"
width="large"
onChange={(value) => console.log('onChange', value)}
>
<Field.Option value="foo" title="Foo!" />
<Field.Option value="bar" title="Baar!" />
</Field.Selection>
<Field.Selection
label="Stretch"
value="bar"
width="stretch"
onChange={(value) => console.log('onChange', value)}
>
<Field.Option value="foo" title="Foo!" />
<Field.Option value="bar" title="Baar!" />
</Field.Selection>

Disabled

<Field.Selection
value="bar"
label="Label text"
onChange={(value) => console.log('onChange', value)}
disabled
>
<Field.Option value="foo" title="Foo!" />
<Field.Option value="bar" title="Baar!" />
</Field.Selection>

Error

This is what is wrong...
<Field.Selection
value="bar"
label="Label text"
onChange={(value) => console.log('onChange', value)}
error={new FormError('This is what is wrong...')}
>
<Field.Option value="foo" title="Foo!" />
<Field.Option value="bar" title="Baar!" />
</Field.Selection>

High number of options

<Field.Selection
value="option-15"
label="Label text"
onChange={(value) => console.log('onChange', value)}
>
<Field.Option value="option-1" title="One" />
<Field.Option value="option-2" title="Two" />
<Field.Option value="option-3" title="Three" />
<Field.Option value="option-4" title="Four" />
<Field.Option value="option-5" title="Five" />
<Field.Option value="option-6" title="Six" />
<Field.Option value="option-7" title="Seven" />
<Field.Option value="option-8" title="Eight" />
<Field.Option value="option-9" title="Nine" />
<Field.Option value="option-10" title="Ten" />
<Field.Option value="option-11" title="Eleven" />
<Field.Option value="option-12" title="Twelve" />
<Field.Option value="option-13" title="Thirteen" />
<Field.Option value="option-14" title="Fourteen" />
<Field.Option value="option-15" title="Fifteen" />
<Field.Option value="option-16" title="Sixteen" />
<Field.Option value="option-17" title="Seventeen" />
<Field.Option value="option-18" title="Eighteen" />
<Field.Option value="option-19" title="Nineteen" />
<Field.Option value="option-20" title="Twenty" />
<Field.Option value="option-21" title="Twentyone" />
<Field.Option value="option-22" title="Twentytwo" />
<Field.Option value="option-23" title="Twentythree" />
<Field.Option value="option-24" title="Twentyfour" />
<Field.Option value="option-25" title="Twentyfive" />
</Field.Selection>

Validation - Required

<Field.Selection
value="foo"
label="Label text"
onChange={(value) => console.log('onChange', value)}
onFocus={(value) => console.log('onFocus', value)}
onBlur={(value) => console.log('onBlur', value)}
required
clear
>
<Field.Option value="foo" title="Foo!" />
<Field.Option value="bar" title="Baar!" />
</Field.Selection>

Radio variant

Empty

<Field.Selection
variant="radio"
onChange={(value) => console.log('onChange', value)}
>
<Field.Option value="foo" title="Foo!" />
<Field.Option value="bar" title="Baar!" />
</Field.Selection>

Label

Label text
<Field.Selection
variant="radio"
label="Label text"
onChange={(value) => console.log('onChange', value)}
>
<Field.Option value="foo" title="Foo!" />
<Field.Option value="bar" title="Baar!" />
</Field.Selection>

Option selected

<Field.Selection
variant="radio"
value="bar"
onChange={(value) => console.log('onChange', value)}
>
<Field.Option value="foo" title="Foo!" />
<Field.Option value="bar" title="Baar!" />
</Field.Selection>

Horizontal layout

Label text
<Field.Selection
variant="radio"
label="Label text"
value="bar"
layout="horizontal"
onChange={(value) => console.log('onChange', value)}
>
<Field.Option value="foo" title="Foo!" />
<Field.Option value="bar" title="Baar!" />
</Field.Selection>

Horizontal options-layout

Label text
<Field.Selection
variant="radio"
label="Label text"
value="bar"
optionsLayout="horizontal"
onChange={(value) => console.log('onChange', value)}
>
<Field.Option value="foo" title="Foo!" />
<Field.Option value="bar" title="Baar!" />
</Field.Selection>

Horizontal layout and horizontal options-layout

Label text
<Field.Selection
variant="radio"
label="Label text"
value="bar"
layout="horizontal"
optionsLayout="horizontal"
onChange={(value) => console.log('onChange', value)}
>
<Field.Option value="foo" title="Foo!" />
<Field.Option value="bar" title="Baar!" />
</Field.Selection>

Disabled

Label text
<Field.Selection
variant="radio"
value="bar"
label="Label text"
onChange={(value) => console.log('onChange', value)}
disabled
>
<Field.Option value="foo" title="Foo!" />
<Field.Option value="bar" title="Baar!" />
</Field.Selection>

Error

Label text
<Field.Selection
variant="radio"
value="bar"
label="Label text"
onChange={(value) => console.log('onChange', value)}
error={new FormError('This is what is wrong...')}
>
<Field.Option value="foo" title="Foo!" />
<Field.Option value="bar" title="Baar!" />
</Field.Selection>

Buttons variant

Empty

<Field.Selection
variant="button"
onChange={(value) => console.log('onChange', value)}
>
<Field.Option value="foo" title="Foo!" />
<Field.Option value="bar" title="Baar!" />
</Field.Selection>

Label

<Field.Selection
variant="button"
label="Label text"
onChange={(value) => console.log('onChange', value)}
>
<Field.Option value="foo" title="Foo!" />
<Field.Option value="bar" title="Baar!" />
</Field.Selection>

Option selected

<Field.Selection
variant="button"
value="bar"
onChange={(value) => console.log('onChange', value)}
>
<Field.Option value="foo" title="Foo!" />
<Field.Option value="bar" title="Baar!" />
</Field.Selection>

Horizontal layout

<Field.Selection
variant="button"
label="Label text"
value="bar"
layout="horizontal"
onChange={(value) => console.log('onChange', value)}
>
<Field.Option value="foo" title="Foo!" />
<Field.Option value="bar" title="Baar!" />
</Field.Selection>

Disabled

<Field.Selection
variant="button"
value="bar"
label="Label text"
onChange={(value) => console.log('onChange', value)}
disabled
>
<Field.Option value="foo" title="Foo!" />
<Field.Option value="bar" title="Baar!" />
</Field.Selection>

Error

This is what is wrong...
<Field.Selection
variant="button"
value="bar"
label="Label text"
onChange={(value) => console.log('onChange', value)}
error={new FormError('This is what is wrong...')}
>
<Field.Option value="foo" title="Foo!" />
<Field.Option value="bar" title="Baar!" />
</Field.Selection>

Properties

Standard input component props

PropertyTypeDescription
data-testidstring(optional) Test ID
classNamestring(optional) Outer DOM element class name
valuenumber | string(optional) Source data value for the input
layoutstring(optional) Layout for the label and input. Can be horizontal or vertical
labelstring(optional) Field label to show above / before the input feature
labelDescriptionstring(optional) A more discreet text displayed beside the label (i.e for "(optional)")
labelSecondarystring(optional) Secondary information displayed at the end of the label line (i.e character counter)
placeholderstring(optional) Text showing in place of the value if no value is given
pathstring(optional) JSON Pointer for where the data for this input is located in the source dataset (when using DataContext)
infoError or string(optional) Info message shown below / after the input
warningError or string(optional) Warning message shown below / after the input
errorError(optional) Error message shown below / after the input
disabledboolean(optional) Set true to show the field but without the possibility of changing the value.
emptyValueany(optional) The value to use (in onChange events etc) when emptying the field. Makes it possible for instance to provide undefined instead of an empty string when clearing the content of a text input.
requiredboolean(optional) When set true, the input will give an error if the value cannot be empty.
schemaobject(optional) Custom JSON Schema for validating the value.
validateInitiallystring(optional) Set true to show validation based errors initially (from given value-prop or source data) before the user interacts with the field.
validateUnchangedstring(optional) Set true to show validation based errors when the field is touched (like focusing a field and blurring) without having changed the value. Since the user did not introduce a new error, this will apply when the value was initially invalid based on validation.
continuousValidationstring(optional) Set true to show validation based errors continuously while writing, not just when blurring the field.
errorMessagesobject(optional) Custom error messages for each type of error, overriding default messages.
validatorfunction(optional) Custom validator function that will be called for every change done by the user. Can be asynchronous or synchronous.
onBlurValidatorfunction(optional) Custom validator function that will be called when the user leaves the field (blurring a text input, closing a dropdown etc). Can be asynchronous or synchronous.
toInputfunction(optional) Derivate called when the received / active value is sent to the input. Can be used for casting, changing syntax etc.
fromInputfunction(optional) Derivate called when changes is made by the user, to cast or change syntax back to the original (opposite of toInput).

Component-specific props

PropertyTypeDescription
variantstring(optional) Choice of UI feature. Can be: dropdown, radio or button.
optionsLayoutstring(optional) Layout for the list of options. Can be horizontal or vertical
widthstring or false(optional)small, medium or large for predefined standard widths, stretch for fill available width.
helpobject(optional) Provide a help button. Object consisting of title and contents
clearboolean(optional) True to have a clear-option to remove selected option as value
childrenReact.Node(optional) For providing Option components

Events

EventDescription
onChange(optional) Will be called on value changes made by the user, with the new value as argument.
onFocus(optional) Will be called when the component gets into focus. Like clicking inside a text input or opening a dropdown. Called with active value as argument.
onBlur(optional) Will be called when the component stop being in focus. Like when going to next field, or closing a dropdown. Called with active value as argument.