Skip to content

Commit

Permalink
fix: Change QueueActions to a button instead of an a element
Browse files Browse the repository at this point in the history
  • Loading branch information
usame-algan committed Dec 17, 2024
1 parent c3ef09f commit 596b102
Show file tree
Hide file tree
Showing 2 changed files with 45 additions and 34 deletions.
64 changes: 30 additions & 34 deletions src/features/myAccounts/components/QueueActions/index.tsx
Original file line number Diff line number Diff line change
@@ -1,12 +1,13 @@
import { useMemo, type ReactNode } from 'react'
import type { UrlObject } from 'url'
import NextLink from 'next/link'
import { Box, Chip, Typography, SvgIcon } from '@mui/material'
import classnames from 'classnames'
import { useRouter } from 'next/router'
import { type ReactNode, useCallback, type MouseEvent } from 'react'
import { Chip, Typography, SvgIcon } from '@mui/material'
import CheckIcon from '@mui/icons-material/Check'
import TransactionsIcon from '@/public/images/transactions/transactions.svg'
import Track from '@/components/common/Track'
import { OVERVIEW_EVENTS } from '@/services/analytics/events/overview'
import { AppRoutes } from '@/config/routes'
import css from './styles.module.css'

const ChipLink = ({ children, color }: { children: ReactNode; color?: string }) => (
<Chip
Expand Down Expand Up @@ -40,12 +41,17 @@ const QueueActions = ({
awaitingConfirmation: number
isMobile?: boolean
}) => {
const queueLink = useMemo<UrlObject>(
() => ({
pathname: AppRoutes.transactions.queue,
query: { safe: `${chainShortName}:${safeAddress}` },
}),
[chainShortName, safeAddress],
const router = useRouter()

const onQueueClick = useCallback(
(e: MouseEvent<HTMLButtonElement>) => {
e.preventDefault()
router.push({
pathname: AppRoutes.transactions.queue,
query: { safe: `${chainShortName}:${safeAddress}` },
})
},
[chainShortName, router, safeAddress],
)

if (!queued && !awaitingConfirmation) {
Expand All @@ -54,31 +60,21 @@ const QueueActions = ({

return (
<Track {...OVERVIEW_EVENTS.OPEN_MISSING_SIGNATURES}>
<NextLink href={queueLink}>
<Box
sx={{
px: isMobile ? 2 : 0,
pb: isMobile ? 2 : 0,
display: 'flex',
gap: 1,
alignItems: 'center',
}}
>
{queued > 0 && (
<ChipLink>
<SvgIcon component={TransactionsIcon} inheritViewBox sx={{ fontSize: 'small' }} />
{queued} pending
</ChipLink>
)}
<button onClick={onQueueClick} className={classnames(css.queueButton, { [css.isMobile]: isMobile })}>
{queued > 0 && (
<ChipLink>
<SvgIcon component={TransactionsIcon} inheritViewBox sx={{ fontSize: 'small' }} />
{queued} pending
</ChipLink>
)}

{awaitingConfirmation > 0 && (
<ChipLink color="warning">
<SvgIcon component={CheckIcon} inheritViewBox sx={{ fontSize: 'small', color: 'warning' }} />
{awaitingConfirmation} to confirm
</ChipLink>
)}
</Box>
</NextLink>
{awaitingConfirmation > 0 && (
<ChipLink color="warning">
<SvgIcon component={CheckIcon} inheritViewBox sx={{ fontSize: 'small', color: 'warning' }} />
{awaitingConfirmation} to confirm
</ChipLink>
)}
</button>
</Track>
)
}
Expand Down
15 changes: 15 additions & 0 deletions src/features/myAccounts/components/QueueActions/styles.module.css
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
.queueButton {
display: flex;
gap: var(--space-1);
align-items: center;
padding: 0;
border: 0;
cursor: pointer;
position: relative;
z-index: 1;
background: transparent;
}

.isMobile {
padding: var(--space-2) var(--space-2) 0;
}

0 comments on commit 596b102

Please sign in to comment.