2021-10-14 22:56:51 +05:30
|
|
|
import { useCallback, useEffect, useRef } from "react";
|
2021-01-15 20:32:46 +05:30
|
|
|
import { TOAST_TIMEOUT } from "../constants";
|
|
|
|
import "./Toast.scss";
|
|
|
|
|
|
|
|
export const Toast = ({
|
|
|
|
message,
|
|
|
|
clearToast,
|
|
|
|
}: {
|
|
|
|
message: string;
|
|
|
|
clearToast: () => void;
|
|
|
|
}) => {
|
|
|
|
const timerRef = useRef<number>(0);
|
|
|
|
|
|
|
|
const scheduleTimeout = useCallback(
|
|
|
|
() =>
|
|
|
|
(timerRef.current = window.setTimeout(() => clearToast(), TOAST_TIMEOUT)),
|
|
|
|
[clearToast],
|
|
|
|
);
|
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
scheduleTimeout();
|
|
|
|
return () => clearTimeout(timerRef.current);
|
|
|
|
}, [scheduleTimeout, message]);
|
|
|
|
|
|
|
|
return (
|
|
|
|
<div
|
|
|
|
className="Toast"
|
|
|
|
onMouseEnter={() => clearTimeout(timerRef?.current)}
|
|
|
|
onMouseLeave={scheduleTimeout}
|
|
|
|
>
|
|
|
|
<p className="Toast__message">{message}</p>
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
};
|