@depay/widgets 6.3.0 → 6.5.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1053,7 +1053,8 @@ var ClosableProvider = (function (props) {
1053
1053
  closable: closable,
1054
1054
  setClosable: setClosable,
1055
1055
  close: close,
1056
- open: open
1056
+ open: open,
1057
+ setOpen: setOpen
1057
1058
  }
1058
1059
  }, props.children);
1059
1060
  });
@@ -1953,23 +1954,21 @@ var Dialog = (function (props) {
1953
1954
  }, /*#__PURE__*/react.createElement("div", {
1954
1955
  className: ["DialogHeader", props.stacked ? 'TextCenter' : ''].join(' ')
1955
1956
  }, props.stacked && /*#__PURE__*/react.createElement("div", {
1956
- className: "DialogHeaderAction PaddingTopS PaddingLeftS PaddingRightS"
1957
+ className: "DialogHeaderActionLeft PaddingTopS PaddingLeftS PaddingRightS"
1957
1958
  }, /*#__PURE__*/react.createElement("button", {
1958
1959
  onClick: function onClick() {
1959
1960
  return navigate('back');
1960
1961
  },
1961
1962
  className: "ButtonCircular",
1962
1963
  title: "Go back"
1963
- }, /*#__PURE__*/react.createElement(ChevronLeft, null))), /*#__PURE__*/react.createElement("div", {
1964
- className: "DialogHeaderTitle"
1965
- }, props.header), /*#__PURE__*/react.createElement("div", {
1966
- className: "DialogHeaderAction PaddingTopS PaddingLeftS PaddingRightS"
1964
+ }, /*#__PURE__*/react.createElement(ChevronLeft, null))), props.header, /*#__PURE__*/react.createElement("div", {
1965
+ className: "DialogHeaderActionRight PaddingTopS PaddingLeftS PaddingRightS"
1967
1966
  }, closable && /*#__PURE__*/react.createElement("button", {
1968
1967
  onClick: close,
1969
1968
  className: "ButtonCircular",
1970
1969
  title: "Close dialog"
1971
1970
  }, /*#__PURE__*/react.createElement(CloseIcon, null)))), /*#__PURE__*/react.createElement("div", {
1972
- className: "DialogBody"
1971
+ className: ["DialogBody", props.bodyClassName].join(' ')
1973
1972
  }, props.body), /*#__PURE__*/react.createElement("div", {
1974
1973
  className: "DialogFooter"
1975
1974
  }, props.footer));
@@ -2302,10 +2301,23 @@ var ethereum = {
2302
2301
  decimals: 18
2303
2302
  },
2304
2303
  explorer: 'https://etherscan.io',
2305
- explorerUrlFor: ({ transaction })=>{
2304
+ explorerUrlFor: ({ transaction, token })=>{
2306
2305
  if(transaction) { return `https://etherscan.io/tx/${transaction.id}` }
2306
+ if(token) { return `https://etherscan.io/token/${token}` }
2307
2307
  },
2308
- rpc: ['https://mainnet.infura.io/v3/9aa3d95b3bc4', '40fa88ea12eaa4456161'].join('')
2308
+ rpc: ['https://mainnet.infura.io/v3/9aa3d95b3bc4', '40fa88ea12eaa4456161'].join(''),
2309
+ tokens: [ // only major tokens
2310
+ {"address": "0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE", "symbol": "ETH", "name": "Ether", "decimals": 18, "logo": ""},
2311
+ {"address": "0xA0b86991c6218b36c1d19D4a2e9Eb0cE3606eB48", "symbol": "USDC", "name": "USD Coin", "decimals": 6, "logo": "https://raw.githubusercontent.com/trustwallet/assets/master/blockchains/ethereum/assets/0xA0b86991c6218b36c1d19D4a2e9Eb0cE3606eB48/logo.png"},
2312
+ {"address": "0x2260FAC5E5542a773Aa44fBCfeDf7C193bc2C599", "symbol": "WBTC", "name": "Wrapped BTC", "decimals": 8, "logo": "https://raw.githubusercontent.com/trustwallet/assets/master/blockchains/ethereum/assets/0x2260FAC5E5542a773Aa44fBCfeDf7C193bc2C599/logo.png"},
2313
+ {"address": "0xdAC17F958D2ee523a2206206994597C13D831ec7", "symbol": "USDT", "name": "Tether USD", "decimals": 6, "logo": "https://raw.githubusercontent.com/trustwallet/assets/master/blockchains/ethereum/assets/0xdAC17F958D2ee523a2206206994597C13D831ec7/logo.png"},
2314
+ {"address": "0x6B175474E89094C44Da98b954EedeAC495271d0F", "symbol": "DAI", "name": "Dai Stablecoin", "decimals": 18, "logo": "https://raw.githubusercontent.com/trustwallet/assets/master/blockchains/ethereum/assets/0x6B175474E89094C44Da98b954EedeAC495271d0F/logo.png"},
2315
+ {"address": "0x853d955aCEf822Db058eb8505911ED77F175b99e", "symbol": "FRAX", "name": "Frax", "decimals": 18, "logo": "https://raw.githubusercontent.com/trustwallet/assets/master/blockchains/ethereum/assets/0x853d955aCEf822Db058eb8505911ED77F175b99e/logo.png"},
2316
+ {"address": "0x4Fabb145d64652a948d72533023f6E7A623C7C53", "symbol": "BUSD", "name": "Binance USD", "decimals": 18, "logo": "https://raw.githubusercontent.com/trustwallet/assets/master/blockchains/ethereum/assets/0x4Fabb145d64652a948d72533023f6E7A623C7C53/logo.png"},
2317
+ {"address": "0x8E870D67F660D95d5be530380D0eC0bd388289E1", "symbol": "USDP", "name": "Pax Dollar", "decimals": 18, "logo": "https://raw.githubusercontent.com/trustwallet/assets/master/blockchains/ethereum/assets/0x8E870D67F660D95d5be530380D0eC0bd388289E1/logo.png"},
2318
+ {"address": "0x1f9840a85d5aF5bf1D1762F925BDADdC4201F984", "symbol": "UNI", "name": "Uniswap", "decimals": 18, "logo": "https://raw.githubusercontent.com/trustwallet/assets/master/blockchains/ethereum/assets/0x1f9840a85d5aF5bf1D1762F925BDADdC4201F984/logo.png"},
2319
+ {"address": "0x956F47F50A910163D8BF957Cf5846D573E7f87CA", "symbol": "FEI", "name": "Fei USD", "decimals": 18, "logo": "https://raw.githubusercontent.com/trustwallet/assets/master/blockchains/ethereum/assets/0x956F47F50A910163D8BF957Cf5846D573E7f87CA/logo.png"}
2320
+ ]
2309
2321
  };
2310
2322
 
2311
2323
  var bsc = {
@@ -2322,10 +2334,20 @@ var bsc = {
2322
2334
  decimals: 18
2323
2335
  },
2324
2336
  explorer: 'https://bscscan.com',
2325
- explorerUrlFor: ({ transaction })=>{
2337
+ explorerUrlFor: ({ transaction, token })=>{
2326
2338
  if(transaction) { return `https://bscscan.com/tx/${transaction.id}` }
2339
+ if(token) { return `https://bscscan.com/token/${token}` }
2327
2340
  },
2328
- rpc: 'https://bsc-dataseed1.binance.org'
2341
+ rpc: 'https://bsc-dataseed1.binance.org',
2342
+ tokens: [ // only major tokens
2343
+ {"address": "0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE", "symbol": "BNB", "name": "Binance Coin", "decimals": 18, "logo": "https://assets.trustwalletapp.com/blockchains/smartchain/assets/0xbb4CdB9CBd36B01bD1cBaEBF2De08d9173bc095c/logo.png"},
2344
+ {"address": "0xe9e7CEA3DedcA5984780Bafc599bD69ADd087D56", "symbol": "BUSD", "name": "BUSD Token", "decimals": 18, "logo": "https://assets.trustwalletapp.com/blockchains/smartchain/assets/0xe9e7CEA3DedcA5984780Bafc599bD69ADd087D56/logo.png"},
2345
+ {"address": "0x55d398326f99059fF775485246999027B3197955", "symbol": "USDT", "name": "Binance-Peg BSC-USD", "decimals": 18, "logo": "https://assets.trustwalletapp.com/blockchains/smartchain/assets/0x55d398326f99059fF775485246999027B3197955/logo.png"},
2346
+ {"address": "0x0E09FaBB73Bd3Ade0a17ECC321fD13a19e81cE82", "symbol": "Cake", "name": "PancakeSwap Token", "decimals": 18, "logo": "https://assets.trustwalletapp.com/blockchains/smartchain/assets/0x0E09FaBB73Bd3Ade0a17ECC321fD13a19e81cE82/logo.png"},
2347
+ {"address": "0x8AC76a51cc950d9822D68b83fE1Ad97B32Cd580d", "symbol": "USDC", "name": "USD Coin", "decimals": 18, "logo": "https://assets.trustwalletapp.com/blockchains/smartchain/assets/0x8AC76a51cc950d9822D68b83fE1Ad97B32Cd580d/logo.png"},
2348
+ {"address": "0x2170Ed0880ac9A755fd29B2688956BD959F933F8", "symbol": "ETH", "name": "Ethereum Token", "decimals": 18, "logo": "https://assets.trustwalletapp.com/blockchains/smartchain/assets/0x2170Ed0880ac9A755fd29B2688956BD959F933F8/logo.png"},
2349
+ {"address": "0x7130d2A12B9BCbFAe4f2634d864A1Ee1Ce3Ead9c", "symbol": "BTCB", "name": "BTCB Token", "decimals": 18, "logo": "https://assets.trustwalletapp.com/blockchains/smartchain/assets/0x7130d2A12B9BCbFAe4f2634d864A1Ee1Ce3Ead9c/logo.png"}
2350
+ ]
2329
2351
  };
2330
2352
 
2331
2353
  var polygon = {
@@ -2342,8 +2364,9 @@ var polygon = {
2342
2364
  decimals: 18
2343
2365
  },
2344
2366
  explorer: 'https://polygonscan.com',
2345
- explorerUrlFor: ({ transaction })=>{
2367
+ explorerUrlFor: ({ transaction, token })=>{
2346
2368
  if(transaction) { return `https://polygonscan.com/tx/${transaction.id}` }
2369
+ if(token) { return `https://polygonscan.com/token/${token}` }
2347
2370
  },
2348
2371
  rpc: 'https://rpc-mainnet.matic.network'
2349
2372
  };
@@ -49089,6 +49112,7 @@ var SelectWalletDialog = (function (props) {
49089
49112
  }, /*#__PURE__*/react.createElement("div", {
49090
49113
  className: "CardImage"
49091
49114
  }, /*#__PURE__*/react.createElement("img", {
49115
+ className: "transparent",
49092
49116
  src: wallet.info.logo
49093
49117
  })), /*#__PURE__*/react.createElement("div", {
49094
49118
  className: "CardBody"
@@ -49105,7 +49129,7 @@ var SelectWalletDialog = (function (props) {
49105
49129
  className: "LineHeightL FontSizeL"
49106
49130
  }, "Select a wallet")),
49107
49131
  body: /*#__PURE__*/react.createElement("div", {
49108
- className: "PaddingTopS PaddingBottomXS PaddingLeftS PaddingRightS"
49132
+ className: "PaddingBottomS PaddingLeftS PaddingRightS"
49109
49133
  }, walletCards),
49110
49134
  footer: /*#__PURE__*/react.createElement("div", {
49111
49135
  className: "PaddingBottomS"
@@ -49362,7 +49386,7 @@ var ErrorBoundary = /*#__PURE__*/function (_React$Component) {
49362
49386
  }(react.Component);
49363
49387
 
49364
49388
  var ErrorProvider = (function (props) {
49365
- var _useState = react.useState(),
49389
+ var _useState = react.useState(props.error),
49366
49390
  _useState2 = _slicedToArray(_useState, 2),
49367
49391
  error = _useState2[0],
49368
49392
  setError = _useState2[1];
@@ -49375,8 +49399,8 @@ var ErrorProvider = (function (props) {
49375
49399
  var setErrorFromChildren = function setErrorFromChildren(error) {
49376
49400
  setError(error);
49377
49401
 
49378
- if (props.error) {
49379
- props.error(error);
49402
+ if (props.errorCallback) {
49403
+ props.errorCallback(error);
49380
49404
  }
49381
49405
  };
49382
49406
 
@@ -49435,6 +49459,10 @@ var ErrorProvider = (function (props) {
49435
49459
  }
49436
49460
  });
49437
49461
 
49462
+ var AlertStyle = (function (style) {
49463
+ return "\n\n .Alert {\n background: rgba(0,0,0,0.08);\n border-radius: 0.4rem;\n font-weight: 500;\n padding: 0.5rem;\n }\n ";
49464
+ });
49465
+
49438
49466
  var BlockchainLogoStyle = (function (style) {
49439
49467
  return "\n\n .BlockchainLogo {\n border-radius: 999px;\n }\n\n .BlockchainLogo.small {\n height: 18px;\n width: 18px;\n }\n ";
49440
49468
  });
@@ -49448,11 +49476,11 @@ var ButtonPrimaryStyle = (function (style) {
49448
49476
  });
49449
49477
 
49450
49478
  var CardStyle = (function (style) {
49451
- return "\n\n .Card {\n align-items: center;\n background: rgb(255,255,255);\n border-radius: 0.8rem;\n box-shadow: 0 0 8px rgba(0,0,0,0.03);\n cursor: pointer;\n display: flex;\n flex-direction: row;\n margin-bottom: 0.5rem;\n min-height: 4.78rem;\n padding: 1rem 0.6rem;\n width: 100%;\n }\n\n a.Card, a.Card * {\n color: inherit;\n text-decoration: none;\n }\n\n .Card.transparent {\n background: none;\n box-shadow: none;\n }\n\n .Card.small {\n min-height: auto;\n padding: 0.5rem 0.5rem;\n margin: 0;\n }\n\n .Card.disabled {\n cursor: default;\n }\n\n .Card:hover:not(.disabled) {\n background: rgb(240,240,240);\n box-shadow: 0 0 0 rgba(0,0,0,0); \n }\n\n .Card:active:not(.disabled) {\n background: rgb(235,235,235);\n box-shadow: inset 0 0 6px rgba(0,0,0,0.02);\n color: inherit;\n }\n\n .Card:hover:not(.disabled) .CardAction {\n opacity: 0.4;\n }\n\n .CardImage, .CardBody, .CardAction, .CardInfo {\n align-items: center;\n display: flex;\n min-width: 0;\n padding: 0 0.4rem;\n }\n\n .CardImage {\n flex-basis: auto;\n flex-grow: 0;\n flex-shrink: 0;\n justify-content: center;\n position: relative;\n width: 3.6rem;\n }\n\n .CardBody {\n flex-basis: auto;\n flex-grow: 1;\n flex-shrink: 1;\n line-height: 1.4rem;\n padding-left: 0.6rem;\n text-align: left;\n }\n\n .CardBodyWrapper {\n min-width: 0;\n }\n\n .CardAction {\n flex-basis: auto;\n flex-shrink: 0;\n flex-grow: 0;\n padding-right: 0;\n margin-left: auto;\n }\n\n .Card.disabled .CardAction {\n opacity: 0; \n }\n\n .CardInfo {\n display: flex;\n flex-basis: auto;\n flex-direction: column;\n flex-grow: 0;\n flex-shrink: 1;\n justify-content: center;\n margin-left: auto; \n padding-right: 0;\n }\n\n .CardImage img {\n background: white;\n border-radius: 99rem;\n border: 1px solid white;\n box-shadow: 0 2px 8px rgb(0 0 0 / 10%);\n height: 2.8rem;\n position: relative;\n vertical-align: middle;\n width: 2.8rem;\n }\n\n .CardImage .BlockchainLogo {\n position: absolute;\n bottom: 0;\n right: 0;\n }\n\n .CardTitle {\n font-size: 0.9rem;\n color: rgb(150,150,150);\n }\n \n .CardText, a .CardText {\n color: ".concat(style.colors.text, ";\n flex: 1;\n font-size: 1.3rem;\n }\n\n .CardText strong {\n font-weight: 500;\n }\n\n .CardText small {\n font-size: 1.1rem;\n color: rgb(150,150,150);\n }\n\n .CardAction {\n opacity: 0.2;\n }\n\n .Card.More {\n display: inline-block;\n text-align: center;\n }\n ");
49479
+ return "\n\n .Card {\n align-items: center;\n background: rgb(255,255,255);\n border-radius: 0.8rem;\n box-shadow: 0 0 8px rgba(0,0,0,0.03);\n cursor: pointer;\n display: flex;\n flex-direction: row;\n margin-bottom: 0.5rem;\n min-height: 4.78rem;\n padding: 1rem 0.6rem;\n width: 100%;\n }\n\n .Card.Row {\n border-radius: 0;\n margin-bottom: 0;\n box-shadow: none;\n min-height: 4.3rem;\n padding: 0.4rem 1.3rem;\n border-top: 1px solid rgba(0,0,0,0.05);\n }\n\n .Card.Row .CardText {\n font-size: 1.2rem;\n }\n\n .CardTokenSymbol {\n width: 40%;\n min-width: 0;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n }\n\n .CardTokenName {\n text-align: right;\n opacity: 0.5;\n width: 60%;\n min-width: 0;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n }\n \n .Card.Row .CardTokenName .CardText {\n font-size: 1rem;\n }\n\n .Card.Row .CardImage {\n width: 2.5rem;\n }\n\n .Card.Row .CardImage img {\n height: 1.9rem;\n width: 1.9rem;\n }\n\n a.Card, a.Card * {\n color: inherit;\n text-decoration: none;\n }\n\n .Card.transparent {\n background: none;\n box-shadow: none;\n }\n\n .Card.small {\n min-height: auto;\n padding: 0.5rem 0.5rem;\n margin: 0;\n }\n\n .CardImage.small {\n width: 1.7rem;\n }\n\n .CardImage.small img {\n height: 1.4rem;\n width: 1.4rem;\n }\n\n .Card.disabled {\n cursor: default;\n }\n\n .Card:hover:not(.disabled) {\n background: rgb(240,240,240);\n box-shadow: 0 0 0 rgba(0,0,0,0); \n }\n\n .Card:active:not(.disabled) {\n background: rgb(235,235,235);\n box-shadow: inset 0 0 6px rgba(0,0,0,0.02);\n color: inherit;\n }\n\n .Card:hover:not(.disabled) .CardAction {\n opacity: 0.4;\n }\n\n .CardImage, .CardBody, .CardAction, .CardInfo {\n align-items: center;\n display: flex;\n min-width: 0;\n padding: 0 0.4rem;\n }\n\n .CardImage {\n flex-basis: auto;\n flex-grow: 0;\n flex-shrink: 0;\n justify-content: center;\n position: relative;\n width: 3.6rem;\n }\n\n .CardBody {\n flex-basis: auto;\n flex-grow: 1;\n flex-shrink: 1;\n line-height: 1.4rem;\n padding-left: 0.6rem;\n text-align: left;\n }\n\n .CardBodyWrapper {\n min-width: 0;\n }\n\n .CardAction {\n flex-basis: auto;\n flex-shrink: 0;\n flex-grow: 0;\n padding-right: 0;\n margin-left: auto;\n }\n\n .Card.disabled .CardAction {\n opacity: 0; \n }\n\n .CardInfo {\n display: flex;\n flex-basis: auto;\n flex-direction: column;\n flex-grow: 0;\n flex-shrink: 1;\n justify-content: center;\n margin-left: auto; \n padding-right: 0;\n }\n\n .CardImage img {\n background: white;\n border-radius: 99rem;\n border: 1px solid white;\n background: rgba(0,0,0,0.1);\n box-shadow: 0 2px 8px rgb(0 0 0 / 10%);\n height: 2.8rem;\n position: relative;\n vertical-align: middle;\n width: 2.8rem;\n }\n\n .CardImage img.transparent {\n border: none;\n background: none;\n box-shadow: none;\n }\n \n .CardImage .BlockchainLogo {\n position: absolute;\n bottom: 0;\n right: 0;\n }\n\n .CardTitle {\n font-size: 0.9rem;\n color: rgb(150,150,150);\n }\n \n .CardText, a .CardText {\n color: ".concat(style.colors.text, ";\n flex: 1;\n font-size: 1.3rem;\n }\n\n .CardText strong {\n font-weight: 500;\n }\n\n .CardText small {\n font-size: 1.26rem;\n color: rgb(150,150,150);\n }\n\n .CardAction {\n opacity: 0.2;\n }\n\n .Card.More {\n display: inline-block;\n text-align: center;\n }\n ");
49452
49480
  });
49453
49481
 
49454
49482
  var DialogStyle = (function (style) {
49455
- return "\n\n .ReactDialogBackground {\n backdrop-filter: blur(5px);\n background: rgba(0,0,0,0.7);\n }\n\n .Dialog {\n margin: 0 auto;\n position: relative;\n width: 420px;\n box-shadow: 0 0 20px rgba(0,0,0,0.1);\n border-radius: 0.8rem;\n }\n\n @media screen and (max-width: 450px) {\n \n .Dialog, .ReactDialogAnimation {\n width: 100%;\n }\n\n }\n\n @media (orientation: portrait) and (max-width: 900px) {\n\n .Dialog {\n align-content: stretch;\n display: flex;\n flex-direction: column;\n height: 100%;\n }\n\n .DialogBody {\n flex: 1;\n align-items: flex-end;\n max-height: 60vh !important;\n }\n\n .DialogFooter {\n padding-bottom: 20px;\n }\n\n .ReactDialogStackCell {\n vertical-align: bottom;\n }\n\n .ReactDialogAnimation {\n bottom: -100px !important;\n max-height: 66vh !important;\n top: inherit !important;\n transition: opacity 0.4s ease, bottom 0.4s ease;\n }\n\n .ReactDialog.ReactDialogOpen .ReactDialogAnimation {\n bottom: 0px !important;\n }\n\n .DialogFooter {\n border-bottom-left-radius: 0 !important;\n border-bottom-right-radius: 0 !important;\n }\n }\n\n .DialogBody {\n background: rgb(248,248,248);\n overflow-x: hidden;\n overflow-y: auto;\n }\n\n .DialogBody.HeightAuto {\n height: auto;\n }\n\n .DialogHeader {\n background: rgb(248,248,248);\n border-top-left-radius: 0.8rem;\n border-top-right-radius: 0.8rem;\n display: flex;\n flex-direction: row;\n position: relative;\n }\n\n .DialogHeaderTitle {\n flex-basis: auto;\n flex-grow: 1;\n }\n \n .DialogHeaderAction {\n height: 3rem;\n }\n\n .DialogFooter {\n background: rgb(248,248,248);\n border-bottom-left-radius: 0.8rem;\n border-bottom-right-radius: 0.8rem;\n line-height: 1.5rem;\n min-height: 2rem;\n position: relative;\n text-align: center;\n }\n\n .ReactShadowDOMInsideContainer > .ReactDialog {\n display: table;\n }\n\n ";
49483
+ return "\n\n .ReactDialogBackground {\n backdrop-filter: blur(5px);\n background: rgba(0,0,0,0.7);\n }\n\n .Dialog {\n margin: 0 auto;\n position: relative;\n width: 420px;\n box-shadow: 0 0 20px rgba(0,0,0,0.1);\n border-radius: 0.8rem;\n background: rgb(248,248,248);\n }\n\n @media screen and (max-width: 450px) {\n \n .Dialog, .ReactDialogAnimation {\n width: 100%;\n }\n\n }\n\n @media (orientation: portrait) and (max-width: 900px) {\n\n .Dialog {\n align-content: stretch;\n display: flex;\n flex-direction: column;\n height: 100%;\n }\n\n .DialogBody {\n flex: 1;\n align-items: flex-end;\n }\n\n .DialogFooter {\n padding-bottom: 20px;\n }\n\n .ReactDialogStackCell {\n vertical-align: bottom;\n }\n\n .ReactDialogAnimation {\n bottom: -100px !important;\n top: inherit !important;\n transition: opacity 0.4s ease, bottom 0.4s ease;\n }\n\n .ReactDialog.ReactDialogOpen .ReactDialogAnimation {\n bottom: 0px !important;\n }\n\n .DialogFooter {\n border-bottom-left-radius: 0 !important;\n border-bottom-right-radius: 0 !important;\n }\n }\n\n .DialogBody {\n background: rgb(248,248,248);\n overflow-x: hidden;\n overflow-y: auto;\n }\n\n .DialogBody.ScrollHeight {\n height: 30vh !important;\n max-height: 30vh !important;\n }\n\n .DialogHeader {\n background: rgb(248,248,248);\n border-top-left-radius: 0.8rem;\n border-top-right-radius: 0.8rem;\n min-height: 3.4rem;\n position: relative;\n width: 100%;\n }\n\n .DialogHeaderActionRight {\n position: absolute;\n top: 0;\n right: 0;\n height: 3rem;\n }\n\n .DialogHeaderActionLeft {\n position: absolute;\n top: 0;\n left: 0;\n height: 3rem;\n }\n\n .DialogFooter {\n background: rgb(248,248,248);\n border-bottom-left-radius: 0.8rem;\n border-bottom-right-radius: 0.8rem;\n line-height: 1.5rem;\n min-height: 2rem;\n position: relative;\n text-align: center;\n }\n\n .ReactShadowDOMInsideContainer > .ReactDialog {\n display: table;\n }\n\n ";
49456
49484
  });
49457
49485
 
49458
49486
  var FontStyle = (function (style) {
@@ -49483,6 +49511,10 @@ var LabelStyle = (function (style) {
49483
49511
  return "\n\n .Label {\n background: rgb(248,248,248);\n border-radius: 999px;\n color: ".concat(style.colors.primary, ";\n font-size: 0.8rem;\n padding: 0.1rem 0.5rem;\n margin: 0.1rem;\n }\n\n ");
49484
49512
  });
49485
49513
 
49514
+ var LinkStyle = (function (style) {
49515
+ return "\n\n .Link {\n color: ".concat(style.colors.primary, ";\n cursor: pointer;\n text-decoration: none;\n }\n\n .Link:hover {\n filter: brightness(0.8);\n }\n\n .Link:active {\n filter: brightness(1.0);\n }\n ");
49516
+ });
49517
+
49486
49518
  var LoadingTextStyle = (function (style) {
49487
49519
  return "\n\n .LoadingText {\n color: ".concat(style.colors.buttonText, ";\n display: inline-block;\n text-decoration: none;\n }\n\n @keyframes blink {\n 0% { opacity: .2; }\n 20% { opacity: 1; }\n 100% { opacity: .2; }\n }\n \n .LoadingText .dot {\n animation-name: blink;\n animation-duration: 1.4s;\n animation-iteration-count: infinite;\n animation-fill-mode: both;\n }\n \n .LoadingText .dot:nth-child(2) {\n animation-delay: .2s;\n }\n \n .LoadingText .dot:nth-child(3) {\n animation-delay: .4s;\n }\n ");
49488
49520
  });
@@ -49507,10 +49539,18 @@ var ResetStyle = (function () {
49507
49539
  return "\n\n html, body, div, span, applet, object, iframe,\n h1, h2, h3, h4, h5, h6, p, blockquote, pre,\n a, abbr, acronym, address, big, cite, code,\n del, dfn, em, img, ins, kbd, q, s, samp,\n small, strike, strong, sub, sup, tt, var,\n b, u, i, center,\n dl, dt, dd, ol, ul, li,\n fieldset, form, label, legend,\n table, caption, tbody, tfoot, thead, tr, th, td,\n article, aside, canvas, details, embed, \n figure, figcaption, footer, header, hgroup, \n menu, nav, output, ruby, section, summary,\n time, mark, audio, video {\n margin: 0;\n padding: 0;\n border: 0;\n font-size: 100%;\n font: inherit;\n text-align: inherit;\n vertical-align: baseline;\n }\n\n article, aside, details, figcaption, figure, \n footer, header, hgroup, menu, nav, section {\n display: block;\n }\n\n body {\n line-height: 1;\n }\n\n ol, ul {\n list-style: none;\n }\n\n blockquote, q {\n quotes: none;\n }\n\n blockquote:before, blockquote:after,\n q:before, q:after {\n content: '';\n content: none;\n }\n \n table {\n border-collapse: collapse;\n border-spacing: 0;\n }\n\n * {\n box-sizing: border-box;\n }\n\n button {\n border: 0;\n background: none;\n outline: none;\n }\n\n ";
49508
49540
  });
49509
49541
 
49542
+ var SearchStyle = (function (style) {
49543
+ return "\n\n .Search {\n border-radius: 0.8rem;\n border: 1px solid rgba(0,0,0,0.2);\n outline: none !important;\n color: ".concat(style.colors.text, ";\n font-size: 1.2rem;\n padding: 0.8rem;\n width: 100%;\n }\n\n .Search::placeholder {\n color: rgb(180,180,180);\n } \n\n .Search:focus, .Search:focus-visible {\n border: 1px solid ").concat(style.colors.primary, ";\n }\n\n ");
49544
+ });
49545
+
49510
49546
  var SkeletonStyle = (function () {
49511
49547
  return "\n \n .Skeleton {\n background: rgb(230,230,230) !important;\n border: 0px solid transparent !important;\n box-shadow: none !important;\n cursor: inherit !important;\n line-height: 0;\n overflow: hidden;\n position: relative;\n }\n\n @keyframes SkeletonBackgroundAnimation {\n from {\n left: -500px;\n }\n to {\n left: +120%;\n }\n }\n\n .SkeletonBackground {\n animation: 2s SkeletonBackgroundAnimation 0.2s ease infinite;\n background: linear-gradient(to right, transparent 0%, rgba(0,0,0,0.1) 50%, transparent 100%);\n height: 100%;\n left: -140%;\n position: absolute;\n top: 0;\n width: 400px;\n }\n\n .SkeletonWrapper {\n line-height: 0;\n }\n ";
49512
49548
  });
49513
49549
 
49550
+ var TableStyle = (function (style) {
49551
+ return "\n\n .Table {\n border-collapse: separate;\n border-radius: 0.4rem;\n border-style: hidden;\n border: 1px solid rgba(0,0,0,0.1);\n font-size: 94%;\n width: 100%;\n }\n\n .Table tr.small td {\n font-size: 90%;\n }\n\n .Table tr td {\n border-bottom: 1px solid rgba(0,0,0,0.1);\n word-break: break-all;\n }\n \n .Table tr:last-child td {\n border-bottom: none;\n }\n \n .Table tr td {\n padding: 0.5rem 0.9rem;\n text-align: left;\n }\n \n .Table tr td:first-child {\n width: 30%\n }\n\n .Table tr td:last-child {\n width: 70%\n }\n \n .Table .TableSubTitle {\n font-weight: 300;\n opacity: 0.7;\n }\n\n .Table tr td:last-child {\n font-weight: 500;\n }\n ";
49552
+ });
49553
+
49514
49554
  var TextButtonStyle = (function (style) {
49515
49555
  return "\n\n .TextButton {\n cursor: pointer;\n font-size: 16px;\n color: ".concat(style.colors.primary, "\n }\n\n .TextButton:hover * {\n opacity: 1.0;\n }\n ");
49516
49556
  });
@@ -49520,7 +49560,15 @@ var TextStyle = (function (style) {
49520
49560
  });
49521
49561
 
49522
49562
  var TokenAmountStyle = (function () {
49523
- return "\n \n .TokenAmountRow {\n min-width: 0;\n width: 100%;\n display: flex;\n flex-direction: row;\n }\n\n .TokenAmountCell {\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n }\n\n .TokenSymbolCell {\n \n }\n ";
49563
+ return "\n \n .TokenAmountRow {\n min-width: 0;\n width: 100%;\n display: flex;\n flex-direction: row;\n }\n\n .TokenAmountCell {\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n }\n\n .TokenSymbolCell {\n }\n ";
49564
+ });
49565
+
49566
+ var TokenImageStyle = (function (style) {
49567
+ return "\n\n .TokenImage img {\n background: white;\n border-radius: 99rem;\n border: 1px solid white;\n background: rgba(0,0,0,0.1);\n box-shadow: 0 2px 8px rgb(0 0 0 / 10%);\n height: 2.8rem;\n position: relative;\n vertical-align: middle;\n width: 2.8rem;\n }\n\n .TokenImage.medium img {\n height: 5.8rem;\n width: 5.8rem;\n }\n ";
49568
+ });
49569
+
49570
+ var TooltipStyle = (function (style) {
49571
+ return "\n\n .Tooltip {\n background: ".concat(style.colors.primary, ";\n border-radius: 0.6rem;\n color: ").concat(style.colors.buttonText, ";\n padding: 0.6rem 0.8rem;\n position: relative;\n box-shadow: 0 0 8px rgba(0,0,0,0.2);\n }\n\n .TooltipArrowUp {\n border-bottom: 10px solid ").concat(style.colors.primary, ";\n border-left: 10px solid transparent;\n border-right: 10px solid transparent;\n height: 0; \n left: 12px;\n position: absolute;\n top: -8px;\n width: 0; \n }\n ");
49524
49572
  });
49525
49573
 
49526
49574
  var styleRenderer = (function (style) {
@@ -49533,7 +49581,7 @@ var styleRenderer = (function (style) {
49533
49581
  },
49534
49582
  fontFamily: '-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol"'
49535
49583
  }, style);
49536
- return [ResetStyle(), FontStyle(style), DialogStyle(), ButtonCircularStyle(), ButtonPrimaryStyle(style), CardStyle(style), PoweredByStyle(style), GraphicStyle(), SkeletonStyle(), TokenAmountStyle(), TextStyle(style), IconStyle(style), OpacityStyle(), PaddingStyle(), HeightStyle(), LabelStyle(style), LoadingTextStyle(style), RangeSliderStyle(style), InputStyle(), TextButtonStyle(style), ImageStyle(), BlockchainLogoStyle()].join('');
49584
+ return [ResetStyle(), FontStyle(style), DialogStyle(), ButtonCircularStyle(), ButtonPrimaryStyle(style), CardStyle(style), PoweredByStyle(style), GraphicStyle(), SkeletonStyle(), TokenAmountStyle(), TextStyle(style), IconStyle(style), OpacityStyle(), PaddingStyle(), HeightStyle(), LabelStyle(style), LoadingTextStyle(style), RangeSliderStyle(style), InputStyle(), TextButtonStyle(style), ImageStyle(), BlockchainLogoStyle(), SearchStyle(style), TokenImageStyle(), AlertStyle(), TableStyle(), LinkStyle(style), TooltipStyle(style)].join('');
49537
49585
  });
49538
49586
 
49539
49587
  const insideContainerClass = 'ReactShadowDOMInsideContainer';
@@ -49724,7 +49772,7 @@ var Connect = function Connect(options) {
49724
49772
 
49725
49773
  return function (container) {
49726
49774
  return /*#__PURE__*/react.createElement(ErrorProvider, {
49727
- error: error,
49775
+ errorCallback: error,
49728
49776
  container: container,
49729
49777
  unmount: unmount
49730
49778
  }, /*#__PURE__*/react.createElement(UpdatableProvider, null, /*#__PURE__*/react.createElement(ClosableProvider, {
@@ -69601,7 +69649,7 @@ var DonationOverviewSkeleton = (function (props) {
69601
69649
  className: "LineHeightL FontSizeL"
69602
69650
  }, "Donation")),
69603
69651
  body: /*#__PURE__*/react.createElement("div", {
69604
- className: "PaddingTopS PaddingLeftM PaddingRightM PaddingBottomXS"
69652
+ className: "PaddingLeftM PaddingRightM PaddingBottomXS"
69605
69653
  }, /*#__PURE__*/react.createElement("div", {
69606
69654
  className: "Card Skeleton"
69607
69655
  }, /*#__PURE__*/react.createElement("div", {
@@ -69910,7 +69958,7 @@ var DonationOverviewDialog = (function (props) {
69910
69958
  className: "LineHeightL FontSizeL"
69911
69959
  }, "Donation")),
69912
69960
  body: /*#__PURE__*/react.createElement("div", {
69913
- className: "PaddingTopS PaddingLeftM PaddingRightM PaddingBottomXS"
69961
+ className: "PaddingLeftM PaddingRightM PaddingBottomXS"
69914
69962
  }, /*#__PURE__*/react.createElement("div", {
69915
69963
  className: ["Card", paymentState == 'initialized' ? '' : 'disabled'].join(' '),
69916
69964
  title: paymentState == 'initialized' ? "Change amount" : undefined,
@@ -70319,7 +70367,7 @@ var Donation = /*#__PURE__*/function () {
70319
70367
  }, function (unmount) {
70320
70368
  return function (container) {
70321
70369
  return /*#__PURE__*/react.createElement(ErrorProvider, {
70322
- error: error,
70370
+ errorCallback: error,
70323
70371
  container: container,
70324
70372
  unmount: unmount
70325
70373
  }, /*#__PURE__*/react.createElement(ConfigurationProvider, {
@@ -70510,7 +70558,7 @@ var Login = function Login(options) {
70510
70558
 
70511
70559
  return function (container) {
70512
70560
  return /*#__PURE__*/react.createElement(ErrorProvider, {
70513
- error: error,
70561
+ errorCallback: error,
70514
70562
  container: container,
70515
70563
  unmount: unmount
70516
70564
  }, /*#__PURE__*/react.createElement(ConfigurationProvider, {
@@ -70592,7 +70640,7 @@ var PaymentOverviewSkeleton = (function (props) {
70592
70640
  className: "LineHeightL FontSizeL"
70593
70641
  }, "Payment")),
70594
70642
  body: /*#__PURE__*/react.createElement("div", {
70595
- className: "PaddingTopS PaddingLeftM PaddingRightM PaddingBottomXS"
70643
+ className: "PaddingLeftM PaddingRightM PaddingBottomXS"
70596
70644
  }, amountsMissing && /*#__PURE__*/react.createElement("div", {
70597
70645
  className: "Card Skeleton"
70598
70646
  }, /*#__PURE__*/react.createElement("div", {
@@ -70643,7 +70691,7 @@ var PaymentOverviewDialog = (function (props) {
70643
70691
  className: "LineHeightL FontSizeL"
70644
70692
  }, "Payment")),
70645
70693
  body: /*#__PURE__*/react.createElement("div", {
70646
- className: "PaddingTopS PaddingLeftM PaddingRightM PaddingBottomXS"
70694
+ className: "PaddingLeftM PaddingRightM PaddingBottomXS"
70647
70695
  }, amountsMissing && /*#__PURE__*/react.createElement("div", {
70648
70696
  className: ["Card", paymentState == 'initialized' ? '' : 'disabled'].join(' '),
70649
70697
  title: paymentState == 'initialized' ? "Change amount" : undefined,
@@ -70790,7 +70838,7 @@ var Payment = /*#__PURE__*/function () {
70790
70838
  }, function (unmount) {
70791
70839
  return function (container) {
70792
70840
  return /*#__PURE__*/react.createElement(ErrorProvider, {
70793
- error: error,
70841
+ errorCallback: error,
70794
70842
  container: container,
70795
70843
  unmount: unmount
70796
70844
  }, /*#__PURE__*/react.createElement(ConfigurationProvider, {
@@ -70944,7 +70992,7 @@ var SaleOverviewSkeleton = (function (props) {
70944
70992
  className: "LineHeightL FontSizeL"
70945
70993
  }, "Purchase")),
70946
70994
  body: /*#__PURE__*/react.createElement("div", {
70947
- className: "PaddingTopS PaddingLeftM PaddingRightM PaddingBottomXS"
70995
+ className: "PaddingLeftM PaddingRightM PaddingBottomXS"
70948
70996
  }, /*#__PURE__*/react.createElement("div", {
70949
70997
  className: "Card Skeleton",
70950
70998
  style: {
@@ -71028,7 +71076,7 @@ var SaleOverviewDialog = (function (props) {
71028
71076
  className: "LineHeightL FontSizeL"
71029
71077
  }, "Purchase")),
71030
71078
  body: /*#__PURE__*/react.createElement("div", {
71031
- className: "PaddingTopS PaddingLeftM PaddingRightM PaddingBottomXS"
71079
+ className: "PaddingLeftM PaddingRightM PaddingBottomXS"
71032
71080
  }, /*#__PURE__*/react.createElement("div", {
71033
71081
  className: ["Card", paymentState == 'initialized' ? '' : 'disabled'].join(' '),
71034
71082
  title: paymentState == 'initialized' ? "Change amount" : undefined,
@@ -71194,7 +71242,7 @@ var Sale = /*#__PURE__*/function () {
71194
71242
  }, function (unmount) {
71195
71243
  return function (container) {
71196
71244
  return /*#__PURE__*/react.createElement(ErrorProvider, {
71197
- error: error,
71245
+ errorCallback: error,
71198
71246
  container: container,
71199
71247
  unmount: unmount
71200
71248
  }, /*#__PURE__*/react.createElement(ConfigurationProvider, {
@@ -71254,12 +71302,575 @@ var Sale = /*#__PURE__*/function () {
71254
71302
  };
71255
71303
  }();
71256
71304
 
71305
+ var SelectionContext = /*#__PURE__*/react.createContext();
71306
+
71307
+ var SelectionProvider = (function (props) {
71308
+ var _useState = react.useState({}),
71309
+ _useState2 = _slicedToArray(_useState, 2),
71310
+ selection = _useState2[0],
71311
+ setSelection = _useState2[1];
71312
+
71313
+ return /*#__PURE__*/react.createElement(SelectionContext.Provider, {
71314
+ value: {
71315
+ selection: selection,
71316
+ setSelection: setSelection
71317
+ }
71318
+ }, props.children);
71319
+ });
71320
+
71321
+ var msToTime = (function (ms) {
71322
+ var year, month, day, hour, minute, second;
71323
+ second = Math.floor(ms / 1000);
71324
+ minute = Math.floor(second / 60);
71325
+ second = second % 60;
71326
+ hour = Math.floor(minute / 60);
71327
+ minute = minute % 60;
71328
+ day = Math.floor(hour / 24);
71329
+ hour = hour % 24;
71330
+ month = Math.floor(day / 30);
71331
+ day = day % 30;
71332
+ year = Math.floor(month / 12);
71333
+ month = month % 12;
71334
+ return {
71335
+ year: year,
71336
+ month: month,
71337
+ day: day,
71338
+ hour: hour,
71339
+ minute: minute,
71340
+ second: second
71341
+ };
71342
+ });
71343
+
71344
+ var ConfirmTokenSelectionDialog = (function (props) {
71345
+ var _useContext = react.useContext(SelectionContext),
71346
+ selection = _useContext.selection;
71347
+
71348
+ var _useContext2 = react.useContext(ClosableContext),
71349
+ setOpen = _useContext2.setOpen;
71350
+
71351
+ var token = selection.token;
71352
+ var address = token.address || token.external_id;
71353
+ var logo = token.logo || token.image;
71354
+ var blockchain = Blockchain.findByName(token.blockchain);
71355
+ var age = token.first_transfer ? msToTime(new Date() - new Date(token.first_transfer)) : undefined;
71356
+
71357
+ if (age) {
71358
+ age = [age.year && age.year >= 1 ? age.year >= 2 ? "".concat(age.year, " years") : "1 year" : undefined, age.month && age.month >= 1 ? age.month >= 2 ? "".concat(age.month, " months") : "1 month" : undefined, age.day && age.day >= 1 && age.month <= 1 && age.year < 1 ? age.day >= 2 ? "".concat(age.day, " days !!!") : "1 day !!!" : undefined].filter(function (n) {
71359
+ return n;
71360
+ }).join(' ');
71361
+ }
71362
+
71363
+ var holders = token.unique_senders ? token.unique_senders : undefined;
71364
+
71365
+ if (holders) {
71366
+ if (holders > 1000000) {
71367
+ holders = "Millions";
71368
+ } else if (holders > 100000) {
71369
+ holders = "Hundreds of Thousands";
71370
+ } else if (holders > 2000) {
71371
+ holders = "Thousands";
71372
+ } else if (holders > 100) {
71373
+ holders = "Hundreds";
71374
+ } else {
71375
+ holders = "Only a Few!!!";
71376
+ }
71377
+ }
71378
+
71379
+ var onClickConfirm = function onClickConfirm() {
71380
+ setOpen(false);
71381
+ props.resolve({
71382
+ blockchain: token.blockchain,
71383
+ address: token.external_id || token.address,
71384
+ symbol: token.symbol,
71385
+ name: token.name,
71386
+ decimals: token.decimals,
71387
+ logo: token.image || token.logo
71388
+ });
71389
+ setTimeout(props.unmount, 300);
71390
+ };
71391
+
71392
+ return /*#__PURE__*/react.createElement(Dialog, {
71393
+ header: /*#__PURE__*/react.createElement("div", {
71394
+ className: "PaddingTopS PaddingLeftM PaddingRightM TextLeft"
71395
+ }, /*#__PURE__*/react.createElement("div", null, /*#__PURE__*/react.createElement("h1", {
71396
+ className: "LineHeightL FontSizeL"
71397
+ }, "Confirm Selection"))),
71398
+ stacked: true,
71399
+ body: /*#__PURE__*/react.createElement("div", {
71400
+ className: "PaddingTopS PaddingLeftM PaddingRightM"
71401
+ }, /*#__PURE__*/react.createElement("div", {
71402
+ className: "TokenImage medium"
71403
+ }, logo && /*#__PURE__*/react.createElement("img", {
71404
+ src: logo
71405
+ }), !logo && /*#__PURE__*/react.createElement(TokenImage, {
71406
+ blockchain: token.blockchain,
71407
+ address: address
71408
+ })), /*#__PURE__*/react.createElement("div", {
71409
+ className: "PaddingTopS"
71410
+ }, /*#__PURE__*/react.createElement("div", {
71411
+ className: "Alert"
71412
+ }, /*#__PURE__*/react.createElement("strong", null, "Please review this information"))), /*#__PURE__*/react.createElement("div", {
71413
+ className: "PaddingTopXS"
71414
+ }, /*#__PURE__*/react.createElement("table", {
71415
+ className: "Table"
71416
+ }, /*#__PURE__*/react.createElement("tbody", null, /*#__PURE__*/react.createElement("tr", {
71417
+ className: "small"
71418
+ }, /*#__PURE__*/react.createElement("td", {
71419
+ colSpan: "2"
71420
+ }, /*#__PURE__*/react.createElement("div", null, /*#__PURE__*/react.createElement("a", {
71421
+ className: "Link",
71422
+ href: blockchain.explorerUrlFor({
71423
+ token: address
71424
+ }),
71425
+ target: "_blank",
71426
+ rel: "noopener noreferrer"
71427
+ }, address)))), /*#__PURE__*/react.createElement("tr", null, /*#__PURE__*/react.createElement("td", null, /*#__PURE__*/react.createElement("div", {
71428
+ className: "TableSubTitle"
71429
+ }, "Blockchain")), /*#__PURE__*/react.createElement("td", null, /*#__PURE__*/react.createElement("div", null, blockchain.label))), /*#__PURE__*/react.createElement("tr", null, /*#__PURE__*/react.createElement("td", null, /*#__PURE__*/react.createElement("div", {
71430
+ className: "TableSubTitle"
71431
+ }, "Symbol")), /*#__PURE__*/react.createElement("td", null, /*#__PURE__*/react.createElement("div", null, token.symbol))), /*#__PURE__*/react.createElement("tr", null, /*#__PURE__*/react.createElement("td", null, /*#__PURE__*/react.createElement("div", {
71432
+ className: "TableSubTitle"
71433
+ }, "Name")), /*#__PURE__*/react.createElement("td", null, /*#__PURE__*/react.createElement("div", null, token.name))), age && /*#__PURE__*/react.createElement("tr", null, /*#__PURE__*/react.createElement("td", null, /*#__PURE__*/react.createElement("div", {
71434
+ className: "TableSubTitle"
71435
+ }, "Age")), /*#__PURE__*/react.createElement("td", null, /*#__PURE__*/react.createElement("div", null, age))), holders && /*#__PURE__*/react.createElement("tr", null, /*#__PURE__*/react.createElement("td", null, /*#__PURE__*/react.createElement("div", {
71436
+ className: "TableSubTitle"
71437
+ }, "Holders")), /*#__PURE__*/react.createElement("td", null, /*#__PURE__*/react.createElement("div", null, holders))))))),
71438
+ footer: /*#__PURE__*/react.createElement("div", {
71439
+ className: "PaddingTopS PaddingRightM PaddingLeftM PaddingBottomS"
71440
+ }, /*#__PURE__*/react.createElement("button", {
71441
+ className: "ButtonPrimary",
71442
+ onClick: onClickConfirm
71443
+ }, "Confirm"))
71444
+ });
71445
+ });
71446
+
71447
+ var SelectBlockchainDialog = (function (props) {
71448
+ var _useContext = react.useContext(SelectionContext),
71449
+ setSelection = _useContext.setSelection;
71450
+
71451
+ var _useContext2 = react.useContext(NavigateStackContext),
71452
+ navigate = _useContext2.navigate;
71453
+
71454
+ var stacked = Object.keys(props.selection).length > 1;
71455
+ var blockchains = [Blockchain.findByName('ethereum'), Blockchain.findByName('bsc')];
71456
+
71457
+ var selectBlockchain = function selectBlockchain(blockchain) {
71458
+ setSelection(Object.assign(props.selection, {
71459
+ blockchain: blockchain
71460
+ }));
71461
+
71462
+ if (stacked) {
71463
+ navigate('back');
71464
+ } else {
71465
+ props.resolve(blockchain);
71466
+ }
71467
+ };
71468
+
71469
+ var elements = blockchains.map(function (blockchain, index) {
71470
+ return /*#__PURE__*/react.createElement("div", {
71471
+ key: index,
71472
+ className: "Card Row",
71473
+ onClick: function onClick() {
71474
+ return selectBlockchain(blockchain);
71475
+ }
71476
+ }, /*#__PURE__*/react.createElement("div", {
71477
+ className: "CardImage"
71478
+ }, /*#__PURE__*/react.createElement("img", {
71479
+ className: "transparent",
71480
+ src: blockchain.logo
71481
+ })), /*#__PURE__*/react.createElement("div", {
71482
+ className: "CardBody"
71483
+ }, /*#__PURE__*/react.createElement("span", {
71484
+ className: "CardText"
71485
+ }, blockchain.label)));
71486
+ });
71487
+ return /*#__PURE__*/react.createElement(Dialog, {
71488
+ header: /*#__PURE__*/react.createElement("div", {
71489
+ className: "PaddingTopS PaddingLeftM PaddingRightM TextLeft"
71490
+ }, /*#__PURE__*/react.createElement("div", null, /*#__PURE__*/react.createElement("h1", {
71491
+ className: "LineHeightL FontSizeL"
71492
+ }, "Select Blockchain"))),
71493
+ stacked: stacked,
71494
+ bodyClassName: "ScrollHeight",
71495
+ body: /*#__PURE__*/react.createElement("div", {
71496
+ className: "PaddingTopS"
71497
+ }, elements),
71498
+ footer: /*#__PURE__*/react.createElement("div", {
71499
+ className: "PaddingTopS PaddingRightM PaddingLeftM PaddingBottomS"
71500
+ })
71501
+ });
71502
+ });
71503
+
71504
+ var SelectTokenDialog = (function (props) {
71505
+ var _useContext = react.useContext(NavigateStackContext),
71506
+ navigate = _useContext.navigate;
71507
+
71508
+ var _useContext2 = react.useContext(ClosableContext),
71509
+ setOpen = _useContext2.setOpen;
71510
+
71511
+ var _useContext3 = react.useContext(SelectionContext),
71512
+ setSelection = _useContext3.setSelection;
71513
+
71514
+ var _useState = react.useState(),
71515
+ _useState2 = _slicedToArray(_useState, 2),
71516
+ requestController = _useState2[0],
71517
+ setRequestController = _useState2[1];
71518
+
71519
+ var _useState3 = react.useState(),
71520
+ _useState4 = _slicedToArray(_useState3, 2),
71521
+ blockchain = _useState4[0],
71522
+ setBlockchain = _useState4[1];
71523
+
71524
+ var _useState5 = react.useState(false),
71525
+ _useState6 = _slicedToArray(_useState5, 2),
71526
+ showAddToken = _useState6[0],
71527
+ setShowAddToken = _useState6[1];
71528
+
71529
+ var _useState7 = react.useState([]),
71530
+ _useState8 = _slicedToArray(_useState7, 2),
71531
+ tokens = _useState8[0],
71532
+ setTokens = _useState8[1];
71533
+
71534
+ var _useState9 = react.useState(),
71535
+ _useState10 = _slicedToArray(_useState9, 2);
71536
+ _useState10[0];
71537
+ _useState10[1];
71538
+
71539
+ var searchElement = react.useRef();
71540
+ var wallet = getWallet();
71541
+
71542
+ var startWithBlockchain = function startWithBlockchain(name) {
71543
+ var blockchain = Blockchain.findByName(name);
71544
+ setBlockchain(blockchain);
71545
+ setSelection(Object.assign(props.selection, {
71546
+ blockchain: blockchain,
71547
+ token: undefined
71548
+ }));
71549
+ setTokens(blockchain.tokens);
71550
+ };
71551
+
71552
+ react.useEffect(function () {
71553
+ if (wallet) {
71554
+ wallet.connectedTo().then(function (name) {
71555
+ var blockchain = Blockchain.findByName(name);
71556
+
71557
+ if (name && name.length && blockchain && blockchain.tokens && blockchain.tokens.length) {
71558
+ startWithBlockchain(name);
71559
+ } else {
71560
+ startWithBlockchain('ethereum');
71561
+ }
71562
+ });
71563
+ } else {
71564
+ startWithBlockchain('ethereum');
71565
+ }
71566
+ }, []);
71567
+ react.useEffect(function () {
71568
+ if (props.selection.blockchain) {
71569
+ setBlockchain(props.selection.blockchain);
71570
+ setTokens(props.selection.blockchain.tokens);
71571
+
71572
+ if (searchElement.current) {
71573
+ searchElement.current.value = '';
71574
+ searchElement.current.focus();
71575
+ }
71576
+ }
71577
+ }, [props.selection, props.selection.blockchain]);
71578
+
71579
+ var onClickChangeBlockchain = function onClickChangeBlockchain() {
71580
+ navigate('SelectBlockchain');
71581
+ };
71582
+
71583
+ var onClickAddToken = function onClickAddToken() {
71584
+ setShowAddToken(true);
71585
+
71586
+ if (searchElement.current) {
71587
+ searchElement.current.value = '';
71588
+ searchElement.current.focus();
71589
+ }
71590
+ };
71591
+
71592
+ var onChangeSearch = function onChangeSearch(event) {
71593
+ if (requestController) {
71594
+ requestController.abort();
71595
+ }
71596
+
71597
+ var newRequestController = new AbortController();
71598
+ setRequestController(newRequestController);
71599
+ var signal = newRequestController.signal;
71600
+ var term = event.target.value;
71601
+
71602
+ if (term.match(/^0x/)) {
71603
+ setTokens([]);
71604
+ var token;
71605
+
71606
+ try {
71607
+ token = new Token({
71608
+ blockchain: blockchain.name,
71609
+ address: term
71610
+ });
71611
+ } catch (_unused) {}
71612
+
71613
+ if (token == undefined) {
71614
+ return;
71615
+ }
71616
+
71617
+ Promise.all([token.name(), token.symbol(), token.decimals()]).then(function (_ref) {
71618
+ var _ref2 = _slicedToArray(_ref, 3),
71619
+ name = _ref2[0],
71620
+ symbol = _ref2[1],
71621
+ decimals = _ref2[2];
71622
+
71623
+ setTokens([{
71624
+ name: name,
71625
+ symbol: symbol,
71626
+ decimals: decimals,
71627
+ address: term,
71628
+ blockchain: blockchain.name
71629
+ }]);
71630
+ });
71631
+ } else if (term && term.length) {
71632
+ setTokens([]);
71633
+ fetch("https://api.depay.fi/v2/tokens/search?blockchain=".concat(blockchain.name, "&term=").concat(term), {
71634
+ signal: signal,
71635
+ headers: {
71636
+ 'X-Api-Key': apiKey
71637
+ }
71638
+ }).then(function (response) {
71639
+ if (response.status == 200) {
71640
+ response.json().then(function (tokens) {
71641
+ setTokens(tokens);
71642
+ });
71643
+ }
71644
+ })["catch"](function () {});
71645
+ } else {
71646
+ setTokens(blockchain.tokens);
71647
+ }
71648
+ };
71649
+
71650
+ var select = function select(token) {
71651
+ if (blockchain.tokens.find(function (majorToken) {
71652
+ return majorToken.address.toLowerCase() == (token.address || token.external_id).toLowerCase();
71653
+ })) {
71654
+ setOpen(false);
71655
+ props.resolve({
71656
+ blockchain: blockchain.name,
71657
+ address: token.address || token.external_id,
71658
+ logo: token.logo || token.image,
71659
+ name: token.name,
71660
+ symbol: token.symbol,
71661
+ decimals: token.decimals
71662
+ });
71663
+ setTimeout(props.unmount, 300);
71664
+ } else {
71665
+ setSelection(Object.assign(props.selection, {
71666
+ token: token
71667
+ }));
71668
+ navigate('ConfirmTokenSelection');
71669
+ }
71670
+ };
71671
+
71672
+ var elements = tokens.map(function (token, index) {
71673
+ return /*#__PURE__*/react.createElement("div", {
71674
+ key: "".concat(index, "-").concat(token.address),
71675
+ className: "Card Row",
71676
+ onClick: function onClick() {
71677
+ return select(token);
71678
+ }
71679
+ }, /*#__PURE__*/react.createElement("div", {
71680
+ className: "CardImage"
71681
+ }, token.logo && /*#__PURE__*/react.createElement("img", {
71682
+ src: token.logo
71683
+ }), token.image && /*#__PURE__*/react.createElement("img", {
71684
+ src: token.image
71685
+ }), !(token.logo || token.image) && /*#__PURE__*/react.createElement(TokenImage, {
71686
+ blockchain: token.blockchain,
71687
+ address: token.external_id || token.address
71688
+ })), /*#__PURE__*/react.createElement("div", {
71689
+ className: "CardBody"
71690
+ }, /*#__PURE__*/react.createElement("div", {
71691
+ className: "CardTokenSymbol",
71692
+ title: token.symbol
71693
+ }, /*#__PURE__*/react.createElement("span", {
71694
+ className: "CardText"
71695
+ }, token.symbol)), /*#__PURE__*/react.createElement("div", {
71696
+ className: "CardTokenName",
71697
+ title: token.name
71698
+ }, /*#__PURE__*/react.createElement("span", {
71699
+ className: "CardText"
71700
+ }, token.name))));
71701
+ });
71702
+
71703
+ if (blockchain == undefined) {
71704
+ return null;
71705
+ }
71706
+
71707
+ return /*#__PURE__*/react.createElement(Dialog, {
71708
+ header: /*#__PURE__*/react.createElement("div", {
71709
+ className: "PaddingTopS PaddingLeftM PaddingRightM TextLeft"
71710
+ }, /*#__PURE__*/react.createElement("div", null, /*#__PURE__*/react.createElement("h1", {
71711
+ className: "LineHeightL FontSizeL"
71712
+ }, "Select Token")), /*#__PURE__*/react.createElement("div", {
71713
+ className: "PaddingTopS PaddingBottomXS"
71714
+ }, /*#__PURE__*/react.createElement("div", {
71715
+ className: "Card small",
71716
+ onClick: onClickChangeBlockchain
71717
+ }, /*#__PURE__*/react.createElement("div", {
71718
+ className: "CardImage small"
71719
+ }, /*#__PURE__*/react.createElement("img", {
71720
+ className: "transparent",
71721
+ src: blockchain.logo
71722
+ })), /*#__PURE__*/react.createElement("div", {
71723
+ className: "CardBody"
71724
+ }, blockchain.label), /*#__PURE__*/react.createElement("div", {
71725
+ className: "CardAction"
71726
+ }, /*#__PURE__*/react.createElement(ChevronRight, null)))), /*#__PURE__*/react.createElement("div", {
71727
+ className: "PaddingTopXS PaddingBottomS"
71728
+ }, /*#__PURE__*/react.createElement("input", {
71729
+ onChange: onChangeSearch,
71730
+ className: "Search",
71731
+ autoFocus: true,
71732
+ placeholder: "Search name or paste address",
71733
+ ref: searchElement
71734
+ }), showAddToken && /*#__PURE__*/react.createElement("div", {
71735
+ className: "PaddingTopXS PaddingRightXS PaddingLeftXS"
71736
+ }, /*#__PURE__*/react.createElement("div", {
71737
+ className: "Tooltip"
71738
+ }, /*#__PURE__*/react.createElement("span", {
71739
+ className: "TooltipArrowUp"
71740
+ }), "Paste or enter token address here!")))),
71741
+ bodyClassName: "ScrollHeight",
71742
+ body: /*#__PURE__*/react.createElement("div", {
71743
+ className: ""
71744
+ }, elements),
71745
+ footer: /*#__PURE__*/react.createElement("div", {
71746
+ className: "PaddingTopS PaddingRightM PaddingLeftM PaddingBottomS"
71747
+ }, /*#__PURE__*/react.createElement("div", {
71748
+ className: "PaddingTopXS PaddingBottomXS"
71749
+ }, /*#__PURE__*/react.createElement("div", {
71750
+ className: "Link",
71751
+ onClick: onClickAddToken
71752
+ }, "Token missing? Add it.")))
71753
+ });
71754
+ });
71755
+
71756
+ var SelectStack = (function (props) {
71757
+ var _useContext = react.useContext(ConfigurationContext),
71758
+ what = _useContext.what;
71759
+
71760
+ var _useContext2 = react.useContext(ClosableContext),
71761
+ open = _useContext2.open,
71762
+ close = _useContext2.close;
71763
+
71764
+ var _useContext3 = react.useContext(SelectionContext),
71765
+ selection = _useContext3.selection;
71766
+
71767
+ var start;
71768
+
71769
+ switch (what) {
71770
+ default:
71771
+ start = 'SelectToken';
71772
+ }
71773
+
71774
+ return /*#__PURE__*/react.createElement(ReactDialogStack, {
71775
+ open: open,
71776
+ close: close,
71777
+ start: start,
71778
+ container: props.container,
71779
+ document: props.document,
71780
+ dialogs: {
71781
+ SelectToken: /*#__PURE__*/react.createElement(SelectTokenDialog, {
71782
+ selection: selection,
71783
+ resolve: props.resolve,
71784
+ unmount: props.unmount
71785
+ }),
71786
+ SelectBlockchain: /*#__PURE__*/react.createElement(SelectBlockchainDialog, {
71787
+ selection: selection,
71788
+ resolve: props.resolve
71789
+ }),
71790
+ ConfirmTokenSelection: /*#__PURE__*/react.createElement(ConfirmTokenSelectionDialog, {
71791
+ selection: selection,
71792
+ resolve: props.resolve,
71793
+ unmount: props.unmount
71794
+ })
71795
+ }
71796
+ });
71797
+ });
71798
+
71799
+ var Select = function Select(options) {
71800
+ var style, error, document, what;
71801
+
71802
+ if (_typeof(options) == 'object') {
71803
+ style = options.style;
71804
+ error = options.error;
71805
+ document = options.document;
71806
+ what = options.what;
71807
+ }
71808
+
71809
+ var startupError;
71810
+
71811
+ if (what == undefined) {
71812
+ startupError = '"what" needs to be configured!';
71813
+ } else if (['token'].indexOf(what) < 0) {
71814
+ startupError = "Unknown \"what\" configured: ".concat(what, "!");
71815
+ }
71816
+
71817
+ return new Promise( /*#__PURE__*/function () {
71818
+ var _ref = _asyncToGenerator( /*#__PURE__*/regenerator.mark(function _callee(resolve, reject) {
71819
+ return regenerator.wrap(function _callee$(_context) {
71820
+ while (1) {
71821
+ switch (_context.prev = _context.next) {
71822
+ case 0:
71823
+ mount({
71824
+ style: style,
71825
+ document: ensureDocument(document)
71826
+ }, function (unmount) {
71827
+ var userClosedDialog = function userClosedDialog() {
71828
+ reject('USER_CLOSED_DIALOG');
71829
+ unmount();
71830
+ };
71831
+
71832
+ return function (container) {
71833
+ return /*#__PURE__*/react.createElement(ErrorProvider, {
71834
+ error: startupError,
71835
+ errorCallback: error,
71836
+ container: container,
71837
+ unmount: unmount
71838
+ }, /*#__PURE__*/react.createElement(ConfigurationProvider, {
71839
+ configuration: {
71840
+ what: what
71841
+ }
71842
+ }, /*#__PURE__*/react.createElement(UpdatableProvider, null, /*#__PURE__*/react.createElement(ClosableProvider, {
71843
+ unmount: userClosedDialog
71844
+ }, /*#__PURE__*/react.createElement(SelectionProvider, null, /*#__PURE__*/react.createElement(SelectStack, {
71845
+ document: document,
71846
+ container: container,
71847
+ unmount: unmount,
71848
+ resolve: resolve
71849
+ })), /*#__PURE__*/react.createElement(PoweredBy, null)))));
71850
+ };
71851
+ });
71852
+
71853
+ case 1:
71854
+ case "end":
71855
+ return _context.stop();
71856
+ }
71857
+ }
71858
+ }, _callee);
71859
+ }));
71860
+
71861
+ return function (_x, _x2) {
71862
+ return _ref.apply(this, arguments);
71863
+ };
71864
+ }());
71865
+ };
71866
+
71257
71867
  var DePayWidgets = {
71258
71868
  Connect: Connect,
71259
71869
  Donation: Donation,
71260
71870
  Login: Login,
71261
71871
  Payment: Payment,
71262
71872
  Sale: Sale,
71873
+ Select: Select,
71263
71874
  provider: provider
71264
71875
  };
71265
71876