diff options
| author | 2020-10-06 19:08:33 +0100 | |
|---|---|---|
| committer | 2020-10-06 19:08:33 +0100 | |
| commit | 2b367c7aeea254655dd3011a4ed44b98f1caf0c9 (patch) | |
| tree | 7b16343d9f95d329fdc025c75f15c30cecb71229 /src/components/OAuth2Button.tsx | |
| parent | Merge pull request #19 from python-discord/discord/add-oauth2-authorize (diff) | |
| parent | Better handle other messages from the React DevTools extension (diff) | |
Merge pull request #20 from python-discord/discord/improve-oauth2-flow
Check for child window closure
Diffstat (limited to '')
| -rw-r--r-- | src/components/OAuth2Button.tsx | 10 | 
1 files changed, 9 insertions, 1 deletions
| diff --git a/src/components/OAuth2Button.tsx b/src/components/OAuth2Button.tsx index 1b3d588..d67b1ab 100644 --- a/src/components/OAuth2Button.tsx +++ b/src/components/OAuth2Button.tsx @@ -50,8 +50,15 @@ function doLogin(disableFunction: (newState: boolean) => void) {      "height=700,width=500,location=no,menubar=no,resizable=no,status=no,titlebar=no,left=300,top=300"    ) +  const interval = setInterval(() => { +    if (windowRef?.closed) { +      clearInterval(interval); +      disableFunction(false); +    } +  }, 500) +    window.onmessage = (code: MessageEvent) => { -    if (code.data.hello) { +    if (code.data.source) {        // React DevTools has a habit of sending messages, ignore them.        return;      } @@ -62,6 +69,7 @@ function doLogin(disableFunction: (newState: boolean) => void) {        console.log("Code received:", code.data);        disableFunction(false); +      clearInterval(interval);        window.onmessage = null;      } | 
