.i147wxg0{display:inline;}
.s46g9zo{-webkit-text-decoration:line-through;text-decoration:line-through;display:inline;}
.i1gnk9ht{cursor:pointer;margin-top:auto;margin-bottom:auto;margin-left:4px;}.i1gnk9ht span:hover{color:var(--primary) !important;}
.s1acmhe{resize:'none';width:100%;padding:var(--spacing-2);border:1px solid var(--line);border-radius:4px;background:var(--background);color:var(--foreground-muted);font-size:var(--body-font-size);font-family:var(--body-font-family);}
/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["src/screens/TransactionHistory/TransactionDetail.tsx"],"names":[".i147wxg0",".s46g9zo",".i1gnk9ht",".s1acmhe"],"mappings":"AA+cMA;AAIAC;AAKAC;AAYAC","file":"src/screens/TransactionHistory/TransactionDetail.tsx","sourcesContent":["import { useCallback, useMemo } from 'react';\nimport { defineMessages, useIntl } from 'react-intl';\nimport { generatePath, useHistory, useParams } from 'react-router-dom';\nimport { css } from '@linaria/core';\nimport { styled } from '@linaria/react';\nimport { logEvent } from 'cb-wallet-analytics/utils/log';\nimport { bigIntStringFromBigInt } from 'cb-wallet-data/chains/AccountBased/Ethereum/Transactions/utils/bigIntStringFromBigInt';\nimport { useNetworkFeeTooltipMessages } from 'cb-wallet-data/hooks/copy/useNetworkFeeTooltipMessages';\nimport { useIsSpeedUpCancelEnabled } from 'cb-wallet-data/hooks/useIsSpeedUpCancelEnabled/useIsSpeedUpCancelEnabled';\nimport { useFormattedTransaction } from 'cb-wallet-data/stores/Transactions/hooks/useFormattedTransaction';\nimport { useIsMaliciousZeroValueTransfer } from 'cb-wallet-data/stores/Transactions/hooks/useIsMaliciousZeroValueTransfer';\nimport { useIsSwapTransaction } from 'cb-wallet-data/stores/Transactions/hooks/useIsSwapTransaction';\nimport { Transaction } from 'cb-wallet-data/stores/Transactions/models/Transaction';\nimport { TxState } from 'cb-wallet-data/stores/Transactions/models/TxState';\nimport { PortfolioIconButtonText } from 'wallet-cds-extension/components/PortfolioMenu/PortfolioIconButtonText';\nimport { Button } from '@cbhq/cds-web/buttons';\nimport { Icon } from '@cbhq/cds-web/icons/Icon';\nimport { Divider, HStack, VStack } from '@cbhq/cds-web/layout';\nimport { Tooltip } from '@cbhq/cds-web/overlays/Tooltip/Tooltip';\nimport { TextBody, TextDisplay2, TextLabel2, TextTitle1 } from '@cbhq/cds-web/typography';\nimport { ActionType, ComponentType } from '@cbhq/client-analytics';\n\nimport { RoutesEnum } from ':extension/screens/Routes/Routes';\n\nconst messages = defineMessages({\n  copyToolTip: {\n    defaultMessage: 'Copy address',\n    description: 'Tooltip label for copy address that shows up on hovering over the tooltip icon',\n  },\n  dateLabel: {\n    defaultMessage: 'Date',\n    description: 'Label for transaction date',\n  },\n  toLabel: {\n    defaultMessage: 'To',\n    description: 'Label for recipients address',\n  },\n  fromLabel: {\n    defaultMessage: 'From',\n    description: 'Label for senders address',\n  },\n  statusLabel: {\n    defaultMessage: 'Status',\n    description: 'Label for status of transaction',\n  },\n  valueLabel: {\n    defaultMessage: 'Value',\n    description: 'Label for value of transaction',\n  },\n  sponsoredTx: {\n    defaultMessage: 'Paid by Coinbase Wallet',\n    description: 'Message for Sponsored Transactions',\n  },\n  networkDisplayName: {\n    defaultMessage: 'Network',\n    description: 'Label for network name',\n  },\n  networkFeeLabel: {\n    defaultMessage: 'Network fee',\n    description: 'Label for network fee',\n  },\n  totalLabel: {\n    defaultMessage: 'Total cost',\n    description: 'Label for total',\n  },\n  totalReceivedLabel: {\n    defaultMessage: 'Total received',\n    description: 'Label for total received',\n  },\n  txExplorerButtonLabel: {\n    defaultMessage: 'View on Tx Explorer',\n    description: 'View on transaction scanner button',\n  },\n  sponsoredTooltip: {\n    defaultMessage: 'This network fee was paid by Coinbase.',\n    description:\n      'Tooltip label for sponsored network fees that shows up on hovering over the question mark icon',\n  },\n  speedupButtonLabel: {\n    defaultMessage: 'Speed up',\n    description: 'Label for Speed up button',\n  },\n  nonceLabel: {\n    defaultMessage: 'Transaction nonce',\n    description: 'Label for Transaction nonce',\n  },\n  hashLabel: {\n    defaultMessage: 'Transaction hash:',\n    description: 'Label for Transaction hash',\n  },\n  tokenLabel: {\n    defaultMessage: 'Token name',\n    description: 'Label for Token name',\n  },\n  cancelButtonLabel: {\n    defaultMessage: 'Cancel',\n    description: 'Label for Cancel button',\n  },\n  etherscanButtonLabel: {\n    defaultMessage: 'Etherscan',\n    description: 'Label for Etherscan button',\n  },\n  receivedLabel: {\n    defaultMessage: 'Received',\n    description: 'Label for swap received value',\n  },\n  coinbaseFeeLabel: {\n    defaultMessage: 'Coinbase fee',\n    description: 'Label for coinbase dex fee row',\n  },\n  freeLabel: {\n    defaultMessage: 'Free',\n    description: 'Label for coinbase dex fee',\n  },\n  thirdPartyDexFeeLabel: {\n    defaultMessage: '3rd party DEX fee',\n    description: 'Label for 3rd party dex fee for current tx',\n  },\n  coinbaseFeeFreeTooltip: {\n    defaultMessage: 'Coinbase does not charge a fee for swaps.',\n    description: 'Value for transaction detail row displaying the free coinbase fee tooltip',\n  },\n});\n\ntype TxnDetailProps = {\n  transaction: Transaction;\n};\n\nexport function TransactionDetail({ transaction }: TxnDetailProps) {\n  const { formatMessage } = useIntl();\n  const history = useHistory();\n\n  const networkName = useMemo(() => transaction.network?.asChain()?.displayName, [transaction]);\n  const { walletId, id } = useParams<{ walletId: string; id: string }>();\n  // Just here for logging\n  useIsMaliciousZeroValueTransfer(transaction);\n\n  const {\n    fiatValue,\n    dateAndTime,\n    networkFee,\n    valueDisplay,\n    blockExplorerUrl,\n    totalFiat,\n    cryptoValueDisplay,\n    is1559Enabled,\n    fromDisplay,\n    toDisplay,\n    status,\n  } = useFormattedTransaction(transaction);\n  const isSponsoredTx = transaction.isSponsored();\n  const isSwapTx = useIsSwapTransaction(transaction);\n  const isSwapPending = isSwapTx && transaction.state === TxState.PENDING;\n  const totalRawValue = useMemo(() => {\n    if (isSponsoredTx) {\n      return `${valueDisplay}`;\n    }\n\n    if (isSwapTx) {\n      return transaction.state === TxState.PENDING ? status : `${valueDisplay}`;\n    }\n    return totalFiat ?? cryptoValueDisplay;\n  }, [\n    isSponsoredTx,\n    isSwapTx,\n    totalFiat,\n    cryptoValueDisplay,\n    valueDisplay,\n    transaction.state,\n    status,\n  ]);\n  const { networkFeeTooltip } = useNetworkFeeTooltipMessages(\n    transaction.network.asChain()?.chainId,\n  );\n\n  const speedUpURL = useMemo(\n    () =>\n      generatePath(RoutesEnum.TX_SPEEDUP_CANCEL, {\n        walletId,\n        id,\n        updateType: 'speedup',\n      }),\n    [id, walletId],\n  );\n\n  const cancelURL = useMemo(\n    () =>\n      generatePath(RoutesEnum.TX_SPEEDUP_CANCEL, {\n        walletId,\n        id,\n        updateType: 'cancel',\n      }),\n    [id, walletId],\n  );\n\n  const handleEtherscanClick = useCallback(() => {\n    logEvent('etherscan_click', {\n      action: ActionType.click,\n      componentType: ComponentType.button,\n      loggingId: 'ba55a561-2385-4378-9adc-a8719b4f348f',\n    });\n    chrome.tabs.create({ url: blockExplorerUrl });\n  }, [blockExplorerUrl]);\n\n  const handleSpeedUp = useCallback(() => {\n    history.push(speedUpURL);\n  }, [speedUpURL, history]);\n\n  const handleCancel = useCallback(() => {\n    history.push(cancelURL);\n  }, [cancelURL, history]);\n\n  const isSpeedUpCancelEnabled = useIsSpeedUpCancelEnabled({\n    is1559Enabled,\n    transaction,\n  });\n\n  const dominantCurrencyIsFiat = useMemo(\n    () => Boolean(fiatValue) && !transaction.network.isTestnet,\n    [fiatValue, transaction.network.isTestnet],\n  );\n\n  const header = useMemo(() => {\n    if (isSwapPending) {\n      return (\n        <TextDisplay2 as=\"h2\" spacingTop={3} spacingBottom={1}>\n          {status}\n        </TextDisplay2>\n      );\n    }\n    return dominantCurrencyIsFiat ? (\n      <>\n        <TextLabel2 spacingTop={2} testID=\"txDetail_crypto_display\" as=\"p\" color=\"foregroundMuted\">\n          {cryptoValueDisplay}\n        </TextLabel2>\n        <TextTitle1 testID=\"txDetail_fiat_display\" as=\"h2\">\n          {fiatValue}\n        </TextTitle1>\n      </>\n    ) : (\n      <TextDisplay2 testID=\"txDetail_crypto_display\" as=\"h2\" spacingTop={3} spacingBottom={1}>\n        {cryptoValueDisplay}\n      </TextDisplay2>\n    );\n  }, [isSwapPending, dominantCurrencyIsFiat, cryptoValueDisplay, fiatValue, status]);\n\n  return (\n    // TODO: Save height value on a shareable place (window height - header space)\n    // Or refactor this screen to use only CDS / relative values\n    <VStack spacingHorizontal={3}>\n      <VStack alignItems=\"center\">{header}</VStack>\n\n      <Divider direction=\"horizontal\" spacingTop={2} />\n      <VStack>\n        {isSwapTx ? (\n          <HStack spacingTop={2} spacingBottom={1} width=\"100%\" justifyContent=\"space-between\">\n            <TextBody as=\"p\">{formatMessage(messages.receivedLabel)}</TextBody>\n            <TextBody as=\"p\" color=\"foregroundMuted\" align=\"end\">\n              {isSwapPending ? status : valueDisplay}\n            </TextBody>\n          </HStack>\n        ) : null}\n        <HStack\n          spacingTop={!isSwapTx ? 2 : 1}\n          spacingBottom={1}\n          width=\"100%\"\n          justifyContent=\"space-between\"\n        >\n          <TextBody as=\"p\">{formatMessage(messages.fromLabel)}</TextBody>\n          <TextBody as=\"p\" color=\"foregroundMuted\" align=\"end\">\n            {fromDisplay}\n          </TextBody>\n        </HStack>\n\n        <HStack spacingVertical={1} width=\"100%\" justifyContent=\"space-between\">\n          <TextBody as=\"p\">{formatMessage(messages.toLabel)}</TextBody>\n          <TextBody as=\"p\" color=\"foregroundMuted\" align=\"end\">\n            {toDisplay}\n          </TextBody>\n        </HStack>\n\n        <HStack spacingVertical={1} width=\"100%\" justifyContent=\"space-between\">\n          <TextBody as=\"p\">{formatMessage(messages.dateLabel)}</TextBody>\n          <TextBody as=\"p\" color=\"foregroundMuted\" align=\"end\">\n            {dateAndTime}\n          </TextBody>\n        </HStack>\n\n        {networkName && (\n          <HStack spacingVertical={1} width=\"100%\" justifyContent=\"space-between\">\n            <TextBody as=\"p\">{formatMessage(messages.networkDisplayName)}</TextBody>\n            <TextBody as=\"p\" color=\"foregroundMuted\" align=\"end\">\n              {networkName}\n            </TextBody>\n          </HStack>\n        )}\n        {transaction.network.isTestnet && (\n          <HStack spacingVertical={1} width=\"100%\" justifyContent=\"space-between\">\n            <TextBody as=\"p\">{formatMessage(messages.tokenLabel)}</TextBody>\n            <TextBody as=\"p\" color=\"foregroundMuted\" align=\"end\">\n              {transaction.tokenName}\n            </TextBody>\n          </HStack>\n        )}\n\n        <HStack spacingVertical={1} width=\"100%\" justifyContent=\"space-between\">\n          <TextBody as=\"p\">{formatMessage(messages.statusLabel)}</TextBody>\n          <TextBody as=\"p\" color=\"foregroundMuted\" align=\"end\">\n            {status}\n          </TextBody>\n        </HStack>\n\n        <HStack spacingVertical={1} width=\"100%\" justifyContent=\"space-between\">\n          <HStack>\n            <TextBody as=\"p\">{formatMessage(messages.coinbaseFeeLabel)}</TextBody>\n            <div className={infoIcon}>\n              <Tooltip content={formatMessage(messages.coinbaseFeeFreeTooltip)} placement=\"bottom\">\n                <Icon name=\"info\" size=\"xs\" color=\"foregroundMuted\" />\n              </Tooltip>\n            </div>\n          </HStack>\n          <TextBody as=\"p\" color=\"foregroundMuted\" align=\"end\">\n            {formatMessage(messages.freeLabel)}\n          </TextBody>\n        </HStack>\n\n        {!transaction.isNFTTransfer() && !isSwapTx ? (\n          <HStack spacingVertical={1} width=\"100%\" justifyContent=\"space-between\">\n            <TextBody as=\"p\">{formatMessage(messages.valueLabel)}</TextBody>\n            <TextBody as=\"p\" color=\"foregroundMuted\" align=\"end\">\n              {valueDisplay}\n            </TextBody>\n          </HStack>\n        ) : null}\n\n        <HStack\n          spacingVertical={1}\n          width=\"100%\"\n          justifyContent=\"space-between\"\n          alignItems=\"flex-start\"\n        >\n          <HStack>\n            <TextBody as=\"p\">{formatMessage(messages.networkFeeLabel)}</TextBody>\n            <div className={infoIcon}>\n              <Tooltip\n                content={formatMessage(\n                  isSponsoredTx ? messages.sponsoredTooltip : networkFeeTooltip,\n                )}\n                placement=\"bottom\"\n              >\n                <Icon name=\"info\" size=\"xs\" color=\"foregroundMuted\" />\n              </Tooltip>\n            </div>\n          </HStack>\n          <VStack alignItems=\"flex-end\">\n            <TextBody\n              as=\"p\"\n              testID=\"tx-detail-network-fee\"\n              dangerouslySetClassName={\n                isSponsoredTx && !isSwapTx ? sponsoredTxStrikethroughText : ''\n              }\n              color=\"foregroundMuted\"\n              align=\"end\"\n            >\n              {isSwapPending ? status : networkFee}\n            </TextBody>\n            {isSponsoredTx && !isSwapTx && (\n              <TextLabel2 as=\"p\" color=\"foregroundMuted\" dangerouslySetClassName={inlineTextBody}>\n                {formatMessage(messages.sponsoredTx)}\n              </TextLabel2>\n            )}\n          </VStack>\n        </HStack>\n\n        {transaction.network.isTestnet && (\n          <VStack gap={2} spacingTop={1} spacingBottom={3}>\n            <>\n              {transaction.nonce && (\n                <HStack width=\"100%\" justifyContent=\"space-between\">\n                  <TextBody as=\"p\">{formatMessage(messages.nonceLabel)}</TextBody>\n                  <TextBody as=\"span\" color=\"foregroundMuted\">\n                    {bigIntStringFromBigInt(transaction.nonce)}\n                  </TextBody>\n                </HStack>\n              )}\n              <VStack width=\"100%\" gap={1} spacingTop={2}>\n                <TextBody as=\"p\">{formatMessage(messages.hashLabel)}</TextBody>\n                <StyledTextArea defaultValue={transaction.txHash} readOnly />\n              </VStack>\n            </>\n          </VStack>\n        )}\n\n        {!transaction.isNFTTransfer() && !transaction.network.isTestnet && !isSwapTx ? (\n          <HStack spacingTop={1} spacingBottom={5} width=\"100%\" justifyContent=\"space-between\">\n            <TextBody as=\"p\">\n              {transaction.isSent\n                ? formatMessage(messages.totalLabel)\n                : formatMessage(messages.totalReceivedLabel)}\n            </TextBody>\n            <TextBody as=\"p\" color=\"foregroundMuted\" align=\"end\">\n              {totalRawValue}\n            </TextBody>\n          </HStack>\n        ) : null}\n\n        <VStack\n          position=\"sticky\"\n          width=\"100%\"\n          spacingHorizontal={3}\n          spacingVertical={1}\n          justifyContent=\"center\"\n          bottom={0}\n          background=\"background\"\n        >\n          {isSpeedUpCancelEnabled ? (\n            <HStack alignSelf=\"center\" gap={3}>\n              <PortfolioIconButtonText\n                variant=\"secondary\"\n                iconName=\"lightningBolt\"\n                handleOnPress={handleSpeedUp}\n                testID=\"speedupButton\"\n                label={formatMessage(messages.speedupButtonLabel)}\n                labelColor=\"foregroundMuted\"\n              />\n              {transaction?.pendingTxData?.txSubmissionType !== 'cancel' ? (\n                <PortfolioIconButtonText\n                  variant=\"secondary\"\n                  iconName=\"close\"\n                  handleOnPress={handleCancel}\n                  testID=\"cancelButton\"\n                  label={formatMessage(messages.cancelButtonLabel)}\n                  labelColor=\"foregroundMuted\"\n                />\n              ) : null}\n              <PortfolioIconButtonText\n                variant=\"secondary\"\n                iconName=\"externalLink\"\n                handleOnPress={handleEtherscanClick}\n                testID=\"view-on-etherscan-button\"\n                label={formatMessage(messages.etherscanButtonLabel)}\n                labelColor=\"foregroundMuted\"\n              />\n            </HStack>\n          ) : (\n            blockExplorerUrl && (\n              <HStack alignSelf=\"center\" spacingBottom={2}>\n                <Button\n                  variant=\"secondary\"\n                  onPress={handleEtherscanClick}\n                  testID=\"view-on-etherscan-button\"\n                >\n                  {formatMessage(messages.txExplorerButtonLabel)}\n                </Button>\n              </HStack>\n            )\n          )}\n        </VStack>\n      </VStack>\n    </VStack>\n  );\n}\n\nconst inlineTextBody = css`\n  display: inline;\n`;\n\nconst sponsoredTxStrikethroughText = css`\n  text-decoration: line-through;\n  display: inline;\n`;\n\nconst infoIcon = css`\n  cursor: pointer;\n  margin-top: auto;\n  margin-bottom: auto;\n  margin-left: 4px;\n\n  span:hover {\n    /* !important here because CDS sets color attribute in-line */\n    color: var(--primary) !important;\n  }\n`;\n\nconst StyledTextArea = styled.textarea`\n  resize: 'none';\n  width: 100%;\n  padding: var(--spacing-2);\n  border: 1px solid var(--line);\n  border-radius: 4px;\n  background: var(--background);\n  color: var(--foreground-muted);\n  font-size: var(--body-font-size);\n  font-family: var(--body-font-family);\n`;\n"]}*/

/*# sourceMappingURL=8005.css.map*/