UNPKG

@enclavemoney/enclave-wallet-sdk

Version:

A simple enclave wallet SDK for React applications

122 lines (121 loc) 5.59 kB
"use strict"; var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { if (k2 === undefined) k2 = k; var desc = Object.getOwnPropertyDescriptor(m, k); if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { desc = { enumerable: true, get: function() { return m[k]; } }; } Object.defineProperty(o, k2, desc); }) : (function(o, m, k, k2) { if (k2 === undefined) k2 = k; o[k2] = m[k]; })); var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { Object.defineProperty(o, "default", { enumerable: true, value: v }); }) : function(o, v) { o["default"] = v; }); var __importStar = (this && this.__importStar) || function (mod) { if (mod && mod.__esModule) return mod; var result = {}; if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k); __setModuleDefault(result, mod); return result; }; Object.defineProperty(exports, "__esModule", { value: true }); exports.AmountDropdown = void 0; var React = __importStar(require("react")); var useState = React.useState, useRef = React.useRef, useEffect = React.useEffect; var lucide_react_1 = require("lucide-react"); var WalletProvider_1 = require("../WalletProvider"); var theme_1 = require("../../types/theme"); var AmountDropdown = function (_a) { var onSelectPercentage = _a.onSelectPercentage, _b = _a.disabled, disabled = _b === void 0 ? false : _b; var _c = useState(false), isOpen = _c[0], setIsOpen = _c[1]; var _d = useState("Presets"), selectedLabel = _d[0], setSelectedLabel = _d[1]; var dropdownRef = useRef(null); var _e = (0, WalletProvider_1.useWallet)(), currentTheme = _e.currentTheme, walletCornerRadius = _e.walletCornerRadius; var currentRadius = theme_1.borderRadiusStyles[walletCornerRadius]; var options = [ { label: "25%", value: 25 }, { label: "50%", value: 50 }, // { label: "Send 75%", value: 75 }, { label: "Max", value: 100 }, ]; // Close dropdown when clicking outside useEffect(function () { var handleClickOutside = function (event) { if (dropdownRef.current && !dropdownRef.current.contains(event.target)) { setIsOpen(false); } }; document.addEventListener("mousedown", handleClickOutside); return function () { document.removeEventListener("mousedown", handleClickOutside); }; }, []); var handleOptionClick = function (option) { setSelectedLabel(option.label); setIsOpen(false); onSelectPercentage(option.value); }; return (React.createElement("div", { ref: dropdownRef, style: { position: "relative" } }, React.createElement("button", { onClick: function () { return setIsOpen(!isOpen); }, disabled: disabled, style: { background: currentTheme.surface, border: "1px solid ".concat(currentTheme.border), borderTopRightRadius: currentRadius.level3Radius, borderBottomRightRadius: currentRadius.level3Radius, padding: "7px 10px", fontSize: 12, color: currentTheme.text, cursor: disabled ? "not-allowed" : "pointer", fontWeight: 500, display: "flex", alignItems: "center", justifyContent: "space-between", gap: 4, minWidth: 60, opacity: disabled ? 0.5 : 1, } }, React.createElement("span", { style: { fontSize: 12, color: currentTheme.primary } }, selectedLabel), React.createElement(lucide_react_1.ChevronDown, { style: { width: 12, height: 12, color: currentTheme.primary, transform: isOpen ? "rotate(180deg)" : "rotate(0deg)", transition: "transform 0.2s ease", } })), isOpen && (React.createElement("div", { style: { position: "absolute", top: "100%", left: 0, right: 0, marginTop: 4, background: currentTheme.surface, border: "1px solid ".concat(currentTheme.border), borderRadius: currentRadius.level3Radius, boxShadow: "0 4px 12px rgba(0, 0, 0, 0.1)", zIndex: 1000, overflow: "hidden", padding: 4, minWidth: 80, } }, options.map(function (option, index) { return (React.createElement("button", { key: option.value, onClick: function () { return handleOptionClick(option); }, style: { width: "100%", padding: "8px 12px", fontSize: 11, color: currentTheme.text, background: "transparent", border: "none", cursor: "pointer", textAlign: "left", outline: "none", fontWeight: 500, borderRadius: currentRadius.level3Radius, }, onMouseEnter: function (e) { e.currentTarget.style.background = currentTheme.surfaceHover; }, onMouseLeave: function (e) { e.currentTarget.style.background = "transparent"; } }, option.label)); }))))); }; exports.AmountDropdown = AmountDropdown;