@depay/widgets 9.1.2 → 9.2.1

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.
package/dist/umd/index.js CHANGED
@@ -1217,7 +1217,7 @@
1217
1217
  });
1218
1218
 
1219
1219
  var CardStyle = (function (style) {
1220
- return "\n\n .Card {\n align-items: center;\n background: rgb(255,255,255);\n border-radius: 13px;\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: 8px;\n min-height: 76px;\n padding: 16px 10px;\n width: 100%;\n }\n\n .Card.Row {\n border-radius: 0;\n margin-bottom: 0;\n box-shadow: none;\n min-height: 69px;\n padding: 7px 21px;\n border-top: 1px solid rgba(0,0,0,0.05);\n }\n\n .Card.Row .CardText {\n font-size: 19px;\n line-height: 40px;\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: 17px;\n }\n\n .Card.Row .CardImage {\n width: 40px;\n }\n\n .Card.Row .CardImage img {\n height: 30px;\n width: 30px;\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: 8px 8px;\n margin: 0;\n }\n\n .CardImage.small {\n width: 27px;\n }\n\n .CardImage.small img {\n height: 27px;\n width: 27px;\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 7px;\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: 58px;\n }\n\n .CardBody {\n flex-basis: auto;\n flex-grow: 1;\n flex-shrink: 1;\n line-height: 27px;\n padding-left: 10px;\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: 9999px;\n border: 1px solid white;\n box-shadow: 0 2px 8px rgb(0 0 0 / 10%);\n height: 45px;\n position: relative;\n vertical-align: middle;\n width: 45px;\n }\n\n .CardImage.square img {\n border-radius: 0;\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: 15px;\n color: rgb(150,150,150);\n line-height: 20px;\n }\n \n .CardText, a .CardText {\n color: ".concat(style.colors.text, ";\n flex: 1;\n font-size: 21px;\n line-height: 26px;\n }\n\n .CardText strong {\n font-weight: 500;\n }\n\n .CardText.small, .CardText.small small {\n font-size: 18px;\n color: rgb(150,150,150);\n line-height: 20px;\n }\n\n .CardAction {\n opacity: 0.2;\n }\n\n .Card.More {\n display: inline-block;\n text-align: center;\n }\n ");
1220
+ return "\n\n .Card {\n align-items: center;\n background: rgb(255,255,255);\n border-radius: 13px;\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: 8px;\n min-height: 76px;\n padding: 16px 10px;\n width: 100%;\n }\n\n .Card.Row {\n border-radius: 0;\n margin-bottom: 0;\n box-shadow: none;\n min-height: 69px;\n padding: 7px 21px;\n border-top: 1px solid rgba(0,0,0,0.05);\n }\n\n .Card.Row .CardText {\n font-size: 19px;\n line-height: 40px;\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 .CardTokenFullName {\n width: 100%;\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: 17px;\n }\n\n .Card.Row .CardImage {\n width: 40px;\n }\n\n .Card.Row .CardImage img {\n height: 30px;\n width: 30px;\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: 8px 8px;\n margin: 0;\n }\n\n .CardImage.small {\n width: 27px;\n }\n\n .CardImage.small img {\n height: 27px;\n width: 27px;\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 7px;\n }\n\n .CardImage {\n display: inline-flex;\n flex-basis: auto;\n flex-grow: 0;\n flex-shrink: 0;\n justify-content: center;\n position: relative;\n width: 58px;\n }\n\n .CardBody {\n flex-basis: auto;\n flex-grow: 1;\n flex-shrink: 1;\n line-height: 27px;\n padding-left: 10px;\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: 9999px;\n border: 1px solid white;\n box-shadow: 0 2px 8px rgb(0 0 0 / 10%);\n height: 45px;\n position: relative;\n vertical-align: middle;\n width: 45px;\n }\n\n .CardImage.square img {\n border-radius: 0;\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: 15px;\n color: rgb(150,150,150);\n line-height: 20px;\n }\n \n .CardText, a .CardText {\n color: ".concat(style.colors.text, ";\n flex: 1;\n font-size: 21px;\n line-height: 26px;\n }\n\n .CardText strong {\n font-weight: 500;\n }\n\n .CardText.small, .CardText.small small {\n font-size: 18px;\n color: rgb(150,150,150);\n line-height: 20px;\n }\n\n .CardAction {\n opacity: 0.2;\n }\n\n .Card.More {\n display: inline-block;\n text-align: center;\n }\n ");
1221
1221
  });
1222
1222
 
1223
1223
  var DialogStyle = (function (style) {
@@ -1293,7 +1293,7 @@
1293
1293
  });
1294
1294
 
1295
1295
  var TextStyle = (function (style) {
1296
- return "\n\n * {\n color: ".concat(style.colors.text, ";\n }\n\n h1, h2, h3, h4, h5, h6 {\n display: block;\n }\n\n .Text {\n font-size: 16px;\n line-height: 24px\n }\n\n .TextLeft, .TextLeft * {\n text-align: left;\n }\n\n .TextCenter, .TextCenter * {\n text-align: center;\n }\n\n .LineHeightL {\n line-height: 32px;\n }\n\n .ErrorSnippetText {\n background: rgb(30, 30, 20);\n border-radius: 19px;\n border: 8px solid rgb(30, 30, 20);\n color: #00FF41;\n font-size: 15px;\n font-style: italic;\n max-height: 100px;\n padding: 6px;\n overflow-wrap: break-word;\n overflow-y: auto;\n white-space: pre-wrap;\n word-wrap: break-word;\n }\n ");
1296
+ return "\n\n * {\n color: ".concat(style.colors.text, ";\n }\n\n h1, h2, h3, h4, h5, h6 {\n display: block;\n }\n\n .Text {\n font-size: 16px;\n line-height: 24px\n }\n\n .TextLeft, .TextLeft * {\n text-align: left !important;\n }\n\n .TextCenter, .TextCenter * {\n text-align: center;\n }\n\n .LineHeightL {\n line-height: 32px;\n }\n\n .ErrorSnippetText {\n background: rgb(30, 30, 20);\n border-radius: 19px;\n border: 8px solid rgb(30, 30, 20);\n color: #00FF41;\n font-size: 15px;\n font-style: italic;\n max-height: 100px;\n padding: 6px;\n overflow-wrap: break-word;\n overflow-y: auto;\n white-space: pre-wrap;\n word-wrap: break-word;\n }\n ");
1297
1297
  });
1298
1298
 
1299
1299
  var TokenAmountStyle = (function () {
@@ -18905,7 +18905,7 @@
18905
18905
  web3Tokens.Token.readable({
18906
18906
  amount: maxRoute.fromBalance,
18907
18907
  blockchain: maxRoute.blockchain,
18908
- address: maxRoute.toToken.address
18908
+ address: maxRoute.fromToken.address
18909
18909
  }).then(setMaxAmount);
18910
18910
  return;
18911
18911
  }
@@ -19351,12 +19351,12 @@
19351
19351
  return obj;
19352
19352
  }
19353
19353
 
19354
- function ownKeys$1(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
19355
- function _objectSpread$1(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys$1(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys$1(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
19354
+ function ownKeys$3(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
19355
+ function _objectSpread$3(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys$3(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys$3(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
19356
19356
  var prepareAcceptedPayments = function prepareAcceptedPayments(accept) {
19357
19357
  var toAddress = _typeof(accept.receiver) == 'object' ? accept.receiver.address : accept.receiver;
19358
19358
  var toContract = _typeof(accept.receiver) == 'object' ? accept.receiver : undefined;
19359
- return _objectSpread$1(_objectSpread$1({}, accept), {}, {
19359
+ return _objectSpread$3(_objectSpread$3({}, accept), {}, {
19360
19360
  toAddress: toAddress,
19361
19361
  toContract: toContract
19362
19362
  });
@@ -19384,8 +19384,8 @@
19384
19384
  });
19385
19385
  });
19386
19386
 
19387
- function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
19388
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
19387
+ function ownKeys$2(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
19388
+ function _objectSpread$2(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys$2(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys$2(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
19389
19389
  var PaymentRoutingProvider = (function (props) {
19390
19390
  var _useState = React.useState(),
19391
19391
  _useState2 = _slicedToArray(_useState, 2),
@@ -19547,7 +19547,7 @@
19547
19547
  return regenerator.wrap(function _callee5$(_context5) {
19548
19548
  while (1) switch (_context5.prev = _context5.next) {
19549
19549
  case 0:
19550
- setSelectedRoute(_objectSpread({}, updatedRouteWithNewPrice));
19550
+ setSelectedRoute(_objectSpread$2({}, updatedRouteWithNewPrice));
19551
19551
  setUpdatedRouteWithNewPrice(null);
19552
19552
  case 2:
19553
19553
  case "end":
@@ -20502,7 +20502,7 @@
20502
20502
  return /*#__PURE__*/React__default["default"].createElement(Dialog$1, {
20503
20503
  stacked: true,
20504
20504
  header: /*#__PURE__*/React__default["default"].createElement("div", {
20505
- className: "PaddingTopS PaddingLeftM PaddingRightM TextLeft"
20505
+ className: "PaddingTopS PaddingLeftM PaddingRightM"
20506
20506
  }, /*#__PURE__*/React__default["default"].createElement("h1", {
20507
20507
  className: "LineHeightL FontSizeL"
20508
20508
  }, "Wrong Network")),
@@ -21525,7 +21525,8 @@
21525
21525
  var PaymentOverviewDialog = (function (props) {
21526
21526
  var _useContext = React.useContext(ConfigurationContext),
21527
21527
  currencyCode = _useContext.currencyCode,
21528
- recover = _useContext.recover;
21528
+ recover = _useContext.recover,
21529
+ amountConfiguration = _useContext.amount;
21529
21530
  var _useContext2 = React.useContext(PaymentContext),
21530
21531
  payment = _useContext2.payment,
21531
21532
  paymentState = _useContext2.paymentState;
@@ -21538,6 +21539,7 @@
21538
21539
  paymentValue = _useContext4.paymentValue;
21539
21540
  var _useContext5 = React.useContext(reactDialogStack.NavigateStackContext),
21540
21541
  navigate = _useContext5.navigate;
21542
+ var displayedCurrencyCode = amountConfiguration != undefined && amountConfiguration.token ? null : currencyCode;
21541
21543
  if (payment == undefined || recover == undefined && paymentValue == undefined) {
21542
21544
  return /*#__PURE__*/React__default["default"].createElement(PaymentOverviewSkeleton, null);
21543
21545
  }
@@ -21567,12 +21569,14 @@
21567
21569
  className: "CardTitle"
21568
21570
  }, "Amount"), /*#__PURE__*/React__default["default"].createElement("h2", {
21569
21571
  className: "CardText"
21570
- }, /*#__PURE__*/React__default["default"].createElement("div", {
21572
+ }, displayedCurrencyCode && /*#__PURE__*/React__default["default"].createElement("div", {
21571
21573
  className: "TokenAmountRow"
21572
21574
  }, new localCurrency.Currency({
21573
21575
  amount: amount.toFixed(2),
21574
21576
  code: currencyCode
21575
- }).toString())))), /*#__PURE__*/React__default["default"].createElement("div", {
21577
+ }).toString()), !displayedCurrencyCode && /*#__PURE__*/React__default["default"].createElement("div", {
21578
+ className: "TokenAmountRow"
21579
+ }, amount)))), /*#__PURE__*/React__default["default"].createElement("div", {
21576
21580
  className: "CardAction"
21577
21581
  }, /*#__PURE__*/React__default["default"].createElement(ChevronRight, null))), /*#__PURE__*/React__default["default"].createElement("div", {
21578
21582
  className: ["Card", paymentState == 'initialized' ? '' : 'disabled'].join(' '),
@@ -22297,51 +22301,52 @@
22297
22301
  };
22298
22302
  });
22299
22303
 
22300
- var ConfirmTokenSelectionDialog = (function (props) {
22304
+ function ownKeys$1(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
22305
+ function _objectSpread$1(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys$1(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys$1(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
22306
+ var ConfirmNFTSelectionDialog = (function (props) {
22307
+ var _selection$nft, _selection$blockchain;
22301
22308
  var _useContext = React.useContext(SelectionContext),
22302
22309
  selection = _useContext.selection;
22310
+ _useContext.setSelection;
22303
22311
  var _useContext2 = React.useContext(ClosableContext),
22304
22312
  setOpen = _useContext2.setOpen;
22305
- var token = selection.token;
22306
- var address = token.address || token.external_id;
22307
- var logo = token.logo || token.image;
22308
- var blockchain = web3Blockchains.Blockchain.findByName(token.blockchain);
22309
- var age = token.first_transfer ? msToTime(new Date() - new Date(token.first_transfer)) : undefined;
22310
- if (age) {
22313
+ var _useContext3 = React.useContext(reactDialogStack.NavigateStackContext),
22314
+ navigate = _useContext3.navigate;
22315
+ var age, holders;
22316
+ if (selection.nft.createdAt) {
22317
+ age = msToTime(new Date() - new Date(selection.nft.createdAt));
22311
22318
  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) {
22312
22319
  return n;
22313
22320
  }).join(' ');
22314
22321
  }
22315
- var holders = token.unique_senders ? token.unique_senders : undefined;
22316
- if (holders) {
22317
- if (holders > 1000000) {
22322
+ if (selection.nft.holders) {
22323
+ if (selection.nft.holders > 1000000) {
22318
22324
  holders = "Millions";
22319
- } else if (holders > 100000) {
22325
+ } else if (selection.nft.holders > 100000) {
22320
22326
  holders = "Hundreds of Thousands";
22321
- } else if (holders > 2000) {
22327
+ } else if (selection.nft.holders > 2000) {
22322
22328
  holders = "Thousands";
22323
- } else if (holders > 100) {
22329
+ } else if (selection.nft.holders > 100) {
22324
22330
  holders = "Hundreds";
22325
22331
  } else {
22326
22332
  holders = "Only a Few!!!";
22327
22333
  }
22328
22334
  }
22335
+ var blockchain = ((_selection$nft = selection.nft) === null || _selection$nft === void 0 ? void 0 : _selection$nft.blockchain) || ((_selection$blockchain = selection.blockchain) === null || _selection$blockchain === void 0 ? void 0 : _selection$blockchain.name);
22336
+ if (blockchain == undefined) {
22337
+ navigate('SelectBlockchain');
22338
+ return null;
22339
+ }
22329
22340
  var onClickConfirm = function onClickConfirm() {
22330
22341
  setOpen(false);
22331
- props.resolve({
22332
- blockchain: token.blockchain,
22333
- address: token.external_id || token.address,
22334
- symbol: token.symbol,
22335
- name: token.name,
22336
- decimals: token.decimals,
22337
- logo: token.image || token.logo,
22338
- routable: token.routable
22339
- });
22342
+ props.resolve(_objectSpread$1(_objectSpread$1({}, selection.nft), {}, {
22343
+ blockchain: blockchain
22344
+ }));
22340
22345
  setTimeout(props.unmount, 300);
22341
22346
  };
22342
22347
  return /*#__PURE__*/React__default["default"].createElement(Dialog$1, {
22343
22348
  header: /*#__PURE__*/React__default["default"].createElement("div", {
22344
- className: "PaddingTopS PaddingLeftM PaddingRightM TextLeft"
22349
+ className: "PaddingTopS PaddingLeftM PaddingRightM"
22345
22350
  }, /*#__PURE__*/React__default["default"].createElement("div", null, /*#__PURE__*/React__default["default"].createElement("h1", {
22346
22351
  className: "LineHeightL FontSizeL"
22347
22352
  }, "Confirm Selection"))),
@@ -22350,11 +22355,8 @@
22350
22355
  className: "PaddingTopS PaddingLeftM PaddingRightM"
22351
22356
  }, /*#__PURE__*/React__default["default"].createElement("div", {
22352
22357
  className: "TokenImage medium TextCenter"
22353
- }, logo && /*#__PURE__*/React__default["default"].createElement("img", {
22354
- src: logo
22355
- }), !logo && /*#__PURE__*/React__default["default"].createElement(reactTokenImage.TokenImage, {
22356
- blockchain: token.blockchain,
22357
- address: address
22358
+ }, selection.nft.image && /*#__PURE__*/React__default["default"].createElement("img", {
22359
+ src: selection.nft.image
22358
22360
  })), /*#__PURE__*/React__default["default"].createElement("div", {
22359
22361
  className: "PaddingTopS TextCenter"
22360
22362
  }, /*#__PURE__*/React__default["default"].createElement("div", {
@@ -22366,20 +22368,25 @@
22366
22368
  }, /*#__PURE__*/React__default["default"].createElement("tbody", null, /*#__PURE__*/React__default["default"].createElement("tr", null, /*#__PURE__*/React__default["default"].createElement("td", null, /*#__PURE__*/React__default["default"].createElement("div", {
22367
22369
  className: "TableSubTitle"
22368
22370
  }, "Address")), /*#__PURE__*/React__default["default"].createElement("td", null, /*#__PURE__*/React__default["default"].createElement("div", null, /*#__PURE__*/React__default["default"].createElement("a", {
22369
- className: "Link FontSizeM",
22370
- title: address,
22371
- href: blockchain.explorerUrlFor({
22372
- token: address
22371
+ className: "Link",
22372
+ title: selection.nft.address,
22373
+ href: web3Blockchains.Blockchain.findByName(blockchain).explorerUrlFor({
22374
+ token: selection.nft.address
22373
22375
  }),
22374
22376
  target: "_blank",
22375
22377
  rel: "noopener noreferrer"
22376
- }, addressEllipsis(address, 4))))), /*#__PURE__*/React__default["default"].createElement("tr", null, /*#__PURE__*/React__default["default"].createElement("td", null, /*#__PURE__*/React__default["default"].createElement("div", {
22378
+ }, addressEllipsis(selection.nft.address, 6))))), selection.nft.id && /*#__PURE__*/React__default["default"].createElement("tr", null, /*#__PURE__*/React__default["default"].createElement("td", null, /*#__PURE__*/React__default["default"].createElement("div", {
22377
22379
  className: "TableSubTitle"
22378
- }, "Blockchain")), /*#__PURE__*/React__default["default"].createElement("td", null, /*#__PURE__*/React__default["default"].createElement("div", null, blockchain.label))), /*#__PURE__*/React__default["default"].createElement("tr", null, /*#__PURE__*/React__default["default"].createElement("td", null, /*#__PURE__*/React__default["default"].createElement("div", {
22380
+ }, "Token ID")), /*#__PURE__*/React__default["default"].createElement("td", null, /*#__PURE__*/React__default["default"].createElement("div", null, selection.nft.id))), /*#__PURE__*/React__default["default"].createElement("tr", null, /*#__PURE__*/React__default["default"].createElement("td", null, /*#__PURE__*/React__default["default"].createElement("div", {
22379
22381
  className: "TableSubTitle"
22380
- }, "Symbol")), /*#__PURE__*/React__default["default"].createElement("td", null, /*#__PURE__*/React__default["default"].createElement("div", null, token.symbol))), /*#__PURE__*/React__default["default"].createElement("tr", null, /*#__PURE__*/React__default["default"].createElement("td", null, /*#__PURE__*/React__default["default"].createElement("div", {
22382
+ }, "Blockchain")), /*#__PURE__*/React__default["default"].createElement("td", null, /*#__PURE__*/React__default["default"].createElement("div", null, web3Blockchains.Blockchain.findByName(blockchain).label))), /*#__PURE__*/React__default["default"].createElement("tr", null, /*#__PURE__*/React__default["default"].createElement("td", null, /*#__PURE__*/React__default["default"].createElement("div", {
22381
22383
  className: "TableSubTitle"
22382
- }, "Name")), /*#__PURE__*/React__default["default"].createElement("td", null, /*#__PURE__*/React__default["default"].createElement("div", null, token.name))), age && /*#__PURE__*/React__default["default"].createElement("tr", null, /*#__PURE__*/React__default["default"].createElement("td", null, /*#__PURE__*/React__default["default"].createElement("div", {
22384
+ }, "Name")), /*#__PURE__*/React__default["default"].createElement("td", null, /*#__PURE__*/React__default["default"].createElement("a", {
22385
+ className: "Link",
22386
+ href: selection.nft.link,
22387
+ target: "_blank",
22388
+ rel: "noopener noreferrer"
22389
+ }, selection.nft.name))), age && /*#__PURE__*/React__default["default"].createElement("tr", null, /*#__PURE__*/React__default["default"].createElement("td", null, /*#__PURE__*/React__default["default"].createElement("div", {
22383
22390
  className: "TableSubTitle"
22384
22391
  }, "Age")), /*#__PURE__*/React__default["default"].createElement("td", null, /*#__PURE__*/React__default["default"].createElement("div", null, age))), holders && /*#__PURE__*/React__default["default"].createElement("tr", null, /*#__PURE__*/React__default["default"].createElement("td", null, /*#__PURE__*/React__default["default"].createElement("div", {
22385
22392
  className: "TableSubTitle"
@@ -22393,19 +22400,227 @@
22393
22400
  });
22394
22401
  });
22395
22402
 
22403
+ var OpenSea = 'data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiIHN0YW5kYWxvbmU9Im5vIj8+CjxzdmcgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB3aWR0aD0iNjMuMjUwODg5bW0iIGhlaWdodD0iNjMuMjUwODg5bW0iIHZpZXdCb3g9IjAgMCA2My4yNTA4ODYgNjMuMjUwODg4Ij4KICA8ZyBmaWxsPSJub25lIiB0cmFuc2Zvcm09InNjYWxlKC42MzI1KSI+CiAgICA8cGF0aCBmaWxsPSIjMjA4MWUyIiBkPSJNMTAwIDUwYzAgMjcuNjEyNy0yMi4zODczIDUwLTUwIDUwUzAgNzcuNjEyNyAwIDUwIDIyLjM4NzMgMCA1MCAwYzI3LjYxODUgMCA1MCAyMi4zODczIDUwIDUweiIvPgogICAgPHBhdGggZmlsbD0iI2ZmZiIgZD0ibTI0LjY2NzkgNTEuNjgwMS4yMTU3LS4zMzkxIDEzLjAwNy0yMC4zNDc4Yy4xOTAxLS4yOTc5LjYzNy0uMjY3MS43ODA4LjA1NjUgMi4xNzMgNC44Njk5IDQuMDQ4IDEwLjkyNjUgMy4xNjk2IDE0LjY5NzEtLjM3NSAxLjU1MTQtMS40MDI0IDMuNjUyNC0yLjU1ODMgNS41OTQyLS4xNDg5LjI4MjYtLjMxMzMuNTYtLjQ4OC44MjcxLS4wODIyLjEyMzMtLjIyMDkuMTk1Mi0uMzY5OS4xOTUySDI1LjA0OGMtLjM1OTYgMC0uNTcwMi0uMzkwNC0uMzgwMS0uNjgzMnoiLz4KICAgIDxwYXRoIGZpbGw9IiNmZmYiIGQ9Ik04Mi42NDQ0IDU1LjQ2MXYzLjIyMDljMCAuMTg0OS0uMTEzLjM0OTMtLjI3NzQuNDIxMi0xLjAwNjguNDMxNS00LjQ1MzggMi4wMTM3LTUuODg3IDQuMDA2OS0zLjY1NzYgNS4wOTA4LTYuNDUyMSAxMi4zNy0xMi42OTg4IDEyLjM3SDM3LjcyMUMyOC40ODQ3IDc1LjQ4IDIxIDY3Ljk2OTcgMjEgNTguNzAyNHYtLjI5NzljMC0uMjQ2Ni4yMDAzLS40NDY5LjQ0NjktLjQ0NjloMTQuNTI3NmMuMjg3NiAwIC40OTgyLjI2NzEuNDcyNi41NDk2LS4xMDI4Ljk0NTIuMDcxOSAxLjkxMS41MTg4IDIuNzg5NC44NjMgMS43NTE4IDIuNjUwNyAyLjg0NiA0LjU4MjIgMi44NDZINDguNzR2LTUuNjE0OGgtNy4xMDk3Yy0uMzY0NyAwLS41ODA0LS40MjEzLS4zNjk4LS43MTkyLjA3Ny0uMTE4Mi4xNjQ0LS4yNDE0LjI1NjgtLjM4MDEuNjczLS45NTU1IDEuNjMzNi0yLjQ0MDEgMi41ODkxLTQuMTMwMi42NTI0LTEuMTQwNCAxLjI4NDItMi4zNTc5IDEuNzkyOC0zLjU4MDUuMTAyOC0uMjIwOS4xODQ5LS40NDcuMjY3MS0uNjY3OS4xMzg3LS4zOTA0LjI4MjYtLjc1NTEuMzg1My0xLjExOTguMTAyOC0uMzA4My4xODQ5LS42MzE5LjI2NzEtLjkzNS4yNDE1LTEuMDM3Ny4zNDQyLTIuMTM3LjM0NDItMy4yNzc0IDAtLjQ0NjktLjAyMDUtLjkxNDQtLjA2MTYtMS4zNjEzLS4wMjA2LS40ODgtLjA4MjItLjk3NjEtLjE0MzktMS40NjQxLS4wNDExLS40MzE1LS4xMTgxLS44NTc5LS4yMDAzLTEuMzA0OC0uMTAyNy0uNjUyNC0uMjQ2Ni0xLjI5OTYtLjQxMS0xLjk1MjFsLS4wNTY1LS4yNDY1Yy0uMTIzMy0uNDQ3LS4yMjYtLjg3MzMtLjM2OTgtMS4zMjAyLS40MDU5LTEuNDAyNS0uODczMy0yLjc2ODktMS4zNjY1LTQuMDQ4LS4xNzk4LS41MDg2LS4zODUzLS45OTY2LS41OTA4LTEuNDg0Ni0uMzAzLS43MzQ2LS42MTEzLTEuNDAyNC0uODkzOC0yLjAzNDMtLjE0MzgtLjI4NzctLjI2NzEtLjU0OTctLjM5MDQtLjgxNjgtLjEzODctLjMwMzEtLjI4MjUtLjYwNjItLjQyNjQtLjg5MzgtLjEwMjctLjIyMDktLjIyMDktLjQyNjQtLjMwMzEtLjYzMTlsLS44Nzg0LTEuNjIzM2MtLjEyMzMtLjIyMDkuMDgyMi0uNDgyOS4zMjM2LS40MTYxbDUuNDk2NyAxLjQ4OTdoLjAxNTRjLjAxMDIgMCAuMDE1NC4wMDUyLjAyMDUuMDA1MmwuNzI0My4yMDAzLjc5NjMuMjI2MS4yOTI4LjA4MjF2LTMuMjY3MUM0OC43NCAyMS4yNzkxIDUwLjAwMzcgMjAgNTEuNTY1NCAyMGMuNzgwOCAwIDEuNDg5Ny4zMTg1IDEuOTk4My44MzczLjUwODUuNTE4OS44MjcgMS4yMjc4LjgyNyAyLjAxODl2NC44NDk0bC41ODU3LjE2NDNjLjA0NjIuMDE1NS4wOTI0LjAzNi4xMzM1LjA2NjguMTQzOS4xMDc5LjM0OTMuMjY3MS42MTEzLjQ2MjQuMjA1NS4xNjQzLjQyNjQuMzY0Ny42OTM1LjU3MDIuNTI5MS40MjYzIDEuMTYxLjk3NiAxLjg1NDUgMS42MDc5LjE4NDkuMTU5Mi4zNjQ3LjMyMzYuNTI5MS40ODguODkzOS44MzIyIDEuODk1NiAxLjgwODIgMi44NTExIDIuODg3LjI2NzEuMzAzMS41MjkxLjYxMTMuNzk2Mi45MzQ5LjI2NzEuMzI4OC41NDk3LjY1MjQuNzk2Mi45NzYxLjMyMzcuNDMxNS42NzMuODc4NC45NzYxIDEuMzQ1OS4xNDM4LjIyMDkuMzA4Mi40NDY5LjQ0NjkuNjY3OC4zOTA0LjU5MDcuNzM0NiAxLjIwMjEgMS4wNjM0IDEuODEzNC4xMzg3LjI4MjUuMjgyNS41OTA3LjQwNTguODkzOC4zNjQ3LjgxNjguNjUyNCAxLjY0OS44MzczIDIuNDgxMi4wNTY1LjE3OTguMDk3Ni4zNzUuMTE4Mi41NDk3di4wNDExYy4wNjE2LjI0NjUuMDgyMi41MDg1LjEwMjcuNzc1Ni4wODIyLjg1MjguMDQxMSAxLjcwNTUtLjE0MzggMi41NjM0LS4wNzcxLjM2NDgtLjE3OTguNzA4OS0uMzAzMSAxLjA3MzctLjEyMzMuMzQ5My0uMjQ2Ni43MTQtLjQwNTggMS4wNTgyLS4zMDgyLjcxNC0uNjczIDEuNDI4MS0xLjEwNDUgMi4wOTU5LS4xMzg3LjI0NjYtLjMwMzEuNTA4Ni0uNDY3NS43NTUyLS4xNzk4LjI2MTktLjM2NDcuNTA4NS0uNTI5MS43NS0uMjI2LjMwODItLjQ2NzQuNjMxOC0uNzE0LjkxOTUtLjIyMDkuMzAzMS0uNDQ2OS42MDYyLS42OTM1Ljg3MzMtLjM0NDIuNDA1OC0uNjczLjc5MTEtMS4wMTcyIDEuMTYxLS4yMDU0LjI0MTQtLjQyNjMuNDg4LS42NTI0LjcwODktLjIyMDguMjQ2NS0uNDQ2OS40Njc0LS42NTI0LjY3MjktLjM0NDEuMzQ0Mi0uNjMxOC42MTEzLS44NzMzLjgzMjJsLS41NjUuNTE4OWMtLjA4MjIuMDcxOS0uMTkwMS4xMTMtLjMwMzEuMTEzaC00LjM3Njh2NS42MTQ4aDUuNTA2OWMxLjIzMjkgMCAyLjQwNDItLjQzNjcgMy4zNDk0LTEuMjM4MS4zMjM2LS4yODI1IDEuNzM2My0xLjUwNTEgMy40MDU4LTMuMzQ5My4wNTY1LS4wNjE3LjEyODUtLjEwNzkuMjEwNy0uMTI4NGwxNS4yMTA3LTQuMzk3M2MuMjgyNi0uMDgyMi41NzAyLjEzMzUuNTcwMi40MzE1eiIvPgogIDwvZz4KPC9zdmc+';
22404
+
22405
+ var EnterNFTDataForOpenSeaDialog = (function (props) {
22406
+ var _Blockchain$findByNam, _selection$blockchain3, _selection$collection3, _Blockchain$findByNam2, _selection$blockchain4, _selection$collection4;
22407
+ var _useContext = React.useContext(reactDialogStack.NavigateStackContext),
22408
+ navigate = _useContext.navigate;
22409
+ var _useContext2 = React.useContext(SelectionContext),
22410
+ selection = _useContext2.selection,
22411
+ setSelection = _useContext2.setSelection;
22412
+ var _useState = React.useState(''),
22413
+ _useState2 = _slicedToArray(_useState, 2),
22414
+ id = _useState2[0],
22415
+ setId = _useState2[1];
22416
+ var _useState3 = React.useState(''),
22417
+ _useState4 = _slicedToArray(_useState3, 2),
22418
+ image = _useState4[0],
22419
+ setImage = _useState4[1];
22420
+ var _useState5 = React.useState(''),
22421
+ _useState6 = _slicedToArray(_useState5, 2),
22422
+ link = _useState6[0],
22423
+ setLink = _useState6[1];
22424
+ var _useState7 = React.useState(''),
22425
+ _useState8 = _slicedToArray(_useState7, 2),
22426
+ name = _useState8[0],
22427
+ setName = _useState8[1];
22428
+ var _useState9 = React.useState(false),
22429
+ _useState10 = _slicedToArray(_useState9, 2),
22430
+ idRequired = _useState10[0],
22431
+ setIdRequired = _useState10[1];
22432
+ var confirm = function confirm() {
22433
+ var _selection$blockchain, _selection$collection;
22434
+ var blockchain = (selection === null || selection === void 0 ? void 0 : (_selection$blockchain = selection.blockchain) === null || _selection$blockchain === void 0 ? void 0 : _selection$blockchain.name) || (selection === null || selection === void 0 ? void 0 : selection.blockchain) || (selection === null || selection === void 0 ? void 0 : (_selection$collection = selection.collection) === null || _selection$collection === void 0 ? void 0 : _selection$collection.blockchain);
22435
+ setSelection(Object.assign(props.selection, {
22436
+ nft: {
22437
+ blockchain: blockchain,
22438
+ id: id,
22439
+ image: image,
22440
+ name: name,
22441
+ link: link,
22442
+ address: selection.nft.address,
22443
+ type: idRequired ? '1155' : '721'
22444
+ }
22445
+ }));
22446
+ navigate('ConfirmNFTSelection');
22447
+ };
22448
+ React.useEffect(function () {
22449
+ var _selection$blockchain2, _selection$collection2;
22450
+ var blockchain = (selection === null || selection === void 0 ? void 0 : (_selection$blockchain2 = selection.blockchain) === null || _selection$blockchain2 === void 0 ? void 0 : _selection$blockchain2.name) || (selection === null || selection === void 0 ? void 0 : selection.blockchain) || (selection === null || selection === void 0 ? void 0 : (_selection$collection2 = selection.collection) === null || _selection$collection2 === void 0 ? void 0 : _selection$collection2.blockchain);
22451
+ var checkForIdRequired = /*#__PURE__*/function () {
22452
+ var _ref = _asyncToGenerator( /*#__PURE__*/regenerator.mark(function _callee() {
22453
+ var balanceWithId;
22454
+ return regenerator.wrap(function _callee$(_context) {
22455
+ while (1) switch (_context.prev = _context.next) {
22456
+ case 0:
22457
+ if (!blockchain) {
22458
+ _context.next = 10;
22459
+ break;
22460
+ }
22461
+ _context.prev = 1;
22462
+ _context.next = 4;
22463
+ return web3Client.request({
22464
+ blockchain: blockchain,
22465
+ address: selection.nft.address,
22466
+ method: 'balanceOf',
22467
+ api: web3Tokens.Token[blockchain][1155],
22468
+ params: ['0x4e260bB2b25EC6F3A59B478fCDe5eD5B8D783B02', '1']
22469
+ });
22470
+ case 4:
22471
+ balanceWithId = _context.sent;
22472
+ _context.next = 9;
22473
+ break;
22474
+ case 7:
22475
+ _context.prev = 7;
22476
+ _context.t0 = _context["catch"](1);
22477
+ case 9:
22478
+ if (balanceWithId) {
22479
+ setIdRequired(true);
22480
+ }
22481
+ case 10:
22482
+ case "end":
22483
+ return _context.stop();
22484
+ }
22485
+ }, _callee, null, [[1, 7]]);
22486
+ }));
22487
+ return function checkForIdRequired() {
22488
+ return _ref.apply(this, arguments);
22489
+ };
22490
+ }();
22491
+ checkForIdRequired();
22492
+ }, [selection.blockchain]);
22493
+ return /*#__PURE__*/React__default["default"].createElement(Dialog$1, {
22494
+ stacked: true,
22495
+ header: /*#__PURE__*/React__default["default"].createElement("div", {
22496
+ className: "PaddingTopS PaddingLeftM PaddingRightM"
22497
+ }, /*#__PURE__*/React__default["default"].createElement("div", null, /*#__PURE__*/React__default["default"].createElement("div", {
22498
+ className: "LineHeightL FontSizeL PaddingTopXS"
22499
+ }, /*#__PURE__*/React__default["default"].createElement("span", {
22500
+ className: "CardImage small"
22501
+ }, /*#__PURE__*/React__default["default"].createElement("img", {
22502
+ className: "transparent",
22503
+ src: OpenSea
22504
+ }))))),
22505
+ body: /*#__PURE__*/React__default["default"].createElement("div", {
22506
+ className: "PaddingLeftM PaddingRightM"
22507
+ }, /*#__PURE__*/React__default["default"].createElement("div", null, /*#__PURE__*/React__default["default"].createElement("div", {
22508
+ className: "PaddingTopXS TextLeft"
22509
+ }, /*#__PURE__*/React__default["default"].createElement("label", {
22510
+ htmlFor: "DePayWidgetsEnterNFTBlockchain"
22511
+ }, /*#__PURE__*/React__default["default"].createElement("span", {
22512
+ className: "FontSizeM Opacity05"
22513
+ }, "Select Blockchain"))), /*#__PURE__*/React__default["default"].createElement("div", {
22514
+ className: "PaddingTopXS PaddingBottomS"
22515
+ }, /*#__PURE__*/React__default["default"].createElement("div", {
22516
+ className: "Card small",
22517
+ onClick: function onClick() {
22518
+ return navigate('SelectBlockchain');
22519
+ }
22520
+ }, /*#__PURE__*/React__default["default"].createElement("div", {
22521
+ className: "CardImage small"
22522
+ }, /*#__PURE__*/React__default["default"].createElement("img", {
22523
+ className: "transparent",
22524
+ src: (_Blockchain$findByNam = web3Blockchains.Blockchain.findByName((selection === null || selection === void 0 ? void 0 : (_selection$blockchain3 = selection.blockchain) === null || _selection$blockchain3 === void 0 ? void 0 : _selection$blockchain3.name) || (selection === null || selection === void 0 ? void 0 : selection.blockchain) || (selection === null || selection === void 0 ? void 0 : (_selection$collection3 = selection.collection) === null || _selection$collection3 === void 0 ? void 0 : _selection$collection3.blockchain))) === null || _Blockchain$findByNam === void 0 ? void 0 : _Blockchain$findByNam.logo
22525
+ })), /*#__PURE__*/React__default["default"].createElement("div", {
22526
+ className: "CardBody FontSizeM"
22527
+ }, (_Blockchain$findByNam2 = web3Blockchains.Blockchain.findByName((selection === null || selection === void 0 ? void 0 : (_selection$blockchain4 = selection.blockchain) === null || _selection$blockchain4 === void 0 ? void 0 : _selection$blockchain4.name) || (selection === null || selection === void 0 ? void 0 : selection.blockchain) || (selection === null || selection === void 0 ? void 0 : (_selection$collection4 = selection.collection) === null || _selection$collection4 === void 0 ? void 0 : _selection$collection4.blockchain))) === null || _Blockchain$findByNam2 === void 0 ? void 0 : _Blockchain$findByNam2.label), /*#__PURE__*/React__default["default"].createElement("div", {
22528
+ className: "CardAction"
22529
+ }, /*#__PURE__*/React__default["default"].createElement(ChevronRight, null))))), idRequired && /*#__PURE__*/React__default["default"].createElement("div", null, /*#__PURE__*/React__default["default"].createElement("div", {
22530
+ className: "PaddingTopXS TextLeft"
22531
+ }, /*#__PURE__*/React__default["default"].createElement("label", {
22532
+ htmlFor: "DePayWidgetsEnterNFTTokenId"
22533
+ }, /*#__PURE__*/React__default["default"].createElement("span", {
22534
+ className: "FontSizeM Opacity05"
22535
+ }, "Enter Token ID"))), /*#__PURE__*/React__default["default"].createElement("div", {
22536
+ className: "PaddingTopXS PaddingBottomS TextLeft"
22537
+ }, /*#__PURE__*/React__default["default"].createElement("input", {
22538
+ id: "DePayWidgetsEnterNFTTokenId",
22539
+ name: "DePayWidgetsEnterNFTTokenId",
22540
+ value: id,
22541
+ onChange: function onChange(event) {
22542
+ return setId(event.target.value);
22543
+ },
22544
+ className: "Search"
22545
+ }))), /*#__PURE__*/React__default["default"].createElement("div", null, /*#__PURE__*/React__default["default"].createElement("div", {
22546
+ className: "PaddingTopXS TextLeft"
22547
+ }, /*#__PURE__*/React__default["default"].createElement("label", {
22548
+ htmlFor: "DePayWidgetsEnterNFTName"
22549
+ }, /*#__PURE__*/React__default["default"].createElement("span", {
22550
+ className: "FontSizeM Opacity05"
22551
+ }, "Enter NFT Name"))), /*#__PURE__*/React__default["default"].createElement("div", {
22552
+ className: "PaddingTopXS PaddingBottomS TextLeft"
22553
+ }, /*#__PURE__*/React__default["default"].createElement("input", {
22554
+ id: "DePayWidgetsEnterNFTName",
22555
+ name: "DePayWidgetsEnterNFTName",
22556
+ value: name,
22557
+ onChange: function onChange(event) {
22558
+ return setName(event.target.value);
22559
+ },
22560
+ placeholder: "CryptoPunks",
22561
+ className: "Search"
22562
+ }))), /*#__PURE__*/React__default["default"].createElement("div", null, /*#__PURE__*/React__default["default"].createElement("div", {
22563
+ className: "PaddingTopXS TextLeft"
22564
+ }, /*#__PURE__*/React__default["default"].createElement("label", {
22565
+ htmlFor: "DePayWidgetsEnterNFTImage"
22566
+ }, /*#__PURE__*/React__default["default"].createElement("span", {
22567
+ className: "FontSizeM Opacity05"
22568
+ }, "Enter Image URL"))), /*#__PURE__*/React__default["default"].createElement("div", {
22569
+ className: "PaddingTopXS PaddingBottomS TextLeft"
22570
+ }, /*#__PURE__*/React__default["default"].createElement("input", {
22571
+ id: "DePayWidgetsEnterNFTImage",
22572
+ name: "DePayWidgetsEnterNFTImage",
22573
+ value: image,
22574
+ onChange: function onChange(event) {
22575
+ return setImage(event.target.value);
22576
+ },
22577
+ placeholder: "https://i.seadn.io/gae/BdxvLseXcfl57BiuQcQYdJ64v-aI8din7WPk0Pgo3qQFhAUH-B6i-dCqqc_mCkRIzULmwzwecnohLhrcH8A9mpWIZqA7ygc52Sr81hE?auto=format&w=128",
22578
+ className: "Search"
22579
+ }))), /*#__PURE__*/React__default["default"].createElement("div", null, /*#__PURE__*/React__default["default"].createElement("div", {
22580
+ className: "PaddingTopXS TextLeft"
22581
+ }, /*#__PURE__*/React__default["default"].createElement("label", {
22582
+ htmlFor: "DePayWidgetsEnterNFTLink"
22583
+ }, /*#__PURE__*/React__default["default"].createElement("span", {
22584
+ className: "FontSizeM Opacity05"
22585
+ }, "Enter Link URL"))), /*#__PURE__*/React__default["default"].createElement("div", {
22586
+ className: "PaddingTopXS PaddingBottomS TextLeft"
22587
+ }, /*#__PURE__*/React__default["default"].createElement("input", {
22588
+ id: "DePayWidgetsEnterNFTLink",
22589
+ name: "DePayWidgetsEnterNFTLink",
22590
+ value: link,
22591
+ onChange: function onChange(event) {
22592
+ return setLink(event.target.value);
22593
+ },
22594
+ placeholder: "https://opensea.io/collection/cryptopunks",
22595
+ className: "Search"
22596
+ })))),
22597
+ footer: /*#__PURE__*/React__default["default"].createElement("div", {
22598
+ className: "PaddingTopS PaddingRightM PaddingLeftM PaddingBottomM"
22599
+ }, /*#__PURE__*/React__default["default"].createElement("button", {
22600
+ className: ['ButtonPrimary', !image.length || !link.length || !name.length || idRequired && !id.length ? 'disabled' : ''].join(' '),
22601
+ onClick: function onClick() {
22602
+ if (!image.length || !link.length || !name.length || idRequired && !id.length) {
22603
+ return;
22604
+ }
22605
+ confirm();
22606
+ }
22607
+ }, "Continue"))
22608
+ });
22609
+ });
22610
+
22396
22611
  var SelectBlockchainDialog = (function (props) {
22397
22612
  var _useContext = React.useContext(SelectionContext),
22398
22613
  setSelection = _useContext.setSelection;
22399
22614
  var _useContext2 = React.useContext(reactDialogStack.NavigateStackContext),
22400
22615
  navigate = _useContext2.navigate;
22401
- var stacked = Object.keys(props.selection).length > 1;
22616
+ var stacked = props.stacked || Object.keys(props.selection).length > 1;
22402
22617
  var blockchains = [web3Blockchains.Blockchain.findByName('ethereum'), web3Blockchains.Blockchain.findByName('bsc'), web3Blockchains.Blockchain.findByName('polygon')];
22403
22618
  var selectBlockchain = function selectBlockchain(blockchain) {
22404
22619
  window._depay_token_selection_selected_blockchain = blockchain.name;
22405
22620
  setSelection(Object.assign(props.selection, {
22406
22621
  blockchain: blockchain
22407
22622
  }));
22408
- if (stacked) {
22623
+ if (stacked && props.navigateBack !== false) {
22409
22624
  navigate('back');
22410
22625
  } else {
22411
22626
  props.resolve(blockchain);
@@ -22431,7 +22646,7 @@
22431
22646
  });
22432
22647
  return /*#__PURE__*/React__default["default"].createElement(Dialog$1, {
22433
22648
  header: /*#__PURE__*/React__default["default"].createElement("div", {
22434
- className: "PaddingTopS PaddingLeftM PaddingRightM TextLeft"
22649
+ className: "PaddingTopS PaddingLeftM PaddingRightM"
22435
22650
  }, /*#__PURE__*/React__default["default"].createElement("div", null, /*#__PURE__*/React__default["default"].createElement("h1", {
22436
22651
  className: "LineHeightL FontSizeL"
22437
22652
  }, "Select Blockchain"))),
@@ -22446,110 +22661,741 @@
22446
22661
  });
22447
22662
  });
22448
22663
 
22449
- var SelectTokenDialog = (function (props) {
22664
+ var BLOCKCHAIN_NAMES$1 = {
22665
+ 'ethereum': 'ethereum',
22666
+ 'matic': 'polygon,'
22667
+ };
22668
+ var SelectNFTContractOnOpenSeaDialog = (function (props) {
22450
22669
  var _useContext = React.useContext(reactDialogStack.NavigateStackContext),
22451
22670
  navigate = _useContext.navigate;
22452
- var _useContext2 = React.useContext(ClosableContext),
22453
- setOpen = _useContext2.setOpen;
22454
- var _useContext3 = React.useContext(SelectionContext),
22455
- setSelection = _useContext3.setSelection;
22456
22671
  var _useState = React.useState(''),
22457
22672
  _useState2 = _slicedToArray(_useState, 2),
22458
22673
  searchTerm = _useState2[0],
22459
22674
  setSearchTerm = _useState2[1];
22460
- var _useState3 = React.useState(),
22675
+ var _useState3 = React.useState(false),
22461
22676
  _useState4 = _slicedToArray(_useState3, 2),
22462
- blockchain = _useState4[0],
22463
- setBlockchain = _useState4[1];
22464
- var _useState5 = React.useState(false),
22677
+ loading = _useState4[0],
22678
+ setLoading = _useState4[1];
22679
+ var _useState5 = React.useState([]),
22465
22680
  _useState6 = _slicedToArray(_useState5, 2),
22466
- showAddToken = _useState6[0],
22467
- setShowAddToken = _useState6[1];
22468
- var _useState7 = React.useState([]),
22469
- _useState8 = _slicedToArray(_useState7, 2),
22470
- tokens = _useState8[0],
22471
- setTokens = _useState8[1];
22472
- var _useState9 = React.useState(),
22473
- _useState10 = _slicedToArray(_useState9, 2);
22474
- _useState10[0];
22475
- _useState10[1];
22476
- var searchElement = React.useRef();
22477
- var wallet = web3Wallets.getWallets()[0];
22478
- var startWithBlockchain = function startWithBlockchain(name) {
22479
- var blockchain = web3Blockchains.Blockchain.findByName(name);
22480
- setBlockchain(blockchain);
22681
+ searchResults = _useState6[0],
22682
+ setSearchResults = _useState6[1];
22683
+ var _useContext2 = React.useContext(SelectionContext),
22684
+ setSelection = _useContext2.setSelection;
22685
+ var select = function select(nft) {
22481
22686
  setSelection(Object.assign(props.selection, {
22482
- blockchain: blockchain,
22483
- token: undefined
22687
+ nft: nft
22484
22688
  }));
22485
- setTokens(blockchain.tokens);
22689
+ navigate('ConfirmNFTSelection');
22486
22690
  };
22487
- React.useEffect(function () {
22488
- if (wallet) {
22489
- wallet.connectedTo().then(function (name) {
22490
- var blockchain = web3Blockchains.Blockchain.findByName(name);
22491
- if (window._depay_token_selection_selected_blockchain) {
22492
- startWithBlockchain(window._depay_token_selection_selected_blockchain);
22493
- } else if (name && name.length && blockchain && blockchain.tokens && blockchain.tokens.length) {
22494
- startWithBlockchain(name);
22495
- } else {
22496
- startWithBlockchain('ethereum');
22691
+ var dataForCollectionViaAsset = function dataForCollectionViaAsset(address) {
22692
+ return new Promise(function (resolve, reject) {
22693
+ fetch("https://api.opensea.io/api/v1/assets?asset_contract_address=".concat(address)).then(function (response) {
22694
+ if (response.status != 200) {
22695
+ return resolve();
22497
22696
  }
22498
- });
22499
- } else {
22500
- startWithBlockchain('ethereum');
22501
- }
22502
- }, []);
22503
- React.useEffect(function () {
22504
- if (props.selection.blockchain) {
22505
- setBlockchain(props.selection.blockchain);
22506
- setTokens(props.selection.blockchain.tokens);
22507
- if (searchElement.current) {
22508
- searchElement.current.value = '';
22509
- searchElement.current.focus();
22510
- }
22511
- }
22512
- }, [props.selection, props.selection.blockchain]);
22513
- var onClickChangeBlockchain = function onClickChangeBlockchain() {
22514
- navigate('SelectBlockchain');
22515
- };
22516
- var onClickAddToken = function onClickAddToken() {
22517
- setShowAddToken(true);
22518
- if (searchElement.current) {
22519
- searchElement.current.value = '';
22520
- searchElement.current.focus();
22521
- }
22522
- };
22523
- var searchTokens = React.useCallback(lodash.debounce(function (term, blockchainName) {
22524
- fetch("https://public.depay.com/tokens/search?blockchain=".concat(blockchainName, "&term=").concat(term)).then(function (response) {
22525
- if (response.status == 200) {
22526
- response.json().then(function (tokens) {
22527
- setTokens(tokens);
22697
+ response.json().then(function (data) {
22698
+ return resolve(data.assets ? data.assets[0] : undefined);
22528
22699
  })["catch"](function () {
22529
- return reject;
22700
+ return resolve();
22530
22701
  });
22531
- } else {
22532
- reject();
22702
+ })["catch"](function () {
22703
+ return resolve();
22704
+ });
22705
+ });
22706
+ };
22707
+ var searchContract = React.useCallback(lodash.debounce(function (address) {
22708
+ fetch("https://api.opensea.io/api/v1/asset_contract/".concat(address)).then(function (response) {
22709
+ if (response.status != 200) {
22710
+ setLoading(false);
22711
+ return;
22533
22712
  }
22713
+ response.json().then( /*#__PURE__*/function () {
22714
+ var _ref = _asyncToGenerator( /*#__PURE__*/regenerator.mark(function _callee(data) {
22715
+ var result, blockchain, holders, additionalData, _additionalData$colle, _additionalData$colle2, _additionalData$colle3, _additionalData$colle4, _additionalData, _blockchain;
22716
+ return regenerator.wrap(function _callee$(_context) {
22717
+ while (1) switch (_context.prev = _context.next) {
22718
+ case 0:
22719
+ if (!(data.asset_contract_type == 'non-fungible')) {
22720
+ _context.next = 8;
22721
+ break;
22722
+ }
22723
+ _context.next = 3;
22724
+ return dataForCollectionViaAsset(address);
22725
+ case 3:
22726
+ additionalData = _context.sent;
22727
+ if (additionalData) {
22728
+ blockchain = additionalData !== null && additionalData !== void 0 && additionalData.permalink.match(/https:\/\/opensea\.io\/assets\/(\w*)\//) ? BLOCKCHAIN_NAMES$1[additionalData.permalink.match(/https:\/\/opensea\.io\/assets\/(\w*)\//)[1]] : undefined;
22729
+ holders = additionalData === null || additionalData === void 0 ? void 0 : (_additionalData$colle = additionalData.collection) === null || _additionalData$colle === void 0 ? void 0 : (_additionalData$colle2 = _additionalData$colle.stats) === null || _additionalData$colle2 === void 0 ? void 0 : _additionalData$colle2.num_owners;
22730
+ }
22731
+ result = {
22732
+ blockchain: blockchain,
22733
+ holders: holders,
22734
+ createdAt: data.created_date,
22735
+ image: data.image_url,
22736
+ name: data.collection ? data.collection.name : undefined,
22737
+ link: data.collection ? "https://opensea.io/collection/".concat(data.collection.slug) : undefined,
22738
+ address: ethers.ethers.utils.getAddress(data.address),
22739
+ type: '721'
22740
+ };
22741
+ _context.next = 22;
22742
+ break;
22743
+ case 8:
22744
+ if (!(data.asset_contract_type == 'semi-fungible')) {
22745
+ _context.next = 21;
22746
+ break;
22747
+ }
22748
+ if (!(data.symbol == 'OPENSTORE' && data.name == 'OpenSea Collection')) {
22749
+ _context.next = 13;
22750
+ break;
22751
+ }
22752
+ result = {
22753
+ id: null,
22754
+ address: ethers.ethers.utils.getAddress(data.address),
22755
+ type: '1155'
22756
+ };
22757
+ _context.next = 19;
22758
+ break;
22759
+ case 13:
22760
+ _context.next = 15;
22761
+ return dataForCollectionViaAsset(address);
22762
+ case 15:
22763
+ _additionalData = _context.sent;
22764
+ _blockchain = _additionalData !== null && _additionalData !== void 0 && _additionalData.permalink.match(/https:\/\/opensea\.io\/assets\/(\w*)\//) ? BLOCKCHAIN_NAMES$1[_additionalData.permalink.match(/https:\/\/opensea\.io\/assets\/(\w*)\//)[1]] : undefined;
22765
+ _additionalData === null || _additionalData === void 0 ? void 0 : (_additionalData$colle3 = _additionalData.collection) === null || _additionalData$colle3 === void 0 ? void 0 : (_additionalData$colle4 = _additionalData$colle3.stats) === null || _additionalData$colle4 === void 0 ? void 0 : _additionalData$colle4.num_owners;
22766
+ result = {
22767
+ blockchain: _blockchain,
22768
+ id: null,
22769
+ createdAt: data.created_date,
22770
+ image: data.image_url,
22771
+ name: data.collection ? data.collection.name : undefined,
22772
+ link: data.collection ? "https://opensea.io/collection/".concat(data.collection.slug) : undefined,
22773
+ address: ethers.ethers.utils.getAddress(data.address),
22774
+ type: '1155'
22775
+ };
22776
+ case 19:
22777
+ _context.next = 22;
22778
+ break;
22779
+ case 21:
22780
+ // like matic/polygon (which is not yet supported by opensea apis)
22781
+ if (data.address) {
22782
+ result = {
22783
+ address: ethers.ethers.utils.getAddress(data.address)
22784
+ };
22785
+ }
22786
+ case 22:
22787
+ if (result) {
22788
+ if (result.type == undefined) {
22789
+ setSelection(Object.assign(props.selection, {
22790
+ nft: result,
22791
+ blockchain: result.blockchain || 'polygon'
22792
+ }));
22793
+ navigate('EnterNFTDataForOpenSea');
22794
+ setSearchTerm('');
22795
+ } else if (result.id !== null) {
22796
+ select(result);
22797
+ setSearchResults([result]);
22798
+ navigate('ConfirmNFTSelection');
22799
+ } else {
22800
+ setSelection(Object.assign(props.selection, {
22801
+ nft: result
22802
+ }));
22803
+ navigate('SelectNFTIdOnOpenSea');
22804
+ setSearchTerm('');
22805
+ }
22806
+ }
22807
+ setLoading(false);
22808
+ case 24:
22809
+ case "end":
22810
+ return _context.stop();
22811
+ }
22812
+ }, _callee);
22813
+ }));
22814
+ return function (_x) {
22815
+ return _ref.apply(this, arguments);
22816
+ };
22817
+ }())["catch"](function () {
22818
+ setLoading(false);
22819
+ });
22534
22820
  })["catch"](function () {
22535
- return reject;
22821
+ setLoading(false);
22536
22822
  });
22537
- }, 300), []);
22538
- var onChangeSearch = function onChangeSearch(event) {
22539
- setShowAddToken(false);
22823
+ }, 500), []);
22824
+ var onChangeTermSearch = function onChangeTermSearch(event) {
22825
+ setLoading(true);
22826
+ setSearchResults([]);
22540
22827
  var term = event.target.value;
22541
22828
  setSearchTerm(term);
22542
- if (term.match(/^0x/)) {
22543
- setTokens([]);
22544
- var token;
22545
- try {
22546
- token = new web3Tokens.Token({
22547
- blockchain: blockchain.name,
22548
- address: term
22549
- });
22550
- } catch (_unused) {}
22551
- if (token == undefined) {
22552
- return;
22829
+ if (term && term.length) {
22830
+ searchContract(term);
22831
+ } else {
22832
+ setLoading(false);
22833
+ }
22834
+ };
22835
+ var elements;
22836
+ if (loading) {
22837
+ elements = [/*#__PURE__*/React__default["default"].createElement("div", {
22838
+ className: "SkeletonWrapper",
22839
+ key: 'loading'
22840
+ }, /*#__PURE__*/React__default["default"].createElement("div", {
22841
+ className: "Skeleton",
22842
+ style: {
22843
+ height: '69px',
22844
+ width: '100%'
22845
+ }
22846
+ }, /*#__PURE__*/React__default["default"].createElement("div", {
22847
+ className: "SkeletonBackground"
22848
+ })))];
22849
+ } else {
22850
+ elements = searchResults.map(function (result, index) {
22851
+ return /*#__PURE__*/React__default["default"].createElement("div", {
22852
+ key: index,
22853
+ className: "Card Row",
22854
+ onClick: function onClick() {
22855
+ return select(result);
22856
+ }
22857
+ }, /*#__PURE__*/React__default["default"].createElement("div", {
22858
+ className: "CardImage"
22859
+ }, /*#__PURE__*/React__default["default"].createElement("img", {
22860
+ src: result.image
22861
+ })), /*#__PURE__*/React__default["default"].createElement("div", {
22862
+ className: "CardBody"
22863
+ }, /*#__PURE__*/React__default["default"].createElement("div", {
22864
+ className: "CardTokenFullName",
22865
+ title: result.name
22866
+ }, /*#__PURE__*/React__default["default"].createElement("span", {
22867
+ className: "CardText"
22868
+ }, result.name))));
22869
+ });
22870
+ }
22871
+ return /*#__PURE__*/React__default["default"].createElement(Dialog$1, {
22872
+ stacked: true,
22873
+ header: /*#__PURE__*/React__default["default"].createElement("div", {
22874
+ className: "PaddingTopS PaddingLeftM PaddingRightM"
22875
+ }, /*#__PURE__*/React__default["default"].createElement("div", null, /*#__PURE__*/React__default["default"].createElement("div", {
22876
+ className: "LineHeightL FontSizeL PaddingTopXS"
22877
+ }, /*#__PURE__*/React__default["default"].createElement("span", {
22878
+ className: "CardImage small"
22879
+ }, /*#__PURE__*/React__default["default"].createElement("img", {
22880
+ className: "transparent",
22881
+ src: OpenSea
22882
+ })))), /*#__PURE__*/React__default["default"].createElement("div", {
22883
+ className: "PaddingTopS PaddingBottomXS TextLeft"
22884
+ }, /*#__PURE__*/React__default["default"].createElement("label", {
22885
+ htmlFor: "DePayWidgetsEnterContractAddress"
22886
+ }, /*#__PURE__*/React__default["default"].createElement("span", {
22887
+ className: "FontSizeM Opacity05"
22888
+ }, "Enter contract address"))), /*#__PURE__*/React__default["default"].createElement("div", {
22889
+ className: "PaddingTopXS PaddingBottomS TextLeft"
22890
+ }, /*#__PURE__*/React__default["default"].createElement("input", {
22891
+ id: "DePayWidgetsEnterContractAddress",
22892
+ name: "DePayWidgetsEnterContractAddress",
22893
+ value: searchTerm,
22894
+ onChange: onChangeTermSearch,
22895
+ className: "Search",
22896
+ autoFocus: true,
22897
+ placeholder: "0x495f947276749ce646f68ac8c248420045cb7b5e"
22898
+ }))),
22899
+ bodyClassName: "ScrollHeight",
22900
+ body: /*#__PURE__*/React__default["default"].createElement("div", null, elements)
22901
+ });
22902
+ });
22903
+
22904
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
22905
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
22906
+ var BLOCKCHAIN_NAMES = {
22907
+ 'ethereum': 'ethereum',
22908
+ 'matic': 'polygon,'
22909
+ };
22910
+ var SelectNFTIdOnOpenSeaDialog = (function (props) {
22911
+ var _useContext = React.useContext(reactDialogStack.NavigateStackContext),
22912
+ navigate = _useContext.navigate;
22913
+ var _useState = React.useState(''),
22914
+ _useState2 = _slicedToArray(_useState, 2),
22915
+ searchTerm = _useState2[0],
22916
+ setSearchTerm = _useState2[1];
22917
+ var _useState3 = React.useState(false),
22918
+ _useState4 = _slicedToArray(_useState3, 2),
22919
+ loading = _useState4[0],
22920
+ setLoading = _useState4[1];
22921
+ var _useState5 = React.useState([]),
22922
+ _useState6 = _slicedToArray(_useState5, 2),
22923
+ searchResults = _useState6[0],
22924
+ setSearchResults = _useState6[1];
22925
+ var _useContext2 = React.useContext(SelectionContext),
22926
+ selection = _useContext2.selection,
22927
+ setSelection = _useContext2.setSelection;
22928
+ var select = function select(nft) {
22929
+ setSelection(Object.assign(props.selection, {
22930
+ nft: nft
22931
+ }));
22932
+ navigate('ConfirmNFTSelection');
22933
+ };
22934
+ var searchForCollectionById = React.useCallback(lodash.debounce(function (id) {
22935
+ fetch("https://api.opensea.io/api/v1/asset/".concat(selection.nft.address, "/").concat(id)).then(function (response) {
22936
+ if (response.status != 200) {
22937
+ return resolve();
22938
+ }
22939
+ response.json().then( /*#__PURE__*/function () {
22940
+ var _ref = _asyncToGenerator( /*#__PURE__*/regenerator.mark(function _callee(data) {
22941
+ var blockchain, result;
22942
+ return regenerator.wrap(function _callee$(_context) {
22943
+ while (1) switch (_context.prev = _context.next) {
22944
+ case 0:
22945
+ blockchain = data !== null && data !== void 0 && data.permalink.match(/https:\/\/opensea\.io\/assets\/(\w*)\//) ? BLOCKCHAIN_NAMES[data.permalink.match(/https:\/\/opensea\.io\/assets\/(\w*)\//)[1]] : undefined;
22946
+ result = _objectSpread(_objectSpread({}, selection.nft), {}, {
22947
+ blockchain: blockchain,
22948
+ id: data.token_id,
22949
+ image: data.image_url,
22950
+ name: data.name,
22951
+ link: data.permalink
22952
+ });
22953
+ setSearchResults([result]);
22954
+ select(result);
22955
+ setLoading(false);
22956
+ case 5:
22957
+ case "end":
22958
+ return _context.stop();
22959
+ }
22960
+ }, _callee);
22961
+ }));
22962
+ return function (_x) {
22963
+ return _ref.apply(this, arguments);
22964
+ };
22965
+ }())["catch"](function () {
22966
+ setLoading(false);
22967
+ });
22968
+ })["catch"](function () {
22969
+ setLoading(false);
22970
+ });
22971
+ }, 500), []);
22972
+ var onChangeTermSearch = function onChangeTermSearch(event) {
22973
+ setLoading(true);
22974
+ setSearchResults([]);
22975
+ var term = event.target.value;
22976
+ setSearchTerm(term);
22977
+ if (term && term.length) {
22978
+ searchForCollectionById(term);
22979
+ } else {
22980
+ setLoading(false);
22981
+ }
22982
+ };
22983
+ React.useEffect(function () {
22984
+ fetch("https://api.opensea.io/api/v1/assets?asset_contract_address=".concat(selection.nft.address)).then(function (response) {
22985
+ if (response.status != 200) {
22986
+ return resolve();
22987
+ }
22988
+ response.json().then(function (data) {
22989
+ if (data.assets.length <= 6) {
22990
+ var results = data.assets.map(function (data) {
22991
+ var blockchain = data !== null && data !== void 0 && data.permalink.match(/https:\/\/opensea\.io\/assets\/(\w*)\//) ? BLOCKCHAIN_NAMES[data.permalink.match(/https:\/\/opensea\.io\/assets\/(\w*)\//)[1]] : undefined;
22992
+ return _objectSpread(_objectSpread({}, selection.nft), {}, {
22993
+ blockchain: blockchain,
22994
+ id: data.token_id,
22995
+ image: data.image_url,
22996
+ name: data.name,
22997
+ link: data.permalink
22998
+ });
22999
+ });
23000
+ setSearchResults(results);
23001
+ if (results.length == 1) {
23002
+ select(results[0]);
23003
+ }
23004
+ }
23005
+ });
23006
+ });
23007
+ }, []);
23008
+ var elements;
23009
+ if (loading) {
23010
+ elements = [/*#__PURE__*/React__default["default"].createElement("div", {
23011
+ className: "SkeletonWrapper",
23012
+ key: 'loading'
23013
+ }, /*#__PURE__*/React__default["default"].createElement("div", {
23014
+ className: "Skeleton",
23015
+ style: {
23016
+ height: '69px',
23017
+ width: '100%'
23018
+ }
23019
+ }, /*#__PURE__*/React__default["default"].createElement("div", {
23020
+ className: "SkeletonBackground"
23021
+ })))];
23022
+ } else {
23023
+ elements = searchResults.map(function (result, index) {
23024
+ return /*#__PURE__*/React__default["default"].createElement("div", {
23025
+ key: index,
23026
+ className: "Card Row",
23027
+ onClick: function onClick() {
23028
+ return select(result);
23029
+ }
23030
+ }, /*#__PURE__*/React__default["default"].createElement("div", {
23031
+ className: "CardImage"
23032
+ }, /*#__PURE__*/React__default["default"].createElement("img", {
23033
+ src: result.image
23034
+ })), /*#__PURE__*/React__default["default"].createElement("div", {
23035
+ className: "CardBody"
23036
+ }, /*#__PURE__*/React__default["default"].createElement("div", {
23037
+ className: "CardTokenFullName",
23038
+ title: result.name
23039
+ }, /*#__PURE__*/React__default["default"].createElement("span", {
23040
+ className: "CardText"
23041
+ }, result.name))));
23042
+ });
23043
+ }
23044
+ return /*#__PURE__*/React__default["default"].createElement(Dialog$1, {
23045
+ stacked: true,
23046
+ header: /*#__PURE__*/React__default["default"].createElement("div", {
23047
+ className: "PaddingTopS PaddingLeftM PaddingRightM"
23048
+ }, /*#__PURE__*/React__default["default"].createElement("div", null, /*#__PURE__*/React__default["default"].createElement("div", {
23049
+ className: "LineHeightL FontSizeL PaddingTopXS"
23050
+ }, /*#__PURE__*/React__default["default"].createElement("span", {
23051
+ className: "CardImage small"
23052
+ }, /*#__PURE__*/React__default["default"].createElement("img", {
23053
+ className: "transparent",
23054
+ src: OpenSea
23055
+ })))), /*#__PURE__*/React__default["default"].createElement("div", {
23056
+ className: "PaddingTopS PaddingBottomXS TextLeft"
23057
+ }, /*#__PURE__*/React__default["default"].createElement("label", {
23058
+ htmlFor: "DePayWidgetsEnterCollectionId"
23059
+ }, /*#__PURE__*/React__default["default"].createElement("span", {
23060
+ className: "FontSizeM Opacity05"
23061
+ }, "Enter Token ID"))), /*#__PURE__*/React__default["default"].createElement("div", {
23062
+ className: "PaddingTopXS PaddingBottomS TextLeft"
23063
+ }, /*#__PURE__*/React__default["default"].createElement("input", {
23064
+ id: "DePayWidgetsEnterCollectionId",
23065
+ name: "DePayWidgetsEnterCollectionId",
23066
+ value: searchTerm,
23067
+ onChange: onChangeTermSearch,
23068
+ className: "Search",
23069
+ placeholder: "35347623114821255323888368639026081793120226253597860997754787918389704654849"
23070
+ }))),
23071
+ bodyClassName: "ScrollHeight",
23072
+ body: /*#__PURE__*/React__default["default"].createElement("div", null, elements)
23073
+ });
23074
+ });
23075
+
23076
+ var SelectNFTPlatformDialog = (function (props) {
23077
+ var _useContext = React.useContext(reactDialogStack.NavigateStackContext),
23078
+ navigate = _useContext.navigate;
23079
+ var select = function select(marketplace) {
23080
+ navigate(marketplace.navigate);
23081
+ };
23082
+ var elements = [{
23083
+ name: 'OpenSea',
23084
+ navigate: 'SelectNFTContractOnOpenSea',
23085
+ logo: OpenSea
23086
+ }].map(function (marketplace, index) {
23087
+ return /*#__PURE__*/React__default["default"].createElement("div", {
23088
+ key: index,
23089
+ className: "Card Row",
23090
+ onClick: function onClick() {
23091
+ return select(marketplace);
23092
+ }
23093
+ }, /*#__PURE__*/React__default["default"].createElement("div", {
23094
+ className: "CardImage"
23095
+ }, /*#__PURE__*/React__default["default"].createElement("img", {
23096
+ src: marketplace.logo
23097
+ })), /*#__PURE__*/React__default["default"].createElement("div", {
23098
+ className: "CardBody"
23099
+ }, /*#__PURE__*/React__default["default"].createElement("div", {
23100
+ className: "CardTokenSymbol",
23101
+ title: marketplace.name
23102
+ }, /*#__PURE__*/React__default["default"].createElement("span", {
23103
+ className: "CardText"
23104
+ }, marketplace.name)), /*#__PURE__*/React__default["default"].createElement("div", {
23105
+ className: "CardTokenName PaddingTopXS"
23106
+ }, /*#__PURE__*/React__default["default"].createElement(ChevronRight, null))));
23107
+ });
23108
+ return /*#__PURE__*/React__default["default"].createElement(Dialog$1, {
23109
+ header: /*#__PURE__*/React__default["default"].createElement("div", {
23110
+ className: "PaddingTopS PaddingLeftM PaddingRightM TextLeft"
23111
+ }, /*#__PURE__*/React__default["default"].createElement("div", null, /*#__PURE__*/React__default["default"].createElement("h1", {
23112
+ className: "LineHeightL FontSizeL"
23113
+ }, "Select NFT")), /*#__PURE__*/React__default["default"].createElement("div", {
23114
+ className: "PaddingTopXS PaddingBottomS"
23115
+ }, /*#__PURE__*/React__default["default"].createElement("span", {
23116
+ className: "FontSizeM Opacity05"
23117
+ }, "Choose which marketplace"))),
23118
+ bodyClassName: "ScrollHeight",
23119
+ body: /*#__PURE__*/React__default["default"].createElement("div", {
23120
+ className: ""
23121
+ }, elements)
23122
+ });
23123
+ });
23124
+
23125
+ var SelectNFTStack = (function (props) {
23126
+ var _ref;
23127
+ var _useContext = React.useContext(ConfigurationContext),
23128
+ what = _useContext.what;
23129
+ var _useContext2 = React.useContext(ClosableContext),
23130
+ open = _useContext2.open,
23131
+ close = _useContext2.close;
23132
+ var _useContext3 = React.useContext(SelectionContext),
23133
+ selection = _useContext3.selection;
23134
+ _useContext3.setSelection;
23135
+ var _useState = React.useState(),
23136
+ _useState2 = _slicedToArray(_useState, 2);
23137
+ _useState2[0];
23138
+ var _setNavigator = _useState2[1];
23139
+ var start;
23140
+ switch (what) {
23141
+ default:
23142
+ start = 'SelectMarketplace';
23143
+ }
23144
+ return /*#__PURE__*/React__default["default"].createElement(reactDialogStack.ReactDialogStack, {
23145
+ open: open,
23146
+ close: close,
23147
+ start: start,
23148
+ container: props.container,
23149
+ document: props.document,
23150
+ setNavigator: function setNavigator(navigator) {
23151
+ _setNavigator(navigator);
23152
+ },
23153
+ dialogs: (_ref = {
23154
+ SelectMarketplace: /*#__PURE__*/React__default["default"].createElement(SelectNFTPlatformDialog, {
23155
+ selection: selection,
23156
+ resolve: props.resolve,
23157
+ unmount: props.unmount
23158
+ }),
23159
+ SelectNFTContractOnOpenSea: /*#__PURE__*/React__default["default"].createElement(SelectNFTContractOnOpenSeaDialog, {
23160
+ selection: selection,
23161
+ resolve: props.resolve,
23162
+ unmount: props.unmount
23163
+ }),
23164
+ SelectNFTIdOnOpenSea: /*#__PURE__*/React__default["default"].createElement(SelectNFTIdOnOpenSeaDialog, {
23165
+ selection: selection,
23166
+ resolve: props.resolve,
23167
+ unmount: props.unmount
23168
+ }),
23169
+ SelectBlockchain: /*#__PURE__*/React__default["default"].createElement(SelectNFTIdOnOpenSeaDialog, {
23170
+ selection: selection,
23171
+ resolve: props.resolve,
23172
+ unmount: props.unmount
23173
+ }),
23174
+ EnterNFTDataForOpenSea: /*#__PURE__*/React__default["default"].createElement(EnterNFTDataForOpenSeaDialog, {
23175
+ selection: selection,
23176
+ resolve: props.resolve,
23177
+ unmount: props.unmount
23178
+ })
23179
+ }, _defineProperty(_ref, "SelectBlockchain", /*#__PURE__*/React__default["default"].createElement(SelectBlockchainDialog, {
23180
+ selection: selection,
23181
+ stacked: true,
23182
+ resolve: props.resolve,
23183
+ unmount: props.unmount
23184
+ })), _defineProperty(_ref, "ConfirmNFTSelection", /*#__PURE__*/React__default["default"].createElement(ConfirmNFTSelectionDialog, {
23185
+ selection: selection,
23186
+ resolve: props.resolve,
23187
+ unmount: props.unmount
23188
+ })), _ref)
23189
+ });
23190
+ });
23191
+
23192
+ var ConfirmTokenSelectionDialog = (function (props) {
23193
+ var _useContext = React.useContext(SelectionContext),
23194
+ selection = _useContext.selection;
23195
+ var _useContext2 = React.useContext(ClosableContext),
23196
+ setOpen = _useContext2.setOpen;
23197
+ var token = selection.token;
23198
+ var address = token.address || token.external_id;
23199
+ var logo = token.logo || token.image;
23200
+ var blockchain = web3Blockchains.Blockchain.findByName(token.blockchain);
23201
+ var age = token.first_transfer ? msToTime(new Date() - new Date(token.first_transfer)) : undefined;
23202
+ if (age) {
23203
+ 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) {
23204
+ return n;
23205
+ }).join(' ');
23206
+ }
23207
+ var holders = token.unique_senders ? token.unique_senders : undefined;
23208
+ if (holders) {
23209
+ if (holders > 1000000) {
23210
+ holders = "Millions";
23211
+ } else if (holders > 100000) {
23212
+ holders = "Hundreds of Thousands";
23213
+ } else if (holders > 2000) {
23214
+ holders = "Thousands";
23215
+ } else if (holders > 100) {
23216
+ holders = "Hundreds";
23217
+ } else {
23218
+ holders = "Only a Few!!!";
23219
+ }
23220
+ }
23221
+ var onClickConfirm = function onClickConfirm() {
23222
+ setOpen(false);
23223
+ props.resolve({
23224
+ blockchain: token.blockchain,
23225
+ address: token.external_id || token.address,
23226
+ symbol: token.symbol,
23227
+ name: token.name,
23228
+ decimals: token.decimals,
23229
+ logo: token.image || token.logo,
23230
+ routable: token.routable
23231
+ });
23232
+ setTimeout(props.unmount, 300);
23233
+ };
23234
+ return /*#__PURE__*/React__default["default"].createElement(Dialog$1, {
23235
+ header: /*#__PURE__*/React__default["default"].createElement("div", {
23236
+ className: "PaddingTopS PaddingLeftM PaddingRightM"
23237
+ }, /*#__PURE__*/React__default["default"].createElement("div", null, /*#__PURE__*/React__default["default"].createElement("h1", {
23238
+ className: "LineHeightL FontSizeL"
23239
+ }, "Confirm Selection"))),
23240
+ stacked: true,
23241
+ body: /*#__PURE__*/React__default["default"].createElement("div", {
23242
+ className: "PaddingTopS PaddingLeftM PaddingRightM"
23243
+ }, /*#__PURE__*/React__default["default"].createElement("div", {
23244
+ className: "TokenImage medium TextCenter"
23245
+ }, logo && /*#__PURE__*/React__default["default"].createElement("img", {
23246
+ src: logo
23247
+ }), !logo && /*#__PURE__*/React__default["default"].createElement(reactTokenImage.TokenImage, {
23248
+ blockchain: token.blockchain,
23249
+ address: address
23250
+ })), /*#__PURE__*/React__default["default"].createElement("div", {
23251
+ className: "PaddingTopS TextCenter"
23252
+ }, /*#__PURE__*/React__default["default"].createElement("div", {
23253
+ className: "Alert FontSizeS"
23254
+ }, /*#__PURE__*/React__default["default"].createElement("strong", null, "Please review this information"))), /*#__PURE__*/React__default["default"].createElement("div", {
23255
+ className: "PaddingTopXS"
23256
+ }, /*#__PURE__*/React__default["default"].createElement("table", {
23257
+ className: "Table TextLeft FontSizeS"
23258
+ }, /*#__PURE__*/React__default["default"].createElement("tbody", null, /*#__PURE__*/React__default["default"].createElement("tr", null, /*#__PURE__*/React__default["default"].createElement("td", null, /*#__PURE__*/React__default["default"].createElement("div", {
23259
+ className: "TableSubTitle"
23260
+ }, "Address")), /*#__PURE__*/React__default["default"].createElement("td", null, /*#__PURE__*/React__default["default"].createElement("div", null, /*#__PURE__*/React__default["default"].createElement("a", {
23261
+ className: "Link",
23262
+ title: address,
23263
+ href: blockchain.explorerUrlFor({
23264
+ token: address
23265
+ }),
23266
+ target: "_blank",
23267
+ rel: "noopener noreferrer"
23268
+ }, addressEllipsis(address, 8))))), /*#__PURE__*/React__default["default"].createElement("tr", null, /*#__PURE__*/React__default["default"].createElement("td", null, /*#__PURE__*/React__default["default"].createElement("div", {
23269
+ className: "TableSubTitle"
23270
+ }, "Blockchain")), /*#__PURE__*/React__default["default"].createElement("td", null, /*#__PURE__*/React__default["default"].createElement("div", null, blockchain.label))), /*#__PURE__*/React__default["default"].createElement("tr", null, /*#__PURE__*/React__default["default"].createElement("td", null, /*#__PURE__*/React__default["default"].createElement("div", {
23271
+ className: "TableSubTitle"
23272
+ }, "Symbol")), /*#__PURE__*/React__default["default"].createElement("td", null, /*#__PURE__*/React__default["default"].createElement("div", null, token.symbol))), /*#__PURE__*/React__default["default"].createElement("tr", null, /*#__PURE__*/React__default["default"].createElement("td", null, /*#__PURE__*/React__default["default"].createElement("div", {
23273
+ className: "TableSubTitle"
23274
+ }, "Name")), /*#__PURE__*/React__default["default"].createElement("td", null, /*#__PURE__*/React__default["default"].createElement("div", null, token.name))), age && /*#__PURE__*/React__default["default"].createElement("tr", null, /*#__PURE__*/React__default["default"].createElement("td", null, /*#__PURE__*/React__default["default"].createElement("div", {
23275
+ className: "TableSubTitle"
23276
+ }, "Age")), /*#__PURE__*/React__default["default"].createElement("td", null, /*#__PURE__*/React__default["default"].createElement("div", null, age))), holders && /*#__PURE__*/React__default["default"].createElement("tr", null, /*#__PURE__*/React__default["default"].createElement("td", null, /*#__PURE__*/React__default["default"].createElement("div", {
23277
+ className: "TableSubTitle"
23278
+ }, "Holders")), /*#__PURE__*/React__default["default"].createElement("td", null, /*#__PURE__*/React__default["default"].createElement("div", null, holders))))))),
23279
+ footer: /*#__PURE__*/React__default["default"].createElement("div", {
23280
+ className: "PaddingTopS PaddingRightM PaddingLeftM PaddingBottomS"
23281
+ }, /*#__PURE__*/React__default["default"].createElement("button", {
23282
+ className: "ButtonPrimary",
23283
+ onClick: onClickConfirm
23284
+ }, "Confirm"))
23285
+ });
23286
+ });
23287
+
23288
+ var SelectTokenDialog = (function (props) {
23289
+ var _useContext = React.useContext(reactDialogStack.NavigateStackContext),
23290
+ navigate = _useContext.navigate;
23291
+ var _useContext2 = React.useContext(ClosableContext),
23292
+ setOpen = _useContext2.setOpen;
23293
+ var _useContext3 = React.useContext(SelectionContext),
23294
+ setSelection = _useContext3.setSelection;
23295
+ var _useState = React.useState(false),
23296
+ _useState2 = _slicedToArray(_useState, 2),
23297
+ loading = _useState2[0],
23298
+ setLoading = _useState2[1];
23299
+ var _useState3 = React.useState(''),
23300
+ _useState4 = _slicedToArray(_useState3, 2),
23301
+ searchTerm = _useState4[0],
23302
+ setSearchTerm = _useState4[1];
23303
+ var _useState5 = React.useState(),
23304
+ _useState6 = _slicedToArray(_useState5, 2),
23305
+ blockchain = _useState6[0],
23306
+ setBlockchain = _useState6[1];
23307
+ var _useState7 = React.useState(false),
23308
+ _useState8 = _slicedToArray(_useState7, 2),
23309
+ showAddToken = _useState8[0],
23310
+ setShowAddToken = _useState8[1];
23311
+ var _useState9 = React.useState([]),
23312
+ _useState10 = _slicedToArray(_useState9, 2),
23313
+ tokens = _useState10[0],
23314
+ setTokens = _useState10[1];
23315
+ var _useState11 = React.useState(),
23316
+ _useState12 = _slicedToArray(_useState11, 2);
23317
+ _useState12[0];
23318
+ _useState12[1];
23319
+ var searchElement = React.useRef();
23320
+ var wallet = web3Wallets.getWallets()[0];
23321
+ var startWithBlockchain = function startWithBlockchain(name) {
23322
+ var blockchain = web3Blockchains.Blockchain.findByName(name);
23323
+ setBlockchain(blockchain);
23324
+ setSelection(Object.assign(props.selection, {
23325
+ blockchain: blockchain,
23326
+ token: undefined
23327
+ }));
23328
+ setTokens(blockchain.tokens);
23329
+ };
23330
+ React.useEffect(function () {
23331
+ if (wallet) {
23332
+ wallet.connectedTo().then(function (name) {
23333
+ var blockchain = web3Blockchains.Blockchain.findByName(name);
23334
+ if (window._depay_token_selection_selected_blockchain) {
23335
+ startWithBlockchain(window._depay_token_selection_selected_blockchain);
23336
+ } else if (name && name.length && blockchain && blockchain.tokens && blockchain.tokens.length) {
23337
+ startWithBlockchain(name);
23338
+ } else {
23339
+ startWithBlockchain('ethereum');
23340
+ }
23341
+ });
23342
+ } else {
23343
+ startWithBlockchain('ethereum');
23344
+ }
23345
+ }, []);
23346
+ React.useEffect(function () {
23347
+ if (props.selection.blockchain) {
23348
+ setBlockchain(props.selection.blockchain);
23349
+ setTokens(props.selection.blockchain.tokens);
23350
+ if (searchElement.current) {
23351
+ searchElement.current.value = '';
23352
+ searchElement.current.focus();
23353
+ }
23354
+ }
23355
+ }, [props.selection, props.selection.blockchain]);
23356
+ var onClickChangeBlockchain = function onClickChangeBlockchain() {
23357
+ navigate('SelectBlockchain');
23358
+ };
23359
+ var onClickAddToken = function onClickAddToken() {
23360
+ setShowAddToken(true);
23361
+ if (searchElement.current) {
23362
+ searchElement.current.value = '';
23363
+ searchElement.current.focus();
23364
+ }
23365
+ };
23366
+ var searchTokens = React.useCallback(lodash.debounce(function (term, blockchainName) {
23367
+ fetch("https://public.depay.com/tokens/search?blockchain=".concat(blockchainName, "&term=").concat(term)).then(function (response) {
23368
+ if (response.status == 200) {
23369
+ response.json().then(function (tokens) {
23370
+ setTokens(tokens);
23371
+ setLoading(false);
23372
+ })["catch"](function () {
23373
+ return reject;
23374
+ });
23375
+ } else {
23376
+ reject();
23377
+ }
23378
+ })["catch"](function () {
23379
+ return reject;
23380
+ });
23381
+ }, 500), []);
23382
+ var onChangeSearch = function onChangeSearch(event) {
23383
+ setShowAddToken(false);
23384
+ setLoading(true);
23385
+ var term = event.target.value;
23386
+ setSearchTerm(term);
23387
+ if (term.match(/^0x/)) {
23388
+ setTokens([]);
23389
+ var token;
23390
+ try {
23391
+ token = new web3Tokens.Token({
23392
+ blockchain: blockchain.name,
23393
+ address: term
23394
+ });
23395
+ } catch (_unused) {}
23396
+ if (token == undefined) {
23397
+ setLoading(false);
23398
+ return;
22553
23399
  }
22554
23400
  Promise.all([token.name(), token.symbol(), token.decimals(), fetch("https://public.depay.com/tokens/routable/".concat(blockchain.name, "/").concat(term)).then(function (response) {
22555
23401
  if (response.status == 200) {
@@ -22569,12 +23415,14 @@
22569
23415
  blockchain: blockchain.name,
22570
23416
  routable: !!routable
22571
23417
  }]);
23418
+ setLoading(false);
22572
23419
  });
22573
23420
  } else if (term && term.length) {
22574
23421
  setTokens([]);
22575
23422
  searchTokens(term, blockchain.name);
22576
23423
  } else {
22577
23424
  setTokens(blockchain.tokens);
23425
+ setLoading(false);
22578
23426
  }
22579
23427
  };
22580
23428
  var select = function select(token) {
@@ -22605,36 +23453,52 @@
22605
23453
  navigate('ConfirmTokenSelection');
22606
23454
  }
22607
23455
  };
22608
- var elements = tokens.map(function (token, index) {
22609
- return /*#__PURE__*/React__default["default"].createElement("div", {
22610
- key: "".concat(index, "-").concat(token.address),
22611
- className: "Card Row",
22612
- onClick: function onClick() {
22613
- return select(token);
22614
- }
23456
+ var elements;
23457
+ if (loading) {
23458
+ elements = [/*#__PURE__*/React__default["default"].createElement("div", {
23459
+ className: "SkeletonWrapper",
23460
+ key: 'loading'
22615
23461
  }, /*#__PURE__*/React__default["default"].createElement("div", {
22616
- className: "CardImage"
22617
- }, token.logo && /*#__PURE__*/React__default["default"].createElement("img", {
22618
- src: token.logo
22619
- }), token.image && /*#__PURE__*/React__default["default"].createElement("img", {
22620
- src: token.image
22621
- }), !(token.logo || token.image) && /*#__PURE__*/React__default["default"].createElement(reactTokenImage.TokenImage, {
22622
- blockchain: token.blockchain,
22623
- address: token.external_id || token.address
22624
- })), /*#__PURE__*/React__default["default"].createElement("div", {
22625
- className: "CardBody"
23462
+ className: "Skeleton",
23463
+ style: {
23464
+ height: '69px',
23465
+ width: '100%'
23466
+ }
22626
23467
  }, /*#__PURE__*/React__default["default"].createElement("div", {
22627
- className: "CardTokenSymbol",
22628
- title: token.symbol
22629
- }, /*#__PURE__*/React__default["default"].createElement("span", {
22630
- className: "CardText"
22631
- }, token.symbol)), /*#__PURE__*/React__default["default"].createElement("div", {
22632
- className: "CardTokenName",
22633
- title: token.name
22634
- }, /*#__PURE__*/React__default["default"].createElement("span", {
22635
- className: "CardText"
22636
- }, token.name))));
22637
- });
23468
+ className: "SkeletonBackground"
23469
+ })))];
23470
+ } else {
23471
+ elements = tokens.map(function (token, index) {
23472
+ return /*#__PURE__*/React__default["default"].createElement("div", {
23473
+ key: "".concat(index, "-").concat(token.address),
23474
+ className: "Card Row",
23475
+ onClick: function onClick() {
23476
+ return select(token);
23477
+ }
23478
+ }, /*#__PURE__*/React__default["default"].createElement("div", {
23479
+ className: "CardImage"
23480
+ }, token.logo && /*#__PURE__*/React__default["default"].createElement("img", {
23481
+ src: token.logo
23482
+ }), token.image && /*#__PURE__*/React__default["default"].createElement("img", {
23483
+ src: token.image
23484
+ }), !(token.logo || token.image) && /*#__PURE__*/React__default["default"].createElement(reactTokenImage.TokenImage, {
23485
+ blockchain: token.blockchain,
23486
+ address: token.external_id || token.address
23487
+ })), /*#__PURE__*/React__default["default"].createElement("div", {
23488
+ className: "CardBody"
23489
+ }, /*#__PURE__*/React__default["default"].createElement("div", {
23490
+ className: "CardTokenSymbol",
23491
+ title: token.symbol
23492
+ }, /*#__PURE__*/React__default["default"].createElement("span", {
23493
+ className: "CardText"
23494
+ }, token.symbol)), /*#__PURE__*/React__default["default"].createElement("div", {
23495
+ className: "CardTokenName",
23496
+ title: token.name
23497
+ }, /*#__PURE__*/React__default["default"].createElement("span", {
23498
+ className: "CardText"
23499
+ }, token.name))));
23500
+ });
23501
+ }
22638
23502
  if (blockchain == undefined) {
22639
23503
  return null;
22640
23504
  }
@@ -22691,7 +23555,7 @@
22691
23555
  });
22692
23556
  });
22693
23557
 
22694
- var SelectStack = (function (props) {
23558
+ var SelectTokenStack = (function (props) {
22695
23559
  var _useContext = React.useContext(ConfigurationContext),
22696
23560
  what = _useContext.what;
22697
23561
  var _useContext2 = React.useContext(ClosableContext),
@@ -22741,7 +23605,7 @@
22741
23605
  var startupError;
22742
23606
  if (what == undefined) {
22743
23607
  startupError = '"what" needs to be configured!';
22744
- } else if (['token'].indexOf(what) < 0) {
23608
+ } else if (['token', 'nft'].indexOf(what) < 0) {
22745
23609
  startupError = "Unknown \"what\" configured: ".concat(what, "!");
22746
23610
  }
22747
23611
  return new Promise( /*#__PURE__*/function () {
@@ -22769,7 +23633,12 @@
22769
23633
  }
22770
23634
  }, /*#__PURE__*/React__default["default"].createElement(UpdatableProvider, null, /*#__PURE__*/React__default["default"].createElement(ClosableProvider, {
22771
23635
  unmount: userClosedDialog
22772
- }, /*#__PURE__*/React__default["default"].createElement(SelectionProvider, null, /*#__PURE__*/React__default["default"].createElement(SelectStack, {
23636
+ }, /*#__PURE__*/React__default["default"].createElement(SelectionProvider, null, what == 'token' && /*#__PURE__*/React__default["default"].createElement(SelectTokenStack, {
23637
+ document: document,
23638
+ container: container,
23639
+ unmount: unmount,
23640
+ resolve: resolve
23641
+ }), what == 'nft' && /*#__PURE__*/React__default["default"].createElement(SelectNFTStack, {
22773
23642
  document: document,
22774
23643
  container: container,
22775
23644
  unmount: unmount,