@mylozzax/mylozzax-web-components
Version:
This npm package contains a number of Lit web components.
118 lines (96 loc) • 102 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.WalletSelector = void 0;
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
var _get2 = _interopRequireDefault(require("@babel/runtime/helpers/get"));
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
var _lit = require("lit");
var _templateObject, _templateObject2, _templateObject3, _templateObject4;
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; }
function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
var WalletSelector = /*#__PURE__*/function (_LitElement) {
(0, _inherits2["default"])(WalletSelector, _LitElement);
var _super = _createSuper(WalletSelector);
function WalletSelector() {
var _this;
(0, _classCallCheck2["default"])(this, WalletSelector);
_this = _super.call(this);
_this.context = {};
_this.wallets = {};
return _this;
}
(0, _createClass2["default"])(WalletSelector, [{
key: "connectedCallback",
value: function connectedCallback() {
(0, _get2["default"])((0, _getPrototypeOf2["default"])(WalletSelector.prototype), "connectedCallback", this).call(this);
var options = {
detail: {
wallet: this.wallets[0]
},
bubbles: true,
composed: true
};
var walletOptionUpdated = new CustomEvent("wallet-selector-update", options);
this.selectedWallet = this.wallets[0];
this.dispatchEvent(walletOptionUpdated, options); // We need to emit an event to provide other web components with the initial wallet data
//this.displayOptionsDropdown = false;
// let amount = this.wallet.Balance_JSBigInt();
// let amountJSBigInt = this.wallet.UnlockedBalance_JSBigInt();
// console.log(amount)
// console.log(amountJSBigInt)
}
}, {
key: "showOptionsDropdown",
value: function showOptionsDropdown() {
if (this.displayOptionsDropdown == false) {
console.log("Show the options");
console.log(this.displayOptionsDropdown); //this.displayOptionsDropdown = false;
this.displayOptionsDropdown = !this.displayOptionsDropdown;
} else {
console.log("HuH");
this.displayOptionsDropdown = !this.displayOptionsDropdown;
}
}
}, {
key: "updateSelectedWallet",
value: function updateSelectedWallet(event) {
this.displayOptionsDropdown = false;
var offset = event.path[0].dataset.walletoffset;
this.selectedWallet = this.wallets[offset];
var options = {
detail: {
wallet: this.wallets[offset]
},
bubbles: true,
composed: true
};
var walletOptionUpdated = new CustomEvent("wallet-selector-update", options);
this.dispatchEvent(walletOptionUpdated, options); //event.preventDefault() // we need to stop this bubbling to show the options
}
}, {
key: "render",
value: function render() {
var _this$wallets;
// TODO: Find a cleaner way to handle update that doesn't require passing offset to every element
if (((_this$wallets = this.wallets) === null || _this$wallets === void 0 ? void 0 : _this$wallets.length) > 0) {
var walletTemplates = [];
for (var i = 0; i < this.wallets.length; i++) {
walletTemplates.push((0, _lit.html)(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n <div @click=", " data-walletoffset=", " data-swatch=\"00F4CD\" data-walletbalance=\"0.00052545\" data-walletid=\"dd7e2ba0-d80d-11eb-b0fd-5d37c436790f\" data-walletpublicaddress=\"47pasa5moXNCSyvvip6sY39VFGYymMhVEXpcaZSaP3hAVNbVXpGu5MVZn9ePeotMRFiJuLq2pB6B3Hm7uWYanyJe1yeSbm9\" class=\"hoverable-cell utility optionCell\" style=\"word-break: break-all; height: 66px; position: relative; left: 0px; top: 0px; box-sizing: border-box; width: 100%;\"> \n <div data-walletoffset=", " class=\"wallet-icon medium-32 ", "\"></div> \n <div data-walletoffset=", " class=\"wallet-label\">", "</div>\n <div data-walletoffset=", " class=\"description-label\">", " LOZZ</div>\n </div>\n "])), this.updateSelectedWallet, i, i, "wallet-" + this.wallets[i].swatch.substr(1), i, this.wallets[i].walletLabel, i, this.wallets[i].Balance_FormattedString()));
}
return (0, _lit.html)(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n <div id=\"wallet-selector\" class=\"WalletSelectView ListCustomSelectView form_field\" data-walletchosen=\"true\" @click=", " ?hidden=", ">\n <!-- selected wallet -->\n <div data-walletoffset=\"0\" id=\"selected-wallet\" class=\"hoverable-cell utility selectionDisplayCellView\">\n <div data-walletoffset=", " class=\"wallet-icon medium-32 ", "\"></div> \n <div data-walletoffset=", " class=\"wallet-label\">", "</div>\n <div data-walletoffset=", " class=\"description-label\">", " LOZZ</div>\n </div>\n\n <!-- wallet options selector -->\n </div>\n <div id=\"wallet-options\" class=\"options_containerView\" ?hidden=", ">\n <div class=\"options_cellViews_containerView\" style=\"position: relative; left: 0px; top: 0px; width: 100%; height: 100%; z-index: 20; overflow-y: auto; max-height: 174.9px;\">\n ", "\n </div>\n </div> \n \n \n <!-- <div data-walletlabel=\"1\" data-walletoffset=\"1\" data-swatch=\"CFCECF\" data-walletbalance=\"0.000001\" data-walletid=\"8b13b0b0-d80d-11eb-b0fd-5d37c436790f\" data-walletpublicaddress=\"47joJKcNWs66f6ein9qTTVFyzeGnmBEGWKomSuMmqwaBYGj7gv2RvFRRUy1xtzpn6qE8BBpDnuFbp44qe9X1XmK78vqXaij\" class=\"hoverable-cell utility optionCell\" style=\"word-break: break-all; height: 66px; position: relative; left: 0px; top: 0px; box-sizing: border-box; width: 100%;\"> \n <div class=\"wallet-icon medium-32\" style=\"background-image: url('../../../assets/img/wallet-CFCECF@3x.png');\"></div> \n <div class=\"walletLabel\">1</div>\n <div class=\"description-label\" style=\"position: relative; box-sizing: border-box; padding: 0px 38px 4px 66px; font-size: 13px; font-family: Native-Light, input, menlo, monospace; font-weight: 100; -webkit-font-smoothing: subpixel-antialiased; max-height: 32px; color: rgb(158, 156, 158); word-break: normal; overflow: hidden; text-overflow: ellipsis; cursor: default;\">0.000001 LOZZ </div>\n </div>\n \n <div data-walletlabel=\"1\" data-walletoffset=\"2\" data-swatch=\"6B696B\" data-walletbalance=\"0\" data-walletid=\"41151480-d025-11eb-abe1-d74624217cf8\" data-walletpublicaddress=\"4B9Qr7SnR67RmDgBnRmMe1YKTrtcLzSHAe5yMDMpqfiGc3TqxbaZcdQ46aURH2rJSRTK4p31MQNyBRTSgTtuoK9n8vGVBdD\" class=\"hoverable-cell utility optionCell\" style=\"word-break: break-all; height: 66px; position: relative; left: 0px; top: 0px; box-sizing: border-box; width: 100%;\"> \n <div class=\"wallet-icon medium-32\" style=\"background-image: url('../../../assets/img/wallet-6B696B@3x.png');\"></div> \n <div class=\"walletLabel\">1</div>\n <div class=\"description-label\" style=\"position: relative; box-sizing: border-box; padding: 0px 38px 4px 66px; font-size: 13px; font-family: Native-Light, input, menlo, monospace; font-weight: 100; -webkit-font-smoothing: subpixel-antialiased; max-height: 32px; color: rgb(158, 156, 158); word-break: normal; overflow: hidden; text-overflow: ellipsis; cursor: default;\">0 LOZZ </div>\n </div>\n \n </div>\n </div>\n </div> -->\n "])), this.showOptionsDropdown, this.displayOptionsDropdown, 0, "wallet-" + this.selectedWallet.swatch.substr(1), 0, this.selectedWallet.walletLabel, 0, this.selectedWallet.Balance_FormattedString(), !this.displayOptionsDropdown, walletTemplates);
} else {
console.error("Zero wallet records found");
return (0, _lit.html)(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n <div id=\"wallet-selector\" class=\"WalletSelectView ListCustomSelectView form_field\" data-walletchosen=\"true\" @click=", " ?hidden=", ">\n \n <div> \n No wallets found\n </div>\n <!-- wallet options selector -->\n </div>\n "])), this.showOptionsDropdown, this.displayOptionsDropdown);
}
}
}], [{
key: "styles",
get: function get() {
return (0, _lit.css)(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n .WalletSelectView {\n display: block;\n outline: none;\n height: 66px;\n width: 100%;\n padding: 0;\n box-sizing: border-box;\n appearance: none;\n background: #383638;\n border-width: 0;\n box-shadow: 0 0.5px 1px 0 #161416, inset 0 0.5px 0 0 #494749;\n border-radius: 5px;\n text-align: left;\n font-size: 14px;\n color: #FCFBFC;\n }\n \n .WalletSelectView .selectionDisplayCellView,\n .WalletSelectView .options_containerView {\n border-radius: 5px;\n overflow: hidden;\n }\n \n .WalletSelectView > .options_containerView {\n border-radius: 5px;\n box-shadow: 0 15px 12px 0 rgba(0, 0, 0, 0.22), 0 19px 38px 0 rgba(0, 0, 0, 0.30);\n }\n \n .WalletSelectView > .options_containerView > .background {\n background: #383638;\n border-radius: 5px;\n box-shadow: 0 0.5px 1px 0 #161416, inset 0 0.5px 0 0 #494749;\n }\n \n .WalletSelectView > .options_containerView .optionCell.active {\n background-color: rgba(73, 71, 73, 0.95) !important;\n }\n wallet-selector {\n position: absolute;\n }\n #wallet-selector {\n position: relative;\n padding: 0px;\n margin: 5px;\n }\n .WalletSelectView .selectionDisplayCellView, .WalletSelectView .options_containerView {\n border-radius: 5px;\n overflow: hidden;\n }\n .selectionDisplayCellView .wallet-icon {\n position: absolute;\n left: 16px;\n top: 16px;\n }\n \n .wallet-icon.medium-32 {\n width: 32px;\n height: 32px;\n background-size: 32px 32px;\n }\n .walletName {\n position: relative;\n box-sizing: border-box;\n padding: 15px 38px 4px 66px;\n display: block;\n word-break: break-word;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n font-family: -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Oxygen, Ubuntu, Cantarell, \"Open Sans\", \"Helvetica Neue\", sans-serif;\n -webkit-font-smoothing: subpixel-antialiased;\n font-size: 12px;\n font-weight: 400;\n letter-spacing: 0.5px;\n color: rgb(252, 251, 252);\n cursor: default;\n }\n .wallet-label {\n position: relative;\n box-sizing: border-box;\n padding: 15px 38px 4px 66px;\n display: block;\n word-break: break-word;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n font-family: -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Oxygen, Ubuntu, Cantarell, \"Open Sans\", \"Helvetica Neue\", sans-serif;\n -webkit-font-smoothing: subpixel-antialiased;\n font-size: 12px;\n font-weight: 400;\n letter-spacing: 0.5px;\n color: rgb(252, 251, 252);\n cursor: default;\n }\n .description-label {\n position: relative;\n box-sizing: border-box;\n padding: 0px 38px 4px 66px;\n font-size: 13px;\n font-family: Native-Light, input, menlo, monospace;\n font-weight: 100;\n -webkit-font-smoothing: subpixel-antialiased;\n max-height: 32px;\n color: rgb(158, 156, 158);\n word-break: normal;\n overflow: hidden;\n text-overflow: ellipsis;\n cursor: default; \n }\n #wallet-options {\n //display: none;\n position: absolute;\n width: 100%;\n top: 0px;\n // left: 0px;\n z-index: 10;\n max-height: 174.9px;\n height: 132px;\n box-sizing: border-box;\n appearance: none;\n background: rgb(56, 54, 56);\n border-width: 0px;\n box-shadow: rgb(22 20 22) 0px 0.5px 1px 0px, rgb(73 71 73) 0px 0.5px 0px 0px inset;\n border-radius: 5px;\n text-align: left;\n font-size: 14px;\n color: rgb(252, 251, 252);\n }\n .WalletSelectView > .options_containerView {\n border-radius: 5px;\n box-shadow: 0 15px 12px 0 rgba(0,0,0,0.22), 0 19px 38px 0 rgba(0,0,0,0.30);\n }\n // #wallet-options.active {\n // display: block !important;\n // }\n #wallet-options {\n //display: block;\n position: absolute;\n width: 100%;\n top: 0px;\n left: 0px;\n z-index: 10;\n max-height: 174.9px;\n height: 132px;\n }\n .WalletSelectView > .options_containerView {\n border-radius: 5px;\n box-shadow: 0 15px 12px 0 rgba(0,0,0,0.22), 0 19px 38px 0 rgba(0,0,0,0.30);\n }\n .WalletSelectView .selectionDisplayCellView, .WalletSelectView .options_containerView {\n border-radius: 5px;\n overflow: hidden;\n }\n .options_containerView.active {\n background: rgb(39, 37, 39);\n }\n .WalletSelectView > .options_containerView {\n border-radius: 5px;\n box-shadow: 0 15px 12px 0 rgba(0, 0, 0, 0.22), 0 19px 38px 0 rgba(0, 0, 0, 0.30);\n }\n .WalletSelectView .selectionDisplayCellView, .WalletSelectView .options_containerView {\n border-radius: 5px;\n overflow: hidden;\n }\n .wallet-icon {\n position: absolute;\n left: 15px;\n top: 16px;\n }\n .wallet-icon.medium-32 {\n width: 32px;\n height: 32px;\n background-size: 32px 32px;\n }\n .wallet-00C6FF {\n background-image: url(\"\");\n }\n .wallet-00F4CD {\n background-image: url(\"\");\n }\n .wallet-6B696B {\n background-image: url(\"\");\n }\n .wallet-CFCECF {\n background-image: url(\"