Skip to content

Commit

Permalink
Merge pull request #1330 from near/simpler-login
Browse files Browse the repository at this point in the history
feat: new login modal
  • Loading branch information
gagdiez authored Oct 16, 2024
2 parents 4327d7b + d190325 commit dd30f96
Show file tree
Hide file tree
Showing 9 changed files with 62 additions and 111 deletions.
Binary file added src/assets/images/wallets/fastAuth.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
14 changes: 4 additions & 10 deletions src/components/sidebar-navigation/Sidebar.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,6 @@ import { useContext } from 'react';
import styled from 'styled-components';

import { networkId } from '@/config';
import { useSignInRedirect } from '@/hooks/useSignInRedirect';

import { NearContext } from '../wallet-selector/WalletSelector';
import NearIconSvg from './icons/near-icon.svg';
Expand Down Expand Up @@ -45,8 +44,7 @@ export const Sidebar = () => {
const toggleExpandedSidebar = useNavigationStore((store) => store.toggleExpandedSidebar);
const handleBubbledClickInSidebar = useNavigationStore((store) => store.handleBubbledClickInSidebar);
const tooltipsDisabled = isSidebarExpanded;
const { signedAccountId } = useContext(NearContext);
const { requestAuthentication } = useSignInRedirect();
const { wallet, signedAccountId } = useContext(NearContext);
const inputRef = useRef<HTMLInputElement>(null);
const [isOpenNetwork, setIsOpenNetwork] = useState(false);

Expand All @@ -56,10 +54,6 @@ export const Sidebar = () => {
}
};

const handleCreateAccount = () => {
requestAuthentication(true);
};

const isNavigationItemActive = useCallback(
(route: string | string[], exactMatch = false) => {
if (expandedDrawer) return false;
Expand Down Expand Up @@ -260,10 +254,10 @@ export const Sidebar = () => {
{signedAccountId ? (
<UserDropdownMenu collapsed={!isSidebarExpanded} />
) : (
<Tooltip content="Sign-up or Login" side="right" disabled={tooltipsDisabled} asChild>
<S.LoginItem $active={false} $type="featured" onClick={handleCreateAccount}>
<Tooltip content="Login" side="right" disabled={tooltipsDisabled} asChild>
<S.LoginItem $active={false} $type="featured" onClick={wallet?.signIn}>
<i className="ph-bold ph-user" />
<span>Sign-up or Login</span>
<span>Login</span>
</S.LoginItem>
</Tooltip>
)}
Expand Down
22 changes: 9 additions & 13 deletions src/components/sidebar-navigation/SmallScreenHeader.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,6 @@ import { useContext } from 'react';
import styled from 'styled-components';

import { networkId } from '@/config';
import { useSignInRedirect } from '@/hooks/useSignInRedirect';

import { NearContext } from '../wallet-selector/WalletSelector';
import NearIconSvg from './icons/near-icon.svg';
Expand All @@ -27,19 +26,14 @@ export const SmallScreenHeader = () => {
const setNavigation = useNavigationStore((store) => store.set);
const showDrawerCollapse = useNavigationStore((store) => store.isOpenedOnSmallScreens && !!store.expandedDrawer);
const expandedDrawerTitle = useNavigationStore((store) => store.expandedDrawerTitle);
const { signedAccountId } = useContext(NearContext);
const { requestAuthentication } = useSignInRedirect();
const { wallet, signedAccountId } = useContext(NearContext);

const preventRedirect = (network: string) => (e: React.MouseEvent) => {
if (networkId == network) {
e.preventDefault();
}
};

const handleCreateAccount = () => {
requestAuthentication(true);
};

return (
<S.SmallScreenHeader>
{showDrawerCollapse ? (
Expand Down Expand Up @@ -69,12 +63,14 @@ export const SmallScreenHeader = () => {
<UserDropdownMenu />
</S.SmallScreenHeaderActions>
) : (
<Button
label="Sign-up or Login"
variant="primary"
onClick={handleCreateAccount}
style={{ alignSelf: 'center', marginRight: '1rem' }}
/>
<>
<Button
label="Login"
variant="primary"
onClick={wallet?.signIn}
style={{ alignSelf: 'center', marginRight: '1rem' }}
/>
</>
)}
<Dropdown.Root>
<Dropdown.Trigger asChild>
Expand Down
38 changes: 20 additions & 18 deletions src/components/wallet-selector/WalletSelector.ts
Original file line number Diff line number Diff line change
Expand Up @@ -6,11 +6,9 @@ import { setupEthereumWallets } from '@near-wallet-selector/ethereum-wallets';
import { setupHereWallet } from '@near-wallet-selector/here-wallet';
import { setupLedger } from '@near-wallet-selector/ledger';
import { setupMeteorWallet } from '@near-wallet-selector/meteor-wallet';
import { setupMintbaseWallet } from '@near-wallet-selector/mintbase-wallet';
import { setupModal } from '@near-wallet-selector/modal-ui';
import { setupMyNearWallet } from '@near-wallet-selector/my-near-wallet';
import { setupNearMobileWallet } from '@near-wallet-selector/near-mobile-wallet';
import { setupNeth } from '@near-wallet-selector/neth';
import { setupNightly } from '@near-wallet-selector/nightly';
import { setupSender } from '@near-wallet-selector/sender';
import { setupWelldoneWallet } from '@near-wallet-selector/welldone-wallet';
Expand All @@ -19,6 +17,7 @@ import { setupFastAuthWallet } from 'near-fastauth-wallet';
import type { Context } from 'react';
import { createContext } from 'react';

import fastAuthIcon from '@/assets/images/wallets/fastAuth.png';
import { networkId as defaultNetwork, signInContractId } from '@/config';
import { KEYPOM_OPTIONS } from '@/utils/keypom-options';
import type { NetworkId } from '@/utils/types';
Expand All @@ -45,32 +44,36 @@ export class Wallet {
}

startUp = async (accountChangeHook: (account: string) => void) => {
const emailLogin = async (moduleOptions: any) => {
const setup = await setupFastAuthWallet({
iconUrl: fastAuthIcon.src,
walletUrl:
this.networkId === 'testnet'
? 'https://wallet.testnet.near.org/fastauth'
: 'https://wallet.near.org/fastauth',
relayerUrl:
this.networkId === 'testnet'
? 'http://34.70.226.83:3030/relay'
: 'https://near-relayer-mainnet.api.pagoda.co/relay',
});
const fastAuth = await setup(moduleOptions);
if (fastAuth) fastAuth.metadata.name = 'Email Login';
return fastAuth;
};

this.selector = setupWalletSelector({
network: this.networkId,
modules: [
await emailLogin,
setupEthereumWallets({ wagmiConfig, web3Modal: web3Modal as any, alwaysOnboardDuringSignIn: true }),
setupMeteorWallet(),
setupBitteWallet(),
setupHereWallet(),
setupMyNearWallet(),
setupNearMobileWallet(),
setupSender(),
setupMintbaseWallet(),
setupNeth({
gas: '300000000000000',
bundle: false,
}),
setupNightly(),
setupWelldoneWallet(),
setupFastAuthWallet({
walletUrl:
this.networkId === 'testnet'
? 'https://wallet.testnet.near.org/fastauth'
: 'https://wallet.near.org/fastauth',
relayerUrl:
this.networkId === 'testnet'
? 'http://34.70.226.83:3030/relay'
: 'https://near-relayer-mainnet.api.pagoda.co/relay',
}),
setupKeypom({
trialAccountSpecs: {
url:
Expand All @@ -89,7 +92,6 @@ export class Wallet {
signInContractId,
}) as any, // TODO: Refactor setupKeypom() to TS
setupLedger(),
setupNearMobileWallet(),
],
});

Expand Down
55 changes: 0 additions & 55 deletions src/hooks/useSignInRedirect.ts

This file was deleted.

8 changes: 3 additions & 5 deletions src/pages/[accountId]/widget/[componentName].tsx
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,6 @@ import { privacyDomainName, termsDomainName } from '@/config';
import { useBosComponents } from '@/hooks/useBosComponents';
import { useGatewayEvents } from '@/hooks/useGatewayEvents';
import { useDefaultLayout } from '@/hooks/useLayout';
import { useSignInRedirect } from '@/hooks/useSignInRedirect';
import type { NextPageWithLayout } from '@/utils/types';

const ViewComponentPage: NextPageWithLayout = () => {
Expand All @@ -17,15 +16,14 @@ const ViewComponentPage: NextPageWithLayout = () => {
const [componentProps, setComponentProps] = useState<Record<string, unknown>>({});
const { wallet, signedAccountId } = useContext(NearContext);
const components = useBosComponents();
const { requestAuthentication } = useSignInRedirect();
const { emitGatewayEvent, shouldPassGatewayEventProps } = useGatewayEvents();

useEffect(() => {
const { requestAuth, createAccount } = componentProps;
const { requestAuth } = componentProps;
if (requestAuth && !signedAccountId) {
requestAuthentication(!!createAccount);
wallet?.signIn();
}
}, [signedAccountId, componentProps, requestAuthentication]);
}, [wallet, signedAccountId, componentProps]);

useEffect(() => {
const urlSearchParams = new URLSearchParams(window.location.search);
Expand Down
10 changes: 4 additions & 6 deletions src/pages/applications.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -5,14 +5,12 @@ import { ComponentWrapperPage } from '@/components/near-org/ComponentWrapperPage
import { NearContext } from '@/components/wallet-selector/WalletSelector';
import { useBosComponents } from '@/hooks/useBosComponents';
import { useDefaultLayout } from '@/hooks/useLayout';
import { useSignInRedirect } from '@/hooks/useSignInRedirect';
import type { NextPageWithLayout } from '@/utils/types';

const ApplicationsPage: NextPageWithLayout = () => {
const components = useBosComponents();
const router = useRouter();
const { requestAuthentication } = useSignInRedirect();
const { signedAccountId } = useContext(NearContext);
const { wallet, signedAccountId } = useContext(NearContext);

const setURLSearchParams = (params: string | string[][] | Record<string, string> | URLSearchParams | undefined) => {
if (!params) return;
Expand All @@ -29,11 +27,11 @@ const ApplicationsPage: NextPageWithLayout = () => {
};

useEffect(() => {
const { requestAuth, createAccount } = router.query;
const { requestAuth } = router.query;
if (requestAuth && !signedAccountId) {
requestAuthentication(!!createAccount);
wallet?.signIn();
}
}, [signedAccountId, requestAuthentication, router.query]);
}, [signedAccountId, wallet, router.query]);

return (
<ComponentWrapperPage
Expand Down
6 changes: 2 additions & 4 deletions src/pages/wallet-utilities.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -10,14 +10,12 @@ import KeyTable from '@/components/wallet-utilities/KeyTable';
import { ReceiveNear } from '@/components/wallet-utilities/ReceiveNear';
import { SendNear } from '@/components/wallet-utilities/SendNear';
import { useDefaultLayout } from '@/hooks/useLayout';
import { useSignInRedirect } from '@/hooks/useSignInRedirect';
import type { NextPageWithLayout } from '@/utils/types';

const WalletUtilitiesPage: NextPageWithLayout = () => {
const router = useRouter();
const selectedTab = (router.query.tab as string) || 'send';
const signedAccountId = useContext(NearContext);
const { requestAuthentication } = useSignInRedirect();
const { wallet, signedAccountId } = useContext(NearContext);

return (
<Section grow="available" style={{ background: 'var(--sand3)' }}>
Expand Down Expand Up @@ -72,7 +70,7 @@ const WalletUtilitiesPage: NextPageWithLayout = () => {
) : (
<Card>
<Text>Please sign in to use wallet utilities.</Text>
<Button label="Sign In" fill="outline" onClick={() => requestAuthentication()} />
<Button label="Sign In" fill="outline" onClick={() => wallet?.signIn()} />
</Card>
)}
</Flex>
Expand Down
20 changes: 20 additions & 0 deletions src/styles/globals.css
Original file line number Diff line number Diff line change
Expand Up @@ -77,3 +77,23 @@ w3m-modal {
bottom: 10px;
}
}

/* wallet selector */
.modal-right {
display: none;
}

.modal-left, .modal-left-title {
border-right: 0 !important;
width: 100% !important;
}

.nws-modal {
max-width: 500px !important;
}

@media (max-width: 576px) {
.nws-modal, .modal-left {
max-height: 280px !important;
}
}

0 comments on commit dd30f96

Please sign in to comment.