@coinbase/wallet-sdk
Version:
Coinbase Wallet JavaScript SDK
83 lines • 2.93 kB
JavaScript
import { NAME, VERSION } from '../sdk-info.js';
import { getCrossOriginOpenerPolicy } from './checkCrossOriginOpenerPolicy.js';
import { standardErrors } from '../core/error/errors.js';
import { Snackbar } from '../sign/walletlink/relay/ui/components/Snackbar/Snackbar.js';
import { RETRY_SVG_PATH } from '../sign/walletlink/relay/ui/WalletLinkRelayUI.js';
const POPUP_WIDTH = 420;
const POPUP_HEIGHT = 540;
const RETRY_BUTTON = {
isRed: false,
info: 'Retry',
svgWidth: '10',
svgHeight: '11',
path: RETRY_SVG_PATH,
defaultFillRule: 'evenodd',
defaultClipRule: 'evenodd',
};
const POPUP_BLOCKED_MESSAGE = 'Popup was blocked. Try again.';
let snackbar = null;
export function openPopup(url) {
const left = (window.innerWidth - POPUP_WIDTH) / 2 + window.screenX;
const top = (window.innerHeight - POPUP_HEIGHT) / 2 + window.screenY;
appendAppInfoQueryParams(url);
function tryOpenPopup() {
const popupId = `wallet_${crypto.randomUUID()}`;
const popup = window.open(url, popupId, `width=${POPUP_WIDTH}, height=${POPUP_HEIGHT}, left=${left}, top=${top}`);
popup === null || popup === void 0 ? void 0 : popup.focus();
if (!popup) {
return null;
}
return popup;
}
let popup = tryOpenPopup();
// If the popup was blocked, show a snackbar with a retry button
if (!popup) {
const sb = initSnackbar();
return new Promise((resolve, reject) => {
sb.presentItem({
autoExpand: true,
message: POPUP_BLOCKED_MESSAGE,
menuItems: [
Object.assign(Object.assign({}, RETRY_BUTTON), { onClick: () => {
popup = tryOpenPopup();
if (popup) {
resolve(popup);
}
else {
reject(standardErrors.rpc.internal('Popup window was blocked'));
}
sb.clear();
} }),
],
});
});
}
return Promise.resolve(popup);
}
export function closePopup(popup) {
if (popup && !popup.closed) {
popup.close();
}
}
function appendAppInfoQueryParams(url) {
const params = {
sdkName: NAME,
sdkVersion: VERSION,
origin: window.location.origin,
coop: getCrossOriginOpenerPolicy(),
};
for (const [key, value] of Object.entries(params)) {
url.searchParams.append(key, value.toString());
}
}
function initSnackbar() {
if (!snackbar) {
const root = document.createElement('div');
root.className = '-cbwsdk-css-reset';
document.body.appendChild(root);
snackbar = new Snackbar();
snackbar.attach(root);
}
return snackbar;
}
//# sourceMappingURL=web.js.map