Alert Dialog

A dialog that requires user response to proceed.

View as Markdown

Anatomy

Import the component and assemble its parts:

Anatomy

API reference

Root

Groups all parts of the alert dialog. Doesn’t render its own HTML element.

defaultOpen

boolean

false

Description

Whether the dialog is initially open.

To render a controlled dialog, use the open prop instead.

Type
boolean | undefined
Default

false

open

boolean

Name
Description

Whether the dialog is currently open.

Type
boolean | undefined
onOpenChange

function

Description

Event handler called when the dialog is opened or closed.

Type
| ((
    open: boolean,
    eventDetails: AlertDialog.Root.ChangeEventDetails,
  ) => void)
| undefined
actionsRef

RefObject<AlertDialog.Root.Actions>

Description

A ref to imperative actions.

  • unmount: When specified, the dialog will not be unmounted when closed. Instead, the unmount function must be called to unmount the dialog manually. Useful when the dialog's animation is controlled by an external library.
Type
| React.RefObject<AlertDialog.Root.Actions>
| undefined
defaultTriggerId

string | null

Description

ID of the trigger that the dialog is associated with. This is useful in conjunction with the defaultOpen prop to create an initially open dialog.

Type
string | null | undefined
handle

DialogHandle<Payload>

Name
Description

A handle to associate the popover with a trigger. If specified, allows external triggers to control the popover's open state. Can be created with the AlertDialog.createHandle() method.

Type
{} | undefined
onOpenChangeComplete

function

Description

Event handler called after any animations complete when the dialog is opened or closed.

Type
((open: boolean) => void) | undefined
triggerId

string | null

Description

ID of the trigger that the dialog is associated with. This is useful in conjuntion with the open prop to create a controlled dialog. There's no need to specify this prop when the popover is uncontrolled (i.e. when the open prop is not set).

Type
string | null | undefined
children

ReactNode | PayloadChildRenderFunction<Payload>

Description

The content of the dialog. This can be a regular React node or a render function that receives the payload of the active trigger.

Type
| React.ReactNode
| ((arg: { payload: Payload | undefined }) => ReactNode)

Trigger

A button that opens the alert dialog. Renders a <button> element.

handle

DialogHandle<Payload>

Name
Description

A handle to associate the trigger with a dialog. Can be created with the AlertDialog.createHandle() method.

Type
{} | undefined
nativeButton

boolean

true

Description

Whether the component renders a native <button> element when replacing it via the render prop. Set to false if the rendered element is not a button (e.g. <div>).

Type
boolean | undefined
Default

true

payload

Payload

Description

A payload to pass to the dialog when it is opened.

Type
Payload | undefined
style

React.CSSProperties | function

Name
Type
| React.CSSProperties
| ((
    state: AlertDialog.Trigger.State,
  ) => CSSProperties | undefined)
| undefined
id

string

Name
Description

ID of the trigger. In addition to being forwarded to the rendered element, it is also used to specify the active trigger for the dialogs in controlled mode (with the Dialog.Root triggerId prop).

Type
string | undefined
className

string | function

Description

CSS class applied to the element, or a function that returns a class based on the component’s state.

Type
| string
| ((state: AlertDialog.Trigger.State) => string | undefined)
render

ReactElement | function

Name
Description

Allows you to replace the component’s HTML element with a different tag, or compose it with another component.

Accepts a ReactElement or a function that returns the element to render.

Type
| ReactElement
| ((
    props: HTMLProps,
    state: AlertDialog.Trigger.State,
  ) => ReactElement)
data-popup-open

Present when the corresponding dialog is open.

data-disabled

Present when the trigger is disabled.

Portal

A portal element that moves the popup to a different part of the DOM. By default, the portal element is appended to <body>. Renders a <div> element.

style

React.CSSProperties | function

Name
Type
| React.CSSProperties
| ((
    state: AlertDialog.Portal.State,
  ) => CSSProperties | undefined)
| undefined
container

Union

Description

A parent element to render the portal element into.

Type
| HTMLElement
| ShadowRoot
| React.RefObject<HTMLElement | ShadowRoot | null>
| null
| undefined
className

string | function

Description

CSS class applied to the element, or a function that returns a class based on the component’s state.

Type
| string
| ((
    state: AlertDialog.Portal.State,
  ) => string | undefined)
keepMounted

boolean

false

Description

Whether to keep the portal mounted in the DOM while the popup is hidden.

Type
boolean | undefined
Default

false

render

ReactElement | function

Name
Description

Allows you to replace the component’s HTML element with a different tag, or compose it with another component.

Accepts a ReactElement or a function that returns the element to render.

Type
| ReactElement
| ((
    props: HTMLProps,
    state: AlertDialog.Portal.State,
  ) => ReactElement)

Backdrop

An overlay displayed beneath the popup. Renders a <div> element.

forceRender

boolean

false

Description

Whether the backdrop is forced to render even when nested.

Type
boolean | undefined
Default

false

style

React.CSSProperties | function

Name
Type
| React.CSSProperties
| ((
    state: AlertDialog.Backdrop.State,
  ) => CSSProperties | undefined)
| undefined
className

string | function

Description

CSS class applied to the element, or a function that returns a class based on the component’s state.

Type
| string
| ((
    state: AlertDialog.Backdrop.State,
  ) => string | undefined)
render

ReactElement | function

Name
Description

Allows you to replace the component’s HTML element with a different tag, or compose it with another component.

Accepts a ReactElement or a function that returns the element to render.

Type
| ReactElement
| ((
    props: HTMLProps,
    state: AlertDialog.Backdrop.State,
  ) => ReactElement)
data-open

Present when the dialog is open.

data-closed

Present when the dialog is closed.

data-starting-style

Present when the dialog is animating in.

data-ending-style

Present when the dialog is animating out.

A container for the alert dialog contents. Renders a <div> element.

style

React.CSSProperties | function

Name
Type
| React.CSSProperties
| ((
    state: AlertDialog.Popup.State,
  ) => CSSProperties | undefined)
| undefined
initialFocus

Union

Description

Determines the element to focus when the dialog is opened.

  • false: Do not move focus.
  • true: Move focus based on the default behavior (first tabbable element or popup).
  • RefObject: Move focus to the ref element.
  • function: Called with the interaction type (mouse, touch, pen, or keyboard). Return an element to focus, true to use the default behavior, or false/undefined to do nothing.
Type
| boolean
| React.RefObject<HTMLElement | null>
| ((
    openType: InteractionType,
  ) => boolean | void | HTMLElement | null)
| undefined
finalFocus

Union

Description

Determines the element to focus when the dialog is closed.

  • false: Do not move focus.
  • true: Move focus based on the default behavior (trigger or previously focused element).
  • RefObject: Move focus to the ref element.
  • function: Called with the interaction type (mouse, touch, pen, or keyboard). Return an element to focus, true to use the default behavior, or false/undefined to do nothing.
Type
| boolean
| React.RefObject<HTMLElement | null>
| ((
    closeType: InteractionType,
  ) => boolean | void | HTMLElement | null)
| undefined
className

string | function

Description

CSS class applied to the element, or a function that returns a class based on the component’s state.

Type
| string
| ((state: AlertDialog.Popup.State) => string | undefined)
render

ReactElement | function

Name
Description

Allows you to replace the component’s HTML element with a different tag, or compose it with another component.

Accepts a ReactElement or a function that returns the element to render.

Type
| ReactElement
| ((
    props: HTMLProps,
    state: AlertDialog.Popup.State,
  ) => ReactElement)
data-open

Present when the dialog is open.

data-closed

Present when the dialog is closed.

data-nested

Present when the dialog is nested within another dialog.

data-nested-dialog-open

Present when the dialog has other open dialogs nested within it.

data-starting-style

Present when the dialog is animating in.

data-ending-style

Present when the dialog is animating out.

--nested-dialogs

Indicates how many dialogs are nested within.

Title

A heading that labels the dialog. Renders an <h2> element.

style

React.CSSProperties | function

Name
Type
| React.CSSProperties
| ((
    state: AlertDialog.Title.State,
  ) => CSSProperties | undefined)
| undefined
className

string | function

Description

CSS class applied to the element, or a function that returns a class based on the component’s state.

Type
| string
| ((state: AlertDialog.Title.State) => string | undefined)
render

ReactElement | function

Name
Description

Allows you to replace the component’s HTML element with a different tag, or compose it with another component.

Accepts a ReactElement or a function that returns the element to render.

Type
| ReactElement
| ((
    props: HTMLProps,
    state: AlertDialog.Title.State,
  ) => ReactElement)

Description

A paragraph with additional information about the alert dialog. Renders a <p> element.

style

React.CSSProperties | function

Name
Type
| React.CSSProperties
| ((
    state: AlertDialog.Description.State,
  ) => CSSProperties | undefined)
| undefined
className

string | function

Description

CSS class applied to the element, or a function that returns a class based on the component’s state.

Type
| string
| ((
    state: AlertDialog.Description.State,
  ) => string | undefined)
render

ReactElement | function

Name
Description

Allows you to replace the component’s HTML element with a different tag, or compose it with another component.

Accepts a ReactElement or a function that returns the element to render.

Type
| ReactElement
| ((
    props: HTMLProps,
    state: AlertDialog.Description.State,
  ) => ReactElement)

Close

A button that closes the alert dialog. Renders a <button> element.

nativeButton

boolean

true

Description

Whether the component renders a native <button> element when replacing it via the render prop. Set to false if the rendered element is not a button (e.g. <div>).

Type
boolean | undefined
Default

true

style

React.CSSProperties | function

Name
Type
| React.CSSProperties
| ((
    state: AlertDialog.Close.State,
  ) => CSSProperties | undefined)
| undefined
className

string | function

Description

CSS class applied to the element, or a function that returns a class based on the component’s state.

Type
| string
| ((state: AlertDialog.Close.State) => string | undefined)
render

ReactElement | function

Name
Description

Allows you to replace the component’s HTML element with a different tag, or compose it with another component.

Accepts a ReactElement or a function that returns the element to render.

Type
| ReactElement
| ((
    props: HTMLProps,
    state: AlertDialog.Close.State,
  ) => ReactElement)
data-disabled

Present when the button is disabled.

Examples

Open from a menu

In order to open a dialog using a menu, control the dialog state and open it imperatively using the onClick handler on the menu item.

Connecting a dialog to a menu

Close confirmation

This example shows a nested confirmation dialog that opens if the text entered in the parent dialog is going to be discarded.

To implement this, both dialogs should be controlled. The confirmation dialog may be opened when onOpenChange callback of the parent dialog receives a request to close. This way, the confirmation is automatically shown when the user clicks the backdrop, presses the Esc key, or clicks a close button.

Use the [data-nested-dialog-open] selector and the var(--nested-dialogs) CSS variable to customize the styling of the parent dialog. Backdrops of the child dialogs won’t be rendered so that you can present the parent dialog in a clean way behind the one on top of it.

Detached triggers

An alert dialog can be controlled by a trigger located either inside or outside the <AlertDialog.Root> component. For simple, one-off interactions, place the <AlertDialog.Trigger> inside <AlertDialog.Root>, as shown in the example at the top of this page.

However, if defining the alert dialog’s content next to its trigger is not practical, you can use a detached trigger. This involves placing the <AlertDialog.Trigger> outside of <AlertDialog.Root> and linking them with a handle created by the AlertDialog.createHandle() function.

Detached triggers

Multiple triggers

A single alert dialog can be opened by multiple trigger elements. You can achieve this by using the same handle for several detached triggers, or by placing multiple <AlertDialog.Trigger> components inside a single <AlertDialog.Root>.

Multiple triggers within the Root part
Multiple detached triggers

The alert dialog can render different content depending on which trigger opened it. This is achieved by passing a payload to the <AlertDialog.Trigger> and using the function-as-a-child pattern in <AlertDialog.Root>.

The payload can be strongly typed by providing a type argument to the createHandle() function:

Detached triggers with payload

Controlled mode with multiple triggers

You can control the alert dialog’s open state externally using the open and onOpenChange props on <AlertDialog.Root>. This allows you to manage the alert dialog’s visibility based on your application’s state. When using multiple triggers, you have to manage which trigger is active with the triggerId prop on <AlertDialog.Root> and the id prop on each <AlertDialog.Trigger>.

Note that there is no separate onTriggerIdChange prop. Instead, the onOpenChange callback receives an additional argument, eventDetails, which contains the trigger element that initiated the state change.