UNPKG

@coinbase/wallet-sdk

Version:
79 lines 5.79 kB
// Copyright (c) 2018-2023 Coinbase, Inc. <https://www.coinbase.com/> import { clsx } from 'clsx'; import { h, render } from 'preact'; import { useEffect, useState } from 'preact/hooks'; import { isDarkMode } from '../util.js'; import css from './Snackbar-css.js'; const cblogo = ``; const gearIcon = ``; export class Snackbar { constructor() { this.items = new Map(); this.nextItemKey = 0; this.root = null; this.darkMode = isDarkMode(); } attach(el) { this.root = document.createElement('div'); this.root.className = '-cbwsdk-snackbar-root'; el.appendChild(this.root); this.render(); } presentItem(itemProps) { const key = this.nextItemKey++; this.items.set(key, itemProps); this.render(); return () => { this.items.delete(key); this.render(); }; } clear() { this.items.clear(); this.render(); } render() { if (!this.root) { return; } render(h("div", null, h(SnackbarContainer, { darkMode: this.darkMode }, Array.from(this.items.entries()).map(([key, itemProps]) => (h(SnackbarInstance, Object.assign({}, itemProps, { key: key })))))), this.root); } } export const SnackbarContainer = (props) => (h("div", { class: clsx('-cbwsdk-snackbar-container') }, h("style", null, css), h("div", { class: "-cbwsdk-snackbar" }, props.children))); export const SnackbarInstance = ({ autoExpand, message, menuItems, }) => { const [hidden, setHidden] = useState(true); const [expanded, setExpanded] = useState(autoExpand !== null && autoExpand !== void 0 ? autoExpand : false); useEffect(() => { const timers = [ window.setTimeout(() => { setHidden(false); }, 1), window.setTimeout(() => { setExpanded(true); }, 10000), ]; return () => { timers.forEach(window.clearTimeout); }; }); const toggleExpanded = () => { setExpanded(!expanded); }; return (h("div", { class: clsx('-cbwsdk-snackbar-instance', hidden && '-cbwsdk-snackbar-instance-hidden', expanded && '-cbwsdk-snackbar-instance-expanded') }, h("div", { class: "-cbwsdk-snackbar-instance-header", onClick: toggleExpanded }, h("img", { src: cblogo, class: "-cbwsdk-snackbar-instance-header-cblogo" }), ' ', h("div", { class: "-cbwsdk-snackbar-instance-header-message" }, message), h("div", { class: "-gear-container" }, !expanded && (h("svg", { width: "24", height: "24", viewBox: "0 0 24 24", fill: "none", xmlns: "http://www.w3.org/2000/svg" }, h("circle", { cx: "12", cy: "12", r: "12", fill: "#F5F7F8" }))), h("img", { src: gearIcon, class: "-gear-icon", title: "Expand" }))), menuItems && menuItems.length > 0 && (h("div", { class: "-cbwsdk-snackbar-instance-menu" }, menuItems.map((action, i) => (h("div", { class: clsx('-cbwsdk-snackbar-instance-menu-item', action.isRed && '-cbwsdk-snackbar-instance-menu-item-is-red'), onClick: action.onClick, key: i }, h("svg", { width: action.svgWidth, height: action.svgHeight, viewBox: "0 0 10 11", fill: "none", xmlns: "http://www.w3.org/2000/svg" }, h("path", { "fill-rule": action.defaultFillRule, "clip-rule": action.defaultClipRule, d: action.path, fill: "#AAAAAA" })), h("span", { class: clsx('-cbwsdk-snackbar-instance-menu-item-info', action.isRed && '-cbwsdk-snackbar-instance-menu-item-info-is-red') }, action.info)))))))); }; //# sourceMappingURL=Snackbar.js.map