app/pages/tabbar/user/my.vue
2025-05-02 17:32:03 +08:00

366 lines
8.6 KiB
Vue
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<template>
<view class="user">
<!-- 个人信息 -->
<view class="status_bar">
<!-- 这里是状态栏 -->
</view>
<view class="header">
<view @click="nav()" :style="{ zIndex: 9999999, padding: '5px' }">
返回
</view>
<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>
<view class="head-2" v-else>
<view class="user-name">登录/注册</view>
</view>
</view>
<!-- <u-icon
style="display: flex; align-items: flex-start"
name="arrow-right"
></u-icon> -->
</view>
<!-- 积分优惠券关注 -->
<div class="pointBox box" >
<u-row text-align="center" gutter="16" class="point">
<!-- <u-col
text-align="center"
span="4"
@click="navigateTo('/pages/mine/deposit/operation')"
>
<view>预存款</view>
<view class="money">{{ walletNum | unitPrice }}</view>
</u-col> -->
<u-col
text-align="center"
span="4"
@click="navigateTo('/pages/cart/coupon/myCoupon')"
>
<view>优惠券</view>
<view>{{ couponNum || 0 }}</view>
</u-col>
<u-col
text-align="center"
span="4"
@click="navigateTo('/pages/mine/myTracks')"
>
<view>足迹</view>
<view>{{ footNum || 0 }}</view>
</u-col>
</u-row>
<!-- 我的订单代付款 -->
<view class="order">
<view
class="order-item"
@click="navigateTo('/pages/order/myOrder?status=0')"
>
<div class="bag bag1">
<u-icon name="order" size="35" color="#fff"></u-icon>
</div>
<view>我的订单</view>
</view>
<view
class="order-item"
@click="navigateTo('/pages/order/myOrder?status=1')"
>
<div class="bag bag2">
<u-icon name="bag-fill" size="35" color="#fff"></u-icon>
</div>
<view>待付款</view>
</view>
<view
class="order-item"
@click="navigateTo('/pages/order/myOrder?status=3')"
>
<div class="bag bag3">
<u-icon name="car-fill" size="35" color="#fff"></u-icon>
</div>
<view>待收货</view>
</view>
<view
class="order-item"
@click="navigateTo('/pages/order/evaluate/myEvaluate')"
>
<div class="bag bag4">
<u-icon name="star-fill" size="35" color="#fff"></u-icon>
</div>
<view>待评价</view>
</view>
<view
class="order-item"
@click="navigateTo('/pages/order/afterSales/afterSales')"
>
<div class="bag bag5">
<u-icon name="server-fill" size="35" color="#fff"></u-icon>
</div>
<view>售后服务</view>
</view>
</view>
</div>
<!-- 常用工具 -->
<tool :userInfo="userInfo" v-if="userInfo.id != undefined" ref="tool" />
</view>
</template>
<script>
import tool from "@/pages/tabbar/user/utils/tool.vue";
import { getCouponsNum, getFootprintNum } from "@/api/members.js";
import { getUserWallet } from "@/api/members";
import Views from "../home/views.vue";
import { getUserInfo } from "@/api/members";
export default {
components: {
tool,
},
data() {
return {
coverTransform: "translateY(0px)",
coverTransition: "0s",
moving: false,
userInfo: {},
couponNum: "",
footNum: "",
walletNum: "",
};
},
onLoad() {
this.userInfo = this.$options.filters.isLogin();
this.getUserOrderNum();
},
onShow() {
this.userInfo = this.$options.filters.isLogin();
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
mounted() {
this.userInfo = this.$options.filters.isLogin();
this.getUserOrderNum();
},
methods: {
nav() {
uni.switchTab({
url: `/pages/me/me`,
});
},
/**
* 统一跳转接口,拦截未登录路由
* navigator标签现在默认没有转场动画所以用view
*/
navigateTo(url) {
uni.navigateTo({
url,
});
},
userDetail() {
this.userInfo.id
? this.navigateTo("/pages/mine/set/personMsg")
: this.$options.filters.navigateToLogin();
},
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;
.headercon {
display: flex;
justify-content: space-between;
}
.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;
margin-left: 15px;
margin-top: 16px;
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);
}
.point {
text-align: center;
height: 160rpx;
justify-content: space-around !important;
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;
}
.user-logn {
display: flex;
align-items: center;
margin: 15px 15px 0px 0px;
font-size: 15px;
.mong {
width: 1rem;
height: 1rem;
background: url("@/static/mon.png") no-repeat;
background-size: 100% 100%;
}
}
.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>