Phone Field
A PhoneField is an input field that merchants can type into optimized for phone numbers with a country code base auto-formatting. The country code is required for the initial render of the field but it can be overriden later by the user either by selecting a country in the country selection dropdown or by manually editing the country phone code directly in the text field.
Anchor to phonefieldpropsPhoneFieldProps
- Anchor to labellabelstringrequired
Content to use as the field label. This value is also used as the placeholder when the field is empty.
- Anchor to accessibilityDescriptionaccessibilityDescriptionstring
A detailed description for screen readers.
- Anchor to accessoryaccessorystring | RemoteFragment
Any content to render at the end of the text field. Commonly used to display an icon that opens a tooltip providing more information about the field.
- Anchor to autocompleteautocomplete| boolean
A hint as to the intended content of the field.
When set to
true
, this property indicates that the field should support autofill, but you do not have any more semantic information on the intended contents.When set to
false
, you are indicating that this field contains sensitive information, or contents that are never saved, like one-time codes.Alternatively, you can provide an
Autocomplete
object, which describes the specific data you would like to be entered into this field during autofill.- Anchor to disableddisabledboolean
Whether the field can be modified.
- Anchor to errorerrorstring
Indicate an error to the user. The field will be given a specific stylistic treatment to communicate problems that have to be resolved immediately.
- Anchor to iconicon| {source: ; position?: 'start' | 'end'}
An icon to render at the start or end of the field. It will render at the start by default.
- string
A unique identifier for the field. When no
id
is set, a globally unique value will be used instead.- Anchor to maxLengthmaxLengthnumber
Specifies the maximum number of characters allowed.
- Anchor to namenamestring
An identifier for the field that is unique within the nearest containing
Form
component.- Anchor to onBluronBlur() => void
Callback when focus is removed.
- Anchor to onChangeonChange(value: string) => void
Callback when the buyer has finished editing a field or pressed the country dropdown. Unlike
callbacks you may be familiar with from Polaris or other React component libraries, this callback is not run on every change to the input. Phone fields are “partially controlled” components, which means that while the buyer edits the field, its state is controlled by the component. Once the buyer has signalled that they have finished editing the field (typically, by blurring the field),
is called if the input actually changed from the most recent
value
property. At that point, you are expected to store this “committed value” in state, and reflect it in the phone field’svalue
property.This state management model is important given how UI Extensions are rendered. UI Extension components run on a separate thread from the UI, so they can’t respond to input synchronously. A pattern popularized by controlled React components is to have the component be the source of truth for the input
value
, and update thevalue
on every user input. The delay in responding to events from a UI extension is only a few milliseconds, but attempting to strictly store state with this delay can cause issues if a user types quickly, or if the buyer is using a lower-powered device. Having the UI thread take ownership for “in progress” input, and only synchronizing when the user is finished with a field, avoids this risk.It can still sometimes be useful to be notified when the user makes any input in the field. If you need this capability, you can use the
prop. However, never use that property to create tightly controlled state for the
value
.This callback is called with the current formatted value of the field. If the value of a field is the same as the current
value
prop provided to the field, thecallback will not be run.
- Anchor to onFocusonFocus() => void
Callback when input is focused.
- Anchor to onInputonInput(value: string) => void
Callback when the user makes any changes in the field including selecting a country in the dropdown. As noted in the documentation for
, you must not use this to update
state
— use thecallback for that purpose. Use the
prop when you need to do something as soon as the buyer makes a change, like clearing validation errors that apply to the field as soon as the user begins making the necessary adjustments.
This callback is called with the current formatted value.
- Anchor to readonlyreadonlyboolean
Whether the field is read-only.
- Anchor to requiredrequiredboolean
Whether the field needs a value. This requirement adds semantic value to the field, but it will not cause an error to appear automatically. If you want to present an error when this field is empty, you can do so with the
error
prop.- Anchor to valuevaluestring
The current value for the field. If omitted, the field will be empty. You should update this value in response to the
callback.
PhoneFieldProps
- accessibilityDescription
A detailed description for screen readers.
string
- accessory
Any content to render at the end of the text field. Commonly used to display an icon that opens a tooltip providing more information about the field.
string | RemoteFragment
- autocomplete
A hint as to the intended content of the field. When set to `true`, this property indicates that the field should support autofill, but you do not have any more semantic information on the intended contents. When set to `false`, you are indicating that this field contains sensitive information, or contents that are never saved, like one-time codes. Alternatively, you can provide an `Autocomplete` object, which describes the specific data you would like to be entered into this field during autofill.
Autocomplete | boolean
- disabled
Whether the field can be modified.
boolean
- error
Indicate an error to the user. The field will be given a specific stylistic treatment to communicate problems that have to be resolved immediately.
string
- icon
An icon to render at the start or end of the field. It will render at the start by default.
IconSource | {source: IconSource; position?: 'start' | 'end'}
- id
A unique identifier for the field. When no `id` is set, a globally unique value will be used instead.
string
- label
Content to use as the field label. This value is also used as the placeholder when the field is empty.
string
- maxLength
Specifies the maximum number of characters allowed.
number
- name
An identifier for the field that is unique within the nearest containing `Form` component.
string
- onBlur
Callback when focus is removed.
() => void
- onChange
Callback when the buyer has **finished editing** a field or pressed the country dropdown. Unlike `onChange` callbacks you may be familiar with from Polaris or other React component libraries, this callback is **not** run on every change to the input. Phone fields are “partially controlled” components, which means that while the buyer edits the field, its state is controlled by the component. Once the buyer has signalled that they have finished editing the field (typically, by blurring the field), `onChange` is called if the input actually changed from the most recent `value` property. At that point, you are expected to store this “committed value” in state, and reflect it in the phone field’s `value` property. This state management model is important given how UI Extensions are rendered. UI Extension components run on a separate thread from the UI, so they can’t respond to input synchronously. A pattern popularized by [controlled React components](https://reactjs.org/docs/forms.html#controlled-components) is to have the component be the source of truth for the input `value`, and update the `value` on every user input. The delay in responding to events from a UI extension is only a few milliseconds, but attempting to strictly store state with this delay can cause issues if a user types quickly, or if the buyer is using a lower-powered device. Having the UI thread take ownership for “in progress” input, and only synchronizing when the user is finished with a field, avoids this risk. It can still sometimes be useful to be notified when the user makes any input in the field. If you need this capability, you can use the `onInput` prop. However, never use that property to create tightly controlled state for the `value`. This callback is called with the current formatted value of the field. If the value of a field is the same as the current `value` prop provided to the field, the `onChange` callback will not be run.
(value: string) => void
- onFocus
Callback when input is focused.
() => void
- onInput
Callback when the user makes any changes in the field including selecting a country in the dropdown. As noted in the documentation for `onChange`, you must not use this to update `state` — use the `onChange` callback for that purpose. Use the `onInput` prop when you need to do something as soon as the buyer makes a change, like clearing validation errors that apply to the field as soon as the user begins making the necessary adjustments. This callback is called with the current formatted value.
(value: string) => void
- readonly
Whether the field is read-only.
boolean
- required
Whether the field needs a value. This requirement adds semantic value to the field, but it will not cause an error to appear automatically. If you want to present an error when this field is empty, you can do so with the `error` prop.
boolean
- value
The current value for the field. If omitted, the field will be empty. You should update this value in response to the `onChange` callback.
string
export interface PhoneFieldProps {
/**
* Any content to render at the end of the text field. Commonly used
* to display an icon that opens a tooltip providing more information about the field.
*/
accessory?: string | RemoteFragment;
/**
* A detailed description for screen readers.
*/
accessibilityDescription?: string;
/**
* A hint as to the intended content of the field.
*
* When set to `true`, this property indicates that the field should support
* autofill, but you do not have any more semantic information on the intended
* contents.
*
* When set to `false`, you are indicating that this field contains sensitive
* information, or contents that are never saved, like one-time codes.
*
* Alternatively, you can provide an `Autocomplete` object, which describes the
* specific data you would like to be entered into this field during autofill.
*/
autocomplete?: Autocomplete | boolean;
/**
* Whether the field can be modified.
*/
disabled?: boolean;
/**
* Indicate an error to the user. The field will be given a specific stylistic treatment
* to communicate problems that have to be resolved immediately.
*/
error?: string;
/**
* An icon to render at the start or end of the field.
* It will render at the start by default.
*/
icon?: IconSource | {source: IconSource; position?: 'start' | 'end'};
/**
* A unique identifier for the field. When no `id` is set,
* a globally unique value will be used instead.
*/
id?: string;
/**
* Content to use as the field label. This value is also used as the placeholder
* when the field is empty.
*/
label: string;
/**
* Specifies the maximum number of characters allowed.
*/
maxLength?: number;
/**
* An identifier for the field that is unique within the nearest
* containing `Form` component.
*/
name?: string;
/**
* Whether the field is read-only.
*/
readonly?: boolean;
/**
* Whether the field needs a value. This requirement adds semantic value
* to the field, but it will not cause an error to appear automatically.
* If you want to present an error when this field is empty, you can do
* so with the `error` prop.
*/
required?: boolean;
/**
* The current value for the field. If omitted, the field will be empty. You should
* update this value in response to the `onChange` callback.
*/
value?: string;
/**
* Callback when the buyer has **finished editing** a field or pressed the country dropdown.
* Unlike `onChange` callbacks you may be familiar with from Polaris or other React component libraries,
* this callback is **not** run on every change to the input. Phone fields are
* “partially controlled” components, which means that while the buyer edits the
* field, its state is controlled by the component. Once the buyer has signalled that
* they have finished editing the field (typically, by blurring the field), `onChange`
* is called if the input actually changed from the most recent `value` property. At
* that point, you are expected to store this “committed value” in state, and reflect
* it in the phone field’s `value` property.
*
* This state management model is important given how UI Extensions are rendered. UI Extension components
* run on a separate thread from the UI, so they can’t respond to input synchronously.
* A pattern popularized by [controlled React components](https://reactjs.org/docs/forms.html#controlled-components)
* is to have the component be the source of truth for the input `value`, and update
* the `value` on every user input. The delay in responding to events from a UI
* extension is only a few milliseconds, but attempting to strictly store state with
* this delay can cause issues if a user types quickly, or if the buyer is using a
* lower-powered device. Having the UI thread take ownership for “in progress” input,
* and only synchronizing when the user is finished with a field, avoids this risk.
*
* It can still sometimes be useful to be notified when the user makes any input in
* the field. If you need this capability, you can use the `onInput` prop. However,
* never use that property to create tightly controlled state for the `value`.
*
* This callback is called with the current formatted value of the field. If the value
* of a field is the same as the current `value` prop provided to the field,
* the `onChange` callback will not be run.
*/
onChange?(value: string): void;
/**
* Callback when the user makes any changes in the field including selecting a country
* in the dropdown. As noted in the documentation for `onChange`, you must not use
* this to update `state` — use the `onChange` callback for that purpose.
* Use the `onInput` prop when you need to do something as soon as the buyer makes a change,
* like clearing validation errors that apply to the field as soon as the user begins
* making the necessary adjustments.
*
* This callback is called with the current formatted value.
*/
onInput?(value: string): void;
/**
* Callback when input is focused.
*/
onFocus?(): void;
/**
* Callback when focus is removed.
*/
onBlur?(): void;
}
Autocomplete
A descriptor for selecting the data a field would like to receive during autocomplete. This attribute is modeled off of a limited set of the autocomplete values supported in browsers.
- field
The type of data that should be inserted into a field supporting autocomplete.
AutocompleteField
- group
The contact information “group” the autocomplete data should be sourced from.
AutocompleteGroup
export interface Autocomplete {
/**
* The contact information “group” the autocomplete data should be sourced from.
*/
group?: AutocompleteGroup;
/**
* The type of data that should be inserted into a field supporting autocomplete.
*/
field: AutocompleteField;
}
AutocompleteField
'name' | 'honorific-prefix' | 'given-name' | 'additional-name' | 'family-name' | 'honorific-suffix' | 'nickname' | 'username' | 'new-password' | 'current-password' | 'one-time-code' | 'organization-title' | 'organization' | 'street-address' | 'address-line1' | 'address-line2' | 'address-line3' | 'address-level4' | 'address-level3' | 'address-level2' | 'address-level1' | 'country' | 'country-name' | 'postal-code' | 'credit-card-name' | 'credit-card-given-name' | 'credit-card-additional-name' | 'credit-card-family-name' | 'credit-card-number' | 'credit-card-expiry' | 'credit-card-expiry-month' | 'credit-card-expiry-year' | 'credit-card-security-code' | 'credit-card-type' | 'transaction-currency' | 'transaction-amount' | 'language' | 'birthday' | 'birthday-day' | 'birthday-month' | 'birthday-year' | 'sex' | 'url' | 'photo' | 'telephone' | 'telephone-country-code' | 'telephone-national' | 'telephone-area-code' | 'telephone-local' | 'telephone-local-prefix' | 'telephone-local-suffix' | 'telephone-extension' | 'email' | 'instant-message' | 'home telephone' | 'home telephone-country-code' | 'home telephone-national' | 'home telephone-area-code' | 'home telephone-local' | 'home telephone-local-prefix' | 'home telephone-local-suffix' | 'home telephone-extension' | 'home email' | 'home instant-message' | 'work telephone' | 'work telephone-country-code' | 'work telephone-national' | 'work telephone-area-code' | 'work telephone-local' | 'work telephone-local-prefix' | 'work telephone-local-suffix' | 'work telephone-extension' | 'work email' | 'work instant-message' | 'mobile telephone' | 'mobile telephone-country-code' | 'mobile telephone-national' | 'mobile telephone-area-code' | 'mobile telephone-local' | 'mobile telephone-local-prefix' | 'mobile telephone-local-suffix' | 'mobile telephone-extension' | 'mobile email' | 'mobile instant-message' | 'fax telephone' | 'fax telephone-country-code' | 'fax telephone-national' | 'fax telephone-area-code' | 'fax telephone-local' | 'fax telephone-local-prefix' | 'fax telephone-local-suffix' | 'fax telephone-extension' | 'fax email' | 'fax instant-message' | 'pager telephone' | 'pager telephone-country-code' | 'pager telephone-national' | 'pager telephone-area-code' | 'pager telephone-local' | 'pager telephone-local-prefix' | 'pager telephone-local-suffix' | 'pager telephone-extension' | 'pager email' | 'pager instant-message'
AutocompleteGroup
'shipping' | 'billing'
IconSource
'arrowLeft' | 'arrowRight' | 'arrowUp' | 'arrowUpRight' | 'arrowDown' | 'bag' | 'bullet' | 'calendar' | 'camera' | 'caretDown' | 'cart' | 'cashDollar' | 'categories' | 'checkmark' | 'chevronLeft' | 'chevronRight' | 'chevronUp' | 'chevronDown' | 'clipboard' | 'clock' | 'close' | 'creditCard' | 'critical' | 'delete' | 'delivered' | 'delivery' | 'disabled' | 'discount' | 'email' | 'error' | 'errorFill' | 'external' | 'filter' | 'geolocation' | 'gift' | 'giftFill' | 'grid' | 'hamburger' | 'hollowCircle' | 'horizontalDots' | 'image' | 'info' | 'infoFill' | 'list' | 'lock' | 'magnify' | 'map' | 'marker' | 'minus' | 'mobile' | 'note' | 'orderBox' | 'pen' | 'plus' | 'profile' | 'question' | 'questionFill' | 'reorder' | 'reset' | 'return' | 'savings' | 'settings' | 'star' | 'starFill' | 'starHalf' | 'store' | 'success' | 'truck' | 'upload' | 'verticalDots' | 'warning' | 'warningFill'
Basic PhoneField
examples
Basic PhoneField
React
import { reactExtension, PhoneField, } from '@shopify/ui-extensions-react/checkout'; export default reactExtension( 'purchase.checkout.block.render', () => <Extension />, ); function Extension() { return ( <PhoneField label="Phone" value="1 (555) 555-5555" /> ); }
JS
import {extension, PhoneField} from '@shopify/ui-extensions/checkout'; export default extension('purchase.checkout.block.render', (root) => { const phoneField = root.createComponent(PhoneField, { label: 'Phone', value: '1 (555) 555-5555', }); root.appendChild(phoneField); });
Preview
