Description
Field.PhoneNumber
is a wrapper component for the input of strings, with user experience tailored for phone number values.
import { Field } from '@dnb/eufemia/extensions/forms'render(<Field.PhoneNumber />)
There is a corresponding Value.PhoneNumber component.
Value
This component behaves as "one single component". Therefor it combines the country code and the number to a single string during an event callback.
Also, the value
property should be a string with the country code, separated from the main number by a space.
The component returns the emptyValue
when no number is set, which defaults to undefined
.
Default country code
The default country code is set to +47
.
Structure and format of phone numbers
Creating a list of all possible phone numbers would be impractical due to the vast number of combinations, especially considering the various country codes, area codes, and local numbers. Additionally, new numbers are constantly being allocated, and existing numbers may be reassigned over time.
Therefore, the structure and format is only used when +47
is selected.
Filter countries
You can filter out the countries based on many possibilities:
- by continent, such as
Europe
. - by regions, such as
Scandinavia
orNorthernNordic
countries. - by iso etc.
Here is the object for Norway:
{"i18n": {"en": "Norway","nb": "Norge"},"cdc": "47","iso": "NO","continent": "Europe","regions": "Scandinavia, NorthernNordic"}
Here is how you would filter countries:
<PhoneNumberfilterCountries={({ regions }) => regions?.includes('Scandinavia')}/>
Demos
Empty
<Field.PhoneNumber onFocus={(value) => console.log('onFocus', value)} onBlur={(value) => console.log('onBlur', value)} onChange={(...args) => console.log('onChange', ...args)} onCountryCodeChange={(countryCode) => console.log('onCountryCodeChange', countryCode) } onNumberChange={(phoneNumber) => console.log('onNumberChange', phoneNumber) } />
Placeholder
<Field.PhoneNumber placeholder="Call this number" onChange={(...args) => console.log('onChange', ...args)} />
Label
<Field.PhoneNumber label="Label text" onChange={(...args) => console.log('onChange', ...args)} />
Label and value
<Field.PhoneNumber label="Label text" value="+47 98765432" onChange={(...args) => console.log('onChange', ...args)} />
Show only Scandinavia countries
<Field.PhoneNumber label="Label text" onChange={(...args) => console.log('onChange', ...args)} filterCountries={({ regions }) => regions && regions.includes('Scandinavia') } />
With help
<Field.PhoneNumber onChange={(...args) => console.log('onChange', ...args)} help={{ title: 'Help is available', contents: 'Helping others, encouraging others, are often acts of being kind that have more meaning that you may realize.', }} />
Disabled
<Field.PhoneNumber value="+47 12345678" label="Label text" onChange={(...args) => console.log('onChange', ...args)} disabled />
Error
<Field.PhoneNumber value="007" label="Label text" onChange={(...args) => console.log('onChange', ...args)} error={new FormError('This is what is wrong...')} />
Validation - Required
<Field.PhoneNumber value="+47 888" label="Label text" onChange={(...args) => console.log('onChange', ...args)} required />