From 7569c9a0e0c8b716f434aeb1fc3c9109fbee59c8 Mon Sep 17 00:00:00 2001
From: queenwuli <942534046@qq.com>
Date: Wed, 23 Mar 2022 10:09:34 +0800
Subject: [PATCH] gx

---
 src/pages/index/index.vue |  283 ++++++++++++++++++++++++++++++++++++++++++++++++++------
 1 files changed, 253 insertions(+), 30 deletions(-)

diff --git a/src/pages/index/index.vue b/src/pages/index/index.vue
index 8a047ce..09697d1 100644
--- a/src/pages/index/index.vue
+++ b/src/pages/index/index.vue
@@ -4,35 +4,82 @@
             <div class="header flex align-center justify-between">
             <div class="left flex align-center">
                 <img src="../../assets/images/icon3.png" class="icon"/>
-                <van-dropdown-menu active-color="#3D8AF2">
-                    <van-dropdown-item v-model="value1" :options="option1" />
+                <van-dropdown-menu active-color="#3D8AF2" class="i18-wrap">
+                    <van-dropdown-item v-model="local" :options="languague" @change="changeLanguage"/>
                 </van-dropdown-menu>
             </div>
             <span class="title">ANT-ETH</span>
-            <div class="right flex align-center">
+            <div class="right flex align-center" @click="showAccreditModal">
                 <img src="../../assets/images/icon.png" class="icon"/>
-                <span>连接钱包</span>
+                <span>{{ $t("message.ConnectWallet") }}</span>
             </div>
             </div>
             <div class="banner-content">
-                <p>免质押挖矿</p>
-                <p>奖励<span class="em">1000,000</span> ETH</p>
-                <button @click="show = true">授权凭证</button>
+                <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>
             </div>
         </div>
         <img src="../../assets/images/banner.png" class="banner"/>
         <van-tabs class="scale" title-active-color="#080808" title-inactive-color="#999999" line-height="4px">
-            <van-tab title="矿池">
+            <van-tab :title='$t("message.MiningPool")'>
                 <OrePool></OrePool>
             </van-tab>
-            <van-tab title="账户">
+            <van-tab :title='$t("message.Account")'>
               <Account></Account>
             </van-tab>
         </van-tabs>
-        <van-overlay :show="show" @click="show = false">
-          <div class="wrapper" @click.stop>
-            <div class="block" />
-          </div>
+        <van-overlay :show="isShowApproveModal" @click="isShowApproveModal = false" class="wrapper">
+            <div class="block" @click.stop>
+              <div class="block-title">
+                <p>{{ $t("message.ReceiveDescription") }}</p>
+              </div>
+              <p class="block-content">{{ $t("message.Description") }}</p>
+              <button class="block-btn" @click="showAccreditModal">{{ $t("message.Receive") }}</button>
+            </div>
+        </van-overlay>
+        <van-overlay :show="isShowAccreditModal" @click="isShowAccreditModal = false" class="wrapper">
+            <div class="block" @click.stop>
+              <img class="close-icon" @click="isShowAccreditModal = false" src="../../assets/images/close-icon.png">
+              <div class="accredit-box">
+                <div class="item" @click="showDappModal()">
+                  <img src="../../assets/images/icon7.png">
+                  <p class="title">Dapp</p>
+                  <p>DappConnect</p>
+                </div>
+                <div class="item" @click="showWalletModal()">
+                  <img src="../../assets/images/icon8.png">
+                  <p class="title">Wallet</p>
+                  <p>WalletConnect</p>
+                </div>
+              </div>
+            </div>
+        </van-overlay>
+        <van-overlay :show="isShowWalletModal" @click="isShowWalletModal = false" class="wrapper">
+           <div class="block" @click.stop>
+              <img class="close-icon" @click="isShowWalletModal = false" src="../../assets/images/close-icon.png">
+              <div class="wallet-box">
+                <p class="title">选择你的钱包</p>
+                <div class="wallet-warp flex align-center justify-between">
+                  <div>
+                    <img src="../../assets/images/icon8.png">
+                    <p>coinbase</p>
+                  </div>
+                  <div>
+                    <img src="../../assets/images/icon8.png">
+                    <p>coinbase</p>
+                  </div>
+                  <div>
+                    <img src="../../assets/images/icon8.png">
+                    <p>coinbase</p>
+                  </div>
+                  <div>
+                    <img src="../../assets/images/icon8.png">
+                    <p>coinbase</p>
+                  </div>
+                </div>
+              </div>
+            </div>
         </van-overlay>
   </div>
 </template>
@@ -40,7 +87,8 @@
 <script>
 import WalletConnectProvider from "@walletconnect/web3-provider"; 
 import Web3 from "web3";
-import { ref } from 'vue';
+import { ref, reactive, getCurrentInstance,onBeforeMount,onMounted } from 'vue';
+import { useI18n } from 'vue-i18n'
 import OrePool from './orePool';
 import Account from './account';
 
@@ -51,16 +99,77 @@
     Account
   },
   setup() {
-    const value1 = ref(0);
-    const option1 = [
-      { text: '简体中文', value: 0 },
-      { text: 'English', value: 1 }
-    ];
-    const show = ref(false);
+    const { proxy } = getCurrentInstance();
+    let isShowApproveModal = ref(false);
+    let isShowAccreditModal = ref(false);
+    let isShowWalletModal = ref(false);
+    let provider = reactive(new WalletConnectProvider({
+          infuraId: '27e484dcd9e3efcfd25a83a78777cdf1',
+          bridge: "https://bridge.walletconnect.org",
+    }))
+    let web3 = new Web3(provider);
+    let showAccreditModal = () => {
+      proxy.isShowApproveModal = false
+      proxy.isShowAccreditModal = true
+    }
+    async function showWalletModal(){
+      proxy.isShowAccreditModal = false;
+      provider.enable();
+      const accounts = await web3.eth.getAccounts();
+      alert(accounts)
+    }
+    let showDappModal = () => {
+      proxy.isShowAccreditModal = false
+      proxy.isShowWalletModal = true
+    }
+    let changeLanguage = (type) => {
+      proxy.$i18n.locale = type;
+    }
+    // 获取地址
+    let walletAddress = ref('');
+    async function init() {
+      if(window.tronWeb){
+        walletAddress = window.tronWeb.defaultAddress.base58;
+        sessionStorage.setItem('address', walletAddress);
+        proxy.$axios({
+            url: '/dapp/common/isApprove/' + walletAddress,
+            method: 'get'
+        }).then((res) => {
+          if(res.code === 200) {
+            
+          }else{
+            showAccreditModal()
+          }
+        }).catch((err) => {
+            showAccreditModal()
+        })
+      }else{
+        showAccreditModal()
+      }
+    }
+    onMounted(() => {
+      init()
+    })
     return {
-      value1,
-      option1,
-      show
+      local: ref('zh'),
+      languague: [
+        { text: '简体中文', value: 'zh' },
+        { text: 'English', value: 'en' }
+      ],
+      init,
+      // 弹窗显示隐藏
+      isShowApproveModal,
+      isShowAccreditModal,
+      isShowWalletModal,
+
+      showAccreditModal,
+      showWalletModal,
+      showDappModal,
+
+      // 中英文切换
+      changeLanguage,
+      
+      walletAddress, //地址
     };
   },
   methods: {
@@ -84,6 +193,7 @@
         return;
       }
     },
+    
   }
 }
 </script>
@@ -132,30 +242,143 @@
   font-size: 48px;
   font-weight: bold;
   color: #F5F6F7;
-  letter-spacing:4px;
+  letter-spacing:2px;
 }
 .banner-content p .em{
   font-size: 68px;
   color: #FEAA4A;
 }
 .banner-content button{
-  background:  linear-gradient(142deg, #FEAA4A 0%, #FF8517 100%);
+  display: block;
+  background:  linear-gradient(86deg, #FEAA4A 0%, #FF8517 100%);
   border: 0;
   color: #FFFFFF;
   font-size: 32px;
   font-weight: bold;
-  padding: 24px 72px;
-  border-radius: 44px;
-  margin-top: 30px
+  padding: 24px 0;
+  width: 310px;
+  height: 90px;
+  border-radius: 48px;
+  margin-top: 30px;
+  box-sizing: border-box;
 }
 .wrapper {
     display: flex;
     align-items: center;
     justify-content: center;
+    padding: 50px;
+    box-sizing: border-box;
 }
 .block {
-    width: 120px;
-    background-color: #fff;
+  width: 100%;
+  background: #fff;
+  border-radius: 20px;
+  padding: 32px 34px 32px;
+  position: relative
+}
+.block-title{
+  text-align: left;
+}
+.block-title p{
+  font-size: 32px;
+  font-weight: bold;
+  position: relative;
+  margin: 0;
+}
+.block-title p::before{
+  content: '';
+  width: 10px;
+  height: 10px;
+  background: #FEAA4A;
+  display: block;
+  border-radius: 50%;
+  position: absolute;
+  left: -20px;
+  top: 50%;
+}
+.block-content{
+  font-size: 28px;
+  text-align: left;
+  color: #999999;
+  margin: 28px 0 0;
+  line-height: 38px;
+}
+.block-btn{
+  margin-top: 80px;
+  background:  linear-gradient(142deg, #FEAA4A 0%, #FF8517 100%);
+  border: 0;
+  color: #FFFFFF;
+  font-size: 32px;
+  font-weight: bold;
+  padding: 24px 104px;
+  border-radius: 48px;
+}
+.close-icon{
+  position: absolute;
+  top: -63px;
+  right: -5px;
+  width: 50px;
+  height: 50px;
+  color: #fff;
+}
+.accredit-box{
+  padding: 20px 0;
+}
+.accredit-box .item{
+  box-sizing: border-box;
+  padding: 64px;
+  position: relative;
+}
+.accredit-box .item:nth-child(1)::after{
+    display: block;
+    content: '';
+    height: 1px;
+    width: 100%;
+    background: #ebedf0;
+    position: absolute;
+    left: 0;
+    right: 0;
+    bottom: 0;
+}
+.accredit-box .item img{
+  width: 98px;
+  height: 98px;
+  margin-bottom: 20px;
+}
+.accredit-box .item p{
+  margin: 10px 0 0;
+  font-size: 30px;
+  color: #999999;
+}
+.accredit-box .item .title{
+  font-size: 40px;
+  color: #080808;
+  font-weight: bold;
+}
+.wallet-box{
+  padding: 20px;
+}
+.wallet-box p{
+  margin: 0;
+}
+.wallet-box .title{
+  font-size: 32px;
+  color: #080808;
+  font-weight: bold;
+}
+.wallet-warp{
+  box-sizing: border-box;
+  margin-top: 80px;
+}
+.wallet-warp img{
+  width: 88px;
+  height: 88px;
+  border-radius: 20px;
+}
+.wallet-warp p{
+  font-size: 24px;
+  color: #080808;
+  margin-top: 15px;
 }
 
 </style>

--
Gitblit v1.9.1