UNPKG

@thirdweb-dev/wallets

Version:

<p align="center"> <br /> <a href="https://thirdweb.com"><img src="https://github.com/thirdweb-dev/js/blob/main/legacy_packages/sdk/logo.svg?raw=true" width="200" alt=""/></a> <br /> </p> <h1 align="center">thirdweb Wallet SDK</h1> <p align="center"> <a h

209 lines (198 loc) • 7.26 kB
'use strict'; Object.defineProperty(exports, '__esModule', { value: true }); var defineProperty = require('../../../../dist/defineProperty-9051a5d3.cjs.dev.js'); var connector = require('../../../../dist/connector-a63dd9e7.cjs.dev.js'); var assertWindowEthereum = require('../../../../dist/assertWindowEthereum-0709ee9e.cjs.dev.js'); var evm_wallets_base_dist_thirdwebDevWalletsEvmWalletsBase = require('../../../../dist/base-23fd36a9.cjs.dev.js'); var walletIds = require('../../../../dist/walletIds-a0be5020.cjs.dev.js'); var wc = require('../../../../dist/wc-6f95118d.cjs.dev.js'); require('eventemitter3'); require('@thirdweb-dev/chains'); require('../../abstract/dist/thirdweb-dev-wallets-evm-wallets-abstract.cjs.dev.js'); require('ethers'); require('@thirdweb-dev/sdk'); require('../../../../dist/headers-2be346e5.cjs.dev.js'); /** * Wallet interface for connecting [Trust Wallet](https://trustwallet.com/) extension or mobile app. * @example * ```javascript * import { TrustWallet } from "@thirdweb-dev/wallets"; * * const wallet = new TrustWallet(); * * wallet.connect(); * ``` * @wallet */ class TrustWallet extends evm_wallets_base_dist_thirdwebDevWalletsEvmWalletsBase.AbstractClientWallet { /** * @internal */ get walletName() { return "Trust Wallet"; } /** * Create instance of `TrustWallet` * @param options - The `options` object contains the following properties: * ### clientId (recommended) * * Provide `clientId` to use the thirdweb RPCs for given `chains` * * You can create a client ID for your application from [thirdweb dashboard](https://thirdweb.com/create-api-key). * * ### projectId (recommended) * * This is only relevant if you want to use [WalletConnect](https://walletconnect.com/) for connecting to Zerion wallet mobile app when MetaMask is not injected. * * This `projectId` can be obtained at [cloud.walletconnect.com](https://cloud.walletconnect.com/). It is highly recommended to use your own project id and only use the default one for testing purposes. * * * ### chains (optional) * Provide an array of chains you want to support. * * Must be an array of `Chain` objects, from the [`@thirdweb-dev/chains`](https://www.npmjs.com/package/\@thirdweb-dev/chains) package. * * Defaults to our [default chains](/react/react.thirdwebprovider#default-chains). * * ### dappMetadata (optional) * Information about your app that the wallet will display when your app tries to connect to it. * * Must be an object containing `name`, `url`, and optionally `description` and `logoUrl` properties. * * ### qrcode * Whether to display the Wallet Connect QR code Modal or not. * * Must be a `boolean`. Defaults to `true`. * * ### qrModalOptions * WalletConnect's [options](https://docs.walletconnect.com/advanced/walletconnectmodal/options) to customize the QR Code Modal. * */ constructor(options) { super(TrustWallet.id, options); if (assertWindowEthereum.assertWindowEthereum(globalThis.window)) { this.isInjected = !!globalThis.window.ethereum?.isTrust; } else { this.isInjected = false; } } async getConnector() { if (!this.connector) { // if trust is injected, use the injected connector // otherwise, use the wallet connect connector for using the trust app on mobile via QR code scan if (this.isInjected) { // import the connector dynamically const { TrustConnector } = await Promise.resolve().then(function () { return require('../../../connectors/trust/dist/thirdweb-dev-wallets-evm-connectors-trust.cjs.dev.js'); }); const trustConnector = new TrustConnector({ chains: this.chains, connectorStorage: this.walletStorage, options: { shimDisconnect: true } }); this.trustConnector = trustConnector; this.connector = new connector.WagmiAdapter(trustConnector); } else { const { WalletConnectConnector } = await Promise.resolve().then(function () { return require('../../../connectors/wallet-connect/dist/thirdweb-dev-wallets-evm-connectors-wallet-connect.cjs.dev.js'); }); const walletConnectConnector = new WalletConnectConnector({ chains: this.chains, options: { projectId: this.options?.projectId || wc.TW_WC_PROJECT_ID, // TODO, storage: this.walletStorage, qrcode: this.options?.qrcode, dappMetadata: this.dappMetadata, qrModalOptions: this.options?.qrModalOptions } }); walletConnectConnector.getProvider().then(provider => { provider.signer.client.on("session_request_sent", () => { this.emit("wc_session_request_sent"); }); }); // need to save this for getting the QR code URI this.walletConnectConnector = walletConnectConnector; this.connector = new connector.WagmiAdapter(walletConnectConnector); } } return this.connector; } /** * Connect to the wallet using a QR code. * You can use this method to display a QR code. The user can scan this QR code using the Trust Wallet mobile app to connect to your dapp. * * @example * ```typescript * wallet.connectWithQrCode({ * chainId: 1, * onQrCodeUri(qrCodeUri) { * // render the QR code with `qrCodeUri` * }, * onConnected(accountAddress) { * // update UI to show connected state * }, * }) * ``` * * @param options - * The options object contains the following properties/method: * * ### chainId (optional) * If provided, wallet will prompt the user to switch to the network with the given `chainId` after connecting. * * ### onQrCodeUri * A callback to get the QR code URI to display to the user. * * ### onConnected * A callback that is called when the user has connected their wallet using the QR code. */ async connectWithQrCode(options) { await this.getConnector(); const wcConnector = this.walletConnectConnector; if (!wcConnector) { throw new Error("WalletConnect connector not found"); } const wcProvider = await wcConnector.getProvider(); // set a listener for display_uri event wcProvider.on("display_uri", uri => { options.onQrCodeUri(uri); }); // trigger connect flow this.connect({ chainId: options.chainId }).then(options.onConnected); } } /** * @internal */ /** * @internal */ /** * @internal */ /** * @internal */ /** * @internal */ defineProperty._defineProperty(TrustWallet, "meta", { name: "Trust Wallet", iconURL: "ipfs://QmNigQbXk7wKZwDcgN38Znj1ZZQ3JEG3DD6fUKLBU8SUTP/trust%20wallet.svg", urls: { chrome: "https://chrome.google.com/webstore/detail/trust-wallet/egjidjbpglichdcondbcbdnbeeppgdph", android: "https://play.google.com/store/apps/details?id=com.wallet.crypto.trustapp", ios: "https://apps.apple.com/us/app/trust-crypto-bitcoin-wallet/id1288339409" } }); /** * @internal */ defineProperty._defineProperty(TrustWallet, "id", walletIds.walletIds.trust); exports.TrustWallet = TrustWallet;