286 lines
6.0 KiB
Vue
286 lines
6.0 KiB
Vue
<template>
|
|
<view class="container">
|
|
<view
|
|
class="person"
|
|
@click="checkUserInfo()"
|
|
>
|
|
<u-image
|
|
width="140"
|
|
height="140"
|
|
shape="circle"
|
|
:src="userInfo.face || '/static/missing-face.png'"
|
|
mode=""
|
|
></u-image>
|
|
<view class="user-name">
|
|
{{ userInfo.id ? userInfo.nickName || '' : '暂未登录' }}
|
|
</view>
|
|
<u-icon
|
|
color="#ccc"
|
|
name="arrow-right"
|
|
></u-icon>
|
|
</view>
|
|
<!-- #ifdef MP-WEIXIN -->
|
|
<view style="height: 20rpx; width: 100%"></view>
|
|
<!-- #endif -->
|
|
<u-cell-group :border="false">
|
|
<!-- #ifdef APP-PLUS -->
|
|
<u-cell-item
|
|
title="清除缓存"
|
|
:value="fileSizeString"
|
|
@click="clearCache"
|
|
></u-cell-item>
|
|
<!-- #endif -->
|
|
<u-cell-item
|
|
title="安全中心"
|
|
@click="navigateTo('/pages/mine/set/securityCenter/securityCenter')"
|
|
></u-cell-item>
|
|
<u-cell-item
|
|
title="意见反馈"
|
|
@click="navigateTo('/pages/mine/set/feedBack')"
|
|
></u-cell-item>
|
|
<!-- #ifndef H5 -->
|
|
<!-- #endif -->
|
|
<u-cell-item
|
|
:title="`关于我们`"
|
|
@click="navigateTo('/pages/mine/set/editionIntro')"
|
|
></u-cell-item>
|
|
<u-cell-item
|
|
title="用户注销"
|
|
v-if="userInfo.id"
|
|
@click="logoff"
|
|
></u-cell-item>
|
|
</u-cell-group>
|
|
<view
|
|
class="submit"
|
|
@click="showModalDialog"
|
|
>
|
|
{{ userInfo.id ? '退出登录' : '返回登录' }}
|
|
</view>
|
|
<u-modal
|
|
show-cancel-button
|
|
v-model="quitShow"
|
|
@confirm="confirm"
|
|
:confirm-color="lightColor"
|
|
:async-close="true"
|
|
:content="userInfo.id ? '确定要退出登录么?' : '确定要返回登录么?'"
|
|
></u-modal>
|
|
</view>
|
|
</template>
|
|
|
|
<script>
|
|
import { logout } from '@/api/login';
|
|
import storage from '@/utils/storage.js';
|
|
import config from '@/config/config';
|
|
import { clearIm } from '@/utils/handleim.js';
|
|
export default {
|
|
data() {
|
|
return {
|
|
config,
|
|
lightColor: this.$lightColor,
|
|
quitShow: false,
|
|
isCertificate: false,
|
|
userInfo: {},
|
|
fileSizeString: '0B'
|
|
};
|
|
},
|
|
|
|
methods: {
|
|
navigateTo(url) {
|
|
if (url == '/pages/set/securityCenter/securityCenter') {
|
|
url += `?mobile=${this.userInfo.mobile}`;
|
|
}
|
|
uni.navigateTo({
|
|
url: url
|
|
});
|
|
},
|
|
clear() {
|
|
storage.setRefreshVlogIndex('1'); //需要刷新
|
|
storage.setHasLogin(false);
|
|
storage.setAccessToken('');
|
|
storage.setRefreshToken('');
|
|
storage.setUuid('');
|
|
storage.setUserInfo({});
|
|
// 清理vlog信息
|
|
storage.setVlogToken('');
|
|
storage.setVlogUserInfo(null);
|
|
// 清除初始化数据内容
|
|
storage.setRefreshVlogIndex('1'); //需要刷新
|
|
// 退出im登录
|
|
clearIm();
|
|
this.$options.filters.navigateToLogin('redirectTo');
|
|
},
|
|
|
|
/**
|
|
* 用户注销
|
|
*/
|
|
logoff() {
|
|
this.$options.filters.logoff();
|
|
},
|
|
|
|
/**
|
|
* 确认退出
|
|
* 清除缓存重新登录
|
|
*/
|
|
async confirm() {
|
|
await logout();
|
|
this.clear();
|
|
},
|
|
|
|
/**
|
|
* 显示退出登录对话框
|
|
*/
|
|
showModalDialog() {
|
|
this.quitShow = true;
|
|
},
|
|
|
|
/**
|
|
* 读取当前缓存
|
|
*/
|
|
getCacheSize() {
|
|
//获取缓存数据
|
|
let that = this;
|
|
plus.cache.calculate(function (size) {
|
|
let sizeCache = parseInt(size);
|
|
if (sizeCache == 0) {
|
|
that.fileSizeString = '0B';
|
|
} else if (sizeCache < 1024) {
|
|
that.fileSizeString = sizeCache + 'B';
|
|
} else if (sizeCache < 1048576) {
|
|
that.fileSizeString = (sizeCache / 1024).toFixed(2) + 'KB';
|
|
} else if (sizeCache < 1073741824) {
|
|
that.fileSizeString = (sizeCache / 1048576).toFixed(2) + 'MB';
|
|
} else {
|
|
that.fileSizeString = (sizeCache / 1073741824).toFixed(2) + 'GB';
|
|
}
|
|
});
|
|
},
|
|
|
|
/**
|
|
* 点击用户详情
|
|
* 判断当前是否进入用户中心
|
|
*/
|
|
checkUserInfo() {
|
|
if (this.$options.filters.isLogin('auth')) {
|
|
this.navigateTo('/pages/mine/set/personMsg');
|
|
} else {
|
|
uni.showToast({
|
|
title: '当前暂无用户请登录后重试',
|
|
duration: 2000,
|
|
icon: 'none'
|
|
});
|
|
}
|
|
},
|
|
|
|
/**
|
|
* 清除当前设备缓存
|
|
*/
|
|
clearCache() {
|
|
//清理缓存
|
|
let that = this;
|
|
let os = plus.os.name;
|
|
if (os == 'Android') {
|
|
let main = plus.android.runtimeMainActivity();
|
|
let sdRoot = main.getCacheDir();
|
|
let files = plus.android.invoke(sdRoot, 'listFiles');
|
|
let len = files.length;
|
|
for (let i = 0; i < len; i++) {
|
|
let filePath = '' + files[i]; // 没有找到合适的方法获取路径,这样写可以转成文件路径
|
|
plus.io.resolveLocalFileSystemURL(
|
|
filePath,
|
|
function (entry) {
|
|
if (entry.isDirectory) {
|
|
entry.removeRecursively(
|
|
function (entry) {
|
|
//递归删除其下的所有文件及子目录
|
|
uni.showToast({
|
|
title: '缓存清理完成',
|
|
duration: 2000,
|
|
icon: 'none'
|
|
});
|
|
that.getCacheSize(); // 重新计算缓存
|
|
},
|
|
function (e) {}
|
|
);
|
|
} else {
|
|
entry.remove();
|
|
}
|
|
},
|
|
function (e) {
|
|
uni.showToast({
|
|
title: '文件路径读取失败',
|
|
duration: 2000,
|
|
icon: 'none'
|
|
});
|
|
}
|
|
);
|
|
}
|
|
} else {
|
|
// ios
|
|
plus.cache.clear(function () {
|
|
uni.showToast({
|
|
title: '缓存清理完成',
|
|
duration: 2000,
|
|
icon: 'none'
|
|
});
|
|
that.getCacheSize();
|
|
});
|
|
}
|
|
}
|
|
},
|
|
onShow() {
|
|
this.userInfo = this.$options.filters.isLogin();
|
|
// #ifdef APP-PLUS
|
|
this.getCacheSize();
|
|
// #endif
|
|
}
|
|
};
|
|
</script>
|
|
|
|
<style lang="scss" scoped>
|
|
.submit {
|
|
height: 90rpx;
|
|
line-height: 90rpx;
|
|
text-align: center;
|
|
margin-top: 90rpx;
|
|
background: #fff;
|
|
width: 100%;
|
|
margin: 0 auto;
|
|
color: $main-color;
|
|
}
|
|
.person {
|
|
height: 208rpx;
|
|
display: flex;
|
|
padding: 0 20rpx;
|
|
font-size: $font-base;
|
|
justify-content: space-between;
|
|
align-items: center;
|
|
margin-bottom: 20rpx;
|
|
.user-name {
|
|
width: 500rpx;
|
|
overflow: hidden;
|
|
|
|
text-overflow: ellipsis;
|
|
|
|
white-space: nowrap;
|
|
margin-left: 30rpx;
|
|
line-height: 2em;
|
|
font-size: 34rpx;
|
|
}
|
|
}
|
|
.u-cell {
|
|
height: 110rpx;
|
|
/* line-height: 110rpx; */
|
|
padding: 0 20rpx;
|
|
align-items: center;
|
|
color: #333333;
|
|
}
|
|
|
|
/deep/ .u-cell__value {
|
|
color: #cccccc !important;
|
|
}
|
|
|
|
/deep/ .u-cell__right-icon-wrap {
|
|
color: #cccccc !important;
|
|
}
|
|
</style>
|