From 054d2ab9b10cedb739abf9f779b3a1ddacba7d62 Mon Sep 17 00:00:00 2001 From: Steve Purves Date: Thu, 23 Nov 2023 10:50:46 +0000 Subject: [PATCH] =?UTF-8?q?=F0=9F=8E=9Aenable=20clean=20shutdown=20(#713)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- packages/react/src/ThebeServerProvider.tsx | 2 ++ packages/react/src/ThebeSessionProvider.tsx | 11 ++++++++++- 2 files changed, 12 insertions(+), 1 deletion(-) diff --git a/packages/react/src/ThebeServerProvider.tsx b/packages/react/src/ThebeServerProvider.tsx index 87e6626b..9d5da836 100644 --- a/packages/react/src/ThebeServerProvider.tsx +++ b/packages/react/src/ThebeServerProvider.tsx @@ -142,6 +142,8 @@ export function ThebeServerProvider({ } setReady(false); setDoConnect(false); + setConnecting(false); + setError(undefined); }, error, }} diff --git a/packages/react/src/ThebeSessionProvider.tsx b/packages/react/src/ThebeSessionProvider.tsx index 27a5694d..dad29615 100644 --- a/packages/react/src/ThebeSessionProvider.tsx +++ b/packages/react/src/ThebeSessionProvider.tsx @@ -38,6 +38,7 @@ export function ThebeSessionProvider({ const [session, setSession] = useState(); const [ready, setReady] = useState(false); const [error, setError] = useState(); + const [unsubscribe, setUnsubscribe] = useState<(() => void) | undefined>(); /// Once server connection is open, auto start a session if start prop is true useEffect(() => { @@ -59,7 +60,7 @@ export function ThebeSessionProvider({ setError(`session ${session.path} - ${data.status} - ${data.message}`); } }; - config.events.on(core.ThebeEventType.status, handler); + setUnsubscribe(config.events.on(core.ThebeEventType.status, handler)); }, [core, config, session]); const startSession = () => { @@ -92,8 +93,12 @@ export function ThebeSessionProvider({ useEffect(() => { return () => { if (shutdownOnUnmount) { + unsubscribe?.(); + setUnsubscribe(undefined); session?.shutdown().then(() => { setReady(false); + setStarting(false); + setError(undefined); }); } }; @@ -116,9 +121,13 @@ export function ThebeSessionProvider({ }, shutdown: async () => { if (session) { + unsubscribe?.(); + setUnsubscribe(undefined); await session.shutdown(); setSession(undefined); setReady(false); + setStarting(false); + setError(undefined); } }, error,