Files
jurong_circle_front_app/pages/my/my.vue

399 lines
8.1 KiB
Vue
Raw Normal View History

2025-09-12 17:23:03 +08:00
<template>
2025-09-16 16:05:34 +08:00
<view class="my-container">
2025-10-24 16:55:40 +08:00
<scroll-view scroll-y="true" style="height: 100%;" :refresher-threshold="50" :refresher-triggered="isRefresher"
refresher-background="transparent" refresher-enabled="true" @refresherrefresh="reflash">
<view v-if="user!=null">
<view class="header">
<view class="header-user">
<view class="header-avatar">
<u-avatar :src="getImageUrl(user.avatar)"></u-avatar>
</view>
<view class="header-username u-m-l-20">
{{user.real_name}}
2025-10-23 10:18:06 +08:00
<view>
<u-tag class="u-m-r-20 u-m-t-10" :text="Math.abs(user.balance)" type="warning"></u-tag>
<u-tag :text="user.points"></u-tag>
</view>
</view>
</view>
<view class="header-setting">
<image src="/static/icon/Settings.png" style="width: 100%;height: 100%;" mode=""></image>
</view>
</view>
<view class="statistics">
<view class="item">
<view class="count">
111
</view>
<view class="title">
积分
</view>
</view>
<view class="item">
<view class="count">
5
</view>
<view class="title">
优惠券
</view>
</view>
<view class="item">
<view class="count">
10
</view>
<view class="title">
我的兑换
</view>
</view>
2025-10-23 10:21:37 +08:00
<view class="item" @click="shop_car">
<view class="count">
2025-10-24 16:55:40 +08:00
{{totalCartCount}}
</view>
<view class="title">
2025-10-23 10:21:37 +08:00
购物车
</view>
</view>
</view>
2025-09-28 09:21:15 +08:00
<view class="open-vip">
<view class="text-vip">
<view class="title">
vip专享
</view>
<view class="sub-title">
立享价值1000元权益
</view>
</view>
<u-button class="btn-vip" hover-class="none" :hair-line="false">298元开通</u-button>
</view>
<view class="white-block">
<view class="item">
<view class="title">
会员权益
</view>
<view class="sub-title">
领取升级福利
</view>
</view>
<view class="item">
<view class="title">
积分商城
</view>
<view class="sub-title">
赚积分享福利
</view>
</view>
</view>
2025-10-16 17:23:57 +08:00
<view class="menu-list">
2025-10-23 10:21:37 +08:00
<view class="menu-item" @click="navigatorSrc">
<u-image src="/static/my/01.png" width="40%" mode="widthFix"></u-image>
<view class="menu-text">
领券中心
</view>
</view>
<view class="menu-item">
<u-image src="/static/my/02.png" width="40%" mode="widthFix"></u-image>
<view class="menu-text">
积分兑换
</view>
</view>
<view class="menu-item">
<u-image src="/static/my/03.png" width="40%" mode="widthFix"></u-image>
<view class="menu-text">
我的客户
</view>
</view>
2025-10-24 16:44:01 +08:00
<view class="menu-item" @click="navigatoCommonProblem">
<u-image src="/static/my/04.png" width="40%" mode="widthFix"></u-image>
<view class="menu-text">
常见问题
</view>
</view>
<view class="menu-item">
<u-image src="/static/my/05.png" width="40%" mode="widthFix"></u-image>
<view class="menu-text">
充值中心
</view>
</view>
2025-10-16 17:23:57 +08:00
<view class="menu-item" @click="handleShippingAddress">
<u-image src="/static/my/06.png" width="40%" mode="widthFix"></u-image>
<view class="menu-text">
收货地址
</view>
</view>
2025-10-24 15:10:06 +08:00
<view class="menu-item" @click="handleOrder">
<u-image src="/static/my/07.png" width="40%" mode="widthFix"></u-image>
<view class="menu-text">
我的订单
</view>
</view>
<view class="menu-item">
<u-image src="/static/my/08.png" width="40%" mode="widthFix"></u-image>
<view class="menu-text">
成为代理
</view>
</view>
</view>
<u-button class="u-m-t-20" @click="loginOut">退出登录</u-button>
2025-10-24 16:02:33 +08:00
<view class="box-div">
</view>
</view>
</scroll-view>
2025-09-16 16:05:34 +08:00
</view>
2025-09-15 11:34:07 +08:00
<Tabbar></Tabbar>
2025-09-12 17:23:03 +08:00
</template>
<script setup lang="ts">
2025-09-28 09:21:15 +08:00
import { onMounted, ref } from 'vue';
import { getImageUrl } from '../../util/common';
2025-10-23 10:18:06 +08:00
import {
authAPI
} from '../../api/auth.js';
import {
onShow
2025-10-24 16:55:40 +08:00
} from '@dcloudio/uni-app';
import {
mallAPI
} from '../../api/mall.js'
2025-09-28 09:21:15 +08:00
const user = ref()
2025-10-24 16:55:40 +08:00
2025-10-24 16:02:33 +08:00
const isRefresher = ref(false)
const reflash = () => {
isRefresher.value = true
loadData()
}
2025-09-12 17:23:03 +08:00
2025-10-16 17:23:57 +08:00
const handleShippingAddress = () => {
uni.navigateTo({
url: '/pages/my/shippingAddress'
})
}
2025-10-24 15:10:06 +08:00
const handleOrder = () => {
uni.navigateTo({
url: '/pages/my/order'
})
}
2025-10-24 16:55:40 +08:00
const totalCartCount = ref(0)
2025-10-23 10:18:06 +08:00
const loadData = () => {
authAPI.me().then(res => {
user.value = res.user
2025-10-24 16:02:33 +08:00
}).finally(() => {
isRefresher.value = false
2025-10-23 10:18:06 +08:00
})
2025-10-24 16:55:40 +08:00
mallAPI.getCartList().then(res => {
totalCartCount.value = res.data.items.length
})
2025-10-23 10:18:06 +08:00
}
onShow(() => {
loadData()
})
2025-09-28 09:21:15 +08:00
onMounted(() => {
2025-09-16 16:05:34 +08:00
})
2025-09-28 09:21:15 +08:00
const loginOut = () => {
uni.removeStorageSync("token")
uni.redirectTo({
url: '/pages/login/login'
})
}
2025-10-24 15:10:06 +08:00
const navigatorSrc = () => {
uni.navigateTo({
url: '/pages/my/getCoupons'
})
}
//购物车跳转
const shop_car = () => {
uni.navigateTo({
url: '/pages/my/car'
})
}
2025-10-24 16:44:01 +08:00
const navigatoCommonProblem = () => {
uni.navigateTo({
url: '/pages/my/commonProblem'
})
}
2025-09-16 16:05:34 +08:00
</script>
2025-09-12 17:23:03 +08:00
2025-09-16 16:05:34 +08:00
<style scoped lang="scss">
.my-container {
width: 100%;
height: 100vh;
background: linear-gradient(180deg, #E3E8FF 0%, #E8EAF4 100%);
background-blend-mode: lighten;
padding: 60rpx 20rpx;
.header {
display: flex;
width: 100%;
justify-content: flex-end;
.header-user {
flex: 1;
display: flex;
align-items: center;
height: 170rpx;
padding-left: 60rpx;
}
.header-setting {
width: 52rpx;
height: 52rpx;
}
}
.statistics {
display: flex;
font-family: SF Pro;
font-weight: 510;
font-style: Medium;
font-size: 32rpx;
leading-trim: NONE;
line-height: 48rpx;
letter-spacing: 0%;
margin: 40rpx 0 20rpx;
.item {
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
width: 25%;
}
}
.open-vip {
display: flex;
justify-content: space-between;
background: #2B2B2B;
align-items: center;
padding: 24rpx 0;
border-top-left-radius: 24rpx;
border-top-right-radius: 24rpx;
.text-vip {
margin-left: 32rpx;
display: flex;
flex-direction: column;
color: #FFDD9E;
justify-content: flex-start;
.title {
font-family: SF Pro;
font-weight: 700;
font-style: Bold;
font-size: 32rpx;
leading-trim: NONE;
line-height: 48rpx;
letter-spacing: 0%;
}
.sub-title {
font-family: SF Pro;
font-weight: 274;
font-style: Light;
font-size: 32rpx;
leading-trim: NONE;
line-height: 48rpx;
letter-spacing: 0%;
}
}
.btn-vip {
margin-right: 42rpx;
width: 180rpx;
height: 56rpx;
border: none;
border-radius: 198rpx;
background: linear-gradient(90deg, #FFCC5E 0%, #FFE9BA 47.27%, #FFCC5E 100%);
}
}
.white-block {
margin-top: 44rpx;
display: flex;
justify-content: space-between;
.item {
width: 48%;
background: #F5F8FF;
display: flex;
flex-direction: column;
padding: 30rpx 32rpx;
border-radius: 24rpx;
.title {
font-family: SF Pro;
font-weight: 700;
font-style: Bold;
font-size: 32rpx;
leading-trim: NONE;
line-height: 48rpx;
letter-spacing: 0%;
}
.sub-title {
margin-top: 14rpx;
font-family: Work Sans;
font-weight: 400;
font-size: 26rpx;
leading-trim: NONE;
line-height: 100%;
letter-spacing: -2%;
color: #8C8C8C;
}
}
}
2025-10-16 17:23:57 +08:00
.menu-list {
background: #F5F8FF;
margin-top: 20rpx;
padding: 20rpx 0 0 0;
border-radius: 24rpx;
display: flex;
flex-wrap: wrap;
2025-10-16 17:23:57 +08:00
.menu-item {
display: flex;
flex-direction: column;
align-items: center;
width: 25%;
margin-bottom: 20rpx;
2025-10-16 17:23:57 +08:00
.menu-text {
font-family: Work Sans;
font-weight: 400;
font-style: Regular;
font-size: 20rpx;
leading-trim: NONE;
line-height: 100%;
letter-spacing: -2%;
}
}
}
2025-10-24 16:02:33 +08:00
.box-div {
padding: 60rpx 0rpx;
}
}
2025-09-16 16:05:34 +08:00
</style>