From e1318fa1dcf22282a0dfd670337d56f96fae0782 Mon Sep 17 00:00:00 2001 From: sage Date: Sun, 14 Nov 2021 09:38:47 +0700 Subject: [PATCH] :lock: (react) Update iframe src after deleting session param Closes #8 --- packages/react/lib/Giscus.tsx | 17 +++++++++++++---- 1 file changed, 13 insertions(+), 4 deletions(-) diff --git a/packages/react/lib/Giscus.tsx b/packages/react/lib/Giscus.tsx index ff6fc83a..6cca187b 100644 --- a/packages/react/lib/Giscus.tsx +++ b/packages/react/lib/Giscus.tsx @@ -1,4 +1,4 @@ -import React, { useEffect, useState } from 'react' +import React, { useEffect, useRef, useState } from 'react' import { GiscusProps } from '@shared/types' import { addDefaultStyles, @@ -16,19 +16,24 @@ function GiscusClient(props: GiscusProps) { const savedSession = localStorage.getItem(GISCUS_SESSION_KEY) const [session, setSession] = useState(url.searchParams.get('giscus') || '') + const [src, setSrc] = useState(getIframeSrc({ ...props, session })) + const ref = useRef(null) useEffect(() => { if (session) { localStorage.setItem(GISCUS_SESSION_KEY, JSON.stringify(session)) url.searchParams.delete('giscus') - history.replaceState(undefined, document.title, url.toString()) + const newOrigin = url.toString() + const newSrc = getIframeSrc({ ...props, session, origin: newOrigin }) + setSrc(newSrc) + history.replaceState(undefined, document.title, newOrigin) return } if (savedSession) { try { setSession(JSON.parse(savedSession || '') || '') - } catch (e) { + } catch (e: any) { setSession('') localStorage.removeItem(GISCUS_SESSION_KEY) console.warn(`${formatError(e?.message)} Session has been cleared.`) @@ -44,7 +49,10 @@ function GiscusClient(props: GiscusProps) { return () => window.removeEventListener('message', listener) }, []) - const src = getIframeSrc({ ...props, session }) + useEffect(() => { + if (!ref.current) return + ref.current.src = src + }, [src]) return (
@@ -52,6 +60,7 @@ function GiscusClient(props: GiscusProps) { className="giscus-frame" title="Comments" src={src} + forwardRef={ref} checkOrigin={[GISCUS_ORIGIN]} />