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

<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>