@depay/widgets 6.3.0 → 6.4.0

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.
@@ -1059,7 +1059,8 @@
1059
1059
  closable: closable,
1060
1060
  setClosable: setClosable,
1061
1061
  close: close,
1062
- open: open
1062
+ open: open,
1063
+ setOpen: setOpen
1063
1064
  }
1064
1065
  }, props.children);
1065
1066
  });
@@ -1959,23 +1960,21 @@
1959
1960
  }, /*#__PURE__*/react.createElement("div", {
1960
1961
  className: ["DialogHeader", props.stacked ? 'TextCenter' : ''].join(' ')
1961
1962
  }, props.stacked && /*#__PURE__*/react.createElement("div", {
1962
- className: "DialogHeaderAction PaddingTopS PaddingLeftS PaddingRightS"
1963
+ className: "DialogHeaderActionLeft PaddingTopS PaddingLeftS PaddingRightS"
1963
1964
  }, /*#__PURE__*/react.createElement("button", {
1964
1965
  onClick: function onClick() {
1965
1966
  return navigate('back');
1966
1967
  },
1967
1968
  className: "ButtonCircular",
1968
1969
  title: "Go back"
1969
- }, /*#__PURE__*/react.createElement(ChevronLeft, null))), /*#__PURE__*/react.createElement("div", {
1970
- className: "DialogHeaderTitle"
1971
- }, props.header), /*#__PURE__*/react.createElement("div", {
1972
- className: "DialogHeaderAction PaddingTopS PaddingLeftS PaddingRightS"
1970
+ }, /*#__PURE__*/react.createElement(ChevronLeft, null))), props.header, /*#__PURE__*/react.createElement("div", {
1971
+ className: "DialogHeaderActionRight PaddingTopS PaddingLeftS PaddingRightS"
1973
1972
  }, closable && /*#__PURE__*/react.createElement("button", {
1974
1973
  onClick: close,
1975
1974
  className: "ButtonCircular",
1976
1975
  title: "Close dialog"
1977
1976
  }, /*#__PURE__*/react.createElement(CloseIcon, null)))), /*#__PURE__*/react.createElement("div", {
1978
- className: "DialogBody"
1977
+ className: ["DialogBody", props.bodyClassName].join(' ')
1979
1978
  }, props.body), /*#__PURE__*/react.createElement("div", {
1980
1979
  className: "DialogFooter"
1981
1980
  }, props.footer));
@@ -2308,10 +2307,23 @@
2308
2307
  decimals: 18
2309
2308
  },
2310
2309
  explorer: 'https://etherscan.io',
2311
- explorerUrlFor: ({ transaction })=>{
2310
+ explorerUrlFor: ({ transaction, token })=>{
2312
2311
  if(transaction) { return `https://etherscan.io/tx/${transaction.id}` }
2312
+ if(token) { return `https://etherscan.io/token/${token}` }
2313
2313
  },
2314
- rpc: ['https://mainnet.infura.io/v3/9aa3d95b3bc4', '40fa88ea12eaa4456161'].join('')
2314
+ rpc: ['https://mainnet.infura.io/v3/9aa3d95b3bc4', '40fa88ea12eaa4456161'].join(''),
2315
+ tokens: [ // only major tokens
2316
+ {"address": "0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE", "symbol": "ETH", "name": "Ether", "decimals": 18, "logo": ""},
2317
+ {"address": "0xA0b86991c6218b36c1d19D4a2e9Eb0cE3606eB48", "symbol": "USDC", "name": "USD Coin", "decimals": 6, "logo": "https://raw.githubusercontent.com/trustwallet/assets/master/blockchains/ethereum/assets/0xA0b86991c6218b36c1d19D4a2e9Eb0cE3606eB48/logo.png"},
2318
+ {"address": "0x2260FAC5E5542a773Aa44fBCfeDf7C193bc2C599", "symbol": "WBTC", "name": "Wrapped BTC", "decimals": 8, "logo": "https://raw.githubusercontent.com/trustwallet/assets/master/blockchains/ethereum/assets/0x2260FAC5E5542a773Aa44fBCfeDf7C193bc2C599/logo.png"},
2319
+ {"address": "0xdAC17F958D2ee523a2206206994597C13D831ec7", "symbol": "USDT", "name": "Tether USD", "decimals": 6, "logo": "https://raw.githubusercontent.com/trustwallet/assets/master/blockchains/ethereum/assets/0xdAC17F958D2ee523a2206206994597C13D831ec7/logo.png"},
2320
+ {"address": "0x6B175474E89094C44Da98b954EedeAC495271d0F", "symbol": "DAI", "name": "Dai Stablecoin", "decimals": 18, "logo": "https://raw.githubusercontent.com/trustwallet/assets/master/blockchains/ethereum/assets/0x6B175474E89094C44Da98b954EedeAC495271d0F/logo.png"},
2321
+ {"address": "0x853d955aCEf822Db058eb8505911ED77F175b99e", "symbol": "FRAX", "name": "Frax", "decimals": 18, "logo": "https://raw.githubusercontent.com/trustwallet/assets/master/blockchains/ethereum/assets/0x853d955aCEf822Db058eb8505911ED77F175b99e/logo.png"},
2322
+ {"address": "0x4Fabb145d64652a948d72533023f6E7A623C7C53", "symbol": "BUSD", "name": "Binance USD", "decimals": 18, "logo": "https://raw.githubusercontent.com/trustwallet/assets/master/blockchains/ethereum/assets/0x4Fabb145d64652a948d72533023f6E7A623C7C53/logo.png"},
2323
+ {"address": "0x8E870D67F660D95d5be530380D0eC0bd388289E1", "symbol": "USDP", "name": "Pax Dollar", "decimals": 18, "logo": "https://raw.githubusercontent.com/trustwallet/assets/master/blockchains/ethereum/assets/0x8E870D67F660D95d5be530380D0eC0bd388289E1/logo.png"},
2324
+ {"address": "0x1f9840a85d5aF5bf1D1762F925BDADdC4201F984", "symbol": "UNI", "name": "Uniswap", "decimals": 18, "logo": "https://raw.githubusercontent.com/trustwallet/assets/master/blockchains/ethereum/assets/0x1f9840a85d5aF5bf1D1762F925BDADdC4201F984/logo.png"},
2325
+ {"address": "0x956F47F50A910163D8BF957Cf5846D573E7f87CA", "symbol": "FEI", "name": "Fei USD", "decimals": 18, "logo": "https://raw.githubusercontent.com/trustwallet/assets/master/blockchains/ethereum/assets/0x956F47F50A910163D8BF957Cf5846D573E7f87CA/logo.png"}
2326
+ ]
2315
2327
  };
2316
2328
 
2317
2329
  var bsc = {
@@ -2328,10 +2340,20 @@
2328
2340
  decimals: 18
2329
2341
  },
2330
2342
  explorer: 'https://bscscan.com',
2331
- explorerUrlFor: ({ transaction })=>{
2343
+ explorerUrlFor: ({ transaction, token })=>{
2332
2344
  if(transaction) { return `https://bscscan.com/tx/${transaction.id}` }
2345
+ if(token) { return `https://bscscan.com/token/${token}` }
2333
2346
  },
2334
- rpc: 'https://bsc-dataseed1.binance.org'
2347
+ rpc: 'https://bsc-dataseed1.binance.org',
2348
+ tokens: [ // only major tokens
2349
+ {"address": "0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE", "symbol": "BNB", "name": "Binance Coin", "decimals": 18, "logo": "https://assets.trustwalletapp.com/blockchains/smartchain/assets/0xbb4CdB9CBd36B01bD1cBaEBF2De08d9173bc095c/logo.png"},
2350
+ {"address": "0xe9e7CEA3DedcA5984780Bafc599bD69ADd087D56", "symbol": "BUSD", "name": "BUSD Token", "decimals": 18, "logo": "https://assets.trustwalletapp.com/blockchains/smartchain/assets/0xe9e7CEA3DedcA5984780Bafc599bD69ADd087D56/logo.png"},
2351
+ {"address": "0x55d398326f99059fF775485246999027B3197955", "symbol": "USDT", "name": "Binance-Peg BSC-USD", "decimals": 18, "logo": "https://assets.trustwalletapp.com/blockchains/smartchain/assets/0x55d398326f99059fF775485246999027B3197955/logo.png"},
2352
+ {"address": "0x0E09FaBB73Bd3Ade0a17ECC321fD13a19e81cE82", "symbol": "Cake", "name": "PancakeSwap Token", "decimals": 18, "logo": "https://assets.trustwalletapp.com/blockchains/smartchain/assets/0x0E09FaBB73Bd3Ade0a17ECC321fD13a19e81cE82/logo.png"},
2353
+ {"address": "0x8AC76a51cc950d9822D68b83fE1Ad97B32Cd580d", "symbol": "USDC", "name": "USD Coin", "decimals": 18, "logo": "https://assets.trustwalletapp.com/blockchains/smartchain/assets/0x8AC76a51cc950d9822D68b83fE1Ad97B32Cd580d/logo.png"},
2354
+ {"address": "0x2170Ed0880ac9A755fd29B2688956BD959F933F8", "symbol": "ETH", "name": "Ethereum Token", "decimals": 18, "logo": "https://assets.trustwalletapp.com/blockchains/smartchain/assets/0x2170Ed0880ac9A755fd29B2688956BD959F933F8/logo.png"},
2355
+ {"address": "0x7130d2A12B9BCbFAe4f2634d864A1Ee1Ce3Ead9c", "symbol": "BTCB", "name": "BTCB Token", "decimals": 18, "logo": "https://assets.trustwalletapp.com/blockchains/smartchain/assets/0x7130d2A12B9BCbFAe4f2634d864A1Ee1Ce3Ead9c/logo.png"}
2356
+ ]
2335
2357
  };
2336
2358
 
2337
2359
  var polygon = {
@@ -2348,8 +2370,9 @@
2348
2370
  decimals: 18
2349
2371
  },
2350
2372
  explorer: 'https://polygonscan.com',
2351
- explorerUrlFor: ({ transaction })=>{
2373
+ explorerUrlFor: ({ transaction, token })=>{
2352
2374
  if(transaction) { return `https://polygonscan.com/tx/${transaction.id}` }
2375
+ if(token) { return `https://polygonscan.com/token/${token}` }
2353
2376
  },
2354
2377
  rpc: 'https://rpc-mainnet.matic.network'
2355
2378
  };
@@ -49095,6 +49118,7 @@
49095
49118
  }, /*#__PURE__*/react.createElement("div", {
49096
49119
  className: "CardImage"
49097
49120
  }, /*#__PURE__*/react.createElement("img", {
49121
+ className: "transparent",
49098
49122
  src: wallet.info.logo
49099
49123
  })), /*#__PURE__*/react.createElement("div", {
49100
49124
  className: "CardBody"
@@ -49111,7 +49135,7 @@
49111
49135
  className: "LineHeightL FontSizeL"
49112
49136
  }, "Select a wallet")),
49113
49137
  body: /*#__PURE__*/react.createElement("div", {
49114
- className: "PaddingTopS PaddingBottomXS PaddingLeftS PaddingRightS"
49138
+ className: "PaddingBottomS PaddingLeftS PaddingRightS"
49115
49139
  }, walletCards),
49116
49140
  footer: /*#__PURE__*/react.createElement("div", {
49117
49141
  className: "PaddingBottomS"
@@ -49368,7 +49392,7 @@
49368
49392
  }(react.Component);
49369
49393
 
49370
49394
  var ErrorProvider = (function (props) {
49371
- var _useState = react.useState(),
49395
+ var _useState = react.useState(props.error),
49372
49396
  _useState2 = _slicedToArray(_useState, 2),
49373
49397
  error = _useState2[0],
49374
49398
  setError = _useState2[1];
@@ -49381,8 +49405,8 @@
49381
49405
  var setErrorFromChildren = function setErrorFromChildren(error) {
49382
49406
  setError(error);
49383
49407
 
49384
- if (props.error) {
49385
- props.error(error);
49408
+ if (props.errorCallback) {
49409
+ props.errorCallback(error);
49386
49410
  }
49387
49411
  };
49388
49412
 
@@ -49441,6 +49465,10 @@
49441
49465
  }
49442
49466
  });
49443
49467
 
49468
+ var AlertStyle = (function (style) {
49469
+ 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 ";
49470
+ });
49471
+
49444
49472
  var BlockchainLogoStyle = (function (style) {
49445
49473
  return "\n\n .BlockchainLogo {\n border-radius: 999px;\n }\n\n .BlockchainLogo.small {\n height: 18px;\n width: 18px;\n }\n ";
49446
49474
  });
@@ -49454,11 +49482,11 @@
49454
49482
  });
49455
49483
 
49456
49484
  var CardStyle = (function (style) {
49457
- 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 ");
49485
+ 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 ");
49458
49486
  });
49459
49487
 
49460
49488
  var DialogStyle = (function (style) {
49461
- 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 ";
49489
+ 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 ";
49462
49490
  });
49463
49491
 
49464
49492
  var FontStyle = (function (style) {
@@ -49489,6 +49517,10 @@
49489
49517
  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 ");
49490
49518
  });
49491
49519
 
49520
+ var LinkStyle = (function (style) {
49521
+ 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 ");
49522
+ });
49523
+
49492
49524
  var LoadingTextStyle = (function (style) {
49493
49525
  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 ");
49494
49526
  });
@@ -49513,10 +49545,18 @@
49513
49545
  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 ";
49514
49546
  });
49515
49547
 
49548
+ var SearchStyle = (function (style) {
49549
+ 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 ");
49550
+ });
49551
+
49516
49552
  var SkeletonStyle = (function () {
49517
49553
  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 ";
49518
49554
  });
49519
49555
 
49556
+ var TableStyle = (function (style) {
49557
+ 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 ";
49558
+ });
49559
+
49520
49560
  var TextButtonStyle = (function (style) {
49521
49561
  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 ");
49522
49562
  });
@@ -49526,7 +49566,15 @@
49526
49566
  });
49527
49567
 
49528
49568
  var TokenAmountStyle = (function () {
49529
- 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 ";
49569
+ 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 ";
49570
+ });
49571
+
49572
+ var TokenImageStyle = (function (style) {
49573
+ 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 ";
49574
+ });
49575
+
49576
+ var TooltipStyle = (function (style) {
49577
+ 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 ");
49530
49578
  });
49531
49579
 
49532
49580
  var styleRenderer = (function (style) {
@@ -49539,7 +49587,7 @@
49539
49587
  },
49540
49588
  fontFamily: '-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol"'
49541
49589
  }, style);
49542
- 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('');
49590
+ 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('');
49543
49591
  });
49544
49592
 
49545
49593
  const insideContainerClass = 'ReactShadowDOMInsideContainer';
@@ -49730,7 +49778,7 @@
49730
49778
 
49731
49779
  return function (container) {
49732
49780
  return /*#__PURE__*/react.createElement(ErrorProvider, {
49733
- error: error,
49781
+ errorCallback: error,
49734
49782
  container: container,
49735
49783
  unmount: unmount
49736
49784
  }, /*#__PURE__*/react.createElement(UpdatableProvider, null, /*#__PURE__*/react.createElement(ClosableProvider, {
@@ -69607,7 +69655,7 @@
69607
69655
  className: "LineHeightL FontSizeL"
69608
69656
  }, "Donation")),
69609
69657
  body: /*#__PURE__*/react.createElement("div", {
69610
- className: "PaddingTopS PaddingLeftM PaddingRightM PaddingBottomXS"
69658
+ className: "PaddingLeftM PaddingRightM PaddingBottomXS"
69611
69659
  }, /*#__PURE__*/react.createElement("div", {
69612
69660
  className: "Card Skeleton"
69613
69661
  }, /*#__PURE__*/react.createElement("div", {
@@ -69916,7 +69964,7 @@
69916
69964
  className: "LineHeightL FontSizeL"
69917
69965
  }, "Donation")),
69918
69966
  body: /*#__PURE__*/react.createElement("div", {
69919
- className: "PaddingTopS PaddingLeftM PaddingRightM PaddingBottomXS"
69967
+ className: "PaddingLeftM PaddingRightM PaddingBottomXS"
69920
69968
  }, /*#__PURE__*/react.createElement("div", {
69921
69969
  className: ["Card", paymentState == 'initialized' ? '' : 'disabled'].join(' '),
69922
69970
  title: paymentState == 'initialized' ? "Change amount" : undefined,
@@ -70325,7 +70373,7 @@
70325
70373
  }, function (unmount) {
70326
70374
  return function (container) {
70327
70375
  return /*#__PURE__*/react.createElement(ErrorProvider, {
70328
- error: error,
70376
+ errorCallback: error,
70329
70377
  container: container,
70330
70378
  unmount: unmount
70331
70379
  }, /*#__PURE__*/react.createElement(ConfigurationProvider, {
@@ -70516,7 +70564,7 @@
70516
70564
 
70517
70565
  return function (container) {
70518
70566
  return /*#__PURE__*/react.createElement(ErrorProvider, {
70519
- error: error,
70567
+ errorCallback: error,
70520
70568
  container: container,
70521
70569
  unmount: unmount
70522
70570
  }, /*#__PURE__*/react.createElement(ConfigurationProvider, {
@@ -70598,7 +70646,7 @@
70598
70646
  className: "LineHeightL FontSizeL"
70599
70647
  }, "Payment")),
70600
70648
  body: /*#__PURE__*/react.createElement("div", {
70601
- className: "PaddingTopS PaddingLeftM PaddingRightM PaddingBottomXS"
70649
+ className: "PaddingLeftM PaddingRightM PaddingBottomXS"
70602
70650
  }, amountsMissing && /*#__PURE__*/react.createElement("div", {
70603
70651
  className: "Card Skeleton"
70604
70652
  }, /*#__PURE__*/react.createElement("div", {
@@ -70649,7 +70697,7 @@
70649
70697
  className: "LineHeightL FontSizeL"
70650
70698
  }, "Payment")),
70651
70699
  body: /*#__PURE__*/react.createElement("div", {
70652
- className: "PaddingTopS PaddingLeftM PaddingRightM PaddingBottomXS"
70700
+ className: "PaddingLeftM PaddingRightM PaddingBottomXS"
70653
70701
  }, amountsMissing && /*#__PURE__*/react.createElement("div", {
70654
70702
  className: ["Card", paymentState == 'initialized' ? '' : 'disabled'].join(' '),
70655
70703
  title: paymentState == 'initialized' ? "Change amount" : undefined,
@@ -70796,7 +70844,7 @@
70796
70844
  }, function (unmount) {
70797
70845
  return function (container) {
70798
70846
  return /*#__PURE__*/react.createElement(ErrorProvider, {
70799
- error: error,
70847
+ errorCallback: error,
70800
70848
  container: container,
70801
70849
  unmount: unmount
70802
70850
  }, /*#__PURE__*/react.createElement(ConfigurationProvider, {
@@ -70950,7 +70998,7 @@
70950
70998
  className: "LineHeightL FontSizeL"
70951
70999
  }, "Purchase")),
70952
71000
  body: /*#__PURE__*/react.createElement("div", {
70953
- className: "PaddingTopS PaddingLeftM PaddingRightM PaddingBottomXS"
71001
+ className: "PaddingLeftM PaddingRightM PaddingBottomXS"
70954
71002
  }, /*#__PURE__*/react.createElement("div", {
70955
71003
  className: "Card Skeleton",
70956
71004
  style: {
@@ -71034,7 +71082,7 @@
71034
71082
  className: "LineHeightL FontSizeL"
71035
71083
  }, "Purchase")),
71036
71084
  body: /*#__PURE__*/react.createElement("div", {
71037
- className: "PaddingTopS PaddingLeftM PaddingRightM PaddingBottomXS"
71085
+ className: "PaddingLeftM PaddingRightM PaddingBottomXS"
71038
71086
  }, /*#__PURE__*/react.createElement("div", {
71039
71087
  className: ["Card", paymentState == 'initialized' ? '' : 'disabled'].join(' '),
71040
71088
  title: paymentState == 'initialized' ? "Change amount" : undefined,
@@ -71200,7 +71248,7 @@
71200
71248
  }, function (unmount) {
71201
71249
  return function (container) {
71202
71250
  return /*#__PURE__*/react.createElement(ErrorProvider, {
71203
- error: error,
71251
+ errorCallback: error,
71204
71252
  container: container,
71205
71253
  unmount: unmount
71206
71254
  }, /*#__PURE__*/react.createElement(ConfigurationProvider, {
@@ -71260,12 +71308,552 @@
71260
71308
  };
71261
71309
  }();
71262
71310
 
71311
+ var SelectionContext = /*#__PURE__*/react.createContext();
71312
+
71313
+ var SelectionProvider = (function (props) {
71314
+ var _useState = react.useState({}),
71315
+ _useState2 = _slicedToArray(_useState, 2),
71316
+ selection = _useState2[0],
71317
+ setSelection = _useState2[1];
71318
+
71319
+ return /*#__PURE__*/react.createElement(SelectionContext.Provider, {
71320
+ value: {
71321
+ selection: selection,
71322
+ setSelection: setSelection
71323
+ }
71324
+ }, props.children);
71325
+ });
71326
+
71327
+ var msToTime = (function (ms) {
71328
+ var year, month, day, hour, minute, second;
71329
+ second = Math.floor(ms / 1000);
71330
+ minute = Math.floor(second / 60);
71331
+ second = second % 60;
71332
+ hour = Math.floor(minute / 60);
71333
+ minute = minute % 60;
71334
+ day = Math.floor(hour / 24);
71335
+ hour = hour % 24;
71336
+ month = Math.floor(day / 30);
71337
+ day = day % 30;
71338
+ year = Math.floor(month / 12);
71339
+ month = month % 12;
71340
+ return {
71341
+ year: year,
71342
+ month: month,
71343
+ day: day,
71344
+ hour: hour,
71345
+ minute: minute,
71346
+ second: second
71347
+ };
71348
+ });
71349
+
71350
+ var ConfirmTokenSelectionDialog = (function (props) {
71351
+ var _useContext = react.useContext(SelectionContext),
71352
+ selection = _useContext.selection;
71353
+
71354
+ var _useContext2 = react.useContext(ClosableContext),
71355
+ setOpen = _useContext2.setOpen;
71356
+
71357
+ var token = selection.token;
71358
+ var address = token.address || token.external_id;
71359
+ var logo = token.logo || token.image;
71360
+ var blockchain = Blockchain.findByName(token.blockchain);
71361
+ var age = token.first_transfer ? msToTime(new Date() - new Date(token.first_transfer)) : undefined;
71362
+
71363
+ if (age) {
71364
+ 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) {
71365
+ return n;
71366
+ }).join(' ');
71367
+ }
71368
+
71369
+ var holders = token.unique_senders ? token.unique_senders : undefined;
71370
+
71371
+ if (holders) {
71372
+ if (holders > 1000000) {
71373
+ holders = "Millions";
71374
+ } else if (holders > 100000) {
71375
+ holders = "Hundreds of Thousands";
71376
+ } else if (holders > 2000) {
71377
+ holders = "Thousands";
71378
+ } else if (holders > 100) {
71379
+ holders = "Hundreds";
71380
+ } else {
71381
+ holders = "Only a Few!!!";
71382
+ }
71383
+ }
71384
+
71385
+ var onClickConfirm = function onClickConfirm() {
71386
+ setOpen(false);
71387
+ props.resolve({
71388
+ blockchain: token.blockchain,
71389
+ address: token.external_id,
71390
+ symbol: token.symbol,
71391
+ name: token.name,
71392
+ decimals: token.decimals,
71393
+ logo: token.image
71394
+ });
71395
+ setTimeout(props.unmount, 300);
71396
+ };
71397
+
71398
+ return /*#__PURE__*/react.createElement(Dialog, {
71399
+ header: /*#__PURE__*/react.createElement("div", {
71400
+ className: "PaddingTopS PaddingLeftM PaddingRightM TextLeft"
71401
+ }, /*#__PURE__*/react.createElement("div", null, /*#__PURE__*/react.createElement("h1", {
71402
+ className: "LineHeightL FontSizeL"
71403
+ }, "Confirm Selection"))),
71404
+ stacked: true,
71405
+ body: /*#__PURE__*/react.createElement("div", {
71406
+ className: "PaddingTopS PaddingLeftM PaddingRightM"
71407
+ }, /*#__PURE__*/react.createElement("div", {
71408
+ className: "TokenImage medium"
71409
+ }, logo && /*#__PURE__*/react.createElement("img", {
71410
+ src: logo
71411
+ }), !logo && /*#__PURE__*/react.createElement(TokenImage, {
71412
+ blockchain: token.blockchain,
71413
+ address: address
71414
+ })), /*#__PURE__*/react.createElement("div", {
71415
+ className: "PaddingTopS"
71416
+ }, /*#__PURE__*/react.createElement("div", {
71417
+ className: "Alert"
71418
+ }, /*#__PURE__*/react.createElement("strong", null, "Please review this information"))), /*#__PURE__*/react.createElement("div", {
71419
+ className: "PaddingTopXS"
71420
+ }, /*#__PURE__*/react.createElement("table", {
71421
+ className: "Table"
71422
+ }, /*#__PURE__*/react.createElement("tbody", null, /*#__PURE__*/react.createElement("tr", {
71423
+ className: "small"
71424
+ }, /*#__PURE__*/react.createElement("td", {
71425
+ colSpan: "2"
71426
+ }, /*#__PURE__*/react.createElement("div", null, /*#__PURE__*/react.createElement("a", {
71427
+ className: "Link",
71428
+ href: blockchain.explorerUrlFor({
71429
+ token: address
71430
+ }),
71431
+ target: "_blank",
71432
+ rel: "noopener noreferrer"
71433
+ }, address)))), /*#__PURE__*/react.createElement("tr", null, /*#__PURE__*/react.createElement("td", null, /*#__PURE__*/react.createElement("div", {
71434
+ className: "TableSubTitle"
71435
+ }, "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", {
71436
+ className: "TableSubTitle"
71437
+ }, "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", {
71438
+ className: "TableSubTitle"
71439
+ }, "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", {
71440
+ className: "TableSubTitle"
71441
+ }, "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", {
71442
+ className: "TableSubTitle"
71443
+ }, "Holders")), /*#__PURE__*/react.createElement("td", null, /*#__PURE__*/react.createElement("div", null, holders))))))),
71444
+ footer: /*#__PURE__*/react.createElement("div", {
71445
+ className: "PaddingTopS PaddingRightM PaddingLeftM PaddingBottomS"
71446
+ }, /*#__PURE__*/react.createElement("button", {
71447
+ className: "ButtonPrimary",
71448
+ onClick: onClickConfirm
71449
+ }, "Confirm"))
71450
+ });
71451
+ });
71452
+
71453
+ var SelectBlockchainDialog = (function (props) {
71454
+ var _useContext = react.useContext(SelectionContext),
71455
+ setSelection = _useContext.setSelection;
71456
+
71457
+ var _useContext2 = react.useContext(NavigateStackContext),
71458
+ navigate = _useContext2.navigate;
71459
+
71460
+ var stacked = Object.keys(props.selection).length > 1;
71461
+ var blockchains = [Blockchain.findByName('ethereum'), Blockchain.findByName('bsc')];
71462
+
71463
+ var selectBlockchain = function selectBlockchain(blockchain) {
71464
+ setSelection(Object.assign(props.selection, {
71465
+ blockchain: blockchain
71466
+ }));
71467
+
71468
+ if (stacked) {
71469
+ navigate('back');
71470
+ } else {
71471
+ props.resolve(blockchain);
71472
+ }
71473
+ };
71474
+
71475
+ var elements = blockchains.map(function (blockchain, index) {
71476
+ return /*#__PURE__*/react.createElement("div", {
71477
+ key: index,
71478
+ className: "Card Row",
71479
+ onClick: function onClick() {
71480
+ return selectBlockchain(blockchain);
71481
+ }
71482
+ }, /*#__PURE__*/react.createElement("div", {
71483
+ className: "CardImage"
71484
+ }, /*#__PURE__*/react.createElement("img", {
71485
+ className: "transparent",
71486
+ src: blockchain.logo
71487
+ })), /*#__PURE__*/react.createElement("div", {
71488
+ className: "CardBody"
71489
+ }, /*#__PURE__*/react.createElement("span", {
71490
+ className: "CardText"
71491
+ }, blockchain.label)));
71492
+ });
71493
+ return /*#__PURE__*/react.createElement(Dialog, {
71494
+ header: /*#__PURE__*/react.createElement("div", {
71495
+ className: "PaddingTopS PaddingLeftM PaddingRightM TextLeft"
71496
+ }, /*#__PURE__*/react.createElement("div", null, /*#__PURE__*/react.createElement("h1", {
71497
+ className: "LineHeightL FontSizeL"
71498
+ }, "Select Blockchain"))),
71499
+ stacked: stacked,
71500
+ bodyClassName: "ScrollHeight",
71501
+ body: /*#__PURE__*/react.createElement("div", {
71502
+ className: "PaddingTopS"
71503
+ }, elements),
71504
+ footer: /*#__PURE__*/react.createElement("div", {
71505
+ className: "PaddingTopS PaddingRightM PaddingLeftM PaddingBottomS"
71506
+ })
71507
+ });
71508
+ });
71509
+
71510
+ var SelectTokenDialog = (function (props) {
71511
+ var _useContext = react.useContext(NavigateStackContext),
71512
+ navigate = _useContext.navigate;
71513
+
71514
+ var _useContext2 = react.useContext(ClosableContext),
71515
+ setOpen = _useContext2.setOpen;
71516
+
71517
+ var _useContext3 = react.useContext(SelectionContext),
71518
+ setSelection = _useContext3.setSelection;
71519
+
71520
+ var _useState = react.useState(Blockchain.findByName('ethereum')),
71521
+ _useState2 = _slicedToArray(_useState, 2),
71522
+ blockchain = _useState2[0],
71523
+ setBlockchain = _useState2[1];
71524
+
71525
+ var _useState3 = react.useState(),
71526
+ _useState4 = _slicedToArray(_useState3, 2),
71527
+ requestController = _useState4[0],
71528
+ setRequestController = _useState4[1];
71529
+
71530
+ var _useState5 = react.useState(false),
71531
+ _useState6 = _slicedToArray(_useState5, 2),
71532
+ showAddToken = _useState6[0],
71533
+ setShowAddToken = _useState6[1];
71534
+
71535
+ var _useState7 = react.useState([]),
71536
+ _useState8 = _slicedToArray(_useState7, 2),
71537
+ tokens = _useState8[0],
71538
+ setTokens = _useState8[1];
71539
+
71540
+ var _useState9 = react.useState(),
71541
+ _useState10 = _slicedToArray(_useState9, 2);
71542
+ _useState10[0];
71543
+ _useState10[1];
71544
+
71545
+ var searchElement = react.useRef();
71546
+ react.useEffect(function () {
71547
+ setSelection(Object.assign(props.selection, {
71548
+ blockchain: blockchain,
71549
+ token: undefined
71550
+ }));
71551
+ }, []);
71552
+ react.useEffect(function () {
71553
+ setBlockchain(props.selection.blockchain);
71554
+ setTokens(props.selection.blockchain.tokens);
71555
+
71556
+ if (searchElement.current) {
71557
+ searchElement.current.value = '';
71558
+ searchElement.current.focus();
71559
+ }
71560
+ }, [props.selection.blockchain]);
71561
+
71562
+ var onClickChangeBlockchain = function onClickChangeBlockchain() {
71563
+ navigate('SelectBlockchain');
71564
+ };
71565
+
71566
+ var onClickAddToken = function onClickAddToken() {
71567
+ setShowAddToken(true);
71568
+
71569
+ if (searchElement.current) {
71570
+ searchElement.current.value = '';
71571
+ searchElement.current.focus();
71572
+ }
71573
+ };
71574
+
71575
+ var onChangeSearch = function onChangeSearch(event) {
71576
+ if (requestController) {
71577
+ requestController.abort();
71578
+ }
71579
+
71580
+ var newRequestController = new AbortController();
71581
+ setRequestController(newRequestController);
71582
+ var signal = newRequestController.signal;
71583
+ var term = event.target.value;
71584
+
71585
+ if (term.match(/^0x/)) {
71586
+ setTokens([]);
71587
+ var token;
71588
+
71589
+ try {
71590
+ token = new Token({
71591
+ blockchain: blockchain.name,
71592
+ address: term
71593
+ });
71594
+ } catch (_unused) {}
71595
+
71596
+ if (token == undefined) {
71597
+ return;
71598
+ }
71599
+
71600
+ Promise.all([token.name(), token.symbol(), token.decimals()]).then(function (_ref) {
71601
+ var _ref2 = _slicedToArray(_ref, 3),
71602
+ name = _ref2[0],
71603
+ symbol = _ref2[1],
71604
+ decimals = _ref2[2];
71605
+
71606
+ setTokens([{
71607
+ name: name,
71608
+ symbol: symbol,
71609
+ decimals: decimals,
71610
+ address: term,
71611
+ blockchain: blockchain.name
71612
+ }]);
71613
+ });
71614
+ } else if (term && term.length) {
71615
+ setTokens([]);
71616
+ fetch("https://api.depay.fi/v2/tokens/search?blockchain=".concat(blockchain.name, "&term=").concat(term), {
71617
+ signal: signal,
71618
+ headers: {
71619
+ 'X-Api-Key': apiKey
71620
+ }
71621
+ }).then(function (response) {
71622
+ if (response.status == 200) {
71623
+ response.json().then(function (tokens) {
71624
+ setTokens(tokens);
71625
+ });
71626
+ }
71627
+ })["catch"](function () {});
71628
+ } else {
71629
+ setTokens(props.selection.blockchain.tokens);
71630
+ }
71631
+ };
71632
+
71633
+ var select = function select(token) {
71634
+ if (blockchain.tokens.find(function (majorToken) {
71635
+ return majorToken.address.toLowerCase() == (token.address || token.external_id).toLowerCase();
71636
+ })) {
71637
+ setOpen(false);
71638
+ props.resolve({
71639
+ blockchain: blockchain.name,
71640
+ address: token.address || token.external_id,
71641
+ logo: token.logo || token.image,
71642
+ name: token.name,
71643
+ symbol: token.symbol,
71644
+ decimals: token.decimals
71645
+ });
71646
+ setTimeout(props.unmount, 300);
71647
+ } else {
71648
+ setSelection(Object.assign(props.selection, {
71649
+ token: token
71650
+ }));
71651
+ navigate('ConfirmTokenSelection');
71652
+ }
71653
+ };
71654
+
71655
+ var elements = tokens.map(function (token, index) {
71656
+ return /*#__PURE__*/react.createElement("div", {
71657
+ key: "".concat(index, "-").concat(token.address),
71658
+ className: "Card Row",
71659
+ onClick: function onClick() {
71660
+ return select(token);
71661
+ }
71662
+ }, /*#__PURE__*/react.createElement("div", {
71663
+ className: "CardImage"
71664
+ }, token.logo && /*#__PURE__*/react.createElement("img", {
71665
+ src: token.logo
71666
+ }), token.image && /*#__PURE__*/react.createElement("img", {
71667
+ src: token.image
71668
+ }), !(token.logo || token.image) && /*#__PURE__*/react.createElement(TokenImage, {
71669
+ blockchain: token.blockchain,
71670
+ address: token.external_id || token.address
71671
+ })), /*#__PURE__*/react.createElement("div", {
71672
+ className: "CardBody"
71673
+ }, /*#__PURE__*/react.createElement("div", {
71674
+ className: "CardTokenSymbol",
71675
+ title: token.symbol
71676
+ }, /*#__PURE__*/react.createElement("span", {
71677
+ className: "CardText"
71678
+ }, token.symbol)), /*#__PURE__*/react.createElement("div", {
71679
+ className: "CardTokenName",
71680
+ title: token.name
71681
+ }, /*#__PURE__*/react.createElement("span", {
71682
+ className: "CardText"
71683
+ }, token.name))));
71684
+ });
71685
+
71686
+ if (props.selection.blockchain == undefined) {
71687
+ return null;
71688
+ }
71689
+
71690
+ return /*#__PURE__*/react.createElement(Dialog, {
71691
+ header: /*#__PURE__*/react.createElement("div", {
71692
+ className: "PaddingTopS PaddingLeftM PaddingRightM TextLeft"
71693
+ }, /*#__PURE__*/react.createElement("div", null, /*#__PURE__*/react.createElement("h1", {
71694
+ className: "LineHeightL FontSizeL"
71695
+ }, "Select Token")), /*#__PURE__*/react.createElement("div", {
71696
+ className: "PaddingTopS PaddingBottomXS"
71697
+ }, /*#__PURE__*/react.createElement("div", {
71698
+ className: "Card small",
71699
+ onClick: onClickChangeBlockchain
71700
+ }, /*#__PURE__*/react.createElement("div", {
71701
+ className: "CardImage small"
71702
+ }, /*#__PURE__*/react.createElement("img", {
71703
+ className: "transparent",
71704
+ src: props.selection.blockchain.logo
71705
+ })), /*#__PURE__*/react.createElement("div", {
71706
+ className: "CardBody"
71707
+ }, props.selection.blockchain.label), /*#__PURE__*/react.createElement("div", {
71708
+ className: "CardAction"
71709
+ }, /*#__PURE__*/react.createElement(ChevronRight, null)))), /*#__PURE__*/react.createElement("div", {
71710
+ className: "PaddingTopXS PaddingBottomS"
71711
+ }, /*#__PURE__*/react.createElement("input", {
71712
+ onChange: onChangeSearch,
71713
+ className: "Search",
71714
+ autoFocus: true,
71715
+ placeholder: "Search name or paste address",
71716
+ ref: searchElement
71717
+ }), showAddToken && /*#__PURE__*/react.createElement("div", {
71718
+ className: "PaddingTopXS PaddingRightXS PaddingLeftXS"
71719
+ }, /*#__PURE__*/react.createElement("div", {
71720
+ className: "Tooltip"
71721
+ }, /*#__PURE__*/react.createElement("span", {
71722
+ className: "TooltipArrowUp"
71723
+ }), "Paste or enter token address here!")))),
71724
+ bodyClassName: "ScrollHeight",
71725
+ body: /*#__PURE__*/react.createElement("div", {
71726
+ className: ""
71727
+ }, elements),
71728
+ footer: /*#__PURE__*/react.createElement("div", {
71729
+ className: "PaddingTopS PaddingRightM PaddingLeftM PaddingBottomS"
71730
+ }, /*#__PURE__*/react.createElement("div", {
71731
+ className: "PaddingTopXS PaddingBottomXS"
71732
+ }, /*#__PURE__*/react.createElement("div", {
71733
+ className: "Link",
71734
+ onClick: onClickAddToken
71735
+ }, "Token missing? Add it.")))
71736
+ });
71737
+ });
71738
+
71739
+ var SelectStack = (function (props) {
71740
+ var _useContext = react.useContext(ConfigurationContext),
71741
+ what = _useContext.what;
71742
+
71743
+ var _useContext2 = react.useContext(ClosableContext),
71744
+ open = _useContext2.open,
71745
+ close = _useContext2.close;
71746
+
71747
+ var _useContext3 = react.useContext(SelectionContext),
71748
+ selection = _useContext3.selection;
71749
+
71750
+ var start;
71751
+
71752
+ switch (what) {
71753
+ default:
71754
+ start = 'SelectToken';
71755
+ }
71756
+
71757
+ return /*#__PURE__*/react.createElement(ReactDialogStack, {
71758
+ open: open,
71759
+ close: close,
71760
+ start: start,
71761
+ container: props.container,
71762
+ document: props.document,
71763
+ dialogs: {
71764
+ SelectToken: /*#__PURE__*/react.createElement(SelectTokenDialog, {
71765
+ selection: selection,
71766
+ resolve: props.resolve,
71767
+ unmount: props.unmount
71768
+ }),
71769
+ SelectBlockchain: /*#__PURE__*/react.createElement(SelectBlockchainDialog, {
71770
+ selection: selection,
71771
+ resolve: props.resolve
71772
+ }),
71773
+ ConfirmTokenSelection: /*#__PURE__*/react.createElement(ConfirmTokenSelectionDialog, {
71774
+ selection: selection,
71775
+ resolve: props.resolve,
71776
+ unmount: props.unmount
71777
+ })
71778
+ }
71779
+ });
71780
+ });
71781
+
71782
+ var Select = function Select(options) {
71783
+ var style, error, document, what;
71784
+
71785
+ if (_typeof(options) == 'object') {
71786
+ style = options.style;
71787
+ error = options.error;
71788
+ document = options.document;
71789
+ what = options.what;
71790
+ }
71791
+
71792
+ var startupError;
71793
+
71794
+ if (what == undefined) {
71795
+ startupError = '"what" needs to be configured!';
71796
+ } else if (['token'].indexOf(what) < 0) {
71797
+ startupError = "Unknown \"what\" configured: ".concat(what, "!");
71798
+ }
71799
+
71800
+ return new Promise( /*#__PURE__*/function () {
71801
+ var _ref = _asyncToGenerator( /*#__PURE__*/regenerator.mark(function _callee(resolve, reject) {
71802
+ return regenerator.wrap(function _callee$(_context) {
71803
+ while (1) {
71804
+ switch (_context.prev = _context.next) {
71805
+ case 0:
71806
+ mount({
71807
+ style: style,
71808
+ document: ensureDocument(document)
71809
+ }, function (unmount) {
71810
+ var userClosedDialog = function userClosedDialog() {
71811
+ reject('USER_CLOSED_DIALOG');
71812
+ unmount();
71813
+ };
71814
+
71815
+ return function (container) {
71816
+ return /*#__PURE__*/react.createElement(ErrorProvider, {
71817
+ error: startupError,
71818
+ errorCallback: error,
71819
+ container: container,
71820
+ unmount: unmount
71821
+ }, /*#__PURE__*/react.createElement(ConfigurationProvider, {
71822
+ configuration: {
71823
+ what: what
71824
+ }
71825
+ }, /*#__PURE__*/react.createElement(UpdatableProvider, null, /*#__PURE__*/react.createElement(ClosableProvider, {
71826
+ unmount: userClosedDialog
71827
+ }, /*#__PURE__*/react.createElement(SelectionProvider, null, /*#__PURE__*/react.createElement(SelectStack, {
71828
+ document: document,
71829
+ container: container,
71830
+ unmount: unmount,
71831
+ resolve: resolve
71832
+ })), /*#__PURE__*/react.createElement(PoweredBy, null)))));
71833
+ };
71834
+ });
71835
+
71836
+ case 1:
71837
+ case "end":
71838
+ return _context.stop();
71839
+ }
71840
+ }
71841
+ }, _callee);
71842
+ }));
71843
+
71844
+ return function (_x, _x2) {
71845
+ return _ref.apply(this, arguments);
71846
+ };
71847
+ }());
71848
+ };
71849
+
71263
71850
  var DePayWidgets = {
71264
71851
  Connect: Connect,
71265
71852
  Donation: Donation,
71266
71853
  Login: Login,
71267
71854
  Payment: Payment,
71268
71855
  Sale: Sale,
71856
+ Select: Select,
71269
71857
  provider: provider
71270
71858
  };
71271
71859