You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
240 lines
6.1 KiB
Vue
240 lines
6.1 KiB
Vue
<template>
|
|
<view class="mine-container" :style="{ height: `${windowHeight}px` }">
|
|
<view class="header-section">
|
|
<view class="flex padding justify-between">
|
|
<view class="flex align-center">
|
|
<view v-if="!avatar" class="cu-avatar xl round bg-white">
|
|
<view class="iconfont icon-people text-gray icon"></view>
|
|
</view>
|
|
<image v-if="avatar" @click="handleToAvatar" :src="avatar" class="cu-avatar xl round" mode="widthFix">
|
|
</image>
|
|
<view v-if="!name" @click="handleToLogin" class="login-tip">
|
|
{{ t('mine.clickLogin') }}
|
|
</view>
|
|
<view v-if="name" @click="handleToInfo" class="user-info">
|
|
<view class="u_title">
|
|
{{ t('mine.username', { name }) }}
|
|
</view>
|
|
</view>
|
|
</view>
|
|
<view @click="handleToInfo" class="flex align-center">
|
|
<text>{{ t('mine.profile') }}</text>
|
|
<view class="iconfont icon-right"></view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
|
|
<view class="content-section">
|
|
<view class="mine-actions grid col-4 text-center">
|
|
<view class="action-item" @click="handleBuilding">
|
|
<view class="iconfont icon-friendfill text-green icon"></view>
|
|
<text class="text">{{ t('mine.feedback') }}</text>
|
|
</view>
|
|
<view class="action-item" @click="handleBuilding">
|
|
<view class="iconfont icon-service text-blue icon"></view>
|
|
<text class="text">{{ t('mine.service') }}</text>
|
|
</view>
|
|
<view class="action-item" @click="handleToPwd">
|
|
<view class="iconfont icon-password text-mauve icon"></view>
|
|
<text class="text">{{ t('mine.changePassword') }}</text>
|
|
</view>
|
|
<view class="action-item" @click="handleLogout">
|
|
<view class="iconfont icon-logout text-red icon"></view>
|
|
<text class="text">{{ t('mine.logout') }}</text>
|
|
</view>
|
|
</view>
|
|
|
|
<view class="menu-list">
|
|
<view class="list-cell list-cell-arrow" @click="handleToEditInfo">
|
|
<view class="menu-item-box">
|
|
<view class="iconfont icon-user menu-icon"></view>
|
|
<view>{{ t('mine.editProfile') }}</view>
|
|
</view>
|
|
</view>
|
|
<view class="list-cell list-cell-arrow" @click="handleHelp">
|
|
<view class="menu-item-box">
|
|
<view class="iconfont icon-help menu-icon"></view>
|
|
<view>{{ t('mine.faq') }}</view>
|
|
</view>
|
|
</view>
|
|
<view class="list-cell list-cell-arrow" @click="handleAbout">
|
|
<view class="menu-item-box">
|
|
<view class="iconfont icon-aixin menu-icon"></view>
|
|
<view>{{ t('mine.about') }}</view>
|
|
</view>
|
|
</view>
|
|
<view class="list-cell list-cell-arrow" @click="handleToSetting">
|
|
<view class="menu-item-box">
|
|
<view class="iconfont icon-setting menu-icon"></view>
|
|
<view>{{ t('mine.appSettings') }}</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
|
|
<view>
|
|
<uni-popup ref="popup" type="dialog">
|
|
<uni-popup-dialog type="info" :cancelText="t('common.close')" :confirmText="t('common.exit')" :title="t('common.notice')" :content="t('common.confirmLogout')"
|
|
@confirm="dialogConfirm" @close="dialogClose">
|
|
</uni-popup-dialog>
|
|
</uni-popup>
|
|
</view>
|
|
</view>
|
|
</template>
|
|
|
|
<script setup>
|
|
import { onUnmounted, ref } from "vue";
|
|
import { onShow } from '@dcloudio/uni-app'
|
|
import { useI18n } from 'vue-i18n'
|
|
import useUserStore from '@/store/modules/user'
|
|
import { onLocaleChange, offLocaleChange, setNavigationTitle } from '@/locales'
|
|
const userStore = useUserStore()
|
|
const name = userStore.name;
|
|
const { t } = useI18n()
|
|
|
|
const avatar = ref(userStore.avatar);
|
|
const windowHeight = ref(uni.getSystemInfoSync().windowHeight - 50);
|
|
const popup = ref(null);
|
|
|
|
uni.$on('refresh', () => {
|
|
avatar.value = userStore.avatar;
|
|
})
|
|
|
|
const updatePageTitle = () => setNavigationTitle('nav.mine')
|
|
onShow(() => {
|
|
updatePageTitle()
|
|
})
|
|
onLocaleChange(updatePageTitle)
|
|
|
|
function handleToInfo() {
|
|
uni.navigateTo({
|
|
url: '/pages_mine/pages/info/index'
|
|
});
|
|
};
|
|
function handleToEditInfo() {
|
|
uni.navigateTo({
|
|
url: '/pages_mine/pages/info/edit'
|
|
});
|
|
};
|
|
function handleToSetting() {
|
|
uni.navigateTo({
|
|
url: '/pages_mine/pages/setting/index'
|
|
});
|
|
};
|
|
function handleToLogin() {
|
|
uni.reLaunch({
|
|
url: '/pages/login'
|
|
});
|
|
};
|
|
function handleToAvatar() {
|
|
uni.navigateTo({
|
|
url: '/pages_mine/pages/avatar/index'
|
|
});
|
|
};
|
|
function handleLogout() {
|
|
popup.value.open();
|
|
};
|
|
function dialogConfirm() {
|
|
userStore.logOut().then(() => {
|
|
uni.reLaunch({
|
|
url: '/pages/login'
|
|
});
|
|
})
|
|
};
|
|
function dialogClose() {
|
|
};
|
|
function handleToPwd() {
|
|
uni.navigateTo({
|
|
url: '/pages_mine/pages/pwd/index'
|
|
});
|
|
}
|
|
function handleHelp() {
|
|
uni.navigateTo({
|
|
url: '/pages_mine/pages/help/index'
|
|
});
|
|
}
|
|
|
|
function handleAbout() {
|
|
uni.navigateTo({
|
|
url: '/pages_mine/pages/about/index'
|
|
});
|
|
}
|
|
function handleBuilding() {
|
|
uni.showToast({
|
|
title: t('common.moduleBuilding'),
|
|
mask: false,
|
|
icon: "none",
|
|
duration: 1000
|
|
});
|
|
}
|
|
|
|
onUnmounted(() => {
|
|
offLocaleChange(updatePageTitle)
|
|
})
|
|
|
|
</script>
|
|
|
|
<style lang="scss">
|
|
page {
|
|
background-color: #f5f6f7;
|
|
}
|
|
|
|
.mine-container {
|
|
width: 100%;
|
|
height: 100%;
|
|
|
|
|
|
.header-section {
|
|
padding: 15px 15px 45px 15px;
|
|
background: linear-gradient(135deg, #1a3a5c 0%, #2d5a87 100%);
|
|
color: white;
|
|
|
|
.login-tip {
|
|
font-size: 18px;
|
|
margin-left: 10px;
|
|
}
|
|
|
|
.cu-avatar {
|
|
border: 2px solid #eaeaea;
|
|
|
|
.icon {
|
|
font-size: 40px;
|
|
}
|
|
}
|
|
|
|
.user-info {
|
|
margin-left: 15px;
|
|
|
|
.u_title {
|
|
font-size: 18px;
|
|
line-height: 30px;
|
|
}
|
|
}
|
|
}
|
|
|
|
.content-section {
|
|
position: relative;
|
|
top: -50px;
|
|
|
|
.mine-actions {
|
|
margin: 15px 15px;
|
|
padding: 20px 0px;
|
|
border-radius: 8px;
|
|
background-color: white;
|
|
|
|
.action-item {
|
|
.icon {
|
|
font-size: 28px;
|
|
}
|
|
|
|
.text {
|
|
display: block;
|
|
font-size: 13px;
|
|
margin: 8px 0px;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
</style>
|