.b9dlpow{background-color:var(--background-alternate);display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column;}
.iu69ejy{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-pack:center;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center;-webkit-align-items:center;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-flex:1;-webkit-flex-grow:1;-ms-flex-positive:1;flex-grow:1;height:390px;color:rgb(var(--orange20));}.iu69ejy > div{zoom:4;}
.b1hvuwxf{height:185px;position:relative;background-color:var(--background);border-top-left-radius:16px;border-top-right-radius:16px;box-shadow:0px 0px 8px rgba(0,0,0,0.04),0px 16px 24px rgba(0,0,0,0.06);}
.bcmu8fm{margin:70px 24px 0 24px;}
.e1y5zb73{font-size:20px;position:relative;margin-left:24px;top:34px;}
/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL2xpYnMvd2FsbGV0LWNkcy1leHRlbnNpb24vY29tcG9uZW50cy9BdXRob3JpemF0aW9uRXJyb3IudHN4Il0sIm5hbWVzIjpbIi5iOWRscG93IiwiLml1NjllankiLCIuYjFodnV3eGYiLCIuYmNtdThmbSIsIi5lMXk1emI3MyJdLCJtYXBwaW5ncyI6IkFBZ0RNQTtBQU1BQztBQWNBQztBQVNBQztBQUlBQyIsImZpbGUiOiIuLi8uLi9saWJzL3dhbGxldC1jZHMtZXh0ZW5zaW9uL2NvbXBvbmVudHMvQXV0aG9yaXphdGlvbkVycm9yLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGRlZmluZU1lc3NhZ2VzLCB1c2VJbnRsIH0gZnJvbSAncmVhY3QtaW50bCc7XG5pbXBvcnQgeyBjc3MgfSBmcm9tICdAbGluYXJpYS9jb3JlJztcbmltcG9ydCB7IHN0eWxlZCB9IGZyb20gJ0BsaW5hcmlhL3JlYWN0JztcbmltcG9ydCB7IEJ1dHRvbiwgQnV0dG9uR3JvdXAgfSBmcm9tICdAY2JocS9jZHMtd2ViL2J1dHRvbnMnO1xuaW1wb3J0IHsgSWNvbiB9IGZyb20gJ0BjYmhxL2Nkcy13ZWIvaWNvbnMvSWNvbic7XG5cbmNvbnN0IG1lc3NhZ2VzID0gZGVmaW5lTWVzc2FnZXMoe1xuICBjb25uZWN0aW9uRmFpbGVkTWVzc2FnZToge1xuICAgIGRlZmF1bHRNZXNzYWdlOiAnQ29ubmVjdGlvbiBmYWlsZWQnLFxuICAgIGRlc2NyaXB0aW9uOiAnQ29ubmVjdGlvbiBmYWlsZWQgZXJyb3Igc3RhdHVzIHRleHQnLFxuICB9LFxuICB0cnlBZ2FpbkJ1dHRvbkdyb3VwOiB7XG4gICAgZGVmYXVsdE1lc3NhZ2U6ICdBY3Rpb24gYnV0dG9ucycsXG4gICAgZGVzY3JpcHRpb246ICdCdXR0b24gZ3JvdXAgYWNjZXNzaWJpbGl0eSBsYWJlbCcsXG4gIH0sXG4gIHRyeUFnYWluQnV0dG9uOiB7XG4gICAgZGVmYXVsdE1lc3NhZ2U6ICdUcnkgYWdhaW4nLFxuICAgIGRlc2NyaXB0aW9uOiAnQWN0aW9uIGJ1dHRvbiB0ZXh0JyxcbiAgfSxcbn0pO1xuXG50eXBlIEF1dGhvcml6YXRpb25FcnJvclByb3BzID0ge1xuICByZXNldEVycm9yOiAoKSA9PiB2b2lkO1xufTtcblxuZXhwb3J0IGZ1bmN0aW9uIEF1dGhvcml6YXRpb25FcnJvcih7IHJlc2V0RXJyb3IgfTogQXV0aG9yaXphdGlvbkVycm9yUHJvcHMpIHtcbiAgY29uc3QgeyBmb3JtYXRNZXNzYWdlIH0gPSB1c2VJbnRsKCk7XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2IGNsYXNzTmFtZT17YmFzZUNvbnRhaW5lcn0+XG4gICAgICA8SWNvbkNvbnRhaW5lcj5cbiAgICAgICAgPEljb24gbmFtZT1cImVycm9yXCIgc2l6ZT1cImxcIiBjb2xvcj1cImN1cnJlbnRDb2xvclwiIC8+XG4gICAgICA8L0ljb25Db250YWluZXI+XG5cbiAgICAgIDxkaXYgY2xhc3NOYW1lPXtidXR0b25Db250YWluZXJ9PlxuICAgICAgICA8ZGl2IGNsYXNzTmFtZT17ZXJyb3JUZXh0fT57Zm9ybWF0TWVzc2FnZShtZXNzYWdlcy5jb25uZWN0aW9uRmFpbGVkTWVzc2FnZSl9PC9kaXY+XG4gICAgICAgIDxkaXYgY2xhc3NOYW1lPXtidXR0b25Qb3NpdGlvbn0+XG4gICAgICAgICAgPEJ1dHRvbkdyb3VwIGJsb2NrIGFjY2Vzc2liaWxpdHlMYWJlbD17Zm9ybWF0TWVzc2FnZShtZXNzYWdlcy50cnlBZ2FpbkJ1dHRvbkdyb3VwKX0+XG4gICAgICAgICAgICA8QnV0dG9uIHR5cGU9XCJidXR0b25cIiB2YXJpYW50PVwicHJpbWFyeVwiIG9uUHJlc3M9e3Jlc2V0RXJyb3J9IGRhdGEtdGVzdGlkPVwidHJ5LWFnYWluXCI+XG4gICAgICAgICAgICAgIHtmb3JtYXRNZXNzYWdlKG1lc3NhZ2VzLnRyeUFnYWluQnV0dG9uKX1cbiAgICAgICAgICAgIDwvQnV0dG9uPlxuICAgICAgICAgIDwvQnV0dG9uR3JvdXA+XG4gICAgICAgIDwvZGl2PlxuICAgICAgPC9kaXY+XG4gICAgPC9kaXY+XG4gICk7XG59XG5cbmNvbnN0IGJhc2VDb250YWluZXIgPSBjc3NgXG4gIGJhY2tncm91bmQtY29sb3I6IHZhcigtLWJhY2tncm91bmQtYWx0ZXJuYXRlKTtcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbmA7XG5cbmNvbnN0IEljb25Db250YWluZXIgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBqdXN0aWZ5LWNvbnRlbnQ6IGNlbnRlcjtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgZmxleC1ncm93OiAxO1xuICBoZWlnaHQ6IDM5MHB4O1xuICBjb2xvcjogcmdiKHZhcigtLW9yYW5nZTIwKSk7XG5cbiAgLyogSGFjayBmb3IgaW5jcmVhc2luZyB0aGUgc2l6ZSBvZiBhIENEUyBJY29uICovXG4gICYgPiBkaXYge1xuICAgIHpvb206IDQ7XG4gIH1cbmA7XG5cbmNvbnN0IGJ1dHRvbkNvbnRhaW5lciA9IGNzc2BcbiAgaGVpZ2h0OiAxODVweDtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuICBiYWNrZ3JvdW5kLWNvbG9yOiB2YXIoLS1iYWNrZ3JvdW5kKTtcbiAgYm9yZGVyLXRvcC1sZWZ0LXJhZGl1czogMTZweDtcbiAgYm9yZGVyLXRvcC1yaWdodC1yYWRpdXM6IDE2cHg7XG4gIGJveC1zaGFkb3c6IDBweCAwcHggOHB4IHJnYmEoMCwgMCwgMCwgMC4wNCksIDBweCAxNnB4IDI0cHggcmdiYSgwLCAwLCAwLCAwLjA2KTtcbmA7XG5cbmNvbnN0IGJ1dHRvblBvc2l0aW9uID0gY3NzYFxuICBtYXJnaW46IDcwcHggMjRweCAwIDI0cHg7XG5gO1xuXG5jb25zdCBlcnJvclRleHQgPSBjc3NgXG4gIGZvbnQtc2l6ZTogMjBweDtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuICBtYXJnaW4tbGVmdDogMjRweDtcbiAgdG9wOiAzNHB4O1xuYDtcbiJdfQ==*/
.b1kpd7hv{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-flex-flow:column nowrap;-ms-flex-flow:column nowrap;flex-flow:column nowrap;margin:24px;}
.b1fu1pg{-webkit-transform:translateY(120%);-ms-transform:translateY(120%);transform:translateY(120%);-webkit-transition:-webkit-transform 0.3s ease-out;-webkit-transition:transform 0.3s ease-out;transition:transform 0.3s ease-out;}
/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["src/screens/Web3/WatchAsset/WatchAsset.tsx"],"names":[".b1kpd7hv",".b1fu1pg"],"mappings":"AAoRMA;AAMAC","file":"src/screens/Web3/WatchAsset/WatchAsset.tsx","sourcesContent":["import { useCallback, useEffect, useMemo, useState } from 'react';\nimport { defineMessages, useIntl } from 'react-intl';\nimport { css, cx } from '@linaria/core';\nimport { triggerCustomTokenAdded } from 'cb-wallet-analytics/settings';\nimport { ETHEREUM_SYMBOL } from 'cb-wallet-data/chains/AccountBased/Ethereum/constants';\nimport { CurrencyCode } from 'cb-wallet-data/models/CurrencyCode';\nimport { useCustomNetworkArgs } from 'cb-wallet-data/stores/CustomNetworks/hooks/useCustomNetworkArgs';\nimport { Network } from 'cb-wallet-data/stores/Networks/models/Network';\nimport { useAddCustomEthToken } from 'cb-wallet-data/stores/Wallets/hooks/useAddCustomEthToken';\nimport { abridgeAddress } from 'cb-wallet-data/utils/abridgeAddress';\nimport { AuthorizationError } from 'wallet-cds-extension/components/AuthorizationError';\nimport { Button, ButtonGroup } from '@cbhq/cds-web/buttons';\nimport { Box, HStack, VStack } from '@cbhq/cds-web/layout';\nimport { RemoteImage } from '@cbhq/cds-web/media/RemoteImage';\nimport { TextBody, TextTitle3 } from '@cbhq/cds-web/typography';\n\nimport { ExtensionConnectionResponse } from ':extension/contentscript/evm/ExtensionConnectionResponse';\nimport { Pubsub, WatchAsset } from ':extension/util/Pubsub';\n\nconst messages = defineMessages({\n  dappLogoAlt: {\n    defaultMessage: 'DApp logo',\n    description: 'Alt text for DApp logo',\n  },\n  addToken: {\n    defaultMessage: `Add Suggested Token?`,\n    description: 'Add Token Header',\n  },\n  addTokenQuestion: {\n    defaultMessage: `Would you like to import this token?`,\n    description: 'Add Token Question body',\n  },\n  addTokenRequestDescription: {\n    defaultMessage: `This website is requesting to add:`,\n    description: 'Add Token Request body',\n  },\n  tokenSymbol: {\n    defaultMessage: `Symbol`,\n    description: 'Token symbol label',\n  },\n  tokenAddress: {\n    defaultMessage: `Address`,\n    description: 'Token address label',\n  },\n  authorizationButtonGroup: {\n    defaultMessage: 'Action buttons',\n    description: 'Button group accessibility label',\n  },\n  addCustomTokenButton: {\n    defaultMessage: 'Add Token',\n    description: 'Action button text',\n  },\n  denyActionButton: {\n    defaultMessage: 'Deny',\n    description: 'Action button text',\n  },\n  closeButton: {\n    defaultMessage: 'Close',\n    description: 'Action close text',\n  },\n  allowlistedMessage: {\n    defaultMessage:\n      'Coinbase Wallet automatically tracks token ownerships on the {network} network. There is no need to import {token}.',\n\n    description: 'Message when user attempts to add custom token to allowlisted network',\n  },\n});\n\ntype AllowlistProps = {\n  symbol?: string;\n  chainName?: string;\n};\n\ntype AuthorizationRequestProps = {\n  options: WatchAsset;\n  network?: Network;\n};\n\nfunction AllowlistedNetworkView({ symbol, chainName }: AllowlistProps) {\n  const { formatMessage } = useIntl();\n  const closeWindow = useCallback(() => {\n    window.close();\n  }, []);\n\n  return (\n    <div data-testid=\"allowlist-prompt\">\n      <VStack spacing={4} justifyContent=\"space-between\" height=\"100%\" width=\"100%\">\n        <VStack gap={2}>\n          <TextTitle3 as=\"h1\" align=\"center\">\n            {formatMessage(messages.addToken)}\n          </TextTitle3>\n          <TextBody as=\"p\" color=\"foregroundMuted\" align=\"center\">\n            {formatMessage(messages.allowlistedMessage, {\n              network: chainName,\n              token: symbol || 'this token',\n            })}\n          </TextBody>\n        </VStack>\n        <Button\n          type=\"button\"\n          variant=\"primary\"\n          data-testid=\"close-watch-asset-button\"\n          transparent\n          onPress={closeWindow}\n        >\n          {formatMessage(messages.closeButton)}\n        </Button>\n      </VStack>\n    </div>\n  );\n}\n\nexport function WatchAssetRequest({ options }: AuthorizationRequestProps) {\n  const [authed, setAuthed] = useState(false);\n  const [authorizing, setAuthorizing] = useState(false);\n  const [error, setError] = useState(null);\n  const resetError = useCallback(() => setError(null), [setError]);\n  const { formatMessage } = useIntl();\n  const addCustomEthToken = useAddCustomEthToken();\n  const customNetworks = useCustomNetworkArgs();\n\n  const customNetwork = useMemo(\n    () =>\n      customNetworks.find(\n        ({ network }) => network && network.asChain()?.chainId === parseInt(options.chainId, 10),\n      ),\n    [customNetworks, options.chainId],\n  );\n\n  const ethereumChain = useMemo(() => {\n    return !customNetwork && Network.fromChainId({ chainId: BigInt(options.chainId) });\n  }, [customNetwork, options.chainId]);\n\n  const addCustomToken = useCallback(async () => {\n    if (!customNetwork) return null;\n    try {\n      const currencyCode = new CurrencyCode(options.symbol ?? '');\n      await addCustomEthToken(\n        currencyCode,\n        options.address,\n        customNetwork,\n        BigInt(options.decimals ?? 18),\n      );\n\n      triggerCustomTokenAdded({\n        contractAddress: options.address,\n        tokenSymbol: currencyCode.rawValue,\n        chainId: Number(customNetwork.network.asChain()?.chainId),\n        chainName: customNetwork.name,\n        fromWatchAsset: true,\n      });\n\n      setError(null);\n      setAuthorizing(false);\n    } catch (err: ErrorOrAny) {\n      setError(err.message);\n      setAuthorizing(false);\n    }\n  }, [addCustomEthToken, customNetwork, options.address, options.decimals, options.symbol]);\n\n  useEffect(function subscribeToAuthStateChanges() {\n    const subscription = Pubsub.subscribe((s) => {\n      if (s.constructor === WatchAsset) {\n        setAuthed(false);\n      }\n    });\n\n    return () => subscription.unsubscribe();\n  }, []);\n\n  const denyAuthorize = useCallback(() => {\n    chrome.runtime.sendMessage({\n      type: 'extensionUIResponse',\n      data: {\n        id: options.eventId,\n        action: ExtensionConnectionResponse.watchAssetDeny,\n        blockchain: ETHEREUM_SYMBOL,\n      },\n    });\n    window.close();\n  }, [options.eventId]);\n\n  const allowAuthorize = useCallback(() => {\n    setAuthorizing(true);\n    chrome.runtime.sendMessage({\n      type: 'extensionUIResponse',\n      data: {\n        id: options.eventId,\n        action: ExtensionConnectionResponse.watchAssetApprove,\n        chainId: options.chainId,\n        blockchain: ETHEREUM_SYMBOL,\n      },\n    });\n    addCustomToken().then(() => window.close());\n  }, [options.eventId, options.chainId, addCustomToken]);\n\n  if (error) {\n    return <AuthorizationError resetError={resetError} />;\n  }\n\n  if (ethereumChain) {\n    return (\n      <AllowlistedNetworkView\n        symbol={options.symbol}\n        chainName={ethereumChain.asChain()?.displayName}\n      />\n    );\n  }\n\n  return (\n    <VStack position=\"absolute\" bottom={0} right={0} width=\"100%\">\n      <HStack justifyContent=\"center\" alignItems=\"center\">\n        {options.image ? (\n          <RemoteImage\n            alt={formatMessage(messages.dappLogoAlt)}\n            width={80}\n            height={80}\n            source={options.image}\n          />\n        ) : (\n          <></>\n        )}\n      </HStack>\n      <div className={cx(body, authed && bodyExit)} data-testid=\"add-token-prompt\">\n        <VStack gap={2}>\n          <TextTitle3 as=\"h1\" align=\"center\">\n            {formatMessage(messages.addToken)}\n          </TextTitle3>\n          <TextBody as=\"p\" color=\"foregroundMuted\" align=\"center\">\n            {formatMessage(messages.addTokenQuestion)}\n          </TextBody>\n          <Box spacingVertical={2}>\n            <VStack gap={2}>\n              <TextBody as=\"p\" color=\"foregroundMuted\" align=\"start\">\n                {formatMessage(messages.addTokenRequestDescription)}\n              </TextBody>\n              <TextBody as=\"p\" color=\"foregroundMuted\" align=\"start\">\n                {formatMessage(messages.tokenSymbol)}: {options.symbol}\n              </TextBody>\n              <TextBody as=\"p\" color=\"foregroundMuted\" align=\"start\">\n                {formatMessage(messages.tokenAddress)}: {abridgeAddress(options.address)}\n              </TextBody>\n            </VStack>\n          </Box>\n        </VStack>\n      </div>\n      <Box spacing={3} flexDirection=\"column\">\n        <ButtonGroup\n          block\n          vertical\n          accessibilityLabel={formatMessage(messages.authorizationButtonGroup)}\n        >\n          <Button\n            type=\"button\"\n            variant=\"primary\"\n            onPress={allowAuthorize}\n            loading={authorizing}\n            data-testid=\"allow-watch-asset-button\"\n          >\n            {formatMessage(messages.addCustomTokenButton)}\n          </Button>\n          <Button\n            type=\"button\"\n            variant=\"secondary\"\n            onPress={denyAuthorize}\n            data-testid=\"deny-watch-asset-button\"\n            transparent\n          >\n            {formatMessage(messages.denyActionButton)}\n          </Button>\n        </ButtonGroup>\n      </Box>\n    </VStack>\n  );\n}\n\nconst body = css`\n  display: flex;\n  flex-flow: column nowrap;\n  margin: 24px;\n`;\n\nconst bodyExit = css`\n  transform: translateY(120%);\n  transition: transform 0.3s ease-out;\n`;\n"]}*/

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