import { Center } from '@mantine/core'; import isElectron from 'is-electron'; import { useEffect, useMemo } from 'react'; import { Navigate, Outlet } from 'react-router-dom'; import { Spinner, toast } from '/@/renderer/components'; import { useServerAuthenticated } from '/@/renderer/hooks/use-server-authenticated'; import { AppRoute } from '/@/renderer/router/routes'; import { useCurrentServer, useSetPlayerFallback } from '/@/renderer/store'; import { AuthState } from '/@/shared/types/types'; const ipc = isElectron() ? window.api.ipc : null; const utils = isElectron() ? window.api.utils : null; const mpvPlayerListener = isElectron() ? window.api.mpvPlayerListener : null; export const AppOutlet = () => { const currentServer = useCurrentServer(); const setFallback = useSetPlayerFallback(); const authState = useServerAuthenticated(); const isActionsRequired = useMemo(() => { const isServerRequired = !currentServer; const actions = [isServerRequired]; const isActionRequired = actions.some((c) => c); return isActionRequired; }, [currentServer]); useEffect(() => { utils?.mainMessageListener((_event, data) => { toast.show(data); }); mpvPlayerListener?.rendererPlayerFallback((_event, data) => { setFallback(data); }); return () => { ipc?.removeAllListeners('toast-from-main'); ipc?.removeAllListeners('renderer-player-fallback'); }; }, [setFallback]); if (authState === AuthState.LOADING) { return (