From 4f14f1c719e98dbbda6e7301e8734f3a678ce28f Mon Sep 17 00:00:00 2001 From: katspaugh <381895+katspaugh@users.noreply.github.com> Date: Mon, 9 Dec 2024 11:40:33 +0100 Subject: [PATCH 1/5] Refactor: Box flex -> Stack --- src/components/balances/AssetsTable/index.tsx | 6 +- .../balances/TokenListSelect/index.tsx | 6 +- src/components/balances/TokenMenu/index.tsx | 6 +- .../batch/BatchIndicator/BatchTooltip.tsx | 6 +- .../batch/BatchSidebar/EmptyBatch.tsx | 10 +- .../common/ConnectWallet/AccountCenter.tsx | 6 +- .../common/CopyAddressButton/index.tsx | 6 +- .../common/CopyTooltip/ConfirmCopyModal.tsx | 10 +- src/components/common/Countdown/index.tsx | 6 +- .../EthHashInfo/SrcEthHashInfo/index.tsx | 6 +- .../common/ExplorerButton/index.tsx | 6 +- src/components/common/Mui/index.test.tsx | 2 +- src/components/common/Mui/index.tsx | 96 +++++++++++++++++++ .../common/OnboardingTooltip/index.tsx | 6 +- src/components/common/PaginatedTxns/index.tsx | 6 +- .../common/SpendingLimitLabel/index.tsx | 10 +- src/components/common/WalletInfo/index.tsx | 10 +- src/components/dashboard/Assets/index.tsx | 10 +- .../PendingTxs/PendingTxListItem.tsx | 6 +- .../dashboard/PendingTxs/PendingTxsList.tsx | 6 +- .../create/steps/SetNameStep/index.tsx | 6 +- .../create/steps/StatusStep/StatusMessage.tsx | 6 +- .../load/steps/SafeOwnerStep/index.tsx | 6 +- .../load/steps/SafeReviewStep/index.tsx | 6 +- src/components/nfts/NftGrid/index.tsx | 13 +-- .../safe-apps/AddCustomSafeAppCard/index.tsx | 6 +- .../AppFrame/TransactionQueueBar/index.tsx | 15 ++- .../safe-apps/SafeAppActionButtons/index.tsx | 9 +- .../safe-apps/SafeAppLandingPage/TryDemo.tsx | 6 +- .../safe-apps/SafeAppPreviewDrawer/index.tsx | 7 +- .../SafeAppSocialLinksCard/index.tsx | 18 ++-- .../safe-apps/SafeAppsFilters/index.tsx | 6 +- .../SafeAppsInfoModal/AllowedFeaturesList.tsx | 6 +- .../safe-apps/SafeAppsInfoModal/Slider.tsx | 6 +- .../SafeAppsInfoModal/UnknownAppWarning.tsx | 6 +- .../safe-messages/MsgDetails/index.tsx | 6 +- .../settings/ProposersList/index.tsx | 6 +- .../GlobalPushNotifications.tsx | 6 +- .../settings/SecurityLogin/index.tsx | 6 +- .../SpendingLimits/SpendingLimitsTable.tsx | 14 +-- .../sidebar/QrCodeButton/QrModal.tsx | 6 +- .../SignedMessagesHelpLink/index.tsx | 6 +- .../TxDetails/TxData/Transfer/index.tsx | 14 +-- .../transactions/TxSummary/QueueActions.tsx | 6 +- .../tx-flow/common/TxNonce/index.tsx | 6 +- .../CancelRecovery/CancelRecoveryOverview.tsx | 10 +- .../flows/NestedTxSuccessScreen/index.tsx | 14 +-- .../tx-flow/flows/ReplaceTx/DeleteTxModal.tsx | 5 +- .../tx-flow/flows/ReplaceTx/index.tsx | 6 +- .../tx-flow/flows/SignMessage/index.tsx | 6 +- .../ReviewSignMessageOnChain.tsx | 8 +- .../ApprovalEditor/EditableApprovalItem.tsx | 6 +- .../SignOrExecuteSkeleton.tsx | 6 +- .../tx/SignOrExecuteForm/SignerForm/index.tsx | 6 +- .../welcome/WelcomeLogin/WalletLogin.tsx | 6 +- .../wrappers/DisclaimerWrapper/index.tsx | 2 +- .../wrappers/SanctionWrapper/index.tsx | 2 +- .../counterfactual/ActivateAccountFlow.tsx | 10 +- .../components/DataWidget/index.tsx | 6 +- .../components/OrderByButton/index.tsx | 6 +- src/features/myAccounts/index.tsx | 5 +- .../components/DeleteProposerDialog.tsx | 5 +- .../proposers/components/UpsertProposer.tsx | 5 +- .../components/RecoverySettings/index.tsx | 6 +- .../components/RecoverySummary/index.tsx | 6 +- .../components/EnableAccountBanner/index.tsx | 6 +- .../speedup/components/SpeedUpModal.tsx | 10 +- .../components/StakingTxExitDetails/index.tsx | 6 +- .../StakingTxWithdrawDetails/index.tsx | 6 +- .../swap/components/SwapProgress/index.tsx | 2 +- .../OutreachPopup/OutreachPopup.tsx | 8 +- .../components/WcHints/index.tsx | 6 +- src/pages/_offline.tsx | 10 +- src/pages/apps/open.tsx | 6 +- 74 files changed, 359 insertions(+), 251 deletions(-) diff --git a/src/components/balances/AssetsTable/index.tsx b/src/components/balances/AssetsTable/index.tsx index 077bfed573..7bf2a85c36 100644 --- a/src/components/balances/AssetsTable/index.tsx +++ b/src/components/balances/AssetsTable/index.tsx @@ -1,6 +1,6 @@ import CheckBalance from '@/features/counterfactual/CheckBalance' import { type ReactElement } from 'react' -import { Box, IconButton, Checkbox, Skeleton, SvgIcon, Tooltip, Typography } from '@mui/material' +import { Stack, IconButton, Checkbox, Skeleton, SvgIcon, Tooltip, Typography } from '@mui/material' import type { TokenInfo } from '@safe-global/safe-gateway-typescript-sdk' import { TokenType } from '@safe-global/safe-gateway-typescript-sdk' import css from './styles.module.css' @@ -185,7 +185,7 @@ const AssetsTable = ({ sticky: true, collapsed: item.tokenInfo.address === hidingAsset, content: ( - + <> @@ -209,7 +209,7 @@ const AssetsTable = ({ )} - + ), }, }, diff --git a/src/components/balances/TokenListSelect/index.tsx b/src/components/balances/TokenListSelect/index.tsx index e300bc4e16..83edc97a84 100644 --- a/src/components/balances/TokenListSelect/index.tsx +++ b/src/components/balances/TokenListSelect/index.tsx @@ -2,7 +2,7 @@ import { useAppDispatch, useAppSelector } from '@/store' import { selectSettings, setTokenList, TOKEN_LISTS } from '@/store/settingsSlice' import { FEATURES } from '@/utils/chains' import type { SelectChangeEvent } from '@mui/material' -import { Box, SvgIcon, Tooltip, Typography, FormControl, InputLabel, Select, MenuItem } from '@mui/material' +import { Stack, SvgIcon, Tooltip, Typography, FormControl, InputLabel, Select, MenuItem } from '@mui/material' import InfoIcon from '@/public/images/notifications/info.svg' import ExternalLink from '@/components/common/ExternalLink' import { OnboardingTooltip } from '@/components/common/OnboardingTooltip' @@ -58,7 +58,7 @@ const TokenListSelect = () => { > - + {TokenListLabel.TRUSTED} { - + diff --git a/src/components/balances/TokenMenu/index.tsx b/src/components/balances/TokenMenu/index.tsx index 10be9fbfd4..dde76fb2da 100644 --- a/src/components/balances/TokenMenu/index.tsx +++ b/src/components/balances/TokenMenu/index.tsx @@ -2,7 +2,7 @@ import { Sticky } from '@/components/common/Sticky' import Track from '@/components/common/Track' import { ASSETS_EVENTS } from '@/services/analytics' import { VisibilityOffOutlined } from '@mui/icons-material' -import { Box, Typography, Button } from '@mui/material' +import { Stack, Typography, Button, Box } from '@mui/material' import css from './styles.module.css' @@ -31,7 +31,7 @@ const TokenMenu = ({ {selectedAssetCount} {selectedAssetCount === 1 ? 'token' : 'tokens'} selected - + - + ) diff --git a/src/components/batch/BatchIndicator/BatchTooltip.tsx b/src/components/batch/BatchIndicator/BatchTooltip.tsx index 9f9718886f..7b499536dd 100644 --- a/src/components/batch/BatchIndicator/BatchTooltip.tsx +++ b/src/components/batch/BatchIndicator/BatchTooltip.tsx @@ -1,5 +1,5 @@ import { type ReactElement, useEffect, useState } from 'react' -import { Box, SvgIcon } from '@mui/material' +import { Box, Stack, SvgIcon } from '@mui/material' import SuccessIcon from '@/public/images/common/success.svg' import { TxEvent, txSubscribe } from '@/services/tx/txEvents' @@ -25,12 +25,12 @@ const BatchTooltip = ({ children }: { children: ReactElement }) => { open={showTooltip} onClose={() => setShowTooltip(false)} title={ - + Transaction is added to batch - + } >
{children}
diff --git a/src/components/batch/BatchSidebar/EmptyBatch.tsx b/src/components/batch/BatchSidebar/EmptyBatch.tsx index ae65fcf4dd..2473fa6255 100644 --- a/src/components/batch/BatchSidebar/EmptyBatch.tsx +++ b/src/components/batch/BatchSidebar/EmptyBatch.tsx @@ -4,10 +4,10 @@ import InfoIcon from '@/public/images/notifications/info.svg' import AssetsIcon from '@/public/images/sidebar/assets.svg' import AppsIcon from '@/public/images/apps/apps-icon.svg' import SettingsIcon from '@/public/images/sidebar/settings.svg' -import { Box, SvgIcon, Typography } from '@mui/material' +import { Box, Stack, SvgIcon, Typography } from '@mui/material' const EmptyBatch = ({ children }: { children: ReactNode }) => ( - + @@ -28,7 +28,7 @@ const EmptyBatch = ({ children }: { children: ReactNode }) => ( What type of transactions can you add to the batch? - +
Token and NFT transfers
@@ -43,9 +43,9 @@ const EmptyBatch = ({ children }: { children: ReactNode }) => (
Safe Account settings
-
+
-
+ ) export default EmptyBatch diff --git a/src/components/common/ConnectWallet/AccountCenter.tsx b/src/components/common/ConnectWallet/AccountCenter.tsx index b625c5c5c1..05d15bbc11 100644 --- a/src/components/common/ConnectWallet/AccountCenter.tsx +++ b/src/components/common/ConnectWallet/AccountCenter.tsx @@ -1,6 +1,6 @@ import type { MouseEvent } from 'react' import { useState } from 'react' -import { Box, ButtonBase, Paper, Popover } from '@mui/material' +import { Stack, ButtonBase, Paper, Popover, Box } from '@mui/material' import css from '@/components/common/ConnectWallet/styles.module.css' import ExpandLessIcon from '@mui/icons-material/ExpandLess' import ExpandMoreIcon from '@mui/icons-material/ExpandMore' @@ -35,9 +35,9 @@ export const AccountCenter = ({ wallet }: { wallet: ConnectedWallet }) => { - + {open ? : } - + diff --git a/src/components/common/CopyAddressButton/index.tsx b/src/components/common/CopyAddressButton/index.tsx index 83a378fa73..36945a9e2c 100644 --- a/src/components/common/CopyAddressButton/index.tsx +++ b/src/components/common/CopyAddressButton/index.tsx @@ -1,5 +1,5 @@ import { checksumAddress } from '@/utils/addresses' -import { Box, Typography } from '@mui/material' +import { Stack, Typography } from '@mui/material' import type { ReactNode, ReactElement } from 'react' import CopyButton from '../CopyButton' import EthHashInfo from '../EthHashInfo' @@ -22,7 +22,7 @@ const CopyAddressButton = ({ const checksummedAddress = checksumAddress(address) const dialogContent = trusted ? undefined : ( - + - + ) return ( diff --git a/src/components/common/CopyTooltip/ConfirmCopyModal.tsx b/src/components/common/CopyTooltip/ConfirmCopyModal.tsx index d659346f01..37e8e9c626 100644 --- a/src/components/common/CopyTooltip/ConfirmCopyModal.tsx +++ b/src/components/common/CopyTooltip/ConfirmCopyModal.tsx @@ -9,7 +9,7 @@ import { DialogContent, DialogActions, Button, - Box, + Stack, } from '@mui/material' import WarningIcon from '@/public/images/notifications/warning.svg' import { type ReactElement, useEffect, type SyntheticEvent } from 'react' @@ -35,7 +35,7 @@ const ConfirmCopyModal = ({ open, onClose, onCopy, children }: ConfirmCopyModalP return ( - + Before you copy @@ -43,13 +43,13 @@ const ConfirmCopyModal = ({ open, onClose, onCopy, children }: ConfirmCopyModalP - + {children} - + - + ) diff --git a/src/components/common/Countdown/index.tsx b/src/components/common/Countdown/index.tsx index de4b9a37ca..ca81a87181 100644 --- a/src/components/common/Countdown/index.tsx +++ b/src/components/common/Countdown/index.tsx @@ -1,4 +1,4 @@ -import { Typography, Box } from '@mui/material' +import { Typography, Stack } from '@mui/material' import type { ReactElement } from 'react' export function _getCountdown(seconds: number): { days: number; hours: number; minutes: number } { @@ -31,11 +31,11 @@ export function Countdown({ seconds }: { seconds: number }): ReactElement | null const { days, hours, minutes } = _getCountdown(seconds) return ( - + - + ) } diff --git a/src/components/common/EthHashInfo/SrcEthHashInfo/index.tsx b/src/components/common/EthHashInfo/SrcEthHashInfo/index.tsx index 39cb29ae58..f380bb08e4 100644 --- a/src/components/common/EthHashInfo/SrcEthHashInfo/index.tsx +++ b/src/components/common/EthHashInfo/SrcEthHashInfo/index.tsx @@ -2,7 +2,7 @@ import classnames from 'classnames' import type { ReactNode, ReactElement, SyntheticEvent } from 'react' import { isAddress } from 'ethers' import { useTheme } from '@mui/material/styles' -import { Box, SvgIcon, Tooltip } from '@mui/material' +import { Box, Stack, SvgIcon, Tooltip } from '@mui/material' import AddressBookIcon from '@/public/images/sidebar/address-book.svg' import useMediaQuery from '@mui/material/useMediaQuery' import Identicon from '../../Identicon' @@ -84,7 +84,7 @@ const SrcEthHashInfo = ({ {name && ( - + {name} @@ -96,7 +96,7 @@ const SrcEthHashInfo = ({ )} - + )}
diff --git a/src/components/common/ExplorerButton/index.tsx b/src/components/common/ExplorerButton/index.tsx index 4bc6db7373..94d2fe0896 100644 --- a/src/components/common/ExplorerButton/index.tsx +++ b/src/components/common/ExplorerButton/index.tsx @@ -1,5 +1,5 @@ import type { ReactElement, ComponentType, SyntheticEvent } from 'react' -import { Box, IconButton, SvgIcon, Tooltip, Typography } from '@mui/material' +import { Stack, IconButton, SvgIcon, Tooltip, Typography } from '@mui/material' import LinkIcon from '@/public/images/common/link.svg' import Link from 'next/link' @@ -44,13 +44,13 @@ const ExplorerButton = ({ href={href} onClick={onClick} > - + View on explorer - + ) } diff --git a/src/components/common/Mui/index.test.tsx b/src/components/common/Mui/index.test.tsx index aaa6f4030f..e332f51ccf 100644 --- a/src/components/common/Mui/index.test.tsx +++ b/src/components/common/Mui/index.test.tsx @@ -18,7 +18,7 @@ describe('Box Component', () => { }) it('applies flex props correctly', () => { - const { getByTestId } = render() + const { getByTestId } = render() const box = getByTestId('box') expect(box).toHaveStyle('display: flex') expect(box).toHaveStyle('flex-direction: column') diff --git a/src/components/common/Mui/index.tsx b/src/components/common/Mui/index.tsx index 1c1189f084..d59b6b37d6 100644 --- a/src/components/common/Mui/index.tsx +++ b/src/components/common/Mui/index.tsx @@ -1,4 +1,6 @@ import { default as MuiBox, type BoxProps } from '@mui/material/Box' +import { type StackProps } from '@mui/material/Stack' + import { default as MuiTypograpahy, type TypographyProps } from '@mui/material/Typography' export * from '@mui/material/index' @@ -101,6 +103,100 @@ export const Box = ({ ) } +export const Stack = ({ + m, + mt, + mr, + mb, + ml, + mx, + my, + p, + pt, + pr, + pb, + pl, + px, + py, + width, + height, + minWidth, + minHeight, + maxWidth, + maxHeight, + flex, + flexWrap, + flexGrow, + flexShrink, + alignItems, + justifyItems, + alignContent, + justifyContent, + columnGap, + color, + textAlign, + position, + overflow, + textOverflow, + border, + borderColor, + borderRadius, + borderBottom, + bgcolor, + gridArea, + lineHeight, + ...props +}: StackProps['sx'] & StackProps) => { + return ( + + ) +} + export const Typography = ({ m, mt, diff --git a/src/components/common/OnboardingTooltip/index.tsx b/src/components/common/OnboardingTooltip/index.tsx index 459ff786a9..3ecd193f94 100644 --- a/src/components/common/OnboardingTooltip/index.tsx +++ b/src/components/common/OnboardingTooltip/index.tsx @@ -1,7 +1,7 @@ import type { ReactElement } from 'react' import useLocalStorage from '@/services/local-storage/useLocalStorage' import type { TooltipProps } from '@mui/material' -import { Box, Button, SvgIcon, Tooltip } from '@mui/material' +import { Stack, Button, SvgIcon, Tooltip } from '@mui/material' import InfoIcon from '@/public/images/notifications/info.svg' import { useDarkMode } from '@/hooks/useDarkMode' @@ -39,7 +39,7 @@ export const OnboardingTooltip = ({ placement={placement} arrow title={ - +
{text}
-
+ } > {children} diff --git a/src/components/common/PaginatedTxns/index.tsx b/src/components/common/PaginatedTxns/index.tsx index 9ecf0284e9..af11e3374d 100644 --- a/src/components/common/PaginatedTxns/index.tsx +++ b/src/components/common/PaginatedTxns/index.tsx @@ -1,5 +1,5 @@ import { type ReactElement, useEffect, useState } from 'react' -import { Box } from '@mui/material' +import { Box, Stack } from '@mui/material' import TxList from '@/components/transactions/TxList' import { type TransactionListPage } from '@safe-global/safe-gateway-typescript-sdk' import ErrorMessage from '@/components/tx/ErrorMessage' @@ -45,9 +45,9 @@ const TxPage = ({ return ( <> {isFirstPage && filter && page && ( - + {getFilterResultCount(filter, page)} - + )} {page && page.results.length > 0 && } diff --git a/src/components/common/SpendingLimitLabel/index.tsx b/src/components/common/SpendingLimitLabel/index.tsx index eecaba68b7..e7671327d1 100644 --- a/src/components/common/SpendingLimitLabel/index.tsx +++ b/src/components/common/SpendingLimitLabel/index.tsx @@ -1,18 +1,18 @@ import React, { type ReactElement } from 'react' -import { Box, SvgIcon, Typography } from '@mui/material' +import { Stack, SvgIcon, Typography } from '@mui/material' +import type { StackProps } from '@mui/material/Stack' import SpeedIcon from '@/public/images/settings/spending-limit/speed.svg' -import type { BoxProps } from '@mui/system' const SpendingLimitLabel = ({ label, isOneTime = false, ...rest -}: { label: string | ReactElement; isOneTime?: boolean } & BoxProps) => { +}: { label: string | ReactElement; isOneTime?: boolean } & StackProps) => { return ( - + {!isOneTime && } {typeof label === 'string' ? {label} : label} - + ) } diff --git a/src/components/common/WalletInfo/index.tsx b/src/components/common/WalletInfo/index.tsx index 23c1af8cbd..803082bc4f 100644 --- a/src/components/common/WalletInfo/index.tsx +++ b/src/components/common/WalletInfo/index.tsx @@ -1,6 +1,6 @@ import WalletBalance from '@/components/common/WalletBalance' import { WalletIdenticon } from '@/components/common/WalletOverview' -import { Box, Button, Typography } from '@mui/material' +import { Stack, Button, Typography, Box } from '@mui/material' import css from './styles.module.css' import EthHashInfo from '@/components/common/EthHashInfo' import ChainSwitcher from '@/components/common/ChainSwitcher' @@ -42,7 +42,7 @@ export const WalletInfo = ({ wallet, balance, currentChainId, onboard, addressBo return ( <> - + @@ -56,7 +56,7 @@ export const WalletInfo = ({ wallet, balance, currentChainId, onboard, addressBo prefix={prefix} /> - + @@ -84,7 +84,7 @@ export const WalletInfo = ({ wallet, balance, currentChainId, onboard, addressBo - + - + ) } diff --git a/src/components/dashboard/Assets/index.tsx b/src/components/dashboard/Assets/index.tsx index 12aca61614..533844181c 100644 --- a/src/components/dashboard/Assets/index.tsx +++ b/src/components/dashboard/Assets/index.tsx @@ -1,5 +1,5 @@ import { useMemo } from 'react' -import { Box, Skeleton, Typography, Paper } from '@mui/material' +import { Stack, Skeleton, Typography, Paper, Box } from '@mui/material' import type { SafeBalanceResponse } from '@safe-global/safe-gateway-typescript-sdk' import useBalances from '@/hooks/useBalances' import FiatValue from '@/components/common/FiatValue' @@ -37,9 +37,9 @@ const NoAssets = () => ( Add funds directly from your bank account or copy your address to send tokens from a different account. - + - + ) @@ -72,11 +72,11 @@ const AssetList = ({ items }: { items: SafeBalanceResponse['items'] }) => { const isSwapFeatureEnabled = useIsSwapFeatureEnabled() return ( - + {items.map((item) => ( ))} - + ) } diff --git a/src/components/dashboard/PendingTxs/PendingTxListItem.tsx b/src/components/dashboard/PendingTxs/PendingTxListItem.tsx index c3e098ed3e..85a99a0c75 100644 --- a/src/components/dashboard/PendingTxs/PendingTxListItem.tsx +++ b/src/components/dashboard/PendingTxs/PendingTxListItem.tsx @@ -4,7 +4,7 @@ import type { ReactElement } from 'react' import { useMemo } from 'react' import ChevronRight from '@mui/icons-material/ChevronRight' import type { TransactionSummary } from '@safe-global/safe-gateway-typescript-sdk' -import { Box } from '@mui/material' +import { Box, Stack } from '@mui/material' import { isMultisigExecutionInfo } from '@/utils/transaction-guards' import TxInfo from '@/components/transactions/TxInfo' import TxType from '@/components/transactions/TxType' @@ -48,7 +48,7 @@ const PendingTx = ({ transaction }: PendingTxType): ReactElement => {
- + {isMultisigExecutionInfo(transaction.executionInfo) && ( { )} - + ) diff --git a/src/components/dashboard/PendingTxs/PendingTxsList.tsx b/src/components/dashboard/PendingTxs/PendingTxsList.tsx index ce6e96bc1a..5b9ab71d62 100644 --- a/src/components/dashboard/PendingTxs/PendingTxsList.tsx +++ b/src/components/dashboard/PendingTxs/PendingTxsList.tsx @@ -3,7 +3,7 @@ import { useMemo } from 'react' import { useRouter } from 'next/router' import dynamic from 'next/dynamic' import { getLatestTransactions } from '@/utils/tx-list' -import { Box, Skeleton, Typography } from '@mui/material' +import { Stack, Skeleton, Typography } from '@mui/material' import { Card, ViewAllLink, WidgetBody, WidgetContainer } from '../styled' import PendingTxListItem from './PendingTxListItem' import useTxQueue from '@/hooks/useTxQueue' @@ -24,13 +24,13 @@ const MAX_TXS = 4 const EmptyState = () => { return ( - + This Safe Account has no queued transactions - + ) } diff --git a/src/components/new-safe/create/steps/SetNameStep/index.tsx b/src/components/new-safe/create/steps/SetNameStep/index.tsx index 88df9c58c7..0012094f64 100644 --- a/src/components/new-safe/create/steps/SetNameStep/index.tsx +++ b/src/components/new-safe/create/steps/SetNameStep/index.tsx @@ -1,4 +1,4 @@ -import { InputAdornment, Tooltip, SvgIcon, Typography, Box, Divider, Button, Grid } from '@mui/material' +import { InputAdornment, Tooltip, SvgIcon, Typography, Stack, Divider, Button, Grid, Box } from '@mui/material' import { FormProvider, useForm, useWatch } from 'react-hook-form' import { useMnemonicSafeName } from '@/hooks/useMnemonicName' import InfoIcon from '@/public/images/notifications/info.svg' @@ -155,14 +155,14 @@ function SetNameStep({ - + - + diff --git a/src/components/new-safe/create/steps/StatusStep/StatusMessage.tsx b/src/components/new-safe/create/steps/StatusStep/StatusMessage.tsx index bf681f515d..0a8714a3ba 100644 --- a/src/components/new-safe/create/steps/StatusStep/StatusMessage.tsx +++ b/src/components/new-safe/create/steps/StatusStep/StatusMessage.tsx @@ -4,7 +4,7 @@ import { SafeCreationEvent } from '@/features/counterfactual/services/safeCreati import type { UndeployedSafe } from '@/features/counterfactual/store/undeployedSafesSlice' import { useCurrentChain } from '@/hooks/useChains' import { getBlockExplorerLink } from '@/utils/chains' -import { Box, Typography } from '@mui/material' +import { Box, Stack, Typography } from '@mui/material' import FailedIcon from '@/public/images/common/tx-failed.svg' const getStep = (status: SafeCreationEvent) => { @@ -64,9 +64,9 @@ const StatusMessage = ({ return ( <> - + {isError ? : } - + {stepInfo.description} diff --git a/src/components/new-safe/load/steps/SafeOwnerStep/index.tsx b/src/components/new-safe/load/steps/SafeOwnerStep/index.tsx index c59bcbb332..5c7a5ef2eb 100644 --- a/src/components/new-safe/load/steps/SafeOwnerStep/index.tsx +++ b/src/components/new-safe/load/steps/SafeOwnerStep/index.tsx @@ -1,7 +1,7 @@ import React, { useEffect } from 'react' import { getSafeInfo, type SafeInfo } from '@safe-global/safe-gateway-typescript-sdk' import { FormProvider, useFieldArray, useForm } from 'react-hook-form' -import { Box, Button, Divider } from '@mui/material' +import { Stack, Button, Divider, Box } from '@mui/material' import type { StepRenderProps } from '@/components/new-safe/CardStepper/useCardStepper' import type { LoadSafeFormData } from '@/components/new-safe/load' @@ -74,14 +74,14 @@ const SafeOwnerStep = ({ data, onSubmit, onBack }: StepRenderProps - + - + diff --git a/src/components/new-safe/load/steps/SafeReviewStep/index.tsx b/src/components/new-safe/load/steps/SafeReviewStep/index.tsx index cd44eb6d41..2823e02e10 100644 --- a/src/components/new-safe/load/steps/SafeReviewStep/index.tsx +++ b/src/components/new-safe/load/steps/SafeReviewStep/index.tsx @@ -1,5 +1,5 @@ import React from 'react' -import { Box, Button, Divider, Grid, Typography } from '@mui/material' +import { Stack, Button, Divider, Grid, Typography, Box } from '@mui/material' import type { StepRenderProps } from '@/components/new-safe/CardStepper/useCardStepper' import type { LoadSafeFormData } from '@/components/new-safe/load' @@ -127,14 +127,14 @@ const SafeReviewStep = ({ data, onBack }: StepRenderProps) => - + - + ) diff --git a/src/components/nfts/NftGrid/index.tsx b/src/components/nfts/NftGrid/index.tsx index e35662b966..6795576941 100644 --- a/src/components/nfts/NftGrid/index.tsx +++ b/src/components/nfts/NftGrid/index.tsx @@ -19,6 +19,7 @@ import { TextField, Typography, Tooltip, + Stack, } from '@mui/material' import FilterAltIcon from '@mui/icons-material/FilterAlt' import NftIcon from '@/public/images/common/nft.svg' @@ -152,7 +153,7 @@ const NftGrid = ({ }} > {headCell.id === 'collection' ? ( - + - + ) : headCell.id === 'links' ? ( linkTemplates ? ( <>Links @@ -202,7 +203,7 @@ const NftGrid = ({ {/* Collection name */} - + {item.imageUri ? activeNftIcon : inactiveNftIcon}
@@ -218,7 +219,7 @@ const NftGrid = ({ />
-
+
{/* Token ID */} @@ -230,13 +231,13 @@ const NftGrid = ({ {/* Links */} - + {linkTemplates?.map(({ title, logo, getUrl }) => ( {title} ))} - + {/* Checkbox */} diff --git a/src/components/safe-apps/AddCustomSafeAppCard/index.tsx b/src/components/safe-apps/AddCustomSafeAppCard/index.tsx index 181b99dbab..93a18545bf 100644 --- a/src/components/safe-apps/AddCustomSafeAppCard/index.tsx +++ b/src/components/safe-apps/AddCustomSafeAppCard/index.tsx @@ -1,11 +1,11 @@ import { useState } from 'react' import Card from '@mui/material/Card' -import Box from '@mui/material/Box' import Button from '@mui/material/Button' import type { SafeAppData } from '@safe-global/safe-gateway-typescript-sdk' import AddCustomAppIcon from '@/public/images/apps/add-custom-app.svg' import { AddCustomAppModal } from '@/components/safe-apps/AddCustomAppModal' +import Stack from '@mui/material/Stack' type Props = { onSave: (data: SafeAppData) => void; safeAppList: SafeAppData[] } @@ -15,7 +15,7 @@ const AddCustomSafeAppCard = ({ onSave, safeAppList }: Props) => { return ( <> - + {/* Add Custom Safe App Icon */} @@ -30,7 +30,7 @@ const AddCustomSafeAppCard = ({ onSave, safeAppList }: Props) => { > Add custom Safe App - + {/* Add Custom Safe App Modal */} diff --git a/src/components/safe-apps/AppFrame/TransactionQueueBar/index.tsx b/src/components/safe-apps/AppFrame/TransactionQueueBar/index.tsx index 25e1b3bc57..2ee0575746 100644 --- a/src/components/safe-apps/AppFrame/TransactionQueueBar/index.tsx +++ b/src/components/safe-apps/AppFrame/TransactionQueueBar/index.tsx @@ -1,5 +1,14 @@ import type { Dispatch, ReactElement, SetStateAction } from 'react' -import { Backdrop, Typography, Box, IconButton, Accordion, AccordionDetails, AccordionSummary } from '@mui/material' +import { + Backdrop, + Typography, + Stack, + IconButton, + Accordion, + AccordionDetails, + AccordionSummary, + Box, +} from '@mui/material' import { ClickAwayListener } from '@mui/material' import CloseIcon from '@mui/icons-material/Close' import ExpandLessIcon from '@mui/icons-material/ExpandLess' @@ -81,9 +90,9 @@ const TransactionQueueBar = ({ - + - + diff --git a/src/components/safe-apps/SafeAppActionButtons/index.tsx b/src/components/safe-apps/SafeAppActionButtons/index.tsx index 40fd557ec5..b1d0e63e43 100644 --- a/src/components/safe-apps/SafeAppActionButtons/index.tsx +++ b/src/components/safe-apps/SafeAppActionButtons/index.tsx @@ -1,8 +1,5 @@ import type { SafeAppData } from '@safe-global/safe-gateway-typescript-sdk' -import Box from '@mui/material/Box' -import IconButton from '@mui/material/IconButton' -import Tooltip from '@mui/material/Tooltip' -import SvgIcon from '@mui/material/SvgIcon' +import { Stack, IconButton, Tooltip, SvgIcon } from '@mui/material' import { useShareSafeAppUrl } from '@/components/safe-apps/hooks/useShareSafeAppUrl' import { SAFE_APPS_EVENTS, trackSafeAppEvent } from '@/services/analytics' @@ -37,7 +34,7 @@ const SafeAppActionButtons = ({ } return ( - + {/* Open the preview drawer */} {openPreviewDrawer && ( )} - + ) } diff --git a/src/components/safe-apps/SafeAppLandingPage/TryDemo.tsx b/src/components/safe-apps/SafeAppLandingPage/TryDemo.tsx index 3266a4237c..5f837c0a31 100644 --- a/src/components/safe-apps/SafeAppLandingPage/TryDemo.tsx +++ b/src/components/safe-apps/SafeAppLandingPage/TryDemo.tsx @@ -1,4 +1,4 @@ -import { Box, Button, Typography } from '@mui/material' +import { Stack, Button, Typography } from '@mui/material' import { CTA_HEIGHT, CTA_BUTTON_WIDTH } from '@/components/safe-apps/SafeAppLandingPage/constants' import Link from 'next/link' import type { LinkProps } from 'next/link' @@ -10,7 +10,7 @@ type Props = { } const TryDemo = ({ demoUrl, onClick }: Props) => ( - + Try the Safe App before using it @@ -20,7 +20,7 @@ const TryDemo = ({ demoUrl, onClick }: Props) => ( Try demo - + ) export { TryDemo } diff --git a/src/components/safe-apps/SafeAppPreviewDrawer/index.tsx b/src/components/safe-apps/SafeAppPreviewDrawer/index.tsx index 442d239e16..365fa48637 100644 --- a/src/components/safe-apps/SafeAppPreviewDrawer/index.tsx +++ b/src/components/safe-apps/SafeAppPreviewDrawer/index.tsx @@ -1,7 +1,7 @@ import Link from 'next/link' import { useRouter } from 'next/router' import Drawer from '@mui/material/Drawer' -import Box from '@mui/material/Box' +import Box from '@mui/material/Stack' import Typography from '@mui/material/Typography' import Button from '@mui/material/Button' import SvgIcon from '@mui/material/SvgIcon' @@ -19,6 +19,7 @@ import CloseIcon from '@/public/images/common/close.svg' import { useOpenedSafeApps } from '@/hooks/safe-apps/useOpenedSafeApps' import css from './styles.module.css' import { SAFE_APPS_EVENTS, SAFE_APPS_LABELS, trackSafeAppEvent } from '@/services/analytics' +import Stack from '@mui/material/Stack' type SafeAppPreviewDrawerProps = { safeApp?: SafeAppData @@ -46,7 +47,7 @@ const SafeAppPreviewDrawer = ({ isOpen, safeApp, isBookmarked, onClose, onBookma {/* Toolbar */} {safeApp && ( - + - + )} {/* Safe App Info */} diff --git a/src/components/safe-apps/SafeAppSocialLinksCard/index.tsx b/src/components/safe-apps/SafeAppSocialLinksCard/index.tsx index 36dea9290d..799c4b1f27 100644 --- a/src/components/safe-apps/SafeAppSocialLinksCard/index.tsx +++ b/src/components/safe-apps/SafeAppSocialLinksCard/index.tsx @@ -1,6 +1,5 @@ import Link from 'next/link' import Card from '@mui/material/Card' -import Box from '@mui/material/Box' import Typography from '@mui/material/Typography' import IconButton from '@mui/material/IconButton' import Divider from '@mui/material/Divider' @@ -13,6 +12,7 @@ import type { SafeAppData, SafeAppSocialProfile } from '@safe-global/safe-gatewa import DiscordIcon from '@/public/images/common/discord-icon.svg' import css from './styles.module.css' +import Stack from '@mui/material/Stack' type SafeAppSocialLinksCardProps = { safeApp: SafeAppData @@ -33,7 +33,7 @@ const SafeAppSocialLinksCard = ({ safeApp }: SafeAppSocialLinksCardProps) => { return ( - + {/* Team Link section */}
@@ -46,9 +46,9 @@ const SafeAppSocialLinksCard = ({ safeApp }: SafeAppSocialLinksCardProps) => { Get in touch with the team
-
+ - + {/* Social links section */} {hasSocialLinks && (
@@ -56,7 +56,7 @@ const SafeAppSocialLinksCard = ({ safeApp }: SafeAppSocialLinksCardProps) => { Social Media - + {discordSocialLink && ( @@ -80,7 +80,7 @@ const SafeAppSocialLinksCard = ({ safeApp }: SafeAppSocialLinksCardProps) => { )} - +
)} @@ -90,7 +90,7 @@ const SafeAppSocialLinksCard = ({ safeApp }: SafeAppSocialLinksCardProps) => { {/* Developer website section */} {developerWebsite && ( - + Website @@ -107,9 +107,9 @@ const SafeAppSocialLinksCard = ({ safeApp }: SafeAppSocialLinksCardProps) => { {developerWebsite} - +
)} -
+
) } diff --git a/src/components/safe-apps/SafeAppsFilters/index.tsx b/src/components/safe-apps/SafeAppsFilters/index.tsx index eec8c8b492..2798d8a7a3 100644 --- a/src/components/safe-apps/SafeAppsFilters/index.tsx +++ b/src/components/safe-apps/SafeAppsFilters/index.tsx @@ -8,7 +8,6 @@ import OutlinedInput from '@mui/material/OutlinedInput' import ListItemText from '@mui/material/ListItemText' import Select from '@mui/material/Select' import IconButton from '@mui/material/IconButton' -import Box from '@mui/material/Box' import Checkbox from '@mui/material/Checkbox' import FormLabel from '@mui/material/FormLabel' import FormControl from '@mui/material/FormControl' @@ -22,6 +21,7 @@ import { getUniqueTags } from '@/components/safe-apps/utils' import SearchIcon from '@/public/images/common/search.svg' import BatchIcon from '@/public/images/apps/batch-icon.svg' import css from './styles.module.css' +import Stack from '@mui/material/Stack' export type safeAppCatogoryOptionType = { label: string @@ -161,9 +161,9 @@ const SafeAppsFilters = ({ onChangeOptimizedWithBatch(value) }} label={ - + Batch transactions - + } /> diff --git a/src/components/safe-apps/SafeAppsInfoModal/AllowedFeaturesList.tsx b/src/components/safe-apps/SafeAppsInfoModal/AllowedFeaturesList.tsx index 5896697320..6ede236108 100644 --- a/src/components/safe-apps/SafeAppsInfoModal/AllowedFeaturesList.tsx +++ b/src/components/safe-apps/SafeAppsInfoModal/AllowedFeaturesList.tsx @@ -1,4 +1,4 @@ -import { Box, Typography, SvgIcon } from '@mui/material' +import { Stack, Typography, SvgIcon, Box } from '@mui/material' import ShieldIcon from '@/public/images/settings/permissions/shield.svg' import { getBrowserPermissionDisplayValues } from '@/hooks/safe-apps/permissions' @@ -34,7 +34,7 @@ const AllowedFeaturesList: React.FC = ({ This Safe App is requesting permission to use: - + {features .filter(({ feature }) => isBrowserFeature(feature)) .map(({ feature, checked }, index) => ( @@ -46,7 +46,7 @@ const AllowedFeaturesList: React.FC = ({ label={getBrowserPermissionDisplayValues(feature).displayName} /> ))} - + ) diff --git a/src/components/safe-apps/SafeAppsInfoModal/Slider.tsx b/src/components/safe-apps/SafeAppsInfoModal/Slider.tsx index d94d9b818f..174f0a5eb5 100644 --- a/src/components/safe-apps/SafeAppsInfoModal/Slider.tsx +++ b/src/components/safe-apps/SafeAppsInfoModal/Slider.tsx @@ -1,4 +1,4 @@ -import { Box, Button } from '@mui/material' +import { Stack, Button } from '@mui/material' import React, { useState, useEffect, useMemo } from 'react' import css from './styles.module.css' @@ -68,7 +68,7 @@ const Slider: React.FC = ({ onSlideChange, children, initialStep }) ))}
- + @@ -85,7 +85,7 @@ const Slider: React.FC = ({ onSlideChange, children, initialStep }) > Continue - + ) } diff --git a/src/components/safe-apps/SafeAppsInfoModal/UnknownAppWarning.tsx b/src/components/safe-apps/SafeAppsInfoModal/UnknownAppWarning.tsx index 837f8b3445..49c50aa870 100644 --- a/src/components/safe-apps/SafeAppsInfoModal/UnknownAppWarning.tsx +++ b/src/components/safe-apps/SafeAppsInfoModal/UnknownAppWarning.tsx @@ -1,5 +1,5 @@ import { useState } from 'react' -import { Box, Checkbox, FormControlLabel, Typography } from '@mui/material' +import { Stack, Checkbox, FormControlLabel, Typography, Box } from '@mui/material' import WarningAmberOutlinedIcon from '@mui/icons-material/WarningAmberOutlined' import lightPalette from '@/components/theme/lightPalette' import Domain from './Domain' @@ -18,7 +18,7 @@ const UnknownAppWarning = ({ url, onHideWarning }: UnknownAppWarningProps): Reac } return ( - + @@ -49,7 +49,7 @@ const UnknownAppWarning = ({ url, onHideWarning }: UnknownAppWarningProps): Reac /> )} - + ) } diff --git a/src/components/safe-messages/MsgDetails/index.tsx b/src/components/safe-messages/MsgDetails/index.tsx index db757ba5b9..bf83b0f901 100644 --- a/src/components/safe-messages/MsgDetails/index.tsx +++ b/src/components/safe-messages/MsgDetails/index.tsx @@ -1,5 +1,5 @@ import { useMemo, type ReactElement } from 'react' -import { Accordion, AccordionSummary, Typography, AccordionDetails, Box } from '@mui/material' +import { Accordion, AccordionSummary, Typography, AccordionDetails, Stack } from '@mui/material' import ExpandMoreIcon from '@mui/icons-material/ExpandMore' import CodeIcon from '@mui/icons-material/Code' import classNames from 'classnames' @@ -125,9 +125,9 @@ const MsgDetails = ({ msg }: { msg: SafeMessage }): ReactElement => {
{wallet && !isConfirmed && ( - + - + )}
diff --git a/src/components/settings/ProposersList/index.tsx b/src/components/settings/ProposersList/index.tsx index d35ccc76fa..8ab9b2b528 100644 --- a/src/components/settings/ProposersList/index.tsx +++ b/src/components/settings/ProposersList/index.tsx @@ -11,7 +11,7 @@ import useProposers from '@/hooks/useProposers' import AddIcon from '@/public/images/common/add.svg' import { SETTINGS_EVENTS } from '@/services/analytics' import { FEATURES } from '@/utils/chains' -import { Box, Button, Grid, Paper, SvgIcon, Typography } from '@mui/material' +import { Stack, Button, Grid, Paper, SvgIcon, Typography, Box } from '@mui/material' import EthHashInfo from '@/components/common/EthHashInfo' import ExternalLink from '@/components/common/ExternalLink' import { HelpCenterArticle } from '@/config/constants' @@ -83,7 +83,7 @@ const ProposersList = () => { return ( - + @@ -126,7 +126,7 @@ const ProposersList = () => { setIsAddDialogOpen(false)} onSuccess={() => setIsAddDialogOpen(false)} /> )} - + ) } diff --git a/src/components/settings/PushNotifications/GlobalPushNotifications.tsx b/src/components/settings/PushNotifications/GlobalPushNotifications.tsx index eb44de9c74..2aa83d61e2 100644 --- a/src/components/settings/PushNotifications/GlobalPushNotifications.tsx +++ b/src/components/settings/PushNotifications/GlobalPushNotifications.tsx @@ -1,6 +1,5 @@ import { selectUndeployedSafes, type UndeployedSafesState } from '@/features/counterfactual/store/undeployedSafesSlice' import { - Box, Grid, Paper, Typography, @@ -13,6 +12,7 @@ import { ListItemIcon, ListItemText, CircularProgress, + Stack, } from '@mui/material' import mapValues from 'lodash/mapValues' import difference from 'lodash/difference' @@ -388,7 +388,7 @@ export const GlobalPushNotifications = (): ReactElement | null => { My Safes Accounts ({totalNotifiableSafes}) - + {totalSignaturesRequired > 0 && ( We'll ask you to verify ownership of each Safe Account with your signature per chain{' '} @@ -403,7 +403,7 @@ export const GlobalPushNotifications = (): ReactElement | null => { )} - + diff --git a/src/components/settings/SecurityLogin/index.tsx b/src/components/settings/SecurityLogin/index.tsx index d2ba01e986..0d66c2b13f 100644 --- a/src/components/settings/SecurityLogin/index.tsx +++ b/src/components/settings/SecurityLogin/index.tsx @@ -1,4 +1,4 @@ -import { Box } from '@mui/material' +import { Stack } from '@mui/material' import dynamic from 'next/dynamic' import { useIsRecoverySupported } from '@/features/recovery/hooks/useIsRecoverySupported' import SecuritySettings from '../SecuritySettings' @@ -11,11 +11,11 @@ const SecurityLogin = () => { const router = useRouter() return ( - + {isRecoverySupported && router.query.safe ? : null} - + ) } diff --git a/src/components/settings/SpendingLimits/SpendingLimitsTable.tsx b/src/components/settings/SpendingLimits/SpendingLimitsTable.tsx index d9f18a3b47..74488d8474 100644 --- a/src/components/settings/SpendingLimits/SpendingLimitsTable.tsx +++ b/src/components/settings/SpendingLimits/SpendingLimitsTable.tsx @@ -1,7 +1,7 @@ import EnhancedTable from '@/components/common/EnhancedTable' import DeleteIcon from '@/public/images/common/delete.svg' import { safeFormatUnits } from '@/utils/formatters' -import { Box, IconButton, Skeleton, SvgIcon, Typography } from '@mui/material' +import { Stack, IconButton, Skeleton, SvgIcon, Typography } from '@mui/material' import { relativeTime } from '@/utils/date' import EthHashInfo from '@/components/common/EthHashInfo' import { useContext, useMemo } from 'react' @@ -20,7 +20,7 @@ const SKELETON_ROWS = new Array(3).fill('').map(() => { beneficiary: { rawValue: '0x', content: ( - +
@@ -30,18 +30,18 @@ const SKELETON_ROWS = new Array(3).fill('').map(() => {
-
+ ), }, spent: { rawValue: '0', content: ( - + - + ), }, resetTime: { @@ -97,10 +97,10 @@ export const SpendingLimitsTable = ({ spent: { rawValue: spendingLimit.spent, content: ( - + {`${formattedSpent} of ${formattedAmount} ${spendingLimit.token.symbol}`} - + ), }, resetTime: { diff --git a/src/components/sidebar/QrCodeButton/QrModal.tsx b/src/components/sidebar/QrCodeButton/QrModal.tsx index 04ec8df5ba..10f2987a97 100644 --- a/src/components/sidebar/QrCodeButton/QrModal.tsx +++ b/src/components/sidebar/QrCodeButton/QrModal.tsx @@ -1,5 +1,5 @@ import { type ReactElement } from 'react' -import { Box, Switch, DialogContent, FormControlLabel, Typography } from '@mui/material' +import { Stack, Switch, DialogContent, FormControlLabel, Typography, Box } from '@mui/material' import ModalDialog from '@/components/common/ModalDialog' import useSafeAddress from '@/hooks/useSafeAddress' import { useCurrentChain } from '@/hooks/useChains' @@ -30,7 +30,7 @@ const QrModal = ({ onClose }: { onClose: () => void }): ReactElement => { Only send {nativeToken} and tokens (e.g. ERC20, ERC721) to this address. - + @@ -55,7 +55,7 @@ const QrModal = ({ onClose }: { onClose: () => void }): ReactElement => { showCopyButton /> -
+ ) diff --git a/src/components/transactions/SignedMessagesHelpLink/index.tsx b/src/components/transactions/SignedMessagesHelpLink/index.tsx index 6c3cfafe14..9725c3034b 100644 --- a/src/components/transactions/SignedMessagesHelpLink/index.tsx +++ b/src/components/transactions/SignedMessagesHelpLink/index.tsx @@ -1,4 +1,4 @@ -import { Box, SvgIcon, Typography } from '@mui/material' +import { Stack, SvgIcon, Typography } from '@mui/material' import InfoIcon from '@/public/images/notifications/info.svg' import ExternalLink from '@/components/common/ExternalLink' import { useAppSelector } from '@/store' @@ -14,14 +14,14 @@ const SignedMessagesHelpLink = () => { } return ( - + What are signed messages? - + ) } diff --git a/src/components/transactions/TxDetails/TxData/Transfer/index.tsx b/src/components/transactions/TxDetails/TxData/Transfer/index.tsx index 9971388af1..cdf2ffbcf2 100644 --- a/src/components/transactions/TxDetails/TxData/Transfer/index.tsx +++ b/src/components/transactions/TxDetails/TxData/Transfer/index.tsx @@ -3,7 +3,7 @@ import { TransferTx } from '@/components/transactions/TxInfo' import { isTxQueued } from '@/utils/transaction-guards' import type { TransactionStatus, Transfer } from '@safe-global/safe-gateway-typescript-sdk' import { TransferDirection } from '@safe-global/safe-gateway-typescript-sdk' -import { Box, Typography } from '@mui/material' +import { Stack, Typography } from '@mui/material' import React from 'react' import TransferActions from '@/components/transactions/TxDetails/TxData/Transfer/TransferActions' @@ -21,7 +21,7 @@ const TransferTxInfoMain = ({ txInfo, txStatus, trusted, imitation }: TransferTx const { direction } = txInfo return ( - + {direction === TransferDirection.INCOMING ? 'Received' : isTxQueued(txStatus) ? 'Send' : 'Sent'}{' '} @@ -30,7 +30,7 @@ const TransferTxInfoMain = ({ txInfo, txStatus, trusted, imitation }: TransferTx {direction === TransferDirection.INCOMING ? ' from:' : ' to:'} {!trusted && !imitation && } - + ) } @@ -38,10 +38,10 @@ const TransferTxInfo = ({ txInfo, txStatus, trusted, imitation }: TransferTxInfo const address = txInfo.direction.toUpperCase() === TransferDirection.INCOMING ? txInfo.sender : txInfo.recipient return ( - + - + - + {imitation && } - + ) } diff --git a/src/components/transactions/TxSummary/QueueActions.tsx b/src/components/transactions/TxSummary/QueueActions.tsx index df6075a6c0..66889fc20d 100644 --- a/src/components/transactions/TxSummary/QueueActions.tsx +++ b/src/components/transactions/TxSummary/QueueActions.tsx @@ -1,4 +1,4 @@ -import { Box } from '@mui/material' +import { Stack } from '@mui/material' import { type TransactionSummary } from '@safe-global/safe-gateway-typescript-sdk' import { isAwaitingExecution } from '@/utils/transaction-guards' import ExecuteTxButton from '../ExecuteTxButton' @@ -20,12 +20,12 @@ const QueueActions = ({ tx }: { tx: TransactionSummary }) => { } return ( - + {ExecutionComponent} {pendingTx && pendingTx.status === PendingStatus.PROCESSING && ( )} - + ) } diff --git a/src/components/tx-flow/common/TxNonce/index.tsx b/src/components/tx-flow/common/TxNonce/index.tsx index 5d3f243e39..7b199376e3 100644 --- a/src/components/tx-flow/common/TxNonce/index.tsx +++ b/src/components/tx-flow/common/TxNonce/index.tsx @@ -1,7 +1,6 @@ import { memo, type ReactElement, useContext, useMemo, useState, useEffect } from 'react' import { Autocomplete, - Box, IconButton, InputAdornment, Skeleton, @@ -13,6 +12,7 @@ import { Typography, ListSubheader, type ListSubheaderProps, + Stack, } from '@mui/material' import { createFilterOptions } from '@mui/material/Autocomplete' import { Controller, useForm } from 'react-hook-form' @@ -277,7 +277,7 @@ const TxNonce = () => { const { nonce, recommendedNonce } = useContext(SafeTxContext) return ( - + Nonce{' '} # @@ -287,7 +287,7 @@ const TxNonce = () => { ) : ( )} - + ) } diff --git a/src/components/tx-flow/flows/CancelRecovery/CancelRecoveryOverview.tsx b/src/components/tx-flow/flows/CancelRecovery/CancelRecoveryOverview.tsx index 8e128c2871..384ca12577 100644 --- a/src/components/tx-flow/flows/CancelRecovery/CancelRecoveryOverview.tsx +++ b/src/components/tx-flow/flows/CancelRecovery/CancelRecoveryOverview.tsx @@ -1,6 +1,6 @@ import { trackEvent } from '@/services/analytics' import { RECOVERY_EVENTS } from '@/services/analytics/events/recovery' -import { Box, Button, Typography } from '@mui/material' +import { Stack, Button, Typography } from '@mui/material' import { useContext } from 'react' import type { ReactElement } from 'react' @@ -20,7 +20,7 @@ export function CancelRecoveryOverview({ onSubmit }: { onSubmit: () => void }): return ( - + {/* TODO: Replace with correct icon when provided */} @@ -33,7 +33,7 @@ export function CancelRecoveryOverview({ onSubmit }: { onSubmit: () => void }): time. - + @@ -41,8 +41,8 @@ export function CancelRecoveryOverview({ onSubmit }: { onSubmit: () => void }): - - + + ) } diff --git a/src/components/tx-flow/flows/NestedTxSuccessScreen/index.tsx b/src/components/tx-flow/flows/NestedTxSuccessScreen/index.tsx index 0e7113fe5c..5a65f29c4a 100644 --- a/src/components/tx-flow/flows/NestedTxSuccessScreen/index.tsx +++ b/src/components/tx-flow/flows/NestedTxSuccessScreen/index.tsx @@ -1,5 +1,5 @@ import { useState, useEffect } from 'react' -import { Box, Container, Paper, Stack, SvgIcon, Typography } from '@mui/material' +import { Stack, Container, Paper, Box, SvgIcon, Typography } from '@mui/material' import { PendingStatus, selectPendingTxById } from '@/store/pendingTxsSlice' import EthHashInfo from '@/components/common/EthHashInfo' import ErrorMessage from '@/components/tx/ErrorMessage' @@ -65,7 +65,7 @@ const NestedTxSuccessScreen = ({ txId }: Props) => { }} maxWidth={false} > - + @@ -76,7 +76,7 @@ const NestedTxSuccessScreen = ({ txId }: Props) => { Once confirmed and executed this signer transaction will confirm the child Safe's transaction. - + Parent Safe @@ -86,7 +86,7 @@ const NestedTxSuccessScreen = ({ txId }: Props) => { isAddressBookName={Boolean(parentSafeAddress)} shortAddress={false} /> - + { approveHash - + Current Safe @@ -115,7 +115,7 @@ const NestedTxSuccessScreen = ({ txId }: Props) => { isAddressBookName={Boolean(currentSafeAddress)} shortAddress={false} /> - + { Open the transaction - + ) } diff --git a/src/components/tx-flow/flows/ReplaceTx/DeleteTxModal.tsx b/src/components/tx-flow/flows/ReplaceTx/DeleteTxModal.tsx index 9bca66b02a..a43bec6371 100644 --- a/src/components/tx-flow/flows/ReplaceTx/DeleteTxModal.tsx +++ b/src/components/tx-flow/flows/ReplaceTx/DeleteTxModal.tsx @@ -12,6 +12,7 @@ import { Box, SvgIcon, CircularProgress, + Stack, } from '@mui/material' import { Close } from '@mui/icons-material' import madProps from '@/utils/mad-props' @@ -90,7 +91,7 @@ const InternalDeleteTxModal = ({ return ( - + Delete this transaction? @@ -103,7 +104,7 @@ const InternalDeleteTxModal = ({ - + diff --git a/src/components/tx-flow/flows/ReplaceTx/index.tsx b/src/components/tx-flow/flows/ReplaceTx/index.tsx index 469dc6304b..2be60ad8a3 100644 --- a/src/components/tx-flow/flows/ReplaceTx/index.tsx +++ b/src/components/tx-flow/flows/ReplaceTx/index.tsx @@ -1,6 +1,6 @@ import { useContext, useState } from 'react' import { type NextRouter, useRouter } from 'next/router' -import { Box, Tooltip, Typography } from '@mui/material' +import { Box, Stack, Tooltip, Typography } from '@mui/material' import DeleteIcon from '@/public/images/common/delete.svg' import CancelIcon from '@/public/images/common/cancel.svg' import ReplaceTxIcon from '@/public/images/transactions/replace-tx.svg' @@ -137,7 +137,7 @@ const ReplaceTxMenu = ({ - + setTxFlow(undefined)} /> )} - + ) diff --git a/src/components/tx-flow/flows/SignMessage/index.tsx b/src/components/tx-flow/flows/SignMessage/index.tsx index 6c608ba339..94f4683351 100644 --- a/src/components/tx-flow/flows/SignMessage/index.tsx +++ b/src/components/tx-flow/flows/SignMessage/index.tsx @@ -3,7 +3,7 @@ import SignMessage, { type ConfirmProps, type ProposeProps } from '@/components/ import { getSwapTitle } from '@/features/swap' import { selectSwapParams } from '@/features/swap/store/swapParamsSlice' import { useAppSelector } from '@/store' -import { Box, Typography } from '@mui/material' +import { Stack, Typography } from '@mui/material' import SafeAppIconCard from '@/components/safe-apps/SafeAppIconCard' import { ErrorBoundary } from '@sentry/react' import { type BaseTransaction } from '@safe-global/safe-apps-sdk' @@ -38,12 +38,12 @@ export const AppTitle = ({ } return ( - + {title} - + ) } diff --git a/src/components/tx-flow/flows/SignMessageOnChain/ReviewSignMessageOnChain.tsx b/src/components/tx-flow/flows/SignMessageOnChain/ReviewSignMessageOnChain.tsx index 1cc055aa17..3859741b43 100644 --- a/src/components/tx-flow/flows/SignMessageOnChain/ReviewSignMessageOnChain.tsx +++ b/src/components/tx-flow/flows/SignMessageOnChain/ReviewSignMessageOnChain.tsx @@ -3,8 +3,8 @@ import type { ReactElement } from 'react' import { useContext, useEffect, useState } from 'react' import { useMemo } from 'react' import { hashMessage, TypedDataEncoder } from 'ethers' -import { Box } from '@mui/system' -import { Typography, SvgIcon } from '@mui/material' +import { Stack } from '@mui/system' +import { Typography, SvgIcon, Box } from '@mui/material' import WarningIcon from '@/public/images/notifications/warning.svg' import { type EIP712TypedData, Methods, type RequestId } from '@safe-global/safe-apps-sdk' import { OperationType } from '@safe-global/safe-core-sdk-types' @@ -146,12 +146,12 @@ const ReviewSignMessageOnChain = ({ message, method, requestId }: SignMessageOnC - + Signing a message with your Safe Account requires a transaction on the blockchain - + ) } diff --git a/src/components/tx/ApprovalEditor/EditableApprovalItem.tsx b/src/components/tx/ApprovalEditor/EditableApprovalItem.tsx index a263aed275..62cc699e93 100644 --- a/src/components/tx/ApprovalEditor/EditableApprovalItem.tsx +++ b/src/components/tx/ApprovalEditor/EditableApprovalItem.tsx @@ -1,4 +1,4 @@ -import { Box, Button, IconButton, Stack, SvgIcon } from '@mui/material' +import { Stack, Button, IconButton, SvgIcon } from '@mui/material' import css from '@/components/tx/ApprovalEditor/styles.module.css' import type { ApprovalInfo } from './hooks/useApprovalInfos' @@ -48,9 +48,9 @@ const EditableApprovalItem = ({ className={css.approvalField} onClick={readOnly ? handleEditMode : undefined} > - + - + diff --git a/src/components/tx/SignOrExecuteForm/SignOrExecuteSkeleton.tsx b/src/components/tx/SignOrExecuteForm/SignOrExecuteSkeleton.tsx index d6c6c20f71..8b90f7c0e2 100644 --- a/src/components/tx/SignOrExecuteForm/SignOrExecuteSkeleton.tsx +++ b/src/components/tx/SignOrExecuteForm/SignOrExecuteSkeleton.tsx @@ -1,12 +1,12 @@ import LoadingSpinner, { SpinnerStatus } from '@/components/new-safe/create/steps/StatusStep/LoadingSpinner' import TxCard from '@/components/tx-flow/common/TxCard' -import { Box } from '@mui/material' +import { Stack } from '@mui/material' const SignOrExecuteSkeleton = () => ( - + - + ) diff --git a/src/components/tx/SignOrExecuteForm/SignerForm/index.tsx b/src/components/tx/SignOrExecuteForm/SignerForm/index.tsx index 07b8e1c6ec..f21c013b9e 100644 --- a/src/components/tx/SignOrExecuteForm/SignerForm/index.tsx +++ b/src/components/tx/SignOrExecuteForm/SignerForm/index.tsx @@ -1,9 +1,9 @@ import { - Box, FormControl, InputLabel, MenuItem, Select, + Stack, SvgIcon, Tooltip, Typography, @@ -86,7 +86,7 @@ export const SignerForm = ({ willExecute }: { willExecute?: boolean }) => { - + Signer Account - + ) } diff --git a/src/components/welcome/WelcomeLogin/WalletLogin.tsx b/src/components/welcome/WelcomeLogin/WalletLogin.tsx index 9486b34edf..bb929f6676 100644 --- a/src/components/welcome/WelcomeLogin/WalletLogin.tsx +++ b/src/components/welcome/WelcomeLogin/WalletLogin.tsx @@ -1,6 +1,6 @@ import useConnectWallet from '@/components/common/ConnectWallet/useConnectWallet' import useWallet from '@/hooks/wallets/useWallet' -import { Box, Button, Typography } from '@mui/material' +import { Stack, Button, Typography, Box } from '@mui/material' import EthHashInfo from '@/components/common/EthHashInfo' import WalletIcon from '@/components/common/WalletIcon' @@ -25,7 +25,7 @@ const WalletLogin = ({ onLogin, onContinue }: { onLogin: () => void; onContinue: alignItems="center" gap={1} > - + Continue with {wallet.label} @@ -38,7 +38,7 @@ const WalletLogin = ({ onLogin, onContinue }: { onLogin: () => void; onContinue: copyAddress={false} /> )} - + {wallet.icon && } diff --git a/src/components/wrappers/DisclaimerWrapper/index.tsx b/src/components/wrappers/DisclaimerWrapper/index.tsx index 12d180b13b..aa95bcd931 100644 --- a/src/components/wrappers/DisclaimerWrapper/index.tsx +++ b/src/components/wrappers/DisclaimerWrapper/index.tsx @@ -26,7 +26,7 @@ export function _DisclaimerWrapper({ if (!hasConsented) { return ( - + } diff --git a/src/components/wrappers/SanctionWrapper/index.tsx b/src/components/wrappers/SanctionWrapper/index.tsx index 12465eed4b..bb80abed35 100644 --- a/src/components/wrappers/SanctionWrapper/index.tsx +++ b/src/components/wrappers/SanctionWrapper/index.tsx @@ -36,7 +36,7 @@ export function _SanctionWrapper({ if (blockedAddress) { return ( - + ) diff --git a/src/features/counterfactual/ActivateAccountFlow.tsx b/src/features/counterfactual/ActivateAccountFlow.tsx index bf9cf65f67..135fcd8589 100644 --- a/src/features/counterfactual/ActivateAccountFlow.tsx +++ b/src/features/counterfactual/ActivateAccountFlow.tsx @@ -22,7 +22,7 @@ import { asError } from '@/services/exceptions/utils' import { useAppSelector } from '@/store' import { hasFeature } from '@/utils/chains' import { hasRemainingRelays } from '@/utils/relaying' -import { Box, Button, CircularProgress, Divider, Grid, Typography } from '@mui/material' +import { Stack, Button, CircularProgress, Divider, Grid, Typography, Box } from '@mui/material' import type { DeploySafeProps } from '@safe-global/protocol-kit' import { FEATURES } from '@/utils/chains' import React, { useContext, useMemo, useState } from 'react' @@ -163,7 +163,7 @@ const ActivateAccountFlow = () => { /> - + {canRelay && ( { Your connected wallet doesn't have enough funds to execute this transaction )} - + - + {(isOk) => ( )} - + ) diff --git a/src/features/myAccounts/components/DataWidget/index.tsx b/src/features/myAccounts/components/DataWidget/index.tsx index a8799633e1..e0f6f5f11e 100644 --- a/src/features/myAccounts/components/DataWidget/index.tsx +++ b/src/features/myAccounts/components/DataWidget/index.tsx @@ -1,4 +1,4 @@ -import { Button, SvgIcon, Card, CardHeader, CardContent, Tooltip, Box } from '@mui/material' +import { Button, SvgIcon, Card, CardHeader, CardContent, Tooltip, Stack } from '@mui/material' import { useState } from 'react' import type { ReactElement } from 'react' @@ -56,7 +56,7 @@ export const DataWidget = (): ReactElement => { } /> - + {hasData && ( - + {importModalOpen && ( + From 68e56438e1ebbb971de782eb2acc2289952098c4 Mon Sep 17 00:00:00 2001 From: katspaugh <381895+katspaugh@users.noreply.github.com> Date: Mon, 9 Dec 2024 14:50:07 +0100 Subject: [PATCH 5/5] Update snapshots --- .../__tests__/__snapshots__/SignOrExecute.test.tsx.snap | 2 +- .../__snapshots__/BatchTransactions.test.tsx.snap | 8 ++++---- .../__snapshots__/SettingsChange.test.tsx.snap | 6 +++--- .../__snapshots__/ConfirmationView.test.tsx.snap | 6 +++--- 4 files changed, 11 insertions(+), 11 deletions(-) diff --git a/src/components/tx/SignOrExecuteForm/__tests__/__snapshots__/SignOrExecute.test.tsx.snap b/src/components/tx/SignOrExecuteForm/__tests__/__snapshots__/SignOrExecute.test.tsx.snap index e4872296c5..29cbb417ed 100644 --- a/src/components/tx/SignOrExecuteForm/__tests__/__snapshots__/SignOrExecute.test.tsx.snap +++ b/src/components/tx/SignOrExecuteForm/__tests__/__snapshots__/SignOrExecute.test.tsx.snap @@ -206,7 +206,7 @@ exports[`SignOrExecute should display a loading component 1`] = ` class="MuiCardContent-root cardContent css-1lt5qva-MuiCardContent-root" >