.r9qmolu{border:var(--r9qmolu-0);}.r9qmolu:first-child{border-top-left-radius:4;border-top-right-radius:4;}.r9qmolu:last-child{border-bottom-left-radius:4;border-bottom-right-radius:4;}
/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInNyYy9zY3JlZW5zL1RyYWRlL0VudHJ5U2VsZWN0b3IvUm93LnRzeCJdLCJuYW1lcyI6WyIucjlxbW9sdSJdLCJtYXBwaW5ncyI6IkFBeUdNQSIsImZpbGUiOiJzcmMvc2NyZWVucy9UcmFkZS9FbnRyeVNlbGVjdG9yL1Jvdy50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyB1c2VNZW1vIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgZGVmaW5lTWVzc2FnZXMsIHVzZUludGwgfSBmcm9tICdyZWFjdC1pbnRsJztcbmltcG9ydCB7IHN0eWxlZCB9IGZyb20gJ0BsaW5hcmlhL3JlYWN0Jztcbi8vIFRPRE86IHdlJ2xsIGJlIGFibGUgdG8gaW1wb3J0IHByb3BlcnRpZXMgZGlyZWN0bHkgZnJvbSBjZHMtd2ViIChub3QgY2RzLWNvbW1vbikgaHR0cHM6Ly9qaXJhLmNvaW5iYXNlLWNvcnAuY29tL2Jyb3dzZS9DRFMtNTQ3XG5pbXBvcnQgeyBib3JkZXJSYWRpdXMgfSBmcm9tICdAY2JocS9jZHMtY29tbW9uL3Rva2Vucy9ib3JkZXInO1xuaW1wb3J0IHsgSFN0YWNrIH0gZnJvbSAnQGNiaHEvY2RzLXdlYi9sYXlvdXQvSFN0YWNrJztcbmltcG9ydCB7IFByZXNzYWJsZSB9IGZyb20gJ0BjYmhxL2Nkcy13ZWIvc3lzdGVtL1ByZXNzYWJsZSc7XG5pbXBvcnQgeyBwYWxldHRlIH0gZnJvbSAnQGNiaHEvY2RzLXdlYi90b2tlbnMnO1xuXG5jb25zdCBtZXNzYWdlcyA9IGRlZmluZU1lc3NhZ2VzKHtcbiAgUm93TGFiZWw6IHtcbiAgICBkZWZhdWx0TWVzc2FnZTogJ1RoZSB7bmFtZX0nLFxuICAgIGRlc2NyaXB0aW9uOiAnQSBsYWJlbCBmb3IgZWFjaCByb3cnLFxuICB9LFxufSk7XG5cbnR5cGUgUm93UHJvcHMgPSB7XG4gIG9uUHJlc3M6ICgpID0+IHZvaWQ7XG4gIGhhc0Vycm9yOiBib29sZWFuO1xuICBhMTF5TGFiZWw/OiBzdHJpbmc7XG4gIGhhc1NlY29uZGFyeVRleHQ6IGJvb2xlYW47XG4gIGRpc2FibGVTZWxlY3Rpb246IGJvb2xlYW47XG4gIGNoaWxkcmVuOiBSZWFjdC5SZWFjdE5vZGU7XG4gIGJvcmRlcmVkVG9wOiBib29sZWFuO1xuICBub25UcnVuY2F0ZWQ/OiBib29sZWFuO1xuICBkYXRhRWxlbWVudEhhbmRsZT86IHN0cmluZztcbn07XG5cbmZ1bmN0aW9uIFJvd0NvbnRlbnQoe1xuICBjaGlsZHJlbixcbiAgYm9yZGVyZWRUb3AsXG4gIGhhc0Vycm9yLFxuICBoYXNTZWNvbmRhcnlUZXh0LFxuICBub25UcnVuY2F0ZWQsXG4gIGRhdGFFbGVtZW50SGFuZGxlLFxufTogUGljazxcbiAgUm93UHJvcHMsXG4gIHwgJ2NoaWxkcmVuJ1xuICB8ICdoYXNFcnJvcidcbiAgfCAnaGFzU2Vjb25kYXJ5VGV4dCdcbiAgfCAnYm9yZGVyZWRUb3AnXG4gIHwgJ25vblRydW5jYXRlZCdcbiAgfCAnZGF0YUVsZW1lbnRIYW5kbGUnXG4+KSB7XG4gIGNvbnN0IHNwYWNpbmdWZXJ0aWNhbCA9IHVzZU1lbW8oKCkgPT4ge1xuICAgIGlmIChub25UcnVuY2F0ZWQpIHJldHVybiAwO1xuICAgIHJldHVybiBoYXNTZWNvbmRhcnlUZXh0ID8gMSA6IDI7XG4gIH0sIFtub25UcnVuY2F0ZWQsIGhhc1NlY29uZGFyeVRleHRdKTtcblxuICByZXR1cm4gKFxuICAgIDxSb3dTdHlsZSBkYXRhLXRlc3RpZD17ZGF0YUVsZW1lbnRIYW5kbGV9IGhhc0Vycm9yPXtoYXNFcnJvcn0+XG4gICAgICA8SFN0YWNrXG4gICAgICAgIHNwYWNpbmc9e25vblRydW5jYXRlZCA/IDAgOiAyfVxuICAgICAgICBzcGFjaW5nVmVydGljYWw9e3NwYWNpbmdWZXJ0aWNhbH1cbiAgICAgICAgYm9yZGVyZWRUb3A9e2JvcmRlcmVkVG9wfVxuICAgICAgICBhbGlnbkl0ZW1zPVwiY2VudGVyXCJcbiAgICAgICAganVzdGlmeUNvbnRlbnQ9XCJzcGFjZS1iZXR3ZWVuXCJcbiAgICAgID5cbiAgICAgICAge2NoaWxkcmVufVxuICAgICAgPC9IU3RhY2s+XG4gICAgPC9Sb3dTdHlsZT5cbiAgKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIFJvdyh7XG4gIG9uUHJlc3MsXG4gIGRpc2FibGVTZWxlY3Rpb24sXG4gIGNoaWxkcmVuLFxuICBkYXRhRWxlbWVudEhhbmRsZSxcbiAgYTExeUxhYmVsLFxuICAuLi5wcm9wc1xufTogUm93UHJvcHMpIHtcbiAgY29uc3QgeyBmb3JtYXRNZXNzYWdlIH0gPSB1c2VJbnRsKCk7XG4gIC8vIFRPRE86IEphcnJldHQgLSBjaGFuZ2UgdGhpcyBwcm9wIHNvIHRoZSBwcmVzc2FibGUgY2FuIGJlIHByb3Blcmx5IGRpc2FibGVkXG4gIGlmIChkaXNhYmxlU2VsZWN0aW9uKSB7XG4gICAgcmV0dXJuIChcbiAgICAgIDxSb3dDb250ZW50IGRhdGFFbGVtZW50SGFuZGxlPXtkYXRhRWxlbWVudEhhbmRsZX0gey4uLnByb3BzfT5cbiAgICAgICAge2NoaWxkcmVufVxuICAgICAgPC9Sb3dDb250ZW50PlxuICAgICk7XG4gIH1cblxuICByZXR1cm4gKFxuICAgIDxQcmVzc2FibGVcbiAgICAgIGFzPVwiYnV0dG9uXCJcbiAgICAgIGRpc2FibGVkPXtkaXNhYmxlU2VsZWN0aW9ufVxuICAgICAgb25QcmVzcz17b25QcmVzc31cbiAgICAgIG5vU2NhbGVPblByZXNzXG4gICAgICBiYWNrZ3JvdW5kQ29sb3I9XCJiYWNrZ3JvdW5kXCJcbiAgICAgIGJvcmRlclJhZGl1cz1cInN0YW5kYXJkXCJcbiAgICAgIHRyYW5zcGFyZW50V2hpbGVJbmFjdGl2ZVxuICAgICAgdGVzdElEPXtkYXRhRWxlbWVudEhhbmRsZX1cbiAgICAgIGRhdGEtZWxlbWVudC1oYW5kbGU9e2RhdGFFbGVtZW50SGFuZGxlfVxuICAgICAgYXJpYS1sYWJlbD17YTExeUxhYmVsIHx8IGZvcm1hdE1lc3NhZ2UobWVzc2FnZXMuUm93TGFiZWwsIHsgbmFtZTogZGF0YUVsZW1lbnRIYW5kbGUgfSl9XG4gICAgPlxuICAgICAgPFJvd0NvbnRlbnQgey4uLnByb3BzfT57Y2hpbGRyZW59PC9Sb3dDb250ZW50PlxuICAgIDwvUHJlc3NhYmxlPlxuICApO1xufVxuXG50eXBlIFJvd1N0eWxlUHJvcHMgPSB7XG4gIGhhc0Vycm9yPzogYm9vbGVhbjtcbiAgbm9Cb3JkZXI/OiBib29sZWFuO1xufTtcblxuY29uc3QgUm93U3R5bGUgPSBzdHlsZWQuZGl2PFJvd1N0eWxlUHJvcHM+YFxuICBib3JkZXI6ICR7KHApID0+IChwLmhhc0Vycm9yID8gYDFweCBzb2xpZCAke3BhbGV0dGUubmVnYXRpdmV9YCA6ICcnKX07XG4gICY6Zmlyc3QtY2hpbGQge1xuICAgIGJvcmRlci10b3AtbGVmdC1yYWRpdXM6ICR7Ym9yZGVyUmFkaXVzLmNvbXBhY3R9O1xuICAgIGJvcmRlci10b3AtcmlnaHQtcmFkaXVzOiAke2JvcmRlclJhZGl1cy5jb21wYWN0fTtcbiAgfVxuICAmOmxhc3QtY2hpbGQge1xuICAgIGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6ICR7Ym9yZGVyUmFkaXVzLmNvbXBhY3R9O1xuICAgIGJvcmRlci1ib3R0b20tcmlnaHQtcmFkaXVzOiAke2JvcmRlclJhZGl1cy5jb21wYWN0fTtcbiAgfVxuYDtcbiJdfQ==*/
.s1ty2zvo{color:var(--primary);font-size:62px;}
.c1dk0jyb{max-width:var(--c1dk0jyb-0);display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-flex:1;-ms-flex:1;flex:1;-webkit-box-pack:center;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center;position:relative;-webkit-transform:scale(var(--c1dk0jyb-1));-ms-transform:scale(var(--c1dk0jyb-1));transform:scale(var(--c1dk0jyb-1));}
.i1m4401q{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-align-items:baseline;-webkit-box-align:baseline;-ms-flex-align:baseline;align-items:baseline;}
.s17j6s2u{width:var(--s17j6s2u-0);padding:0;margin:0;box-shadow:none;border:none;overflow:hidden;outline:none;color:var(--primary);font-family:CoinbaseSans;font-size:62px;text-align:right;background-color:var(--background);}.s17j6s2u::-webkit-input-placeholder{color:var(--primary);line-height:normal;opacity:1;}.s17j6s2u::-moz-placeholder{color:var(--primary);line-height:normal;opacity:1;}.s17j6s2u:-ms-input-placeholder{color:var(--primary);line-height:normal;opacity:1;}.s17j6s2u::placeholder{color:var(--primary);line-height:normal;opacity:1;}
/*# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL2xpYnMvd2FsbGV0LWNkcy1leHRlbnNpb24vY29tcG9uZW50cy9BbW91bnRJbnB1dC9EaXNhYmxlZEFtb3VudElucHV0LnRzeCJdLCJuYW1lcyI6WyIuczF0eTJ6dm8iLCIuYzFkazBqeWIiLCIuaTFtNDQwMXEiLCIuczE3ajZzMnUiXSwibWFwcGluZ3MiOiJBQWtEYUE7QUFLUEM7QUFZQUM7QUFPT0MiLCJmaWxlIjoiLi4vLi4vbGlicy93YWxsZXQtY2RzLWV4dGVuc2lvbi9jb21wb25lbnRzL0Ftb3VudElucHV0L0Rpc2FibGVkQW1vdW50SW5wdXQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgZGVmaW5lTWVzc2FnZXMsIHVzZUludGwgfSBmcm9tICdyZWFjdC1pbnRsJztcbmltcG9ydCB7IHN0eWxlZCB9IGZyb20gJ0BsaW5hcmlhL3JlYWN0JztcbmltcG9ydCB7IGNzc1ZhbHVlIH0gZnJvbSAnd2FsbGV0LWNkcy1leHRlbnNpb24vdXRpbC9jc3MvY3NzVmFsdWUnO1xuaW1wb3J0IHsgSFN0YWNrLCBTcGFjZXIsIFZTdGFjayB9IGZyb20gJ0BjYmhxL2Nkcy13ZWIvbGF5b3V0JztcbmltcG9ydCB7IHBhbGV0dGUgfSBmcm9tICdAY2JocS9jZHMtd2ViL3Rva2Vucyc7XG5cbmNvbnN0IENPTlRBSU5FUl9NQVhfV0lEVEggPSAyNDc7XG5jb25zdCBJTklUSUFMX0ZPTlRfU0laRSA9IDYyO1xuY29uc3QgSU5JVElBTF9JTlBVVF9XSURUSCA9IDQwO1xuXG5jb25zdCBtZXNzYWdlcyA9IGRlZmluZU1lc3NhZ2VzKHtcbiAgYW1vdW50OiB7XG4gICAgZGVmYXVsdE1lc3NhZ2U6ICdBbW91bnQnLFxuICAgIGRlc2NyaXB0aW9uOiAnTGFiZWwgZm9yIHRoZSB2YWx1ZSBpbiB0aGUgY3VycmVuY3kgaW5wdXQnLFxuICB9LFxufSk7XG5cbmV4cG9ydCBmdW5jdGlvbiBEaXNhYmxlZEFtb3VudElucHV0KCkge1xuICBjb25zdCB7IGZvcm1hdE1lc3NhZ2UgfSA9IHVzZUludGwoKTtcbiAgY29uc3Qgc3ltYm9sID0gJyQnO1xuXG4gIHJldHVybiAoXG4gICAgPFZTdGFjayB0ZXN0SUQ9XCJkaXNhYmxlZC1hbW91bnQtaW5wdXRcIj5cbiAgICAgIDxIU3RhY2sganVzdGlmeUNvbnRlbnQ9XCJjZW50ZXJcIiBhbGlnbkl0ZW1zPVwiY2VudGVyXCI+XG4gICAgICAgIDxWU3RhY2sgd2lkdGg9XCIxMDAlXCIgYWxpZ25JdGVtcz1cImNlbnRlclwiPlxuICAgICAgICAgIDxIU3RhY2sgd2lkdGg9XCIxMDAlXCIgYWxpZ25JdGVtcz1cImNlbnRlclwiIGp1c3RpZnlDb250ZW50PVwiY2VudGVyXCI+XG4gICAgICAgICAgICA8U3BhY2VyIGhvcml6b250YWw9ezF9IC8+XG4gICAgICAgICAgICA8Q29udGFpbmVyIHNjYWxlPXsxfSBtYXhXaWR0aD17Q09OVEFJTkVSX01BWF9XSURUSH0+XG4gICAgICAgICAgICAgIDxJbnB1dENvbnRhaW5lcj5cbiAgICAgICAgICAgICAgICA8U3R5bGVkU3ltYm9sPntzeW1ib2x9PC9TdHlsZWRTeW1ib2w+XG4gICAgICAgICAgICAgICAgPFN0eWxlZElucHV0XG4gICAgICAgICAgICAgICAgICBrZXk9XCJpbnB1dFwiXG4gICAgICAgICAgICAgICAgICBkYXRhLXRlc3RpZD1cImN1cnJlbmN5LWlucHV0XCJcbiAgICAgICAgICAgICAgICAgIGFyaWEtbGFiZWw9e2Zvcm1hdE1lc3NhZ2UobWVzc2FnZXMuYW1vdW50KX1cbiAgICAgICAgICAgICAgICAgIHdpZHRoPXtJTklUSUFMX0lOUFVUX1dJRFRIfVxuICAgICAgICAgICAgICAgICAgbWluTGVuZ3RoPXsxfVxuICAgICAgICAgICAgICAgICAgaW5wdXRNb2RlPVwiZGVjaW1hbFwiXG4gICAgICAgICAgICAgICAgICBwbGFjZWhvbGRlcj1cIjBcIlxuICAgICAgICAgICAgICAgICAgdmFsdWU9XCJcIlxuICAgICAgICAgICAgICAgICAgcmVhZE9ubHlcbiAgICAgICAgICAgICAgICAvPlxuICAgICAgICAgICAgICA8L0lucHV0Q29udGFpbmVyPlxuICAgICAgICAgICAgPC9Db250YWluZXI+XG4gICAgICAgICAgPC9IU3RhY2s+XG4gICAgICAgIDwvVlN0YWNrPlxuICAgICAgPC9IU3RhY2s+XG4gICAgPC9WU3RhY2s+XG4gICk7XG59XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRTeW1ib2wgPSBzdHlsZWQuc3BhbmBcbiAgY29sb3I6ICR7cGFsZXR0ZS5wcmltYXJ5fTtcbiAgZm9udC1zaXplOiAke2Nzc1ZhbHVlKElOSVRJQUxfRk9OVF9TSVpFKX1weDtcbmA7XG5cbmNvbnN0IENvbnRhaW5lciA9IHN0eWxlZC5kaXY8e1xuICBzY2FsZT86IG51bWJlciB8IHN0cmluZztcbiAgbWF4V2lkdGg/OiBudW1iZXIgfCBzdHJpbmc7XG59PmBcbiAgbWF4LXdpZHRoOiAkeyhwKSA9PiBjc3NWYWx1ZShwLm1heFdpZHRoKX1weDtcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleDogMTtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgdHJhbnNmb3JtOiBzY2FsZSgkeyhwKSA9PiBjc3NWYWx1ZShwLnNjYWxlKX0pO1xuYDtcblxuY29uc3QgSW5wdXRDb250YWluZXIgPSBzdHlsZWQuZGl2PHtcbiAgc2hha2U/OiBib29sZWFuO1xufT5gXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBiYXNlbGluZTtcbmA7XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRJbnB1dCA9IHN0eWxlZC5pbnB1dGBcbiAgd2lkdGg6ICR7KHApID0+IGNzc1ZhbHVlKHAud2lkdGgpfXB4O1xuICBwYWRkaW5nOiAwO1xuICBtYXJnaW46IDA7XG4gIGJveC1zaGFkb3c6IG5vbmU7XG4gIGJvcmRlcjogbm9uZTtcbiAgb3ZlcmZsb3c6IGhpZGRlbjtcbiAgb3V0bGluZTogbm9uZTtcbiAgY29sb3I6ICR7cGFsZXR0ZS5wcmltYXJ5fTtcbiAgZm9udC1mYW1pbHk6IENvaW5iYXNlU2FucztcbiAgZm9udC1zaXplOiAke2Nzc1ZhbHVlKElOSVRJQUxfRk9OVF9TSVpFKX1weDtcbiAgdGV4dC1hbGlnbjogcmlnaHQ7XG4gIGJhY2tncm91bmQtY29sb3I6ICR7cGFsZXR0ZS5iYWNrZ3JvdW5kfTtcblxuICAmOjpwbGFjZWhvbGRlciB7XG4gICAgY29sb3I6ICR7cGFsZXR0ZS5wcmltYXJ5fTtcbiAgICBsaW5lLWhlaWdodDogbm9ybWFsO1xuICAgIG9wYWNpdHk6IDE7XG4gIH1cbmA7XG4iXX0=*/
.o1ksljwo{overflow:hidden;white-space:nowrap;text-overflow:ellipsis;color:var(--o1ksljwo-0);font-size:14px;text-align:left;padding-left:5px;}
.s15ol1l0{position:absolute;top:50%;left:16px;-webkit-transform:translateY(-50%);-ms-transform:translateY(-50%);transform:translateY(-50%);cursor:pointer;border:1px solid var(--line);border-radius:100%;background-color:var(--background);}
/*# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["src/screens/Trade/EntrySelector/EntrySelector.tsx"],"names":[".o1ksljwo",".s15ol1l0"],"mappings":"AA8OMA;AAUOC","file":"src/screens/Trade/EntrySelector/EntrySelector.tsx","sourcesContent":["import { memo, useCallback, useMemo } from 'react';\nimport { defineMessages, useIntl } from 'react-intl';\nimport { styled } from '@linaria/react';\nimport { useEntryStepLowLiquidityError } from 'cb-wallet-analytics/swap';\nimport { BridgeAsset } from 'cb-wallet-data/stores/Bridge/models/BridgeAsset';\nimport { QuoteError } from 'cb-wallet-data/stores/Swap/api/useSwapQuote';\nimport { GenerateTransactionsError } from 'cb-wallet-data/stores/Swap/hooks/useGenerateTransactions';\nimport { SwapAsset } from 'cb-wallet-data/stores/Swap/models/SwapAsset';\nimport noop from 'lodash/noop';\nimport { AssetIcon, AssetLikeProps } from 'wallet-cds-extension/components/AssetIcon/AssetIcon';\nimport { TxError } from 'wallet-cds-extension/components/TxError/TxError';\nimport { IconName } from '@cbhq/cds-web';\nimport { CellMedia, ContentCell } from '@cbhq/cds-web/cells';\nimport { Icon } from '@cbhq/cds-web/icons/Icon';\nimport { Box, Fallback, HStack, Spacer, VStack } from '@cbhq/cds-web/layout';\nimport { Tooltip } from '@cbhq/cds-web/overlays/Tooltip/Tooltip';\nimport { palette } from '@cbhq/cds-web/tokens';\nimport { TextLabel1, TextLabel2 } from '@cbhq/cds-web/typography';\n\nimport { useSwapAnalyticsDetails } from '../useSwapAnalyticsDetails';\n\nimport { Row } from './Row';\n\nexport const DEFAULT_LEFT_COLUMN_WIDTH = 80;\nexport const LARGE_ICON_SIZE = 32;\n\nexport const ICON_SIZE = 20;\n\nconst messages = defineMessages({\n  switcherWrapperLabel: {\n    defaultMessage: 'Switch the active input',\n    description: 'A label for switcher wrapper',\n  },\n});\n\nexport type EntrySelectorRow = {\n  borderedTop?: boolean;\n  hasError?: boolean;\n  primaryLabel?: React.ReactNode;\n  image?: string;\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  icon?: React.ReactElement<any>;\n  secondaryLabel?: React.ReactNode;\n  a11yLabel?: string;\n  pmDisabled?: boolean;\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\n  rightIcon?: React.ReactElement<any> | null;\n  onPress?: () => void;\n  hideCaret?: boolean;\n  className?: string;\n  secondaryText?: string;\n  dataElementHandle?: string;\n  disableSelection?: boolean;\n  leftColumnWidth?: number;\n  nonTruncated?: boolean;\n  swapAsset?: SwapAsset;\n  bridgeAsset?: BridgeAsset;\n  isLoading?: boolean;\n};\n\nfunction NonTruncatedSelectorRow(props: EntrySelectorRow) {\n  const {\n    borderedTop = false,\n    hasError = false,\n    image,\n    icon,\n    primaryLabel = '',\n    secondaryLabel = '',\n    rightIcon: rightIconProp,\n    onPress: onClick,\n    hideCaret = false,\n    secondaryText,\n    dataElementHandle,\n    disableSelection = false,\n  } = props;\n\n  const rightIcon = useMemo(() => {\n    if (rightIconProp) return rightIconProp;\n    if (!hideCaret)\n      return <Icon spacingStart={1} size=\"s\" name=\"caretRight\" color=\"foregroundMuted\" />;\n    return null;\n  }, [rightIconProp, hideCaret]);\n\n  const handlePress = useCallback(() => {\n    if (!disableSelection && onClick) {\n      onClick();\n    }\n  }, [disableSelection, onClick]);\n\n  return (\n    <Row\n      onPress={handlePress}\n      borderedTop={borderedTop}\n      hasError={hasError}\n      hasSecondaryText={!!secondaryText}\n      dataElementHandle={dataElementHandle}\n      disableSelection={disableSelection}\n      nonTruncated\n    >\n      <ContentCell\n        testID=\"non-truncated-row-cell\"\n        title={\n          <HStack alignItems=\"center\" justifyContent=\"space-between\" spacingBottom={0.5}>\n            <TextLabel1 as=\"p\">{primaryLabel}</TextLabel1>\n            {rightIcon}\n          </HStack>\n        }\n        description={\n          <VStack maxWidth=\"90%\">\n            <TextLabel2 as=\"p\" overflow=\"clip\" color=\"foregroundMuted\">\n              {secondaryLabel}\n            </TextLabel2>\n          </VStack>\n        }\n        media={image ? <CellMedia type=\"asset\" title=\"asset\" source={image} /> : icon}\n        reduceHorizontalSpacing\n      />\n    </Row>\n  );\n}\n\nexport function SelectorRow(props: EntrySelectorRow) {\n  const {\n    borderedTop = false,\n    hasError = false,\n    icon,\n    primaryLabel = '',\n    secondaryLabel = '',\n    a11yLabel = '',\n    pmDisabled = false,\n    rightIcon,\n    onPress = noop,\n    hideCaret = false,\n    secondaryText,\n    dataElementHandle,\n    disableSelection = false,\n    leftColumnWidth = DEFAULT_LEFT_COLUMN_WIDTH,\n    nonTruncated = false,\n    isLoading = false,\n    swapAsset,\n    bridgeAsset,\n  } = props;\n\n  const asset = useMemo(\n    (): AssetLikeProps => ({\n      currencyCode: swapAsset?.currencyCode?.value || bridgeAsset?.currencyCode?.value,\n      iconUrl: swapAsset?.imageURL || bridgeAsset?.imageURL,\n      network: swapAsset?.network || bridgeAsset?.network,\n    }),\n    [swapAsset, bridgeAsset],\n  );\n\n  const assetImage = useMemo(() => {\n    if (!swapAsset && !bridgeAsset) return null;\n\n    return <AssetIcon asset={asset} size=\"medium\" layout=\"inside-trade-row\" />;\n  }, [swapAsset, asset, bridgeAsset]);\n\n  const secondaryLabelElement = useMemo(() => {\n    if (isLoading) {\n      return (\n        <Box width=\"100%\">\n          <Fallback width={100} percentage height={20} flexGrow={1} />\n        </Box>\n      );\n    }\n\n    return typeof secondaryLabel === 'string' ? (\n      // TODO: mbasrai - text label 2 w/ elipsize prop\n      <Overflow\n        data-testid={`${dataElementHandle}-secondary-label`}\n        color={hasError || pmDisabled ? 'foregroundMuted' : 'foreground'}\n      >\n        {secondaryLabel}\n      </Overflow>\n    ) : (\n      <TextLabel2 testID={`${dataElementHandle}-primary-label`} as=\"div\" spacingStart={1}>\n        {secondaryLabel}\n      </TextLabel2>\n    );\n  }, [dataElementHandle, hasError, isLoading, pmDisabled, secondaryLabel]);\n\n  if (nonTruncated) {\n    return <NonTruncatedSelectorRow {...props} />;\n  }\n\n  return (\n    <Row\n      onPress={onPress}\n      borderedTop={borderedTop}\n      hasError={hasError}\n      hasSecondaryText={!!secondaryText}\n      dataElementHandle={dataElementHandle}\n      disableSelection={disableSelection}\n      a11yLabel={a11yLabel}\n    >\n      <VStack testID=\"truncated-selector-row\" width={`${leftColumnWidth}px`}>\n        <TextLabel2\n          testID={`${dataElementHandle}-primary-label`}\n          as=\"label\"\n          color=\"foregroundMuted\"\n        >\n          {primaryLabel}\n        </TextLabel2>\n      </VStack>\n      <HStack\n        width={`calc(100% - ${leftColumnWidth}px)`}\n        alignItems=\"center\"\n        justifyContent=\"space-between\"\n        overflow=\"visible\"\n      >\n        {icon}\n        {assetImage}\n        <VStack\n          justifyContent=\"flex-start\"\n          alignItems=\"flex-start\"\n          overflow=\"hidden\"\n          spacingStart={typeof secondaryLabel === 'string' ? 0.5 : 0}\n          width=\"100%\"\n        >\n          {secondaryLabelElement}\n          {secondaryText && (\n            <TextLabel2\n              testID={`${dataElementHandle}-secondary-label`}\n              as=\"span\"\n              color=\"foregroundMuted\"\n            >\n              {secondaryText}\n            </TextLabel2>\n          )}\n        </VStack>\n        {rightIcon && rightIcon}\n        {!hideCaret && <Icon spacingStart={1} size=\"s\" name=\"caretRight\" color=\"foregroundMuted\" />}\n      </HStack>\n    </Row>\n  );\n}\n\nconst Overflow = styled.span<{ color: keyof typeof palette }>`\n  overflow: hidden;\n  white-space: nowrap;\n  text-overflow: ellipsis;\n  color: ${(p) => palette[p.color]};\n  font-size: 14px;\n  text-align: left;\n  padding-left: 5px;\n`;\n\nexport const SwitcherWrapper = styled.div`\n  position: absolute;\n  top: 50%;\n  left: 16px;\n  transform: translateY(-50%);\n  cursor: pointer;\n  border: 1px solid ${palette.line};\n  border-radius: 100%;\n  background-color: ${palette.background};\n`;\n\ntype EntrySelectorProps = {\n  row1: EntrySelectorRow;\n  row2: EntrySelectorRow;\n  isSwitchDisabled?: boolean;\n  error?: QuoteError | GenerateTransactionsError;\n  onClickSwitcher?: () => void;\n  onClickSwitcherIcon?: IconName;\n  noBottomPadding?: boolean;\n  tooltipContent?: React.ReactNode;\n};\n\nfunction EntrySelectorComponent({\n  row1,\n  row2,\n  isSwitchDisabled,\n  error,\n  onClickSwitcher = undefined,\n  onClickSwitcherIcon = 'convert',\n  noBottomPadding,\n  tooltipContent,\n}: EntrySelectorProps) {\n  const { formatMessage } = useIntl();\n  const chainDetails = useSwapAnalyticsDetails();\n  const triggerAnalyticsLowLiquidityError = useEntryStepLowLiquidityError({ chainDetails });\n\n  const errorComponent = useMemo(() => {\n    if (!error) {\n      return null;\n    }\n\n    if (!tooltipContent) {\n      return (\n        <Box spacingTop={1} spacingBottom={1}>\n          <TxError triggerAnalytics={triggerAnalyticsLowLiquidityError} error={error} />\n        </Box>\n      );\n    }\n\n    return (\n      <Tooltip content={tooltipContent}>\n        <Box spacingTop={1} spacingBottom={1}>\n          <TxError triggerAnalytics={triggerAnalyticsLowLiquidityError} error={error} hasTooltip />\n        </Box>\n      </Tooltip>\n    );\n  }, [triggerAnalyticsLowLiquidityError, error, tooltipContent]);\n\n  return (\n    <>\n      <VStack bordered position=\"relative\" borderRadius=\"standard\">\n        <SelectorRow {...row1} />\n        <SelectorRow borderedTop {...row2} />\n        {!isSwitchDisabled && onClickSwitcher && (\n          <SwitcherWrapper\n            data-testid=\"entry-selector-switcher\"\n            onClick={onClickSwitcher}\n            role=\"button\"\n            aria-label={formatMessage(messages.switcherWrapperLabel)}\n          >\n            <Icon name={onClickSwitcherIcon} size=\"xs\" color=\"foreground\" bordered spacing={0.5} />\n          </SwitcherWrapper>\n        )}\n      </VStack>\n      {errorComponent}\n      {!noBottomPadding && <Spacer vertical={2} />}\n    </>\n  );\n}\n\nexport const EntrySelector = memo(EntrySelectorComponent);\n"]}*/

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