diff --git a/package.json b/package.json index fb230185..7c2f7b4b 100644 --- a/package.json +++ b/package.json @@ -9,8 +9,8 @@ "@fortawesome/fontawesome-svg-core": "6.5.1", "@fortawesome/free-solid-svg-icons": "6.5.1", "@fortawesome/react-fontawesome": "0.2.0", - "@multiversx/sdk-core": "13.13.0", - "@multiversx/sdk-dapp": "3.0.3", + "@multiversx/sdk-core": "13.15.0", + "@multiversx/sdk-dapp": "3.0.14", "axios": "1.7.4", "classnames": "2.3.2", "moment": "2.29.4", diff --git a/src/App.tsx b/src/App.tsx index 7c2865a4..3b9cc9fb 100644 --- a/src/App.tsx +++ b/src/App.tsx @@ -15,8 +15,7 @@ import { apiTimeout, walletConnectV2ProjectId, environment, - sampleAuthenticatedDomains, - metamaskSnapWalletAddress + sampleAuthenticatedDomains } from 'config'; import { RouteNamesEnum } from 'localConstants'; import { PageNotFound, Unlock } from 'pages'; @@ -30,8 +29,7 @@ const AppContent = () => { customNetworkConfig={{ name: 'customConfig', apiTimeout, - walletConnectV2ProjectId, - metamaskSnapWalletAddress + walletConnectV2ProjectId }} dappConfig={{ shouldUseWebViewProvider: true, diff --git a/src/config/config.devnet.ts b/src/config/config.devnet.ts index 53eeb7ee..16843fbc 100644 --- a/src/config/config.devnet.ts +++ b/src/config/config.devnet.ts @@ -7,5 +7,3 @@ export const contractAddress = export const API_URL = 'https://devnet-template-api.multiversx.com'; export const sampleAuthenticatedDomains = [API_URL]; export const environment = EnvironmentsEnum.devnet; -export const metamaskSnapWalletAddress = - 'https://devnet-snap-wallet.multiversx.com'; diff --git a/src/config/config.mainnet.ts b/src/config/config.mainnet.ts index 08891eb9..7327e026 100644 --- a/src/config/config.mainnet.ts +++ b/src/config/config.mainnet.ts @@ -7,4 +7,3 @@ export const contractAddress = export const API_URL = 'https://template-api.multiversx.com'; export const sampleAuthenticatedDomains = [API_URL]; export const environment = EnvironmentsEnum.mainnet; -export const metamaskSnapWalletAddress = 'https://snap-wallet.multiversx.com'; diff --git a/src/config/config.testnet.ts b/src/config/config.testnet.ts index af3dec37..ff1e1c0a 100644 --- a/src/config/config.testnet.ts +++ b/src/config/config.testnet.ts @@ -7,5 +7,3 @@ export const contractAddress = export const API_URL = 'https://testnet-template-api.multiversx.com'; export const sampleAuthenticatedDomains = [API_URL]; export const environment = EnvironmentsEnum.testnet; -export const metamaskSnapWalletAddress = - 'https://testnet-snap-wallet.multiversx.com'; diff --git a/src/hooks/index.ts b/src/hooks/index.ts index f5eff249..8572a88e 100644 --- a/src/hooks/index.ts +++ b/src/hooks/index.ts @@ -3,3 +3,4 @@ export * from './withPageTitle'; export * from './transactions'; export * from './useScrollToElement'; export * from './useIsWebProvider'; +export * from './useWindowSize'; diff --git a/src/hooks/useWindowSize.ts b/src/hooks/useWindowSize.ts new file mode 100644 index 00000000..a2bdc7ea --- /dev/null +++ b/src/hooks/useWindowSize.ts @@ -0,0 +1,25 @@ +import { useEffect, useState } from 'react'; + +export const useWindowSize = () => { + const [windowSize, setWindowSize] = useState<{ + width: number; + height: number; + }>({ + width: window.innerWidth, + height: window.innerHeight, + }); + + useEffect(() => { + function handleResize() { + setWindowSize({ + width: window.innerWidth, + height: window.innerHeight, + }); + } + window.addEventListener('resize', handleResize); + handleResize(); + + return () => window.removeEventListener('resize', handleResize); + }, []); + return windowSize; +}; diff --git a/src/pages/Unlock/Unlock.tsx b/src/pages/Unlock/Unlock.tsx index 57a27675..556e9f95 100644 --- a/src/pages/Unlock/Unlock.tsx +++ b/src/pages/Unlock/Unlock.tsx @@ -3,8 +3,7 @@ import { type WebWalletLoginButtonPropsType, type OperaWalletLoginButtonPropsType, type LedgerLoginButtonPropsType, - type WalletConnectLoginButtonPropsType, - IframeButton + type WalletConnectLoginButtonPropsType } from '@multiversx/sdk-dapp/UI'; import { ExtensionLoginButton, @@ -12,14 +11,20 @@ import { OperaWalletLoginButton, WalletConnectLoginButton, WebWalletLoginButton as WebWalletUrlLoginButton, - XaliasCrossWindowLoginButton, CrossWindowLoginButton } from 'components/sdkDappComponents'; import { nativeAuth } from 'config'; import { RouteNamesEnum } from 'localConstants'; import { useNavigate } from 'react-router-dom'; import { AuthRedirectWrapper } from 'wrappers'; -import { WebWalletLoginWrapper, XaliasLoginWrapper } from './components'; +import { + IframeButton, + WebWalletLoginWrapper, + XaliasLoginWrapper +} from './components'; +import { IframeLoginTypes } from '@multiversx/sdk-web-wallet-iframe-provider/out/constants'; +import { useIframeLogin } from '@multiversx/sdk-dapp/hooks/login/useIframeLogin'; +import { useWindowSize } from 'hooks'; type CommonPropsType = | OperaWalletLoginButtonPropsType @@ -37,12 +42,24 @@ const WebWalletLoginButton = USE_WEB_WALLET_CROSS_WINDOW export const Unlock = () => { const navigate = useNavigate(); - const commonProps: CommonPropsType = { + const { width } = useWindowSize(); + + const [onInitiateLogin, { isLoading }] = useIframeLogin({ callbackRoute: RouteNamesEnum.dashboard, nativeAuth, onLoginRedirect: () => { navigate(RouteNamesEnum.dashboard); } + }); + + const isMobile = width < 768; + const commonProps: CommonPropsType = { + callbackRoute: RouteNamesEnum.dashboard, + nativeAuth, + onLoginRedirect: () => { + navigate(RouteNamesEnum.dashboard); + }, + disabled: isLoading }; return ( @@ -74,16 +91,18 @@ export const Unlock = () => { /> - + {isMobile && ( + onInitiateLogin(IframeLoginTypes.passkey)} + /> + )} onInitiateLogin(IframeLoginTypes.metamask)} /> diff --git a/src/pages/Unlock/components/IframeButton/IframeButton.tsx b/src/pages/Unlock/components/IframeButton/IframeButton.tsx new file mode 100644 index 00000000..770ba56c --- /dev/null +++ b/src/pages/Unlock/components/IframeButton/IframeButton.tsx @@ -0,0 +1,23 @@ +import { Button } from 'components'; + +export interface IframeButtonPropsType { + loginButtonText?: string; + disabled?: boolean; + onClick?: () => void; +} + +export const IframeButton = ({ + disabled, + onClick, + loginButtonText +}: IframeButtonPropsType) => { + return ( + + ); +}; diff --git a/src/pages/Unlock/components/IframeButton/index.ts b/src/pages/Unlock/components/IframeButton/index.ts new file mode 100644 index 00000000..6a65c504 --- /dev/null +++ b/src/pages/Unlock/components/IframeButton/index.ts @@ -0,0 +1 @@ +export * from './IframeButton'; diff --git a/src/pages/Unlock/components/index.tsx b/src/pages/Unlock/components/index.tsx index 93dbf205..bc2e8042 100644 --- a/src/pages/Unlock/components/index.tsx +++ b/src/pages/Unlock/components/index.tsx @@ -1,2 +1,3 @@ export * from './WebWalletLoginWrapper'; export * from './XaliasLoginWrapper'; +export * from './IframeButton';