Version 2025-07 is the last API version to support React-based UI components. Later versions use web components, native UI elements with built-in accessibility, better performance, and consistent styling with Shopify's design system. Check out the migration guide to upgrade your extension.
DateField
Use the DateField component to get a date input from a buyer.
Supported targets
- Checkout::Actions::Render
Before - Checkout::Cart
Line Details::Render After - Checkout::Cart
Lines::Render After - Checkout::Contact::Render
After - Checkout::Customer
Information::Render After - Checkout::Delivery
Address::Render Before - Checkout::Dynamic::Render
- Checkout::Pickup
Locations::Render After - Checkout::Pickup
Locations::Render Before - Checkout::Pickup
Points::Render After - Checkout::Pickup
Points::Render Before - Checkout::Reductions::Render
After - Checkout::Reductions::Render
Before - Checkout::Shipping
Method Details::Render After - Checkout::Shipping
Method Details::Render Expanded - Checkout::Shipping
Methods::Render After - Checkout::Shipping
Methods::Render Before - Checkout::Thank
You::Cart Line Details::Render After - Checkout::Thank
You::Cart Lines::Render After - Checkout::Thank
You::Customer Information::Render After - Checkout::Thank
You::Dynamic::Render - purchase.
checkout. actions. render-before - purchase.
checkout. block. render - purchase.
checkout. cart-line-item. render-after - purchase.
checkout. cart-line-list. render-after - purchase.
checkout. contact. render-after - purchase.
checkout. delivery-address. render-after - purchase.
checkout. delivery-address. render-before - purchase.
checkout. footer. render-after - purchase.
checkout. header. render-after - purchase.
checkout. payment-method-list. render-after - purchase.
checkout. payment-method-list. render-before - purchase.
checkout. pickup-location-list. render-after - purchase.
checkout. pickup-location-list. render-before - purchase.
checkout. pickup-location-option-item. render-after - purchase.
checkout. pickup-point-list. render-after - purchase.
checkout. pickup-point-list. render-before - purchase.
checkout. reductions. render-after - purchase.
checkout. reductions. render-before - purchase.
checkout. shipping-option-item. details. render - purchase.
checkout. shipping-option-item. render-after - purchase.
checkout. shipping-option-list. render-after - purchase.
checkout. shipping-option-list. render-before - purchase.
thank-you. announcement. render - purchase.
thank-you. block. render - purchase.
thank-you. cart-line-item. render-after - purchase.
thank-you. cart-line-list. render-after - purchase.
thank-you. customer-information. render-after - purchase.
thank-you. footer. render-after - purchase.
thank-you. header. render-after
Supported targets
- Checkout::Actions::Render
Before - Checkout::Cart
Line Details::Render After - Checkout::Cart
Lines::Render After - Checkout::Contact::Render
After - Checkout::Customer
Information::Render After - Checkout::Delivery
Address::Render Before - Checkout::Dynamic::Render
- Checkout::Pickup
Locations::Render After - Checkout::Pickup
Locations::Render Before - Checkout::Pickup
Points::Render After - Checkout::Pickup
Points::Render Before - Checkout::Reductions::Render
After - Checkout::Reductions::Render
Before - Checkout::Shipping
Method Details::Render After - Checkout::Shipping
Method Details::Render Expanded - Checkout::Shipping
Methods::Render After - Checkout::Shipping
Methods::Render Before - Checkout::Thank
You::Cart Line Details::Render After - Checkout::Thank
You::Cart Lines::Render After - Checkout::Thank
You::Customer Information::Render After - Checkout::Thank
You::Dynamic::Render - purchase.
checkout. actions. render-before - purchase.
checkout. block. render - purchase.
checkout. cart-line-item. render-after - purchase.
checkout. cart-line-list. render-after - purchase.
checkout. contact. render-after - purchase.
checkout. delivery-address. render-after - purchase.
checkout. delivery-address. render-before - purchase.
checkout. footer. render-after - purchase.
checkout. header. render-after - purchase.
checkout. payment-method-list. render-after - purchase.
checkout. payment-method-list. render-before - purchase.
checkout. pickup-location-list. render-after - purchase.
checkout. pickup-location-list. render-before - purchase.
checkout. pickup-location-option-item. render-after - purchase.
checkout. pickup-point-list. render-after - purchase.
checkout. pickup-point-list. render-before - purchase.
checkout. reductions. render-after - purchase.
checkout. reductions. render-before - purchase.
checkout. shipping-option-item. details. render - purchase.
checkout. shipping-option-item. render-after - purchase.
checkout. shipping-option-list. render-after - purchase.
checkout. shipping-option-list. render-before - purchase.
thank-you. announcement. render - purchase.
thank-you. block. render - purchase.
thank-you. cart-line-item. render-after - purchase.
thank-you. cart-line-list. render-after - purchase.
thank-you. customer-information. render-after - purchase.
thank-you. footer. render-after - purchase.
thank-you. header. render-after
- Anchor to labellabellabelstringstringrequiredrequired
The text displayed as the field label, which identifies the purpose of the field to users. This value is also used as the placeholder when the field is empty.
- Anchor to defaultYearMonthdefaultYearMonthdefaultYearMonthYearMonthYearMonth
Default uncontrolled year and month to display. Ignored when year/month navigation is controlled.
- Anchor to disableddisableddisabledDisabledDate[] | booleanDisabledDate[] | boolean
Disabled dates, days, and/or ranges, or the date picker. Unbound range disables all dates either from
startdate or toenddate.truedisables the date picker.- Anchor to errorerrorerrorstringstring
An error message displayed below the field to indicate validation problems. When set, the field is styled with error indicators.
- Anchor to idididstringstring
A unique identifier for the field. When no
idis set, a globally unique value will be used instead.- Anchor to namenamenamestringstring
An identifier for the field that is unique within the nearest containing
Formcomponent.- Anchor to onBluronBluronBlur() => void() => void
A callback fired when the text field loses focus.
- Anchor to onChangeonChangeonChange(value: string) => void(value: string) => void
A callback fired when the user has finished editing the field, such as when they blur the field. 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. Text fields are “partially controlled” components, which means that while the user edits the field, its state is controlled by the component. Once the user has signalled that they have finished editing the field (typically, by blurring the field),is called if the input actually changed from the most recentvalueproperty. At that point, you are expected to store this “committed value” in state, and reflect it in the text field’svalueproperty.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 thevalueon 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 user 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 thevalue.This callback is called with the current value of the field. If the value of a field is the same as the current
valueprop provided to the field, thecallback will not be run.- Anchor to onFocusonFocusonFocus() => void() => void
A callback fired when the text field receives focus.
- Anchor to onInputonInputonInput(value: string) => void(value: string) => void
A callback fired when the user makes any changes in the field, such as typing a character. As noted in the documentation for
, you must not use this to updatestate— use thecallback for that purpose. Use theprop when you need to do something as soon as the user 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 value of the field.
- Anchor to onInvalidonInvalidonInvalid() => void() => void
A callback fired when the date field contains an invalid or disabled date after the user finishes editing. This callback is invoked when the date typed is invalid or disabled.
Dates that don’t exist or have formatting errors are considered invalid. Some examples of invalid dates are:
- 2021-02-31: February doesn’t have 31 days
- 2021-02-00: The day can’t be 00
Dates and ranges specified in the
disabledproperty are considered disabled dates. If thedisabledproperty is2021-06-14, and the user types2021-06-14, this callback will be called as this date is disabled.Note that this will be called only when the user finishes editing the date, after the
callback. The field is not validated on every change to the input. Once the user has signalled that they have finished editing the field (typically, by blurring the field), the field gets validated and the callback is run if the value is invalid.- Anchor to onYearMonthChangeonYearMonthChangeonYearMonthChange(yearMonth: { year: number; month: number; }) => void(yearMonth: { year: number; month: number; }) => void
A callback fired when the displayed year and month change. This callback is called with an object indicating the year/month the UI should change to. When year/month navigation is controlled you must store these values in state and reflect it back in the
prop.- Anchor to readonlyreadonlyreadonlybooleanboolean
Whether the field is read-only and can't be edited. Read-only fields remain focusable and their content is announced by screen readers.
- Anchor to valuevaluevalueTT
The current value for the field. If omitted, the field will be empty. You should update this value in response to the
callback.- Anchor to yearMonthyearMonthyearMonthYearMonthYearMonth
Controlled year and month to display. Use in combination with
. Makes year/month navigation controlled.
YearMonth
{year: number; month: number} | YearMonthStringYearMonthString
A year/month string using the simplified ISO 8601 format (`YYYY-MM`)
stringDisabledDate
DateString | DateRange | DayStringDateString
stringDateRange
- end
Last day (inclusive) of the selected range
DateString - start
First day (inclusive) of the selected range
DateString
DayString
keyof typeof DayDay
- Sunday
0 - Monday
1 - Tuesday
2 - Wednesday
3 - Thursday
4 - Friday
5 - Saturday
6
Anchor to ExamplesExamples
Anchor to Basic DateFieldBasic Date Field
Basic DateField

Basic DateField
React
import {
reactExtension,
DateField,
} from '@shopify/ui-extensions-react/checkout';
export default reactExtension(
'purchase.checkout.block.render',
() => <Extension />,
);
function Extension() {
return <DateField label="Select a date" />;
}JS
import {extension, DateField} from '@shopify/ui-extensions/checkout';
export default extension('purchase.checkout.block.render', (root) => {
const datefield = root.createComponent(DateField, {
label: 'Select a date',
});
root.appendChild(datefield);
});Anchor to Best practicesBest practices
- Set meaningful defaults: Pre-fill when you already know a sensible date to reduce manual entry.
- Restrict invalid dates: Use the
disabledprop with dates, ranges, or day rules to prevent buyers from choosing unavailable dates. - Pair with DatePicker: For selection that benefits from calendar context, use the DatePicker component alongside or instead of the DateField component.
Anchor to LimitationsLimitations
- Date values use
YYYY-MM-DDformat. Locale-specific formats aren't supported for the value buyers enter. - Unavailable dates are configured through the
disabledprop. See the API reference for supported shapes.