ch-tgr/src/views/User/My.vue
2026-05-26 18:46:23 +08:00

412 lines
14 KiB
Vue

<template>
<ManagerPopup v-model="managerPopupVisible" />
<div class="my">
<div class="top">
<img class="avatar" v-if="data.userimg" :src="$file(data.userimg)">
<div class="_info">
<div class="name">
{{ $substring(data.nickname, 0, 12) }}
</div>
<div class="user">
<img src="/img/my-i1.png" />{{ data.cellphone }}
</div>
<div class="box">
<div class="vBicon vip">
{{ data.userlevelname }}
</div>
<div class="vBicon svip" v-if="data.col3">
{{ data.col3name }}
</div>
<div class="vBicon director" v-if="data.col1">
{{ data.col1name }}
</div>
</div>
</div>
<!-- v-if="data.isstudio" -->
<div class="shopcenter" v-if="data.col2 || data.isshop" @click="$showManagerPopup()">
<span>
管理中心
<van-icon name="arrow" />
</span>
</div>
</div>
<div class="wallet_box">
<div @click="$navigate('Balance')">
<div class="t">
<img src="/img/my_w1.png" alt="">
<span>余额</span>
</div>
<b>{{ data.zijin?.toFixed(2) }}</b>
</div>
<div @click="$navigate('CV')">
<div class="t">
<img src="/img/my_w2.png" alt="">
<span>会员卡</span>
</div>
<b>{{ data.xiaofeiquan?.toFixed(2) }}</b>
</div>
<div @click="$navigate('Point')">
<div class="t">
<img src="/img/my_w3.png" alt="">
<span>积分</span>
</div>
<b>{{ data.xiaofeijifen?.toFixed(2) }}</b>
</div>
</div>
<div class="my_order">
<div class="t">
<b>我的订单</b>
<span class="r" @click="$navigate('TradeList')">
更多
<van-icon name="arrow"></van-icon>
</span>
</div>
<div class="c">
<van-badge :dot="data.ordercountdaifukuan > 0" :offset="[3, -3]">
<div class="st_box" @click="$navigate(`/TradeList?state=0`)">
<img src="/img/my_o1.png">
<p>待付款</p>
</div>
</van-badge>
<van-badge :dot="data.ordercountdaifahuo > 0" :offset="[3, -3]">
<div class="st_box" @click="$navigate(`/TradeList?state=1`)">
<img src="/img/my_o2.png">
<p>待发货</p>
</div>
</van-badge>
<van-badge :dot="data.ordercountdaishouhuo > 0" :offset="[3, -3]">
<div class="st_box" @click="$navigate(`/TradeList?state=3`)">
<img src="/img/my_o3.png">
<p>待收货</p>
</div>
</van-badge>
<div class="st_box" @click="$navigate(`/TradeList?state=4`)">
<img src="/img/my_o4.png">
<p>已完成</p>
</div>
</div>
</div>
<div class="fast_to">
<div>
<img src="/img/my_f1.jpg" @click="toInvite()" alt="">
<img src="/img/my_f2.jpg" @click="$navigate('Team')" alt="">
</div>
<div>
<img src="/img/my_f3.jpg" @click="$navigate('Allow')" alt="">
<img src="/img/my_f4.jpg" @click="$navigate('Certificate')" alt="">
</div>
</div>
<div class="service_center">
<div class="tit">
<b>服务中心</b>
</div>
<div class="list">
<div @click="$navigate('CashoutAccount')">
<img src="/img/my_s1.png" alt="">
<span>提现账号</span>
<van-icon name="arrow" class="r"></van-icon>
</div>
<div @click="$navigate('Address')">
<img src="/img/my_s2.png" alt="">
<span>收货地址</span>
<van-icon name="arrow" class="r"></van-icon>
</div>
<div @click="$navigate('Service')">
<img src="/img/my_s3.png" alt="">
<span>联系客服</span>
<van-icon name="arrow" class="r"></van-icon>
</div>
<div @click="settingVisibled = true">
<img src="/img/my_s4.png" alt="">
<span>设置中心</span>
<van-icon name="arrow" class="r"></van-icon>
</div>
</div>
</div>
<van-action-sheet v-model:show="settingVisibled" title="设置中心" class="setting">
<div style="height: 1rem" />
<van-cell is-link icon="/img/set-i1.png" title="个人资料" size="large"
@click="tempData = {}; Object.assign(tempData, data); tempData.AvatarUploader = [{ url: $file(tempData.userimg), isImage: true }]; showInfo = true;">
<template #right-icon>
<img class="y50" :src="$file(data.userimg)" width="29" height="29" />
</template>
</van-cell>
<van-cell is-link icon="/img/set-i2.png" title="登录密码" size="large" value="修改"
@click="changePasswordVisibled = true">
</van-cell>
<van-cell is-link icon="/img/set-i3.png" title="提现账户" size="large" value="管理"
@click="$navigate('/CashoutAccount')">
</van-cell>
<van-cell is-link icon="/img/set-i4.png" title="退出登录" size="large" @click="logout">
<template #right-icon> </template>
</van-cell>
<div style="height: 2rem" />
</van-action-sheet>
<van-action-sheet v-model:show="showInfo" title="个人信息">
<van-form @submit="save">
<van-cell-group inset>
<van-field name="uploader" label="头像" required>
<template #input>
<van-uploader v-model="tempData.AvatarUploader" :after-read="upload" :max-count="1" upload-text="头像" />
</template>
</van-field>
<van-field v-model="tempData.nickname" label="昵称" placeholder="请输入昵称"
:rules="[{ required: true, message: '请填写昵称' }]" clearable required />
<van-field v-model="tempData.cellphone" label="手机号" readonly>
<template #button>
不可更改
</template>
</van-field>
<van-cell>
<template #title>
<van-button color="#ca2904" style="width: 100%" round type="primary" native-type="save"
:loading="saving">保存</van-button>
</template>
</van-cell>
</van-cell-group>
</van-form>
</van-action-sheet>
<van-action-sheet v-model:show="changePasswordVisibled" title="修改登录密码">
<div class="my-setting-password">
<van-cell-group inset>
<van-field style="white-space: nowrap;" v-model="tempPasswordData.code" center clearable label-width="24vw"
:label="this.data.cellphone" placeholder="请输入短信验证码">
<template #button>
<van-button @click="getSmsCode" color="#ca2904" size="small" type="primary" :disabled="isSendCode">{{
isSendCode ? `${sendCodeTime}s` : '获取验证码' }}</van-button>
</template>
</van-field>
<van-field v-model="tempPasswordData.newpwd" type="password" label="新密码" placeholder="请输入新密码" required />
<van-field v-model="tempPasswordData.repwd" type="password" label="确认密码" placeholder="请再次输入新密码" required />
<van-cell size="large">
<template #title>
<van-button round color="#ca2904" type="primary" size="large" @click="setPassword"
:loading="saving">保存</van-button>
</template>
</van-cell>
</van-cell-group>
</div>
</van-action-sheet>
<van-dialog v-model:show="showFollow" :closeOnClickOverlay="false" :showConfirmButton="false"
style="background: transparent; display: flex; align-items: center; flex-direction: column;">
<img :src="$file(FollowQRCode)" style="width: 60vw" />
<div style="margin: 3.333vw 0">
<span style="color: #fff">为了更好为您提供服务<br />请长按识别二维码关注公众号</span>
</div>
<van-button style="background: #fff; width: 60vw" @click="showFollow = false">关闭</van-button>
</van-dialog>
</div>
</template>
<script>
import ManagerPopup from "@/components/ManagerPopup.vue"
export default {
name: 'My',
components: { ManagerPopup },
computed: {
},
beforeRouteEnter(to, from, next) {
if (!localStorage.getItem('member_token')) {
next({ name: 'Login', query: { redirect: to.fullPath } });
} else {
next();
}
},
mounted() {
this.init();
this.$get('/v1/client/HWxinfoClient/qrcode').then(res => {
this.FollowQRCode = res.data;
});
if (this.$isWechat()) {
// alert(localStorage.getItem('openid'))
this.$get(`/v1/client/DUsersClient/subscribe?openid=${localStorage.getItem('openid')}`).then(res => {
// alert(JSON.stringify(res))
if (res.data === false) {
this.showFollow = true;
}
}).catch(() => { });
// this.showFollow = true;
}
window.addEventListener('showManagerPopup', this.onShowManagerPopup)
window.addEventListener('closeManagerPopup', this.onCloseManagerPopup)
},
beforeUnmount() {
window.removeEventListener('showManagerPopup', this.onShowManagerPopup)
window.removeEventListener('closeManagerPopup', this.onCloseManagerPopup)
},
data() {
return {
managerPopupVisible: false,
data: { userimg: '', username: '' },
settingVisibled: false,
changePasswordVisibled: false,
tempPasswordData: {
code: '',
newpwd: '',
repwd: '',
},
showInfo: false,
saving: false,
tempData: {},
showFollow: false,
hf_data: {},
hfLoading: true,
isSendCode: false,
sendCodeTime: 0,
FollowQRCode: '',
}
},
methods: {
init() {
if (!this.$isLogin()) {
this.$showFailToast('登录状态异常,请重新登录')
location.replace('#/Login')
return
}
window.addEventListener('showManagerPopup', this.onShowManagerPopup)
window.addEventListener('closeManagerPopup', this.onCloseManagerPopup)
Promise.all([
this.$get('/v1/client/DUsersClient').then(data => {
// console.log(data);
this.data = data.data;
this.$ls.set('cellphone', data.data.cellphone);
this.$ls.set('userimg', data.data.userimg);
this.$ls.set('nickname', data.data.nickname);
this.$ls.set('isshop', data.data.isshop);
this.$ls.set('iscenter', data.data.col2);
this.$ls.set('user_id', data.data.id);
this.$ls.set('huiyuankaid', data.data.huiyuankaid);
this.$ls.set('user_cv', data.data.xiaofeiquan);
this.$ls.set('user_point', data.data.xiaofeijifen);
}),
]
)
},
onShowManagerPopup() {
this.managerPopupVisible = true
},
onCloseManagerPopup() {
this.managerPopupVisible = false
},
logout() {
this.$showConfirmDialog({
title: "确认退出?",
}).then(() => {
this.$ls.remove('member_token');
location.replace('#/Login');
setTimeout(() => {
location.reload();
}, 100);
}).catch(() => { });
},
toInvite() {
if (!this.data.allowinvitation) {
this.$showFailToast('您暂无邀请权限');
return
}
this.$navigate('Invite')
},
upload(file) {
this.tempData.userimg = file.file;
},
save() {
const fd = new FormData();
fd.append('nickname', this.tempData.nickname);
fd.append('cellphone', this.tempData.cellphone);
if (this.tempData.userimg instanceof File) {
fd.append('file', this.tempData.userimg);
}
this.$postForm('/v1/client/DUsersClient/userinfo', fd).then(() => {
this.$showSuccessToast('保存成功');
this.showInfo = false;
window.location.reload();
}).catch(err => {
this.$showFailToast(err.message || '保存失败');
});
},
valid(field, msg) {
if (!field) {
this.$showFailToast(msg);
return false;
}
return true;
},
getSmsCode() {
if (this.isSendCode) return;
this.isSendCode = true;
this.sendCodeTime = 60;
const id = setInterval(() => {
if (this.sendCodeTime > 0) this.sendCodeTime--;
else { clearInterval(id); this.isSendCode = false; }
}, 1000);
this.$post('/v1/client/AuthClient/sendcode', {
"purpose": "chgpwd",
"cellphone": this.data.cellphone
}).then(res => {
if (res.status === 200) {
this.$showSuccessToast('验证码发送成功')
}
}).catch(err => {
clearInterval(id);
this.isSendCode = false;
this.$showFailToast(err.message);
});
},
setPassword() {
if (!this.tempPasswordData.newpwd) {
this.$showFailToast('请输入新密码');
return;
}
if (this.tempPasswordData.newpwd !== this.tempPasswordData.repwd) {
this.$showFailToast('两次输入的密码不一致');
return;
}
this.saving = true;
this.$put('/v1/client/DUsersClient/changepwd', {
"password": this.tempPasswordData.newpwd,
"code": this.tempPasswordData.code
}).then(res => {
if (res.status === 200) {
this.$showDialog({
title: '密码重置成功!',
message: '点击确认登录中心重新登录',
theme: 'round-button',
confirmButtonText: '确定',
}).then(() => {
this.saving = false;
this.$ls.remove('member_token');
location.replace('#/Login');
});
} else {
this.$showFailToast(res.message);
this.saving = false;
}
}).catch(err => {
this.$showFailToast(err.message);
this.saving = false;
});
},
}
}
</script>