diff options
Diffstat (limited to 'frontend/src/components/DeckyToaster.tsx')
| -rw-r--r-- | frontend/src/components/DeckyToaster.tsx | 54 |
1 files changed, 54 insertions, 0 deletions
diff --git a/frontend/src/components/DeckyToaster.tsx b/frontend/src/components/DeckyToaster.tsx new file mode 100644 index 00000000..eaee75eb --- /dev/null +++ b/frontend/src/components/DeckyToaster.tsx @@ -0,0 +1,54 @@ +import { ToastData, joinClassNames } from 'decky-frontend-lib'; +import { FC, useEffect, useState } from 'react'; +import { ReactElement } from 'react-markdown/lib/react-markdown'; + +import { useDeckyToasterState } from './DeckyToasterState'; +import Toast, { toastClasses } from './Toast'; + +interface DeckyToasterProps {} + +interface RenderedToast { + component: ReactElement; + data: ToastData; +} + +const DeckyToaster: FC<DeckyToasterProps> = () => { + const { toasts, removeToast } = useDeckyToasterState(); + const [renderedToast, setRenderedToast] = useState<RenderedToast | null>(null); + console.log(toasts); + if (toasts.size > 0) { + const [activeToast] = toasts; + if (!renderedToast || activeToast != renderedToast.data) { + // TODO play toast sound + console.log('rendering toast', activeToast); + setRenderedToast({ component: <Toast key={Math.random()} toast={activeToast} />, data: activeToast }); + } + } else { + if (renderedToast) setRenderedToast(null); + } + useEffect(() => { + // not actually node but TS is shit + let interval: NodeJS.Timer | null; + if (renderedToast) { + interval = setTimeout(() => { + interval = null; + console.log('clear toast', renderedToast.data); + removeToast(renderedToast.data); + }, (renderedToast.data.duration || 5e3) + 1000); + console.log('set int', interval); + } + return () => { + if (interval) { + console.log('clearing int', interval); + clearTimeout(interval); + } + }; + }, [renderedToast]); + return ( + <div className={joinClassNames('deckyToaster', toastClasses.ToastPlaceholder)}> + {renderedToast && renderedToast.component} + </div> + ); +}; + +export default DeckyToaster; |
