| | |
| | | <div @click="goToTopUp()"> |
| | | <img src="@/assets/img/qianbao.png" alt /> |
| | | </div> |
| | | <div> |
| | | <div @click="goOnline"> |
| | | <img src="@/assets/img/kefu.png" alt /> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | <div class="users"> |
| | | <div class="users" @click="goWall()"> |
| | | <div class="left_tou"> |
| | | <div class="left_tx"> |
| | | <div> |
| | | <img src="@/assets/img/eslogo.png" alt /> |
| | | </div> |
| | | </div> |
| | | <div class="right_name" @click="$router.push('/wallet')"> |
| | | <div class="right_name"> |
| | | <span>{{ userInfo.realName ? userInfo.realName : userInfo.phone }}</span> |
| | | </div> |
| | | </div> |
| | |
| | | <div class="keyon"> |
| | | <span>{{ '总资产' }}</span> |
| | | </div> |
| | | <div class="num_price"> |
| | | <p |
| | | v-if="this.$store.state.settingForm.indexDisplay && !this.$store.state.settingForm.futuresDisplay" |
| | | class="account" |
| | | > |
| | | <div class="num_price" v-if="userInfo.length == 0"> |
| | | ¥0 |
| | | </div> |
| | | <div class="num_price" v-if="userInfo.length != 0"> |
| | | <p v-if="this.$store.state.settingForm.indexDisplay && !this.$store.state.settingForm.futuresDisplay" |
| | | class="account"> |
| | | ¥{{ $store.state.hide ? '****' : Number($store.state.userInfo.userAmt + |
| | | $store.state.userInfo.userIndexAmt).toFixed(2) |
| | | }} |
| | | $store.state.userInfo.userIndexAmt).toFixed(2) |
| | | }}11 |
| | | </p> |
| | | <p |
| | | v-else-if="!this.$store.state.settingForm.indexDisplay && this.$store.state.settingForm.futuresDisplay" |
| | | class="account" |
| | | > |
| | | <p v-else-if="!this.$store.state.settingForm.indexDisplay && this.$store.state.settingForm.futuresDisplay" |
| | | class="account"> |
| | | ¥{{ $store.state.hide ? '****' : Number($store.state.userInfo.userAmt + |
| | | $store.state.userInfo.userFuturesAmt).toFixed(2) |
| | | }} |
| | | $store.state.userInfo.userFuturesAmt).toFixed(2) |
| | | }}22 |
| | | </p> |
| | | <p |
| | | v-else-if="!this.$store.state.settingForm.indexDisplay && !this.$store.state.settingForm.futuresDisplay" |
| | | class="account" |
| | | >¥{{ $store.state.hide ? '****' : Number($store.state.userInfo.userAmt).toFixed(2) }}</p> |
| | | <p v-else-if="!this.$store.state.settingForm.indexDisplay && !this.$store.state.settingForm.futuresDisplay" |
| | | class="account">¥ {{ $store.state.hide ? '****' : Number($store.state.userInfo.userAmt).toFixed(2) }}</p> |
| | | </div> |
| | | <div class="yk es"> |
| | | <div> |
| | | <span>{{ '冻结保证金' }}</span> |
| | | </div> |
| | | <div> |
| | | <span>{{ '盈亏' }}</span> |
| | | </div> |
| | | |
| | | <div> |
| | | <span>{{ '可用余额(¥)' }}</span> |
| | | </div> |
| | | </div> |
| | | <div class="yk as"> |
| | | <div> |
| | | <span class="orenge">¥ {{ userInfo.length != 0 ? $store.state.userInfo.allFreezAmt + $store.state.userInfo.djzj : 0}}</span> |
| | | </div> |
| | | <div v-if="userInfo.length == 0"> |
| | | <span v-if="!selectUserFlag"> |
| | | <span>{{ '¥ 0' }}</span> |
| | | </span> |
| | | <span v-else > |
| | | <span>{{ '¥ 0' }}</span> |
| | | </span> |
| | | </div> |
| | | <div v-if="userInfo.length != 0"> |
| | | <span v-if="!selectUserFlag"> |
| | | <span |
| | | :class="$store.state.userInfo.allIndexProfitAndLose > 0 ? ' red' : $store.state.userInfo.allIndexProfitAndLose < 0 ? ' green' : ''" |
| | | >{{ '¥ ' + $store.state.userInfo.allIndexProfitAndLose }}</span> |
| | | :class="$store.state.userInfo.allIndexProfitAndLose > 0 ? ' red' : $store.state.userInfo.allIndexProfitAndLose < 0 ? ' green' : ''">{{ |
| | | '¥ ' + $store.state.userInfo.allIndexProfitAndLose |
| | | }}</span> |
| | | </span> |
| | | <span v-else> |
| | | <span |
| | | :class="$store.state.userInfo.allProfitAndLose > 0 ? ' red' : $store.state.userInfo.allProfitAndLose < 0 ? ' green' : ''" |
| | | >{{ '¥ ' + $store.state.userInfo.allProfitAndLose }}</span> |
| | | :class="$store.state.userInfo.allProfitAndLose > 0 ? ' red' : $store.state.userInfo.allProfitAndLose < 0 ? ' green' : ''">{{ |
| | | '¥ ' + $store.state.userInfo.allProfitAndLose |
| | | }}</span> |
| | | </span> |
| | | </div> |
| | | <div> |
| | | |
| | | <div v-if="userInfo.length == 0"> |
| | | <span class="bzz" v-if="!selectUserFlag">{{ '¥ 0' }}</span> |
| | | <span class="bzz" v-else>{{ '¥ 0' }}</span> |
| | | </div> |
| | | <div v-if="userInfo.length != 0"> |
| | | <span class="bzz" v-if="!selectUserFlag">{{ '¥ ' + $store.state.userInfo.userIndexAmt }}</span> |
| | | <span class="bzz" v-else>{{ '¥ ' + $store.state.userInfo.userAmt }}</span> |
| | | </div> |
| | | |
| | | </div> |
| | | <div class="btns" @click="handleZh()" :class="selectUserFlag ? '' : 'active'"> |
| | | <span>{{ selectUserFlag ? '切换指数账户' : '切换沪深账户' }}</span> |
| | |
| | | </div> |
| | | </div> |
| | | </van-popup> |
| | | <loginPopup /> |
| | | |
| | | </div> |
| | | </template> |
| | | |
| | |
| | | import * as api from "@/axios/api"; |
| | | import { Toast } from "mint-ui"; |
| | | import { isNull, pwdReg } from "@/utils/utils"; |
| | | import loginPopup from "@/components/loginDialog.vue"; |
| | | |
| | | |
| | | export default { |
| | | name: "newUser", |
| | |
| | | oldPassword: "", // 旧密码 |
| | | newPassword: "", // 新密码 |
| | | cirNewPassword: "", //确认新密码 |
| | | userInfo: {}, |
| | | userInfo: [], |
| | | onlineService: "", |
| | | }; |
| | | }, |
| | | components: { |
| | | loginPopup, |
| | | }, |
| | | created() { |
| | | this.getUserInfo(); |
| | | this.getInfoSite(); |
| | | }, |
| | | methods: { |
| | | goOnline() { |
| | | if (navigator.vibrate) { |
| | | // 支持 |
| | | navigator.vibrate([55]); |
| | | } |
| | | window.location.href = this.onlineService; |
| | | }, |
| | | async getInfoSite() { |
| | | let data = await api.getInfoSite() |
| | | if (data.status === 0) { |
| | | this.onlineService = data.data.onlineService |
| | | } else { |
| | | Toast(data.msg) |
| | | } |
| | | }, |
| | | goWall() { |
| | | if (this.userInfo.length == 0) { |
| | | this.$store.commit('dialogVisible', true); |
| | | return; |
| | | } |
| | | this.$router.push('/wallet') |
| | | }, |
| | | handleZh() { |
| | | this.selectUserFlag = !this.selectUserFlag; |
| | | this.dialogVisible = true; |
| | | |
| | | if (this.userInfo.length == 0) { |
| | | this.$store.commit('dialogVisible', true); |
| | | return; |
| | | } |
| | | if (navigator.vibrate) { |
| | | // 支持 |
| | | navigator.vibrate([55]); |
| | | } |
| | | }, |
| | | async getUserInfo() { |
| | | // 获取用户信息 |
| | | let data = await api.getUserInfo(); |
| | | if (data.status === 0) { |
| | | // 判断是否登录 |
| | | this.$store.commit('dialogVisible', false); |
| | | this.$store.state.userInfo = data.data; |
| | | this.userInfo = data.data; |
| | | } else { |
| | | this.$store.commit('dialogVisible', true); |
| | | } |
| | | }, |
| | | goToTopUp() { |
| | | if (this.userInfo.length == 0) { |
| | | this.$store.commit('dialogVisible', true); |
| | | return; |
| | | } |
| | | if (navigator.vibrate) { |
| | | // 支持 |
| | | navigator.vibrate([55]); |
| | | } |
| | | this.$router.push("/wallet"); |
| | | }, |
| | | handleOutLoginClick() { |
| | |
| | | this.toRegister(); |
| | | }, |
| | | goToSettings() { |
| | | if (this.userInfo.length == 0) { |
| | | this.$store.commit('dialogVisible', true); |
| | | return; |
| | | } |
| | | // 每次打开dialog 清空密码数据 |
| | | this.settingDialog = !this.settingDialog; |
| | | if (this.settingDialog) { |
| | |
| | | } |
| | | }, |
| | | handleGoToTransfer() { |
| | | if (this.userInfo.length == 0) { |
| | | this.$store.commit('dialogVisible', true); |
| | | return; |
| | | } |
| | | this.$router.push("/transfers"); |
| | | }, |
| | | handleGoToAuthentication() { |
| | | if (this.userInfo.length == 0) { |
| | | this.$store.commit('dialogVisible', true); |
| | | return; |
| | | } |
| | | this.$router.push("/authentications"); |
| | | }, |
| | | handleGoToBankCard() { |
| | | if (this.userInfo.length == 0) { |
| | | this.$store.commit('dialogVisible', true); |
| | | return; |
| | | } |
| | | this.$router.push("/bankCard"); |
| | | }, |
| | | async toRegister() { |
| | |
| | | this.settingDialog = false; |
| | | } |
| | | } |
| | | if (navigator.vibrate) { |
| | | // 支持 |
| | | navigator.vibrate([55]); |
| | | } |
| | | } |
| | | } |
| | | }; |
| | | </script> |
| | | |
| | | <style scoped lang="less"> |
| | | .green { |
| | | color: #028f52 !important; |
| | | } |
| | | .red{ |
| | | color: #b60c0d !important; |
| | | } |
| | | .user_page { |
| | | width: 100%; |
| | | height: calc(100% - 1.3rem); |
| | | |
| | | .content { |
| | | width: 100%; |
| | | height: 100%; |
| | | padding: 0 0.3rem; |
| | | |
| | | .top_icon { |
| | | width: 100%; |
| | | height: 1.5rem; |
| | | display: flex; |
| | | justify-content: flex-end; |
| | | align-items: center; |
| | | |
| | | .right_icon { |
| | | width: 25%; |
| | | height: 50%; |
| | | display: flex; |
| | | > div { |
| | | |
| | | >div { |
| | | width: 50%; |
| | | height: 100%; |
| | | display: flex; |
| | | justify-content: center; |
| | | align-items: center; |
| | | |
| | | img { |
| | | width: 0.6rem; |
| | | height: 0.6rem; |
| | |
| | | } |
| | | } |
| | | } |
| | | |
| | | .users { |
| | | width: 100%; |
| | | height: 1.7949rem; |
| | |
| | | display: flex; |
| | | align-items: center; |
| | | justify-content: space-between; |
| | | |
| | | .left_tou { |
| | | width: 80%; |
| | | height: 70%; |
| | | display: flex; |
| | | |
| | | .left_tx { |
| | | width: 20%; |
| | | height: 100%; |
| | |
| | | display: flex; |
| | | align-items: center; |
| | | justify-content: center; |
| | | > div { |
| | | |
| | | >div { |
| | | width: 1rem; |
| | | height: 1rem; |
| | | border-radius: 50%; |
| | | overflow: hidden; |
| | | background: rgb(211, 211, 211); |
| | | |
| | | img { |
| | | width: 100%; |
| | | height: 100%; |
| | | } |
| | | } |
| | | } |
| | | |
| | | .right_name { |
| | | width: 80%; |
| | | height: 100%; |
| | | display: flex; |
| | | align-items: center; |
| | | font-size: 0.4415rem; |
| | | |
| | | span { |
| | | font-weight: 600; |
| | | } |
| | | } |
| | | } |
| | | |
| | | .right_go { |
| | | width: 20%; |
| | | height: 70%; |
| | |
| | | justify-content: flex-end; |
| | | align-items: center; |
| | | padding-right: 0.2rem; |
| | | |
| | | img { |
| | | width: 0.6rem; |
| | | height: 0.6rem; |
| | | } |
| | | } |
| | | } |
| | | |
| | | .center_card { |
| | | width: 100%; |
| | | height: 5.3846rem; |
| | | // height: 5.3846rem; |
| | | background-image: linear-gradient(to right bottom, #ffffff, #dfedfc); |
| | | // background-image: linear-gradient(to right, #ffffff , #dfedfc); |
| | | margin-top: 0.5rem; |
| | | border-radius: 0.15rem; |
| | | padding: 0.5rem 0.4rem; |
| | | |
| | | .keyon { |
| | | width: 100%; |
| | | height: 0.5128rem; |
| | | font-size: 0.359rem; |
| | | display: flex; |
| | | align-items: center; |
| | | color: #3d4144; |
| | | font-weight: 600; |
| | | justify-content: center; |
| | | padding-bottom: 0.2rem; |
| | | |
| | | span { |
| | | font-weight: 600; |
| | | font-size: 0.6rem; |
| | | } |
| | | } |
| | | |
| | | .num_price { |
| | | width: 100%; |
| | | // height: 0.6667rem; |
| | | margin-top: 0.1rem; |
| | | display: flex; |
| | | align-items: center; |
| | | justify-content: center; |
| | | font-size: 0.5528rem; |
| | | padding-bottom: 0.3rem; |
| | | |
| | | span { |
| | | font-weight: 600; |
| | | } |
| | | } |
| | | .num_price { |
| | | width: 100%; |
| | | height: 0.6667rem; |
| | | margin-top: 0.1rem; |
| | | display: flex; |
| | | align-items: center; |
| | | font-size: 0.5528rem; |
| | | span { |
| | | font-weight: 600; |
| | | } |
| | | |
| | | .account{ |
| | | font-size: 0.6rem; |
| | | font-weight: 600; |
| | | } |
| | | .yk { |
| | | width: 100%; |
| | | height: 0.5rem; |
| | | display: flex; |
| | | align-items: center; |
| | | > div { |
| | | width: 50%; |
| | | justify-content: space-between; |
| | | |
| | | >div { |
| | | width: 33%; |
| | | height: 100%; |
| | | color: #97989d; |
| | | display: flex; |
| | | align-items: center; |
| | | justify-content: center; |
| | | } |
| | | .orenge{ |
| | | // color: rgb(216, 141, 1) !important; |
| | | } |
| | | } |
| | | |
| | | .yk.es { |
| | | margin-top: 0.3rem; |
| | | } |
| | | |
| | | .yk.as { |
| | | font-size: 0.4033rem; |
| | | margin-top: 0.1rem; |
| | | |
| | | span { |
| | | color: #000; |
| | | font-weight: 600; |
| | | } |
| | | |
| | | .bzz { |
| | | color: #4ea364; |
| | | // color: #4ea364; |
| | | } |
| | | } |
| | | |
| | | .btns { |
| | | width: 100%; |
| | | height: 1.2821rem; |
| | |
| | | font-size: 0.4015rem; |
| | | color: #fff; |
| | | margin-top: 0.35rem; |
| | | |
| | | span { |
| | | font-weight: 600; |
| | | } |
| | | } |
| | | |
| | | .active { |
| | | background: #4ea364; |
| | | } |
| | | } |
| | | |
| | | .jy { |
| | | width: 100%; |
| | | height: 1.5rem; |
| | |
| | | justify-content: space-between; |
| | | padding: 0 0.3rem; |
| | | margin-top: 0.3rem; |
| | | |
| | | .left_gn { |
| | | width: 40%; |
| | | height: 60%; |
| | | display: flex; |
| | | |
| | | .l_icon { |
| | | width: 30%; |
| | | height: 100%; |
| | | display: flex; |
| | | justify-content: center; |
| | | align-items: center; |
| | | |
| | | img { |
| | | width: 0.5041rem; |
| | | height: 0.5041rem; |
| | | } |
| | | } |
| | | |
| | | .r_title { |
| | | width: 70%; |
| | | height: 100%; |
| | |
| | | align-items: center; |
| | | font-size: 0.4046rem; |
| | | color: #404040; |
| | | |
| | | span { |
| | | font-weight: 600; |
| | | } |
| | | } |
| | | } |
| | | |
| | | .right_gos { |
| | | width: 20%; |
| | | height: 60%; |
| | | display: flex; |
| | | align-items: center; |
| | | justify-content: flex-end; |
| | | |
| | | img { |
| | | width: 0.6rem; |
| | | height: 0.6rem; |
| | |
| | | } |
| | | } |
| | | } |
| | | |
| | | .setting_content { |
| | | width: 100%; |
| | | height: 5rem; |
| | | padding: 0.3rem; |
| | | |
| | | .old_password { |
| | | width: 100%; |
| | | height: 1rem; |
| | |
| | | border-radius: 0.15rem; |
| | | display: flex; |
| | | margin-top: 0.5rem; |
| | | |
| | | .left_titles { |
| | | width: 25%; |
| | | height: 100%; |
| | | display: flex; |
| | | align-items: center; |
| | | padding-left: 0.2rem; |
| | | |
| | | // justify-content: flex-end; |
| | | span { |
| | | font-weight: 600; |
| | | } |
| | | } |
| | | |
| | | .right_password_input { |
| | | width: 80%; |
| | | height: 100%; |
| | | display: flex; |
| | | align-items: center; |
| | | |
| | | input { |
| | | width: 100%; |
| | | height: 100%; |
| | |
| | | } |
| | | } |
| | | } |
| | | |
| | | .btn_setting { |
| | | width: 100%; |
| | | height: 1.3rem; |
| | |
| | | display: flex; |
| | | align-items: center; |
| | | justify-content: center; |
| | | |
| | | span { |
| | | font-weight: 600; |
| | | } |
| | | } |
| | | } |
| | | |
| | | </style> |