Usage
Modal dialog overlays on top of the main content of a page. It is used to focus the user's attention on a specific task and require interaction before they can continue browsing the site. Modal dialogs are disruptive and should be used sparingly and with caution.
Best practices
data:image/s3,"s3://crabby-images/4a6cd/4a6cddc50e78ea449761e2fc3c4c04aae713b9cf" alt=""
Open modal dialogs on user’s request i.e., clicking a button
data:image/s3,"s3://crabby-images/e3a50/e3a5028bcb380ef939db7556df4f1727aaac71a1" alt=""
Don’t disrupt user’s workflow with modal dialogs that appear without user action i.e., for marketing purposes.
data:image/s3,"s3://crabby-images/3f16f/3f16f6dc3c4a7853667a4027eafada38201ec23d" alt=""
Use a modal dialog to confirm decisions before proceeding
data:image/s3,"s3://crabby-images/34484/344848c43f92c75d0febdde2c1e21028db12425b" alt=""
Don't use a modal dialog if confirmation is not necessary, or to give feedback to the user. Use Toast or Banner instead.
data:image/s3,"s3://crabby-images/3ae24/3ae24b0408890c611a07d6c90f3b7560de91af64" alt=""
Don’t nest modals. If the situation requires a sequence of decisions, consider a different design pattern. Confirmation modals upon closing are an exception.
Anatomy
data:image/s3,"s3://crabby-images/27ffc/27ffcd49a61927d58fb13ef970765971b96e7dc8" alt=""
Header
Header provides a title that describes the context of the modal dialog and a close button in the top right corner.
data:image/s3,"s3://crabby-images/4352d/4352d6058c806f41ff152bcfee5f1a140baa6e4c" alt=""
Use a brief and clear title that explains the context of a modal dialog.
data:image/s3,"s3://crabby-images/6fdf9/6fdf92ba098a6bf1e6561d65e3f879b9b4cc9554" alt=""
Don’t use modal dialogs without a title.
Body
The body is used to display and provide the main functionality of the modal.
data:image/s3,"s3://crabby-images/e0f7a/e0f7ab9a7af7ceaa1b512fb1aea18499f2146603" alt=""
Avoid including navigation inside a modal dialog. A dialog should be used within a single context.
Footer
The footer provides a space for the main actions of the modal dialog.
data:image/s3,"s3://crabby-images/c31dc/c31dc1b8eba400c801ef01439fd26e1f0919a2fb" alt=""
Always align the actions to the right side, with the primary action always at the far right.
data:image/s3,"s3://crabby-images/3c7b1/3c7b10191496ca5baa3fbe011f7a05690d3ccd5c" alt=""
Don’t overcrowd the footer with too many actions. Include max of 2 actions to provide a clear hierarchy.
Sizes
Modal dialog offers two sizes: medium and large. Each size defines the width of the modal dialog.
Medium (default)
Medium is the default size for modal dialogs. It's ideal for seeking confirmation from the user and presenting simple forms or data.
Large
Choose large size when presenting complex forms or dense data. Do not use it for confirmation dialogs.
Positioning
Modal dialogs are always displayed in the center of the screen with a visible background that covers the content behind
them. Modal dialogs include safespace area between the modal and viewport equal to Space L
.
data:image/s3,"s3://crabby-images/c84c5/c84c5c0fd1cfec5085415c8b8cbc7b2264ec3336" alt=""
Dismissing modal dialogs
Modal dialogs provide multiple ways to exit them:
- X button in top right corner
- Mouse click outside of the modal dialog
- Browser back button
- Escape key using keyboard
- Custom close button (Optional)
data:image/s3,"s3://crabby-images/173ed/173ed81e829c33508061ee1872458ea1b0f18f34" alt=""
Consider providing a “Cancel” button for modal dialogs that require action from the user.
data:image/s3,"s3://crabby-images/2bc81/2bc81cf56fc2bc551375202dfefa85392eb3024c" alt=""
Don’t provide custom close button in the footer for passive modal dialogs.
data:image/s3,"s3://crabby-images/6f897/6f89756bca64027fb752b480064f893a23ce0af9" alt=""
Seek confirmation from the user if dismissing the modal dialog means losing progress.
Examples
Live Preview
Props
Name | Description | Type | Default | Values |
---|---|---|---|---|
close-on-click-outside | Decides if the modal can be closed by clicking outside of it. | boolean | ||
disable-teleport | Toggles teleporting of the modal to the target element | boolean | ||
v-model model-value v2, wc show v1 | State of the modal | boolean | ||
size | Size of the modal dialog | string | medium | medium | large |
target | Type string or an actual DOM node where you want render component | string|object | body | |
title Required | Title of the modal dialog displayed in the header | string | ||
translations | Provide values as translated strings. | object | {
closeBtnAriaLabel: 'Close'
} | Object with the following key: closeBtnAriaLabel |
prevent-close | When true, prevents the user from closing the modal through UI interactions (close button, ESC key, clicking outside, browser back button). Modal can only be closed programmatically through v-model. | boolean |
Slots
Name | Description |
---|---|
body | Slot for body content |
footer | Optional slot for footer content |
Events
Name | Description | Type |
---|---|---|
v-model update:modelValue v2, wc toggle v1 | Emitted on modal close | { "names": [ "Boolean" ] } |