| <template> | |
| 	<view class="login"> | |
| 		<view class="logo"> | |
| 			<image :src="configList.logo_image" mode=""></image> | |
| 		</view> | |
| 		<view class="title"> | |
| 			{{ configList.logo_name }} | |
| 		</view> | |
| 		<view class="title"> | |
| 			申请获取你的头像、昵称 | |
| 		</view> | |
| 
 | |
| 		<!-- #ifdef MP-WEIXIN --> | |
| 		<button class="chooseAvatar" open-type="chooseAvatar" @chooseavatar="onChooseAvatar"> | |
| 			<view class="line"> | |
| 				<view class=""> | |
| 					头像 | |
| 				</view> | |
| 				<view class=""> | |
| 					<image :src="userInfoForm.headImage" v-if="userInfoForm.headImage" style="width: 60rpx;height: 60rpx;" | |
| 						mode=""></image> | |
|  | |
| 					<image src="../static/auth/headImage.png" v-else style="width: 50rpx;height: 50rpx;" mode=""></image> | |
| 				</view> | |
| 			</view> | |
| 		</button> | |
| 		<!-- #endif --> | |
| 		 | |
| 		<!-- #ifdef H5 --> | |
| 		<view class="line"> | |
| 			<view class=""> | |
| 				头像 | |
| 			</view> | |
| 			<view class="h5-avatar-upload"> | |
| 				<uv-upload :fileList="fileList" :maxCount="1" width="60rpx" height="60rpx"  | |
| 					@afterRead="afterRead" @delete="deleteImage"> | |
| 					<image src="../static/auth/headImage.png" style="width: 50rpx;height: 50rpx;" mode=""></image> | |
| 				</uv-upload> | |
| 			</view> | |
| 		</view> | |
| 		<!-- #endif --> | |
| 		<view class="line"> | |
| 			<view class=""> | |
| 				昵称 | |
| 			</view> | |
| 			<view class=""> | |
| 				<input type="nickname" placeholder="请输入昵称" style="text-align: right;" id="nickName" | |
| 					v-model="userInfoForm.nickName" /> | |
| 			</view> | |
| 		</view> | |
| 		<view class="line"> | |
| 			<view class=""> | |
| 				手机号 | |
| 			</view> | |
| 			 | |
| 			<!-- #ifdef MP-WEIXIN --> | |
| 			<view class="" | |
| 			v-if="userInfoForm.phone"> | |
| 				<input placeholder="请输入手机号" style="text-align: right;" | |
| 				disabled | |
| 				v-model="userInfoForm.phone" /> | |
| 			</view> | |
| 			 | |
| 			<view class="" | |
| 			v-else> | |
| 				<button | |
| 				class="getPhoneNumber" | |
| 				open-type="getPhoneNumber"  | |
| 				@getphonenumber="getPhone"> | |
| 					获取电话号码 | |
| 				</button> | |
| 			</view> | |
| 			<!-- #endif --> | |
| 			 | |
| 			<!-- #ifdef H5 --> | |
| 			<view class=""> | |
| 				<input placeholder="请输入手机号" style="text-align: right;" | |
| 				v-model="userInfoForm.phone" /> | |
| 			</view> | |
| 			<!-- #endif --> | |
| 		</view> | |
| 		 | |
| 		 | |
| 		 | |
| 		<view class="btn" @click="submit"> | |
| 			确认 | |
| 		</view> | |
| 	</view> | |
| </template> | |
| 
 | |
| <script> | |
| 	export default { | |
| 		data() { | |
| 			return { | |
| 				userInfoForm: { | |
| 					headImage: '', | |
| 					nickName: '', | |
| 					phone : '', | |
| 				}, | |
| 				// #ifdef H5 | |
| 				fileList: [] | |
| 				// #endif | |
| 			}; | |
| 		}, | |
| 		onShow() {}, | |
| 		onLoad() { | |
| 			this.userInfoForm.phone = this.userInfo.phone || '' | |
| 			this.userInfoForm.nickName = this.userInfo.nickName || '' | |
| 			this.userInfoForm.headImage = this.userInfo.headImage || '' | |
| 			if(this.userInfoForm.headImage){ | |
| 				this.fileList = [{ | |
| 					url: this.userInfoForm.headImage | |
| 				}] | |
| 			} | |
| 		}, | |
| 		computed: {}, | |
| 		methods: { | |
| 			// #ifdef MP-WEIXIN | |
| 			onChooseAvatar(res) { | |
| 				this.$Oss.ossUpload(res.target.avatarUrl) | |
| 				.then(url => { | |
| 					this.userInfoForm.headImage = url | |
| 				}) | |
| 			}, | |
| 			getPhone(e){ | |
| 				this.$api('bindPhone', { | |
| 					code : e.detail.code | |
| 				}, res => { | |
| 					if(res.code == 200){ | |
| 						let phoneObj = JSON.parse(res.result) | |
| 						if(phoneObj.errmsg == 'ok'){ | |
| 							this.userInfoForm.phone = phoneObj.phone_info.phoneNumber | |
| 						}else{ | |
| 							// uni.showModal({ | |
| 							// 	title: '' | |
| 							// }) | |
| 						} | |
| 					} | |
| 				}) | |
| 			}, | |
| 			// #endif | |
| 			 | |
| 			// #ifdef H5 | |
| 			deleteImage(e){ | |
| 				this.fileList.splice(e.index, 1) | |
| 				this.userInfoForm.headImage = '' | |
| 			}, | |
| 			afterRead(e){ | |
| 				let self = this | |
| 				// e.file.forEach(file => { | |
| 					self.$Oss.ossUpload(e.file.url).then(url => { | |
| 						self.userInfoForm.headImage = url | |
| 						self.fileList = [{ | |
| 							url | |
| 						}] | |
| 					}) | |
| 				// }) | |
| 			}, | |
| 			// #endif | |
| 			submit() { | |
| 				let self = this | |
| 
 | |
| 				uni.createSelectorQuery().in(this) | |
| 					.select("#nickName") | |
| 					.fields({ | |
| 						properties: ["value"], | |
| 					}) | |
| 					.exec((res) => { | |
| 						const nickName = res?.[0]?.value | |
| 						self.userInfoForm.nickName = nickName | |
| 						 | |
| 						if (self.$utils.verificationAll(self.userInfoForm, { | |
| 								headImage: '请选择头像', | |
| 								nickName: '请填写昵称', | |
| 								phone: '请填写手机号', | |
| 							})) { | |
| 							return | |
| 						} | |
| 						 | |
| 						// #ifdef H5 | |
| 						// H5端需要验证手机号格式 | |
| 						if (!self.$utils.verificationPhone(self.userInfoForm.phone)) { | |
| 							uni.showToast({ | |
| 								title: '请输入正确的手机号格式', | |
| 								icon: 'none' | |
| 							}) | |
| 							return | |
| 						} | |
| 						// #endif | |
| 						 | |
| 						self.$api('updateInfo', { | |
| 							avatarUrl : self.userInfoForm.headImage, | |
| 							nickName : self.userInfoForm.nickName, | |
| 							phone : self.userInfoForm.phone, | |
| 						}, res => { | |
| 							if (res.code == 200) { | |
| 								uni.reLaunch({ | |
| 									url:'/pages/index/index' | |
| 								}) | |
| 							} | |
| 						}) | |
| 					}) | |
| 				 | |
| 			}, | |
| 		} | |
| 	} | |
| </script> | |
| 
 | |
| <style lang="scss" scoped> | |
| 	.login { | |
| 		display: flex; | |
| 		flex-direction: column; | |
| 		justify-content: center; | |
| 		align-items: center; | |
| 		height: 80vh; | |
| 		.logo{ | |
| 			height: 140rpx; | |
| 			width: 140rpx; | |
| 			image{ | |
| 				height: 140rpx; | |
| 				width: 140rpx; | |
| 				border-radius: 30rpx; | |
| 			} | |
| 			margin-bottom: 20rpx; | |
| 		} | |
| 
 | |
| 		.title { | |
| 			line-height: 45rpx; | |
| 			font-weight: 900; | |
| 		} | |
| 
 | |
| 		.line { | |
| 			display: flex; | |
| 			justify-content: space-between; | |
| 			align-items: center; | |
| 			width: 80%; | |
| 			border-bottom: 1px solid #00000023; | |
| 			padding: 30rpx 0; | |
| 			margin: 0 auto; | |
| 		} | |
| 
 | |
| 		.chooseAvatar { | |
| 			width: 100%; | |
| 			padding: 0; | |
| 			margin: 0; | |
| 			margin-top: 10vh; | |
| 			border: none; | |
| 		} | |
| 
 | |
| 		.btn { | |
| 			// background: $uni-linear-gradient-btn-color; | |
| 			background: $uni-color; | |
| 			color: #fff; | |
| 			width: 80%; | |
| 			padding: 20rpx 0; | |
| 			text-align: center; | |
| 			border-radius: 15rpx; | |
| 			margin-top: 10vh; | |
| 		} | |
| 		.getPhoneNumber{ | |
| 			// all: unset; | |
| 			display: flex; | |
| 			justify-content: center; | |
| 			align-items: center; | |
| 			// background: $uni-linear-gradient-btn-color; | |
| 			background: $uni-color; | |
| 			color: #fff; | |
| 			width: 200rpx; | |
| 			height: 60rpx; | |
| 			border-radius: 30rpx; | |
| 			font-size: 24rpx; | |
| 		} | |
| 	} | |
| </style> |