モーダル
注意を必要とする、または追加情報を提供するカスタムコンテンツを持つダイアログを表示します。
インストール
npx nextui-cli@latest add modal
上記のコマンドは個別のインストール専用です。もし @nextui-org/react がグローバルにインストールされている場合は、このステップをスキップできます。
インポート
NextUI は、モーダル関連のコンポーネントを 5 つエクスポートします。
- Modal: モーダルを表示するためのメインコンポーネント。
- ModalContent: 他のモーダルコンポーネントのラッパー。
- ModalHeader: モーダルのヘッダー。
- ModalBody: モーダルの本体。
- ModalFooter: モーダルのフッター。
使い方
モーダルが開くと
- フォーカスはモーダル内に制限され、最初のタブ移動可能な要素に設定されます。
- モーダルダイアログの背後にあるコンテンツは非アクティブになり、ユーザーは操作できなくなります。
サイズ
非破棄可能
デフォルトでは、モーダルはオーバーレイをクリックするか、Escキーを押すことで閉じることができます。この動作を無効にするには、次のプロパティを設定します。
isDismissableプロパティをfalseに設定すると、オーバーレイをクリックしてもモーダルが閉じられなくなります。isKeyboardDismissDisabledプロパティをtrueに設定すると、Esc キーを押してもモーダルが閉じられなくなります。
モーダルの配置
デフォルトでは、モーダルは sm より大きい画面では中央に配置され、モバイルでは画面の 下部 に配置されます。この配置は auto と呼ばれますが、placement プロパティを使用して変更できます。
注意:
top-centerおよびbottom-centerの位置は、モーダルがモバイルでは画面の上部/下部に配置され、デスクトップでは画面の中央に配置されることを意味します。
オーバーフロースクロール
モーダルのスクロール動作を設定するには、scrollBehavior プロパティを使用できます。
- inside: モーダルのコンテンツがスクロール可能になります。
- outside: モーダルのコンテンツがスクロール可能になり、モーダルが固定されます。
フォームの使用
Modal は、モーダルコンテンツ内のフォーカスを処理します。つまり、フォーム要素を持つモーダルを問題なく使用できます。モーダルが閉じると、フォーカスはトリガーに戻ります。
注意: モーダルが開いたときにフォーカスを当てるには、最初の
InputコンポーネントにautoFocusプロパティを追加できます。
背景
Modal コンポーネントには、モーダルの背後に背景を表示する backdrop プロパティがあります。背景は、transparent、opaque、または blur のいずれかにできます。デフォルト値は opaque です。
カスタム背景
backdrop スロットを使用すると、背景をカスタマイズできます。
カスタムモーション
モーダルは、enter / exit アニメーションをカスタマイズするための motionProps プロパティを提供します。
Framer motion variants の詳細については、こちらを参照してください。
スロット
- wrapper: モーダルのラッパースロット。
baseスロットとbackdropスロットをラップします。 - base: モーダルコンテンツのメインスロット。
- backdrop: 背景スロット。モーダルの背後に表示されます。
- header: モーダルのヘッダー。モーダルの上部に表示されます。
- body: モーダルの本文。モーダルの中央に表示されます。
- footer: モーダルのフッター。モーダルの下部に表示されます。
- closeButton: モーダルの閉じるボタン。
カスタムスタイル
コンポーネントスロットにカスタムTailwind CSSクラスを渡すことで、Modal コンポーネントをカスタマイズできます。
データ属性
Modal の base 要素には、次の属性があります。
- data-open: モーダルが開いている場合。モーダル状態に基づきます。
- data-dismissable: モーダルが閉じることが可能な場合。
isDismissableプロパティに基づきます。
アクセシビリティ
- モーダルが開いている間、モーダル外のコンテンツは支援技術から隠されます。
- モーダルは、モーダル外の操作時、またはEscキーを押すとオプションで閉じます。
- フォーカスはマウント時にモーダル内に移動し、アンマウント時にトリガー要素に戻ります。
- 開いている間、フォーカスはモーダル内に閉じ込められ、ユーザーが外にタブ移動することを防ぎます。
- モーダルが開いている間、モバイルブラウザを含め、モーダルの背後にあるページのスクロールは阻止されます。
API
モーダルProps
| 属性 | 型 | 説明 | デフォルト |
|---|---|---|---|
| children* | ReactNode | モーダルのコンテンツ。ModalContentであることが一般的です。 | - |
| size | xs | sm | md | lg | xl | 2xl | 3xl | 4xl | 5xl | full | モーダルのサイズ。これにより、モーダルのmax-widthとheight (full) が変わります。 | md |
| radius | none | sm | md | lg | モーダルのボーダー半径。 | lg |
| shadow | none | sm | md | lg | モーダルの影。 | lg |
| backdrop | transparent | opaque | blur | モーダルの背景タイプ。 | opaque |
| scrollBehavior | normal | inside | outside | モーダルのスクロール動作。 | normal |
| placement | auto | top | center | bottom | モーダルの位置。 | auto |
| isOpen | boolean | モーダルがデフォルトで開いているかどうか(制御付き)。 | - |
| defaultOpen | boolean | モーダルがデフォルトで開いているかどうか(非制御)。 | - |
| isDismissable | boolean | オーバーレイをクリックするか、Escキーを押してモーダルを閉じることができるかどうか。 | true |
| isKeyboardDismissDisabled | boolean | Escキーを押してモーダルを閉じることを無効にするかどうか。 | false |
| shouldBlockScroll | boolean | モーダルが開いているときにページのスクロールをブロックするかどうか。 | true |
| hideCloseButton | boolean | モーダルのクローズボタンを非表示にするかどうか。 | false |
| closeButton | ReactNode | 右上隅に表示するカスタムのクローズボタン。 | - |
| motionProps | MotionProps | framer motionアニメーションを修正するprops。variants APIを使用して、独自のアニメーションを作成します。 | |
| portalContainer | HTMLElement | オーバーレイポータルが配置されるコンテナ要素。 | document.body |
| disableAnimation | boolean | モーダルにアニメーションを適用しないかどうか。 | false |
| classNames | Record<"wrapper"| "base"| "backdrop"| "header" | "body" | "footer" | "closeButton", string> | モーダルのスロットにカスタムクラス名をセットできます。 | - |
モーダルイベント
| 属性 | 型 | 説明 |
|---|---|---|
| onOpenChange | (isOpen: boolean) => void | モーダルのオープン状態が変更されたときに呼び出されるハンドラー。 |
| onClose | () => void | モーダルが閉じられたときに呼び出されるハンドラー。 |
モーダルタイプ
Motion Props
export type MotionProps = HTMLMotionProps<"div">; // @see https://www.framer.com/motion/

