From 9eb3282e428836571aefb9cfc529e10293660606 Mon Sep 17 00:00:00 2001 From: Alec Chen <93971719+0xAlec@users.noreply.github.com> Date: Fri, 9 Aug 2024 09:39:18 -0700 Subject: [PATCH] window mode --- .../WalletDropdownFundLink.test.tsx | 48 +++++++++----- .../components/WalletDropdownFundLink.tsx | 64 ++++++++++++++----- 2 files changed, 78 insertions(+), 34 deletions(-) diff --git a/src/wallet/components/WalletDropdownFundLink.test.tsx b/src/wallet/components/WalletDropdownFundLink.test.tsx index f3bdb35854..bab4714aa3 100644 --- a/src/wallet/components/WalletDropdownFundLink.test.tsx +++ b/src/wallet/components/WalletDropdownFundLink.test.tsx @@ -1,5 +1,5 @@ -import { render, screen } from '@testing-library/react'; -import { describe, expect, it } from 'vitest'; +import { render, screen, fireEvent } from '@testing-library/react'; +import { describe, expect, it, vi } from 'vitest'; import { WalletDropdownFundLink } from './WalletDropdownFundLink'; const FUNDING_URL = @@ -17,31 +17,45 @@ describe('WalletDropdownFundLink', () => { it('renders correctly with custom icon element', () => { const customIcon = ; - render( - - Link Text - - ); + render(); const linkElement = screen.getByRole('link'); expect(linkElement).toBeInTheDocument(); expect(linkElement).toHaveAttribute('href', FUNDING_URL); - expect(screen.getByText('Link Text')).toBeInTheDocument(); + expect(screen.getByText('Deposit Funds')).toBeInTheDocument(); expect(screen.getByLabelText('custom-icon')).toBeInTheDocument(); }); - it('renders correctly with target and rel attributes', () => { - render( - - Link Text - - ); + it('renders correctly with custom text', () => { + render(); const linkElement = screen.getByRole('link'); expect(linkElement).toBeInTheDocument(); expect(linkElement).toHaveAttribute('href', FUNDING_URL); - expect(linkElement).toHaveAttribute('target', '_blank'); - expect(linkElement).toHaveAttribute('rel', 'noopener noreferrer'); - expect(screen.getByText('Link Text')).toBeInTheDocument(); + expect(screen.getByText('test')).toBeInTheDocument(); + }); + + it('opens a new window when clicked with type="window"', () => { + // Mock window.open + const mockOpen = vi.fn(); + vi.stubGlobal('open', mockOpen); + + // Mock window.screen + vi.stubGlobal('screen', { width: 1024, height: 768 }); + + render(); + + const linkElement = screen.getByText('Deposit Funds'); + fireEvent.click(linkElement); + + // Check if window.open was called with the correct arguments + expect(mockOpen).toHaveBeenCalledWith( + expect.stringContaining('http://keys.coinbase.com/funding'), + 'Coinbase Fund Wallet', + expect.stringContaining('width=600,height=700'), + ); + + // Clean up + vi.unstubAllGlobals(); }); }); diff --git a/src/wallet/components/WalletDropdownFundLink.tsx b/src/wallet/components/WalletDropdownFundLink.tsx index 01deaeb40c..6c2b2359cc 100644 --- a/src/wallet/components/WalletDropdownFundLink.tsx +++ b/src/wallet/components/WalletDropdownFundLink.tsx @@ -1,15 +1,17 @@ import { isValidElement, useMemo } from 'react'; import { FundWalletSvg } from '../../internal/svg/fundWallet'; -import { cn, pressable, text } from '../../styles/theme'; -import type { WalletDropdownLinkReact } from '../types'; +import { cn, pressable, text as themeText } from '../../styles/theme'; +import type { WalletDropdownFundLinkReact } from '../types'; export function WalletDropdownFundLink({ - children, className, icon, rel, target, -}: WalletDropdownLinkReact) { + text = 'Deposit Funds', + type = 'tab', + size = 'm', +}: WalletDropdownFundLinkReact) { const iconSvg = useMemo(() => { if (icon === undefined) { return FundWalletSvg; @@ -21,24 +23,52 @@ export function WalletDropdownFundLink({ const currentURL = window.location.href; const tabName = document.title; + const windowSizes: Record< + 's' | 'm' | 'l', + { + width: number; + height: number; + } + > = { + s: { width: 400, height: 500 }, + m: { width: 600, height: 700 }, + l: { width: 800, height: 900 }, + }; + + const handleClick = (e: React.MouseEvent) => { + e.preventDefault(); + const url = `http://keys.coinbase.com/funding?dappName=${tabName}&dappUrl=${currentURL}`; + const { width, height } = windowSizes[size]; + const left = (window.screen.width - width) / 2; + const top = (window.screen.height - height) / 2; + const windowFeatures = `width=${width},height=${height},resizable,scrollbars=yes,status=1,left=${left},top=${top}`; + window.open(url, 'Coinbase Fund Wallet', windowFeatures); + }; + + const commonProps = { + className: cn( + pressable.default, + 'relative flex items-center px-4 py-3', + className, + ), + }; + + const linkProps = + type === 'tab' + ? { + ...commonProps, + href: `http://keys.coinbase.com/funding?dappName=${tabName}&dappUrl=${currentURL}`, + target, + rel, + } + : { ...commonProps, onClick: handleClick }; return ( - +
{iconSvg}
- - {children || 'Deposit Funds'} - + {text}
); }