ucenter.vue 10.0 KB
Newer Older
L
213  
linju 已提交
1
<template>
2
	<view class="center">
3 4 5 6 7
		<view class="userInfo" @click.capture="toUserInfo">
			<uni-file-picker v-if="userInfo.avatar_file" v-model="userInfo.avatar_file"
				fileMediatype="image" :del-icon="false" return-type="object" :image-styles="listStyles" disablePreview
				disabled />
			<image v-else class="logo-img" src="/static/uni-center/defaultAvatarUrl.png"></image>
芊里 已提交
8
			<view class="logo-title">
9
				<text class="uer-name">{{userInfo.nickname||userInfo.username||userInfo.mobile||'未登录'}}</text>
L
213  
linju 已提交
10
			</view>
L
123  
linju 已提交
11
		</view>
12
		<uni-grid class="grid" :column="4" :showBorder="false" :square="true">
13
			<uni-grid-item class="item" v-for="(item,index) in gridList" @click.native="tapGrid(index)" :key="index">
14
				<uni-icons class="icon" color="#007AFF" :type="item.icon" size="26"></uni-icons>
芊里 已提交
15
				<text class="text">{{item.text}}</text>
L
213  
linju 已提交
16 17
			</uni-grid-item>
		</uni-grid>
18 19
		<uni-list class="center-list" v-for="(sublist , index) in ucenterList" :key="index">
			<uni-list-item v-for="(item,i) in sublist" :title="item.title" link :rightText="item.rightText" :key="i"
20 21
				:clickable="true" :to="item.to" @click="ucenterListClick(item)" :show-extra-icon="true"
				:extraIcon="{type:item.icon,color:'#999'}">
L
123  
linju 已提交
22 23 24 25
				<view v-if="item.showBadge" class="item-footer" slot="footer">
					<text class="item-footer-text">{{item.rightText}}</text>
					<view class="item-footer-badge"></view>
				</view>
芊里 已提交
26
			</uni-list-item>
DCloud_JSON's avatar
DCloud_JSON 已提交
27
		</uni-list>
L
213  
linju 已提交
28 29 30 31 32 33 34 35
	</view>
</template>

<script>
	import {
		mapGetters,
		mapMutations
	} from 'vuex';
芊里 已提交
36 37
	import checkUpdate from '@/uni_modules/uni-upgrade-center-app/utils/check-update';
	import callCheckVersion from '@/uni_modules/uni-upgrade-center-app/utils/call-check-version';
38
	import uniShare from 'uni_modules/uni-share/js_sdk/uni-share.js';
芊里 已提交
39 40

	const db = uniCloud.database();
L
213  
linju 已提交
41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61
	export default {
		data() {
			return {
				gridList: [{
						"text": "文字1",
						"icon": "chat"
					},
					{
						"text": "文字2",
						"icon": "cloud-upload"
					},
					{
						"text": "文字3",
						"icon": "contact"
					},
					{
						"text": "文字4",
						"icon": "download"
					}
				],
				ucenterList: [
芊里 已提交
62 63 64
					[
						// #ifdef APP-PLUS
						{
65
							"title": '去评分',
66
							"event": 'gotoMarket',
67
							"icon": "hand-thumbsup"
芊里 已提交
68
						},
DCloud_JSON's avatar
DCloud_JSON 已提交
69
						//#endif
L
123  
linju 已提交
70
						{
71
							"title": '阅读过的文章',
72
							"to": '/pages/ucenter/read-news-log/read-news-log',
73
							"icon": "flag"
74
						},
DCloud_JSON's avatar
DCloud_JSON 已提交
75
						{
76 77
							"title": '我的积分',
							"to": '',
78
							"event": 'getScore',
79 80
							"icon": "paperplane"
						}
81
						// #ifdef APP-PLUS
82 83 84 85 86 87
						,{
							"title": '分销推荐',
							"event": 'share',
							"icon": "redo"
						}
						// #endif
芊里 已提交
88
					],
L
213  
linju 已提交
89
					[{
90
						"title": '问题与反馈',
91
						"to": '/uni_modules/uni-feedback/pages/uni-feedback/uni-feedback',
92
						"icon": "help"
DCloud_JSON's avatar
DCloud_JSON 已提交
93
					}, {
94
						"title": '设置',
95
						"to": '/pages/ucenter/settings/settings',
96
						"icon": "gear"
97 98
					}],
					[{
99
						"title": '关于',
100
						"to": '/pages/ucenter/about/about',
101
						"icon": "info"
L
123  
linju 已提交
102
					}]
103 104 105 106 107 108 109 110 111 112 113
				],
				listStyles: {
					"height": "150rpx", // 边框高度
					"width": "150rpx", // 边框宽度
					"border": { // 如果为 Boolean 值,可以控制边框显示与否
						"color": "#eee", // 边框颜色
						"width": "1px", // 边框宽度
						"style": "solid", // 边框样式
						"radius": "100%" // 边框圆角,支持百分比
					}
				}
L
213  
linju 已提交
114 115
			}
		},
DCloud_JSON's avatar
DCloud_JSON 已提交
116
		onLoad() {
芊里 已提交
117
			//#ifdef APP-PLUS
118
			this.ucenterList[this.ucenterList.length - 2].unshift({
芊里 已提交
119 120
				title: '检查更新',
				rightText: this.appVersion.version + '-' + this.appVersion.versionCode,
121
				event: 'checkVersion',
122
				icon: 'loop',
芊里 已提交
123 124
				showBadge: this.appVersion.hasNew
			})
芊里 已提交
125
			//#endif
L
123  
linju 已提交
126
		},
L
213  
linju 已提交
127 128 129 130
		computed: {
			...mapGetters({
				userInfo: 'user/info',
				login: 'user/hasLogin'
芊里 已提交
131 132
			})
			// #ifdef APP-PLUS
133 134
			,
			appVersion() {
芊里 已提交
135 136
				return getApp().appVersion
			}
DCloud_JSON's avatar
DCloud_JSON 已提交
137
			// #endif
138 139
			,
			appConfig() {
DCloud_JSON's avatar
DCloud_JSON 已提交
140
				return getApp().globalData.config
DCloud_JSON's avatar
DCloud_JSON 已提交
141
			}
L
213  
linju 已提交
142
		},
143 144 145
		methods: {
			...mapMutations({
				setUserInfo: 'user/login'
146
			}),
L
123  
linju 已提交
147
			toSettings() {
148
				uni.navigateTo({
L
123  
linju 已提交
149
					url: "/pages/ucenter/settings/settings"
150
				})
L
123  
linju 已提交
151
			},
L
213  
linju 已提交
152 153 154 155 156 157 158 159
			/**
			 * 个人中心项目列表点击事件
			 */
			ucenterListClick(item) {
				if (!item.to && item.event) {
					this[item.event]();
				}
			},
芊里 已提交
160
			async checkVersion() {
161 162
				let res = await callCheckVersion()
				console.log(res);
163 164 165
				if (res.result.code > 0) {
					checkUpdate()
				} else {
166 167 168 169
					uni.showToast({
						title: res.result.message,
						icon: 'none'
					});
DCloud_JSON's avatar
123  
DCloud_JSON 已提交
170
				}
L
213  
linju 已提交
171
			},
172 173
			toUserInfo() {
				uni.navigateTo({
DCloud_JSON's avatar
DCloud_JSON 已提交
174
					url: '/pages/ucenter/userinfo/userinfo'
175
				})
176
			},
L
123  
linju 已提交
177
			tapGrid(index) {
178
				uni.showToast({
L
123  
linju 已提交
179
					title: '你点击了,第' + (index + 1) + '',
180 181
					icon: 'none'
				});
182 183 184 185
			},
			/**
			 * 去应用市场评分
			 */
芊里 已提交
186
			gotoMarket() {
DCloud_JSON's avatar
DCloud_JSON 已提交
187
				// #ifdef APP-PLUS
188 189
				if (uni.getSystemInfoSync().platform == "ios") {
					// 这里填写appstore应用id
190
					let appstoreid = this.appConfig.marketId.ios; // 'id1417078253';
L
123  
linju 已提交
191
					plus.runtime.openURL("itms-apps://" + 'itunes.apple.com/cn/app/wechat/' + appstoreid + '?mt=8');
192 193 194
				}
				if (uni.getSystemInfoSync().platform == "android") {
					var Uri = plus.android.importClass("android.net.Uri");
DCloud_JSON's avatar
DCloud_JSON 已提交
195
					var uri = Uri.parse("market://details?id=" + this.appConfig.marketId.android);
L
123  
linju 已提交
196 197 198 199
					var Intent = plus.android.importClass('android.content.Intent');
					var intent = new Intent(Intent.ACTION_VIEW, uri);
					var main = plus.android.runtimeMainActivity();
					main.startActivity(intent);
200 201
				}
				// #endif
芊里 已提交
202 203 204 205 206 207 208 209 210 211 212 213
			},
			/**
			 * 获取积分信息
			 */
			getScore() {
				if (!this.userInfo) return uni.showToast({
					title: '请登录后查看积分',
					icon: 'none'
				});
				uni.showLoading({
					mask: true
				})
214 215
				db.collection("uni-id-scores").where('user_id == $env.uid').field('score,balance').get().then((res) => {
					console.log(res);
芊里 已提交
216
					const data = res.result.data[0];
217
					let msg = '';
芊里 已提交
218
					msg = data ? ('当前积分为' + data.balance) : '当前无积分';
芊里 已提交
219
					uni.showToast({
芊里 已提交
220
						title: msg,
芊里 已提交
221 222 223 224 225
						icon: 'none'
					});
				}).finally(() => {
					uni.hideLoading()
				})
226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298
			},
			async share() {
				let {result} = await uniCloud.callFunction({
					name: 'uni-id-cf',
					data: {
						action: 'getUserInviteCode'
					}
				})
				console.log(result);
				let myInviteCode = result.myInviteCode || result.userInfo.my_invite_code
				console.log(myInviteCode);
				let {
					appName,
					logo,
					company,
					slogan
				} = this.appConfig.about
				// #ifdef APP-PLUS
				uniShare({
					content: { //公共的分享类型(type)、链接(herf)、标题(title)、summary(描述)、imageUrl(缩略图)
						type: 0,
						href: this.appConfig.h5.url +
							`/#/pages/ucenter/invite/invite?code=${myInviteCode}`,
						title: appName,
						summary: slogan,
						imageUrl: logo + '?x-oss-process=image/resize,m_fill,h_100,w_100' //压缩图片解决,在ios端分享图过大导致的图片失效问题
					},
					menus: [{
							"img": "/static/app-plus/sharemenu/wechatfriend.png",
							"text": "微信好友",
							"share": {
								"provider": "weixin",
								"scene": "WXSceneSession"
							}
						},
						{
							"img": "/static/app-plus/sharemenu/wechatmoments.png",
							"text": "微信朋友圈",
							"share": {
								"provider": "weixin",
								"scene": "WXSenceTimeline"
							}
						},
						{
							"img": "/static/app-plus/sharemenu/weibo.png",
							"text": "微博",
							"share": {
								"provider": "sinaweibo"
							}
						},
						{
							"img": "/static/app-plus/sharemenu/qq.png",
							"text": "QQ",
							"share": {
								"provider": "qq"
							}
						},
						{
							"img": "/static/app-plus/sharemenu/copyurl.png",
							"text": "复制",
							"share": "copyurl"
						},
						{
							"img": "/static/app-plus/sharemenu/more.png",
							"text": "更多",
							"share": "shareSystem"
						}
					],
					cancelText: "取消分享",
				}, e => { //callback
					console.log(e);
				})
				// #endif
L
213  
linju 已提交
299 300 301 302 303 304 305 306 307 308
			}
		}
	}
</script>

<style>
	/* #ifndef APP-PLUS-NVUE */
	page {
		background-color: #f8f8f8;
	}
309

L
213  
linju 已提交
310 311 312 313 314 315 316
	/* #endif*/

	.center {
		flex: 1;
		flex-direction: column;
		background-color: #f8f8f8;
	}
317

L
213  
linju 已提交
318 319
	.userInfo {
		width: 750rpx;
320
		padding: 20rpx;
L
123  
linju 已提交
321
		padding-top: 50px;
322
		background-image: url(../../static/uni-center/headers.png);
L
213  
linju 已提交
323
		flex-direction: column;
L
213  
linju 已提交
324 325
		align-items: center;
	}
326

L
213  
linju 已提交
327
	.logo-img {
L
213  
linju 已提交
328 329
		width: 150rpx;
		height: 150rpx;
330
		border-radius: 150rpx;
L
213  
linju 已提交
331
	}
332

L
213  
linju 已提交
333 334 335 336 337 338 339 340
	.logo-title {
		flex: 1;
		align-items: center;
		justify-content: space-between;
		flex-direction: row;
	}

	.uer-name {
341 342
		height: 100rpx;
		line-height: 100rpx;
L
213  
linju 已提交
343
		font-size: 38rpx;
L
213  
linju 已提交
344 345
		color: #FFFFFF;
	}
346

347
	.center-list {
L
213  
linju 已提交
348 349 350
		margin-bottom: 30rpx;
		background-color: #f9f9f9;
	}
351

L
213  
linju 已提交
352
	.center-list-cell {
353
		width: 750rpx;
L
213  
linju 已提交
354 355 356
		background-color: #007AFF;
		height: 40rpx;
	}
357

L
123  
linju 已提交
358
	.grid {
359
		background-color: #FFFFFF;
DCloud_JSON's avatar
DCloud_JSON 已提交
360
		margin-bottom: 6px;
L
213  
linju 已提交
361
	}
L
123  
linju 已提交
362

L
213  
linju 已提交
363
	.uni-grid .text {
364
		font-size: 30rpx;
DCloud_JSON's avatar
DCloud_JSON 已提交
365 366
		height: 25px;
		line-height: 25px;
L
213  
linju 已提交
367 368 369 370 371 372
		color: #817f82;
	}

	.uni-grid .item /deep/ .uni-grid-item__box {
		justify-content: center;
		align-items: center;
373 374
	}

L
123  
linju 已提交
375 376 377

	/*修改边线粗细示例*/
	/* #ifndef APP-NVUE */
378
	.center-list /deep/ .uni-list--border:after {
379
		-webkit-transform: scaleY(0.2);
380
		transform: scaleY(0.2);
DCloud_JSON's avatar
DCloud_JSON 已提交
381
		margin-left: 80rpx;
382 383 384 385 386 387 388
	}

	.center-list /deep/ .uni-list--border-top,
	.center-list /deep/ .uni-list--border-bottom {
		display: none;
	}

L
123  
linju 已提交
389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409
	/* #endif */
	.item-footer {
		flex-direction: row;
		align-items: center;
	}

	.item-footer-text {
		color: #999;
		font-size: 24rpx;
		padding-right: 10rpx;
	}

	.item-footer-badge {
		width: 20rpx;
		height: 20rpx;
		/* #ifndef APP-NVUE */
		border-radius: 50%;
		/* #endif */
		/* #ifdef APP-NVUE */
		border-radius: 10rpx;
		/* #endif */
410
		background-color: #DD524D;
L
123  
linju 已提交
411
	}
412
</style>