1
0
mirror of https://github.com/kremalicious/metamask-extension.git synced 2024-11-27 12:56:01 +01:00
metamask-extension/ui/components/component-library/modal-overlay
2023-03-23 06:36:09 -07:00
..
__snapshots__ Adding ModalOverlay component (#18161) 2023-03-23 06:36:09 -07:00
index.ts Adding ModalOverlay component (#18161) 2023-03-23 06:36:09 -07:00
modal-overlay.scss Adding ModalOverlay component (#18161) 2023-03-23 06:36:09 -07:00
modal-overlay.stories.tsx Adding ModalOverlay component (#18161) 2023-03-23 06:36:09 -07:00
modal-overlay.test.tsx Adding ModalOverlay component (#18161) 2023-03-23 06:36:09 -07:00
modal-overlay.tsx Adding ModalOverlay component (#18161) 2023-03-23 06:36:09 -07:00
modal-overlay.types.ts Adding ModalOverlay component (#18161) 2023-03-23 06:36:09 -07:00
README.mdx Adding ModalOverlay component (#18161) 2023-03-23 06:36:09 -07:00

import { Story, Canvas, ArgsTable } from '@storybook/addon-docs';

import { ModalOverlay } from './modal-overlay';

# ModalOverlay

`ModalOverlay` is a transparent overlay that covers the entire screen. It is used to dim the background when a modal is open.

<Canvas>
  <Story id="components-componentlibrary-modaloverlay--default-story" />
</Canvas>

## Props

The `ModalOverlay` accepts all props below as well as all [Box](/docs/components-ui-box--default-story#props) component props

<ArgsTable of={ModalOverlay} />

### On Click

Use the `onClick` prop to handle clicks on the overlay

<Canvas>
  <Story id="components-componentlibrary-modaloverlay--on-click" />
</Canvas>

```jsx
import React, { useState } from 'react';
import { ModalOverlay } from '../../component-library';

const [open, setOpen] = useState(false);
const handleOnClick = () => {
  setOpen(!open);
};

<button onClick={handleOnClick}>Show modal overlay</button>;
{
  open && <ModalOverlay onClick={handleOnClick} />;
}
```