diff --git a/.env.dev b/.env.dev index d183d89..0c6ffaf 100644 --- a/.env.dev +++ b/.env.dev @@ -22,4 +22,5 @@ VUE_APP_PRODUCTION=sandbox VUE_APP_LOGIN_API='https://login-test.kingsome.cn' VUE_APP_NET_ID_MAIN='11155111' -VUE_APP_LOCKER_ADDRESS_MAIN='0x7F2b4DB626d878778e178B4F0C7bA3a2870C6dd0' \ No newline at end of file +VUE_APP_LOCKER_ADDRESS_MAIN='0x7F2b4DB626d878778e178B4F0C7bA3a2870C6dd0' +VUE_APP_NET_ID_CLAIM='97' diff --git a/.env.development b/.env.development index 6f2e4b3..d8a89f0 100644 --- a/.env.development +++ b/.env.development @@ -22,4 +22,5 @@ VUE_APP_PRODUCTION=sandbox VUE_APP_LOGIN_API='https://login-test.kingsome.cn' VUE_APP_NET_ID_MAIN='11155111' -VUE_APP_LOCKER_ADDRESS_MAIN='0x7F2b4DB626d878778e178B4F0C7bA3a2870C6dd0' \ No newline at end of file +VUE_APP_LOCKER_ADDRESS_MAIN='0x7F2b4DB626d878778e178B4F0C7bA3a2870C6dd0' +VUE_APP_NET_ID_CLAIM='97' diff --git a/.env.production b/.env.production index 7d05f76..a92dde8 100644 --- a/.env.production +++ b/.env.production @@ -22,4 +22,5 @@ VUE_APP_PRODUCTION=production VUE_APP_LOGIN_API='https://login-test.cebggame.com' VUE_APP_NET_ID_MAIN='1' -VUE_APP_LOCKER_ADDRESS_MAIN='0x5c16AC8322E5cac8ad235F7e0Dc5d23bffe3ed50' \ No newline at end of file +VUE_APP_LOCKER_ADDRESS_MAIN='0x5c16AC8322E5cac8ad235F7e0Dc5d23bffe3ed50' +VUE_APP_NET_ID_CLAIM='56' diff --git a/.env.test b/.env.test index 53fea36..e98f6b1 100644 --- a/.env.test +++ b/.env.test @@ -23,4 +23,5 @@ VUE_APP_LOGIN_API='https://login-test.cebggame.com' VUE_APP_NET_ID_MAIN='1' -VUE_APP_LOCKER_ADDRESS_MAIN='0x5c16AC8322E5cac8ad235F7e0Dc5d23bffe3ed50' \ No newline at end of file +VUE_APP_LOCKER_ADDRESS_MAIN='0x5c16AC8322E5cac8ad235F7e0Dc5d23bffe3ed50' +VUE_APP_NET_ID_CLAIM='56' diff --git a/marketplace-test.zip b/marketplace-test.zip deleted file mode 100644 index 5cec2f5..0000000 Binary files a/marketplace-test.zip and /dev/null differ diff --git a/src/assets/img/cec_claim/Bitgetlogo.png b/src/assets/img/cec_claim/Bitgetlogo.png index 3f11209..2088070 100644 Binary files a/src/assets/img/cec_claim/Bitgetlogo.png and b/src/assets/img/cec_claim/Bitgetlogo.png differ diff --git a/src/components/chain/BlockChain.js b/src/components/chain/BlockChain.js index 4bd3fa7..ba500d2 100644 --- a/src/components/chain/BlockChain.js +++ b/src/components/chain/BlockChain.js @@ -12,6 +12,7 @@ import {ImtblMarket} from "@/components/chain/Market"; import { ALL_PROVIDERS } from "@/configs/configchain"; import {Locker} from "@/components/chain/contract/Locker"; import {GameItemMall} from "@/components/chain/contract/GameItemMall"; +import { CecClaim } from "@/components/chain/contract/cecClaim" import ConfirmDialog from "@/components/Dialogs/confirmDialog.vue"; import { Widgets } from "./Widgets"; @@ -34,6 +35,7 @@ export class BlockChain { this.market = new ImtblMarket(this) this.locker = new Locker(this) this.mall = new GameItemMall(this) + this.claim = new CecClaim(this) this.widgets = new Widgets(this) BlockChain.instance = this; @@ -340,6 +342,8 @@ export class BlockChain { } async claimAddress({title, subTitle, targetChainId}) { + console.log(targetChainId) + // return const initData = {} initData[this.store.walletType] = this.store.address const rewardModal = createModal(WalletSelectModel, { @@ -354,7 +358,7 @@ export class BlockChain { console.log(`select address result : ${errmsg}`); throw new Error(errmsg); } - targetChainId = targetChainId || cfgChainId; + targetChainId = targetChainId; let chainId = await walletInstance.getChainId(); if (chainId !== targetChainId) { console.log(`current chain: ${chainId}, want: ${targetChainId}`) diff --git a/src/components/chain/WalletSelectModel.vue b/src/components/chain/WalletSelectModel.vue index a5fa84c..ea2d325 100644 --- a/src/components/chain/WalletSelectModel.vue +++ b/src/components/chain/WalletSelectModel.vue @@ -90,7 +90,7 @@ async function selectWallet(id) { const Provider = allProviders[id]; const walletInstance = new Provider() const { provider, accounts } = await walletInstance.web3Provider(); - console.log(accounts) + // console.log(accounts) hideModal({errcode: 0, provider, wallet: id, walletInstance, accounts}); } diff --git a/src/components/chain/contract/cecClaim.js b/src/components/chain/contract/cecClaim.js new file mode 100644 index 0000000..6a2283d --- /dev/null +++ b/src/components/chain/contract/cecClaim.js @@ -0,0 +1,48 @@ +import { apiCecClaim } from '@/utils/marketplace' + +export class CecClaim { + constructor(_chainInstance) { + this.bc = _chainInstance + } + + async sendTransaction(provider, {from, to, data}) { + const txHash = await provider.provider.request({ + method: 'eth_sendTransaction', + params: [{ + from, + to, + data + }] + }) + const res = await provider.waitForTransaction(txHash) + if (res.status == 0) { + throw new Error('transaction failed') + } + return txHash + } + + async cecClaim(token) { + const chainId = parseInt(import.meta.env.VUE_APP_NET_ID_CLAIM); + const subTitle = 'Select the payment address.' + const { provider, address } = await this.bc.claimAddress({subTitle: subTitle,targetChainId: chainId}) + // const preDatas = { + // address: address, + // } + const { errocode, errmsg, calls } = await apiCecClaim(address,token) + if (errocode) { + throw new Error(errmsg) + } + if (!calls || calls.length == 0) { + throw new Error('no calls') + } + + let resutls = [] + for (let i = 0; i < calls.length; i++) { + const { to, data } = calls[i].trans_req + let hash = await this.sendTransaction(provider, {from: address, to, data}) + resutls.push(hash) + } + return resutls + } + +} \ No newline at end of file diff --git a/src/configs/allchain.ts b/src/configs/allchain.ts index 5303e0c..91ecbdf 100644 --- a/src/configs/allchain.ts +++ b/src/configs/allchain.ts @@ -80,6 +80,15 @@ export const AllChains = [ symbol: 'BNB', explorerurl: 'https://bscscan.com' }, + { + name: 'Binance Smart Chain Testnet RPC', + type: 'Testnet', + rpc: 'https://data-seed-prebsc-1-s1.binance.org:8545/', + id: 97, + logo: '', + symbol: 'BNB', + explorerurl: 'https://testnet.bscscan.com' + }, { name: 'OKExChain Mainnet RPC', type: 'Mainnet', diff --git a/src/views/ClaimView.vue b/src/views/ClaimView.vue index 9ec74f0..106453e 100644 --- a/src/views/ClaimView.vue +++ b/src/views/ClaimView.vue @@ -47,12 +47,22 @@
-
+
+
  • +
    + Claim to your wallet +
    +
    + Sep 9, 00:00 UTC +
    +
  • +
    +
  • @@ -62,7 +72,7 @@ 0 gas
    - Aug 30, 06:00 - Sep 5, 06:00 UTC + Closed
  • @@ -71,21 +81,9 @@
  • - -
    -
  • -
    -
    - Claim to your wallet -
    -
    - Coming soon -
    -
  • -
    -
    +
    You have no CEC available to claim.
    @@ -94,61 +92,24 @@
    -
    -
    -
  • -
    -
    - -
    -

    Deposit to Bitget

    - 0 gas -
    -
    - Aug 30, 06:00 - Sep 5, 06:00 UTC -
    -
  • -
  • -
    -

    Grab a share of 1,000,000 $CEC

    -
    -
  • -
    -
    -
    -
  • -
    -
    - Claim to your wallet -
    -
    - Coming soon -
    -
  • -
    -
    -
    -
    -
    - Address: {{address}} -
    -
    - You can currently pre-deposit to Bitget -
    -
    -
    +
  • + Claim to your wallet +
    +
    + Sep 9, 00:00 UTC +
    +
  • +
    +
    +
  • +
    @@ -156,7 +117,7 @@ 0 gas
    - Aug 30, 06:00 - Sep 5, 06:00 UTC + Closed
  • @@ -165,22 +126,59 @@
  • - -
    -
  • -
    -
    - Claim to your wallet -
    -
    - - Coming soon -
    -
  • -
    +
    + Address: {{address}} +
    + + +
    + +
    +
  • +
    +
    + Claim to your wallet +
    +
    + + Claim +
    +
  • + +
    + +
    +
  • +
    +
    + +
    +

    Deposit to Bitget

    + 0 gas +
    +
    + Closed +
    +
  • +
  • +
    +

    Grab a share of 1,000,000 $CEC

    +
    +
  • +
    +
    +
    +
    @@ -329,7 +327,7 @@
    - +
    Cec claim
    @@ -346,14 +344,17 @@ import { ref, toRefs, toRaw, onMounted, computed, watch, inject} from "vue" const message = inject('$message') import { FileTextOutlined } from '@ant-design/icons-vue'; +import LoadingDialog from "@/components/Dialogs/loadingDialog.vue"; import { priceCalculated } from "@/configs/priceCalculate" import {walletStore} from "@/store/wallet"; import { useMarketplaceStore } from "@/store/marketplace" import { BlockChain } from "@/components/chain/BlockChain" import { apiCecInfoAll, apiBindAccount, apiCecClaim } from "@/utils/marketplace" +import ConfirmDialog from "@/components/Dialogs/confirmDialog.vue"; +import {createModal} from "@/utils/model.util"; - +const loadingDialogVisible = ref(false) const localWalletStore = walletStore() const marketplaceStore = useMarketplaceStore() const instructionLink = ref('https://medium.com/@CounterFire/pre-deposit-instruction-a30d6ce62f80') @@ -361,7 +362,7 @@ const claimLogDialogVisible = ref(false) const address = ref() const tradeId = ref() const tradeAddress = ref() -const cecUserStatus = ref(0) // -2 没有cec -1 登陆后 0 是否绑定交易所 1 绑定账号 2 账号回显 3 绑定成功提示 4 是否取消绑定 5 取消绑定成功 +const cecUserStatus = ref(-1) // -2 没有cec -1 登陆后 0 是否绑定交易所 1 绑定账号 2 账号回显 3 绑定成功提示 4 是否取消绑定 5 取消绑定成功 const cecInfo = ref({ available: 0, bindAddress: '', @@ -378,17 +379,22 @@ const getCecTotal = async () => { let token = marketplaceStore.fireToken || localWalletStore.token let data = await apiCecInfoAll(address.value, token) cecInfo.value = data.data - if(data.data.available == 0 || data.data.available == '0') { - cecUserStatus.value = -2 - } else { + if(data.data.bindUid) { + // cecUserStatus.value = -2 + // } else { cecUserStatus.value = -1 + } else { + if(data.data.available == 0 || data.data.available == '0') { + cecUserStatus.value = -2 + } else { + cecUserStatus.value = -1 + } } } } const isBindAccount = () => { - console.log(cecInfo.value.bindUid) if(cecInfo.value.bindUid) { cecUserStatus.value = 3 } else { @@ -474,12 +480,36 @@ const reqGetInfo = async () => { // 领取 const cecClaim = async () => { - let res = await new BlockChain().claimAddress({}) - console.log(res.address) let walletToken = await new BlockChain().token() let token = marketplaceStore.fireToken || walletToken - let res1 = await apiCecClaim(res.address, token) - console.log(res1) + try { + loadingDialogVisible.value = true + let res = await new BlockChain().claim.cecClaim(token) + if(res) { + loadingDialogVisible.value = false + getCecTotal() + const confirmResult = await createModal(ConfirmDialog, { + title: '', + noBtnTitle: '', + message: 'Claim Successful' + }).show() + } + } catch(e) { + if(e.message.indexOf("User denied transaction signature") > -1) { + message.error("User rejected the request"); + } else if(e.message.indexOf("reject") > -1){ + message.error("User rejected the request"); + } else if(e.message.indexOf("User denied request signature") > -1){ + message.error("User rejected the request"); + } else { + message.error("Claim fail."); + } + loadingDialogVisible.value = false + } + + // let walletToken = await new BlockChain().token() + // let token = marketplaceStore.fireToken || walletToken + // let res1 = await apiCecClaim(res.address, token) } onMounted(() => { @@ -844,16 +874,69 @@ onMounted(() => { .content-time-top { background: url('@/assets/img/cec_claim/Counterfire_mbg02.png') no-repeat; background-size: 100% 100%; + height: 100px; padding: 10px 20px 0 20px; cursor: pointer; + li { + display: flex; + justify-content: space-between; + margin-top: 20px; + font-size: 18px; + font-family: 'Poppins'; + // color: #8d8598; + .left { + margin-left: 60px; + width: 390px; + font-family: "Poppins"; + font-size: 24px; + font-weight: 700; + } + .right { + width: 283px; + text-align: right; + span { + padding-right: 40px; + } + .claim-btn { + padding: 5px 20px; + border-radius: 20px; + color: #000; + background: #fec25d; + margin-right: 40px; + } + } + .claim-btn { + span { + color: #fff; + padding: 10px; + border: 1px solid #31FFF3; + border-radius: 20px; + cursor: pointer; + } + } + } + &:hover { + background: url('@/assets/img/cec_claim/Counterfire_mbg01.png') no-repeat; + background-size: 100% 100%; + } + } + .content-time-line { + width: 100%; + height: 2px; + background: #44375c; + } + .content-time-btm { + padding-top: 10px; li { display: flex; align-items: center; justify-content: space-between; + color: #8e8497; .left { display: flex; align-items: center; width: 380px; + padding-left: 40px; div { width: 30px; height: 30px; @@ -873,7 +956,7 @@ onMounted(() => { span { display: inline-block; color: #000; - background: #31FFF3; + background: #8e8497; font-size: 12px; font-family: "Poppins"; padding: 0 5px; @@ -892,6 +975,7 @@ onMounted(() => { span { font-weight: 700; font-size: 16px; + padding-right: 60px; } .tips { position: relative; @@ -929,42 +1013,7 @@ onMounted(() => { } } } - &:hover { - background: url('@/assets/img/cec_claim/Counterfire_mbg01.png') no-repeat; - background-size: 100% 100%; - } - } - .content-time-line { - width: 100%; - height: 2px; - background: #44375c; - } - .content-time-btm { - li { - display: flex; - justify-content: space-between; - margin-top: 20px; - font-size: 18px; - font-family: 'Poppins'; - color: #8d8598; - .left { - margin-left: 60px; - width: 390px; - } - .right { - width: 283px; - text-align: left; - } - .claim-btn { - span { - color: #fff; - padding: 10px; - border: 1px solid #31FFF3; - border-radius: 20px; - cursor: pointer; - } - } - } + } } .content-title {