From 255ad383379d421c2ea4083b78a909976c26271a Mon Sep 17 00:00:00 2001 From: Tomasz Dysinski Date: Wed, 25 Sep 2024 11:45:33 -0700 Subject: [PATCH] experimental google auth redirect --- packages/kit/src/components/Connect/Connect.tsx | 11 +++++++++-- .../src/components/Connect/ConnectWalletContent.tsx | 2 ++ .../src/components/ConnectButton/ConnectButton.tsx | 6 +++++- .../KitPreviewProvider/KitPreviewProvider.tsx | 2 ++ .../kit/src/components/KitProvider/KitProvider.tsx | 2 ++ packages/kit/src/types.ts | 2 ++ 6 files changed, 22 insertions(+), 3 deletions(-) diff --git a/packages/kit/src/components/Connect/Connect.tsx b/packages/kit/src/components/Connect/Connect.tsx index df82db03..c6b934ef 100644 --- a/packages/kit/src/components/Connect/Connect.tsx +++ b/packages/kit/src/components/Connect/Connect.tsx @@ -31,12 +31,14 @@ import { ExtendedWalletList } from './ExtendedWalletList' interface ConnectWalletContentProps extends KitConnectProviderProps { emailConflictInfo?: FormattedEmailConflictInfo | null onClose: () => void + googleUseRedirectMode?: boolean + googleRedirectModeLoginUri?: string } export const Connect = (props: ConnectWalletContentProps) => { useScript(appleAuthHelpers.APPLE_SCRIPT_SRC) - const { onClose, emailConflictInfo, config = {} } = props + const { onClose, emailConflictInfo, config = {}, googleUseRedirectMode, googleRedirectModeLoginUri } = props const { signIn = {} } = config as KitConfig const { isConnected } = useAccount() const storage = useStorage() @@ -233,7 +235,12 @@ export const Connect = (props: ConnectWalletContentProps) => { return ( {connector._wallet.id === 'google-waas' ? ( - + ) : connector._wallet.id === 'apple-waas' ? ( ) : connector._wallet.id.includes('email') ? ( diff --git a/packages/kit/src/components/Connect/ConnectWalletContent.tsx b/packages/kit/src/components/Connect/ConnectWalletContent.tsx index a50e83c7..6a5d2d6d 100644 --- a/packages/kit/src/components/Connect/ConnectWalletContent.tsx +++ b/packages/kit/src/components/Connect/ConnectWalletContent.tsx @@ -11,6 +11,8 @@ interface ConnectWalletContent extends KitConnectProviderProps { emailConflictInfo?: FormattedEmailConflictInfo | null onClose: () => void isPreview?: boolean + googleUseRedirectMode?: boolean + googleRedirectModeLoginUri?: string } export const ConnectWalletContent = (props: ConnectWalletContent) => { diff --git a/packages/kit/src/components/ConnectButton/ConnectButton.tsx b/packages/kit/src/components/ConnectButton/ConnectButton.tsx index bcdd7fa4..51ab8f30 100644 --- a/packages/kit/src/components/ConnectButton/ConnectButton.tsx +++ b/packages/kit/src/components/ConnectButton/ConnectButton.tsx @@ -19,6 +19,8 @@ interface ConnectButtonProps { connector: ExtendedConnector label?: string onConnect: (connector: ExtendedConnector) => void + googleUseRedirectMode?: boolean + googleRedirectModeLoginUri?: string } export const ConnectButton = (props: ConnectButtonProps) => { @@ -47,7 +49,7 @@ export const ConnectButton = (props: ConnectButtonProps) => { } export const GoogleWaasConnectButton = (props: ConnectButtonProps) => { - const { connector, onConnect } = props + const { connector, onConnect, googleUseRedirectMode, googleRedirectModeLoginUri } = props const storage = useStorage() const [enableGoogleTooltip, setEnableGoogleTooltip] = useState(false) @@ -95,6 +97,8 @@ export const GoogleWaasConnectButton = (props: ConnectButtonProps) => { onError={() => { console.log('Login Failed') }} + ux_mode={googleUseRedirectMode ? 'redirect' : 'popup'} + login_uri={googleRedirectModeLoginUri} /> { onClose={() => setOpenConnectModal(false)} emailConflictInfo={emailConflictInfo} isPreview + googleUseRedirectMode={props.config.googleUseRedirectMode} + googleRedirectModeLoginUri={props.config.googleRedirectModeLoginUri} {...props} /> diff --git a/packages/kit/src/components/KitProvider/KitProvider.tsx b/packages/kit/src/components/KitProvider/KitProvider.tsx index ccd9122e..53b13b87 100644 --- a/packages/kit/src/components/KitProvider/KitProvider.tsx +++ b/packages/kit/src/components/KitProvider/KitProvider.tsx @@ -160,6 +160,8 @@ export const KitProvider = (props: KitConnectProviderProps) => { setOpenConnectModal(false)} emailConflictInfo={emailConflictInfo} + googleUseRedirectMode={props.config.googleUseRedirectMode} + googleRedirectModeLoginUri={props.config.googleRedirectModeLoginUri} {...props} /> diff --git a/packages/kit/src/types.ts b/packages/kit/src/types.ts index 5ef32da5..6449c5ed 100644 --- a/packages/kit/src/types.ts +++ b/packages/kit/src/types.ts @@ -76,6 +76,8 @@ export interface KitConfig { displayedAssets?: DisplayedAsset[] ethAuth?: EthAuthSettings isDev?: boolean + googleUseRedirectMode?: boolean + googleRedirectModeLoginUri?: string } export type StorageItem = {