ucenter.vue 10.1 KB
Newer Older
L
213  
linju 已提交
1
<template>
2
	<view class="center">
3
		<uni-sign-in ref="signIn"></uni-sign-in>
4 5 6 7 8
		<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>
芊里 已提交
9
			<view class="logo-title">
10
				<text class="uer-name">{{userInfo.nickname||userInfo.username||userInfo.mobile||'未登录'}}</text>
L
213  
linju 已提交
11
			</view>
L
123  
linju 已提交
12
		</view>
13
		<uni-grid class="grid" :column="4" :showBorder="false" :square="true">
14
			<uni-grid-item class="item" v-for="(item,index) in gridList" @click.native="tapGrid(index)" :key="index">
15
				<uni-icons class="icon" color="#007AFF" :type="item.icon" size="26"></uni-icons>
芊里 已提交
16
				<text class="text">{{item.text}}</text>
L
213  
linju 已提交
17 18
			</uni-grid-item>
		</uni-grid>
19 20
		<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"
21 22
				:clickable="true" :to="item.to" @click="ucenterListClick(item)" :show-extra-icon="true"
				:extraIcon="{type:item.icon,color:'#999'}">
L
123  
linju 已提交
23 24 25 26
				<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>
芊里 已提交
27
			</uni-list-item>
DCloud_JSON's avatar
DCloud_JSON 已提交
28
		</uni-list>
L
213  
linju 已提交
29 30 31 32 33 34 35 36
	</view>
</template>

<script>
	import {
		mapGetters,
		mapMutations
	} from 'vuex';
芊里 已提交
37 38
	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';
39
	import uniShare from 'uni_modules/uni-share/js_sdk/uni-share.js';
芊里 已提交
40 41

	const db = uniCloud.database();
L
213  
linju 已提交
42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62
	export default {
		data() {
			return {
				gridList: [{
						"text": "文字1",
						"icon": "chat"
					},
					{
						"text": "文字2",
						"icon": "cloud-upload"
					},
					{
						"text": "文字3",
						"icon": "contact"
					},
					{
						"text": "文字4",
						"icon": "download"
					}
				],
				ucenterList: [
63 64 65 66 67 68
					[
						{
							"title": '签到有奖',
							"event": 'signIn',
							"icon": "compose"
						},
芊里 已提交
69 70
						// #ifdef APP-PLUS
						{
71
							"title": '去评分',
72
							"event": 'gotoMarket',
73
							"icon": "hand-thumbsup"
芊里 已提交
74
						},
DCloud_JSON's avatar
DCloud_JSON 已提交
75
						//#endif
L
123  
linju 已提交
76
						{
77
							"title": '阅读过的文章',
78
							"to": '/pages/ucenter/read-news-log/read-news-log',
79
							"icon": "flag"
80
						},
DCloud_JSON's avatar
DCloud_JSON 已提交
81
						{
82 83
							"title": '我的积分',
							"to": '',
84
							"event": 'getScore',
85 86
							"icon": "paperplane"
						}
87
						// #ifdef APP-PLUS
88 89 90 91 92 93
						,{
							"title": '分销推荐',
							"event": 'share',
							"icon": "redo"
						}
						// #endif
芊里 已提交
94
					],
L
213  
linju 已提交
95
					[{
96
						"title": '问题与反馈',
97
						"to": '/uni_modules/uni-feedback/pages/uni-feedback/uni-feedback',
98
						"icon": "help"
DCloud_JSON's avatar
DCloud_JSON 已提交
99
					}, {
100
						"title": '设置',
101
						"to": '/pages/ucenter/settings/settings',
102
						"icon": "gear"
103 104
					}],
					[{
105
						"title": '关于',
106
						"to": '/pages/ucenter/about/about',
107
						"icon": "info"
L
123  
linju 已提交
108
					}]
109 110 111 112 113 114 115 116 117 118 119
				],
				listStyles: {
					"height": "150rpx", // 边框高度
					"width": "150rpx", // 边框宽度
					"border": { // 如果为 Boolean 值,可以控制边框显示与否
						"color": "#eee", // 边框颜色
						"width": "1px", // 边框宽度
						"style": "solid", // 边框样式
						"radius": "100%" // 边框圆角,支持百分比
					}
				}
L
213  
linju 已提交
120 121
			}
		},
DCloud_JSON's avatar
DCloud_JSON 已提交
122
		onLoad() {
芊里 已提交
123
			//#ifdef APP-PLUS
124
			this.ucenterList[this.ucenterList.length - 2].unshift({
芊里 已提交
125 126
				title: '检查更新',
				rightText: this.appVersion.version + '-' + this.appVersion.versionCode,
127
				event: 'checkVersion',
128
				icon: 'loop',
芊里 已提交
129 130
				showBadge: this.appVersion.hasNew
			})
芊里 已提交
131
			//#endif
L
123  
linju 已提交
132
		},
L
213  
linju 已提交
133 134 135 136
		computed: {
			...mapGetters({
				userInfo: 'user/info',
				login: 'user/hasLogin'
芊里 已提交
137 138
			})
			// #ifdef APP-PLUS
139 140
			,
			appVersion() {
芊里 已提交
141 142
				return getApp().appVersion
			}
DCloud_JSON's avatar
DCloud_JSON 已提交
143
			// #endif
144 145
			,
			appConfig() {
DCloud_JSON's avatar
DCloud_JSON 已提交
146
				return getApp().globalData.config
DCloud_JSON's avatar
DCloud_JSON 已提交
147
			}
L
213  
linju 已提交
148
		},
149 150 151
		methods: {
			...mapMutations({
				setUserInfo: 'user/login'
152
			}),
L
123  
linju 已提交
153
			toSettings() {
154
				uni.navigateTo({
L
123  
linju 已提交
155
					url: "/pages/ucenter/settings/settings"
156
				})
157 158 159
			},
			signIn(){ 	//签到
				this.$refs.signIn.open()
L
123  
linju 已提交
160
			},
L
213  
linju 已提交
161 162 163 164 165 166 167 168
			/**
			 * 个人中心项目列表点击事件
			 */
			ucenterListClick(item) {
				if (!item.to && item.event) {
					this[item.event]();
				}
			},
芊里 已提交
169
			async checkVersion() {
170 171
				let res = await callCheckVersion()
				console.log(res);
172 173 174
				if (res.result.code > 0) {
					checkUpdate()
				} else {
175 176 177 178
					uni.showToast({
						title: res.result.message,
						icon: 'none'
					});
DCloud_JSON's avatar
123  
DCloud_JSON 已提交
179
				}
L
213  
linju 已提交
180
			},
181 182
			toUserInfo() {
				uni.navigateTo({
DCloud_JSON's avatar
DCloud_JSON 已提交
183
					url: '/pages/ucenter/userinfo/userinfo'
184
				})
185
			},
L
123  
linju 已提交
186
			tapGrid(index) {
187
				uni.showToast({
L
123  
linju 已提交
188
					title: '你点击了,第' + (index + 1) + '',
189 190
					icon: 'none'
				});
191 192 193 194
			},
			/**
			 * 去应用市场评分
			 */
芊里 已提交
195
			gotoMarket() {
DCloud_JSON's avatar
DCloud_JSON 已提交
196
				// #ifdef APP-PLUS
197 198
				if (uni.getSystemInfoSync().platform == "ios") {
					// 这里填写appstore应用id
199
					let appstoreid = this.appConfig.marketId.ios; // 'id1417078253';
L
123  
linju 已提交
200
					plus.runtime.openURL("itms-apps://" + 'itunes.apple.com/cn/app/wechat/' + appstoreid + '?mt=8');
201 202 203
				}
				if (uni.getSystemInfoSync().platform == "android") {
					var Uri = plus.android.importClass("android.net.Uri");
DCloud_JSON's avatar
DCloud_JSON 已提交
204
					var uri = Uri.parse("market://details?id=" + this.appConfig.marketId.android);
L
123  
linju 已提交
205 206 207 208
					var Intent = plus.android.importClass('android.content.Intent');
					var intent = new Intent(Intent.ACTION_VIEW, uri);
					var main = plus.android.runtimeMainActivity();
					main.startActivity(intent);
209 210
				}
				// #endif
芊里 已提交
211 212 213 214 215 216 217 218 219 220 221 222
			},
			/**
			 * 获取积分信息
			 */
			getScore() {
				if (!this.userInfo) return uni.showToast({
					title: '请登录后查看积分',
					icon: 'none'
				});
				uni.showLoading({
					mask: true
				})
223 224
				db.collection("uni-id-scores").where('"user_id" == $env.uid').field('score,balance').get().then((res) => {
					uni.hideLoading()
225
					console.log(res);
芊里 已提交
226
					const data = res.result.data[0];
227
					let msg = '';
228
					msg = data ? ('当前积分为' + data.score) : '当前无积分';
芊里 已提交
229
					uni.showToast({
芊里 已提交
230
						title: msg,
芊里 已提交
231 232 233
						icon: 'none'
					});
				})
234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255
			},
			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 +
256
							`/#/pages/ucenter/invite/invite?code=uniInvitationCode:${myInviteCode}`,
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 299 300 301 302 303 304 305 306
						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 已提交
307 308 309 310 311 312 313 314 315 316
			}
		}
	}
</script>

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

L
213  
linju 已提交
318 319 320 321 322 323 324
	/* #endif*/

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

L
213  
linju 已提交
326 327
	.userInfo {
		width: 750rpx;
328
		padding: 20rpx;
L
123  
linju 已提交
329
		padding-top: 50px;
330
		background-image: url(../../static/uni-center/headers.png);
L
213  
linju 已提交
331
		flex-direction: column;
L
213  
linju 已提交
332 333
		align-items: center;
	}
334

L
213  
linju 已提交
335
	.logo-img {
L
213  
linju 已提交
336 337
		width: 150rpx;
		height: 150rpx;
338
		border-radius: 150rpx;
L
213  
linju 已提交
339
	}
340

L
213  
linju 已提交
341 342 343 344 345 346 347 348
	.logo-title {
		flex: 1;
		align-items: center;
		justify-content: space-between;
		flex-direction: row;
	}

	.uer-name {
349 350
		height: 100rpx;
		line-height: 100rpx;
L
213  
linju 已提交
351
		font-size: 38rpx;
L
213  
linju 已提交
352 353
		color: #FFFFFF;
	}
354

355
	.center-list {
L
213  
linju 已提交
356 357 358
		margin-bottom: 30rpx;
		background-color: #f9f9f9;
	}
359

L
213  
linju 已提交
360
	.center-list-cell {
361
		width: 750rpx;
L
213  
linju 已提交
362 363 364
		background-color: #007AFF;
		height: 40rpx;
	}
365

L
123  
linju 已提交
366
	.grid {
367
		background-color: #FFFFFF;
DCloud_JSON's avatar
DCloud_JSON 已提交
368
		margin-bottom: 6px;
L
213  
linju 已提交
369
	}
L
123  
linju 已提交
370

L
213  
linju 已提交
371
	.uni-grid .text {
372
		font-size: 30rpx;
DCloud_JSON's avatar
DCloud_JSON 已提交
373 374
		height: 25px;
		line-height: 25px;
L
213  
linju 已提交
375 376 377 378 379 380
		color: #817f82;
	}

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

L
123  
linju 已提交
383 384 385

	/*修改边线粗细示例*/
	/* #ifndef APP-NVUE */
386
	.center-list /deep/ .uni-list--border:after {
387
		-webkit-transform: scaleY(0.2);
388
		transform: scaleY(0.2);
DCloud_JSON's avatar
DCloud_JSON 已提交
389
		margin-left: 80rpx;
390 391 392 393 394 395 396
	}

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

L
123  
linju 已提交
397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417
	/* #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 */
418
		background-color: #DD524D;
L
123  
linju 已提交
419
	}
420
</style>