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; `; |