From 766128be22d3a1fb71c7f48d915e9d2701a4c8bf Mon Sep 17 00:00:00 2001 From: cebgcontract <99630598+cebgcontract@users.noreply.github.com> Date: Tue, 26 Apr 2022 11:36:21 +0800 Subject: [PATCH] =?UTF-8?q?=E5=AE=8C=E5=96=84=E7=99=BB=E5=BD=95=E6=B5=81?= =?UTF-8?q?=E7=A8=8B?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/chain/ChainManager.ts | 4 ++ src/chain/blockchain.ts | 87 +++++++++++++++++++----------- src/components/core/ChainModal.vue | 21 ++------ src/components/market/TopMenu.vue | 4 +- src/configs/config_chain.ts | 17 +++++- src/utils/chain.util.ts | 22 ++++++++ src/views/desktop/MyNft.vue | 24 +++++++-- src/views/desktop/Mystery.vue | 19 ++++++- 8 files changed, 142 insertions(+), 56 deletions(-) diff --git a/src/chain/ChainManager.ts b/src/chain/ChainManager.ts index 477884b..d1ddcfa 100644 --- a/src/chain/ChainManager.ts +++ b/src/chain/ChainManager.ts @@ -55,6 +55,10 @@ export default class ChainManager { await this.bc.disconnect() } + public get currentChain() { + return this.bc.currentChain + } + public async login() { if (!AppModule.step) { try { diff --git a/src/chain/blockchain.ts b/src/chain/blockchain.ts index 4806655..442e281 100644 --- a/src/chain/blockchain.ts +++ b/src/chain/blockchain.ts @@ -16,10 +16,11 @@ import { } from '@/utils/event-bus' import { UserModule } from '@/store/modules/user' import { isMobile } from '@/utils/resize' -import { hasMetamask } from '@/utils/chain.util' +import { hasMetamask, toHexChainId } from '@/utils/chain.util' import { AllChains } from '@/configs/allchain' import { MessageBox } from 'element-ui' import { ERC20ABI } from '@/configs/contracts' +import { TransactionReceipt } from 'web3-core' const EIP721_DOMAIN_DATA = [ { name: 'name', type: 'string' }, @@ -58,11 +59,6 @@ export class Blockchain { EventBus.$on(NEED_LOGIN, this.connect.bind(this)) } - loadJson(url: string) { - return fetch(url) - .then(response => response.json()) - } - get isWalletConnect() { return !!this.walletType && !!this.currentChain } @@ -72,11 +68,7 @@ export class Blockchain { } public get hexChainId() { - return this.toHexChainId(this.currentChain) - } - - public toHexChainId(chainId: number) { - return '0x' + chainId.toString(16) + return toHexChainId(this.currentChain) } public async chainSelected(id: number) { @@ -124,10 +116,22 @@ export class Blockchain { return { account: accounts[0], chainId } } + /** + * check whether special chainId is supported by config + * show chain picker when chainId is not supported and current wallet is meatmask + * show message box when chainId is not supported and current wallet is wallet connect + * @param {number} chainId + * @return {Promise} + * @private + */ private async checkChain(chainId: number) { if (!this.chainMap.has(chainId)) { if (this.walletType === 1) { - await this.selectChain() + try { + await this.selectChain() + } catch (err) { + await this.disconnect() + } } else if (this.walletType === 2) { await this.disconnect() this.walletType = 2 @@ -157,6 +161,11 @@ export class Blockchain { if (isManual || this.isWalletConnect) { await this.connectWallet(isManual) } } + /** + * show wallet picker + * @return {Promise} + * @private + */ private selectWallet(): Promise { return new Promise((resolve, reject) => { EventBus.$emit(SHOW_CHAIN_MODAL, { @@ -172,6 +181,11 @@ export class Blockchain { }) } + /** + * show chain picker + * @return {Promise} + * @private + */ private selectChain(): Promise { return new Promise((resolve, reject) => { EventBus.$emit(NEED_CHANGE_CHAIN, { @@ -225,19 +239,13 @@ export class Blockchain { return provider } - private async initInstance({ abi, address, account }: - {abi: any, address: string, account: string}) { - return new this.web3.eth.Contract( - abi, - address, - { from: account } - ) - } - public async getContractInstance(address: string, abi: any = ERC20ABI) { if (!this.instanceCacheMap.has(address)) { - const instance = await this.initInstance( - { abi, address, account: AppModule.accountId }) + const instance = new this.web3.eth.Contract( + abi, + address, + { from: AppModule.accountId } + ) this.instanceCacheMap.set(address, instance) } return this.instanceCacheMap.get(address) @@ -275,16 +283,16 @@ export class Blockchain { public async disconnect() { try { await UserModule.LogOut() - this.currentChain = 0 - this.walletType = 0 - this.instanceCacheMap.clear() - this.clearCachedProvider() - AppModule.updateStep(0) - AppModule.updateNonce('') await this.provider?.disconnect() } catch (err) { } + this.currentChain = 0 + this.walletType = 0 + this.instanceCacheMap.clear() this.clearCachedProvider() + AppModule.updateStep(0) + AppModule.updateChainID(0) + AppModule.updateNonce('') AppModule.updateAccount('') AppModule.updateWalletStatus(false) } @@ -303,11 +311,12 @@ export class Blockchain { // Subscribe to chainId change this.provider.on('chainChanged', async(chainId: string) => { - console.log('chainChanged', chainId) const chainIdNum = parseInt(chainId) + console.log('chainChanged', chainId, chainIdNum) await this.checkChain(chainIdNum) this.currentChain = chainIdNum this.saveProvider() + AppModule.updateChainID(this.currentChain) }) // Subscribe to session disconnection @@ -316,9 +325,15 @@ export class Blockchain { }) } + /** + * change chain of metamask + * @param {number} chainId + * @param {() => void} cb + * @return {Promise} + */ async switchEthereumChain(chainId?: number, cb?: () => void) { chainId = chainId || this.currentChain - const hexChainId = this.toHexChainId(chainId) + const hexChainId = toHexChainId(chainId) const onChainChange = (chainId: string) => { console.log('switchEthereumChain: ', chainId) this.provider.removeListener('chainChanged', onChainChange) @@ -362,6 +377,16 @@ export class Blockchain { } } + public async getTransactionReceipt(txHash: string) { + return this.web3.eth.getTransactionReceipt(txHash) + } + + public async getTxConfirms(txhash: string) { + const receipt: TransactionReceipt = await this.getTransactionReceipt(txhash) + const latest = await this.web3.eth.getBlockNumber() + return latest - receipt.blockNumber + 1 + } + public async signPresale({ type, paymentTokenAddress, price, buyerAddress, netId }: { type: number | string diff --git a/src/components/core/ChainModal.vue b/src/components/core/ChainModal.vue index 5af0afe..c2e30cf 100644 --- a/src/components/core/ChainModal.vue +++ b/src/components/core/ChainModal.vue @@ -23,6 +23,7 @@ import { Component, Vue } from 'vue-property-decorator' import { EventBus, NEED_CHANGE_CHAIN, SHOW_CHAIN_MODAL } from '@/utils/event-bus' import ChainManager from '@/chain/ChainManager' +import { ALL_PROVIDERS } from '@/configs/config_chain' @Component({ name: 'ChainModal', @@ -36,28 +37,13 @@ export default class ChainModal extends Vue { confirmFun: (id: number) => void cancelFun: (reason: any) => void - private providers = [ - { - id: 1, - name: 'MetaMask', - logo: '', - desc: 'Connect to your MetaMask Wallet' - }, - { - id: 2, - name: 'WalletConnect', - logo: '', - desc: 'Scan with WalletConnect to connect' - } - ] - get chainDatas() { - return new ChainManager().availableChains.values() + return [...new ChainManager().availableChains.values()] } get currentDatas() { if (this.dataType === 0) { - return this.providers + return ALL_PROVIDERS } else if (this.dataType === 1) { return this.chainDatas } else { @@ -84,6 +70,7 @@ export default class ChainModal extends Vue { showModal(type?: number) { this.dataType = type || 0 this.modalShow = true + console.log('chain modal show with: ', this.dataType, this.currentDatas) } showSelectWallet({ confirm, cancel }: {confirm: (id: number)=>void, cancel: (reason: any)=>void}) { diff --git a/src/components/market/TopMenu.vue b/src/components/market/TopMenu.vue index 5153a19..9024fec 100644 --- a/src/components/market/TopMenu.vue +++ b/src/components/market/TopMenu.vue @@ -25,7 +25,7 @@
- +
MysteryBoxes
@@ -77,7 +77,7 @@
Home Official Shop Marketplace - MysteryBoxes + MysteryBoxes MyNFT