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