summaryrefslogtreecommitdiff
path: root/src/components/ModalCloseAllConnections.js
blob: 8a06393332624f485e4e6429b82e2515910a3c3c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
import React from 'react';

import Modal from 'react-modal';
import Button from './Button';
import cx from 'classnames';

import modalStyle from './Modal.module.css';
import s from './ModalCloseAllConnections.module.css';

const { useRef, useCallback, useMemo } = React;

export default function Comp({ isOpen, onRequestClose, primaryButtonOnTap }) {
  const primaryButtonRef = useRef(null);
  const onAfterOpen = useCallback(() => {
    primaryButtonRef.current.focus();
  }, []);
  const className = useMemo(
    () => ({
      base: cx(modalStyle.content, s.cnt),
      afterOpen: s.afterOpen,
      beforeClose: ''
    }),
    []
  );
  return (
    <Modal
      isOpen={isOpen}
      onRequestClose={onRequestClose}
      onAfterOpen={onAfterOpen}
      className={className}
      overlayClassName={cx(modalStyle.overlay, s.overlay)}
    >
      <p>Are you sure you want to close all connections?</p>
      <div className={s.btngrp}>
        <Button onClick={primaryButtonOnTap} ref={primaryButtonRef}>
          I'm sure
        </Button>
        {/* im lazy :) */}
        <div style={{ width: 20 }} />
        <Button onClick={onRequestClose}>No</Button>
      </div>
    </Modal>
  );
}