.b89j0hz{overflow-wrap:anywhere;}
.a176mdao{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-flex-direction:row;-ms-flex-direction:row;flex-direction:row;-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap;height:100%;width:324px;row-gap:10px;-webkit-column-gap:10px;column-gap:10px;overflow-y:auto;overflow-x:hidden;}
/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9zY3JlZW5zL0NvbGxlY3RpYmxlRGV0YWlsL0NvbGxlY3RpYmxlQXR0cmlidXRlcy50c3giXSwibmFtZXMiOlsiLmI4OWowaHoiLCIuYTE3Nm1kYW8iXSwibWFwcGluZ3MiOiJBQTBHTUE7QUFJQUMiLCJmaWxlIjoic3JjL3NjcmVlbnMvQ29sbGVjdGlibGVEZXRhaWwvQ29sbGVjdGlibGVBdHRyaWJ1dGVzLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHVzZU1lbW8gfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBkZWZpbmVNZXNzYWdlcywgdXNlSW50bCB9IGZyb20gJ3JlYWN0LWludGwnO1xuaW1wb3J0IHsgc3R5bGVkIH0gZnJvbSAnQGxpbmFyaWEvcmVhY3QnO1xuaW1wb3J0IHsgQ29sbGVjdGlibGUgfSBmcm9tICdjYi13YWxsZXQtZGF0YS9zdG9yZXMvQ29sbGVjdGlvbi90eXBlcyc7XG5pbXBvcnQgeyBCb3gsIFZTdGFjayB9IGZyb20gJ0BjYmhxL2Nkcy13ZWIvbGF5b3V0JztcbmltcG9ydCB7IFRoZW1lUHJvdmlkZXIgfSBmcm9tICdAY2JocS9jZHMtd2ViL3N5c3RlbSc7XG5pbXBvcnQgeyBUZXh0SGVhZGxpbmUsIFRleHRMYWJlbDIsIFRleHRUaXRsZTMgfSBmcm9tICdAY2JocS9jZHMtd2ViL3R5cG9ncmFwaHknO1xuXG5jb25zdCBXSURUSCA9ICczMjRweCc7XG5cbmNvbnN0IG1lc3NhZ2VzID0gZGVmaW5lTWVzc2FnZXMoe1xuICBhdHRyaWJ1dGVzOiB7XG4gICAgZGVmYXVsdE1lc3NhZ2U6ICdBdHRyaWJ1dGVzJyxcbiAgICBkZXNjcmlwdGlvbjogJ0xhYmVsIGZvciBhdHRyaWJ1dGVzJyxcbiAgfSxcbn0pO1xuXG50eXBlIENvbGxlY3RpYmxlQXR0cmlidXRlUHJvcHMgPSBQaWNrPENvbGxlY3RpYmxlLCAnYXR0cmlidXRlcyc+O1xuXG50eXBlIEF0dHJpYnV0ZVRhZ1Byb3BzID0ge1xuICBhdHRyaWJ1dGVOYW1lOiBzdHJpbmc7XG4gIGF0dHJpYnV0ZVZhbHVlOiBzdHJpbmc7XG59O1xuXG5mdW5jdGlvbiBBdHRyaWJ1dGVUYWcoeyBhdHRyaWJ1dGVOYW1lLCBhdHRyaWJ1dGVWYWx1ZSB9OiBBdHRyaWJ1dGVUYWdQcm9wcykge1xuICByZXR1cm4gKFxuICAgIDxUaGVtZVByb3ZpZGVyIHNjYWxlPVwic21hbGxcIj5cbiAgICAgIDxCcmVha1dvcmRzPlxuICAgICAgICA8Qm94IGJhY2tncm91bmQ9XCJiYWNrZ3JvdW5kQWx0ZXJuYXRlXCIgYm9yZGVyUmFkaXVzPVwiY29tcGFjdFwiIHNwYWNpbmc9ezF9IG1heFdpZHRoPXtXSURUSH0+XG4gICAgICAgICAgPFZTdGFjayBnYXA9ezAuNX0gc3BhY2luZz17MC41fT5cbiAgICAgICAgICAgIDxUZXh0TGFiZWwyXG4gICAgICAgICAgICAgIGFzPVwicFwiXG4gICAgICAgICAgICAgIGNvbG9yPVwiZm9yZWdyb3VuZE11dGVkXCJcbiAgICAgICAgICAgICAgdGVzdElEPXtgbmZ0LWNvbGxlY3RpYmxlLSR7YXR0cmlidXRlTmFtZS50b0xvd2VyQ2FzZSgpfWB9XG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgIHthdHRyaWJ1dGVOYW1lfVxuICAgICAgICAgICAgPC9UZXh0TGFiZWwyPlxuICAgICAgICAgICAgPFRleHRIZWFkbGluZSBhcz1cInBcIiB0ZXN0SUQ9e2BuZnQtY29sbGVjdGlibGUtJHthdHRyaWJ1dGVWYWx1ZS50b0xvd2VyQ2FzZSgpfWB9PlxuICAgICAgICAgICAgICB7YXR0cmlidXRlVmFsdWV9XG4gICAgICAgICAgICA8L1RleHRIZWFkbGluZT5cbiAgICAgICAgICA8L1ZTdGFjaz5cbiAgICAgICAgPC9Cb3g+XG4gICAgICA8L0JyZWFrV29yZHM+XG4gICAgPC9UaGVtZVByb3ZpZGVyPlxuICApO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gQ29sbGVjdGlibGVBdHRyaWJ1dGVzKHsgYXR0cmlidXRlcyB9OiBDb2xsZWN0aWJsZUF0dHJpYnV0ZVByb3BzKSB7XG4gIGNvbnN0IHsgZm9ybWF0TWVzc2FnZSB9ID0gdXNlSW50bCgpO1xuXG4gIGNvbnN0IHNob3dBdHRyaWJ1dGVzID0gYXR0cmlidXRlcz8uZmluZCgoYXR0cmlidXRlKSA9PiBhdHRyaWJ1dGUuYXR0cmlidXRlTmFtZT8udHJpbSgpKTtcblxuICBjb25zdCBzb3J0ZWRBdHRyaWJ1dGVzOiBBdHRyaWJ1dGVUYWdQcm9wc1tdID0gdXNlTWVtbygoKSA9PiB7XG4gICAgY29uc3QgZmlsdGVyZWRBdHRyaWJ1dGVzOiBBdHRyaWJ1dGVUYWdQcm9wc1tdID0gW107XG5cbiAgICBhdHRyaWJ1dGVzPy5mb3JFYWNoKChhKSA9PiB7XG4gICAgICBpZiAoYS5hdHRyaWJ1dGVOYW1lPy50cmltKCkgJiYgYS5hdHRyaWJ1dGVWYWx1ZT8udHJpbSgpKSB7XG4gICAgICAgIGZpbHRlcmVkQXR0cmlidXRlcy5wdXNoKHtcbiAgICAgICAgICBhdHRyaWJ1dGVOYW1lOiBhLmF0dHJpYnV0ZU5hbWUsXG4gICAgICAgICAgYXR0cmlidXRlVmFsdWU6IGEuYXR0cmlidXRlVmFsdWUsXG4gICAgICAgIH0pO1xuICAgICAgfVxuICAgIH0pO1xuXG4gICAgcmV0dXJuIGZpbHRlcmVkQXR0cmlidXRlcy5zb3J0KChhLCBiKSA9PiB7XG4gICAgICBpZiAoYS5hdHRyaWJ1dGVOYW1lID4gYi5hdHRyaWJ1dGVOYW1lKSB7XG4gICAgICAgIHJldHVybiAxO1xuICAgICAgfVxuICAgICAgcmV0dXJuIC0xO1xuICAgIH0pO1xuICB9LCBbYXR0cmlidXRlc10pO1xuXG4gIGlmICghc2hvd0F0dHJpYnV0ZXMgfHwgIXNvcnRlZEF0dHJpYnV0ZXMpIHtcbiAgICByZXR1cm4gbnVsbDtcbiAgfVxuXG4gIGNvbnN0IGNhbWVsU2VudGVuY2UgPSAoc3RyOiBzdHJpbmcpID0+IHtcbiAgICByZXR1cm4gYCAke3N0cn1gXG4gICAgICAudG9Mb3dlckNhc2UoKVxuICAgICAgLnJlcGxhY2UoL1teYS16QS1aMC05XSsoLikvZywgKG1hdGNoLCBjaHIpID0+IHtcbiAgICAgICAgcmV0dXJuIGAgJHtjaHIudG9VcHBlckNhc2UoKX1gO1xuICAgICAgfSlcbiAgICAgIC50cmltKCk7XG4gIH07XG5cbiAgcmV0dXJuIChcbiAgICA8Qm94IHNwYWNpbmdUb3A9ezV9IGJhY2tncm91bmQgdGVzdElEPVwiY29sbGVjdGlibGUtYXR0cmlidXRlc1wiPlxuICAgICAgPFZTdGFjayBnYXA9ezJ9PlxuICAgICAgICA8VGV4dFRpdGxlMyBhcz1cInBcIj57Zm9ybWF0TWVzc2FnZShtZXNzYWdlcy5hdHRyaWJ1dGVzKX08L1RleHRUaXRsZTM+XG4gICAgICAgIDxBdHRyaWJ1dGVGbGV4Ym94PlxuICAgICAgICAgIHtzb3J0ZWRBdHRyaWJ1dGVzLm1hcCgoYXR0cmlidXRlLCBpbmRleDogbnVtYmVyKSA9PiB7XG4gICAgICAgICAgICByZXR1cm4gKFxuICAgICAgICAgICAgICA8QXR0cmlidXRlVGFnXG4gICAgICAgICAgICAgICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIHJlYWN0L25vLWFycmF5LWluZGV4LWtleVxuICAgICAgICAgICAgICAgIGtleT17YGF0dHJpYnV0ZS0ke2luZGV4fWB9XG4gICAgICAgICAgICAgICAgYXR0cmlidXRlTmFtZT17YXR0cmlidXRlLmF0dHJpYnV0ZU5hbWUucmVwbGFjZUFsbCgnXycsICcgJykudG9VcHBlckNhc2UoKX1cbiAgICAgICAgICAgICAgICBhdHRyaWJ1dGVWYWx1ZT17Y2FtZWxTZW50ZW5jZShhdHRyaWJ1dGUuYXR0cmlidXRlVmFsdWUucmVwbGFjZUFsbCgnXycsICcgJykpfVxuICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgKTtcbiAgICAgICAgICB9KX1cbiAgICAgICAgPC9BdHRyaWJ1dGVGbGV4Ym94PlxuICAgICAgPC9WU3RhY2s+XG4gICAgPC9Cb3g+XG4gICk7XG59XG5cbmNvbnN0IEJyZWFrV29yZHMgPSBzdHlsZWQuZGl2YFxuICBvdmVyZmxvdy13cmFwOiBhbnl3aGVyZTtcbmA7XG5cbmNvbnN0IEF0dHJpYnV0ZUZsZXhib3ggPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogcm93O1xuICBmbGV4LXdyYXA6IHdyYXA7XG4gIGhlaWdodDogMTAwJTtcbiAgd2lkdGg6ICR7V0lEVEh9O1xuICByb3ctZ2FwOiAxMHB4O1xuICBjb2x1bW4tZ2FwOiAxMHB4O1xuICBvdmVyZmxvdy15OiBhdXRvO1xuICBvdmVyZmxvdy14OiBoaWRkZW47XG5gO1xuIl19*/
.i4dv3r6{margin-top:auto;margin-bottom:auto;}
/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["src/screens/CollectibleDetail/CollectibleChainData.tsx"],"names":[".i4dv3r6"],"mappings":"AAiPMA","file":"src/screens/CollectibleDetail/CollectibleChainData.tsx","sourcesContent":["import { ReactNode, useEffect, useState } from 'react';\nimport { defineMessages, useIntl } from 'react-intl';\nimport { styled } from '@linaria/react';\nimport {\n  ETHEREUM_CURRENCY_DECIMAL,\n  ETHEREUM_PREFIX,\n} from 'cb-wallet-data/chains/AccountBased/Ethereum/constants';\nimport { SOLANA_PREFIX } from 'cb-wallet-data/chains/AccountBased/Solana/utils/chain';\nimport { useCurrencyFormatter } from 'cb-wallet-data/CurrencyFormatter/hooks/useCurrencyFormatter';\nimport { useIsSolanaCollection } from 'cb-wallet-data/hooks/Collections/useIsSolanaCollection';\nimport { CurrencyCode } from 'cb-wallet-data/models/CurrencyCode';\nimport { useIsNFTFloorPriceEnabled } from 'cb-wallet-data/stores/Collection/hooks/useIsNFTFloorPriceEnabled';\nimport { Collectible } from 'cb-wallet-data/stores/Collection/types';\nimport { fetchDomains } from 'cb-wallet-data/stores/DecentralizedID/hooks/usePublicProfileByAddress';\nimport { Network } from 'cb-wallet-data/stores/Networks/models/Network';\nimport { abridgeAddress } from 'cb-wallet-data/utils/abridgeAddress';\nimport { convertEthtoWei } from 'cb-wallet-data/utils/CurrencyUtil';\nimport { NetworkIcon } from 'wallet-cds-extension/components/NetworkIcon/NetworkIcon';\nimport { IconName } from '@cbhq/cds-web';\nimport { Icon } from '@cbhq/cds-web/icons/Icon';\nimport { HStack, Spacer, VStack } from '@cbhq/cds-web/layout';\nimport { Tooltip } from '@cbhq/cds-web/overlays/Tooltip/Tooltip';\nimport { TextBody } from '@cbhq/cds-web/typography';\n\nconst messages = defineMessages({\n  collection: {\n    defaultMessage: 'Collection',\n    description: 'Label for collection',\n  },\n  network: {\n    defaultMessage: 'Network',\n    description: 'Label for network',\n  },\n  lastSoldPrice: {\n    defaultMessage: 'Last purchased price',\n    description: 'Label for last purchased price of this nft',\n  },\n  floor: {\n    defaultMessage: 'Collection floor price',\n    description: \"label for collection's floor price\",\n  },\n  estimateValue: {\n    defaultMessage: 'Estimated value',\n    description: \"label for collectible's estimated value in eth\",\n  },\n  estimateValueTooltip: {\n    defaultMessage:\n      \"This is our best guess at the perceived value of this particular NFT. This value has been derived by looking at the item's rarity, its collection floor price and recent collection sale activity.\",\n    description: \"Tooltip text for collectible's estimated value in eth\",\n  },\n  owner: {\n    defaultMessage: 'Owner',\n    description: 'Label text for owner of the NFT',\n  },\n});\n\ntype CollectionProps = {\n  icon: ReactNode | IconName;\n  title: string;\n  tooltipText?: string;\n  value: string;\n  accessory?: ReactNode | IconName;\n  testID?: string;\n};\n\nfunction CollectionListItem({\n  icon,\n  title,\n  tooltipText,\n  value,\n  accessory,\n  testID,\n}: CollectionProps) {\n  return (\n    <HStack gap={1} alignItems=\"center\" testID={testID}>\n      <IconContainer>\n        {typeof icon === 'string' ? (\n          <Icon name={icon as IconName} size=\"s\" color=\"primary\" />\n        ) : (\n          icon\n        )}\n      </IconContainer>\n      <TextBody as=\"p\">{title}</TextBody>\n      {tooltipText ? (\n        <Tooltip\n          testID={`nft-collectible-${title.toLowerCase()}-tooltip`}\n          content={tooltipText}\n          placement=\"bottom\"\n        >\n          <Icon\n            testID={`nft-collectible-${title.toLowerCase()}-tooltip-icon`}\n            name=\"info\"\n            size=\"xs\"\n            color=\"foregroundMuted\"\n          />\n        </Tooltip>\n      ) : null}\n      <Spacer />\n      {typeof accessory === 'string' ? <Icon name={accessory as IconName} size=\"xs\" /> : accessory}\n      <TextBody\n        as=\"p\"\n        noWrap\n        overflow=\"truncate\"\n        color=\"foregroundMuted\"\n        testID={`nft-collectible-${title.toLowerCase()}`}\n      >\n        {value}\n      </TextBody>\n    </HStack>\n  );\n}\n\ntype CollectibleProps = Pick<\n  Collectible,\n  | 'collectionName'\n  | 'contractAddress'\n  | 'lastSoldPrice'\n  | 'floorPrice'\n  | 'estimatedTokenValue'\n  | 'ownerAddress'\n>;\n\ntype CollectibleChainDataProps = CollectibleProps & {\n  chainId: string;\n  tokenType?: string;\n};\n\nexport function CollectibleChainData({\n  collectionName,\n  contractAddress,\n  ownerAddress: ownerAddressProp = '',\n  lastSoldPrice,\n  floorPrice,\n  estimatedTokenValue,\n  chainId,\n  tokenType,\n}: CollectibleChainDataProps) {\n  const isFloorPriceEnabled = useIsNFTFloorPriceEnabled();\n\n  const { formatMessage } = useIntl();\n  const currencyFormatter = useCurrencyFormatter();\n\n  const isSolanaCollection = useIsSolanaCollection({ tokenType, chainId });\n  const chainPrefix = isSolanaCollection ? SOLANA_PREFIX : ETHEREUM_PREFIX;\n  const network = Network.fromChainId({ chainId: BigInt(chainId), chainPrefix });\n\n  const blockchain = network.asChain()?.displayName ?? '';\n\n  const name = collectionName || abridgeAddress(contractAddress);\n\n  const ownerAddress = abridgeAddress(ownerAddressProp);\n\n  const [owner, setOwner] = useState(ownerAddress);\n\n  useEffect(\n    function resolveDomain() {\n      const domain = async function getDomain() {\n        const [ownerDomain] = await fetchDomains([ownerAddressProp]);\n\n        setOwner(ownerDomain ? abridgeAddress(ownerDomain) : ownerAddress);\n      };\n\n      domain();\n    },\n    [ownerAddress, ownerAddressProp],\n  );\n\n  const lastSold =\n    lastSoldPrice && Number(lastSoldPrice) > 0\n      ? currencyFormatter.formatToCrypto({\n          currencyCode: CurrencyCode.ETH,\n          decimals: ETHEREUM_CURRENCY_DECIMAL,\n          value: BigInt(lastSoldPrice),\n          includeCode: true,\n        })\n      : 0;\n\n  const floor =\n    floorPrice && Number(floorPrice) > 0\n      ? currencyFormatter.formatToCrypto({\n          currencyCode: CurrencyCode.ETH,\n          decimals: ETHEREUM_CURRENCY_DECIMAL,\n          value: convertEthtoWei(floorPrice),\n          includeCode: true,\n        })\n      : 0;\n\n  const estimate =\n    estimatedTokenValue && Number(estimatedTokenValue) > 0\n      ? currencyFormatter.formatToCrypto({\n          currencyCode: CurrencyCode.ETH,\n          decimals: ETHEREUM_CURRENCY_DECIMAL,\n          value: convertEthtoWei(estimatedTokenValue),\n          includeCode: true,\n          maxDisplayDecimals: 2n,\n        })\n      : 0;\n\n  return (\n    <VStack gap={3} overflow=\"hidden\" testID=\"collection-chain-data\">\n      {name && (\n        <CollectionListItem icon=\"nft\" title={formatMessage(messages.collection)} value={name} />\n      )}\n      {!!isFloorPriceEnabled && !!floor ? (\n        <CollectionListItem\n          icon=\"arrowDown\"\n          title={formatMessage(messages.floor)}\n          value={floor}\n          testID=\"floor-price-list-cell\"\n        />\n      ) : null}\n      {owner && (\n        <CollectionListItem icon=\"profile\" title={formatMessage(messages.owner)} value={owner} />\n      )}\n      {estimate ? (\n        <CollectionListItem\n          icon=\"cash\"\n          title={formatMessage(messages.estimateValue)}\n          tooltipText={formatMessage(messages.estimateValueTooltip)}\n          value={estimate}\n        />\n      ) : null}\n      {lastSold ? (\n        <CollectionListItem\n          icon=\"clock\"\n          title={formatMessage(messages.lastSoldPrice)}\n          value={lastSold}\n        />\n      ) : null}\n      {network ? (\n        <CollectionListItem\n          icon=\"blockchain\"\n          title={formatMessage(messages.network)}\n          value={blockchain}\n          accessory={<NetworkIcon network={network} size=\"small\" />}\n        />\n      ) : null}\n    </VStack>\n  );\n}\n\nconst IconContainer = styled.div`\n  margin-top: auto;\n  margin-bottom: auto;\n`;\n"]}*/
.cw8c9pg{overflow-y:auto;height:100%;width:375px;overflow-x:hidden;}
/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["src/screens/CollectibleDetail/CollectibleDetailCommerce.tsx"],"names":[".cw8c9pg"],"mappings":"AAiMMA","file":"src/screens/CollectibleDetail/CollectibleDetailCommerce.tsx","sourcesContent":["import { ReactNode, Suspense, useCallback, useMemo, useRef, useState } from 'react';\nimport { useHistory, useParams } from 'react-router-dom';\nimport { styled } from '@linaria/react';\nimport { useOnMount } from 'cb-wallet-data/hooks/useOnMount';\nimport { ETHEREUM_COLLECTION_CHAIN_ID } from 'cb-wallet-data/stores/Collection/api';\nimport { useCollectibleOffers } from 'cb-wallet-data/stores/Collection/hooks/useCollectibleOffers';\nimport { useCollectibleTxHistory } from 'cb-wallet-data/stores/Collection/hooks/useCollectibleTxHistory';\nimport { useIsNFTFloorPriceEnabled } from 'cb-wallet-data/stores/Collection/hooks/useIsNFTFloorPriceEnabled';\nimport { useRefreshCollectible } from 'cb-wallet-data/stores/Collection/hooks/useRefreshCollectible';\nimport { useTokenDetails } from 'cb-wallet-data/stores/Collection/hooks/useTokenDetails';\n\nimport { useCollectiblePerfMarks } from ':extension/screens/Portfolio/CollectionsPortfolio/hooks/useCollectiblePerfMarks';\n\nimport { CollectibleDetailContainerCommerce } from './CollectibleDetailContainerCommerce';\n\nfunction Fallback() {\n  // TODO: add fallback screen\n  return <div data-testid=\"portfolio-collectible-detail-commerce-fallback\" />;\n}\n\ntype Props = {\n  address: string;\n  tokenId: string;\n  tokenCount: string;\n  chainId: string;\n  includeOffers?: boolean;\n  listingAmounts?: ReactNode;\n  actionBar?: ReactNode;\n  showNavbarExternalLinks?: boolean;\n  onMount?: () => void;\n};\n\nexport function CollectibleDetailCommerceContent({\n  address,\n  tokenId,\n  tokenCount,\n  chainId,\n  includeOffers = true,\n  listingAmounts,\n  actionBar,\n  showNavbarExternalLinks = false,\n  onMount,\n}: Props) {\n  const { endCollectiblePerfMark: endNFTDetailLoad } = useCollectiblePerfMarks(\n    'nft_detail',\n    'load',\n  );\n\n  useOnMount(() => {\n    onMount?.();\n    endNFTDetailLoad();\n  });\n\n  // This is a temporary hack to prevent the send button from being shown when coming from the\n  // collectible details page from explore. We fully intend to refactor this to a better solution right after the\n  // cut\n  const history = useHistory();\n  const routePathArray = history.location.pathname.split('/');\n  const routePath = routePathArray.length ? routePathArray[routePathArray.length - 1] : '';\n\n  const contractAddress = decodeURIComponent(address);\n  const id = decodeURIComponent(tokenId);\n  const container = useRef<HTMLDivElement | null>(null);\n\n  const [hasOffersError, setHasOffersError] = useState(false);\n  const [hasTransactionsError, setHasTransactionsError] = useState(false);\n\n  const onOffersError = useCallback(() => setHasOffersError(true), []);\n  const onTransactionsError = useCallback(() => setHasTransactionsError(true), []);\n\n  const { data: offersQueryRes, refetch: refetchOffers } = useCollectibleOffers({\n    contractAddress,\n    tokenId,\n    chainId,\n    onError: onOffersError,\n    suspense: false,\n    disabled: !includeOffers,\n  });\n  const offers = useMemo(() => offersQueryRes?.openBids || [], [offersQueryRes]);\n\n  const { data: transactionsQueryRes, refetch: refetchTransactions } = useCollectibleTxHistory({\n    contractAddress,\n    tokenId,\n    chainId,\n    onError: onTransactionsError,\n  });\n\n  const transactions = useMemo(() => {\n    return transactionsQueryRes ?? [];\n  }, [transactionsQueryRes]);\n\n  const { refetch: refresh } = useRefreshCollectible(contractAddress, id, chainId);\n\n  const useFloorPrice = useIsNFTFloorPriceEnabled();\n  const { data: collectible, refetch: refetchDetails } = useTokenDetails({\n    contractAddress,\n    tokenId: id,\n    chainId,\n    includeFloorPrice: useFloorPrice,\n  });\n\n  const handleTokenRefresh = useCallback(\n    async (onSuccess?: () => void, onError?: () => void) => {\n      try {\n        await Promise.all([\n          refetchDetails({ throwOnError: true }),\n          refetchOffers({ throwOnError: true }),\n          refetchTransactions({ throwOnError: true }),\n          refresh({ throwOnError: true }),\n        ]);\n        onSuccess?.();\n      } catch (e) {\n        onError?.();\n      }\n    },\n    [refetchDetails, refetchOffers, refetchTransactions, refresh],\n  );\n\n  if (!collectible) {\n    throw new Error(`Can not find NFT with contract ${contractAddress} and id ${id}`);\n  }\n\n  // Hack to use the collectionList api to populate the tokenCount\n  collectible.tokenCount = tokenCount;\n\n  return (\n    <CollectibleContainer data-testid=\"portfolio-collectible-detail-commerce\" ref={container}>\n      <CollectibleDetailContainerCommerce\n        collectible={collectible}\n        offers={offers}\n        hasOffersError={hasOffersError}\n        showOffersTab={includeOffers}\n        transactions={transactions}\n        hasTransactionsError={hasTransactionsError}\n        onRefresh={handleTokenRefresh}\n        chainId={chainId.toString()}\n        fromSend={routePath === 'collectionDetails'}\n        listingAmounts={listingAmounts}\n        actionBar={actionBar}\n        showNavbarExternalLinks={showNavbarExternalLinks}\n      />\n    </CollectibleContainer>\n  );\n}\n\nexport function CollectibleDetailCommerce() {\n  const { address, tokenId, tokenCount, chainId } = useParams<{\n    address: string;\n    tokenId: string;\n    tokenCount: string;\n    chainId: string;\n  }>();\n\n  const {\n    startCollectiblePerfMark: startNFTDetailLoad,\n    clearCollectiblePerfMark: clearNFTDetailLoad,\n  } = useCollectiblePerfMarks('nft_detail', 'load');\n\n  useOnMount(() => {\n    startNFTDetailLoad();\n    return clearNFTDetailLoad;\n  });\n\n  const { startCollectiblePerfMark: startAssetLoad, clearCollectiblePerfMark: clearAssetLoad } =\n    useCollectiblePerfMarks('nft_detail_asset', 'load');\n\n  const {\n    startCollectiblePerfMark: startCloudinaryAssetLoad,\n    clearCollectiblePerfMark: clearCloudinaryAssetLoad,\n  } = useCollectiblePerfMarks('nft_detail_asset', 'load_cloudinary');\n\n  useOnMount(() => {\n    startAssetLoad();\n    startCloudinaryAssetLoad();\n    return () => {\n      clearAssetLoad();\n      clearCloudinaryAssetLoad();\n    };\n  });\n\n  return (\n    <Suspense fallback={<Fallback />}>\n      <CollectibleDetailCommerceContent\n        address={address}\n        tokenId={tokenId}\n        tokenCount={tokenCount}\n        chainId={chainId}\n        includeOffers={chainId === ETHEREUM_COLLECTION_CHAIN_ID.toString()}\n      />\n    </Suspense>\n  );\n}\n\nconst CollectibleContainer = styled.div`\n  overflow-y: auto;\n  height: 100%;\n  width: 375px;\n  overflow-x: hidden;\n`;\n"]}*/

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