Dialog

A window overlaid on either the primary window or another dialog window, rendering the content underneath inert.
Access to Fuegokit npm packages, source code repositories, and some content is limited to Appfire staff. Log in with Slack to continue.

A dialog consists of a container element, title, and optional description. It is an overlay shown above other content in an application.

The Fuegokit React dialog primitive provides the behavior and accessibility implementation for a dialog component.

Import

import {Dialog} from '@fuegokit/react/experimental'

Additional styling guides and examples are coming soon. For now, explore the examples at Storybook.

Usage

<Dialog>
<Dialog.Trigger asChild>
<DialogButton>Edit profile</DialogButton>
</Dialog.Trigger>
<Dialog.Portal>
<Dialog.Overlay />
<Dialog.Content>
<Dialog.Title>Edit profile</Dialog.Title>
<Dialog.Description>Make changes to your profile here. Click save when you're done.</Dialog.Description>

Styling

To apply styles, use Fuegokit React's themeGet function to access Fuegokit Tokens directly.

const MyDialog = styled(Dialog)`
/* reset */
button,
fieldset,
input {
all: unset;
}
`
const MyDialogOverlay = styled(Dialog.Overlay)`

Props

Dialog

A window overlaid on either the primary window or another dialog window, rendering the content underneath inert.
NameTypeDefaultDescription
defaultOpen
boolean
-The open state of the dialog when it is initially rendered. Use when you do not need to control its open state.
open
boolean
-The controlled open state of the dialog. Must be used in conjunction with `onOpenChange`.
onOpenChange
(open: boolean) => void
-Event handler called when the open state of the dialog changes.
defaultOpen
boolean
trueThe open state of the dialog when it is initially rendered. Use when you do not need to control its open state.
modal
boolean
trueThe modality of the dialog. When set to `true`, interaction with outside elements will be disabled and only dialog content will be visible to screen readers.
children
React.ReactNode
trueChildren to render in the dialog

Dialog.Trigger

The button that opens the dialog.
NameTypeDefaultDescription
asChild
boolean
falseChange the default rendered element for the one passed as a child, merging their props and behavior.
Data attributes
Data attributeValues
[data-state]
'open' | 'closed'

Dialog.Portal

When used, portals your overlay and content parts into the `body`.
NameTypeDefaultDescription
forceMount
boolean
-Used to force mounting when more control is needed. Useful when controlling animation with React animation libraries. If used on this part, it will be inherited by `Dialog.Overlay` and `Dialog.Content`.
container
HTMLElement
document.bodySpecify a container element to portal the content into.

Dialog.Overlay

A layer that covers the inert portion of the view when the dialog is open.
NameTypeDefaultDescription
asChild
boolean
falseChange the default rendered element for the one passed as a child, merging their props and behavior.
forceMount
boolean
-Used to force mounting when more control is needed. Useful when controlling animation with React animation libraries. If used on this part, it will be inherited by `Dialog.Overlay` and `Dialog.Content`.
Data attributes
Data attributeValues
[data-state]
'open' | 'closed'

Dialog.Content

Contains content to be rendered in the open dialog.
NameTypeDefaultDescription
asChild
boolean
falseChange the default rendered element for the one passed as a child, merging their props and behavior.
forceMount
boolean
-Used to force mounting when more control is needed. Useful when controlling animation with React animation libraries. If used on this part, it will be inherited by `Dialog.Portal`.
Events
NameTypeDefaultDescription
onOpenAutoFocus
(event: Event) => void
-Event handler called when focus moves into the component after opening. It can be prevented by calling `event.preventDefault`.
onCloseAutoFocus
(event: Event) => void
-Event handler called when focus moves to the trigger after closing. It can be prevented by calling `event.preventDefault`.
onEscapeKeyDown
(event: Event) => void
-Event handler called when the escape key is down. It can be prevented by calling `event.preventDefault`.
onPointerDownOutside
(event: PointerDownOutsideEvent) => void
-Event handler called when a pointer event occurs outside the bounds of the component. It can be prevented by calling `event.preventDefault`.
onInteractOutside
(event: PointerDownOutsideEvent | FocusOutsideEvent) => void
-Event handler called when an interaction (pointer or focus event) happens outside the bounds of the component. It can be prevented by calling `event.preventDefault`.
Data attributes
Data attributeValues
[data-state]
'open' | 'closed'

Dialog.Close

The button that closes the dialog.
NameTypeDefaultDescription
asChild
boolean
falseChange the default rendered element for the one passed as a child, merging their props and behavior.

Dialog.Title

An optional accessible description to be announced when the dialog is opened. If you want to hide the title, wrap it inside a <VisuallyHidden> utility.
NameTypeDefaultDescription
asChild
boolean
falseChange the default rendered element for the one passed as a child, merging their props and behavior.

Dialog.Description

An optional accessible description to be announced when the dialog is opened. If you want to hide the description, wrap it inside a <VisuallyHidden> utility. If you want to remove the description entirely, remove this part and pass `aria-describedby={undefined}` to `Dialog.Content`.
NameTypeDefaultDescription
asChild
boolean
falseChange the default rendered element for the one passed as a child, merging their props and behavior.