2025-03-14 16:27:50 +08:00
|
|
|
|
<template>
|
|
|
|
|
<view class="user">
|
|
|
|
|
<!-- 个人信息 -->
|
|
|
|
|
<view class="status_bar">
|
|
|
|
|
<!-- 这里是状态栏 -->
|
|
|
|
|
</view>
|
2025-04-30 14:42:40 +08:00
|
|
|
|
<view class="header">
|
|
|
|
|
<view @click="nav()" :style="{ zIndex: 9999999, padding: '5px' }">
|
|
|
|
|
返回
|
2025-03-14 16:27:50 +08:00
|
|
|
|
</view>
|
2025-04-30 14:42:40 +08:00
|
|
|
|
<view class="headercon" @click="userDetail">
|
|
|
|
|
<view class="head-1">
|
|
|
|
|
<image :src="userInfo.face || '/static/imlogo.png'"></image>
|
|
|
|
|
</view>
|
|
|
|
|
<view class="head-2" v-if="userInfo.id">
|
|
|
|
|
<view class="user-name">{{ userInfo.nickName }}</view>
|
|
|
|
|
<view class="user-logn" v-if="userInfo.expert">
|
|
|
|
|
<view class="mong"></view>
|
|
|
|
|
<view>达人</view>
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
2025-04-25 18:20:19 +08:00
|
|
|
|
|
2025-04-30 14:42:40 +08:00
|
|
|
|
<view class="head-2" v-else>
|
|
|
|
|
<view class="user-name">登录/注册</view>
|
2025-04-25 18:20:19 +08:00
|
|
|
|
</view>
|
2025-03-14 16:27:50 +08:00
|
|
|
|
</view>
|
2025-04-21 17:39:41 +08:00
|
|
|
|
|
2025-04-25 18:20:19 +08:00
|
|
|
|
<!-- <u-icon
|
2025-04-21 17:39:41 +08:00
|
|
|
|
style="display: flex; align-items: flex-start"
|
|
|
|
|
name="arrow-right"
|
2025-04-25 18:20:19 +08:00
|
|
|
|
></u-icon> -->
|
2025-03-14 16:27:50 +08:00
|
|
|
|
</view>
|
|
|
|
|
<!-- 积分,优惠券,关注, -->
|
2025-04-30 14:42:40 +08:00
|
|
|
|
<div class="pointBox box" >
|
2025-03-14 16:27:50 +08:00
|
|
|
|
<u-row text-align="center" gutter="16" class="point">
|
2025-04-30 14:42:40 +08:00
|
|
|
|
<!-- <u-col
|
2025-04-21 17:39:41 +08:00
|
|
|
|
text-align="center"
|
|
|
|
|
span="4"
|
|
|
|
|
@click="navigateTo('/pages/mine/deposit/operation')"
|
|
|
|
|
>
|
2025-03-14 16:27:50 +08:00
|
|
|
|
<view>预存款</view>
|
2025-04-21 17:39:41 +08:00
|
|
|
|
<view class="money">{{ walletNum | unitPrice }}</view>
|
2025-04-30 14:42:40 +08:00
|
|
|
|
</u-col> -->
|
2025-03-14 16:27:50 +08:00
|
|
|
|
|
2025-04-21 17:39:41 +08:00
|
|
|
|
<u-col
|
|
|
|
|
text-align="center"
|
|
|
|
|
span="4"
|
|
|
|
|
@click="navigateTo('/pages/cart/coupon/myCoupon')"
|
|
|
|
|
>
|
2025-03-14 16:27:50 +08:00
|
|
|
|
<view>优惠券</view>
|
|
|
|
|
<view>{{ couponNum || 0 }}</view>
|
|
|
|
|
</u-col>
|
|
|
|
|
|
2025-04-21 17:39:41 +08:00
|
|
|
|
<u-col
|
|
|
|
|
text-align="center"
|
|
|
|
|
span="4"
|
|
|
|
|
@click="navigateTo('/pages/mine/myTracks')"
|
|
|
|
|
>
|
2025-03-14 16:27:50 +08:00
|
|
|
|
<view>足迹</view>
|
|
|
|
|
<view>{{ footNum || 0 }}</view>
|
|
|
|
|
</u-col>
|
|
|
|
|
</u-row>
|
|
|
|
|
<!-- 我的订单,代付款 -->
|
|
|
|
|
<view class="order">
|
2025-04-21 17:39:41 +08:00
|
|
|
|
<view
|
|
|
|
|
class="order-item"
|
|
|
|
|
@click="navigateTo('/pages/order/myOrder?status=0')"
|
|
|
|
|
>
|
2025-03-14 16:27:50 +08:00
|
|
|
|
<div class="bag bag1">
|
|
|
|
|
<u-icon name="order" size="35" color="#fff"></u-icon>
|
|
|
|
|
</div>
|
|
|
|
|
<view>我的订单</view>
|
|
|
|
|
</view>
|
2025-04-21 17:39:41 +08:00
|
|
|
|
<view
|
|
|
|
|
class="order-item"
|
|
|
|
|
@click="navigateTo('/pages/order/myOrder?status=1')"
|
|
|
|
|
>
|
2025-03-14 16:27:50 +08:00
|
|
|
|
<div class="bag bag2">
|
|
|
|
|
<u-icon name="bag-fill" size="35" color="#fff"></u-icon>
|
|
|
|
|
</div>
|
|
|
|
|
<view>待付款</view>
|
|
|
|
|
</view>
|
2025-04-21 17:39:41 +08:00
|
|
|
|
<view
|
|
|
|
|
class="order-item"
|
|
|
|
|
@click="navigateTo('/pages/order/myOrder?status=3')"
|
|
|
|
|
>
|
2025-03-14 16:27:50 +08:00
|
|
|
|
<div class="bag bag3">
|
|
|
|
|
<u-icon name="car-fill" size="35" color="#fff"></u-icon>
|
|
|
|
|
</div>
|
|
|
|
|
<view>待收货</view>
|
|
|
|
|
</view>
|
2025-04-21 17:39:41 +08:00
|
|
|
|
<view
|
|
|
|
|
class="order-item"
|
|
|
|
|
@click="navigateTo('/pages/order/evaluate/myEvaluate')"
|
|
|
|
|
>
|
2025-03-14 16:27:50 +08:00
|
|
|
|
<div class="bag bag4">
|
|
|
|
|
<u-icon name="star-fill" size="35" color="#fff"></u-icon>
|
|
|
|
|
</div>
|
|
|
|
|
<view>待评价</view>
|
|
|
|
|
</view>
|
2025-04-21 17:39:41 +08:00
|
|
|
|
<view
|
|
|
|
|
class="order-item"
|
|
|
|
|
@click="navigateTo('/pages/order/afterSales/afterSales')"
|
|
|
|
|
>
|
2025-03-14 16:27:50 +08:00
|
|
|
|
<div class="bag bag5">
|
|
|
|
|
<u-icon name="server-fill" size="35" color="#fff"></u-icon>
|
|
|
|
|
</div>
|
|
|
|
|
<view>售后服务</view>
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
|
|
|
|
</div>
|
|
|
|
|
<!-- 常用工具 -->
|
|
|
|
|
|
2025-04-25 18:20:19 +08:00
|
|
|
|
<tool :userInfo="userInfo" v-if="userInfo.id != undefined" ref="tool" />
|
2025-03-14 16:27:50 +08:00
|
|
|
|
</view>
|
|
|
|
|
</template>
|
|
|
|
|
<script>
|
|
|
|
|
import tool from "@/pages/tabbar/user/utils/tool.vue";
|
|
|
|
|
import { getCouponsNum, getFootprintNum } from "@/api/members.js";
|
|
|
|
|
import { getUserWallet } from "@/api/members";
|
2025-04-25 18:20:19 +08:00
|
|
|
|
import Views from "../home/views.vue";
|
|
|
|
|
import { getUserInfo } from "@/api/members";
|
2025-03-14 16:27:50 +08:00
|
|
|
|
export default {
|
|
|
|
|
components: {
|
|
|
|
|
tool,
|
|
|
|
|
},
|
|
|
|
|
data() {
|
|
|
|
|
return {
|
|
|
|
|
coverTransform: "translateY(0px)",
|
|
|
|
|
coverTransition: "0s",
|
|
|
|
|
moving: false,
|
|
|
|
|
userInfo: {},
|
|
|
|
|
couponNum: "",
|
|
|
|
|
footNum: "",
|
|
|
|
|
walletNum: "",
|
|
|
|
|
};
|
|
|
|
|
},
|
2025-04-30 14:42:40 +08:00
|
|
|
|
onLoad() {
|
|
|
|
|
this.userInfo = this.$options.filters.isLogin();
|
|
|
|
|
this.getUserOrderNum();
|
|
|
|
|
},
|
2025-03-14 16:27:50 +08:00
|
|
|
|
onShow() {
|
|
|
|
|
this.userInfo = this.$options.filters.isLogin();
|
2025-04-30 14:42:40 +08:00
|
|
|
|
|
2025-03-14 16:27:50 +08:00
|
|
|
|
if (this.$options.filters.isLogin("auth")) {
|
|
|
|
|
this.getUserOrderNum();
|
|
|
|
|
} else {
|
|
|
|
|
this.walletNum = 0;
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
onPullDownRefresh() {
|
|
|
|
|
this.getUserOrderNum();
|
|
|
|
|
this.userInfo = this.$options.filters.isLogin();
|
|
|
|
|
},
|
|
|
|
|
// #ifndef MP
|
|
|
|
|
onNavigationBarButtonTap(e) {
|
|
|
|
|
const index = e.index;
|
|
|
|
|
if (index === 0) {
|
|
|
|
|
this.navigateTo("/pages/mine/set/setUp");
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
// #endif
|
|
|
|
|
|
2025-04-30 14:42:40 +08:00
|
|
|
|
mounted() {
|
|
|
|
|
this.userInfo = this.$options.filters.isLogin();
|
|
|
|
|
this.getUserOrderNum();
|
|
|
|
|
},
|
2025-03-14 16:27:50 +08:00
|
|
|
|
methods: {
|
2025-04-30 14:42:40 +08:00
|
|
|
|
nav() {
|
|
|
|
|
uni.switchTab({
|
|
|
|
|
url: `/pages/me/me`,
|
2025-04-25 18:20:19 +08:00
|
|
|
|
});
|
|
|
|
|
},
|
2025-04-30 14:42:40 +08:00
|
|
|
|
|
2025-03-14 16:27:50 +08:00
|
|
|
|
/**
|
|
|
|
|
* 统一跳转接口,拦截未登录路由
|
|
|
|
|
* navigator标签现在默认没有转场动画,所以用view
|
|
|
|
|
*/
|
|
|
|
|
navigateTo(url) {
|
|
|
|
|
uni.navigateTo({
|
|
|
|
|
url,
|
|
|
|
|
});
|
|
|
|
|
},
|
|
|
|
|
userDetail() {
|
|
|
|
|
this.userInfo.id
|
|
|
|
|
? this.navigateTo("/pages/mine/set/personMsg")
|
2025-04-21 17:39:41 +08:00
|
|
|
|
: this.$options.filters.navigateToLogin();
|
2025-03-14 16:27:50 +08:00
|
|
|
|
},
|
|
|
|
|
async getUserOrderNum() {
|
|
|
|
|
uni.stopPullDownRefresh();
|
|
|
|
|
|
|
|
|
|
Promise.all([
|
|
|
|
|
getCouponsNum(), //优惠券
|
|
|
|
|
getFootprintNum(), //浏览数量
|
|
|
|
|
getUserWallet(), //预存款
|
|
|
|
|
]).then((res) => {
|
|
|
|
|
this.couponNum = res[0].data.result;
|
|
|
|
|
this.footNum = res[1].data.result;
|
|
|
|
|
this.walletNum = res[2].data.result.memberWallet;
|
|
|
|
|
});
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
};
|
|
|
|
|
</script>
|
|
|
|
|
|
|
|
|
|
<style lang="scss" scoped>
|
|
|
|
|
html,
|
|
|
|
|
body {
|
|
|
|
|
overflow: auto;
|
|
|
|
|
}
|
|
|
|
|
.money {
|
|
|
|
|
overflow: hidden;
|
|
|
|
|
|
|
|
|
|
text-overflow: ellipsis;
|
|
|
|
|
white-space: nowrap;
|
|
|
|
|
}
|
|
|
|
|
.user {
|
|
|
|
|
.header {
|
|
|
|
|
max-width: 100%;
|
|
|
|
|
padding: calc(50rpx + var(--status-bar-height)) 30rpx 0 6%;
|
|
|
|
|
height: calc(var(--status-bar-height) + 360rpx);
|
|
|
|
|
background-size: cover;
|
|
|
|
|
border-bottom-left-radius: 30rpx;
|
|
|
|
|
border-bottom-right-radius: 30rpx;
|
|
|
|
|
background-image: url("/static/img/main-bg.png");
|
|
|
|
|
background-position: bottom;
|
|
|
|
|
background-repeat: no-repeat;
|
|
|
|
|
color: #ffffff;
|
2025-04-30 14:42:40 +08:00
|
|
|
|
|
|
|
|
|
.headercon {
|
|
|
|
|
display: flex;
|
|
|
|
|
justify-content: space-between;
|
|
|
|
|
}
|
2025-03-14 16:27:50 +08:00
|
|
|
|
.head-1 {
|
|
|
|
|
text-align: center;
|
|
|
|
|
width: 152rpx;
|
|
|
|
|
position: relative;
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
image {
|
|
|
|
|
width: 152rpx;
|
|
|
|
|
height: 144rpx;
|
|
|
|
|
border-radius: 50%;
|
|
|
|
|
margin-bottom: 30rpx;
|
|
|
|
|
border: 3px solid #fff;
|
|
|
|
|
}
|
|
|
|
|
.edti-head {
|
|
|
|
|
position: absolute;
|
|
|
|
|
width: 40rpx;
|
|
|
|
|
height: 40rpx;
|
|
|
|
|
border-radius: 50%;
|
|
|
|
|
background-color: rgba(255, 255, 255, 0.3);
|
|
|
|
|
top: 100rpx;
|
|
|
|
|
right: 0;
|
|
|
|
|
image {
|
|
|
|
|
width: 100%;
|
|
|
|
|
height: 100%;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
.head-2 {
|
|
|
|
|
flex: 1;
|
2025-04-30 14:42:40 +08:00
|
|
|
|
margin-left: 15px;
|
|
|
|
|
margin-top: 16px;
|
2025-03-14 16:27:50 +08:00
|
|
|
|
line-height: 1;
|
|
|
|
|
}
|
|
|
|
|
/deep/ .u-icon,
|
|
|
|
|
.u-icon {
|
|
|
|
|
margin-top: 106rpx;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
.pointBox {
|
|
|
|
|
width: 94%;
|
|
|
|
|
margin: 0 3%;
|
|
|
|
|
background: #fff;
|
|
|
|
|
border-radius: 20rpx;
|
|
|
|
|
box-shadow: 0 4rpx 24rpx 0 rgba($color: #f6f6f6, $alpha: 1);
|
2025-04-30 14:42:40 +08:00
|
|
|
|
|
2025-03-14 16:27:50 +08:00
|
|
|
|
}
|
|
|
|
|
.point {
|
|
|
|
|
text-align: center;
|
|
|
|
|
height: 160rpx;
|
2025-04-30 14:42:40 +08:00
|
|
|
|
justify-content: space-around !important;
|
2025-03-14 16:27:50 +08:00
|
|
|
|
font-size: $font-sm;
|
|
|
|
|
// #ifdef MP-WEIXIN
|
|
|
|
|
padding: 24rpx;
|
|
|
|
|
// #endif
|
|
|
|
|
.u-col {
|
|
|
|
|
view {
|
|
|
|
|
color: $u-main-color;
|
|
|
|
|
font-size: 28rpx;
|
|
|
|
|
}
|
|
|
|
|
view:last-child {
|
|
|
|
|
margin-top: 8rpx;
|
|
|
|
|
color: $main-color;
|
|
|
|
|
font-size: $font-lg;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
.order {
|
|
|
|
|
height: 140rpx;
|
|
|
|
|
text-align: center;
|
|
|
|
|
font-size: $font-sm;
|
|
|
|
|
display: flex;
|
|
|
|
|
justify-content: space-around;
|
|
|
|
|
align-items: center;
|
|
|
|
|
padding: 0 3%;
|
|
|
|
|
color: #999;
|
|
|
|
|
.order-item {
|
|
|
|
|
position: relative;
|
|
|
|
|
line-height: 2em;
|
|
|
|
|
width: 96rpx;
|
|
|
|
|
:first-child {
|
|
|
|
|
font-size: 48rpx;
|
|
|
|
|
margin-bottom: 10rpx;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.box {
|
|
|
|
|
transform: translateY(-30rpx);
|
|
|
|
|
}
|
|
|
|
|
.user-name {
|
|
|
|
|
font-size: 34rpx;
|
|
|
|
|
}
|
2025-04-25 18:20:19 +08:00
|
|
|
|
.user-logn {
|
|
|
|
|
display: flex;
|
|
|
|
|
align-items: center;
|
|
|
|
|
margin: 15px 15px 0px 0px;
|
|
|
|
|
font-size: 15px;
|
2025-04-30 14:42:40 +08:00
|
|
|
|
.mong {
|
2025-04-25 18:20:19 +08:00
|
|
|
|
width: 1rem;
|
2025-04-30 14:42:40 +08:00
|
|
|
|
height: 1rem;
|
2025-04-25 18:20:19 +08:00
|
|
|
|
background: url("@/static/mon.png") no-repeat;
|
|
|
|
|
background-size: 100% 100%;
|
|
|
|
|
}
|
|
|
|
|
}
|
2025-03-14 16:27:50 +08:00
|
|
|
|
.bag {
|
|
|
|
|
width: 56rpx;
|
|
|
|
|
height: 56rpx;
|
|
|
|
|
border-radius: 50%;
|
|
|
|
|
margin: 0 auto;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.bag1 {
|
|
|
|
|
background: #ff4a48;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.bag2 {
|
|
|
|
|
background: #ff992f;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.bag3 {
|
|
|
|
|
background: #009ee0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.bag4 {
|
|
|
|
|
background: #00d5d5;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.bag5 {
|
|
|
|
|
background: #28ccb0;
|
|
|
|
|
}
|
|
|
|
|
</style>
|