@coinbase/wallet-sdk
Version:
Coinbase Wallet JavaScript SDK
79 lines • 5.79 kB
JavaScript
// 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