.a1q37wuz{-webkit-transform:scale(calc(2 / 3));-ms-transform:scale(calc(2 / 3));transform:scale(calc(2 / 3));padding-right:var(--spacing-0.5);}
/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL2xpYnMvd2FsbGV0LWNkcy1leHRlbnNpb24vY29tcG9uZW50cy9Vc2VyQXZhdGFyL0F2YXRhckJveC50c3giXSwibmFtZXMiOlsiLmExcTM3d3V6Il0sIm1hcHBpbmdzIjoiQUFFYUEiLCJmaWxlIjoiLi4vLi4vbGlicy93YWxsZXQtY2RzLWV4dGVuc2lvbi9jb21wb25lbnRzL1VzZXJBdmF0YXIvQXZhdGFyQm94LnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHN0eWxlZCB9IGZyb20gJ0BsaW5hcmlhL3JlYWN0JztcblxuZXhwb3J0IGNvbnN0IEF2YXRhckJveCA9IHN0eWxlZC5kaXZgXG4gIHRyYW5zZm9ybTogc2NhbGUoY2FsYygyIC8gMykpO1xuICBwYWRkaW5nLXJpZ2h0OiB2YXIoLS1zcGFjaW5nLTBcXC41KTtcbmA7XG4iXX0=*/
.cmv46nh{width:80px;height:80px;border-radius:50%;}
.p1vf18iw{word-break:break-word;margin:0;}
/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["src/screens/Web3/SignMessage/SignMessage.tsx"],"names":[".cmv46nh",".p1vf18iw"],"mappings":"AAybMA;AAMAC","file":"src/screens/Web3/SignMessage/SignMessage.tsx","sourcesContent":["import { useCallback, useContext, useEffect, useMemo, useState } from 'react';\nimport { defineMessages, useIntl } from 'react-intl';\nimport { standardErrors } from '@coinbase/wallet-sdk/dist/errors';\nimport { SignEthereumMessageRequest } from '@coinbase/wallet-sdk/dist/relay/Web3Request';\nimport { css } from '@linaria/core';\nimport {\n  triggerWeb3CancelMessageClicked,\n  triggerWeb3SignMessageClicked,\n  triggerWeb3SignMessageError,\n  useTriggerWeb3SignMessageRequestViewed,\n} from 'cb-wallet-analytics/sign-message';\nimport { useTriggerWeb3RequestSendingSuccessResponse } from 'cb-wallet-analytics/sign-transaction';\nimport { ETHEREUM_SYMBOL } from 'cb-wallet-data/chains/AccountBased/Ethereum/constants';\nimport { LedgerError } from 'cb-wallet-data/chains/AccountBased/Ethereum/Transactions/ledgerError';\nimport { SOLANA_SYMBOL } from 'cb-wallet-data/chains/AccountBased/Solana/constants';\nimport { useAccountIdFromWeb3Request } from 'cb-wallet-data/stores/Accounts/hooks/useAccountIdFromWeb3Request';\nimport { useAccountById } from 'cb-wallet-data/stores/Accounts/hooks/useGetAccountById';\nimport {\n  useIsHardwareWalletSigning,\n  useSetIsHardwareWalletSigning,\n} from 'cb-wallet-data/stores/HardwareWallet/hooks/useIsHardwareWalletSigning';\nimport { useMessageScanner } from 'cb-wallet-data/stores/TxScanner/hooks/useMessageScanner';\nimport { useSanitizeMessageSigningRequest } from 'cb-wallet-data/stores/TxScanner/hooks/useSanitizeMessageSigningRequest';\nimport { useGetWalletGroupForWallet } from 'cb-wallet-data/stores/Wallets/hooks/useGetWalletGroupForWallet';\nimport { useSpecificWalletForAccountId } from 'cb-wallet-data/stores/Wallets/hooks/useSpecificWalletForAccountId';\nimport { hexToUtf8 } from 'cb-wallet-data/utils/String+Core';\nimport { useBuildDappMessageSignature } from 'cb-wallet-data/Web3/hooks/useBuildDappMessageSignature';\nimport { isEthereumWeb3Request } from 'cb-wallet-data/Web3/types';\nimport { SigningAddressHeader } from 'wallet-cds-extension/components/SigningAddressHeader/SigningAddressHeader';\nimport { WarningBanner } from 'wallet-cds-extension/components/WarningBanner/WarningBanner';\nimport { Button, ButtonGroup } from '@cbhq/cds-web/buttons';\nimport { Icon } from '@cbhq/cds-web/icons/Icon';\nimport { Box, VStack } from '@cbhq/cds-web/layout';\nimport { Tooltip } from '@cbhq/cds-web/overlays/Tooltip/Tooltip';\nimport { TextBody, TextHeadline, TextLabel2, TextTitle3 } from '@cbhq/cds-web/typography';\nimport { sendScheduledEvents } from '@cbhq/client-analytics';\n\nimport { HWTroubleConnecting } from ':extension/components/HardwareWallet/HWTroubleConnecting/HWTroubleConnecting';\nimport { UNSUPPORTED_SIGNING_CODE } from ':extension/components/HardwareWallet/HWTroubleConnecting/mapErrorToCopy';\nimport { BlocklistContext } from ':extension/contexts/BlocklistContext';\nimport { useHandleUnlockForTransaction } from ':extension/hooks/useHandleUnlock/useHandleUnlockForTransaction';\nimport { useSignMessageLedger } from ':extension/hooks/useSignMessageLedger/useSignMessageLedger';\nimport { triggerWeb3RequestConfirmButtonEnabled } from ':extension/screens/Web3/eventing';\nimport { completeSignedMessage as completeSignedEVMMessage } from ':extension/screens/Web3/hooks/evm/completeSignedMessage';\nimport { completeSignedMessage as completeSignedSolanaMessage } from ':extension/screens/Web3/hooks/solana/completeSignedMessage';\nimport { useCancel } from ':extension/screens/Web3/hooks/useCancel';\nimport { useHandleNextQueuedRequest } from ':extension/screens/Web3/hooks/useHandleNextQueuedRequest';\nimport { useHasNextQueuedRequest } from ':extension/screens/Web3/hooks/useHasNextQueuedRequest';\nimport { SolanaSignMessage } from ':extension/util/app-states/solana/appState';\nimport { log } from ':extension/util/log';\nimport { SignEthereumMessage } from ':extension/util/Pubsub';\n\nconst messages = defineMessages({\n  message: {\n    defaultMessage: 'Message',\n    description: 'Message Label',\n  },\n  signatureRequested: {\n    defaultMessage: 'Signature requested',\n    description: 'Signature Requested Label',\n  },\n  specialSignatureRequest: {\n    defaultMessage: 'Special signature request',\n    description: 'Special signature request label',\n  },\n  signatureRequestedTooltip: {\n    defaultMessage: 'This dapp requires you to sign a message before you can proceed.',\n    description: 'Tooltip label for signature request that displays on hover over info icon',\n  },\n  sign: {\n    defaultMessage: 'Sign',\n    description: 'Sign Button Label',\n  },\n  cancel: {\n    defaultMessage: 'Cancel',\n    description: 'Cancel Button Label',\n  },\n});\n\nexport type SignMessageProps = { data: SignEthereumMessage | SolanaSignMessage };\n\nexport function SignMessage({ data }: SignMessageProps) {\n  const {\n    request: originalRequest,\n    kind,\n    dappURL: dappUrl,\n    eventId,\n    kind: requestMethod,\n    dappLogoURLAlt,\n    dappLogoURL,\n  } = data;\n\n  const isEVMSigningRequest = isEthereumWeb3Request(originalRequest);\n\n  const activeBlockchain = isEVMSigningRequest ? ETHEREUM_SYMBOL : SOLANA_SYMBOL;\n  const accountIdFromWeb3Request = useAccountIdFromWeb3Request(data.request);\n  const walletFromWeb3Request = useSpecificWalletForAccountId({\n    accountId: accountIdFromWeb3Request,\n    address: originalRequest.params.address,\n    blockchainSymbol: activeBlockchain,\n  });\n  const getWalletGroupForWallet = useGetWalletGroupForWallet();\n  const walletGroup = walletFromWeb3Request\n    ? getWalletGroupForWallet(walletFromWeb3Request)\n    : undefined;\n  const derivationPath = walletGroup?.hardwareDerivationPath;\n  const { formatMessage } = useIntl();\n  const { isLedgerAccount, hasLocallyStoredKey } = useAccountById(accountIdFromWeb3Request);\n  const handleUnlockForTransaction = useHandleUnlockForTransaction();\n  const { disableConfirmButton } = useContext(BlocklistContext);\n  const [ledgerError, setLedgerError] = useState<LedgerError | undefined>(undefined);\n  const handleNextQueuedRequest = useHandleNextQueuedRequest();\n  const hasNextQueuedRequest = useHasNextQueuedRequest();\n  const web3Cancel = useCancel();\n  const isHardwareWalletSigning = useIsHardwareWalletSigning();\n  const setIsHardwareWalletSigning = useSetIsHardwareWalletSigning();\n\n  const { message } = originalRequest.params;\n  const { addPrefix, typedDataJson } = (originalRequest as SignEthereumMessageRequest).params;\n  const isSpecialMessage = !addPrefix && !typedDataJson && isEVMSigningRequest;\n  const formattedDappURL = new URL(dappUrl).hostname;\n\n  const analyticsData = useMemo(\n    () => ({\n      dappUrl,\n      request: originalRequest.method,\n      blockchain: activeBlockchain,\n    }),\n    [dappUrl, originalRequest.method, activeBlockchain],\n  );\n\n  useTriggerWeb3SignMessageRequestViewed(analyticsData);\n\n  const readableMessage = useMemo(() => {\n    return addPrefix ? hexToUtf8(message) : message;\n  }, [message, addPrefix]);\n\n  const sanitizedRequest = useSanitizeMessageSigningRequest(\n    (data as SignEthereumMessage).request || (data as SolanaSignMessage).request,\n    formattedDappURL, // dapp hostname\n  );\n\n  const sanitizedTypedDataJson = useMemo(\n    () => (sanitizedRequest as SignEthereumMessageRequest).params.typedDataJson,\n    [sanitizedRequest],\n  );\n\n  const signMessage = useBuildDappMessageSignature({\n    request: sanitizedRequest,\n    accountId: accountIdFromWeb3Request,\n    activeAddress: walletFromWeb3Request?.primaryAddress,\n    activeWalletIndex: walletFromWeb3Request?.selectedIndex,\n  });\n\n  useEffect(\n    function logEventForConfirmButtonEnabled() {\n      if (!disableConfirmButton) {\n        triggerWeb3RequestConfirmButtonEnabled({\n          dappURL: dappUrl,\n          request: kind,\n          blockchain: activeBlockchain,\n        });\n      }\n    },\n    [activeBlockchain, dappUrl, disableConfirmButton, kind],\n  );\n\n  const onCancel = useCallback(\n    (error: Error) => {\n      web3Cancel({\n        eventId,\n        error,\n        dappURL: dappUrl,\n        blockchain: activeBlockchain,\n        request: requestMethod,\n      });\n      if (hasNextQueuedRequest()) {\n        handleNextQueuedRequest();\n      } else {\n        sendScheduledEvents();\n        window.close();\n      }\n    },\n    [\n      web3Cancel,\n      eventId,\n      dappUrl,\n      activeBlockchain,\n      requestMethod,\n      hasNextQueuedRequest,\n      handleNextQueuedRequest,\n    ],\n  );\n\n  const onError = useCallback(\n    (err: Error) => {\n      triggerWeb3SignMessageError({\n        ...analyticsData,\n        errorName: err.name,\n        errorMessage: err.message,\n      });\n      log(err);\n      onCancel(err);\n    },\n    [onCancel, analyticsData],\n  );\n\n  const onReject = useCallback(() => {\n    triggerWeb3CancelMessageClicked(analyticsData);\n    onCancel(standardErrors.provider.userRejectedRequest({}));\n  }, [onCancel, analyticsData]);\n\n  const triggerWeb3RequestSendingSuccessResponse =\n    useTriggerWeb3RequestSendingSuccessResponse(analyticsData);\n  const onSignSuccess = useCallback(\n    async (signature: Buffer) => {\n      if (isEVMSigningRequest) {\n        await completeSignedEVMMessage(data, signature, triggerWeb3RequestSendingSuccessResponse);\n      } else {\n        await completeSignedSolanaMessage(\n          data,\n          signature,\n          triggerWeb3RequestSendingSuccessResponse,\n        );\n      }\n\n      if (hasNextQueuedRequest()) {\n        handleNextQueuedRequest();\n      } else {\n        sendScheduledEvents();\n        window.close();\n      }\n    },\n    [\n      data,\n      handleNextQueuedRequest,\n      hasNextQueuedRequest,\n      isEVMSigningRequest,\n      triggerWeb3RequestSendingSuccessResponse,\n    ],\n  );\n\n  const signLedgerError = useCallback(\n    (err: Error) => {\n      if (err.name.startsWith('Transport')) {\n        log(err);\n        setLedgerError(err as LedgerError);\n      } else {\n        onError(err);\n      }\n    },\n    [onError],\n  );\n\n  const { signMessageLedger, isSignMessageLedgerLoading, hardwareWalletScreen } =\n    useSignMessageLedger({\n      message,\n      typedDataJson,\n      signSuccess: onSignSuccess,\n      signError: signLedgerError,\n      derivationPath,\n    });\n\n  const onSignMessage = useCallback(async () => {\n    triggerWeb3SignMessageClicked(analyticsData);\n\n    const signWithFetchedMnemonic = () => {\n      signMessage()\n        .then((signature: Buffer) => {\n          onSignSuccess(signature);\n        })\n        .catch((signError: Error) => {\n          onError(signError);\n        });\n    };\n\n    if (hasLocallyStoredKey) {\n      handleUnlockForTransaction({\n        accountId: accountIdFromWeb3Request,\n        unlockSuccess: signWithFetchedMnemonic,\n        unlockError: (_err: Error | undefined) => {\n          onError(new Error('Unknown please try again'));\n        },\n      });\n    } else if (isLedgerAccount) {\n      if (isEVMSigningRequest) {\n        return signMessageLedger();\n      }\n\n      // This code path will not be possible once we prevent HW wallet users from connecting to Solana dapps (see WALL-7368)\n      onError(new Error('Cannot sign request for Ledger: Unsupported blockchain'));\n    }\n  }, [\n    analyticsData,\n    hasLocallyStoredKey,\n    isLedgerAccount,\n    signMessage,\n    onSignSuccess,\n    onError,\n    handleUnlockForTransaction,\n    accountIdFromWeb3Request,\n    isEVMSigningRequest,\n    signMessageLedger,\n  ]);\n\n  const handleLedgerErrorOnBack = useCallback(() => {\n    setLedgerError(undefined);\n    setIsHardwareWalletSigning(false);\n  }, [setIsHardwareWalletSigning]);\n\n  const setAlternativeDappLogoURL = useCallback(\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    (ev: any) => {\n      // eslint-disable-next-line no-param-reassign\n      ev.target.src = dappLogoURLAlt;\n    },\n    [dappLogoURLAlt],\n  );\n\n  const warningMessage = useMessageScanner(\n    (data as SignEthereumMessage).request || (data as SolanaSignMessage).request,\n    formattedDappURL, // dapp hostname\n  );\n\n  if ((isSpecialMessage || ledgerError || !isEVMSigningRequest) && isLedgerAccount) {\n    let statusCode = UNSUPPORTED_SIGNING_CODE;\n    if (ledgerError?.statusCode) {\n      statusCode = ledgerError.statusCode;\n    }\n    return (\n      <VStack spacingHorizontal={3} spacingTop={3}>\n        <HWTroubleConnecting statusCode={statusCode} handleBack={handleLedgerErrorOnBack} />\n      </VStack>\n    );\n  }\n\n  if (isHardwareWalletSigning) {\n    return hardwareWalletScreen;\n  }\n\n  return (\n    <VStack height=\"100%\" testID=\"signature-request-component\">\n      <SigningAddressHeader address={sanitizedRequest.params.address} />\n      <VStack spacingHorizontal={3} spacingTop={2} spacingBottom={1} height=\"100%\">\n        <VStack flexGrow={1}>\n          <VStack flexGrow={0} spacingBottom={1}>\n            <Box spacingBottom={2} flexGrow={1} justifyContent=\"center\">\n              <img\n                alt={dappLogoURLAlt}\n                src={dappLogoURL}\n                onError={setAlternativeDappLogoURL}\n                className={circleImage}\n              />\n            </Box>\n            <Box flexGrow={1} justifyContent=\"center\" spacingBottom={0.5}>\n              <TextTitle3 as=\"p\" testID=\"signature-title\">\n                {isSpecialMessage\n                  ? formatMessage(messages.specialSignatureRequest)\n                  : formatMessage(messages.signatureRequested)}\n              </TextTitle3>\n              <Box alignItems=\"center\">\n                <Tooltip\n                  testID=\"signature-tooltip\"\n                  content={formatMessage(messages.signatureRequestedTooltip)}\n                  placement=\"bottom\"\n                >\n                  <Icon name=\"info\" size=\"xs\" color=\"foreground\" spacingStart={1} />\n                </Tooltip>\n              </Box>\n            </Box>\n            <Box justifyContent=\"center\">\n              <TextBody\n                as=\"p\"\n                color=\"foregroundMuted\"\n                overflow=\"break\"\n                testID=\"signature-request-component-dapp-host-name\"\n              >\n                {formattedDappURL}\n              </TextBody>\n            </Box>\n          </VStack>\n          <VStack>\n            <TextHeadline as=\"p\" spacingTop={1} spacingBottom={1} spacingEnd={1}>\n              {formatMessage(messages.message)}:\n            </TextHeadline>\n            <Box\n              bordered\n              borderRadius=\"compact\"\n              borderColor=\"secondary\"\n              spacingHorizontal={1}\n              spacingTop={1}\n              flexGrow={1}\n            >\n              <Box flexGrow={1} overflow=\"scroll\">\n                <TextLabel2 as=\"div\" color=\"foregroundMuted\" testID=\"message-content\">\n                  <pre\n                    style={{\n                      whiteSpace: sanitizedTypedDataJson ? 'pre-wrap' : 'normal',\n                      maxHeight: warningMessage ? '180px' : '220px',\n                    }}\n                    className={preSpacing}\n                  >\n                    {sanitizedTypedDataJson || readableMessage}\n                  </pre>\n                </TextLabel2>\n              </Box>\n            </Box>\n          </VStack>\n        </VStack>\n      </VStack>\n      <VStack spacingBottom={2}>\n        {warningMessage ? (\n          <WarningBanner\n            spacingBottom={0.5}\n            message={warningMessage}\n            isDismissible={false}\n            showErrorIcon\n            testID=\"sign-txn-warning\"\n          />\n        ) : null}\n        <VStack gap={1} spacingHorizontal={3} spacingTop={1} testID=\"button-area\">\n          <ButtonGroup accessibilityLabel=\"Group\" block>\n            <Button testID=\"cancel-message\" onPress={onReject} block variant=\"secondary\">\n              {formatMessage(messages.cancel)}\n            </Button>\n            <Button\n              testID=\"sign-message\"\n              onPress={onSignMessage}\n              block\n              loading={isSignMessageLedgerLoading}\n              disabled={disableConfirmButton}\n            >\n              {formatMessage(messages.sign)}\n            </Button>\n          </ButtonGroup>\n        </VStack>\n      </VStack>\n    </VStack>\n  );\n}\n\nconst circleImage = css`\n  width: 80px;\n  height: 80px;\n  border-radius: 50%;\n`;\n\nconst preSpacing = css`\n  word-break: break-word;\n  margin: 0;\n`;\n"]}*/

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