1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483 |
- <template>
- <view class="content">
- <view class="wrap flex flsb" :style="{paddingTop:statusBarHeight+'rpx'}">
- <w3m-network-button size='md' balance='show' />
- <w3m-button size='sm' balance='hide' />
- </view>
- <!-- <w3m-button /> -->
- <!-- <Modal></Modal> -->
- <view class="header wrap flex flsb">
- <view class="headFl flex">
- <image src="../../static/logo.png" mode="" class="logoimg"></image>
- <!-- <p style="padding: 0 12rpx;">{{userInfo.nickName}}</p> -->
- <view class="vipBox flex">
- <image src="../../static/vip.png" mode="" class="vipimg"></image>
- <span class="_span">{{userInfo.dengji}}</span>
- </view>
- <view class="vipBox flex">
- <image src="../../static/vip.png" mode="" class="vipimg"></image>
- <span class="_span">{{userInfo.jiedian}}</span>
- </view>
- <view class="unsealBtn buttonbj" v-if="userInfo.status==2" @click="unseal()">自助解封</view>
- </view>
- <view class="flex">
- <view class="headFr flex" >
- <!-- <image src="../../static/icon/iconw.png" mode="" class="iconw"></image> -->
- <view class="jiaocheng flex" @click="gotoUrl()">
- <span>教程</span>
- <image src="../../static/iconxs.png" mode="" class="iconlog" ></image>
- <!-- <i class="iconfont"></i> -->
- </view>
- </view>
- <view class="headFr flex" v-if="inviteLink">
- <!-- <image src="../../static/icon/iconw.png" mode="" class="iconw"></image> -->
- <view class="address flex" @click="copy(inviteLink)">
- <span>邀請連結</span>
- <image src="../../static/icon/ordericon.png" mode="" class="iconlog" ></image>
- <!-- <i class="iconfont"></i> -->
- </view>
- </view>
- </view>
-
- </view>
- <view class="invitID wrap flex" v-if="userInfo.invitation">
- <view class="idp">轉帳ID:</view>
- <view class="idpBox flex " @click="copy(userInfo.invitation)">
- {{invitId}}
- <image src="../../static/icon/ordericon.png" mode="" class="ordericon" @click="copy(userInfo.invitation)"></image></view>
- </view>
- <view class="wrap">
- <!--体现 top 42rpx-->
- <view class="banner flex flsb">
- <view class="bannerFl" >
- <p>餘額</p>
- <view class="txt">{{userInfo.qian1}}USDT</view>
- </view>
- <view class="bannerBtn" @click="withdrawBtn()">
- 提現
- </view>
- </view>
- <!--exchange兑换 top 48rpx-->
- <view class="exchange mt">
- <view class="flex flsb">
- <h4 class="h">兌換</h4>
- <view class="exBtn flex" @click="exopen()">
- <image src="../../static/icon/Add.png" mode="" class="add"></image>
- 轉帳
- </view>
- </view>
-
- <view class="flex flsb flat ">
- <view class="exusdt">
- <view class="flex inputbox">
- <image src="../../static/usdt.png" class="image"></image>
- <!-- <span>USDT</span> -->
- <input type="number" v-model="money" placeholder="USDT"
- @blur="Listeningfocus"
- class="moneyInput">
- </view>
- <view class="nums">餘額:{{userInfo.qian1}}</view>
- </view>
- <image src="../../static/icon/icon4.png" mode="" class="iconex"></image>
- <view class="exusdt">
- <view class="flex inputbox">
- <image src="../../static/testlog.png" class="image"></image>
- <span>{{exmoney}}</span>
- </view>
- <view class="nums flex">餘額:{{userInfo.qian2}}</view>
- </view>
- </view>
- </view>
- <!-- 订单列表 top 48rpx-->
- <view class="orderList mt">
- <view class="rows wrap" v-for="(item,indexs) in list" :key="indexs" >
- <view class="wraps">
- <view class="title flex flsb ">
- <view class="titfl flex">
- <image src="../../static/tip.png" class="listimg"></image>
- {{item.name}}
- <view class="typeTips red" v-if="item.ifshow==0"></view>
- <view class="typeTips green" v-if="item.ifshow==1"></view>
- </view>
- <view class="price">{{item.money1}}-{{item.money2}}USDT</view>
- </view>
- <view class="flex flsb">
- <view class="rowsfl">
- <view class="times flex">
- <image src="../../static/icon/icon1.png" class="iconimg"></image>
- 時間:
- <span>{{item.begin}}-{{item.end}}</span>
- </view>
- <view class="times flex">
- <image src="../../static/icon/icon2.png" class="iconimg"></image>
- 收益:
- <span>{{(item.shouyi)*100}}%</span>
- </view>
- </view>
- <view class="rowsfr" v-if="item.ifshow==1" @click="orderopen(item.id,indexs)">預約</view>
- <view class="rowsfr" v-if="item.ifshow==0">預約</view>
-
- </view>
- </view>
- </view>
- </view>
- </view>
- <view class="mask" v-show="isShows||isShow||isShowDj||isShowfk" @click="clearBtn()"></view>
- <view class="exform" v-show="isShows">
- <view class="wrap">
- <view class="passtitle flex">
- <h2>VGT轉出數量</h2>
- <view class="icon iconfont" @click="clearBtn()"></view>
- </view>
- <view class="boxli">
- <p>請輸入VGT轉出數量</p>
- <input type="number" v-model="buyNum" placeholder="請輸入VGT轉出數量" placeholder-style="color:#737C96">
- </view>
- <view class="boxli">
- <p>接收地址</p>
- <input type="text" v-model="address" placeholder="請輸入VGT接收地址" placeholder-style="color:#737C96">
- </view>
- <view class="tjBtn buttonbj" @click="openbtn()">確定</view>
- </view>
- </view>
- <view class="preBook" v-show="isShow">
- <view class="wrap" v-if="list.length>0">
- <view class="passtitle flex">
- <h2>{{list[activeId].name}}</h2>
- <view class="icon iconfont" @click="clearBtn()"></view>
- </view>
- <view class="rowsfl flex">
- <view class="times flex">
- <image src="../../static/icon/icon2.png" class="iconimg"></image>
- 收益:
- <span>{{(list[activeId].shouyi)*100}}%</span>
- </view>
- <view class="times flex">
- <image src="../../static/icon/icon1.png" class="iconimg"></image>
- 用時:
- <span>{{list[activeId].xiaoshi}}小时</span>
- </view>
- <view class="times flex" style="width: 100%;">
- <image src="../../static/icon/icon3.png" class="iconimg"></image>
- 價格:
- <span style="color: red;"> {{list[activeId].zuidi}}-{{list[activeId].zuigao}}USDT</span>
- </view>
- </view>
- <view class="dataex">
- <view class="wrapdata">
- <p>請選擇預約日期(可多選)</p>
- <view class="datalistBox">
- <view v-for="(item,index) in dataList" :key="index" @click="choice(index)"
- :class="[item.selected?'selde boxs':'noselde boxs']">
- {{item.selected?item.title:item.title}}
- </view>
- </view>
- <!-- <view class="datalistTips flex">
- <image src="../../static/icon/tcicon.png" class="tcicon"></image>
- <p>{{}}VGT</p>
- </view> -->
- </view>
- </view>
- <view class="tjBtn buttonbj" @click="openbtns(list[activeId].id)">預約</view>
- </view>
- </view>
- <!-- 凍結 -->
- <view class="freeze" v-if="isShowDj&&freezenum==0">
- <view class="wrap">
- <view class="passtitle flex">
- <!-- <h2>{{list[activeId].name}}</h2> -->
- <view class="icon iconfont" @click="clearBtn()"></view>
- </view>
- <image src="../../static/djicon.png" mode="" class="djicon"></image>
- <view class="p">
- 地址已凍結
- </view>
- </view>
- </view>
- <!-- 支付成功 -->
- <view class="freeze" v-if="isShowfk">
- <view class="wrap">
- <view class="passtitle flex">
- <view class="icon iconfont" @click="clearBtn()"></view>
- </view>
- <image src="../../static/icons.png" mode="" class="fkicon"></image>
- <view class="p">付款成功</view>
- <view class="p">請勿重複支付</view>
- </view>
- </view>
- <!-- 黑名单 -->
- <view class="blacklist" v-if='userInfo.status==4'>
- <view class="wrap">
- <view class="p">
- 黑名單用戶
- </view>
- </view>
- </view>
- </view>
- </template>
- <script>
- import {
- createWeb3Modal,
- defaultWagmiConfig,
- useWeb3ModalState,
- useWeb3Modal
- } from '@web3modal/wagmi/vue'
- import {
- mainnet,
- arbitrum,
- optimism,
- bsc,
- polygon
- } from '@wagmi/core/chains'
- import {
- getAccount, //地址
- writeContract,
- disconnect, //断开
- watchAccount,//观察账户
- createConfig, //创建客户端
- configureChains, //配置链
- getNetwork, //获取链
- getWalletClient,
- fetchToken,
- connect, //链接
- watchContractEvent,
- watchNetwork,
- sendTransaction,
- signMessage,
- prepareSendTransaction
- } from '@wagmi/core'
- import {
- publicProvider
- } from '@wagmi/core/providers/public'
- import {
- InjectedConnector
- } from '@wagmi/core/connectors/injected'
- import {
- parseEther
- } from 'viem'
- import { SassColor } from 'sass'
- // 1. Get projectId YOUR_PROJECT_ID
- const projectId = 'c46fe115e62fd8cc283e8db10b3a7fa7'
- // 2. Create wagmiConfig
- const metadata = {
- name: 'Web3Modal',
- description: 'Web3Modal Example',
- url: 'https://web3modal.com',
- icons: ['https://avatars.githubusercontent.com/u/37784886']
- }
- const chains = [bsc]
- const wagmiConfig = defaultWagmiConfig({
- chains,
- projectId,
- metadata
- })
- // 3. Create modal
- const modal = createWeb3Modal({
- wagmiConfig,
- projectId,
- chains,
- optionalChains: [{
- chainId: 128,
- chainName: "HECO",
- nativeCurrency: {
- name: "HECO",
- symbol: "HT",
- decimals: 18,
- },
- rpcUrls: ["https://http-mainnet.hecochain.com/ "]
- },
- {
- chainId: 137,
- chainName: "MATIC",
- nativeCurrency: {
- name: "MATIC",
- symbol: "MATIC",
- decimals: 18,
- },
- rpcUrls: ["https://matic.mytokenpocket.vip/ "],
- }
- ],
- defaultChain: bsc,
- tokens: {
- 1: {
- address: '0xdac17f958d2ee523a2206206994597c13d831ec7',
- image: 'token_image_url' //optional ETH
- },
- 56: {
- address: '0x55d398326f99059ff775485246999027b3197955',
- image: 'token_image_url' //optional BSC
- },
- 137: {
- address: '0xc2132d05d31c914a87c6611c10748aeb04b58e8f',
- image: 'token_image_url' //optional MATIC
- },
- 128: {
- address: '0xa71edc38d189767582c38a3145b5873052c3e47a',
- image: 'token_image_url' //optional HT
- }
- },
- //主题覆盖
- themeVariables: {
- '--w3m-accent': '#02cc66',
- },
- //主题亮,暗
- themeMode: 'light'
- })
- const state = useWeb3ModalState()
- //账户信息
- const account = getAccount()
- //const addConnector
- //账户信息chain
- const { chain} = getNetwork()
- const result = new InjectedConnector()
-
- export default {
- data() {
- return {
- walletAddress: '',
- cType: '',
- changid: '', //场次id
- type: {}, //天数
- activeId: '0',
- statusBarHeight: '',
- isShow: false,
- isShows: false,
- isShowDj:false,
- isShowfk:false,
- freezenum:'',
- buyNum: '',
- address: '',
- payment_password: '',
- list: [],
- selectList: "",
- selectId: [],
- userInfo: {},
- money: '', //输入兑换数量
- inviteLink:'',//邀请链接
- invitId:'',
- exmoney: 'VGT',
- dataList: [{
- selected: false,
- title: '今日',
- id: '1'
- },
- {
- selected: false,
- title:'明日',
- id: '2'
- },
- {
- selected: false,
- title: '後天',
- id: '3'
- }
- ],
- url:'',
- tips:'0'
- }
- },
- onLoad() {
- console.log('load')
- uni.startPullDownRefresh(); //这里表示当进入页面的时候就开始执行下拉刷新动画
- this.url = location.origin;
- const unwatch = watchNetwork((network) => {
- this.getChindnew(network)
- })
- const unwatchAcc = watchAccount((account) => {
- this.watchAccounts(account)
- })
- if (account) {
- this.walletAddress = account.address
- uni.setStorageSync('walletAddress', account.address)
- }
- this.getList()
- //this.getNum()
- //获取状态栏+导航栏的高度
- let _that = this;
- uni.getSystemInfo({
- success(e) {
- if (e.platform == "ios") {
- _that.statusBarHeight = e.statusBarHeight + 45;
- } else {
- _that.statusBarHeight = e.statusBarHeight + 50;
- }
- }
- })
- },
- //监听该页面用户下拉刷新事件
- onPullDownRefresh() {
- this.getList()
- this.getWall()
- setTimeout(function () {
- uni.stopPullDownRefresh();
-
- }, 1000);
- },
- computed: {
- setup() {
- const i18n = computed(() => $t('lang'))
- return {
- i18n
- }
- }
- },
- components: {},
-
- methods: {
- getWall(){
- const state = useWeb3ModalState()
- //账户信息
- const account = getAccount()
- //账户信息chain
- const {chain} = getNetwork()
- const result = new InjectedConnector()
- const unwatchAcc = watchAccount((account) => {
- console.log(account,'地址')
- this.watchAccounts(account)
- })
- //console.log(account)
- // if (account) {
- // this.walletAddress = account.address
- // uni.setStorageSync('walletAddress', account.address)
- // this.cType = 'BSC'
- // this.getuserInfo()
- // }
-
- },
- copy(value) {
- uni.setClipboardData({
- data: value, //要被复制的内容
- success: () => { //复制成功的回调函数
-
- uni.showToast({ //提示
- title:'複製成功',
-
- })
- }
- });
-
- },
- getChindnew(obj) {
- this.cType = obj.chain.id
- if (obj.chain.id == 1) {
- this.cType = 'ETH'
- uni.setStorageSync('cType', 'ETH')
- this.getuserInfo() //获取用户信息
- } else if (obj.chain.id == 56) {
- this.cType = 'BSC'
- uni.setStorageSync('cType', 'BSC')
- this.getuserInfo() //获取用户信息
- this.getNum()
- } else if (obj.chain.id == 137) {
- this.cType = 'MATIC'
- uni.setStorageSync('cType', 'MATIC')
- this.getuserInfo() //获取用户信息
- } else if (obj.chain.id == 128) {
- this.cType = 'HT'
- uni.setStorageSync('cType', 'HT')
- this.getuserInfo() //获取用户信息
- }
- },
- watchAccounts(data){
- console.log(data.address,this.walletAddress)
- if(data.address!=this.walletAddress){
- this.walletAddress = data.address
- uni.setStorageSync('walletAddress', data.address)
- this.cType = 'BSC'
- uni.setStorageSync('cType', 'BSC')
- this.getuserInfo() //获取用户信息
- }else{
- //console.log('观察账户',data)
- this.getuserInfo() //获取用户信息
- }
- },
- clearBtn() {
- this.isShows = false
- this.isShow = false
- this.isShowDj =false
- this.isShowfk = false
- uni.showTabBar()
- this.selectId = []
- this.exchenge()
- this.freezeNum==2
- },
- //转账弹窗
- exopen() {
- this.isShows = true
- uni.hideTabBar()
- },
- orderopen(id, index) {
- this.activeId = index
- this.isShow = true
- uni.hideTabBar()
- this.changid = id
- },
- Listeningfocus(e){
- this.exmoney = (e.detail.value) * this.userInfo.huilv
- this.convert()
- },
- //进行兑换
- convert() {
- let data = {
- walletAddress: this.walletAddress,
- cType: this.cType,
- money: this.money
- }
- this.$http.dhyuzhifu(data).then(res => {
- var datas = res.data
- if (datas.code == 200) {
- uni.showToast({
- title: datas.msg,
- icon: 'none',
- })
- const str = datas.data.data
- const lines = str.split("\n");
- this.getExchen(lines[0], datas.data.toAddress, datas.data.order_sn)
- } else {
- uni.showToast({
- title: datas.msg,
- icon: 'none',
- })
- }
- }).catch(err => {
- uni.showToast({
- title: err,
- icon: 'none',
- })
- })
- },
- //进行
- async getExchen(data, to, order_sn) {
- try {
- const hash = await sendTransaction({
- data: data,
- to: to,
- value: parseEther('0'),
- });
- this.getHash(hash.hash, order_sn)
- } catch (error) {
- console.log(error)
- }
- },
- //兑换后回调
- getHash(hash, order_sn) {
- let data = {
- walletAddress: this.walletAddress,
- cType: this.cType,
- order_sn: order_sn,
- haxi1: hash
- }
- this.$http.dhinfo(data).then(res => {
- var datas = res.data
- var that=this
- if (datas.code == 200) {
- that.isShowfk=true
- setTimeout(function (){
- that.getHashs(hash, order_sn)
- },2000);
-
- } else {
- setTimeout(function () {
- that.getHashs(hash, order_sn)
- }, 2000);
- // uni.showToast({
- // title: datas.msg,
- // icon: 'none',
- // })
- }
- }).catch(err => {
- uni.showToast({
- title: err,
- icon: 'none',
- })
- })
- },
- getHashs(hash, order_sn) {
- let data = {
- walletAddress: this.walletAddress,
- cType: this.cType,
- order_sn: order_sn,
- haxi1: hash
- }
- this.$http.dhinfo(data).then(res => {
- var datas = res.data
- if (datas.code == 200) {
- //this.isShowfk=true
- console.log(datas.msg)
- } else {
- // uni.showToast({
- // title: datas.msg,
- // icon: 'none',
- // })
- }
- }).catch(err => {
- uni.showToast({
- title: err,
- icon: 'none',
- })
- })
- },
- //转账进行
- openbtn() {
- if (this.buyNum == '') {
- uni.showToast({
- title: '請輸入VGT轉出數量',
- icon: 'none',
- })
- return false
- }
- if (this.address == '') {
- uni.showToast({
- title: '請輸入VGT接收地址',
- icon: 'none',
- })
- return false
- }
- let data = {
- walletAddress: this.walletAddress,
- cType: this.cType,
- money: this.buyNum,
- invitation: this.address
- }
- this.$http.zzyuzhifu(data).then(res => {
- var datas = res.data
- if (datas.code == 200) {
- uni.showToast({
- title: datas.msg,
- icon: 'none',
- })
- this.getMessage(datas.data.msg, datas.data.order_sn)
- } else {
- uni.showToast({
- title: datas.msg,
- icon: 'none',
- })
- }
- }).catch(err => {
- uni.showToast({
- title: err,
- icon: 'none',
- })
- })
- },
- //签名消息
- async getMessage(messages, order_sn) {
- try {
- const signature = await signMessage({
- message: messages,
- })
- //console.log(signature)
- this.getZzinfo(signature, messages, order_sn)
- } catch (error) {
- console.log(hash.hash)
- }
- },
- //转账回调
- getZzinfo(canshu2, canshu1, order_sn) {
- let data = {
- walletAddress: this.walletAddress,
- cType: this.cType,
- canshu1: canshu1,
- canshu2: canshu2,
- order_sn: order_sn
- }
- this.$http.zzinfo(data).then(res => {
- var datas = res.data
- if (datas.code == 200) {
- uni.showToast({
- title: datas.msg,
- icon: 'none',
- })
- this.clearBtn()
- this.getuserInfo()
- } else {
- uni.showToast({
- title: datas.msg,
- icon: 'none',
- })
- this.clearBtn()
- }
- }).catch(err => {
- uni.showToast({
- title: err,
- icon: 'none',
- })
- })
- },
- //预约
- openbtns(id) {
- if (this.selectId == '') {
- uni.showToast({
- title: '請選擇預約時間',
- icon: 'none',
- })
- return false
- }
- this.type = this.selectId.toString()
- let data = {
- walletAddress: this.walletAddress,
- cType: this.cType,
- changid: this.changid,
- type: this.type
- }
- this.$http.yuyue(data).then(res => {
- var datas = res.data
- if (datas.code == 200) {
- uni.showToast({
- title: datas.msg,
- icon: 'none',
- })
- this.clearBtn()
- } else {
- uni.showToast({
- title: datas.msg,
- icon: 'none',
- })
- this.clearBtn()
- }
- }).catch(err => {
- uni.showToast({
- title: err,
- icon: 'none',
- })
- })
- },
- exchenge() {
- this.dataList.map(item => {
- if (item.selected) {
- item.selected = false
- }
- return item
- })
- console.log(this.dataList, 'data');
- },
- //获取个人信息
- getuserInfo() {
- let data = {
- walletAddress: this.walletAddress,
- cType: this.cType,
- }
- this.$http.getUserInfo(data).then(res => {
- var datas = res.data
- if (datas.code == 200) {
- this.userInfo = datas.data
- uni.showToast({
- title: datas.msg,
- icon: 'none',
- })
- uni.setStorageSync('userInfo', datas.data)
- this.inviteLink=this.url+'/vgst/#/pages/login/register?inviteId='+ datas.data.invitation
- var text =datas.data.invitation
- this.invitId=text.slice(0,10) + "..." + text.slice(-10)
- if(datas.data.status==2&&this.freezeNum!=2){
- this.freezenum=0
- this.isShowDj=true
- }else{
- this.freezenum=1
- }
- const that = this
- setInterval(function() {
- that.getNum()
- }, 2000);
- } else {
- uni.showToast({
- title: datas.msg,
- icon: 'none',
- })
- uni.navigateTo({
- url:'/pages/login/register'
- })
- }
- }).catch(err => {
- uni.showToast({
- title: err
- })
- })
- },
- //场次列列表
- getList() {
- this.$http.paimaiGoodspaicat().then(res => {
- var datas = res.data
- if (datas.code == 200) {
- this.list = datas.data
- } else {
- uni.showToast({
- title: datas.msg,
- icon: 'none',
- })
- }
- }).catch(err => {
- uni.showToast({
- title: err
- })
- })
- },
- getNum(){
- let data = {
- walletAddress: this.walletAddress,
- cType: this.cType,
- }
- this.$http.jianlounum(data).then(res => {
- var datas = res.data
- console.log('循环请求')
- if (datas.code == 200) {
- var tipsnum=datas.data.num.toString()
- if(datas.data.num>0){
- // 设置徽标
- uni.setTabBarBadge({
- index: 2, // 索引,从 0 开始,指定第几个 tabBar
- text:"2" // 徽标中显示的文本
- })
-
- }else{
- // 移除徽标
- uni.removeTabBarBadge({
- index: 2
- })
- }
- } else {
- uni.showToast({
- title: datas.msg,
- icon: 'none',
- })
- }
- }).catch(err => {
- uni.showToast({
- title: err
- })
- })
- },
- //选择按钮
- choice(index) {
- //当再次被选中时,取消当前选中项
- if (this.dataList[index].selected == true) {
- this.dataList[index].selected = false;
- //取消选中时删除数组中的值
- for (var i = 0; i < this.selectId.length; i++) {
- if (this.selectId[i] === this.dataList[index].id) {
- this.selectId.splice(i, 1);
- }
- }
- this.selectList = this.selectId
- } else {
- this.dataList[index].selected = true;
- this.selectId.push(this.dataList[index].id)
- for (var i = 0; i < this.selectId.length; i++) {
- console.log(this.selectId[i])
- }
- this.selectList = this.selectId
- }
- },
- //提现
- withdrawBtn(){
- let data = {
- walletAddress: this.walletAddress,
- cType: this.cType,
- }
- this.$http.applyWithdraw(data).then(res => {
- var datas = res.data
- if (datas.code == 200) {
- //this.userInfo = datas.data
- uni.showToast({
- title: datas.msg,
- icon: 'none',
- })
- //uni.setStorageSync('userInfo', datas.data)
- console.log(datas)
-
- } else {
- uni.showToast({
- title: datas.msg,
- icon: 'none',
- })
- }
- }).catch(err => {
- uni.showToast({
- title: err
- })
- })
- },
- /**
- * 调用钱包连接
- */
- callWalletConnect() {
- let that = this;
- const web3Modal = new Web3Modal({
- network: 'mainnet', // 指定网络类型,可以是mainnet、ropsten、kovan等
- cacheProvider: true, // 启用缓存提供商
- });
- web3Modal.connect().then(provider => {
- // 连接成功,返回一个Provider实例,可以通过该实例与以太坊进行交互
- console.log(provider)
- const web3 = new Web3(provider);
- }).catch(error => {
- // 连接失败,处理错误情况
- });
- },
- //自助解封
- unseal(){
- let data = {
- walletAddress: this.walletAddress,
- cType: this.cType,
- }
- this.$http.jiefeng(data).then(res => {
- var datas = res.data
- if (datas.code == 200) {
- //this.userInfo = datas.data
- uni.showToast({
- title: datas.msg,
- icon: 'none',
- })
- this.getuserInfo()
- }else{
- uni.showToast({
- title: datas.msg,
- icon: 'none',
- })
- }
- }).catch(err => {
- uni.showToast({
- title: err
- })
- })
- },
- gotoUrl(){
- uni.navigateTo({
- url:'/pages/my/tutorial'
- })
- }
- }
- }
- </script>
- <style scoped lang="scss">
- .header {
- height: auto;
- padding-top: 30rpx;
- .headFl {
- height: auto;
- font-size: 28rpx;
- color: #333333;
- font-weight: 700;
- .logoimg {
- width: 64rpx;
- height: 64rpx;
- }
- .vipBox {
- background-color: #FFE09E;
- padding: 0 7rpx;
- border-radius: 4rpx;
- margin-right:6rpx ;
- .vipimg {
- width: 29rpx;
- height: 28rpx;
- }
- ._span {
- font-size: 28rpx;
- color: #B77E06;
- font-weight: 700;
- }
- }
- .unsealBtn{
- padding: 10rpx 20rpx;
- border-radius: 12rpx;
- margin-left: 20rpx;
- font-size: 28rpx;
- }
- }
- .headFr {
- height: auto;
- .iconw {
- width: 56rpx;
- height: 56rpx;
- }
- .address {
- margin-left: 20rpx;
- border: 1rpx solid #909BB2;
- border-radius: 24rpx;
- padding: 6rpx;
- font-size: 26rpx;
- color: #576072;
- .iconlog {
- width: 30rpx;
- height: 30rpx;
- border-radius: 50%;
- }
- span {
- padding: 0 6rpx;
- font-weight: 700;
- }
- }
- .jiaocheng{
- border: 1rpx solid #FFBB8D;
- border-radius: 24rpx;
- padding: 6rpx;
- font-size: 26rpx;
- color: #FF6509;
- background-color: #FDECED;
- .iconlog {
- width: 38rpx;
- height: 27rpx;
- border-radius: 50%;
- }
-
- span {
- padding: 0 6rpx;
- font-weight: 700;
- }
- }
- }
- }
-
- .invitID{
- margin-top: 20rpx;
- .idp{
- font-size: 32rpx;
- font-weight: 700;
- margin-left: 20rpx;
- }
- .idpBox{
- justify-content: center;
- margin-left: 20rpx;
- width: 60%;
- font-size: 28rpx;
- color: #333333;
- border-radius: 25rpx;
- padding:10rpx 1%;
- border: 1rpx solid rgba(0, 0, 0, 0.05);
- border-radius: 25rpx;
- text-align: center;
- background-color: rgba(0, 0, 0, 0.02);
- }
- .ordericon{
- margin-left: 20rpx;
- width: 36rpx;
- height: 36rpx;
- margin-left: 12rpx;
- }
- }
- .banner {
- margin-top: 42rpx;
- width: 100%;
- height: 218rpx;
- background-repeat: no-repeat;
- background-size: 100% 218rpx;
- background-image: url('');
- .bannerFl {
- margin-left: 48rpx;
- font-size: 28rpx;
- color: #fff;
- .txt {
- font-size: 44rpx;
- font-weight: 700;
- padding-top: 12rpx;
- }
- }
- .bannerBtn {
- margin-right: 48rpx;
- padding: 20rpx 64rpx;
- background-color: #fff;
- text-align: center;
- color: #14C670;
- border-radius: 36rpx;
- }
- }
- .exchange {
- height: auto;
- .h {
- font-size: 36rpx;
- color: #333333;
- margin-bottom: 20rpx;
- }
- .exBtn {
- font-size: 28rpx;
- color: #00529E;
- margin-bottom: 20rpx;
- .add {
- width: 37rpx;
- height: 37rpx;
- }
- }
- .exusdt {
- width: 40%;
- .inputbox {
- border: 1rpx solid #DADCE1;
- width: 80%;
- padding: 18rpx 22rpx;
- border-radius: 8rpx;
- .moneyInput {
- width: 70%;
- }
- }
- .image {
- width: 36rpx;
- height: 36rpx;
- border-radius: 50%;
- margin-right: 10rpx;
- }
- .nums {
- color: #405073;
- font-size: 28rpx;
- margin-top: 20rpx;
- justify-content: space-between;
-
- }
- }
- .iconex {
- width: 60rpx;
- height: 60rpx;
- }
- }
- .orderList {
- height: auto;
- .rows {
- background-color: #fff;
- border-radius: 20rpx;
- padding: 32rpx 0;
- margin-bottom: 32rpx;
- .title {
- margin-bottom: 20rpx;
- .titfl {
- color: #333333;
- font-size: 32rpx;
- font-weight: 700;
- .typeTips{
- width: 20rpx;
- height: 20rpx;
- border-radius: 50rpx;
- margin-left: 20rpx;
- }
- .red{
- background-color: red;
- }
- .green{
- background-color: #14C670;
- }
- }
- .price {
- color: #F5A94F;
- }
- }
- .listimg {
- width: 48rpx;
- height: 48rpx;
- margin-right: 10rpx;
- }
- .iconimg {
- width: 36rpx;
- height: 36rpx;
- }
- .rowsfl {
- font-size: 28rpx;
- .times {
- margin-bottom: 12rpx;
- color: #828282;
- span {
- color: #333333;
- }
- }
- }
- .rowsfr {
- background: linear-gradient(90.89deg, #38F957 49.57%, #1DEEE1 99.24%);
- width: 164rpx;
- height: 64rpx;
- text-align: center;
- line-height: 64rpx;
- color: #040616;
- font-size: 28rpx;
- border-radius: 8rpx;
- }
- }
- }
- .exform {
- background-color: #fff;
- border-radius: 32rpx 32rpx 0 0;
- width: 90%;
- padding: 46rpx 5%;
- position: fixed;
- left: 0;
- bottom: 0;
- z-index: 12;
- .passtitle {
- justify-content: space-between;
- color: #333;
- h2 {
- width: 100%;
- font-size: 32rpx;
- text-align: center;
- }
- .iconfont {
- font-size: 44rpx;
- color: #BDBDBD;
- }
- }
- .boxli {
- margin: 40rpx 0;
- font-size: 28;
- color: #333333;
- p {
- padding-bottom: 20rpx;
- }
- input {
- font-size: 28rpx;
- padding: 36rpx 20rpx;
- background-color: #F6F6F6;
- border-radius: 4rpx;
- }
- }
- .tjBtn {
- width: 100%;
- text-align: center;
- height: 92rpx;
- line-height: 92rpx;
- color: #333;
- font-weight: 700;
- border-radius: 8rpx;
- font-size: 36rpx;
- }
- }
- .preBook {
- background-color: #fff;
- border-radius: 32rpx 32rpx 0 0;
- width: 90%;
- padding: 46rpx 5%;
- position: fixed;
- left: 0;
- bottom: 0;
- z-index: 12;
- .passtitle {
- justify-content: space-between;
- color: #333;
- h2 {
- width: 100%;
- font-size: 36rpx;
- text-align: center;
- }
- .iconfont {
- font-size: 44rpx;
- color: #BDBDBD;
- }
- }
- .rowsfl {
- margin: 40rpx 0 20rpx 0;
- flex-wrap: wrap;
- font-size: 32rpx;
- .iconimg {
- width: 40rpx;
- height: 40rpx;
- }
- .times {
- width: 45%;
- margin-bottom: 23rpx;
- color: #828282;
- span {
- color: #333333;
- padding-left: 10rpx;
- }
- }
- }
- .dataex {
- margin-top: 20rpx;
- margin-bottom: 40rpx;
- width: 100%;
- height: 326rpx;
- background-repeat: no-repeat;
- background-size: 100% 326rpx;
- background-image: url('');
- .wrapdata {
- padding: 65rpx 58rpx;
- }
- .datalistBox {
- display: flex;
- flex-wrap: wrap;
- .boxs {
- width: 25%;
- height: 56rpx;
- line-height: 56rpx;
- text-align: center;
- margin-top: 30rpx;
- border-radius: 28rpx;
- &:not(:nth-child(3n)) {
- margin-right: calc(10% / 2);
- }
- }
- }
- /* 已选择 */
- .selde {
- border: 1px solid #2F80ED;
- background: #2F80ED;
- color: #FFFFFF;
- border-radius: 28rpx;
- font-size: 28rpx;
- padding: 0 10rpx;
- }
- /* 未选择 */
- .noselde {
- border: 1px solid #2F80ED;
- background: #FFFFFF;
- color: #2F80ED;
- border-radius: 28rpx;
- font-size: 28rpx;
- padding: 0 10rpx;
- }
- .valueList {
- margin-top: 20rpx;
- padding: 20rpx;
- display: flex;
- justify-content: center;
- }
- .datalistTips {
- margin-top: 30rpx;
- color: #223A7A;
- .tcicon {
- width: 28rpx;
- height: 28rpx;
- margin-right: 6rpx;
- }
- }
- }
- .tjBtn {
- width: 100%;
- text-align: center;
- height: 92rpx;
- line-height: 92rpx;
- color: #333;
- font-weight: 700;
- border-radius: 8rpx;
- font-size: 36rpx;
- }
- }
- .freeze{
- width: 80%;
- border-radius: 20rpx;
- background-color: #fff;
- position: fixed;
- left: 10%;
- top: 30%;
- z-index: 1000;
- padding: 20rpx 0;
- .djicon{
- width: 255rpx;
- height: 309rpx;
- margin: 0 auto;
- display: block;
- }
- .fkicon{
- width: 188rpx;
- height: 175rpx;
- margin: 0 auto;
- display: block;
- }
- .p{
- text-align: center;
- font-size: 34rpx;
- padding: 40rpx 0;
- }
- .passtitle {
- justify-content: flex-end;
- color: #333;
- .iconfont {
- font-size: 44rpx;
- color: #BDBDBD;
- margin-right: 30rpx;
- }
- }
- }
- .blacklist{
- width: 100%;
- height: 100vh;
- position: fixed;
- left: 0;
- top: 0;
- background-color: rgba(0, 0, 0, 0.6);
- z-index: 10000;
- .p{
- width: 80%;
- margin-left: 10%;
- margin-top: 80%;
- background-color: #fff;
- text-align: center;
- color: #212121;
- line-height: 200rpx;
- font-size: 44rpx;
- border-radius: 20rpx;
- }
- }
-
- </style>
|