Press n or j to go to the next uncovered block, b, p or k for the previous block.
| 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 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 | 2x 7x 7x 7x 7x 2x 2x 2x 2x 2x 2x 2x 2x 7x 7x 7x 7x 2x 2x 2x 2x | /* eslint-disable jsx-a11y/click-events-have-key-events */
import { css, keyframes } from '@emotion/react';
import React from 'react';
export const ALERT_CLOSE_TEST_ID = 'alert-close-component';
interface AlertRenderData {
message: string;
}
export function useAlert() {
const [isOpen, setIsOpen] = React.useState(false);
const [renderData, setRenderData] = React.useState<AlertRenderData>();
const onCloseRef = React.useRef<() => unknown>();
const openAlertWithAwait = React.useCallback(
(nextRenderData: AlertRenderData) =>
new Promise((resolve) => {
onCloseRef.current = () => {
setRenderData(undefined);
setIsOpen(false);
onCloseRef.current = undefined;
resolve(true);
};
setRenderData(nextRenderData);
setIsOpen(true);
}),
[setRenderData, setIsOpen]
);
const alertProps = React.useMemo(
() => ({
...renderData,
isOpen,
onClose: onCloseRef.current
}),
[renderData, isOpen, setIsOpen]
);
return {
props: alertProps,
openAlertWithAwait
};
}
interface AlertProps {
isOpen: boolean;
onClose?: () => unknown;
message?: string;
}
export function Alert({ isOpen, onClose, message }: AlertProps) {
return isOpen ? (
<div css={modalWrapper}>
<div css={backDrop}>
<div
css={modalBody}
data-testid={ALERT_CLOSE_TEST_ID}
onClick={onClose}
role="button"
tabIndex={0}
>
{message}
</div>
</div>
</div>
) : null;
}
const showBounce = keyframes`
0% {
transform: scale(1);
}
50% {
transform: scale(1.2);
}
80% {
transform: scale(0.9);
}
100% {
transform: scale(1);
}
`;
const modalWrapper = css`
position: absolute;
display: flex;
justify-content: center;
align-items: center;
padding: 0 8px;
`;
const backDrop = css`
position: fixed;
display: flex;
justify-content: center;
align-items: center;
top: 0;
right: 0;
bottom: 0;
left: 0;
background: rgba(0, 0, 0, 0.1);
backdrop-filter: blur(10px);
padding: 0 16px;
z-index: 10000;
`;
const modalBody = css`
width: 343px;
padding: 16px;
background: #eeeeee;
border: 1px solid #505050;
border-radius: 8px;
text-align: center;
animation: ${showBounce} 0.4s;
`;
|