.lnr9chz{position:relative;width:38px;height:38px;}
.njuihv5{position:absolute;bottom:0px;right:0px;width:16px;height:16px;border-radius:50%;}
.duoahwy{width:32px;height:32px;border-radius:10px;}
/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9zY3JlZW5zL1dlYjMvRGFwcFRyYW5zYWN0aW9uUmVxdWVzdC9zdGVwcy9UcmFuc2FjdGlvblJlcXVlc3RTdGVwL1RyYW5zYWN0aW9uUmVxdWVzdFRvcFNlY3Rpb24udHN4Il0sIm5hbWVzIjpbIi5sbnI5Y2h6IiwiLm5qdWlodjUiLCIuZHVvYWh3eSJdLCJtYXBwaW5ncyI6IkFBaUZNQTtBQU1BQztBQVNBQyIsImZpbGUiOiJzcmMvc2NyZWVucy9XZWIzL0RhcHBUcmFuc2FjdGlvblJlcXVlc3Qvc3RlcHMvVHJhbnNhY3Rpb25SZXF1ZXN0U3RlcC9UcmFuc2FjdGlvblJlcXVlc3RUb3BTZWN0aW9uLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHVzZUNhbGxiYWNrLCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IGRlZmluZU1lc3NhZ2VzLCB1c2VJbnRsIH0gZnJvbSAncmVhY3QtaW50bCc7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAbGluYXJpYS9jb3JlJztcbmltcG9ydCB7IENhcmQgfSBmcm9tICdAY2JocS9jZHMtd2ViL2NhcmRzJztcbmltcG9ydCB7IEljb24gfSBmcm9tICdAY2JocS9jZHMtd2ViL2ljb25zL0ljb24nO1xuaW1wb3J0IHsgSFN0YWNrLCBWU3RhY2sgfSBmcm9tICdAY2JocS9jZHMtd2ViL2xheW91dCc7XG5pbXBvcnQgeyBUb29sdGlwIH0gZnJvbSAnQGNiaHEvY2RzLXdlYi9vdmVybGF5cy9Ub29sdGlwL1Rvb2x0aXAnO1xuaW1wb3J0IHsgVGV4dExhYmVsMiwgVGV4dFRpdGxlMyB9IGZyb20gJ0BjYmhxL2Nkcy13ZWIvdHlwb2dyYXBoeSc7XG5cbmNvbnN0IG1lc3NhZ2VzID0gZGVmaW5lTWVzc2FnZXMoe1xuICByZXF1ZXN0RnJvbToge1xuICAgIGRlZmF1bHRNZXNzYWdlOiAnUmVxdWVzdCBmcm9tJyxcbiAgICBkZXNjcmlwdGlvbjogJ1JlcXVlc3QgZnJvbSBkYXBwIGxhYmVsJyxcbiAgfSxcbiAgcmVxdWVzdFdhcm5pbmc6IHtcbiAgICBkZWZhdWx0TWVzc2FnZTogJ01ha2Ugc3VyZSB5b3UgdHJ1c3QgdGhpcyBkYXBwJyxcbiAgICBkZXNjcmlwdGlvbjogJ1dhcm5pbmcgdG8gbWl0aWdhdGUgcmlza3MgaW52b2x2ZWQgaW4gdGhlIHRyYW5zYWN0aW9uJyxcbiAgfSxcbn0pO1xuXG50eXBlIFByb3BzID0ge1xuICBkYXBwTG9nb1VSTDogc3RyaW5nO1xuICBkYXBwTG9nb1VSTEFsdDogc3RyaW5nO1xuICBkYXBwVVJMOiBzdHJpbmc7XG4gIG5ldHdvcmtCYWRnZVVSTD86IHN0cmluZztcbiAgbmV0d29ya0JhZGdlQWx0Pzogc3RyaW5nO1xufTtcblxuZXhwb3J0IGZ1bmN0aW9uIFRyYW5zYWN0aW9uUmVxdWVzdFRvcFNlY3Rpb24oe1xuICBkYXBwTG9nb1VSTCxcbiAgZGFwcExvZ29VUkxBbHQsXG4gIGRhcHBVUkwsXG4gIG5ldHdvcmtCYWRnZVVSTCxcbiAgbmV0d29ya0JhZGdlQWx0LFxufTogUHJvcHMpIHtcbiAgY29uc3QgeyBmb3JtYXRNZXNzYWdlIH0gPSB1c2VJbnRsKCk7XG4gIGNvbnN0IHVybCA9IG5ldyBVUkwoZGFwcFVSTCk7XG4gIGNvbnN0IFtzb3VyY2VVcmwsIHNldFNvdXJjZVVybF0gPSB1c2VTdGF0ZShkYXBwTG9nb1VSTCk7XG5cbiAgY29uc3Qgc2V0QWx0ZXJuYXRpdmVEYXBwTG9nb1VSTCA9IHVzZUNhbGxiYWNrKCgpID0+IHtcbiAgICBzZXRTb3VyY2VVcmwoZGFwcExvZ29VUkxBbHQpO1xuICB9LCBbZGFwcExvZ29VUkxBbHRdKTtcblxuICByZXR1cm4gKFxuICAgIDxWU3RhY2sgd2lkdGg9XCIxMDAlXCIgZ2FwPXswLjV9IHNwYWNpbmdUb3A9ezJ9PlxuICAgICAgPENhcmQgYm9yZGVyZWQgYm9yZGVyUmFkaXVzPVwic3RhbmRhcmRcIiBlbGV2YXRpb249ezF9IHNwYWNpbmc9ezJ9IHdpZHRoPVwiMTAwJVwiIGhlaWdodD1cIjE2MHB4XCI+XG4gICAgICAgIDxWU3RhY2sganVzdGlmeUNvbnRlbnQ9XCJjZW50ZXJcIiBnYXA9ezAuNX0gaGVpZ2h0PVwiMTAwJVwiPlxuICAgICAgICAgIDxkaXYgY2xhc3NOYW1lPXtsb2dvQ29udGFpbmVyfT5cbiAgICAgICAgICAgIDxpbWdcbiAgICAgICAgICAgICAgY2xhc3NOYW1lPXtkYXBwTG9nb31cbiAgICAgICAgICAgICAgc3JjPXtzb3VyY2VVcmx9XG4gICAgICAgICAgICAgIGFsdD17ZGFwcExvZ29VUkxBbHR9XG4gICAgICAgICAgICAgIG9uRXJyb3I9e3NldEFsdGVybmF0aXZlRGFwcExvZ29VUkx9XG4gICAgICAgICAgICAvPlxuICAgICAgICAgICAge25ldHdvcmtCYWRnZVVSTCAmJiAoXG4gICAgICAgICAgICAgIDxpbWcgY2xhc3NOYW1lPXtuZXR3b3JrQmFkZ2V9IHNyYz17bmV0d29ya0JhZGdlVVJMfSBhbHQ9e25ldHdvcmtCYWRnZUFsdH0gLz5cbiAgICAgICAgICAgICl9XG4gICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgPEhTdGFjayBhbGlnbkl0ZW1zPVwiY2VudGVyXCI+XG4gICAgICAgICAgICA8VGV4dExhYmVsMiBjb2xvcj1cImZvcmVncm91bmRNdXRlZFwiIGFzPVwicFwiPlxuICAgICAgICAgICAgICB7Zm9ybWF0TWVzc2FnZShtZXNzYWdlcy5yZXF1ZXN0RnJvbSl9XG4gICAgICAgICAgICA8L1RleHRMYWJlbDI+XG4gICAgICAgICAgICA8VG9vbHRpcCBjb250ZW50PXtmb3JtYXRNZXNzYWdlKG1lc3NhZ2VzLnJlcXVlc3RXYXJuaW5nKX0gcGxhY2VtZW50PVwiYm90dG9tXCI+XG4gICAgICAgICAgICAgIDxJY29uXG4gICAgICAgICAgICAgICAgdGVzdElEPVwiZGFwcC10cmFuc2FjdGlvbi1yZXF1ZXN0LW1vcmUtaW5mby1pY29uXCJcbiAgICAgICAgICAgICAgICBuYW1lPVwiaW5mb1wiXG4gICAgICAgICAgICAgICAgc2l6ZT1cInhzXCJcbiAgICAgICAgICAgICAgICBjb2xvcj1cImZvcmVncm91bmRNdXRlZFwiXG4gICAgICAgICAgICAgICAgc3BhY2luZ1N0YXJ0PXsxfVxuICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgPC9Ub29sdGlwPlxuICAgICAgICAgIDwvSFN0YWNrPlxuICAgICAgICAgIDxUZXh0VGl0bGUzIGFzPVwicFwiIG92ZXJmbG93PVwiYnJlYWtcIiB0ZXN0SUQ9XCJkYXBwLXRyYW5zYWN0aW9uLXJlcXVlc3QtZGFwcC1ob3N0LW5hbWVcIj5cbiAgICAgICAgICAgIHt1cmwuaG9zdG5hbWV9XG4gICAgICAgICAgPC9UZXh0VGl0bGUzPlxuICAgICAgICA8L1ZTdGFjaz5cbiAgICAgIDwvQ2FyZD5cbiAgICA8L1ZTdGFjaz5cbiAgKTtcbn1cblxuY29uc3QgbG9nb0NvbnRhaW5lciA9IGNzc2BcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuICB3aWR0aDogMzhweDtcbiAgaGVpZ2h0OiAzOHB4O1xuYDtcblxuY29uc3QgbmV0d29ya0JhZGdlID0gY3NzYFxuICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gIGJvdHRvbTogMHB4O1xuICByaWdodDogMHB4O1xuICB3aWR0aDogMTZweDtcbiAgaGVpZ2h0OiAxNnB4O1xuICBib3JkZXItcmFkaXVzOiA1MCU7XG5gO1xuXG5jb25zdCBkYXBwTG9nbyA9IGNzc2BcbiAgd2lkdGg6IDMycHg7XG4gIGhlaWdodDogMzJweDtcbiAgYm9yZGVyLXJhZGl1czogMTBweDtcbmA7XG4iXX0=*/
.nb1wmky{position:absolute;bottom:0;right:0;width:16px;height:16px;border-radius:50%;}
/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["src/screens/Web3/DappTransactionRequest/steps/TxApproval/TxApproval.tsx"],"names":[".nb1wmky"],"mappings":"AAuMMA","file":"src/screens/Web3/DappTransactionRequest/steps/TxApproval/TxApproval.tsx","sourcesContent":["import { memo, useCallback, useMemo, useState } from 'react';\nimport { defineMessages, useIntl } from 'react-intl';\nimport { css } from '@linaria/core';\nimport { AllPossibleBlockchainSymbol } from 'cb-wallet-data/chains/blockchains';\nimport {\n  OperationType,\n  ParsedPreapprovalOperations,\n} from 'cb-wallet-data/stores/TxScanner/interfaces/ScanTxResult';\nimport { CollectibleMedia } from 'wallet-cds-extension/components/CollectibleMedia/CollectibleMedia';\nimport { getHostNameForDapp } from 'wallet-cds-extension/util/getHostNameForDapp/getHostNameForDapp';\nimport { Icon } from '@cbhq/cds-web/icons/Icon';\nimport { Box, HStack, VStack } from '@cbhq/cds-web/layout';\nimport { RemoteImage } from '@cbhq/cds-web/media/RemoteImage';\nimport { Tooltip } from '@cbhq/cds-web/overlays/Tooltip/Tooltip';\nimport { TextLabel2, TextTitle3 } from '@cbhq/cds-web/typography';\n\nimport { useTriggerTxApprovalLoaded } from ':extension/screens/Web3/eventing';\n\ntype Props = {\n  dappLogoURL: string;\n  dappLogoURLAlt: string;\n  dappURL: string;\n  networkBadgeURL?: string;\n  networkBadgeAlt?: string;\n  approveOperation?: ParsedPreapprovalOperations;\n  error?: Error;\n  request: string;\n  blockchain: AllPossibleBlockchainSymbol;\n  chainId: string;\n};\n\nconst ICON_COLOR = 'var(--foreground-muted)';\n\nconst messages = defineMessages({\n  tokenAccessTitle: {\n    defaultMessage: 'Allow token access',\n    description: 'allowing token access',\n  },\n  nftAccessTitle: {\n    defaultMessage: 'Allow NFT access',\n    description: 'allowing NFT access',\n  },\n  dappAllowedText: {\n    defaultMessage: '{dappHostname}',\n    description: 'Dapp host URL',\n  },\n  warning: {\n    defaultMessage: 'Only allow dapps that you fully trust with access to your wallet',\n    description: '',\n  },\n  onlySignText: {\n    defaultMessage: 'Only sign if you fully trust this site with access to your account',\n    description: 'only sign if website is trusted.',\n  },\n});\n\nfunction TxApprovalComponent({\n  dappLogoURL,\n  dappLogoURLAlt,\n  dappURL,\n  networkBadgeURL,\n  networkBadgeAlt,\n  approveOperation,\n  request,\n  blockchain,\n  chainId,\n}: Props) {\n  const dappHostname: string = useMemo(() => {\n    return getHostNameForDapp(dappURL);\n  }, [dappURL]);\n\n  useTriggerTxApprovalLoaded({\n    approveOperation,\n    dappURL: dappHostname,\n    request,\n    blockchain,\n  });\n\n  const { formatMessage } = useIntl();\n  const [sourceUrl, setSourceUrl] = useState(dappLogoURL);\n  const imageUrl = useMemo(() => approveOperation?.imageUrl, [approveOperation]);\n\n  const collectionImageUrl = useCallback(\n    (url: string) => {\n      const collectionName =\n        approveOperation &&\n        (approveOperation.operationType === OperationType.ITEM_APPROVAL ||\n          approveOperation.operationType === OperationType.ITEM_APPROVAL_ALL)\n          ? approveOperation.collectionName\n          : '';\n      return {\n        imageUrl: url,\n        contractAddress: '',\n        youtubeUrl: undefined,\n        iframeUrl: undefined,\n        animationUrl: undefined,\n        tokenType: '',\n        collectionName: collectionName || '',\n        tokenId: '',\n      };\n    },\n    [approveOperation],\n  );\n\n  const setAlternativeDappLogoURL = useCallback(() => {\n    setSourceUrl(dappLogoURLAlt);\n  }, [dappLogoURLAlt]);\n\n  const headerTitle = useMemo(() => {\n    if (approveOperation?.operationType === 'BALANCE_APPROVAL') {\n      return messages.tokenAccessTitle;\n    }\n\n    if (\n      approveOperation?.operationType === 'ITEM_APPROVAL_ALL' ||\n      approveOperation?.operationType === 'ITEM_APPROVAL'\n    ) {\n      return messages.nftAccessTitle;\n    }\n\n    return null;\n  }, [approveOperation?.operationType]);\n\n  return (\n    <Box\n      bordered\n      borderRadius=\"standard\"\n      flexDirection=\"column\"\n      spacingHorizontal={2}\n      width=\"100%\"\n      testID=\"tx-approval\"\n    >\n      <HStack justifyContent=\"flex-start\" alignItems=\"center\">\n        <Box spacingTop={3} position=\"relative\">\n          <RemoteImage\n            source={sourceUrl}\n            resizeMode=\"contain\"\n            width={32}\n            height={32}\n            shape=\"squircle\"\n            alt={dappLogoURLAlt}\n            onError={setAlternativeDappLogoURL}\n          />\n          {networkBadgeURL ? (\n            <img className={networkBadge} src={networkBadgeURL} alt={networkBadgeAlt} />\n          ) : null}\n        </Box>\n        {imageUrl ? (\n          <>\n            <Box spacingTop={3} spacingHorizontal={1}>\n              <Icon size=\"s\" name=\"arrowsHorizontal\" dangerouslySetColor={ICON_COLOR} />\n            </Box>\n            <Box spacingTop={3}>\n              <CollectibleMedia\n                {...collectionImageUrl(imageUrl)}\n                radius=\"roundedFull\"\n                height=\"32px\"\n                width=\"32px\"\n                chainId={chainId}\n              />\n            </Box>\n          </>\n        ) : null}\n      </HStack>\n      <Box spacingBottom={0.5} spacingTop={3}>\n        <VStack>\n          {Boolean(headerTitle) && <TextTitle3 as=\"h1\">{formatMessage(headerTitle!)}</TextTitle3>}\n        </VStack>\n      </Box>\n      <Box spacingBottom={3}>\n        <HStack>\n          <TextLabel2\n            as=\"span\"\n            color=\"foregroundMuted\"\n            overflow=\"break\"\n            testID=\"dapp-transaction-request-dapp-host-name\"\n          >\n            {formatMessage(messages.dappAllowedText, {\n              dappHostname,\n            })}\n          </TextLabel2>\n          <Tooltip content={formatMessage(messages.onlySignText)} placement=\"bottom\">\n            <Icon\n              testID=\"dapp-transaction-request-more-info-icon\"\n              name=\"info\"\n              size=\"xs\"\n              color=\"foregroundMuted\"\n              spacingStart={1}\n              spacingTop={0.5}\n            />\n          </Tooltip>\n        </HStack>\n      </Box>\n    </Box>\n  );\n}\n\nexport const TxApproval = memo(TxApprovalComponent);\n\nconst networkBadge = css`\n  position: absolute;\n  bottom: 0;\n  right: 0;\n  width: 16px;\n  height: 16px;\n  border-radius: 50%;\n`;\n"]}*/

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