Backdrop.tsx 892 B

12345678910111213141516171819202122232425262728293031323334353637
  1. import React, { MouseEventHandler, SyntheticEvent } from 'react';
  2. import styled from 'styled-components';
  3. interface BackdropProps {
  4. onClick?: (e: SyntheticEvent<HTMLElement>) => void;
  5. open?: boolean;
  6. }
  7. const BackdropStyled = styled.div`
  8. display: flex;
  9. position: fixed;
  10. top: 0;
  11. right: 0;
  12. bottom: 0;
  13. left: 0;
  14. flex-direction: column;
  15. align-items: center;
  16. justify-content: center;
  17. background: rgba(#000000, 0.5);
  18. `;
  19. const Backdrop: React.FC<BackdropProps> = ({ open, onClick }) => {
  20. const handleClick: MouseEventHandler<HTMLElement> = (e) => {
  21. e.stopPropagation();
  22. if (e.target !== e.currentTarget) {
  23. return;
  24. }
  25. onClick?.(e);
  26. };
  27. return open ? (
  28. // eslint-disable-next-line jsx-a11y/click-events-have-key-events,jsx-a11y/no-static-element-interactions
  29. <BackdropStyled onClick={handleClick} />
  30. ) : null;
  31. };
  32. export default Backdrop;