Skip to content

Commit

Permalink
fix(widgets): complete etherscan link and stop timer on tx inclusion (#…
Browse files Browse the repository at this point in the history
…3267)

* fix(widgets): complete etherscan link and stop timer on tx inclusion

* use preexisting helper for etherscan link

* use z's EtherscanLink component

* pr review
  • Loading branch information
JFrankfurt authored Feb 10, 2022
1 parent 88712b5 commit c5ea01c
Show file tree
Hide file tree
Showing 3 changed files with 12 additions and 19 deletions.
3 changes: 2 additions & 1 deletion cosmos.config.json
Original file line number Diff line number Diff line change
Expand Up @@ -5,5 +5,6 @@
"webpack": {
"configPath": "react-scripts/config/webpack.config",
"overridePath": "cosmos.override.js"
}
},
"port": 5001
}
2 changes: 1 addition & 1 deletion src/lib/components/EtherscanLink.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ import { ExplorerDataType, getExplorerLink } from 'utils/getExplorerLink'
import ExternalLink from './ExternalLink'

const Link = styled(ExternalLink)<{ color: Color }>`
color: ${({ theme, color }) => theme[color]}
color: ${({ theme, color }) => theme[color]};
text-decoration: none;
`

Expand Down
26 changes: 9 additions & 17 deletions src/lib/components/Swap/Status/StatusDialog.tsx
Original file line number Diff line number Diff line change
@@ -1,10 +1,13 @@
import { Trans } from '@lingui/macro'
import ErrorDialog, { StatusHeader } from 'lib/components/Error/ErrorDialog'
import EtherscanLink from 'lib/components/EtherscanLink'
import useInterval from 'lib/hooks/useInterval'
import { CheckCircle, Clock, Spinner } from 'lib/icons'
import { SwapTransactionInfo, Transaction } from 'lib/state/transactions'
import styled, { ThemedText } from 'lib/theme'
import ms from 'ms.macro'
import { useCallback, useMemo, useState } from 'react'
import { ExplorerDataType } from 'utils/getExplorerLink'

import ActionButton from '../../ActionButton'
import Column from '../../Column'
Expand All @@ -25,16 +28,9 @@ const TransactionRow = styled(Row)`

function ElapsedTime({ tx }: { tx: Transaction<SwapTransactionInfo> }) {
const [elapsedMs, setElapsedMs] = useState(0)
useInterval(
() => {
if (tx.info.response.timestamp) {
setElapsedMs(tx.info.response.timestamp - tx.addedTime)
} else {
setElapsedMs(Date.now() - tx.addedTime)
}
},
elapsedMs === tx.info.response.timestamp ? null : 1000
)

useInterval(() => setElapsedMs(Date.now() - tx.addedTime), tx.receipt ? null : ms`1s`)

const toElapsedTime = useCallback((ms: number) => {
let sec = Math.floor(ms / 1000)
const min = Math.floor(sec / 60)
Expand All @@ -57,11 +53,6 @@ function ElapsedTime({ tx }: { tx: Transaction<SwapTransactionInfo> }) {
)
}

const EtherscanA = styled.a`
color: ${({ theme }) => theme.accent};
text-decoration: none;
`

interface TransactionStatusProps {
tx: Transaction<SwapTransactionInfo>
onClose: () => void
Expand All @@ -74,6 +65,7 @@ function TransactionStatus({ tx, onClose }: TransactionStatusProps) {
const heading = useMemo(() => {
return tx.receipt?.status ? <Trans>Transaction submitted</Trans> : <Trans>Transaction pending</Trans>
}, [tx.receipt?.status])

return (
<Column flex padded gap={0.75} align="stretch" style={{ height: '100%' }}>
<StatusHeader icon={Icon} iconColor={tx.receipt?.status ? 'success' : undefined}>
Expand All @@ -82,9 +74,9 @@ function TransactionStatus({ tx, onClose }: TransactionStatusProps) {
</StatusHeader>
<TransactionRow flex>
<ThemedText.ButtonSmall>
<EtherscanA href="//etherscan.io" target="_blank">
<EtherscanLink type={ExplorerDataType.TRANSACTION} data={tx.info.response.hash}>
<Trans>View on Etherscan</Trans>
</EtherscanA>
</EtherscanLink>
</ThemedText.ButtonSmall>
<ElapsedTime tx={tx} />
</TransactionRow>
Expand Down

0 comments on commit c5ea01c

Please sign in to comment.