New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

@web3modal/scaffold

Package Overview
Dependencies
Maintainers
6
Versions
245
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@web3modal/scaffold - npm Package Compare versions

Comparing version 3.0.0-84bf2f84 to 3.0.0-90049a6a

dist/esm/src/modal/w3m-account-button/index.js

55

dist/esm/index.js

@@ -1,26 +0,31 @@

export * from './src/modal/w3m-modal';
export * from './src/modal/w3m-router';
export * from './src/views/w3m-account-view';
export * from './src/views/w3m-all-wallets-view';
export * from './src/views/w3m-connect-view';
export * from './src/views/w3m-connecting-external-view';
export * from './src/views/w3m-connecting-wc-view';
export * from './src/views/w3m-network-switch-view';
export * from './src/views/w3m-networks-view';
export * from './src/views/w3m-what-is-a-network-view';
export * from './src/views/w3m-what-is-a-wallet-view';
export * from './src/partials/w3m-all-wallets-list';
export * from './src/partials/w3m-all-wallets-search';
export * from './src/partials/w3m-connecting-header';
export * from './src/partials/w3m-connecting-wc-desktop';
export * from './src/partials/w3m-connecting-wc-injected';
export * from './src/partials/w3m-connecting-wc-mobile';
export * from './src/partials/w3m-connecting-wc-qrcode';
export * from './src/partials/w3m-connecting-wc-unsupported';
export * from './src/partials/w3m-connecting-wc-web';
export * from './src/partials/w3m-connecting-widget';
export * from './src/partials/w3m-header';
export * from './src/partials/w3m-help-widget';
export * from './src/partials/w3m-snackbar';
export { Web3ModalScaffoldHtml } from './src/client';
export * from './src/modal/w3m-account-button/index.js';
export * from './src/modal/w3m-button/index.js';
export * from './src/modal/w3m-connect-button/index.js';
export * from './src/modal/w3m-modal/index.js';
export * from './src/modal/w3m-network-button/index.js';
export * from './src/modal/w3m-router/index.js';
export * from './src/views/w3m-account-view/index.js';
export * from './src/views/w3m-all-wallets-view/index.js';
export * from './src/views/w3m-connect-view/index.js';
export * from './src/views/w3m-connecting-external-view/index.js';
export * from './src/views/w3m-connecting-wc-view/index.js';
export * from './src/views/w3m-get-wallet-view/index.js';
export * from './src/views/w3m-network-switch-view/index.js';
export * from './src/views/w3m-networks-view/index.js';
export * from './src/views/w3m-what-is-a-network-view/index.js';
export * from './src/views/w3m-what-is-a-wallet-view/index.js';
export * from './src/partials/w3m-all-wallets-list/index.js';
export * from './src/partials/w3m-all-wallets-search/index.js';
export * from './src/partials/w3m-connecting-header/index.js';
export * from './src/partials/w3m-connecting-wc-desktop/index.js';
export * from './src/partials/w3m-connecting-wc-injected/index.js';
export * from './src/partials/w3m-connecting-wc-mobile/index.js';
export * from './src/partials/w3m-connecting-wc-qrcode/index.js';
export * from './src/partials/w3m-connecting-wc-unsupported/index.js';
export * from './src/partials/w3m-connecting-wc-web/index.js';
export * from './src/partials/w3m-header/index.js';
export * from './src/partials/w3m-help-widget/index.js';
export * from './src/partials/w3m-legal-footer/index.js';
export * from './src/partials/w3m-snackbar/index.js';
export { Web3ModalScaffold } from './src/client.js';
//# sourceMappingURL=index.js.map

@@ -1,4 +0,5 @@

import { AccountController, ConnectionController, ConnectorController, CoreHelperUtil, ExplorerApiController, ModalController, NetworkController } from '@web3modal/core';
import { AccountController, ApiController, BlockchainApiController, ConnectionController, ConnectorController, CoreHelperUtil, ModalController, NetworkController, OptionsController, ThemeController } from '@web3modal/core';
import { setColorTheme, setThemeVariables } from '@web3modal/ui';
let isInitialized = false;
export class Web3ModalScaffoldHtml {
export class Web3ModalScaffold {
constructor(options) {

@@ -41,2 +42,6 @@ this.initPromise = undefined;

};
this.fetchIdentity = request => BlockchainApiController.fetchIdentity(request);
this.setAddressExplorerUrl = addressExplorerUrl => {
AccountController.setAddressExplorerUrl(addressExplorerUrl);
};
this.initControllers(options);

@@ -53,6 +58,38 @@ this.initOrContinue();

}
getThemeMode() {
return ThemeController.state.themeMode;
}
getThemeVariables() {
return ThemeController.state.themeVariables;
}
setThemeMode(themeMode) {
ThemeController.setThemeMode(themeMode);
setColorTheme(ThemeController.state.themeMode);
}
setThemeVariables(themeVariables) {
ThemeController.setThemeVariables(themeVariables);
setThemeVariables(ThemeController.state.themeVariables);
}
subscribeTheme(callback) {
return ThemeController.subscribe(callback);
}
initControllers(options) {
NetworkController.setClient(options.networkControllerClient);
NetworkController.setDefaultCaipNetwork(options.defaultChain);
OptionsController.setProjectId(options.projectId);
OptionsController.setIncludeWalletIds(options.includeWalletIds);
OptionsController.setExcludeWalletIds(options.excludeWalletIds);
OptionsController.setFeaturedWalletIds(options.featuredWalletIds);
OptionsController.setTokens(options.tokens);
OptionsController.setTermsConditionsUrl(options.termsConditionsUrl);
OptionsController.setPrivacyPolicyUrl(options.privacyPolicyUrl);
OptionsController.setCustomWallets(options.customWallets);
ConnectionController.setClient(options.connectionControllerClient);
ExplorerApiController.setProjectId(options.projectId);
ApiController.setSdkVersion(options._sdkVersion);
if (options.themeMode) {
ThemeController.setThemeMode(options.themeMode);
}
if (options.themeVariables) {
ThemeController.setThemeVariables(options.themeVariables);
}
}

@@ -59,0 +96,0 @@ async initOrContinue() {

@@ -7,10 +7,9 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {

};
import { ExplorerApiController, ModalController, SnackController } from '@web3modal/core';
import { initializeTheming, setColorTheme } from '@web3modal/ui';
import { ApiController, ModalController, SnackController, ThemeController } from '@web3modal/core';
import { UiHelperUtil, initializeTheming } from '@web3modal/ui';
import { LitElement, html } from 'lit';
import { customElement, state } from 'lit/decorators.js';
import { animate } from 'motion';
import styles from './styles';
import styles from './styles.js';
const SCROLL_LOCK = 'scroll-lock';
export let W3mModal = class W3mModal extends LitElement {
let W3mModal = class W3mModal extends LitElement {
constructor() {

@@ -21,5 +20,4 @@ super();

this.open = ModalController.state.open;
initializeTheming();
setColorTheme('dark');
ExplorerApiController.fetchRecommendedListings();
this.initializeTheming();
ApiController.prefetch();
this.unsubscribe.push(ModalController.subscribeKey('open', val => (val ? this.onOpen() : this.onClose())));

@@ -49,5 +47,14 @@ }

}
initializeTheming() {
const { themeVariables, themeMode } = ThemeController.state;
const defaultThemeMode = UiHelperUtil.getColorTheme(themeMode);
initializeTheming(themeVariables, defaultThemeMode);
}
async onClose() {
this.onScrollUnlock();
await animate(this, { opacity: [1, 0] }, { duration: 0.2 }).finished;
await this.animate([{ opacity: 1 }, { opacity: 0 }], {
duration: 200,
easing: 'ease',
fill: 'forwards'
}).finished;
SnackController.hide();

@@ -60,6 +67,14 @@ this.open = false;

this.open = true;
await animate(this, { opacity: [0, 1] }, { duration: 0.2 }).finished;
await this.animate([{ opacity: 0 }, { opacity: 1 }], {
duration: 200,
easing: 'ease',
fill: 'forwards'
}).finished;
this.onAddKeyboardListener();
}
onScrollLock() {
const { body } = document;
const { innerHeight: viewportHeight } = window;
const scrollHeight = body?.scrollHeight;
const scrollbarGutter = scrollHeight > viewportHeight ? 'scrollbar-gutter: stable;' : '';
const styleTag = document.createElement('style');

@@ -72,3 +87,4 @@ styleTag.dataset['w3m'] = SCROLL_LOCK;

overscroll-behavior: contain;
scrollbar-gutter: stable;
min-height: 100vh;
${scrollbarGutter}
}

@@ -112,2 +128,3 @@ `;

], W3mModal);
export { W3mModal };
//# sourceMappingURL=index.js.map
import { css } from 'lit';
export default css `
:host {
z-index: var(--w3m-z-index);
position: relative;
}
@keyframes zoom-in {

@@ -21,8 +26,2 @@ 0% {

wui-overlay {
display: flex;
align-items: center;
justify-content: center;
}
wui-card {

@@ -29,0 +28,0 @@ max-width: 360px;

@@ -10,5 +10,4 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {

import { customElement, state } from 'lit/decorators.js';
import { animate } from 'motion';
import styles from './styles';
export let W3mRouter = class W3mRouter extends LitElement {
import styles from './styles.js';
let W3mRouter = class W3mRouter extends LitElement {
constructor() {

@@ -27,3 +26,7 @@ super();

if (this.prevHeight !== '0px') {
await animate(this, { height: [this.prevHeight, height] }, { duration: 0.15 }).finished;
await this.animate([{ height: this.prevHeight }, { height }], {
duration: 150,
easing: 'ease',
fill: 'forwards'
}).finished;
this.style.height = 'auto';

@@ -62,2 +65,4 @@ }

return html `<w3m-what-is-a-network-view></w3m-what-is-a-network-view>`;
case 'GetWallet':
return html `<w3m-get-wallet-view></w3m-get-wallet-view>`;
default:

@@ -76,5 +81,11 @@ return html `<w3m-connect-view></w3m-connect-view>`;

this.prevHistoryLength = history.length;
await animate(this, { opacity: [1, 0], x: [0, xOut] }, { duration: 0.15 }).finished;
await this.animate([
{ opacity: 1, transform: 'translateX(0px)' },
{ opacity: 0, transform: `translateX(${xOut}px)` }
], { duration: 150, easing: 'ease', fill: 'forwards' }).finished;
this.view = newView;
animate(this, { opacity: [0, 1], x: [xIn, 0] }, { duration: 0.15, delay: 0.05 });
await this.animate([
{ opacity: 0, transform: `translateX(${xIn}px)` },
{ opacity: 1, transform: 'translateX(0px)' }
], { duration: 150, easing: 'ease', fill: 'forwards', delay: 50 }).finished;
}

@@ -92,2 +103,3 @@ getWrapper() {

], W3mRouter);
export { W3mRouter };
//# sourceMappingURL=index.js.map

@@ -7,9 +7,9 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {

};
import { ExplorerApiController, RouterController } from '@web3modal/core';
import { ApiController, AssetUtil, ConnectorController, RouterController } from '@web3modal/core';
import { LitElement, html } from 'lit';
import { customElement, state } from 'lit/decorators.js';
import { ifDefined } from 'lit/directives/if-defined.js';
import { animate } from 'motion';
import styles from './styles';
export let W3mAllWalletsList = class W3mAllWalletsList extends LitElement {
import styles from './styles.js';
const PAGINATOR_ID = 'local-paginator';
let W3mAllWalletsList = class W3mAllWalletsList extends LitElement {
constructor() {

@@ -19,8 +19,10 @@ super();

this.paginationObserver = undefined;
this.initial = !ExplorerApiController.state.listings.length;
this.listings = ExplorerApiController.state.listings;
this.recommended = ExplorerApiController.state.recommended;
this.initial = !ApiController.state.wallets.length;
this.wallets = ApiController.state.wallets;
this.recommended = ApiController.state.recommended;
this.featured = ApiController.state.featured;
this.unsubscribe.push(...[
ExplorerApiController.subscribeKey('listings', val => (this.listings = val)),
ExplorerApiController.subscribeKey('recommended', val => (this.recommended = val))
ApiController.subscribeKey('wallets', val => (this.wallets = val)),
ApiController.subscribeKey('recommended', val => (this.recommended = val)),
ApiController.subscribeKey('featured', val => (this.featured = val))
]);

@@ -41,7 +43,7 @@ }

.padding=${['0', 's', 's', 's']}
gridTemplateColumns="repeat(4, 1fr)"
columnGap="xxs"
rowGap="l"
columnGap="xs"
justifyContent="space-between"
>
${this.initial ? this.shimmerTemplate() : this.walletsTemplate()}
${this.initial ? this.shimmerTemplate(16) : this.walletsTemplate()}
${this.paginationLoaderTemplate()}

@@ -54,20 +56,29 @@ </wui-grid>

if (this.initial && gridEl) {
await ExplorerApiController.fetchListings();
await animate(gridEl, { opacity: [1, 0] }, { duration: 0.2 }).finished;
await ApiController.fetchWallets({ page: 1 });
await gridEl.animate([{ opacity: 1 }, { opacity: 0 }], {
duration: 200,
fill: 'forwards',
easing: 'ease'
}).finished;
this.initial = false;
animate(gridEl, { opacity: [0, 1] }, { duration: 0.2 });
gridEl.animate([{ opacity: 0 }, { opacity: 1 }], {
duration: 200,
fill: 'forwards',
easing: 'ease'
});
}
}
shimmerTemplate() {
return [...Array(16)].map(() => html `<wui-card-select-loader type="wallet"></wui-card-select-loader>`);
shimmerTemplate(items, id) {
return [...Array(items)].map(() => html `
<wui-card-select-loader type="wallet" id=${ifDefined(id)}></wui-card-select-loader>
`);
}
walletsTemplate() {
const { images } = ExplorerApiController.state;
const wallets = [...this.recommended, ...this.listings];
return wallets.map(listing => html `
const wallets = [...this.featured, ...this.recommended, ...this.wallets];
return wallets.map(wallet => html `
<wui-card-select
imageSrc=${ifDefined(images[listing.image_id])}
imageSrc=${ifDefined(AssetUtil.getWalletImage(wallet))}
type="wallet"
name=${listing.name}
@click=${() => this.onConnectListing(listing)}
name=${wallet.name}
@click=${() => this.onConnectWallet(wallet)}
></wui-card-select>

@@ -77,5 +88,10 @@ `);

paginationLoaderTemplate() {
const { listings, total } = ExplorerApiController.state;
if (total === 0 || listings.length < total) {
return html `<wui-loading-spinner></wui-loading-spinner>`;
const { wallets, recommended, featured, count } = ApiController.state;
const columns = window.innerWidth < 352 ? 3 : 4;
const currentWallets = wallets.length + recommended.length;
const minimumRows = Math.ceil(currentWallets / columns);
let shimmerCount = minimumRows * columns - currentWallets + columns;
shimmerCount -= wallets.length ? featured.length % columns : 0;
if (count === 0 || [...featured, ...wallets, ...recommended].length < count) {
return this.shimmerTemplate(shimmerCount, PAGINATOR_ID);
}

@@ -85,9 +101,9 @@ return null;

createPaginationObserver() {
const loaderEl = this.shadowRoot?.querySelector('wui-loading-spinner');
const loaderEl = this.shadowRoot?.querySelector(`#${PAGINATOR_ID}`);
if (loaderEl) {
this.paginationObserver = new IntersectionObserver(([element]) => {
if (element?.isIntersecting && !this.initial) {
const { page, total, listings } = ExplorerApiController.state;
if (listings.length < total) {
ExplorerApiController.fetchListings({ page: page + 1 });
const { page, count, wallets } = ApiController.state;
if (wallets.length < count) {
ApiController.fetchWallets({ page: page + 1 });
}

@@ -99,4 +115,11 @@ }

}
onConnectListing(listing) {
RouterController.push('ConnectingWalletConnect', { listing });
onConnectWallet(wallet) {
const { connectors } = ConnectorController.state;
const connector = connectors.find(({ explorerId }) => explorerId === wallet.id);
if (connector) {
RouterController.push('ConnectingExternal', { connector });
}
else {
RouterController.push('ConnectingWalletConnect', { wallet });
}
}

@@ -110,9 +133,13 @@ };

state()
], W3mAllWalletsList.prototype, "listings", void 0);
], W3mAllWalletsList.prototype, "wallets", void 0);
__decorate([
state()
], W3mAllWalletsList.prototype, "recommended", void 0);
__decorate([
state()
], W3mAllWalletsList.prototype, "featured", void 0);
W3mAllWalletsList = __decorate([
customElement('w3m-all-wallets-list')
], W3mAllWalletsList);
export { W3mAllWalletsList };
//# sourceMappingURL=index.js.map
import { css } from 'lit';
export default css `
wui-grid {
max-height: 360px;
max-height: clamp(360px, 400px, 80vh);
overflow: scroll;
scrollbar-width: none;
grid-auto-rows: min-content;
grid-template-columns: repeat(auto-fill, 76px);
}
@media (max-width: 435px) {
wui-grid {
grid-template-columns: repeat(auto-fill, 77px);
}
}
wui-grid[data-scroll='false'] {

@@ -11,0 +18,0 @@ overflow: hidden;

@@ -7,8 +7,8 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {

};
import { ExplorerApiController, RouterController } from '@web3modal/core';
import { ApiController, AssetUtil, ConnectorController, RouterController } from '@web3modal/core';
import { LitElement, html } from 'lit';
import { customElement, property, state } from 'lit/decorators.js';
import { ifDefined } from 'lit/directives/if-defined.js';
import styles from './styles';
export let W3mAllWalletsSearch = class W3mAllWalletsSearch extends LitElement {
import styles from './styles.js';
let W3mAllWalletsSearch = class W3mAllWalletsSearch extends LitElement {
constructor() {

@@ -22,3 +22,5 @@ super(...arguments);

this.onSearch();
return this.loading ? html `<wui-loading-spinner></wui-loading-spinner>` : this.walletsTemplate();
return this.loading
? html `<wui-loading-spinner color="accent-100"></wui-loading-spinner>`
: this.walletsTemplate();
}

@@ -29,3 +31,3 @@ async onSearch() {

this.loading = true;
await ExplorerApiController.searchListings({ search: this.query });
await ApiController.searchWallet({ search: this.query });
this.loading = false;

@@ -35,3 +37,3 @@ }

walletsTemplate() {
const { search, images } = ExplorerApiController.state;
const { search } = ApiController.state;
if (!search.length) {

@@ -58,8 +60,8 @@ return html `

>
${search.map(listing => html `
${search.map(wallet => html `
<wui-card-select
imageSrc=${ifDefined(images[listing.image_id])}
imageSrc=${ifDefined(AssetUtil.getWalletImage(wallet))}
type="wallet"
name=${listing.name}
@click=${() => this.onConnectListing(listing)}
name=${wallet.name}
@click=${() => this.onConnectWallet(wallet)}
></wui-card-select>

@@ -70,4 +72,11 @@ `)}

}
onConnectListing(listing) {
RouterController.push('ConnectingWalletConnect', { listing });
onConnectWallet(wallet) {
const { connectors } = ConnectorController.state;
const connector = connectors.find(({ explorerId }) => explorerId === wallet.id);
if (connector) {
RouterController.push('ConnectingExternal', { connector });
}
else {
RouterController.push('ConnectingWalletConnect', { wallet });
}
}

@@ -85,2 +94,3 @@ };

], W3mAllWalletsSearch);
export { W3mAllWalletsSearch };
//# sourceMappingURL=index.js.map

@@ -7,11 +7,18 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {

};
import { ConnectionController } from '@web3modal/core';
import { LitElement, html } from 'lit';
import { customElement, property } from 'lit/decorators.js';
export let W3mConnectingHeader = class W3mConnectingHeader extends LitElement {
import { customElement, property, state } from 'lit/decorators.js';
let W3mConnectingHeader = class W3mConnectingHeader extends LitElement {
constructor() {
super(...arguments);
super();
this.platformTabs = [];
this.unsubscribe = [];
this.platforms = [];
this.onSelectPlatfrom = undefined;
this.buffering = false;
this.unsubscribe.push(ConnectionController.subscribeKey('buffering', val => (this.buffering = val)));
}
disconnectCallback() {
this.unsubscribe.forEach(unsubscribe => unsubscribe());
}
render() {

@@ -21,3 +28,7 @@ const tabs = this.generateTabs();

<wui-flex justifyContent="center" .padding=${['l', '0', '0', '0']}>
<wui-tabs .tabs=${tabs} .onTabChange=${this.onTabChange.bind(this)}></wui-tabs>
<wui-tabs
?disabled=${this.buffering}
.tabs=${tabs}
.onTabChange=${this.onTabChange.bind(this)}
></wui-tabs>
</wui-flex>

@@ -29,3 +40,3 @@ `;

if (platform === 'injected') {
return { label: 'Extension', icon: 'extension', platform: 'injected' };
return { label: 'Browser', icon: 'extension', platform: 'injected' };
}

@@ -44,3 +55,3 @@ else if (platform === 'mobile') {

}
return { label: 'Extension', icon: 'extension', platform: 'unsupported' };
return { label: 'Browser', icon: 'extension', platform: 'unsupported' };
});

@@ -63,5 +74,9 @@ this.platformTabs = tabs.map(({ platform }) => platform);

], W3mConnectingHeader.prototype, "onSelectPlatfrom", void 0);
__decorate([
state()
], W3mConnectingHeader.prototype, "buffering", void 0);
W3mConnectingHeader = __decorate([
customElement('w3m-connecting-header')
], W3mConnectingHeader);
export { W3mConnectingHeader };
//# sourceMappingURL=index.js.map

@@ -7,54 +7,30 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {

};
import { ConnectionController, CoreHelperUtil, ExplorerApiController, RouterController, SnackController } from '@web3modal/core';
import { LitElement, html } from 'lit';
import { customElement, property, state } from 'lit/decorators.js';
import { ifDefined } from 'lit/directives/if-defined.js';
export let W3mConnectingWcDesktop = class W3mConnectingWcDesktop extends LitElement {
import { ConnectionController, CoreHelperUtil } from '@web3modal/core';
import { customElement } from 'lit/decorators.js';
import { W3mConnectingWidget } from '../../utils/w3m-connecting-widget/index.js';
let W3mConnectingWcDesktop = class W3mConnectingWcDesktop extends W3mConnectingWidget {
constructor() {
super();
this.listing = RouterController.state.data?.listing;
this.images = ExplorerApiController.state.images;
this.unsubscribe = [];
this.timeout = undefined;
this.error = false;
this.uri = ConnectionController.state.wcUri;
this.ready = false;
this.multiPlatfrom = false;
this.unsubscribe.push(ConnectionController.subscribeKey('wcUri', val => (this.uri = val)));
}
disconnectedCallback() {
this.unsubscribe.forEach(unsubscribe => unsubscribe());
clearTimeout(this.timeout);
}
render() {
if (!this.listing) {
throw new Error('w3m-connecting-wc-desktop: No listing provided');
if (!this.wallet) {
throw new Error('w3m-connecting-wc-desktop: No wallet provided');
}
this.isReady();
return html `
<w3m-connecting-widget
imageSrc=${ifDefined(this.images[this.listing.image_id])}
name=${this.listing.name}
.error=${this.error}
.onConnect=${this.onConnect.bind(this)}
.onCopyUri=${this.onCopyUri.bind(this)}
.autoConnect=${false}
></w3m-connecting-widget>
`;
this.onConnect = this.onConnectProxy.bind(this);
this.onRender = this.onRenderProxy.bind(this);
}
isReady() {
onRenderProxy() {
if (!this.ready && this.uri) {
this.ready = true;
this.timeout = setTimeout(() => {
this.ready = true;
this.onConnect();
this.onConnect?.();
}, 250);
}
}
onConnect() {
if (this.listing && this.uri) {
onConnectProxy() {
if (this.wallet?.desktop_link && this.uri) {
try {
this.error = false;
const { desktop, name } = this.listing;
const { redirect, href } = CoreHelperUtil.formatNativeUrl(desktop.native, this.uri);
const { desktop_link, name } = this.wallet;
const { redirect, href } = CoreHelperUtil.formatNativeUrl(desktop_link, this.uri);
ConnectionController.setWcLinking({ name, href });
ConnectionController.setRecentWallet(this.wallet);
CoreHelperUtil.openHref(redirect, '_self');

@@ -67,29 +43,7 @@ }

}
onCopyUri() {
try {
if (this.uri) {
CoreHelperUtil.copyToClopboard(this.uri);
SnackController.showSuccess('Link copied');
}
}
catch {
SnackController.showError('Failed to copy');
}
}
};
__decorate([
state()
], W3mConnectingWcDesktop.prototype, "error", void 0);
__decorate([
state()
], W3mConnectingWcDesktop.prototype, "uri", void 0);
__decorate([
state()
], W3mConnectingWcDesktop.prototype, "ready", void 0);
__decorate([
property({ type: Boolean })
], W3mConnectingWcDesktop.prototype, "multiPlatfrom", void 0);
W3mConnectingWcDesktop = __decorate([
customElement('w3m-connecting-wc-desktop')
], W3mConnectingWcDesktop);
export { W3mConnectingWcDesktop };
//# sourceMappingURL=index.js.map

@@ -7,31 +7,18 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {

};
import { ConnectionController, ExplorerApiController, ModalController, RouterController } from '@web3modal/core';
import { LitElement, html } from 'lit';
import { customElement, property, state } from 'lit/decorators.js';
import { ifDefined } from 'lit/directives/if-defined.js';
export let W3mConnectingWcInjected = class W3mConnectingWcInjected extends LitElement {
import { ConnectionController, ModalController } from '@web3modal/core';
import { customElement } from 'lit/decorators.js';
import { W3mConnectingWidget } from '../../utils/w3m-connecting-widget/index.js';
let W3mConnectingWcInjected = class W3mConnectingWcInjected extends W3mConnectingWidget {
constructor() {
super(...arguments);
this.listing = RouterController.state.data?.listing;
this.images = ExplorerApiController.state.images;
this.error = false;
this.multiPlatfrom = false;
}
render() {
if (!this.listing) {
throw new Error('w3m-connecting-wc-injected: No listing provided');
super();
if (!this.wallet) {
throw new Error('w3m-connecting-wc-injected: No wallet provided');
}
return html `
<w3m-connecting-widget
name=${this.listing.name}
imageSrc=${ifDefined(this.images[this.listing.image_id])}
.error=${this.error}
.onConnect=${this.onConnect.bind(this)}
></w3m-connecting-widget>
`;
this.onConnect = this.onConnectProxy.bind(this);
this.onAutoConnect = this.onConnectProxy.bind(this);
}
async onConnect() {
async onConnectProxy() {
try {
this.error = false;
await ConnectionController.connectInjected();
await ConnectionController.connectExternal('injected');
ModalController.close();

@@ -44,11 +31,6 @@ }

};
__decorate([
state()
], W3mConnectingWcInjected.prototype, "error", void 0);
__decorate([
property({ type: Boolean })
], W3mConnectingWcInjected.prototype, "multiPlatfrom", void 0);
W3mConnectingWcInjected = __decorate([
customElement('w3m-connecting-wc-injected')
], W3mConnectingWcInjected);
export { W3mConnectingWcInjected };
//# sourceMappingURL=index.js.map

@@ -7,50 +7,33 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {

};
import { ConnectionController, CoreHelperUtil, ExplorerApiController, RouterController, SnackController } from '@web3modal/core';
import { LitElement, html } from 'lit';
import { customElement, property, state } from 'lit/decorators.js';
import { ifDefined } from 'lit/directives/if-defined.js';
export let W3mConnectingWcMobile = class W3mConnectingWcMobile extends LitElement {
import { ConnectionController, CoreHelperUtil } from '@web3modal/core';
import { customElement } from 'lit/decorators.js';
import { W3mConnectingWidget } from '../../utils/w3m-connecting-widget/index.js';
let W3mConnectingWcMobile = class W3mConnectingWcMobile extends W3mConnectingWidget {
constructor() {
super();
this.listing = RouterController.state.data?.listing;
this.images = ExplorerApiController.state.images;
this.unsubscribe = [];
this.error = false;
this.uri = ConnectionController.state.wcUri;
this.ready = false;
this.multiPlatfrom = false;
this.unsubscribe.push(ConnectionController.subscribeKey('wcUri', val => (this.uri = val)));
if (!this.wallet) {
throw new Error('w3m-connecting-wc-mobile: No wallet provided');
}
this.onConnect = this.onConnectProxy.bind(this);
this.onRender = this.onRenderProxy.bind(this);
document.addEventListener('visibilitychange', this.onBuffering.bind(this));
}
disconnectedCallback() {
this.unsubscribe.forEach(unsubscribe => unsubscribe());
super.disconnectedCallback();
document.removeEventListener('visibilitychange', this.onBuffering.bind(this));
}
render() {
if (!this.listing) {
throw new Error('w3m-connecting-wc-mobile: No listing provided');
}
this.isReady();
return html `
<w3m-connecting-widget
name=${this.listing.name}
imageSrc=${ifDefined(this.images[this.listing.image_id])}
.error=${this.error}
.onConnect=${this.onConnect.bind(this)}
.onCopyUri=${this.onCopyUri.bind(this)}
.autoConnect=${false}
></w3m-connecting-widget>
`;
}
isReady() {
onRenderProxy() {
if (!this.ready && this.uri) {
this.ready = true;
this.onConnect();
this.onConnect?.();
}
}
onConnect() {
if (this.listing && this.uri) {
onConnectProxy() {
if (this.wallet?.mobile_link && this.uri) {
try {
this.error = false;
const { mobile, name } = this.listing;
const { redirect, href } = CoreHelperUtil.formatNativeUrl(mobile.native ?? mobile.universal, this.uri);
const { mobile_link, name } = this.wallet;
const { redirect, href } = CoreHelperUtil.formatNativeUrl(mobile_link, this.uri);
ConnectionController.setWcLinking({ name, href });
ConnectionController.setRecentWallet(this.wallet);
CoreHelperUtil.openHref(redirect, '_self');

@@ -63,29 +46,16 @@ }

}
onCopyUri() {
try {
if (this.uri) {
CoreHelperUtil.copyToClopboard(this.uri);
SnackController.showSuccess('Link copied');
}
onBuffering() {
const isIos = CoreHelperUtil.isIos();
if (document?.visibilityState === 'visible' && !this.error && isIos) {
ConnectionController.setBuffering(true);
setTimeout(() => {
ConnectionController.setBuffering(false);
}, 5000);
}
catch {
SnackController.showError('Failed to copy');
}
}
};
__decorate([
state()
], W3mConnectingWcMobile.prototype, "error", void 0);
__decorate([
state()
], W3mConnectingWcMobile.prototype, "uri", void 0);
__decorate([
state()
], W3mConnectingWcMobile.prototype, "ready", void 0);
__decorate([
property({ type: Boolean })
], W3mConnectingWcMobile.prototype, "multiPlatfrom", void 0);
W3mConnectingWcMobile = __decorate([
customElement('w3m-connecting-wc-mobile')
], W3mConnectingWcMobile);
export { W3mConnectingWcMobile };
//# sourceMappingURL=index.js.map

@@ -7,27 +7,25 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {

};
import { ConnectionController, CoreHelperUtil, ExplorerApiController, RouterController, SnackController } from '@web3modal/core';
import { LitElement, html } from 'lit';
import { customElement, state } from 'lit/decorators.js';
import { AssetUtil, ConnectionController, ThemeController } from '@web3modal/core';
import { html } from 'lit';
import { customElement } from 'lit/decorators.js';
import { ifDefined } from 'lit/directives/if-defined.js';
import styles from './styles';
export let W3mConnectingWcQrcode = class W3mConnectingWcQrcode extends LitElement {
import { W3mConnectingWidget } from '../../utils/w3m-connecting-widget/index.js';
import styles from './styles.js';
let W3mConnectingWcQrcode = class W3mConnectingWcQrcode extends W3mConnectingWidget {
constructor() {
super();
this.unsubscribe = [];
this.timeout = undefined;
this.listing = RouterController.state.data?.listing;
this.images = ExplorerApiController.state.images;
this.uri = ConnectionController.state.wcUri;
this.ready = false;
this.unsubscribe.push(ConnectionController.subscribeKey('wcUri', val => (this.uri = val)));
this.forceUpdate = () => {
this.requestUpdate();
};
window.addEventListener('resize', this.forceUpdate);
}
disconnectedCallback() {
this.unsubscribe.forEach(unsubscribe => unsubscribe());
clearTimeout(this.timeout);
super.disconnectedCallback();
window.removeEventListener('resize', this.forceUpdate);
}
render() {
this.isReady();
this.onRenderProxy();
return html `
<wui-flex padding="xl" flexDirection="column" gap="xl" alignItems="center">
<wui-shimmer borderRadius="l" width="100%"> ${this.qrCodeTenmplate()} </wui-shimmer>
<wui-shimmer borderRadius="l" width="100%"> ${this.qrCodeTemplate()} </wui-shimmer>

@@ -45,8 +43,10 @@ <wui-text variant="paragraph-500" color="fg-100">

}
isReady() {
onRenderProxy() {
if (!this.ready && this.uri) {
this.timeout = setTimeout(() => (this.ready = true), 250);
this.timeout = setTimeout(() => {
this.ready = true;
}, 250);
}
}
qrCodeTenmplate() {
qrCodeTemplate() {
if (!this.uri || !this.ready) {

@@ -56,34 +56,19 @@ return null;

const size = this.getBoundingClientRect().width - 40;
const imageSrc = this.listing ? this.images[this.listing.image_id] : undefined;
const alt = this.listing ? this.listing.name : undefined;
const alt = this.wallet ? this.wallet.name : undefined;
ConnectionController.setWcLinking(undefined);
ConnectionController.setRecentWallet(this.wallet);
return html `<wui-qr-code
size=${size}
theme="dark"
theme=${ThemeController.state.themeMode}
uri=${this.uri}
imageSrc=${ifDefined(imageSrc)}
imageSrc=${ifDefined(AssetUtil.getWalletImage(this.wallet))}
alt=${ifDefined(alt)}
></wui-qr-code>`;
}
onCopyUri() {
try {
if (this.uri) {
CoreHelperUtil.copyToClopboard(this.uri);
SnackController.showSuccess('Link copied');
}
}
catch {
SnackController.showError('Failed to copy');
}
}
};
W3mConnectingWcQrcode.styles = styles;
__decorate([
state()
], W3mConnectingWcQrcode.prototype, "uri", void 0);
__decorate([
state()
], W3mConnectingWcQrcode.prototype, "ready", void 0);
W3mConnectingWcQrcode = __decorate([
customElement('w3m-connecting-wc-qrcode')
], W3mConnectingWcQrcode);
export { W3mConnectingWcQrcode };
//# sourceMappingURL=index.js.map

@@ -15,3 +15,3 @@ import { css } from 'lit';

aspect-ratio: 1 / 1;
border-radius: var(--wui-border-radius-m) !important;
border-radius: clamp(0px, var(--wui-border-radius-l), 40px) !important;
}

@@ -18,0 +18,0 @@

@@ -7,15 +7,14 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {

};
import { CoreHelperUtil, ExplorerApiController, RouterController } from '@web3modal/core';
import { AssetUtil, CoreHelperUtil, RouterController } from '@web3modal/core';
import { LitElement, html } from 'lit';
import { customElement } from 'lit/decorators.js';
import { ifDefined } from 'lit/directives/if-defined.js';
export let W3mConnectingWcUnsupported = class W3mConnectingWcUnsupported extends LitElement {
let W3mConnectingWcUnsupported = class W3mConnectingWcUnsupported extends LitElement {
constructor() {
super(...arguments);
this.listing = RouterController.state.data?.listing;
this.images = ExplorerApiController.state.images;
this.wallet = RouterController.state.data?.wallet;
}
render() {
if (!this.listing) {
throw new Error('w3m-connecting-wc-unsupported: No listing provided');
if (!this.wallet) {
throw new Error('w3m-connecting-wc-unsupported: No wallet provided');
}

@@ -31,3 +30,3 @@ return html `

size="lg"
imageSrc=${ifDefined(this.images[this.listing.image_id])}
imageSrc=${ifDefined(AssetUtil.getWalletImage(this.wallet))}
></wui-wallet-image>

@@ -38,18 +37,28 @@

<wui-text variant="small-500" color="fg-200" align="center">
Download and install ${this.listing.name} to continue
Download and install ${this.wallet.name} to continue
</wui-text>
</wui-flex>
<wui-button size="sm" variant="fill" @click=${this.onDownload}>
<wui-icon color="inherit" slot="iconRight" name="externalLink"></wui-icon>
Download
</wui-button>
${this.downloadBtnTemplate()}
</wui-flex>
`;
}
onDownload() {
if (!this.listing) {
throw new Error('w3m-connecting-wc-unsupported:onDownload No listing provided');
downloadBtnTemplate() {
if (!this.wallet) {
throw new Error('w3m-connecting-wc-unsupported:onDownload No wallet provided');
}
CoreHelperUtil.openHref(this.listing.homepage, '_blank');
const { homepage } = this.wallet;
if (!homepage) {
return null;
}
return html `
<wui-button
size="sm"
variant="fill"
@click=${() => CoreHelperUtil.openHref(homepage, '_blank')}
>
<wui-icon color="inherit" slot="iconRight" name="externalLink"></wui-icon>
Download
</wui-button>
`;
}

@@ -60,2 +69,3 @@ };

], W3mConnectingWcUnsupported);
export { W3mConnectingWcUnsupported };
//# sourceMappingURL=index.js.map

@@ -7,54 +7,24 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {

};
import { ConnectionController, CoreHelperUtil, ExplorerApiController, RouterController, SnackController } from '@web3modal/core';
import { LitElement, html } from 'lit';
import { customElement, property, state } from 'lit/decorators.js';
import { ifDefined } from 'lit/directives/if-defined.js';
export let W3mConnectingWcWeb = class W3mConnectingWcWeb extends LitElement {
import { ConnectionController, CoreHelperUtil } from '@web3modal/core';
import { customElement } from 'lit/decorators.js';
import { W3mConnectingWidget } from '../../utils/w3m-connecting-widget/index.js';
let W3mConnectingWcWeb = class W3mConnectingWcWeb extends W3mConnectingWidget {
constructor() {
super();
this.listing = RouterController.state.data?.listing;
this.images = ExplorerApiController.state.images;
this.unsubscribe = [];
this.timeout = undefined;
this.error = false;
this.uri = ConnectionController.state.wcUri;
this.ready = false;
this.multiPlatfrom = false;
this.unsubscribe.push(ConnectionController.subscribeKey('wcUri', val => (this.uri = val)));
}
disconnectedCallback() {
this.unsubscribe.forEach(unsubscribe => unsubscribe());
clearTimeout(this.timeout);
}
render() {
if (!this.listing) {
throw new Error('w3m-connecting-wc-web: No listing provided');
if (!this.wallet) {
throw new Error('w3m-connecting-wc-web: No wallet provided');
}
this.isReady();
return html `
<w3m-connecting-widget
name=${this.listing.name}
imageSrc=${ifDefined(this.images[this.listing.image_id])}
.error=${this.error}
.onConnect=${this.onConnect.bind(this)}
.onCopyUri=${this.onCopyUri.bind(this)}
.autoConnect=${false}
></w3m-connecting-widget>
`;
this.onConnect = this.onConnectProxy.bind(this);
this.secondaryBtnLabel = 'Open';
this.secondaryLabel = 'Open and continue in a new browser tab';
this.secondaryBtnIcon = 'externalLink';
}
isReady() {
if (!this.ready && this.uri) {
this.timeout = setTimeout(() => {
this.ready = true;
this.onConnect();
}, 250);
}
}
onConnect() {
if (this.listing && this.uri) {
onConnectProxy() {
if (this.wallet?.webapp_link && this.uri) {
try {
this.error = false;
const { desktop, name } = this.listing;
const { redirect, href } = CoreHelperUtil.formatUniversalUrl(desktop.universal, this.uri);
const { webapp_link, name } = this.wallet;
const { redirect, href } = CoreHelperUtil.formatUniversalUrl(webapp_link, this.uri);
ConnectionController.setWcLinking({ name, href });
ConnectionController.setRecentWallet(this.wallet);
CoreHelperUtil.openHref(redirect, '_blank');

@@ -67,29 +37,7 @@ }

}
onCopyUri() {
try {
if (this.uri) {
CoreHelperUtil.copyToClopboard(this.uri);
SnackController.showSuccess('Link copied');
}
}
catch {
SnackController.showError('Failed to copy');
}
}
};
__decorate([
state()
], W3mConnectingWcWeb.prototype, "error", void 0);
__decorate([
state()
], W3mConnectingWcWeb.prototype, "uri", void 0);
__decorate([
state()
], W3mConnectingWcWeb.prototype, "ready", void 0);
__decorate([
property({ type: Boolean })
], W3mConnectingWcWeb.prototype, "multiPlatfrom", void 0);
W3mConnectingWcWeb = __decorate([
customElement('w3m-connecting-wc-web')
], W3mConnectingWcWeb);
export { W3mConnectingWcWeb };
//# sourceMappingURL=index.js.map

@@ -7,14 +7,14 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {

};
import { ModalController, RouterController } from '@web3modal/core';
import { ConnectionController, ModalController, RouterController } from '@web3modal/core';
import { LitElement, html } from 'lit';
import { customElement, state } from 'lit/decorators.js';
import { animate } from 'motion';
import styles from './styles.js';
function headings() {
const connectorName = RouterController.state.data?.connector?.name;
const listingName = RouterController.state.data?.listing?.name;
const walletName = RouterController.state.data?.wallet?.name;
const networkName = RouterController.state.data?.network?.name;
const name = listingName ?? connectorName;
const name = walletName ?? connectorName;
return {
Connect: 'Connect Wallet',
Account: 'Account',
Account: undefined,
ConnectingExternal: name ?? 'Connect Wallet',

@@ -26,6 +26,7 @@ ConnectingWalletConnect: name ?? 'WalletConnect',

WhatIsANetwork: 'What is a network?',
WhatIsAWallet: 'What is a wallet?'
WhatIsAWallet: 'What is a wallet?',
GetWallet: 'Get a Wallet'
};
}
export let W3mHeader = class W3mHeader extends LitElement {
let W3mHeader = class W3mHeader extends LitElement {
constructor() {

@@ -35,2 +36,3 @@ super();

this.heading = headings()[RouterController.state.view];
this.buffering = false;
this.showBack = false;

@@ -40,3 +42,3 @@ this.unsubscribe.push(RouterController.subscribeKey('view', val => {

this.onHistoryChange();
}));
}), ConnectionController.subscribeKey('buffering', val => (this.buffering = val)));
}

@@ -48,15 +50,19 @@ disconnectCallback() {

return html `
<wui-flex
.padding=${['l', '2l', 'l', '2l']}
justifyContent="space-between"
alignItems="center"
>
${this.dynamicButtonTemplate()}
<wui-text variant="paragraph-700" color="fg-100">${this.heading}</wui-text>
<wui-icon-link icon="close" @click=${ModalController.close}></wui-icon-link>
<wui-flex .padding=${this.getPadding()} justifyContent="space-between" alignItems="center">
${this.dynamicButtonTemplate()} ${this.titleTemplate()}
<wui-icon-link
?disabled=${this.buffering}
icon="close"
@click=${ModalController.close}
></wui-icon-link>
</wui-flex>
<wui-separator></wui-separator>
${this.separatorTemplate()}
`;
}
titleTemplate() {
return html `<wui-text variant="paragraph-700" color="fg-100">${this.heading}</wui-text>`;
}
dynamicButtonTemplate() {
const { view } = RouterController.state;
const isConnectHelp = view === 'Connect';
if (this.showBack) {

@@ -66,2 +72,3 @@ return html `<wui-icon-link

icon="chevronLeft"
?disabled=${this.buffering}
@click=${RouterController.goBack}

@@ -71,14 +78,19 @@ ></wui-icon-link>`;

return html `<wui-icon-link
data-hidden=${!isConnectHelp}
id="dynamic"
icon="helpCircle"
@click=${this.handleHelpClick}
@click=${() => RouterController.push('WhatIsAWallet')}
></wui-icon-link>`;
}
handleHelpClick() {
if (RouterController.state.view === 'Networks') {
RouterController.push('WhatIsANetwork');
separatorTemplate() {
if (!this.heading) {
return null;
}
else {
RouterController.push('WhatIsAWallet');
return html `<wui-separator></wui-separator>`;
}
getPadding() {
if (this.heading) {
return ['l', '2l', 'l', '2l'];
}
return ['l', '2l', '0', '2l'];
}

@@ -89,5 +101,13 @@ async onViewChange(view) {

const preset = headings()[view];
await animate(headingEl, { opacity: [1, 0] }, { duration: 0.2 }).finished;
await headingEl.animate([{ opacity: 1 }, { opacity: 0 }], {
duration: 200,
fill: 'forwards',
easing: 'ease'
}).finished;
this.heading = preset;
animate(headingEl, { opacity: [0, 1] }, { duration: 0.2 });
headingEl.animate([{ opacity: 0 }, { opacity: 1 }], {
duration: 200,
fill: 'forwards',
easing: 'ease'
});
}

@@ -99,13 +119,30 @@ }

if (history.length > 1 && !this.showBack && buttonEl) {
await animate(buttonEl, { opacity: [1, 0] }, { duration: 0.2 }).finished;
await buttonEl.animate([{ opacity: 1 }, { opacity: 0 }], {
duration: 200,
fill: 'forwards',
easing: 'ease'
}).finished;
this.showBack = true;
animate(buttonEl, { opacity: [0, 1] }, { duration: 0.2 });
buttonEl.animate([{ opacity: 0 }, { opacity: 1 }], {
duration: 200,
fill: 'forwards',
easing: 'ease'
});
}
else if (history.length <= 1 && this.showBack && buttonEl) {
await animate(buttonEl, { opacity: [1, 0] }, { duration: 0.2 }).finished;
await buttonEl.animate([{ opacity: 1 }, { opacity: 0 }], {
duration: 200,
fill: 'forwards',
easing: 'ease'
}).finished;
this.showBack = false;
animate(buttonEl, { opacity: [0, 1] }, { duration: 0.2 });
buttonEl.animate([{ opacity: 0 }, { opacity: 1 }], {
duration: 200,
fill: 'forwards',
easing: 'ease'
});
}
}
};
W3mHeader.styles = [styles];
__decorate([

@@ -116,2 +153,5 @@ state()

state()
], W3mHeader.prototype, "buffering", void 0);
__decorate([
state()
], W3mHeader.prototype, "showBack", void 0);

@@ -121,2 +161,3 @@ W3mHeader = __decorate([

], W3mHeader);
export { W3mHeader };
//# sourceMappingURL=index.js.map

@@ -9,3 +9,3 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {

import { customElement, property } from 'lit/decorators.js';
export let W3mHelpWidget = class W3mHelpWidget extends LitElement {
let W3mHelpWidget = class W3mHelpWidget extends LitElement {
constructor() {

@@ -41,2 +41,3 @@ super(...arguments);

], W3mHelpWidget);
export { W3mHelpWidget };
//# sourceMappingURL=index.js.map

@@ -10,4 +10,3 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {

import { customElement, state } from 'lit/decorators.js';
import { animate } from 'motion';
import styles from './styles';
import styles from './styles.js';
const presets = {

@@ -25,3 +24,3 @@ success: {

};
export let W3mSnackBar = class W3mSnackBar extends LitElement {
let W3mSnackBar = class W3mSnackBar extends LitElement {
constructor() {

@@ -56,7 +55,21 @@ super();

if (this.open) {
animate(this, { opacity: [0, 1], x: ['-50%', '-50%'], scale: [0.85, 1] }, { duration: 0.15 });
this.animate([
{ opacity: 0, transform: 'translateX(-50%) scale(0.85)' },
{ opacity: 1, transform: 'translateX(-50%) scale(1)' }
], {
duration: 150,
fill: 'forwards',
easing: 'ease'
});
this.timeout = setTimeout(() => SnackController.hide(), 2500);
}
else {
animate(this, { opacity: [1, 0], x: ['-50%', '-50%'], scale: [1, 0.85] }, { duration: 0.15 });
this.animate([
{ opacity: 1, transform: 'translateX(-50%) scale(1)' },
{ opacity: 0, transform: 'translateX(-50%) scale(0.85)' }
], {
duration: 150,
fill: 'forwards',
easing: 'ease'
});
}

@@ -72,2 +85,3 @@ }

], W3mSnackBar);
export { W3mSnackBar };
//# sourceMappingURL=index.js.map

@@ -7,12 +7,13 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {

};
import { AccountController, ConnectionController, CoreHelperUtil, ModalController, RouterController, SnackController } from '@web3modal/core';
import { AccountController, AssetController, ConnectionController, CoreHelperUtil, ModalController, NetworkController, RouterController, SnackController } from '@web3modal/core';
import { UiHelperUtil } from '@web3modal/ui';
import { LitElement, html } from 'lit';
import { customElement, state } from 'lit/decorators.js';
import { ifDefined } from 'lit/directives/if-defined.js';
import styles from './styles';
import { UiHelperUtil } from '@web3modal/ui/src/utils/UiHelperUtils';
export let W3mAccountView = class W3mAccountView extends LitElement {
import styles from './styles.js';
let W3mAccountView = class W3mAccountView extends LitElement {
constructor() {
super();
this.usubscribe = [];
this.networkImages = AssetController.state.networkImages;
this.address = AccountController.state.address;

@@ -23,13 +24,21 @@ this.profileImage = AccountController.state.profileImage;

this.balanceSymbol = AccountController.state.balanceSymbol;
this.usubscribe.push(AccountController.subscribe(val => {
if (val.address) {
this.address = val.address;
this.profileImage = val.profileImage;
this.profileName = val.profileName;
this.balance = val.balance;
this.balanceSymbol = val.balanceSymbol;
this.network = NetworkController.state.caipNetwork;
this.disconecting = false;
this.usubscribe.push(...[
AccountController.subscribe(val => {
if (val.address) {
this.address = val.address;
this.profileImage = val.profileImage;
this.profileName = val.profileName;
this.balance = val.balance;
this.balanceSymbol = val.balanceSymbol;
}
else {
ModalController.close();
}
})
], NetworkController.subscribeKey('caipNetwork', val => {
if (val?.id) {
this.network = val;
}
else {
ModalController.close();
}
}));

@@ -44,8 +53,9 @@ }

}
const networkImage = this.networkImages[this.network?.imageId ?? ''];
return html `
<wui-flex
flexDirection="column"
.padding=${['s', 's', 'xl', 's']}
.padding=${['0', 's', 'm', 's']}
alignItems="center"
gap="xs"
gap="l"
>

@@ -58,12 +68,26 @@ <wui-avatar

<wui-flex gap="3xs" alignItems="center" justifyContent="center">
<wui-text variant="large-600" color="fg-100">
${this.profileName ?? UiHelperUtil.getTruncateAddress(this.address, 4)}
</wui-text>
<wui-icon-link
size="md"
icon="copy"
iconColor="fg-200"
@click=${this.onCopyAddress}
></wui-icon-link>
<wui-flex flexDirection="column" alignItems="center">
<wui-flex gap="3xs" alignItems="center" justifyContent="center">
<wui-text variant="large-600" color="fg-100">
${this.profileName
? UiHelperUtil.getTruncateString(this.profileName, 20, 'end')
: UiHelperUtil.getTruncateString(this.address, 8, 'middle')}
</wui-text>
<wui-icon-link
size="md"
icon="copy"
iconColor="fg-200"
@click=${this.onCopyAddress}
></wui-icon-link>
</wui-flex>
<wui-flex gap="s" flexDirection="column" alignItems="center">
<wui-text variant="paragraph-500" color="fg-200">
${CoreHelperUtil.formatBalance(this.balance, this.balanceSymbol)}
</wui-text>
<wui-button size="sm" variant="shade" @click=${this.onExplorer.bind(this)}>
<wui-icon size="sm" color="inherit" slot="iconLeft" name="compass"></wui-icon>
Block Explorer
<wui-icon size="sm" color="inherit" slot="iconRight" name="externalLink"></wui-icon>
</wui-button>
</wui-flex>
</wui-flex>

@@ -74,8 +98,12 @@ </wui-flex>

<wui-list-item
variant="icon"
.variant=${networkImage ? 'image' : 'icon'}
iconVariant="overlay"
icon="networkPlaceholder"
imageSrc=${ifDefined(networkImage)}
?chevron=${this.isMultiNetwork()}
@click=${this.onNetworks.bind(this)}
>
<wui-text variant="paragraph-500" color="fg-100">${this.showBalance()}</wui-text>
<wui-text variant="paragraph-500" color="fg-100">
${this.network?.name ?? 'Unknown'}
</wui-text>
</wui-list-item>

@@ -86,2 +114,4 @@ <wui-list-item

icon="disconnect"
?chevron=${false}
.loading=${this.disconecting}
@click=${this.onDisconnect.bind(this)}

@@ -94,2 +124,6 @@ >

}
isMultiNetwork() {
const { requestedCaipNetworks } = NetworkController.state;
return requestedCaipNetworks ? requestedCaipNetworks.length > 1 : false;
}
onCopyAddress() {

@@ -107,21 +141,25 @@ try {

onNetworks() {
RouterController.push('Networks');
if (this.isMultiNetwork()) {
RouterController.push('Networks');
}
}
async onDisconnect() {
await ConnectionController.disconnect();
ModalController.close();
}
showBalance() {
let formattedBalance = undefined;
if (this.balance === '0.0') {
formattedBalance = '0';
try {
this.disconecting = true;
await ConnectionController.disconnect();
ModalController.close();
}
else if (typeof this.balance === 'string' && this.balance.length > 6) {
formattedBalance = this.balance.substring(0, 6);
catch {
SnackController.showError('Failed to disconnect');
}
else if (typeof this.balance === 'string') {
formattedBalance = this.balance;
finally {
this.disconecting = false;
}
return formattedBalance ? `${formattedBalance} ${this.balanceSymbol}` : '_._';
}
onExplorer() {
const { addressExplorerUrl } = AccountController.state;
if (addressExplorerUrl) {
CoreHelperUtil.openHref(addressExplorerUrl, '_blank');
}
}
};

@@ -144,5 +182,12 @@ W3mAccountView.styles = styles;

], W3mAccountView.prototype, "balanceSymbol", void 0);
__decorate([
state()
], W3mAccountView.prototype, "network", void 0);
__decorate([
state()
], W3mAccountView.prototype, "disconecting", void 0);
W3mAccountView = __decorate([
customElement('w3m-account-view')
], W3mAccountView);
export { W3mAccountView };
//# sourceMappingURL=index.js.map

@@ -6,3 +6,11 @@ import { css } from 'lit';

}
:host > wui-flex:first-child {
transform: translateY(calc(var(--wui-spacing-xxs) * -1));
}
wui-icon-link {
margin-right: calc(var(--wui-icon-box-size-md) * -1);
}
`;
//# sourceMappingURL=styles.js.map

@@ -7,7 +7,6 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {

};
import { CoreHelperUtil } from '@web3modal/core';
import { CoreHelperUtil, RouterController } from '@web3modal/core';
import { LitElement, html } from 'lit';
import { customElement, state } from 'lit/decorators.js';
import styles from './styles';
export let W3mAllWalletsView = class W3mAllWalletsView extends LitElement {
let W3mAllWalletsView = class W3mAllWalletsView extends LitElement {
constructor() {

@@ -23,4 +22,5 @@ super(...arguments);

return html `
<wui-flex padding="s">
<wui-flex padding="s" gap="s">
<wui-search-bar @inputChange=${this.onInputChange.bind(this)}></wui-search-bar>
${this.qrButtonTemplate()}
</wui-flex>

@@ -35,4 +35,23 @@ ${isSearch

}
qrButtonTemplate() {
if (CoreHelperUtil.isMobile()) {
return html `
<wui-icon-box
size="lg"
iconcolor="accent-100"
backgroundcolor="accent-100"
icon="qrCode"
background="transparent"
border
borderColor="wui-accent-glass-010"
@click=${this.onWalletConnectQr.bind(this)}
></wui-icon-box>
`;
}
return null;
}
onWalletConnectQr() {
RouterController.push('ConnectingWalletConnect');
}
};
W3mAllWalletsView.styles = styles;
__decorate([

@@ -44,2 +63,3 @@ state()

], W3mAllWalletsView);
export { W3mAllWalletsView };
//# sourceMappingURL=index.js.map

@@ -7,10 +7,11 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {

};
import { ConnectorController, ExplorerApiController, RouterController } from '@web3modal/core';
import { ApiController, AssetUtil, ConnectionController, ConnectorController, CoreHelperUtil, OptionsController, RouterController, StorageUtil } from '@web3modal/core';
import { LitElement, html } from 'lit';
import { customElement, state } from 'lit/decorators.js';
export let W3mConnectView = class W3mConnectView extends LitElement {
import { ifDefined } from 'lit/directives/if-defined.js';
import styles from './styles.js';
let W3mConnectView = class W3mConnectView extends LitElement {
constructor() {
super();
this.unsubscribe = [];
this.images = ExplorerApiController.state.images;
this.connectors = ConnectorController.state.connectors;

@@ -23,24 +24,136 @@ this.unsubscribe.push(ConnectorController.subscribeKey('connectors', val => (this.connectors = val)));

render() {
const walletImages = Object.values(this.images).map(src => ({ src }));
return html `
<wui-flex flexDirection="column" padding="s" gap="xs">
${this.connectorsTemplate()}
<wui-list-wallet
name="All Wallets"
showAllWallets
.walletImages=${walletImages}
@click=${this.onAllWallets.bind(this)}
></wui-list-wallet>
${this.walletConnectConnectorTemplate()} ${this.recentTemplate()} ${this.featuredTemplate()}
${this.customTemplate()} ${this.recommendedTemplate()} ${this.connectorsTemplate()}
${this.allWalletsTemplate()}
</wui-flex>
<w3m-legal-footer></w3m-legal-footer>
`;
}
walletConnectConnectorTemplate() {
if (CoreHelperUtil.isMobile()) {
return null;
}
const connector = this.connectors.find(c => c.type === 'WALLET_CONNECT');
if (!connector) {
return null;
}
return html `
<wui-list-wallet
imageSrc=${ifDefined(AssetUtil.getConnectorImage(connector))}
name=${connector.name ?? 'Unknown'}
@click=${() => this.onConnector(connector)}
tagLabel="qr code"
tagVariant="main"
>
</wui-list-wallet>
`;
}
customTemplate() {
const { customWallets } = OptionsController.state;
if (!customWallets?.length) {
return null;
}
const wallets = this.filterOutRecentWallets(customWallets);
return wallets.map(wallet => html `
<wui-list-wallet
imageSrc=${ifDefined(AssetUtil.getWalletImage(wallet))}
name=${wallet.name ?? 'Unknown'}
@click=${() => RouterController.push('ConnectingWalletConnect', { wallet })}
>
</wui-list-wallet>
`);
}
featuredTemplate() {
const { featured } = ApiController.state;
if (!featured.length) {
return null;
}
const wallets = this.filterOutRecentWallets(featured);
return wallets.map(wallet => html `
<wui-list-wallet
imageSrc=${ifDefined(AssetUtil.getWalletImage(wallet))}
name=${wallet.name ?? 'Unknown'}
@click=${() => RouterController.push('ConnectingWalletConnect', { wallet })}
>
</wui-list-wallet>
`);
}
recentTemplate() {
const recent = StorageUtil.getRecentWallets();
return recent.map(wallet => html `
<wui-list-wallet
imageSrc=${ifDefined(AssetUtil.getWalletImage(wallet))}
name=${wallet.name ?? 'Unknown'}
@click=${() => RouterController.push('ConnectingWalletConnect', { wallet })}
tagLabel="recent"
tagVariant="shade"
>
</wui-list-wallet>
`);
}
connectorsTemplate() {
return this.connectors.map(connector => html `<wui-list-wallet
return this.connectors.map(connector => {
if (connector.type === 'WALLET_CONNECT') {
return null;
}
let tagLabel = undefined;
let tagVariant = undefined;
if (connector.type === 'INJECTED') {
const isInstalled = ConnectionController.checkInjectedInstalled();
if (!isInstalled) {
return null;
}
tagLabel = 'installed';
tagVariant = 'success';
}
return html `
<wui-list-wallet
imageSrc=${ifDefined(AssetUtil.getConnectorImage(connector))}
name=${connector.name ?? 'Unknown'}
@click=${() => this.onConnector(connector)}
></wui-list-wallet>`);
tagLabel=${ifDefined(tagLabel)}
tagVariant=${ifDefined(tagVariant)}
>
</wui-list-wallet>
`;
});
}
allWalletsTemplate() {
return html `
<wui-list-wallet
name="All Wallets"
walletIcon="allWallets"
showAllWallets
@click=${() => RouterController.push('AllWallets')}
tagLabel=${`${ApiController.state.count}+`}
tagVariant="shade"
></wui-list-wallet>
`;
}
recommendedTemplate() {
const { recommended, featured } = ApiController.state;
const { customWallets } = OptionsController.state;
if (!recommended.length || featured.length || customWallets?.length) {
return null;
}
const [first, second] = this.filterOutRecentWallets(recommended);
return [first, second].map(wallet => html `
<wui-list-wallet
imageSrc=${ifDefined(AssetUtil.getWalletImage(wallet))}
name=${wallet?.name ?? 'Unknown'}
@click=${() => RouterController.push('ConnectingWalletConnect', { wallet })}
>
</wui-list-wallet>
`);
}
onConnector(connector) {
if (connector.type === 'WALLET_CONNECT') {
RouterController.push('ConnectingWalletConnect', { connector });
if (CoreHelperUtil.isMobile()) {
RouterController.push('AllWallets');
}
else {
RouterController.push('ConnectingWalletConnect');
}
}

@@ -51,6 +164,10 @@ else {

}
onAllWallets() {
RouterController.push('AllWallets');
filterOutRecentWallets(wallets) {
const recent = StorageUtil.getRecentWallets();
const recentIds = recent.map(wallet => wallet.id);
const filtered = wallets.filter(wallet => !recentIds.includes(wallet.id));
return filtered;
}
};
W3mConnectView.styles = styles;
__decorate([

@@ -62,2 +179,3 @@ state()

], W3mConnectView);
export { W3mConnectView };
//# sourceMappingURL=index.js.map

@@ -7,25 +7,16 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {

};
import { ConnectionController, ModalController, RouterController } from '@web3modal/core';
import { LitElement, html } from 'lit';
import { customElement, state } from 'lit/decorators.js';
import { ifDefined } from 'lit/directives/if-defined.js';
export let W3mConnectingExternalView = class W3mConnectingExternalView extends LitElement {
import { ConnectionController, ModalController } from '@web3modal/core';
import { customElement } from 'lit/decorators.js';
import { W3mConnectingWidget } from '../../utils/w3m-connecting-widget/index.js';
let W3mConnectingExternalView = class W3mConnectingExternalView extends W3mConnectingWidget {
constructor() {
super(...arguments);
this.connector = RouterController.state.data?.connector;
this.error = false;
}
render() {
super();
if (!this.connector) {
throw new Error('w3m-connecting-view: No connector provided');
}
return html `
<w3m-connecting-widget
name=${ifDefined(this.connector.name)}
.error=${this.error}
.onConnect=${this.onConnect.bind(this)}
></w3m-connecting-widget>
`;
this.onConnect = this.onConnectProxy.bind(this);
this.onAutoConnect = this.onConnectProxy.bind(this);
this.isWalletConnect = false;
}
async onConnect() {
async onConnectProxy() {
try {

@@ -43,8 +34,6 @@ this.error = false;

};
__decorate([
state()
], W3mConnectingExternalView.prototype, "error", void 0);
W3mConnectingExternalView = __decorate([
customElement('w3m-connecting-external-view')
], W3mConnectingExternalView);
export { W3mConnectingExternalView };
//# sourceMappingURL=index.js.map

@@ -10,4 +10,3 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {

import { customElement, state } from 'lit/decorators.js';
import { animate } from 'motion';
export let W3mConnectingWcView = class W3mConnectingWcView extends LitElement {
let W3mConnectingWcView = class W3mConnectingWcView extends LitElement {
constructor() {

@@ -17,3 +16,3 @@ super();

this.lastRetry = Date.now();
this.listing = RouterController.state.data?.listing;
this.wallet = RouterController.state.data?.wallet;
this.platform = undefined;

@@ -28,3 +27,3 @@ this.platforms = [];

render() {
if (!this.listing) {
if (!this.wallet) {
return html `<w3m-connecting-wc-qrcode></w3m-connecting-wc-qrcode>`;

@@ -44,6 +43,3 @@ }

await ConnectionController.state.wcPromise;
const { wcLinking } = ConnectionController.state;
if (wcLinking) {
StorageUtil.setWalletConnectDeepLink(wcLinking);
}
this.storeWalletConnectDeeplink();
ModalController.close();

@@ -53,2 +49,3 @@ }

catch {
ConnectionController.setWcError(true);
if (CoreHelperUtil.isAllowedRetry(this.lastRetry)) {

@@ -61,5 +58,14 @@ SnackController.showError('Declined');

}
storeWalletConnectDeeplink() {
const { wcLinking, recentWallet } = ConnectionController.state;
if (wcLinking) {
StorageUtil.setWalletConnectDeepLink(wcLinking);
}
if (recentWallet) {
StorageUtil.setWeb3ModalRecent(recentWallet);
}
}
determinePlatforms() {
if (!this.listing) {
throw new Error('w3m-connecting-wc-view:determinePlatforms No listing');
if (!this.wallet) {
throw new Error('w3m-connecting-wc-view:determinePlatforms No wallet');
}

@@ -70,11 +76,11 @@ if (this.platform) {

const { connectors } = ConnectorController.state;
const { mobile, desktop, injected } = this.listing;
const injectedIds = injected?.map(({ injected_id }) => injected_id) ?? [];
const { mobile_link, desktop_link, webapp_link, injected } = this.wallet;
const injectedIds = injected?.map(({ injected_id }) => injected_id).filter(Boolean) ?? [];
const isInjected = injectedIds.length;
const isMobileWc = mobile?.native || mobile?.universal;
const isWebWc = desktop?.universal;
const isMobileWc = mobile_link;
const isWebWc = webapp_link;
const isInjectedConnector = connectors.find(c => c.type === 'INJECTED');
const isInjectedInstalled = ConnectionController.checkInjectedInstalled(injectedIds);
const isInjectedWc = isInjected && isInjectedInstalled && isInjectedConnector;
const isDesktopWc = desktop?.native && !CoreHelperUtil.isMobile();
const isDesktopWc = desktop_link && !CoreHelperUtil.isMobile();
if (isInjectedWc) {

@@ -98,22 +104,19 @@ this.platforms.push('injected');

platformTemplate() {
const multiPlatform = this.platforms.length > 1;
if (!this.platform) {
return null;
}
switch (this.platform) {
case 'injected':
return html `
<w3m-connecting-wc-injected .multiPlatfrom=${multiPlatform}></w3m-connecting-wc-injected>
`;
return html `<w3m-connecting-wc-injected></w3m-connecting-wc-injected>`;
case 'desktop':
return html `
<w3m-connecting-wc-desktop .multiPlatfrom=${multiPlatform}></w3m-connecting-wc-desktop>
<w3m-connecting-wc-desktop .onRetry=${() => this.initializeConnection(true)}>
</w3m-connecting-wc-desktop>
`;
case 'web':
return html `
<w3m-connecting-wc-web .multiPlatfrom=${multiPlatform}></w3m-connecting-wc-web>
<w3m-connecting-wc-web .onRetry=${() => this.initializeConnection(true)}>
</w3m-connecting-wc-web>
`;
case 'mobile':
return html `
<w3m-connecting-wc-mobile .multiPlatfrom=${multiPlatform}></w3m-connecting-wc-mobile>
<w3m-connecting-wc-mobile .onRetry=${() => this.initializeConnection(true)}>
</w3m-connecting-wc-mobile>
`;

@@ -142,5 +145,13 @@ case 'qrcode':

if (container) {
await animate(container, { opacity: [1, 0] }, { duration: 0.2 }).finished;
await container.animate([{ opacity: 1 }, { opacity: 0 }], {
duration: 200,
fill: 'forwards',
easing: 'ease'
}).finished;
this.platform = platform;
animate(container, { opacity: [0, 1] }, { duration: 0.2 });
container.animate([{ opacity: 0 }, { opacity: 1 }], {
duration: 200,
fill: 'forwards',
easing: 'ease'
});
}

@@ -158,2 +169,3 @@ }

], W3mConnectingWcView);
export { W3mConnectingWcView };
//# sourceMappingURL=index.js.map

@@ -7,15 +7,24 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {

};
import { NetworkController, RouterController } from '@web3modal/core';
import { AssetUtil, NetworkController, RouterController } from '@web3modal/core';
import { LitElement, html } from 'lit';
import { customElement, state } from 'lit/decorators.js';
import { ifDefined } from 'lit/directives/if-defined.js';
import { animate } from 'motion';
import styles from './styles';
export let W3mNetworkSwitchView = class W3mNetworkSwitchView extends LitElement {
import styles from './styles.js';
let W3mNetworkSwitchView = class W3mNetworkSwitchView extends LitElement {
constructor() {
super(...arguments);
super();
this.network = RouterController.state.data?.network;
this.unsubscribe = [];
this.showRetry = false;
this.error = false;
this.currentNetwork = NetworkController.state.caipNetwork;
this.unsubscribe.push(NetworkController.subscribeKey('caipNetwork', val => {
if (val?.id !== this.currentNetwork?.id) {
RouterController.goBack();
}
}));
}
disconnectedCallback() {
this.unsubscribe.forEach(unsubscribe => unsubscribe());
}
firstUpdated() {

@@ -44,3 +53,3 @@ this.onSwitchNetwork();

size="lg"
imageSrc=${ifDefined(this.network.imageSrc)}
imageSrc=${ifDefined(AssetUtil.getNetworkImage(this.network))}
></wui-network-image>

@@ -56,3 +65,4 @@

size="sm"
border
?border=${true}
borderColor="wui-color-bg-125"
></wui-icon-box>

@@ -82,3 +92,6 @@ </wui-flex>

const retryButton = this.shadowRoot?.querySelector('wui-button');
animate(retryButton, { opacity: [0, 1] });
retryButton.animate([{ opacity: 0 }, { opacity: 1 }], {
fill: 'forwards',
easing: 'ease'
});
}

@@ -91,3 +104,2 @@ }

await NetworkController.switchActiveNetwork(this.network);
RouterController.goBack();
}

@@ -107,5 +119,9 @@ }

], W3mNetworkSwitchView.prototype, "error", void 0);
__decorate([
state()
], W3mNetworkSwitchView.prototype, "currentNetwork", void 0);
W3mNetworkSwitchView = __decorate([
customElement('w3m-network-switch-view')
], W3mNetworkSwitchView);
export { W3mNetworkSwitchView };
//# sourceMappingURL=index.js.map

@@ -35,2 +35,3 @@ import { css } from 'lit';

transform: scale(0.5);
z-index: 1;
transition: all var(--wui-ease-out-power-2) var(--wui-duration-lg);

@@ -37,0 +38,0 @@ }

@@ -7,7 +7,7 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {

};
import { AccountController, NetworkController, RouterController } from '@web3modal/core';
import { AccountController, AssetUtil, NetworkController, RouterController } from '@web3modal/core';
import { LitElement, html } from 'lit';
import { customElement, state } from 'lit/decorators.js';
import { ifDefined } from 'lit/directives/if-defined.js';
export let W3mNetworksView = class W3mNetworksView extends LitElement {
let W3mNetworksView = class W3mNetworksView extends LitElement {
constructor() {

@@ -30,6 +30,10 @@ super();

<wui-flex padding="s">
<wui-flex padding="s" flexDirection="column" gap="m" alignItems="center">
<wui-text variant="small-500" color="fg-300" align="center">
Your connected wallet may not support some of the networks available for this dApp
</wui-text>
<wui-link @click=${() => RouterController.push('WhatIsANetwork')}>
<wui-icon size="xs" color="accent-100" slot="iconLeft" name="helpCircle"></wui-icon>
What is a network
</wui-link>
</wui-flex>

@@ -48,3 +52,3 @@ `;

.selected=${this.caipNetwork?.id === network.id}
imageSrc=${ifDefined(network.imageSrc)}
imageSrc=${ifDefined(AssetUtil.getNetworkImage(network))}
type="network"

@@ -80,2 +84,3 @@ name=${network.name ?? network.id}

], W3mNetworksView);
export { W3mNetworksView };
//# sourceMappingURL=index.js.map

@@ -7,4 +7,3 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {

};
import { RouterController } from '@web3modal/core';
import { resetStyles } from '@web3modal/ui/src/utils/ThemeUtil';
import { CoreHelperUtil } from '@web3modal/core';
import { LitElement, html } from 'lit';

@@ -21,6 +20,6 @@ import { customElement } from 'lit/decorators.js';

title: 'Designed for different uses',
text: 'A wallet lets you store, send and receive digital assets like cryptocurrencies and NFTs.'
text: 'Each network is designed differently, and may therefore suit certain apps and experiences.'
}
];
export let W3mWhatIsANetworkView = class W3mWhatIsANetworkView extends LitElement {
let W3mWhatIsANetworkView = class W3mWhatIsANetworkView extends LitElement {
render() {

@@ -38,3 +37,5 @@ return html `

size="sm"
@click=${() => RouterController.push('WhatIsANetwork')}
@click=${() => {
CoreHelperUtil.openHref('https://ethereum.org/en/developers/docs/networks/', '_blank');
}}
>

@@ -48,6 +49,6 @@ Learn more

};
W3mWhatIsANetworkView.styles = [resetStyles];
W3mWhatIsANetworkView = __decorate([
customElement('w3m-what-is-a-network-view')
], W3mWhatIsANetworkView);
export { W3mWhatIsANetworkView };
//# sourceMappingURL=index.js.map

@@ -8,3 +8,2 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {

import { RouterController } from '@web3modal/core';
import { resetStyles } from '@web3modal/ui/src/utils/ThemeUtil';
import { LitElement, html } from 'lit';

@@ -29,3 +28,3 @@ import { customElement } from 'lit/decorators.js';

];
export let W3mWhatIsAWalletView = class W3mWhatIsAWalletView extends LitElement {
let W3mWhatIsAWalletView = class W3mWhatIsAWalletView extends LitElement {
render() {

@@ -40,3 +39,3 @@ return html `

<w3m-help-widget .data=${data}></w3m-help-widget>
<wui-button variant="fill" size="sm" @click=${() => RouterController.push('WhatIsAWallet')}>
<wui-button variant="fill" size="sm" @click=${() => RouterController.push('GetWallet')}>
<wui-icon color="inherit" slot="iconLeft" name="wallet"></wui-icon>

@@ -49,6 +48,6 @@ Get a Wallet

};
W3mWhatIsAWalletView.styles = [resetStyles];
W3mWhatIsAWalletView = __decorate([
customElement('w3m-what-is-a-wallet-view')
], W3mWhatIsAWalletView);
export { W3mWhatIsAWalletView };
//# sourceMappingURL=index.js.map

@@ -1,26 +0,32 @@

export * from './src/modal/w3m-modal';
export * from './src/modal/w3m-router';
export * from './src/views/w3m-account-view';
export * from './src/views/w3m-all-wallets-view';
export * from './src/views/w3m-connect-view';
export * from './src/views/w3m-connecting-external-view';
export * from './src/views/w3m-connecting-wc-view';
export * from './src/views/w3m-network-switch-view';
export * from './src/views/w3m-networks-view';
export * from './src/views/w3m-what-is-a-network-view';
export * from './src/views/w3m-what-is-a-wallet-view';
export * from './src/partials/w3m-all-wallets-list';
export * from './src/partials/w3m-all-wallets-search';
export * from './src/partials/w3m-connecting-header';
export * from './src/partials/w3m-connecting-wc-desktop';
export * from './src/partials/w3m-connecting-wc-injected';
export * from './src/partials/w3m-connecting-wc-mobile';
export * from './src/partials/w3m-connecting-wc-qrcode';
export * from './src/partials/w3m-connecting-wc-unsupported';
export * from './src/partials/w3m-connecting-wc-web';
export * from './src/partials/w3m-connecting-widget';
export * from './src/partials/w3m-header';
export * from './src/partials/w3m-help-widget';
export * from './src/partials/w3m-snackbar';
export { Web3ModalScaffoldHtml } from './src/client';
export * from './src/modal/w3m-account-button/index.js';
export * from './src/modal/w3m-button/index.js';
export * from './src/modal/w3m-connect-button/index.js';
export * from './src/modal/w3m-modal/index.js';
export * from './src/modal/w3m-network-button/index.js';
export * from './src/modal/w3m-router/index.js';
export * from './src/views/w3m-account-view/index.js';
export * from './src/views/w3m-all-wallets-view/index.js';
export * from './src/views/w3m-connect-view/index.js';
export * from './src/views/w3m-connecting-external-view/index.js';
export * from './src/views/w3m-connecting-wc-view/index.js';
export * from './src/views/w3m-get-wallet-view/index.js';
export * from './src/views/w3m-network-switch-view/index.js';
export * from './src/views/w3m-networks-view/index.js';
export * from './src/views/w3m-what-is-a-network-view/index.js';
export * from './src/views/w3m-what-is-a-wallet-view/index.js';
export * from './src/partials/w3m-all-wallets-list/index.js';
export * from './src/partials/w3m-all-wallets-search/index.js';
export * from './src/partials/w3m-connecting-header/index.js';
export * from './src/partials/w3m-connecting-wc-desktop/index.js';
export * from './src/partials/w3m-connecting-wc-injected/index.js';
export * from './src/partials/w3m-connecting-wc-mobile/index.js';
export * from './src/partials/w3m-connecting-wc-qrcode/index.js';
export * from './src/partials/w3m-connecting-wc-unsupported/index.js';
export * from './src/partials/w3m-connecting-wc-web/index.js';
export * from './src/partials/w3m-header/index.js';
export * from './src/partials/w3m-help-widget/index.js';
export * from './src/partials/w3m-legal-footer/index.js';
export * from './src/partials/w3m-snackbar/index.js';
export { Web3ModalScaffold } from './src/client.js';
export type { LibraryOptions, ScaffoldOptions } from './src/client.js';
export type * from '@web3modal/core';

@@ -1,13 +0,34 @@

import type { ConnectionControllerClient, ExplorerApiControllerState, ModalControllerArguments, NetworkControllerClient } from '@web3modal/core';
import { AccountController, ConnectionController, ConnectorController, NetworkController } from '@web3modal/core';
interface Options {
import type { ApiControllerState, ConnectionControllerClient, NetworkControllerClient, NetworkControllerState, OptionsControllerState, ThemeControllerState, ThemeMode, ThemeVariables } from '@web3modal/core';
import { AccountController, BlockchainApiController, ConnectionController, ConnectorController, NetworkController } from '@web3modal/core';
export interface LibraryOptions {
projectId: OptionsControllerState['projectId'];
themeMode?: ThemeMode;
themeVariables?: ThemeVariables;
includeWalletIds?: OptionsControllerState['includeWalletIds'];
excludeWalletIds?: OptionsControllerState['excludeWalletIds'];
featuredWalletIds?: OptionsControllerState['featuredWalletIds'];
defaultChain?: NetworkControllerState['caipNetwork'];
tokens?: OptionsControllerState['tokens'];
termsConditionsUrl?: OptionsControllerState['termsConditionsUrl'];
privacyPolicyUrl?: OptionsControllerState['privacyPolicyUrl'];
customWallets?: OptionsControllerState['customWallets'];
_sdkVersion: ApiControllerState['sdkVersion'];
}
export interface ScaffoldOptions extends LibraryOptions {
networkControllerClient: NetworkControllerClient;
connectionControllerClient: ConnectionControllerClient;
projectId: ExplorerApiControllerState['projectId'];
}
export declare class Web3ModalScaffoldHtml {
export interface OpenOptions {
view: 'Account' | 'Connect' | 'Networks';
}
export declare class Web3ModalScaffold {
private initPromise?;
constructor(options: Options);
open(options?: ModalControllerArguments['open']): Promise<void>;
constructor(options: ScaffoldOptions);
open(options?: OpenOptions): Promise<void>;
close(): Promise<void>;
getThemeMode(): ThemeMode;
getThemeVariables(): ThemeVariables;
setThemeMode(themeMode: ThemeControllerState['themeMode']): void;
setThemeVariables(themeVariables: ThemeControllerState['themeVariables']): void;
subscribeTheme(callback: (newState: ThemeControllerState) => void): () => void;
protected setIsConnected: (typeof AccountController)['setIsConnected'];

@@ -26,5 +47,6 @@ protected setCaipAddress: (typeof AccountController)['setCaipAddress'];

protected resetWcConnection: (typeof ConnectionController)['resetWcConnection'];
protected fetchIdentity: (typeof BlockchainApiController)['fetchIdentity'];
protected setAddressExplorerUrl: (typeof AccountController)['setAddressExplorerUrl'];
private initControllers;
private initOrContinue;
}
export {};

@@ -11,2 +11,3 @@ import { LitElement } from 'lit';

private onOverlayClick;
private initializeTheming;
private onClose;

@@ -13,0 +14,0 @@ private onOpen;

@@ -7,4 +7,5 @@ import { LitElement } from 'lit';

private initial;
private listings;
private wallets;
private recommended;
private featured;
constructor();

@@ -19,3 +20,3 @@ firstUpdated(): void;

private createPaginationObserver;
private onConnectListing;
private onConnectWallet;
}

@@ -22,0 +23,0 @@ declare global {

@@ -10,3 +10,3 @@ import { LitElement } from 'lit';

private walletsTemplate;
private onConnectListing;
private onConnectWallet;
}

@@ -13,0 +13,0 @@ declare global {

@@ -5,4 +5,8 @@ import type { Platform } from '@web3modal/core';

private platformTabs;
private unsubscribe;
platforms: Platform[];
onSelectPlatfrom?: (platform: Platform) => void;
private buffering;
constructor();
disconnectCallback(): void;
render(): import("lit-html").TemplateResult<1>;

@@ -9,0 +13,0 @@ private generateTabs;

@@ -1,17 +0,6 @@

import { LitElement } from 'lit';
export declare class W3mConnectingWcDesktop extends LitElement {
private readonly listing;
private readonly images;
private unsubscribe;
private timeout?;
private error;
private uri;
private ready;
multiPlatfrom: boolean;
import { W3mConnectingWidget } from '../../utils/w3m-connecting-widget/index.js';
export declare class W3mConnectingWcDesktop extends W3mConnectingWidget {
constructor();
disconnectedCallback(): void;
render(): import("lit-html").TemplateResult<1>;
private isReady;
private onConnect;
private onCopyUri;
private onRenderProxy;
private onConnectProxy;
}

@@ -18,0 +7,0 @@ declare global {

@@ -1,9 +0,5 @@

import { LitElement } from 'lit';
export declare class W3mConnectingWcInjected extends LitElement {
private readonly listing;
private readonly images;
private error;
multiPlatfrom: boolean;
render(): import("lit-html").TemplateResult<1>;
private onConnect;
import { W3mConnectingWidget } from '../../utils/w3m-connecting-widget/index.js';
export declare class W3mConnectingWcInjected extends W3mConnectingWidget {
constructor();
private onConnectProxy;
}

@@ -10,0 +6,0 @@ declare global {

@@ -1,16 +0,8 @@

import { LitElement } from 'lit';
export declare class W3mConnectingWcMobile extends LitElement {
private readonly listing;
private readonly images;
private unsubscribe;
private error;
private uri;
private ready;
multiPlatfrom: boolean;
import { W3mConnectingWidget } from '../../utils/w3m-connecting-widget/index.js';
export declare class W3mConnectingWcMobile extends W3mConnectingWidget {
constructor();
disconnectedCallback(): void;
render(): import("lit-html").TemplateResult<1>;
private isReady;
private onConnect;
private onCopyUri;
private onRenderProxy;
private onConnectProxy;
private onBuffering;
}

@@ -17,0 +9,0 @@ declare global {

@@ -1,16 +0,10 @@

import { LitElement } from 'lit';
export declare class W3mConnectingWcQrcode extends LitElement {
import { W3mConnectingWidget } from '../../utils/w3m-connecting-widget/index.js';
export declare class W3mConnectingWcQrcode extends W3mConnectingWidget {
static styles: import("lit").CSSResult;
private unsubscribe;
private timeout?;
private readonly listing;
private readonly images;
private uri;
private ready;
constructor();
disconnectedCallback(): void;
render(): import("lit-html").TemplateResult<1>;
private isReady;
private qrCodeTenmplate;
private onCopyUri;
private onRenderProxy;
private qrCodeTemplate;
private forceUpdate;
}

@@ -17,0 +11,0 @@ declare global {

import { LitElement } from 'lit';
export declare class W3mConnectingWcUnsupported extends LitElement {
private readonly listing;
private readonly images;
private readonly wallet;
render(): import("lit-html").TemplateResult<1>;
private onDownload;
private downloadBtnTemplate;
}

@@ -8,0 +7,0 @@ declare global {

@@ -1,17 +0,5 @@

import { LitElement } from 'lit';
export declare class W3mConnectingWcWeb extends LitElement {
private readonly listing;
private readonly images;
private unsubscribe;
private timeout?;
private error;
private uri;
private ready;
multiPlatfrom: boolean;
import { W3mConnectingWidget } from '../../utils/w3m-connecting-widget/index.js';
export declare class W3mConnectingWcWeb extends W3mConnectingWidget {
constructor();
disconnectedCallback(): void;
render(): import("lit-html").TemplateResult<1>;
private isReady;
private onConnect;
private onCopyUri;
private onConnectProxy;
}

@@ -18,0 +6,0 @@ declare global {

import { LitElement } from 'lit';
export declare class W3mHeader extends LitElement {
static styles: import("lit").CSSResult[];
private unsubscribe;
private heading;
private buffering;
private showBack;

@@ -9,4 +11,6 @@ constructor();

render(): import("lit-html").TemplateResult<1>;
private titleTemplate;
private dynamicButtonTemplate;
private handleHelpClick;
private separatorTemplate;
private getPadding;
private onViewChange;

@@ -13,0 +17,0 @@ private onHistoryChange;

@@ -1,2 +0,2 @@

import type { VisualType } from '@web3modal/ui/src/utils/TypesUtil';
import type { VisualType } from '@web3modal/ui';
import { LitElement } from 'lit';

@@ -3,0 +3,0 @@ type Data = {

@@ -5,2 +5,3 @@ import { LitElement } from 'lit';

private usubscribe;
private readonly networkImages;
private address;

@@ -11,9 +12,12 @@ private profileImage;

private balanceSymbol;
private network;
private disconecting;
constructor();
disconnectedCallback(): void;
render(): import("lit-html").TemplateResult<1>;
private isMultiNetwork;
private onCopyAddress;
private onNetworks;
private onDisconnect;
private showBalance;
private onExplorer;
}

@@ -20,0 +24,0 @@ declare global {

import { LitElement } from 'lit';
export declare class W3mAllWalletsView extends LitElement {
static styles: import("lit").CSSResult;
private search;

@@ -8,2 +7,4 @@ render(): import("lit-html").TemplateResult<1>;

private onDebouncedSearch;
private qrButtonTemplate;
private onWalletConnectQr;
}

@@ -10,0 +11,0 @@ declare global {

import { LitElement } from 'lit';
export declare class W3mConnectView extends LitElement {
static styles: import("lit").CSSResult;
private unsubscribe;
private images;
private connectors;

@@ -9,5 +9,11 @@ constructor();

render(): import("lit-html").TemplateResult<1>;
private walletConnectConnectorTemplate;
private customTemplate;
private featuredTemplate;
private recentTemplate;
private connectorsTemplate;
private allWalletsTemplate;
private recommendedTemplate;
private onConnector;
private onAllWallets;
private filterOutRecentWallets;
}

@@ -14,0 +20,0 @@ declare global {

@@ -1,7 +0,5 @@

import { LitElement } from 'lit';
export declare class W3mConnectingExternalView extends LitElement {
private readonly connector;
private error;
render(): import("lit-html").TemplateResult<1>;
private onConnect;
import { W3mConnectingWidget } from '../../utils/w3m-connecting-widget/index.js';
export declare class W3mConnectingExternalView extends W3mConnectingWidget {
constructor();
private onConnectProxy;
}

@@ -8,0 +6,0 @@ declare global {

@@ -5,3 +5,3 @@ import { LitElement } from 'lit';

private lastRetry;
private listing;
private wallet;
private platform?;

@@ -13,2 +13,3 @@ private platforms;

private initializeConnection;
private storeWalletConnectDeeplink;
private determinePlatforms;

@@ -15,0 +16,0 @@ private platformTemplate;

@@ -5,4 +5,8 @@ import { LitElement } from 'lit';

private network;
private unsubscribe;
private showRetry;
error: boolean;
private currentNetwork;
constructor();
disconnectedCallback(): void;
firstUpdated(): void;

@@ -9,0 +13,0 @@ render(): import("lit-html").TemplateResult<1>;

import { LitElement } from 'lit';
export declare class W3mWhatIsANetworkView extends LitElement {
static styles: import("lit").CSSResult[];
render(): import("lit-html").TemplateResult<1>;

@@ -5,0 +4,0 @@ }

import { LitElement } from 'lit';
export declare class W3mWhatIsAWalletView extends LitElement {
static styles: import("lit").CSSResult[];
render(): import("lit-html").TemplateResult<1>;

@@ -5,0 +4,0 @@ }

{
"name": "@web3modal/scaffold",
"version": "3.0.0-84bf2f84",
"version": "3.0.0-90049a6a",
"type": "module",

@@ -12,12 +12,11 @@ "main": "./dist/esm/index.js",

"build:clean": "rm -rf dist",
"build:types": "tsc --declaration --emitDeclarationOnly --outDir ./dist/types",
"build:source": "tsc --outDir ./dist/esm",
"build": "npm run build:clean; npm run build:types; npm run build:source",
"typecheck": "tsc --noEmit"
"build": "npm run build:clean; tsc --build; rm dist/esm/tsconfig.tsbuildinfo",
"watch": "npm run build:clean; tsc --watch",
"typecheck": "tsc --noEmit",
"lint": "eslint . --ext .js,.jsx,.ts,.tsx"
},
"dependencies": {
"@web3modal/core": "3.0.0-84bf2f84",
"@web3modal/ui": "3.0.0-84bf2f84",
"lit": "2.7.6",
"motion": "10.16.2"
"@web3modal/core": "3.0.0-90049a6a",
"@web3modal/ui": "3.0.0-90049a6a",
"lit": "2.8.0"
},

@@ -24,0 +23,0 @@ "keywords": [

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc