index.vue 76 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483
  1. <template>
  2. <view class="content">
  3. <view class="wrap flex flsb" :style="{paddingTop:statusBarHeight+'rpx'}">
  4. <w3m-network-button size='md' balance='show' />
  5. <w3m-button size='sm' balance='hide' />
  6. </view>
  7. <!-- <w3m-button /> -->
  8. <!-- <Modal></Modal> -->
  9. <view class="header wrap flex flsb">
  10. <view class="headFl flex">
  11. <image src="../../static/logo.png" mode="" class="logoimg"></image>
  12. <!-- <p style="padding: 0 12rpx;">{{userInfo.nickName}}</p> -->
  13. <view class="vipBox flex">
  14. <image src="../../static/vip.png" mode="" class="vipimg"></image>
  15. <span class="_span">{{userInfo.dengji}}</span>
  16. </view>
  17. <view class="vipBox flex">
  18. <image src="../../static/vip.png" mode="" class="vipimg"></image>
  19. <span class="_span">{{userInfo.jiedian}}</span>
  20. </view>
  21. <view class="unsealBtn buttonbj" v-if="userInfo.status==2" @click="unseal()">自助解封</view>
  22. </view>
  23. <view class="flex">
  24. <view class="headFr flex" >
  25. <!-- <image src="../../static/icon/iconw.png" mode="" class="iconw"></image> -->
  26. <view class="jiaocheng flex" @click="gotoUrl()">
  27. <span>教程</span>
  28. <image src="../../static/iconxs.png" mode="" class="iconlog" ></image>
  29. <!-- <i class="iconfont">&#xeb8d;</i> -->
  30. </view>
  31. </view>
  32. <view class="headFr flex" v-if="inviteLink">
  33. <!-- <image src="../../static/icon/iconw.png" mode="" class="iconw"></image> -->
  34. <view class="address flex" @click="copy(inviteLink)">
  35. <span>邀請連結</span>
  36. <image src="../../static/icon/ordericon.png" mode="" class="iconlog" ></image>
  37. <!-- <i class="iconfont">&#xeb8d;</i> -->
  38. </view>
  39. </view>
  40. </view>
  41. </view>
  42. <view class="invitID wrap flex" v-if="userInfo.invitation">
  43. <view class="idp">轉帳ID:</view>
  44. <view class="idpBox flex " @click="copy(userInfo.invitation)">
  45. {{invitId}}
  46. <image src="../../static/icon/ordericon.png" mode="" class="ordericon" @click="copy(userInfo.invitation)"></image></view>
  47. </view>
  48. <view class="wrap">
  49. <!--体现 top 42rpx-->
  50. <view class="banner flex flsb">
  51. <view class="bannerFl" >
  52. <p>餘額</p>
  53. <view class="txt">{{userInfo.qian1}}USDT</view>
  54. </view>
  55. <view class="bannerBtn" @click="withdrawBtn()">
  56. 提現
  57. </view>
  58. </view>
  59. <!--exchange兑换 top 48rpx-->
  60. <view class="exchange mt">
  61. <view class="flex flsb">
  62. <h4 class="h">兌換</h4>
  63. <view class="exBtn flex" @click="exopen()">
  64. <image src="../../static/icon/Add.png" mode="" class="add"></image>
  65. 轉帳
  66. </view>
  67. </view>
  68. <view class="flex flsb flat ">
  69. <view class="exusdt">
  70. <view class="flex inputbox">
  71. <image src="../../static/usdt.png" class="image"></image>
  72. <!-- <span>USDT</span> -->
  73. <input type="number" v-model="money" placeholder="USDT"
  74. @blur="Listeningfocus"
  75. class="moneyInput">
  76. </view>
  77. <view class="nums">餘額:{{userInfo.qian1}}</view>
  78. </view>
  79. <image src="../../static/icon/icon4.png" mode="" class="iconex"></image>
  80. <view class="exusdt">
  81. <view class="flex inputbox">
  82. <image src="../../static/testlog.png" class="image"></image>
  83. <span>{{exmoney}}</span>
  84. </view>
  85. <view class="nums flex">餘額:{{userInfo.qian2}}</view>
  86. </view>
  87. </view>
  88. </view>
  89. <!-- 订单列表 top 48rpx-->
  90. <view class="orderList mt">
  91. <view class="rows wrap" v-for="(item,indexs) in list" :key="indexs" >
  92. <view class="wraps">
  93. <view class="title flex flsb ">
  94. <view class="titfl flex">
  95. <image src="../../static/tip.png" class="listimg"></image>
  96. {{item.name}}
  97. <view class="typeTips red" v-if="item.ifshow==0"></view>
  98. <view class="typeTips green" v-if="item.ifshow==1"></view>
  99. </view>
  100. <view class="price">{{item.money1}}-{{item.money2}}USDT</view>
  101. </view>
  102. <view class="flex flsb">
  103. <view class="rowsfl">
  104. <view class="times flex">
  105. <image src="../../static/icon/icon1.png" class="iconimg"></image>
  106. 時間:
  107. <span>{{item.begin}}-{{item.end}}</span>
  108. </view>
  109. <view class="times flex">
  110. <image src="../../static/icon/icon2.png" class="iconimg"></image>
  111. 收益:
  112. <span>{{(item.shouyi)*100}}%</span>
  113. </view>
  114. </view>
  115. <view class="rowsfr" v-if="item.ifshow==1" @click="orderopen(item.id,indexs)">預約</view>
  116. <view class="rowsfr" v-if="item.ifshow==0">預約</view>
  117. </view>
  118. </view>
  119. </view>
  120. </view>
  121. </view>
  122. <view class="mask" v-show="isShows||isShow||isShowDj||isShowfk" @click="clearBtn()"></view>
  123. <view class="exform" v-show="isShows">
  124. <view class="wrap">
  125. <view class="passtitle flex">
  126. <h2>VGT轉出數量</h2>
  127. <view class="icon iconfont" @click="clearBtn()">&#xe600;</view>
  128. </view>
  129. <view class="boxli">
  130. <p>請輸入VGT轉出數量</p>
  131. <input type="number" v-model="buyNum" placeholder="請輸入VGT轉出數量" placeholder-style="color:#737C96">
  132. </view>
  133. <view class="boxli">
  134. <p>接收地址</p>
  135. <input type="text" v-model="address" placeholder="請輸入VGT接收地址" placeholder-style="color:#737C96">
  136. </view>
  137. <view class="tjBtn buttonbj" @click="openbtn()">確定</view>
  138. </view>
  139. </view>
  140. <view class="preBook" v-show="isShow">
  141. <view class="wrap" v-if="list.length>0">
  142. <view class="passtitle flex">
  143. <h2>{{list[activeId].name}}</h2>
  144. <view class="icon iconfont" @click="clearBtn()">&#xe600;</view>
  145. </view>
  146. <view class="rowsfl flex">
  147. <view class="times flex">
  148. <image src="../../static/icon/icon2.png" class="iconimg"></image>
  149. 收益:
  150. <span>{{(list[activeId].shouyi)*100}}%</span>
  151. </view>
  152. <view class="times flex">
  153. <image src="../../static/icon/icon1.png" class="iconimg"></image>
  154. 用時:
  155. <span>{{list[activeId].xiaoshi}}小时</span>
  156. </view>
  157. <view class="times flex" style="width: 100%;">
  158. <image src="../../static/icon/icon3.png" class="iconimg"></image>
  159. 價格:
  160. <span style="color: red;"> {{list[activeId].zuidi}}-{{list[activeId].zuigao}}USDT</span>
  161. </view>
  162. </view>
  163. <view class="dataex">
  164. <view class="wrapdata">
  165. <p>請選擇預約日期(可多選)</p>
  166. <view class="datalistBox">
  167. <view v-for="(item,index) in dataList" :key="index" @click="choice(index)"
  168. :class="[item.selected?'selde boxs':'noselde boxs']">
  169. {{item.selected?item.title:item.title}}
  170. </view>
  171. </view>
  172. <!-- <view class="datalistTips flex">
  173. <image src="../../static/icon/tcicon.png" class="tcicon"></image>
  174. <p>{{}}VGT</p>
  175. </view> -->
  176. </view>
  177. </view>
  178. <view class="tjBtn buttonbj" @click="openbtns(list[activeId].id)">預約</view>
  179. </view>
  180. </view>
  181. <!-- 凍結 -->
  182. <view class="freeze" v-if="isShowDj&&freezenum==0">
  183. <view class="wrap">
  184. <view class="passtitle flex">
  185. <!-- <h2>{{list[activeId].name}}</h2> -->
  186. <view class="icon iconfont" @click="clearBtn()">&#xe600;</view>
  187. </view>
  188. <image src="../../static/djicon.png" mode="" class="djicon"></image>
  189. <view class="p">
  190. 地址已凍結
  191. </view>
  192. </view>
  193. </view>
  194. <!-- 支付成功 -->
  195. <view class="freeze" v-if="isShowfk">
  196. <view class="wrap">
  197. <view class="passtitle flex">
  198. <view class="icon iconfont" @click="clearBtn()">&#xe600;</view>
  199. </view>
  200. <image src="../../static/icons.png" mode="" class="fkicon"></image>
  201. <view class="p">付款成功</view>
  202. <view class="p">請勿重複支付</view>
  203. </view>
  204. </view>
  205. <!-- 黑名单 -->
  206. <view class="blacklist" v-if='userInfo.status==4'>
  207. <view class="wrap">
  208. <view class="p">
  209. 黑名單用戶
  210. </view>
  211. </view>
  212. </view>
  213. </view>
  214. </template>
  215. <script>
  216. import {
  217. createWeb3Modal,
  218. defaultWagmiConfig,
  219. useWeb3ModalState,
  220. useWeb3Modal
  221. } from '@web3modal/wagmi/vue'
  222. import {
  223. mainnet,
  224. arbitrum,
  225. optimism,
  226. bsc,
  227. polygon
  228. } from '@wagmi/core/chains'
  229. import {
  230. getAccount, //地址
  231. writeContract,
  232. disconnect, //断开
  233. watchAccount,//观察账户
  234. createConfig, //创建客户端
  235. configureChains, //配置链
  236. getNetwork, //获取链
  237. getWalletClient,
  238. fetchToken,
  239. connect, //链接
  240. watchContractEvent,
  241. watchNetwork,
  242. sendTransaction,
  243. signMessage,
  244. prepareSendTransaction
  245. } from '@wagmi/core'
  246. import {
  247. publicProvider
  248. } from '@wagmi/core/providers/public'
  249. import {
  250. InjectedConnector
  251. } from '@wagmi/core/connectors/injected'
  252. import {
  253. parseEther
  254. } from 'viem'
  255. import { SassColor } from 'sass'
  256. // 1. Get projectId YOUR_PROJECT_ID
  257. const projectId = 'c46fe115e62fd8cc283e8db10b3a7fa7'
  258. // 2. Create wagmiConfig
  259. const metadata = {
  260. name: 'Web3Modal',
  261. description: 'Web3Modal Example',
  262. url: 'https://web3modal.com',
  263. icons: ['https://avatars.githubusercontent.com/u/37784886']
  264. }
  265. const chains = [bsc]
  266. const wagmiConfig = defaultWagmiConfig({
  267. chains,
  268. projectId,
  269. metadata
  270. })
  271. // 3. Create modal
  272. const modal = createWeb3Modal({
  273. wagmiConfig,
  274. projectId,
  275. chains,
  276. optionalChains: [{
  277. chainId: 128,
  278. chainName: "HECO",
  279. nativeCurrency: {
  280. name: "HECO",
  281. symbol: "HT",
  282. decimals: 18,
  283. },
  284. rpcUrls: ["https://http-mainnet.hecochain.com/ "]
  285. },
  286. {
  287. chainId: 137,
  288. chainName: "MATIC",
  289. nativeCurrency: {
  290. name: "MATIC",
  291. symbol: "MATIC",
  292. decimals: 18,
  293. },
  294. rpcUrls: ["https://matic.mytokenpocket.vip/ "],
  295. }
  296. ],
  297. defaultChain: bsc,
  298. tokens: {
  299. 1: {
  300. address: '0xdac17f958d2ee523a2206206994597c13d831ec7',
  301. image: 'token_image_url' //optional ETH
  302. },
  303. 56: {
  304. address: '0x55d398326f99059ff775485246999027b3197955',
  305. image: 'token_image_url' //optional BSC
  306. },
  307. 137: {
  308. address: '0xc2132d05d31c914a87c6611c10748aeb04b58e8f',
  309. image: 'token_image_url' //optional MATIC
  310. },
  311. 128: {
  312. address: '0xa71edc38d189767582c38a3145b5873052c3e47a',
  313. image: 'token_image_url' //optional HT
  314. }
  315. },
  316. //主题覆盖
  317. themeVariables: {
  318. '--w3m-accent': '#02cc66',
  319. },
  320. //主题亮,暗
  321. themeMode: 'light'
  322. })
  323. const state = useWeb3ModalState()
  324. //账户信息
  325. const account = getAccount()
  326. //const addConnector
  327. //账户信息chain
  328. const { chain} = getNetwork()
  329. const result = new InjectedConnector()
  330. export default {
  331. data() {
  332. return {
  333. walletAddress: '',
  334. cType: '',
  335. changid: '', //场次id
  336. type: {}, //天数
  337. activeId: '0',
  338. statusBarHeight: '',
  339. isShow: false,
  340. isShows: false,
  341. isShowDj:false,
  342. isShowfk:false,
  343. freezenum:'',
  344. buyNum: '',
  345. address: '',
  346. payment_password: '',
  347. list: [],
  348. selectList: "",
  349. selectId: [],
  350. userInfo: {},
  351. money: '', //输入兑换数量
  352. inviteLink:'',//邀请链接
  353. invitId:'',
  354. exmoney: 'VGT',
  355. dataList: [{
  356. selected: false,
  357. title: '今日',
  358. id: '1'
  359. },
  360. {
  361. selected: false,
  362. title:'明日',
  363. id: '2'
  364. },
  365. {
  366. selected: false,
  367. title: '後天',
  368. id: '3'
  369. }
  370. ],
  371. url:'',
  372. tips:'0'
  373. }
  374. },
  375. onLoad() {
  376. console.log('load')
  377. uni.startPullDownRefresh(); //这里表示当进入页面的时候就开始执行下拉刷新动画
  378. this.url = location.origin;
  379. const unwatch = watchNetwork((network) => {
  380. this.getChindnew(network)
  381. })
  382. const unwatchAcc = watchAccount((account) => {
  383. this.watchAccounts(account)
  384. })
  385. if (account) {
  386. this.walletAddress = account.address
  387. uni.setStorageSync('walletAddress', account.address)
  388. }
  389. this.getList()
  390. //this.getNum()
  391. //获取状态栏+导航栏的高度
  392. let _that = this;
  393. uni.getSystemInfo({
  394. success(e) {
  395. if (e.platform == "ios") {
  396. _that.statusBarHeight = e.statusBarHeight + 45;
  397. } else {
  398. _that.statusBarHeight = e.statusBarHeight + 50;
  399. }
  400. }
  401. })
  402. },
  403. //监听该页面用户下拉刷新事件
  404. onPullDownRefresh() {
  405. this.getList()
  406. this.getWall()
  407. setTimeout(function () {
  408. uni.stopPullDownRefresh();
  409. }, 1000);
  410. },
  411. computed: {
  412. setup() {
  413. const i18n = computed(() => $t('lang'))
  414. return {
  415. i18n
  416. }
  417. }
  418. },
  419. components: {},
  420. methods: {
  421. getWall(){
  422. const state = useWeb3ModalState()
  423. //账户信息
  424. const account = getAccount()
  425. //账户信息chain
  426. const {chain} = getNetwork()
  427. const result = new InjectedConnector()
  428. const unwatchAcc = watchAccount((account) => {
  429. console.log(account,'地址')
  430. this.watchAccounts(account)
  431. })
  432. //console.log(account)
  433. // if (account) {
  434. // this.walletAddress = account.address
  435. // uni.setStorageSync('walletAddress', account.address)
  436. // this.cType = 'BSC'
  437. // this.getuserInfo()
  438. // }
  439. },
  440. copy(value) {
  441. uni.setClipboardData({
  442. data: value, //要被复制的内容
  443. success: () => { //复制成功的回调函数
  444. uni.showToast({ //提示
  445. title:'複製成功',
  446. })
  447. }
  448. });
  449. },
  450. getChindnew(obj) {
  451. this.cType = obj.chain.id
  452. if (obj.chain.id == 1) {
  453. this.cType = 'ETH'
  454. uni.setStorageSync('cType', 'ETH')
  455. this.getuserInfo() //获取用户信息
  456. } else if (obj.chain.id == 56) {
  457. this.cType = 'BSC'
  458. uni.setStorageSync('cType', 'BSC')
  459. this.getuserInfo() //获取用户信息
  460. this.getNum()
  461. } else if (obj.chain.id == 137) {
  462. this.cType = 'MATIC'
  463. uni.setStorageSync('cType', 'MATIC')
  464. this.getuserInfo() //获取用户信息
  465. } else if (obj.chain.id == 128) {
  466. this.cType = 'HT'
  467. uni.setStorageSync('cType', 'HT')
  468. this.getuserInfo() //获取用户信息
  469. }
  470. },
  471. watchAccounts(data){
  472. console.log(data.address,this.walletAddress)
  473. if(data.address!=this.walletAddress){
  474. this.walletAddress = data.address
  475. uni.setStorageSync('walletAddress', data.address)
  476. this.cType = 'BSC'
  477. uni.setStorageSync('cType', 'BSC')
  478. this.getuserInfo() //获取用户信息
  479. }else{
  480. //console.log('观察账户',data)
  481. this.getuserInfo() //获取用户信息
  482. }
  483. },
  484. clearBtn() {
  485. this.isShows = false
  486. this.isShow = false
  487. this.isShowDj =false
  488. this.isShowfk = false
  489. uni.showTabBar()
  490. this.selectId = []
  491. this.exchenge()
  492. this.freezeNum==2
  493. },
  494. //转账弹窗
  495. exopen() {
  496. this.isShows = true
  497. uni.hideTabBar()
  498. },
  499. orderopen(id, index) {
  500. this.activeId = index
  501. this.isShow = true
  502. uni.hideTabBar()
  503. this.changid = id
  504. },
  505. Listeningfocus(e){
  506. this.exmoney = (e.detail.value) * this.userInfo.huilv
  507. this.convert()
  508. },
  509. //进行兑换
  510. convert() {
  511. let data = {
  512. walletAddress: this.walletAddress,
  513. cType: this.cType,
  514. money: this.money
  515. }
  516. this.$http.dhyuzhifu(data).then(res => {
  517. var datas = res.data
  518. if (datas.code == 200) {
  519. uni.showToast({
  520. title: datas.msg,
  521. icon: 'none',
  522. })
  523. const str = datas.data.data
  524. const lines = str.split("\n");
  525. this.getExchen(lines[0], datas.data.toAddress, datas.data.order_sn)
  526. } else {
  527. uni.showToast({
  528. title: datas.msg,
  529. icon: 'none',
  530. })
  531. }
  532. }).catch(err => {
  533. uni.showToast({
  534. title: err,
  535. icon: 'none',
  536. })
  537. })
  538. },
  539. //进行
  540. async getExchen(data, to, order_sn) {
  541. try {
  542. const hash = await sendTransaction({
  543. data: data,
  544. to: to,
  545. value: parseEther('0'),
  546. });
  547. this.getHash(hash.hash, order_sn)
  548. } catch (error) {
  549. console.log(error)
  550. }
  551. },
  552. //兑换后回调
  553. getHash(hash, order_sn) {
  554. let data = {
  555. walletAddress: this.walletAddress,
  556. cType: this.cType,
  557. order_sn: order_sn,
  558. haxi1: hash
  559. }
  560. this.$http.dhinfo(data).then(res => {
  561. var datas = res.data
  562. var that=this
  563. if (datas.code == 200) {
  564. that.isShowfk=true
  565. setTimeout(function (){
  566. that.getHashs(hash, order_sn)
  567. },2000);
  568. } else {
  569. setTimeout(function () {
  570. that.getHashs(hash, order_sn)
  571. }, 2000);
  572. // uni.showToast({
  573. // title: datas.msg,
  574. // icon: 'none',
  575. // })
  576. }
  577. }).catch(err => {
  578. uni.showToast({
  579. title: err,
  580. icon: 'none',
  581. })
  582. })
  583. },
  584. getHashs(hash, order_sn) {
  585. let data = {
  586. walletAddress: this.walletAddress,
  587. cType: this.cType,
  588. order_sn: order_sn,
  589. haxi1: hash
  590. }
  591. this.$http.dhinfo(data).then(res => {
  592. var datas = res.data
  593. if (datas.code == 200) {
  594. //this.isShowfk=true
  595. console.log(datas.msg)
  596. } else {
  597. // uni.showToast({
  598. // title: datas.msg,
  599. // icon: 'none',
  600. // })
  601. }
  602. }).catch(err => {
  603. uni.showToast({
  604. title: err,
  605. icon: 'none',
  606. })
  607. })
  608. },
  609. //转账进行
  610. openbtn() {
  611. if (this.buyNum == '') {
  612. uni.showToast({
  613. title: '請輸入VGT轉出數量',
  614. icon: 'none',
  615. })
  616. return false
  617. }
  618. if (this.address == '') {
  619. uni.showToast({
  620. title: '請輸入VGT接收地址',
  621. icon: 'none',
  622. })
  623. return false
  624. }
  625. let data = {
  626. walletAddress: this.walletAddress,
  627. cType: this.cType,
  628. money: this.buyNum,
  629. invitation: this.address
  630. }
  631. this.$http.zzyuzhifu(data).then(res => {
  632. var datas = res.data
  633. if (datas.code == 200) {
  634. uni.showToast({
  635. title: datas.msg,
  636. icon: 'none',
  637. })
  638. this.getMessage(datas.data.msg, datas.data.order_sn)
  639. } else {
  640. uni.showToast({
  641. title: datas.msg,
  642. icon: 'none',
  643. })
  644. }
  645. }).catch(err => {
  646. uni.showToast({
  647. title: err,
  648. icon: 'none',
  649. })
  650. })
  651. },
  652. //签名消息
  653. async getMessage(messages, order_sn) {
  654. try {
  655. const signature = await signMessage({
  656. message: messages,
  657. })
  658. //console.log(signature)
  659. this.getZzinfo(signature, messages, order_sn)
  660. } catch (error) {
  661. console.log(hash.hash)
  662. }
  663. },
  664. //转账回调
  665. getZzinfo(canshu2, canshu1, order_sn) {
  666. let data = {
  667. walletAddress: this.walletAddress,
  668. cType: this.cType,
  669. canshu1: canshu1,
  670. canshu2: canshu2,
  671. order_sn: order_sn
  672. }
  673. this.$http.zzinfo(data).then(res => {
  674. var datas = res.data
  675. if (datas.code == 200) {
  676. uni.showToast({
  677. title: datas.msg,
  678. icon: 'none',
  679. })
  680. this.clearBtn()
  681. this.getuserInfo()
  682. } else {
  683. uni.showToast({
  684. title: datas.msg,
  685. icon: 'none',
  686. })
  687. this.clearBtn()
  688. }
  689. }).catch(err => {
  690. uni.showToast({
  691. title: err,
  692. icon: 'none',
  693. })
  694. })
  695. },
  696. //预约
  697. openbtns(id) {
  698. if (this.selectId == '') {
  699. uni.showToast({
  700. title: '請選擇預約時間',
  701. icon: 'none',
  702. })
  703. return false
  704. }
  705. this.type = this.selectId.toString()
  706. let data = {
  707. walletAddress: this.walletAddress,
  708. cType: this.cType,
  709. changid: this.changid,
  710. type: this.type
  711. }
  712. this.$http.yuyue(data).then(res => {
  713. var datas = res.data
  714. if (datas.code == 200) {
  715. uni.showToast({
  716. title: datas.msg,
  717. icon: 'none',
  718. })
  719. this.clearBtn()
  720. } else {
  721. uni.showToast({
  722. title: datas.msg,
  723. icon: 'none',
  724. })
  725. this.clearBtn()
  726. }
  727. }).catch(err => {
  728. uni.showToast({
  729. title: err,
  730. icon: 'none',
  731. })
  732. })
  733. },
  734. exchenge() {
  735. this.dataList.map(item => {
  736. if (item.selected) {
  737. item.selected = false
  738. }
  739. return item
  740. })
  741. console.log(this.dataList, 'data');
  742. },
  743. //获取个人信息
  744. getuserInfo() {
  745. let data = {
  746. walletAddress: this.walletAddress,
  747. cType: this.cType,
  748. }
  749. this.$http.getUserInfo(data).then(res => {
  750. var datas = res.data
  751. if (datas.code == 200) {
  752. this.userInfo = datas.data
  753. uni.showToast({
  754. title: datas.msg,
  755. icon: 'none',
  756. })
  757. uni.setStorageSync('userInfo', datas.data)
  758. this.inviteLink=this.url+'/vgst/#/pages/login/register?inviteId='+ datas.data.invitation
  759. var text =datas.data.invitation
  760. this.invitId=text.slice(0,10) + "..." + text.slice(-10)
  761. if(datas.data.status==2&&this.freezeNum!=2){
  762. this.freezenum=0
  763. this.isShowDj=true
  764. }else{
  765. this.freezenum=1
  766. }
  767. const that = this
  768. setInterval(function() {
  769. that.getNum()
  770. }, 2000);
  771. } else {
  772. uni.showToast({
  773. title: datas.msg,
  774. icon: 'none',
  775. })
  776. uni.navigateTo({
  777. url:'/pages/login/register'
  778. })
  779. }
  780. }).catch(err => {
  781. uni.showToast({
  782. title: err
  783. })
  784. })
  785. },
  786. //场次列列表
  787. getList() {
  788. this.$http.paimaiGoodspaicat().then(res => {
  789. var datas = res.data
  790. if (datas.code == 200) {
  791. this.list = datas.data
  792. } else {
  793. uni.showToast({
  794. title: datas.msg,
  795. icon: 'none',
  796. })
  797. }
  798. }).catch(err => {
  799. uni.showToast({
  800. title: err
  801. })
  802. })
  803. },
  804. getNum(){
  805. let data = {
  806. walletAddress: this.walletAddress,
  807. cType: this.cType,
  808. }
  809. this.$http.jianlounum(data).then(res => {
  810. var datas = res.data
  811. console.log('循环请求')
  812. if (datas.code == 200) {
  813. var tipsnum=datas.data.num.toString()
  814. if(datas.data.num>0){
  815. // 设置徽标
  816. uni.setTabBarBadge({
  817. index: 2, // 索引,从 0 开始,指定第几个 tabBar
  818. text:"2" // 徽标中显示的文本
  819. })
  820. }else{
  821. // 移除徽标
  822. uni.removeTabBarBadge({
  823. index: 2
  824. })
  825. }
  826. } else {
  827. uni.showToast({
  828. title: datas.msg,
  829. icon: 'none',
  830. })
  831. }
  832. }).catch(err => {
  833. uni.showToast({
  834. title: err
  835. })
  836. })
  837. },
  838. //选择按钮
  839. choice(index) {
  840. //当再次被选中时,取消当前选中项
  841. if (this.dataList[index].selected == true) {
  842. this.dataList[index].selected = false;
  843. //取消选中时删除数组中的值
  844. for (var i = 0; i < this.selectId.length; i++) {
  845. if (this.selectId[i] === this.dataList[index].id) {
  846. this.selectId.splice(i, 1);
  847. }
  848. }
  849. this.selectList = this.selectId
  850. } else {
  851. this.dataList[index].selected = true;
  852. this.selectId.push(this.dataList[index].id)
  853. for (var i = 0; i < this.selectId.length; i++) {
  854. console.log(this.selectId[i])
  855. }
  856. this.selectList = this.selectId
  857. }
  858. },
  859. //提现
  860. withdrawBtn(){
  861. let data = {
  862. walletAddress: this.walletAddress,
  863. cType: this.cType,
  864. }
  865. this.$http.applyWithdraw(data).then(res => {
  866. var datas = res.data
  867. if (datas.code == 200) {
  868. //this.userInfo = datas.data
  869. uni.showToast({
  870. title: datas.msg,
  871. icon: 'none',
  872. })
  873. //uni.setStorageSync('userInfo', datas.data)
  874. console.log(datas)
  875. } else {
  876. uni.showToast({
  877. title: datas.msg,
  878. icon: 'none',
  879. })
  880. }
  881. }).catch(err => {
  882. uni.showToast({
  883. title: err
  884. })
  885. })
  886. },
  887. /**
  888. * 调用钱包连接
  889. */
  890. callWalletConnect() {
  891. let that = this;
  892. const web3Modal = new Web3Modal({
  893. network: 'mainnet', // 指定网络类型,可以是mainnet、ropsten、kovan等
  894. cacheProvider: true, // 启用缓存提供商
  895. });
  896. web3Modal.connect().then(provider => {
  897. // 连接成功,返回一个Provider实例,可以通过该实例与以太坊进行交互
  898. console.log(provider)
  899. const web3 = new Web3(provider);
  900. }).catch(error => {
  901. // 连接失败,处理错误情况
  902. });
  903. },
  904. //自助解封
  905. unseal(){
  906. let data = {
  907. walletAddress: this.walletAddress,
  908. cType: this.cType,
  909. }
  910. this.$http.jiefeng(data).then(res => {
  911. var datas = res.data
  912. if (datas.code == 200) {
  913. //this.userInfo = datas.data
  914. uni.showToast({
  915. title: datas.msg,
  916. icon: 'none',
  917. })
  918. this.getuserInfo()
  919. }else{
  920. uni.showToast({
  921. title: datas.msg,
  922. icon: 'none',
  923. })
  924. }
  925. }).catch(err => {
  926. uni.showToast({
  927. title: err
  928. })
  929. })
  930. },
  931. gotoUrl(){
  932. uni.navigateTo({
  933. url:'/pages/my/tutorial'
  934. })
  935. }
  936. }
  937. }
  938. </script>
  939. <style scoped lang="scss">
  940. .header {
  941. height: auto;
  942. padding-top: 30rpx;
  943. .headFl {
  944. height: auto;
  945. font-size: 28rpx;
  946. color: #333333;
  947. font-weight: 700;
  948. .logoimg {
  949. width: 64rpx;
  950. height: 64rpx;
  951. }
  952. .vipBox {
  953. background-color: #FFE09E;
  954. padding: 0 7rpx;
  955. border-radius: 4rpx;
  956. margin-right:6rpx ;
  957. .vipimg {
  958. width: 29rpx;
  959. height: 28rpx;
  960. }
  961. ._span {
  962. font-size: 28rpx;
  963. color: #B77E06;
  964. font-weight: 700;
  965. }
  966. }
  967. .unsealBtn{
  968. padding: 10rpx 20rpx;
  969. border-radius: 12rpx;
  970. margin-left: 20rpx;
  971. font-size: 28rpx;
  972. }
  973. }
  974. .headFr {
  975. height: auto;
  976. .iconw {
  977. width: 56rpx;
  978. height: 56rpx;
  979. }
  980. .address {
  981. margin-left: 20rpx;
  982. border: 1rpx solid #909BB2;
  983. border-radius: 24rpx;
  984. padding: 6rpx;
  985. font-size: 26rpx;
  986. color: #576072;
  987. .iconlog {
  988. width: 30rpx;
  989. height: 30rpx;
  990. border-radius: 50%;
  991. }
  992. span {
  993. padding: 0 6rpx;
  994. font-weight: 700;
  995. }
  996. }
  997. .jiaocheng{
  998. border: 1rpx solid #FFBB8D;
  999. border-radius: 24rpx;
  1000. padding: 6rpx;
  1001. font-size: 26rpx;
  1002. color: #FF6509;
  1003. background-color: #FDECED;
  1004. .iconlog {
  1005. width: 38rpx;
  1006. height: 27rpx;
  1007. border-radius: 50%;
  1008. }
  1009. span {
  1010. padding: 0 6rpx;
  1011. font-weight: 700;
  1012. }
  1013. }
  1014. }
  1015. }
  1016. .invitID{
  1017. margin-top: 20rpx;
  1018. .idp{
  1019. font-size: 32rpx;
  1020. font-weight: 700;
  1021. margin-left: 20rpx;
  1022. }
  1023. .idpBox{
  1024. justify-content: center;
  1025. margin-left: 20rpx;
  1026. width: 60%;
  1027. font-size: 28rpx;
  1028. color: #333333;
  1029. border-radius: 25rpx;
  1030. padding:10rpx 1%;
  1031. border: 1rpx solid rgba(0, 0, 0, 0.05);
  1032. border-radius: 25rpx;
  1033. text-align: center;
  1034. background-color: rgba(0, 0, 0, 0.02);
  1035. }
  1036. .ordericon{
  1037. margin-left: 20rpx;
  1038. width: 36rpx;
  1039. height: 36rpx;
  1040. margin-left: 12rpx;
  1041. }
  1042. }
  1043. .banner {
  1044. margin-top: 42rpx;
  1045. width: 100%;
  1046. height: 218rpx;
  1047. background-repeat: no-repeat;
  1048. background-size: 100% 218rpx;
  1049. background-image: url('');
  1050. .bannerFl {
  1051. margin-left: 48rpx;
  1052. font-size: 28rpx;
  1053. color: #fff;
  1054. .txt {
  1055. font-size: 44rpx;
  1056. font-weight: 700;
  1057. padding-top: 12rpx;
  1058. }
  1059. }
  1060. .bannerBtn {
  1061. margin-right: 48rpx;
  1062. padding: 20rpx 64rpx;
  1063. background-color: #fff;
  1064. text-align: center;
  1065. color: #14C670;
  1066. border-radius: 36rpx;
  1067. }
  1068. }
  1069. .exchange {
  1070. height: auto;
  1071. .h {
  1072. font-size: 36rpx;
  1073. color: #333333;
  1074. margin-bottom: 20rpx;
  1075. }
  1076. .exBtn {
  1077. font-size: 28rpx;
  1078. color: #00529E;
  1079. margin-bottom: 20rpx;
  1080. .add {
  1081. width: 37rpx;
  1082. height: 37rpx;
  1083. }
  1084. }
  1085. .exusdt {
  1086. width: 40%;
  1087. .inputbox {
  1088. border: 1rpx solid #DADCE1;
  1089. width: 80%;
  1090. padding: 18rpx 22rpx;
  1091. border-radius: 8rpx;
  1092. .moneyInput {
  1093. width: 70%;
  1094. }
  1095. }
  1096. .image {
  1097. width: 36rpx;
  1098. height: 36rpx;
  1099. border-radius: 50%;
  1100. margin-right: 10rpx;
  1101. }
  1102. .nums {
  1103. color: #405073;
  1104. font-size: 28rpx;
  1105. margin-top: 20rpx;
  1106. justify-content: space-between;
  1107. }
  1108. }
  1109. .iconex {
  1110. width: 60rpx;
  1111. height: 60rpx;
  1112. }
  1113. }
  1114. .orderList {
  1115. height: auto;
  1116. .rows {
  1117. background-color: #fff;
  1118. border-radius: 20rpx;
  1119. padding: 32rpx 0;
  1120. margin-bottom: 32rpx;
  1121. .title {
  1122. margin-bottom: 20rpx;
  1123. .titfl {
  1124. color: #333333;
  1125. font-size: 32rpx;
  1126. font-weight: 700;
  1127. .typeTips{
  1128. width: 20rpx;
  1129. height: 20rpx;
  1130. border-radius: 50rpx;
  1131. margin-left: 20rpx;
  1132. }
  1133. .red{
  1134. background-color: red;
  1135. }
  1136. .green{
  1137. background-color: #14C670;
  1138. }
  1139. }
  1140. .price {
  1141. color: #F5A94F;
  1142. }
  1143. }
  1144. .listimg {
  1145. width: 48rpx;
  1146. height: 48rpx;
  1147. margin-right: 10rpx;
  1148. }
  1149. .iconimg {
  1150. width: 36rpx;
  1151. height: 36rpx;
  1152. }
  1153. .rowsfl {
  1154. font-size: 28rpx;
  1155. .times {
  1156. margin-bottom: 12rpx;
  1157. color: #828282;
  1158. span {
  1159. color: #333333;
  1160. }
  1161. }
  1162. }
  1163. .rowsfr {
  1164. background: linear-gradient(90.89deg, #38F957 49.57%, #1DEEE1 99.24%);
  1165. width: 164rpx;
  1166. height: 64rpx;
  1167. text-align: center;
  1168. line-height: 64rpx;
  1169. color: #040616;
  1170. font-size: 28rpx;
  1171. border-radius: 8rpx;
  1172. }
  1173. }
  1174. }
  1175. .exform {
  1176. background-color: #fff;
  1177. border-radius: 32rpx 32rpx 0 0;
  1178. width: 90%;
  1179. padding: 46rpx 5%;
  1180. position: fixed;
  1181. left: 0;
  1182. bottom: 0;
  1183. z-index: 12;
  1184. .passtitle {
  1185. justify-content: space-between;
  1186. color: #333;
  1187. h2 {
  1188. width: 100%;
  1189. font-size: 32rpx;
  1190. text-align: center;
  1191. }
  1192. .iconfont {
  1193. font-size: 44rpx;
  1194. color: #BDBDBD;
  1195. }
  1196. }
  1197. .boxli {
  1198. margin: 40rpx 0;
  1199. font-size: 28;
  1200. color: #333333;
  1201. p {
  1202. padding-bottom: 20rpx;
  1203. }
  1204. input {
  1205. font-size: 28rpx;
  1206. padding: 36rpx 20rpx;
  1207. background-color: #F6F6F6;
  1208. border-radius: 4rpx;
  1209. }
  1210. }
  1211. .tjBtn {
  1212. width: 100%;
  1213. text-align: center;
  1214. height: 92rpx;
  1215. line-height: 92rpx;
  1216. color: #333;
  1217. font-weight: 700;
  1218. border-radius: 8rpx;
  1219. font-size: 36rpx;
  1220. }
  1221. }
  1222. .preBook {
  1223. background-color: #fff;
  1224. border-radius: 32rpx 32rpx 0 0;
  1225. width: 90%;
  1226. padding: 46rpx 5%;
  1227. position: fixed;
  1228. left: 0;
  1229. bottom: 0;
  1230. z-index: 12;
  1231. .passtitle {
  1232. justify-content: space-between;
  1233. color: #333;
  1234. h2 {
  1235. width: 100%;
  1236. font-size: 36rpx;
  1237. text-align: center;
  1238. }
  1239. .iconfont {
  1240. font-size: 44rpx;
  1241. color: #BDBDBD;
  1242. }
  1243. }
  1244. .rowsfl {
  1245. margin: 40rpx 0 20rpx 0;
  1246. flex-wrap: wrap;
  1247. font-size: 32rpx;
  1248. .iconimg {
  1249. width: 40rpx;
  1250. height: 40rpx;
  1251. }
  1252. .times {
  1253. width: 45%;
  1254. margin-bottom: 23rpx;
  1255. color: #828282;
  1256. span {
  1257. color: #333333;
  1258. padding-left: 10rpx;
  1259. }
  1260. }
  1261. }
  1262. .dataex {
  1263. margin-top: 20rpx;
  1264. margin-bottom: 40rpx;
  1265. width: 100%;
  1266. height: 326rpx;
  1267. background-repeat: no-repeat;
  1268. background-size: 100% 326rpx;
  1269. background-image: url('');
  1270. .wrapdata {
  1271. padding: 65rpx 58rpx;
  1272. }
  1273. .datalistBox {
  1274. display: flex;
  1275. flex-wrap: wrap;
  1276. .boxs {
  1277. width: 25%;
  1278. height: 56rpx;
  1279. line-height: 56rpx;
  1280. text-align: center;
  1281. margin-top: 30rpx;
  1282. border-radius: 28rpx;
  1283. &:not(:nth-child(3n)) {
  1284. margin-right: calc(10% / 2);
  1285. }
  1286. }
  1287. }
  1288. /* 已选择 */
  1289. .selde {
  1290. border: 1px solid #2F80ED;
  1291. background: #2F80ED;
  1292. color: #FFFFFF;
  1293. border-radius: 28rpx;
  1294. font-size: 28rpx;
  1295. padding: 0 10rpx;
  1296. }
  1297. /* 未选择 */
  1298. .noselde {
  1299. border: 1px solid #2F80ED;
  1300. background: #FFFFFF;
  1301. color: #2F80ED;
  1302. border-radius: 28rpx;
  1303. font-size: 28rpx;
  1304. padding: 0 10rpx;
  1305. }
  1306. .valueList {
  1307. margin-top: 20rpx;
  1308. padding: 20rpx;
  1309. display: flex;
  1310. justify-content: center;
  1311. }
  1312. .datalistTips {
  1313. margin-top: 30rpx;
  1314. color: #223A7A;
  1315. .tcicon {
  1316. width: 28rpx;
  1317. height: 28rpx;
  1318. margin-right: 6rpx;
  1319. }
  1320. }
  1321. }
  1322. .tjBtn {
  1323. width: 100%;
  1324. text-align: center;
  1325. height: 92rpx;
  1326. line-height: 92rpx;
  1327. color: #333;
  1328. font-weight: 700;
  1329. border-radius: 8rpx;
  1330. font-size: 36rpx;
  1331. }
  1332. }
  1333. .freeze{
  1334. width: 80%;
  1335. border-radius: 20rpx;
  1336. background-color: #fff;
  1337. position: fixed;
  1338. left: 10%;
  1339. top: 30%;
  1340. z-index: 1000;
  1341. padding: 20rpx 0;
  1342. .djicon{
  1343. width: 255rpx;
  1344. height: 309rpx;
  1345. margin: 0 auto;
  1346. display: block;
  1347. }
  1348. .fkicon{
  1349. width: 188rpx;
  1350. height: 175rpx;
  1351. margin: 0 auto;
  1352. display: block;
  1353. }
  1354. .p{
  1355. text-align: center;
  1356. font-size: 34rpx;
  1357. padding: 40rpx 0;
  1358. }
  1359. .passtitle {
  1360. justify-content: flex-end;
  1361. color: #333;
  1362. .iconfont {
  1363. font-size: 44rpx;
  1364. color: #BDBDBD;
  1365. margin-right: 30rpx;
  1366. }
  1367. }
  1368. }
  1369. .blacklist{
  1370. width: 100%;
  1371. height: 100vh;
  1372. position: fixed;
  1373. left: 0;
  1374. top: 0;
  1375. background-color: rgba(0, 0, 0, 0.6);
  1376. z-index: 10000;
  1377. .p{
  1378. width: 80%;
  1379. margin-left: 10%;
  1380. margin-top: 80%;
  1381. background-color: #fff;
  1382. text-align: center;
  1383. color: #212121;
  1384. line-height: 200rpx;
  1385. font-size: 44rpx;
  1386. border-radius: 20rpx;
  1387. }
  1388. }
  1389. </style>