From 3f6885acad09dce93db50667fd125026c90d879c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?S=C3=B8ren=20Bruus=20Zeppelin?= Date: Mon, 15 Apr 2024 16:00:53 +0200 Subject: [PATCH] Update wc modal (#65) ## Purpose Deep linking does not work with the deprecated `@walletconnect/qrcode-modal`. This PR aims to update the dependency. --- packages/wallet-connectors/CHANGELOG.md | 12 + packages/wallet-connectors/package.json | 3 +- .../wallet-connectors/src/WalletConnect.ts | 219 +++++++- samples/contractupdate/src/config.ts | 12 +- samples/proofs/src/config.ts | 12 +- samples/sign-message/src/config.ts | 12 +- yarn.lock | 477 ++++++++++-------- 7 files changed, 509 insertions(+), 238 deletions(-) diff --git a/packages/wallet-connectors/CHANGELOG.md b/packages/wallet-connectors/CHANGELOG.md index de59203..a869962 100644 --- a/packages/wallet-connectors/CHANGELOG.md +++ b/packages/wallet-connectors/CHANGELOG.md @@ -5,6 +5,18 @@ All notable changes to this project will be documented in this file. The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/), and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html). +## Unreleased + +### Added + +- Added `createWalletConnectModalConfig` to create a configuration the modal shown when connecting to a walletconnect compatible wallet. The value returned can be passed to `WalletConnectConnector.create`. +- Added `CRYPTO_X_WALLET_MAINNET` and `CONCORDIUM_WALLET_MAINNET` exports, which can be passed `createWalletConnectModalConfig` for more control over which wallets are shown. +- Added option to specify the methods and events to request permission for by walletconnect + +### Changed + +- Changed the wallet connect modal dependency from `@walletconnect/qrcode-modal` (which is deprecated) to `@walletconnect/modal`. + ## [0.5.1] - 2024-03-22 ### Fixed diff --git a/packages/wallet-connectors/package.json b/packages/wallet-connectors/package.json index 27b5279..d9b4c8b 100644 --- a/packages/wallet-connectors/package.json +++ b/packages/wallet-connectors/package.json @@ -29,7 +29,8 @@ }, "dependencies": { "@concordium/browser-wallet-api-helpers": "^3.0.0", - "@walletconnect/qrcode-modal": "^1.8.0", + "@walletconnect/modal": "^2.6.2", + "@walletconnect/modal-core": "^2.6.2", "@walletconnect/sign-client": "^2.1.4" }, "peerDependencies": { diff --git a/packages/wallet-connectors/src/WalletConnect.ts b/packages/wallet-connectors/src/WalletConnect.ts index 78d43c1..c5b2423 100644 --- a/packages/wallet-connectors/src/WalletConnect.ts +++ b/packages/wallet-connectors/src/WalletConnect.ts @@ -22,9 +22,11 @@ import { serializeUpdateContractParameters, toBuffer, } from '@concordium/web-sdk'; -import QRCodeModal from '@walletconnect/qrcode-modal'; +import { WalletConnectModal, WalletConnectModalConfig } from '@walletconnect/modal'; +import { MobileWallet } from '@walletconnect/modal-core'; import SignClient from '@walletconnect/sign-client'; -import { ISignClient, SessionTypes, SignClientTypes } from '@walletconnect/types'; +import { ISignClient, ProposalTypes, SessionTypes, SignClientTypes } from '@walletconnect/types'; +import { CONCORDIUM_WALLET_CONNECT_PROJECT_ID, MAINNET, TESTNET } from '.'; import { Network, Schema, @@ -38,22 +40,155 @@ import { UnreachableCaseError } from './error'; const WALLET_CONNECT_SESSION_NAMESPACE = 'ccd'; -async function connect(client: ISignClient, chainId: string, cancel: () => void) { +/** + * Describes the possible methods to invoke + */ +export enum WalletConnectMethod { + SignAndSendTransaction = 'sign_and_send_transaction', + SignMessage = 'sign_message', + RequestVerifiablePresentation = 'request_verifiable_presentation', +} + +/** + * Describes the possible events to listen to + */ +export enum WalletConnectEvent { + ChainChanged = 'chain_changed', + AccountsChanged = 'accounts_changed', +} + +/** + * Describes a mobile wallet to connect to through a wallet connect modal. + */ +export type WalletConnectModalMobileWallet = MobileWallet & { + /** Url for an icon to represent the wallet */ + iconUrl?: string; +}; + +/** + * Concordium mainnet wallet for mobile described as {@linkcode WalletConnectModalMobileWallet} + */ +export const CONCORDIUM_WALLET_MAINNET = { + id: 'ConcordiumMainet', + name: 'Concordium Wallet', + links: { + native: 'concordiumwallet://', + }, + iconUrl: + '', +} satisfies WalletConnectModalMobileWallet; + +/** + * Concordium testnet wallet for mobile described as {@linkcode WalletConnectModalMobileWallet} + */ +export const CONCORDIUM_WALLET_TESTNET = { + id: 'ConcordiumTestnet', + name: 'Concordium Wallet (Testnet)', + links: { + native: 'concordiumwallettest://', + }, + iconUrl: + '', +} satisfies WalletConnectModalMobileWallet; + +/** + * CryptoX mainnet wallet for mobile described as {@linkcode WalletConnectModalMobileWallet} + */ +export const CRYPTO_X_WALLET_MAINNET = { + id: 'CryptoXMainnet', + name: 'CryptoX Wallet', + links: { + native: 'cryptox://', + }, + iconUrl: + '', +} satisfies WalletConnectModalMobileWallet; + +/** + * CryptoX testnet wallet for mobile described as {@linkcode WalletConnectModalMobileWallet} + */ +export const CRYPTO_X_WALLET_TESTNET = { + id: 'CryptoXTestnet', + name: 'CryptoX Wallet (Testnet)', + links: { + native: 'cryptoXStage://', + }, + iconUrl: + '', +} satisfies WalletConnectModalMobileWallet; + +const DEFAULT_MOBILE_WALLETS = { + [TESTNET.name]: [CONCORDIUM_WALLET_TESTNET, CRYPTO_X_WALLET_TESTNET], + [MAINNET.name]: [CONCORDIUM_WALLET_MAINNET, CRYPTO_X_WALLET_MAINNET], +}; + +/** + * Creates a {@linkcode WalletConnectModalConfig}. + * + * @param network The {@linkcode Network} to connect to. + * @param [mobileWallets] The list of mobile wallets to use for deep linking. Defaults to the concordium and cryptoX wallets for mobile for the specified `network`. + * If `network` is anything but {@linkcode MAINNET} or {@linkcode TESTNET}, the default value is an empty list. + * @param [enableExplorer] Whether to enable the wallet connect explorer in the wallet connect modal. Defaults to `false`. + * + * @returns the corresponding {@linkcode WalletConnectModalConfig} + */ +export function createWalletConnectModalConfig( + network: Network, + mobileWallets: WalletConnectModalMobileWallet[] = DEFAULT_MOBILE_WALLETS[network.name] ?? [], + enableExplorer = false +): WalletConnectModalConfig { + let walletImages: Record | undefined; + const mws: MobileWallet[] = []; + + mobileWallets.forEach(({ iconUrl, ...wallet }) => { + mws.push(wallet); + if (iconUrl !== undefined) { + walletImages = walletImages ?? {}; + walletImages[wallet.name] = iconUrl; + } + }); + + return { + projectId: CONCORDIUM_WALLET_CONNECT_PROJECT_ID, + chains: [getChainId(network)], + mobileWallets: mws, + desktopWallets: [], + explorerRecommendedWalletIds: 'NONE', + explorerExcludedWalletIds: 'ALL', + walletImages, + enableExplorer, + }; +} + +async function connect( + client: ISignClient, + namespaceConfig: ProposalTypes.RequiredNamespace, + cancel: () => void, + modalConfig: WalletConnectModalConfig +) { + let modal: WalletConnectModal | undefined; + try { const { uri, approval } = await client.connect({ requiredNamespaces: { - ccd: { - methods: ['sign_and_send_transaction', 'sign_message', 'request_verifiable_presentation'], - chains: [chainId], - events: ['chain_changed', 'accounts_changed'], - }, + ccd: namespaceConfig, }, }); + let response: SessionTypes.Struct | undefined = undefined; if (uri) { + modal = new WalletConnectModal(modalConfig); + modal.subscribeModal(({ open }) => { + if (!open && response === undefined) { + cancel(); + } + }); + // Open modal as we're not connecting to an existing pairing. - QRCodeModal.open(uri, cancel); + await modal.openModal({ uri }); } - return await approval(); + + response = await approval(); + return response; } catch (e) { // Ignore falsy errors. if (e) { @@ -61,7 +196,7 @@ async function connect(client: ISignClient, chainId: string, cancel: () => void) } cancel(); } finally { - QRCodeModal.close(); + modal?.closeModal(); } } @@ -327,6 +462,29 @@ export class WalletConnectConnection implements WalletConnection { } } +function getChainId({ name }: Network): string { + return `${WALLET_CONNECT_SESSION_NAMESPACE}:${name}`; +} + +/** + * Describes the configuration of a connection to a wallet through wallet connect + */ +export type WalletConnectNamespaceConfig = { + /** Which methods to request permission for */ + methods: WalletConnectMethod[]; + /** Which events to request permission for */ + events: WalletConnectEvent[]; +}; + +export const FULL_WALLET_CONNECT_NAMESPACE_CONFIG: WalletConnectNamespaceConfig = { + methods: [ + WalletConnectMethod.SignMessage, + WalletConnectMethod.SignAndSendTransaction, + WalletConnectMethod.RequestVerifiablePresentation, + ], + events: [WalletConnectEvent.AccountsChanged, WalletConnectEvent.ChainChanged], +}; + /** * Implementation of {@link WalletConnector} for WalletConnect v2. * @@ -337,12 +495,16 @@ export class WalletConnectConnection implements WalletConnection { export class WalletConnectConnector implements WalletConnector { readonly client: ISignClient; - readonly network: Network; + readonly chainId: string; readonly delegate: WalletConnectionDelegate; readonly connections = new Map(); + readonly modalConfig: WalletConnectModalConfig; + + readonly namespaceConfig: WalletConnectNamespaceConfig; + /** * Construct a new instance. * @@ -354,11 +516,21 @@ export class WalletConnectConnector implements WalletConnector { * @param client The underlying WalletConnect client. * @param delegate The object to receive events emitted by the client. * @param network The network/chain that connected accounts must live on. + * @param [namespaceConfig] The namespace configuration of the connections, i.e. which methods and events to request permission for in the wallet. Defaults to {@linkcode FULL_WALLET_CONNECT_NAMESPACE_CONFIG} + * @param [modalConfig] The configuration of the modal for connecting to the mobile wallet. Defaults to the default invocation of {@linkcode createWalletConnectModalConfig} */ - constructor(client: SignClient, delegate: WalletConnectionDelegate, network: Network) { + constructor( + client: SignClient, + delegate: WalletConnectionDelegate, + network: Network, + namespaceConfig: WalletConnectNamespaceConfig = FULL_WALLET_CONNECT_NAMESPACE_CONFIG, + modalConfig: WalletConnectModalConfig = createWalletConnectModalConfig(network) + ) { this.client = client; - this.network = network; + this.chainId = getChainId(network); this.delegate = delegate; + this.modalConfig = modalConfig; + this.namespaceConfig = namespaceConfig; client.on('session_event', ({ topic, params: { chainId, event }, id }) => { console.debug('WalletConnect event: session_event', { topic, id, chainId, event }); @@ -401,28 +573,33 @@ export class WalletConnectConnector implements WalletConnector { * if the dApp doesn't have its own {@link https://cloud.walletconnect.com WalletConnect Cloud} project. * @param delegate The object to receive events emitted by the client. * @param network The network/chain that connected accounts must live on. + * @param [namespaceConfig] The namespace configuration of the connections, i.e. which methods and events to request permission for in the wallet. Defaults to {@linkcode FULL_WALLET_CONNECT_NAMESPACE_CONFIG} + * @param [modalConfig] The configuration of the modal for connecting to the mobile wallet. Defaults to the default invocation of {@linkcode createWalletConnectModalConfig} */ static async create( signClientInitOpts: SignClientTypes.Options, delegate: WalletConnectionDelegate, - network: Network + network: Network, + namespaceConfig: WalletConnectNamespaceConfig = FULL_WALLET_CONNECT_NAMESPACE_CONFIG, + modalConfig: WalletConnectModalConfig = createWalletConnectModalConfig(network) ) { const client = await SignClient.init(signClientInitOpts); - return new WalletConnectConnector(client, delegate, network); + return new WalletConnectConnector(client, delegate, network, namespaceConfig, modalConfig); } async connect() { - const { name } = this.network; - - const chainId = `${WALLET_CONNECT_SESSION_NAMESPACE}:${name}`; + const namespaceConfig: ProposalTypes.RequiredNamespace = { + chains: [this.chainId], + ...this.namespaceConfig, + }; const session = await new Promise((resolve) => { - connect(this.client, chainId, () => resolve(undefined)).then(resolve); + connect(this.client, namespaceConfig, () => resolve(undefined), this.modalConfig).then(resolve); }); if (!session) { // Connect was cancelled. return undefined; } - const connection = new WalletConnectConnection(this, chainId, session); + const connection = new WalletConnectConnection(this, this.chainId, session); this.connections.set(session.topic, connection); this.delegate.onConnected(connection, connection.getConnectedAccount()); return connection; diff --git a/samples/contractupdate/src/config.ts b/samples/contractupdate/src/config.ts index 54dc727..b98bc11 100644 --- a/samples/contractupdate/src/config.ts +++ b/samples/contractupdate/src/config.ts @@ -2,6 +2,9 @@ import { BrowserWalletConnector, CONCORDIUM_WALLET_CONNECT_PROJECT_ID, WalletConnectConnector, + WalletConnectEvent, + WalletConnectMethod, + WalletConnectNamespaceConfig, ephemeralConnectorType, } from '@concordium/react-components'; import { SignClientTypes } from '@walletconnect/types'; @@ -16,5 +19,12 @@ const WALLET_CONNECT_OPTS: SignClientTypes.Options = { }, }; +const WALLET_CONNECT_NS_CONFIG: WalletConnectNamespaceConfig = { + methods: [WalletConnectMethod.SignAndSendTransaction], + events: [WalletConnectEvent.AccountsChanged, WalletConnectEvent.ChainChanged], +}; + export const BROWSER_WALLET = ephemeralConnectorType(BrowserWalletConnector.create); -export const WALLET_CONNECT = ephemeralConnectorType(WalletConnectConnector.create.bind(this, WALLET_CONNECT_OPTS)); +export const WALLET_CONNECT = ephemeralConnectorType((delegate, network) => + WalletConnectConnector.create(WALLET_CONNECT_OPTS, delegate, network, WALLET_CONNECT_NS_CONFIG) +); diff --git a/samples/proofs/src/config.ts b/samples/proofs/src/config.ts index cfab85b..35eadff 100644 --- a/samples/proofs/src/config.ts +++ b/samples/proofs/src/config.ts @@ -2,6 +2,9 @@ import { BrowserWalletConnector, CONCORDIUM_WALLET_CONNECT_PROJECT_ID, WalletConnectConnector, + WalletConnectEvent, + WalletConnectMethod, + WalletConnectNamespaceConfig, ephemeralConnectorType, } from '@concordium/react-components'; import { SignClientTypes } from '@walletconnect/types'; @@ -16,5 +19,12 @@ const WALLET_CONNECT_OPTS: SignClientTypes.Options = { }, }; +const WALLET_CONNECT_SCOPE: WalletConnectNamespaceConfig = { + methods: [WalletConnectMethod.RequestVerifiablePresentation], + events: [WalletConnectEvent.AccountsChanged, WalletConnectEvent.ChainChanged], +}; + export const BROWSER_WALLET = ephemeralConnectorType(BrowserWalletConnector.create); -export const WALLET_CONNECT = ephemeralConnectorType(WalletConnectConnector.create.bind(this, WALLET_CONNECT_OPTS)); +export const WALLET_CONNECT = ephemeralConnectorType((delegate, network) => + WalletConnectConnector.create(WALLET_CONNECT_OPTS, delegate, network, WALLET_CONNECT_SCOPE) +); diff --git a/samples/sign-message/src/config.ts b/samples/sign-message/src/config.ts index 011a3c6..5a6f6e4 100644 --- a/samples/sign-message/src/config.ts +++ b/samples/sign-message/src/config.ts @@ -2,6 +2,9 @@ import { BrowserWalletConnector, CONCORDIUM_WALLET_CONNECT_PROJECT_ID, WalletConnectConnector, + WalletConnectEvent, + WalletConnectMethod, + WalletConnectNamespaceConfig, ephemeralConnectorType, } from '@concordium/react-components'; import { SignClientTypes } from '@walletconnect/types'; @@ -16,5 +19,12 @@ const WALLET_CONNECT_OPTS: SignClientTypes.Options = { }, }; +const WALLET_CONNECT_SCOPE: WalletConnectNamespaceConfig = { + methods: [WalletConnectMethod.SignMessage], + events: [WalletConnectEvent.AccountsChanged, WalletConnectEvent.ChainChanged], +}; + export const BROWSER_WALLET = ephemeralConnectorType(BrowserWalletConnector.create); -export const WALLET_CONNECT = ephemeralConnectorType(WalletConnectConnector.create.bind(this, WALLET_CONNECT_OPTS)); +export const WALLET_CONNECT = ephemeralConnectorType((delegate, network) => + WalletConnectConnector.create(WALLET_CONNECT_OPTS, delegate, network, WALLET_CONNECT_SCOPE) +); diff --git a/yarn.lock b/yarn.lock index e755850..413a116 100644 --- a/yarn.lock +++ b/yarn.lock @@ -1969,7 +1969,8 @@ __metadata: "@jest/types": ^29.6.3 "@tsconfig/recommended": ^1.0.1 "@types/jest": ^29.5.12 - "@walletconnect/qrcode-modal": ^1.8.0 + "@walletconnect/modal": ^2.6.2 + "@walletconnect/modal-core": ^2.6.2 "@walletconnect/sign-client": ^2.1.4 "@walletconnect/types": ^2.1.4 jest: ^29.7.0 @@ -2936,6 +2937,107 @@ __metadata: languageName: node linkType: hard +"@lit-labs/ssr-dom-shim@npm:^1.0.0, @lit-labs/ssr-dom-shim@npm:^1.1.0": + version: 1.2.0 + resolution: "@lit-labs/ssr-dom-shim@npm:1.2.0" + checksum: 704621c28df8d651e54a1b93f6ede8103db2dd3e7a1f02463fe5492bd28aa22de813314c7833260204fed5c8491a6bbd763f6051abc25690df537d812a508c35 + languageName: node + linkType: hard + +"@lit/reactive-element@npm:^1.3.0, @lit/reactive-element@npm:^1.6.0": + version: 1.6.3 + resolution: "@lit/reactive-element@npm:1.6.3" + dependencies: + "@lit-labs/ssr-dom-shim": ^1.0.0 + checksum: 79b58631c38effeabad090070324431da8a22cf0ff665f5e4de35e4d791f984742b3d340c9c7fce996d1124a8da95febc582471b4c237236c770b1300b56ef6e + languageName: node + linkType: hard + +"@motionone/animation@npm:^10.15.1, @motionone/animation@npm:^10.17.0": + version: 10.17.0 + resolution: "@motionone/animation@npm:10.17.0" + dependencies: + "@motionone/easing": ^10.17.0 + "@motionone/types": ^10.17.0 + "@motionone/utils": ^10.17.0 + tslib: ^2.3.1 + checksum: 8cab13cde7ccbe29bcaff1cb43ba39acdc51d9be4726628f4d0ba27898c59456887fd9ec56aceaa3d5b82993efbdfa9a7b9e99d4b96bc458f486208394027093 + languageName: node + linkType: hard + +"@motionone/dom@npm:^10.16.2, @motionone/dom@npm:^10.16.4": + version: 10.17.0 + resolution: "@motionone/dom@npm:10.17.0" + dependencies: + "@motionone/animation": ^10.17.0 + "@motionone/generators": ^10.17.0 + "@motionone/types": ^10.17.0 + "@motionone/utils": ^10.17.0 + hey-listen: ^1.0.8 + tslib: ^2.3.1 + checksum: 6415f17032136218dfa88b9b00fbab738e514544129edf6f5c01dbdacefe9be48efd2d06f3d0cb7f2f5d2d2d79c94362effc7d034332406fd4dec6a710e603a2 + languageName: node + linkType: hard + +"@motionone/easing@npm:^10.17.0": + version: 10.17.0 + resolution: "@motionone/easing@npm:10.17.0" + dependencies: + "@motionone/utils": ^10.17.0 + tslib: ^2.3.1 + checksum: 2870d9e94645cf4ed3a27309a858dccee26615291ec46b56e993ef3ac9f059a659b02a2115ed61d27250fc8800acc9640f0319aeb402de7fa0e15dffbebeb548 + languageName: node + linkType: hard + +"@motionone/generators@npm:^10.17.0": + version: 10.17.0 + resolution: "@motionone/generators@npm:10.17.0" + dependencies: + "@motionone/types": ^10.17.0 + "@motionone/utils": ^10.17.0 + tslib: ^2.3.1 + checksum: 6d048a0362692db3f450b97c1679a8d0265bff93106412bdcc33b9c48b9362a3e97f672f29a2932d5e393330750fdd55921c1c9b2bf20690922a37a0164e649f + languageName: node + linkType: hard + +"@motionone/svelte@npm:^10.16.2": + version: 10.16.4 + resolution: "@motionone/svelte@npm:10.16.4" + dependencies: + "@motionone/dom": ^10.16.4 + tslib: ^2.3.1 + checksum: 699e20955ea832bcf32d410ae9f88edf61a5c2cf2b56527119ab1df6fecbf2632b62d541743d0f6d278fd700a15a20b9eb7c8aa5266e7aed5e113b8f8f75b863 + languageName: node + linkType: hard + +"@motionone/types@npm:^10.15.1, @motionone/types@npm:^10.17.0": + version: 10.17.0 + resolution: "@motionone/types@npm:10.17.0" + checksum: 3996c84e1578b17146c14bd581ab682b7b2a06ca7fd5a7dc378a0f3b10539256d7b803a7df748f0c60d6df6b33950269a27ba2bb1839de779196bd024bee4b87 + languageName: node + linkType: hard + +"@motionone/utils@npm:^10.15.1, @motionone/utils@npm:^10.17.0": + version: 10.17.0 + resolution: "@motionone/utils@npm:10.17.0" + dependencies: + "@motionone/types": ^10.17.0 + hey-listen: ^1.0.8 + tslib: ^2.3.1 + checksum: 408e278c9051a221e528bb9ca0a773018b9953ecd53bb88715421afc009f4647417b0d9f163c8195467badd934f39ade24f57e007416988e4291242e749ea43d + languageName: node + linkType: hard + +"@motionone/vue@npm:^10.16.2": + version: 10.16.4 + resolution: "@motionone/vue@npm:10.16.4" + dependencies: + "@motionone/dom": ^10.16.4 + tslib: ^2.3.1 + checksum: 746e38d0ee831829bfac2ce471f3d98a9e37bd8cbdf2706fa3becce69c17f51180a1ee47582d97758d68aafdfc9a187ab47ff216c77254ac994287dabcf266c1 + languageName: node + linkType: hard + "@nicolo-ribaudo/eslint-scope-5-internals@npm:5.1.1-v1": version: 5.1.1-v1 resolution: "@nicolo-ribaudo/eslint-scope-5-internals@npm:5.1.1-v1" @@ -4569,19 +4671,6 @@ __metadata: languageName: node linkType: hard -"@walletconnect/browser-utils@npm:^1.8.0": - version: 1.8.0 - resolution: "@walletconnect/browser-utils@npm:1.8.0" - dependencies: - "@walletconnect/safe-json": 1.0.0 - "@walletconnect/types": ^1.8.0 - "@walletconnect/window-getters": 1.0.0 - "@walletconnect/window-metadata": 1.0.0 - detect-browser: 5.2.0 - checksum: cf4b55c9e8d53b1ffa99322ebcdfce7ad8df8e3ee90f57252da0b3882d3bfb592414cad09900c20619216c6a42d1184ad03728e6514e95a34467a8821aa5aef8 - languageName: node - linkType: hard - "@walletconnect/core@npm:2.7.7": version: 2.7.7 resolution: "@walletconnect/core@npm:2.7.7" @@ -4709,24 +4798,34 @@ __metadata: languageName: node linkType: hard -"@walletconnect/mobile-registry@npm:^1.4.0": - version: 1.4.0 - resolution: "@walletconnect/mobile-registry@npm:1.4.0" - checksum: 06f18842e68f88e71e87f36daea143684afc49551974cf359fb55cc731e9b4fc0bce762d87b79b268e529def889e82fc2fbc2bc12d6a28a04ed0d6a060188020 +"@walletconnect/modal-core@npm:2.6.2, @walletconnect/modal-core@npm:^2.6.2": + version: 2.6.2 + resolution: "@walletconnect/modal-core@npm:2.6.2" + dependencies: + valtio: 1.11.2 + checksum: 94daceba50c323b06ecbeac2968d9f0972f327359c6118887c6526cd64006249b12f64322d71bc6c4a2b928436ecc89cf3d3af706511fcdc264c1f4b34a2dd5d + languageName: node + linkType: hard + +"@walletconnect/modal-ui@npm:2.6.2": + version: 2.6.2 + resolution: "@walletconnect/modal-ui@npm:2.6.2" + dependencies: + "@walletconnect/modal-core": 2.6.2 + lit: 2.8.0 + motion: 10.16.2 + qrcode: 1.5.3 + checksum: cd1ec0205eb491e529670599d3dd26f6782d7c5a99d5594bf6949a8c760c1c5f4eb6ed72b8662450774fe4e2dd47678f2c05145c8f2494bd7153446ddf4bd7ed languageName: node linkType: hard -"@walletconnect/qrcode-modal@npm:^1.8.0": - version: 1.8.0 - resolution: "@walletconnect/qrcode-modal@npm:1.8.0" +"@walletconnect/modal@npm:^2.6.2": + version: 2.6.2 + resolution: "@walletconnect/modal@npm:2.6.2" dependencies: - "@walletconnect/browser-utils": ^1.8.0 - "@walletconnect/mobile-registry": ^1.4.0 - "@walletconnect/types": ^1.8.0 - copy-to-clipboard: ^3.3.1 - preact: 10.4.1 - qrcode: 1.4.4 - checksum: 0abae2268579f55da87ed766fee32d428f951f18ab0a4addbfe8cbcbad1ce3a5642cc26ceb80654b158e537000ee5006b14eff43515619bc17af8c5da51adc55 + "@walletconnect/modal-core": 2.6.2 + "@walletconnect/modal-ui": 2.6.2 + checksum: 68b354d49960b96d22de0e47a3801df27c01a3e96ec5fbde3ca6df1344ca2b20668b0c4d58fe1803f5670ac7b7b4c6f5b7b405e354f5f9eaff5cca147c13de9c languageName: node linkType: hard @@ -4754,13 +4853,6 @@ __metadata: languageName: node linkType: hard -"@walletconnect/safe-json@npm:1.0.0": - version: 1.0.0 - resolution: "@walletconnect/safe-json@npm:1.0.0" - checksum: a8ee161cad37242983522d19ace57c2d2725b5b1cf5fd4d61e3e5f4190a2b369acc4cd0fa40774b50cf4aa322f477e31b7841a6b8f0d84a3af12da8c4344e9b7 - languageName: node - linkType: hard - "@walletconnect/safe-json@npm:^1.0.1, @walletconnect/safe-json@npm:^1.0.2": version: 1.0.2 resolution: "@walletconnect/safe-json@npm:1.0.2" @@ -4810,13 +4902,6 @@ __metadata: languageName: node linkType: hard -"@walletconnect/types@npm:^1.8.0": - version: 1.8.0 - resolution: "@walletconnect/types@npm:1.8.0" - checksum: 194d615888068030183489222641332987846aa5c6bcf0a62fa60ca7a282b9f94932c49fcd2b293a859e98624fe3e7a2d3c5fb66545fe30d3391e7ac91a99e34 - languageName: node - linkType: hard - "@walletconnect/utils@npm:2.7.7": version: 2.7.7 resolution: "@walletconnect/utils@npm:2.7.7" @@ -4839,14 +4924,7 @@ __metadata: languageName: node linkType: hard -"@walletconnect/window-getters@npm:1.0.0": - version: 1.0.0 - resolution: "@walletconnect/window-getters@npm:1.0.0" - checksum: 192af7acb2051d304addb2e5a3f121fedd8c83ba6750018e3b0da5757bad525336bc5d9cb571f63b09828658764151da181337ec0e898811ad7f506910bd3b5f - languageName: node - linkType: hard - -"@walletconnect/window-getters@npm:^1.0.0, @walletconnect/window-getters@npm:^1.0.1": +"@walletconnect/window-getters@npm:^1.0.1": version: 1.0.1 resolution: "@walletconnect/window-getters@npm:1.0.1" dependencies: @@ -4855,15 +4933,6 @@ __metadata: languageName: node linkType: hard -"@walletconnect/window-metadata@npm:1.0.0": - version: 1.0.0 - resolution: "@walletconnect/window-metadata@npm:1.0.0" - dependencies: - "@walletconnect/window-getters": ^1.0.0 - checksum: eec506ff6d35ae6e88db1e38b6f514f6cbf1a45b979878e5e50819d229b616fc645a2b0816145b61acda2701042160a4e0685f080927b87461853a62a887a9e9 - languageName: node - linkType: hard - "@walletconnect/window-metadata@npm:^1.0.1": version: 1.0.1 resolution: "@walletconnect/window-metadata@npm:1.0.1" @@ -5255,13 +5324,6 @@ __metadata: languageName: node linkType: hard -"ansi-regex@npm:^4.1.0": - version: 4.1.1 - resolution: "ansi-regex@npm:4.1.1" - checksum: b1a6ee44cb6ecdabaa770b2ed500542714d4395d71c7e5c25baa631f680fb2ad322eb9ba697548d498a6fd366949fc8b5bfcf48d49a32803611f648005b01888 - languageName: node - linkType: hard - "ansi-regex@npm:^5.0.1": version: 5.0.1 resolution: "ansi-regex@npm:5.0.1" @@ -5276,7 +5338,7 @@ __metadata: languageName: node linkType: hard -"ansi-styles@npm:^3.2.0, ansi-styles@npm:^3.2.1": +"ansi-styles@npm:^3.2.1": version: 3.2.1 resolution: "ansi-styles@npm:3.2.1" dependencies: @@ -6008,47 +6070,13 @@ __metadata: languageName: node linkType: hard -"buffer-alloc-unsafe@npm:^1.1.0": - version: 1.1.0 - resolution: "buffer-alloc-unsafe@npm:1.1.0" - checksum: c5e18bf51f67754ec843c9af3d4c005051aac5008a3992938dda1344e5cfec77c4b02b4ca303644d1e9a6e281765155ce6356d85c6f5ccc5cd21afc868def396 - languageName: node - linkType: hard - -"buffer-alloc@npm:^1.2.0": - version: 1.2.0 - resolution: "buffer-alloc@npm:1.2.0" - dependencies: - buffer-alloc-unsafe: ^1.1.0 - buffer-fill: ^1.0.0 - checksum: 560cd27f3cbe73c614867da373407d4506309c62fe18de45a1ce191f3785ec6ca2488d802ff82065798542422980ca25f903db078c57822218182c37c3576df5 - languageName: node - linkType: hard - -"buffer-fill@npm:^1.0.0": - version: 1.0.0 - resolution: "buffer-fill@npm:1.0.0" - checksum: c29b4723ddeab01e74b5d3b982a0c6828f2ded49cef049ddca3dac661c874ecdbcecb5dd8380cf0f4adbeb8cff90a7de724126750a1f1e5ebd4eb6c59a1315b1 - languageName: node - linkType: hard - -"buffer-from@npm:^1.0.0, buffer-from@npm:^1.1.1": +"buffer-from@npm:^1.0.0": version: 1.1.2 resolution: "buffer-from@npm:1.1.2" checksum: 0448524a562b37d4d7ed9efd91685a5b77a50672c556ea254ac9a6d30e3403a517d8981f10e565db24e8339413b43c97ca2951f10e399c6125a0d8911f5679bb languageName: node linkType: hard -"buffer@npm:^5.4.3": - version: 5.7.1 - resolution: "buffer@npm:5.7.1" - dependencies: - base64-js: ^1.3.1 - ieee754: ^1.1.13 - checksum: e2cf8429e1c4c7b8cbd30834ac09bd61da46ce35f5c22a78e6c2f04497d6d25541b16881e30a019c6fd3154150650ccee27a308eff3e26229d788bbdeb08ab84 - languageName: node - linkType: hard - "buffer@npm:^6.0.3": version: 6.0.3 resolution: "buffer@npm:6.0.3" @@ -6345,14 +6373,14 @@ __metadata: languageName: node linkType: hard -"cliui@npm:^5.0.0": - version: 5.0.0 - resolution: "cliui@npm:5.0.0" +"cliui@npm:^6.0.0": + version: 6.0.0 + resolution: "cliui@npm:6.0.0" dependencies: - string-width: ^3.1.0 - strip-ansi: ^5.2.0 - wrap-ansi: ^5.1.0 - checksum: 0bb8779efe299b8f3002a73619eaa8add4081eb8d1c17bc4fedc6240557fb4eacdc08fe87c39b002eacb6cfc117ce736b362dbfd8bf28d90da800e010ee97df4 + string-width: ^4.2.0 + strip-ansi: ^6.0.0 + wrap-ansi: ^6.2.0 + checksum: 4fcfd26d292c9f00238117f39fc797608292ae36bac2168cfee4c85923817d0607fe21b3329a8621e01aedf512c99b7eaa60e363a671ffd378df6649fb48ae42 languageName: node linkType: hard @@ -6686,15 +6714,6 @@ __metadata: languageName: node linkType: hard -"copy-to-clipboard@npm:^3.3.1": - version: 3.3.3 - resolution: "copy-to-clipboard@npm:3.3.3" - dependencies: - toggle-selection: ^1.0.6 - checksum: e0a325e39b7615108e6c1c8ac110ae7b829cdc4ee3278b1df6a0e4228c490442cc86444cd643e2da344fbc424b3aab8909e2fec82f8bc75e7e5b190b7c24eecf - languageName: node - linkType: hard - "core-js-compat@npm:^3.30.1, core-js-compat@npm:^3.30.2": version: 3.30.2 resolution: "core-js-compat@npm:3.30.2" @@ -7267,13 +7286,6 @@ __metadata: languageName: node linkType: hard -"detect-browser@npm:5.2.0": - version: 5.2.0 - resolution: "detect-browser@npm:5.2.0" - checksum: 63b5c38fecc657ff12de01a41e6c8c97b3d610dffa37aef1983ec5bfb4314687d588c0c44c5ee03bd45ef15b7fe465bce9349c373369e6a7405f318e0aae56f9 - languageName: node - linkType: hard - "detect-browser@npm:5.3.0": version: 5.3.0 resolution: "detect-browser@npm:5.3.0" @@ -7603,13 +7615,6 @@ __metadata: languageName: node linkType: hard -"emoji-regex@npm:^7.0.1": - version: 7.0.3 - resolution: "emoji-regex@npm:7.0.3" - checksum: 9159b2228b1511f2870ac5920f394c7e041715429a68459ebe531601555f11ea782a8e1718f969df2711d38c66268174407cbca57ce36485544f695c2dfdc96e - languageName: node - linkType: hard - "emoji-regex@npm:^8.0.0": version: 8.0.0 resolution: "emoji-regex@npm:8.0.0" @@ -7631,6 +7636,13 @@ __metadata: languageName: node linkType: hard +"encode-utf8@npm:^1.0.3": + version: 1.0.3 + resolution: "encode-utf8@npm:1.0.3" + checksum: 550224bf2a104b1d355458c8a82e9b4ea07f9fc78387bc3a49c151b940ad26473de8dc9e121eefc4e84561cb0b46de1e4cd2bc766f72ee145e9ea9541482817f + languageName: node + linkType: hard + "encodeurl@npm:~1.0.2": version: 1.0.2 resolution: "encodeurl@npm:1.0.2" @@ -9047,6 +9059,13 @@ __metadata: languageName: node linkType: hard +"hey-listen@npm:^1.0.8": + version: 1.0.8 + resolution: "hey-listen@npm:1.0.8" + checksum: 6bad60b367688f5348e25e7ca3276a74b59ac5a09b0455e6ff8ab7d4a9e38cd2116c708a7dcd8a954d27253ce1d8717ec891d175723ea739885b828cf44e4072 + languageName: node + linkType: hard + "hoopy@npm:^0.1.4": version: 0.1.4 resolution: "hoopy@npm:0.1.4" @@ -9315,7 +9334,7 @@ __metadata: languageName: node linkType: hard -"ieee754@npm:^1.1.13, ieee754@npm:^1.2.1": +"ieee754@npm:^1.2.1": version: 1.2.1 resolution: "ieee754@npm:1.2.1" checksum: 5144c0c9815e54ada181d80a0b810221a253562422e7c6c3a60b1901154184f49326ec239d618c416c1c5945a2e197107aee8d986a3dd836b53dffefd99b5e7e @@ -9548,13 +9567,6 @@ __metadata: languageName: node linkType: hard -"is-fullwidth-code-point@npm:^2.0.0": - version: 2.0.0 - resolution: "is-fullwidth-code-point@npm:2.0.0" - checksum: eef9c6e15f68085fec19ff6a978a6f1b8f48018fd1265035552078ee945573594933b09bbd6f562553e2a241561439f1ef5339276eba68d272001343084cfab8 - languageName: node - linkType: hard - "is-fullwidth-code-point@npm:^3.0.0": version: 3.0.0 resolution: "is-fullwidth-code-point@npm:3.0.0" @@ -9784,7 +9796,7 @@ __metadata: languageName: node linkType: hard -"isarray@npm:^2.0.1, isarray@npm:^2.0.5": +"isarray@npm:^2.0.5": version: 2.0.5 resolution: "isarray@npm:2.0.5" checksum: bd5bbe4104438c4196ba58a54650116007fa0262eccef13a4c55b2e09a5b36b59f1e75b9fcc49883dd9d4953892e6fc007eef9e9155648ceea036e184b0f930a @@ -11299,6 +11311,37 @@ __metadata: languageName: node linkType: hard +"lit-element@npm:^3.3.0": + version: 3.3.3 + resolution: "lit-element@npm:3.3.3" + dependencies: + "@lit-labs/ssr-dom-shim": ^1.1.0 + "@lit/reactive-element": ^1.3.0 + lit-html: ^2.8.0 + checksum: 29a596fa556e231cce7246ca3e5687ad238f299b0cb374a0934d5e6fe9adf1436e031d4fbd21b280aabfc0e21a66e6c4b52da558a908df2566d09d960f3ca93d + languageName: node + linkType: hard + +"lit-html@npm:^2.8.0": + version: 2.8.0 + resolution: "lit-html@npm:2.8.0" + dependencies: + "@types/trusted-types": ^2.0.2 + checksum: 2d70df07248bcb2f502a3afb1e91d260735024fa669669ffb1417575aa39c3092779725ac1b90f5f39e4ce78c63f431f51176bc67f532389f0285a6991573255 + languageName: node + linkType: hard + +"lit@npm:2.8.0": + version: 2.8.0 + resolution: "lit@npm:2.8.0" + dependencies: + "@lit/reactive-element": ^1.6.0 + lit-element: ^3.3.0 + lit-html: ^2.8.0 + checksum: 2480e733f7d022d3ecba91abc58a20968f0ca8f5fa30b3341ecf4bcf4845e674ad27b721a5ae53529cafc6ca603c015b80d0979ceb7a711e268ef20bb6bc7527 + languageName: node + linkType: hard + "loader-runner@npm:^4.2.0": version: 4.3.0 resolution: "loader-runner@npm:4.3.0" @@ -11793,6 +11836,20 @@ __metadata: languageName: node linkType: hard +"motion@npm:10.16.2": + version: 10.16.2 + resolution: "motion@npm:10.16.2" + dependencies: + "@motionone/animation": ^10.15.1 + "@motionone/dom": ^10.16.2 + "@motionone/svelte": ^10.16.2 + "@motionone/types": ^10.15.1 + "@motionone/utils": ^10.15.1 + "@motionone/vue": ^10.16.2 + checksum: 0b91256808c2374d8b7f4ac5e7ed513f2ca8df2b7d1be4fbc00ec5baece5162ada648aedaa5bc1d60be9ad2e6c9bc1d3bb160333051c20ab79e241b8e02e3c92 + languageName: node + linkType: hard + "ms@npm:2.0.0": version: 2.0.0 resolution: "ms@npm:2.0.0" @@ -12533,10 +12590,10 @@ __metadata: languageName: node linkType: hard -"pngjs@npm:^3.3.0": - version: 3.4.0 - resolution: "pngjs@npm:3.4.0" - checksum: 8bd40bd698abd16b72c97b85cb858c80894fbedc76277ce72a784aa441e14795d45d9856e97333ca469b34b67528860ffc8a7317ca6beea349b645366df00bcd +"pngjs@npm:^5.0.0": + version: 5.0.0 + resolution: "pngjs@npm:5.0.0" + checksum: 04e912cc45fb9601564e2284efaf0c5d20d131d9b596244f8a6789fc6cdb6b18d2975a6bbf7a001858d7e159d5c5c5dd7b11592e97629b7137f7f5cef05904c8 languageName: node linkType: hard @@ -13381,13 +13438,6 @@ __metadata: languageName: node linkType: hard -"preact@npm:10.4.1": - version: 10.4.1 - resolution: "preact@npm:10.4.1" - checksum: e8c5eae6dca469226177394cf49994d6beab5b9b10d31e000d8b16d9b00bfa52cdd10b41331759d68646e7b8f601430d78eb025f9026263adc90150699800ed3 - languageName: node - linkType: hard - "prelude-ls@npm:^1.2.1": version: 1.2.1 resolution: "prelude-ls@npm:1.2.1" @@ -13576,6 +13626,13 @@ __metadata: languageName: node linkType: hard +"proxy-compare@npm:2.5.1": + version: 2.5.1 + resolution: "proxy-compare@npm:2.5.1" + checksum: c7cc151ac255150bcb24becde6495b3e399416c31991af377ce082255b51f07eaeb5d861bf8bf482703e92f88b90a5892ad57d3153ea29450d03ef921683d9fa + languageName: node + linkType: hard + "psl@npm:^1.1.33": version: 1.9.0 resolution: "psl@npm:1.9.0" @@ -13604,20 +13661,17 @@ __metadata: languageName: node linkType: hard -"qrcode@npm:1.4.4": - version: 1.4.4 - resolution: "qrcode@npm:1.4.4" +"qrcode@npm:1.5.3": + version: 1.5.3 + resolution: "qrcode@npm:1.5.3" dependencies: - buffer: ^5.4.3 - buffer-alloc: ^1.2.0 - buffer-from: ^1.1.1 dijkstrajs: ^1.0.1 - isarray: ^2.0.1 - pngjs: ^3.3.0 - yargs: ^13.2.4 + encode-utf8: ^1.0.3 + pngjs: ^5.0.0 + yargs: ^15.3.1 bin: - qrcode: ./bin/qrcode - checksum: 8c1a7ee3092c0ed60f0413594af879ac6dffb897d4921144a8e7ae3dce40c04ba6457ab21664ca43934ba3fe19cced85abaf0b87b07916239d7254d4bb4fcf13 + qrcode: bin/qrcode + checksum: 9a8a20a0a9cb1d15de8e7b3ffa214e8b6d2a8b07655f25bd1b1d77f4681488f84d7bae569870c0652872d829d5f8ac4922c27a6bd14c13f0e197bf07b28dead7 languageName: node linkType: hard @@ -15053,17 +15107,6 @@ __metadata: languageName: node linkType: hard -"string-width@npm:^3.0.0, string-width@npm:^3.1.0": - version: 3.1.0 - resolution: "string-width@npm:3.1.0" - dependencies: - emoji-regex: ^7.0.1 - is-fullwidth-code-point: ^2.0.0 - strip-ansi: ^5.1.0 - checksum: 57f7ca73d201682816d573dc68bd4bb8e1dff8dc9fcf10470fdfc3474135c97175fec12ea6a159e67339b41e86963112355b64529489af6e7e70f94a7caf08b2 - languageName: node - linkType: hard - "string-width@npm:^5.0.0": version: 5.1.2 resolution: "string-width@npm:5.1.2" @@ -15153,15 +15196,6 @@ __metadata: languageName: node linkType: hard -"strip-ansi@npm:^5.0.0, strip-ansi@npm:^5.1.0, strip-ansi@npm:^5.2.0": - version: 5.2.0 - resolution: "strip-ansi@npm:5.2.0" - dependencies: - ansi-regex: ^4.1.0 - checksum: bdb5f76ade97062bd88e7723aa019adbfacdcba42223b19ccb528ffb9fb0b89a5be442c663c4a3fb25268eaa3f6ea19c7c3fbae830bd1562d55adccae1fcec46 - languageName: node - linkType: hard - "strip-ansi@npm:^6.0.0, strip-ansi@npm:^6.0.1": version: 6.0.1 resolution: "strip-ansi@npm:6.0.1" @@ -15584,13 +15618,6 @@ __metadata: languageName: node linkType: hard -"toggle-selection@npm:^1.0.6": - version: 1.0.6 - resolution: "toggle-selection@npm:1.0.6" - checksum: a90dc80ed1e7b18db8f4e16e86a5574f87632dc729cfc07d9ea3ced50021ad42bb4e08f22c0913e0b98e3837b0b717e0a51613c65f30418e21eb99da6556a74c - languageName: node - linkType: hard - "toidentifier@npm:1.0.1": version: 1.0.1 resolution: "toidentifier@npm:1.0.1" @@ -15748,6 +15775,13 @@ __metadata: languageName: node linkType: hard +"tslib@npm:^2.3.1": + version: 2.6.2 + resolution: "tslib@npm:2.6.2" + checksum: 329ea56123005922f39642318e3d1f0f8265d1e7fcb92c633e0809521da75eeaca28d2cf96d7248229deb40e5c19adf408259f4b9640afd20d13aecc1430f3ad + languageName: node + linkType: hard + "tsutils@npm:^3.21.0": version: 3.21.0 resolution: "tsutils@npm:3.21.0" @@ -16046,6 +16080,15 @@ __metadata: languageName: node linkType: hard +"use-sync-external-store@npm:1.2.0": + version: 1.2.0 + resolution: "use-sync-external-store@npm:1.2.0" + peerDependencies: + react: ^16.8.0 || ^17.0.0 || ^18.0.0 + checksum: 5c639e0f8da3521d605f59ce5be9e094ca772bd44a4ce7322b055a6f58eeed8dda3c94cabd90c7a41fb6fa852210092008afe48f7038792fd47501f33299116a + languageName: node + linkType: hard + "util-deprecate@npm:^1.0.1, util-deprecate@npm:^1.0.2, util-deprecate@npm:~1.0.1": version: 1.0.2 resolution: "util-deprecate@npm:1.0.2" @@ -16117,6 +16160,24 @@ __metadata: languageName: node linkType: hard +"valtio@npm:1.11.2": + version: 1.11.2 + resolution: "valtio@npm:1.11.2" + dependencies: + proxy-compare: 2.5.1 + use-sync-external-store: 1.2.0 + peerDependencies: + "@types/react": ">=16.8" + react: ">=16.8" + peerDependenciesMeta: + "@types/react": + optional: true + react: + optional: true + checksum: cce2d9212aac9fc4bdeba2d381188cc831cfe8d2d03039024cfcd58ba1801f2a5b14d01c2bb21a2c9f12046d2ede64f1dd887175185f39bee553677a35592c30 + languageName: node + linkType: hard + "vary@npm:~1.1.2": version: 1.1.2 resolution: "vary@npm:1.1.2" @@ -16697,17 +16758,6 @@ __metadata: languageName: node linkType: hard -"wrap-ansi@npm:^5.1.0": - version: 5.1.0 - resolution: "wrap-ansi@npm:5.1.0" - dependencies: - ansi-styles: ^3.2.0 - string-width: ^3.0.0 - strip-ansi: ^5.0.0 - checksum: 9b48c862220e541eb0daa22661b38b947973fc57054e91be5b0f2dcc77741a6875ccab4ebe970a394b4682c8dfc17e888266a105fb8b0a9b23c19245e781ceae - languageName: node - linkType: hard - "wrap-ansi@npm:^6.2.0": version: 6.2.0 resolution: "wrap-ansi@npm:6.2.0" @@ -16845,13 +16895,13 @@ __metadata: languageName: node linkType: hard -"yargs-parser@npm:^13.1.2": - version: 13.1.2 - resolution: "yargs-parser@npm:13.1.2" +"yargs-parser@npm:^18.1.2": + version: 18.1.3 + resolution: "yargs-parser@npm:18.1.3" dependencies: camelcase: ^5.0.0 decamelize: ^1.2.0 - checksum: c8bb6f44d39a4acd94462e96d4e85469df865de6f4326e0ab1ac23ae4a835e5dd2ddfe588317ebf80c3a7e37e741bd5cb0dc8d92bcc5812baefb7df7c885e86b + checksum: 60e8c7d1b85814594d3719300ecad4e6ae3796748b0926137bfec1f3042581b8646d67e83c6fc80a692ef08b8390f21ddcacb9464476c39bbdf52e34961dd4d9 languageName: node linkType: hard @@ -16869,21 +16919,22 @@ __metadata: languageName: node linkType: hard -"yargs@npm:^13.2.4": - version: 13.3.2 - resolution: "yargs@npm:13.3.2" +"yargs@npm:^15.3.1": + version: 15.4.1 + resolution: "yargs@npm:15.4.1" dependencies: - cliui: ^5.0.0 - find-up: ^3.0.0 + cliui: ^6.0.0 + decamelize: ^1.2.0 + find-up: ^4.1.0 get-caller-file: ^2.0.1 require-directory: ^2.1.1 require-main-filename: ^2.0.0 set-blocking: ^2.0.0 - string-width: ^3.0.0 + string-width: ^4.2.0 which-module: ^2.0.0 y18n: ^4.0.0 - yargs-parser: ^13.1.2 - checksum: 75c13e837eb2bb25717957ba58d277e864efc0cca7f945c98bdf6477e6ec2f9be6afa9ed8a876b251a21423500c148d7b91e88dee7adea6029bdec97af1ef3e8 + yargs-parser: ^18.1.2 + checksum: 40b974f508d8aed28598087720e086ecd32a5fd3e945e95ea4457da04ee9bdb8bdd17fd91acff36dc5b7f0595a735929c514c40c402416bbb87c03f6fb782373 languageName: node linkType: hard