userinfo.vue 6.3 KB
Newer Older
DCloud_JSON's avatar
DCloud_JSON 已提交
1
<!-- 用户资料页 -->
DCloud_JSON's avatar
DCloud_JSON 已提交
2 3 4 5 6 7 8 9
<template>
	<view class="uni-content">
		<view class="avatar">
			<uni-id-pages-avatar width="260rpx" height="260rpx"></uni-id-pages-avatar>
		</view>
		<uni-list>
			<uni-list-item class="item" @click="setNickname('')" title="昵称" :rightText="userInfo.nickname||'未设置'" link>
			</uni-list-item>
DCloud_JSON's avatar
DCloud_JSON 已提交
10 11
			<uni-list-item class="item" @click="bindMobile" title="手机号" :rightText="userInfo.mobile||'未绑定'" link>
			</uni-list-item>
12 13
			<uni-list-item v-if="userInfo.email" class="item" title="电子邮箱" :rightText="userInfo.email">
			</uni-list-item>
DCloud_JSON's avatar
DCloud_JSON 已提交
14
			<uni-list-item v-if="hasPwd" class="item" @click="changePassword" title="修改密码" link>
DCloud_JSON's avatar
DCloud_JSON 已提交
15 16 17 18 19 20 21 22 23 24
			</uni-list-item>
		</uni-list>
		<uni-list class="mt10">
			<uni-list-item @click="deactivate" title="注销账号" link="navigateTo"></uni-list-item>
		</uni-list>
		<uni-popup ref="dialog" type="dialog">
			<uni-popup-dialog mode="input" :value="userInfo.nickname" @confirm="setNickname" title="设置昵称"
				placeholder="请输入要设置的昵称">
			</uni-popup-dialog>
		</uni-popup>
DCloud_JSON's avatar
1.0.20  
DCloud_JSON 已提交
25
		<uni-id-pages-bind-mobile ref="bind-mobile-by-sms" @success="bindMobileSuccess"></uni-id-pages-bind-mobile>
DCloud_JSON's avatar
1.0.12  
DCloud_JSON 已提交
26
		<template v-if="showLoginManage">
DCloud_JSON's avatar
1.0.20  
DCloud_JSON 已提交
27
			<button v-if="userInfo._id" @click="logout">退出登录</button>
DCloud_JSON's avatar
1.0.12  
DCloud_JSON 已提交
28 29
			<button v-else @click="login">去登录</button>
		</template>
DCloud_JSON's avatar
DCloud_JSON 已提交
30 31 32 33 34 35
	</view>
</template>
<script>
	const db = uniCloud.database();
	const usersTable = db.collection('uni-id-users')
	const uniIdCo = uniCloud.importObject("uni-id-co")
36 37 38 39
  import {
    store,
    mutations
  } from '@/uni_modules/uni-id-pages/common/store.js'
DCloud_JSON's avatar
DCloud_JSON 已提交
40
	export default {
41 42 43 44 45
    computed: {
      userInfo() {
        return store.userInfo
      }
    },
DCloud_JSON's avatar
DCloud_JSON 已提交
46 47 48 49 50 51 52 53 54 55
		data() {
			return {
				univerifyStyle: {
					authButton: {
						"title": "本机号码一键绑定", // 授权按钮文案
					},
					otherLoginButton: {
						"title": "其他号码绑定",
					}
				},
DCloud_JSON's avatar
1.0.20  
DCloud_JSON 已提交
56 57 58 59
				// userInfo: {
				// 	mobile:'',
				// 	nickname:''
				// },
DCloud_JSON's avatar
1.0.12  
DCloud_JSON 已提交
60 61
				hasPwd:false,
				showLoginManage:false//通过页面传参隐藏登录&退出登录按钮
DCloud_JSON's avatar
DCloud_JSON 已提交
62 63 64 65 66 67
			}
		},
		async onShow() {
			this.univerifyStyle.authButton.title = "本机号码一键绑定"
			this.univerifyStyle.otherLoginButton.title = "其他号码绑定"
		},
DCloud_JSON's avatar
1.0.12  
DCloud_JSON 已提交
68 69 70 71
		async onLoad(e) {
			if(e.showLoginManage){
				this.showLoginManage = true//通过页面传参隐藏登录&退出登录按钮
			}
DCloud_JSON's avatar
DCloud_JSON 已提交
72 73
			//判断当前用户是否有密码,否则就不显示密码修改功能
			let res = await uniIdCo.getAccountInfo()
DCloud_JSON's avatar
DCloud_JSON 已提交
74 75 76 77 78 79 80 81 82 83 84
			this.hasPwd = res.isPasswordSet
		},
		methods: {
			login() {
				uni.navigateTo({
					url: '/uni_modules/uni-id-pages/pages/login/login-withoutpwd',
					complete: (e) => {
						console.log(e);
					}
				})
			},
85 86 87 88 89 90
      logout(){
        mutations.logout()
      },
      bindMobileSuccess(){
        mutations.updateUserInfo()
      },
DCloud_JSON's avatar
DCloud_JSON 已提交
91 92
			changePassword(){
				uni.navigateTo({
DCloud_JSON's avatar
DCloud_JSON 已提交
93
					url: '/uni_modules/uni-id-pages/pages/userinfo/change_pwd/change_pwd',
DCloud_JSON's avatar
DCloud_JSON 已提交
94 95 96 97
					complete: (e) => {
						console.log(e);
					}
				})
DCloud_JSON's avatar
DCloud_JSON 已提交
98 99 100 101 102 103 104 105 106 107 108 109 110 111 112
			},
			bindMobile() {
				// #ifdef APP-PLUS
				uni.preLogin({
					provider: 'univerify',
					success: this.univerify(), //预登录成功
					fail: (res) => { // 预登录失败
						// 不显示一键登录选项(或置灰)
						console.log(res)
						this.bindMobileBySmsCode()
					}
				})
				// #endif

				// #ifdef MP-WEIXIN
113
				this.$refs['bind-mobile-by-sms'].open()
DCloud_JSON's avatar
DCloud_JSON 已提交
114 115 116 117 118 119 120 121 122 123 124 125 126 127 128
				// #endif

				// #ifdef H5
				//...去用验证码绑定
				this.bindMobileBySmsCode()
				// #endif
			},
			univerify() {
				uni.login({
					"provider": 'univerify',
					"univerifyStyle": this.univerifyStyle,
					success: async e => {
						console.log(e.authResult);
						uniIdCo.bindMobileByUniverify(e.authResult).then(res => {
							console.log(res);
129
              mutations.updateUserInfo()
DCloud_JSON's avatar
DCloud_JSON 已提交
130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145
						}).catch(e => {
							console.log(e);
						}).finally(e=>{
							console.log(e);
							uni.closeAuthView()
						})
					},
					fail: (err) => {
						console.log(err);
						if (err.code == '30002' || err.code == '30001') {
							this.bindMobileBySmsCode()
						}
					}
				})
			},
			bindMobileBySmsCode() {
146 147 148
        uni.navigateTo({
          url: './bind-mobile/bind-mobile'
        })
DCloud_JSON's avatar
DCloud_JSON 已提交
149 150 151
			},
			setNickname(nickname) {
				console.log(nickname);
152 153 154 155 156 157
        if (nickname) {
          mutations.updateUserInfo({nickname})
          this.$refs.dialog.close()
        } else {
          this.$refs.dialog.open()
        }
DCloud_JSON's avatar
DCloud_JSON 已提交
158 159 160 161 162
			},
			deactivate(){
				uni.navigateTo({
					url:"/uni_modules/uni-id-pages/pages/userinfo/deactivate/deactivate"
				})
163 164 165 166 167 168 169 170 171
			},
      async bindThirdAccount(provider) {
        const uniIdCo = uniCloud.importObject("uni-id-co")
        const bindField = {
          weixin: 'wx_openid',
          alipay: 'ali_openid',
          apple: 'apple_openid',
          qq: 'qq_openid'
        }[provider.toLowerCase()]
172

173 174 175 176 177 178 179 180 181 182 183 184 185
        if (this.userInfo[bindField]) {
          await uniIdCo['unbind' + provider]()
          await mutations.updateUserInfo()
        } else {
          uni.login({
            provider: provider.toLowerCase(),
            onlyAuthorize: true,
            success: async e => {
              const res = await uniIdCo['bind' + provider]({
                code: e.code
              })
              if (res.errCode) {
                uni.showToast({
186 187
                  title: res.errMsg || '绑定失败',
				  duration: 3000
188 189 190 191 192 193 194 195 196 197 198 199
                })
              }
              await mutations.updateUserInfo()
            },
            fail: async (err) => {
              console.log(err);
              uni.hideLoading()
            }
          })
        }

      }
DCloud_JSON's avatar
DCloud_JSON 已提交
200 201 202 203 204
		}
	}
</script>
<style lang="scss" scoped>

DCloud_JSON's avatar
1.0.20  
DCloud_JSON 已提交
205
	@import "@/uni_modules/uni-id-pages/common/login-page.scss";
DCloud_JSON's avatar
DCloud_JSON 已提交
206 207 208 209 210 211 212 213 214 215 216

	.uni-content {
		padding: 0;
	}

	/* #ifndef APP-NVUE */
	view {
		display: flex;
		box-sizing: border-box;
		flex-direction: column;
	}
DCloud_JSON's avatar
1.0.12  
DCloud_JSON 已提交
217 218 219 220 221 222 223 224 225 226 227
	@media screen and (min-width: 690px) {
		.uni-content {
			padding: 0;
			max-width: 690px;
			margin-left: calc(50% - 345px);
			border: none;
			max-height: none;
			border-radius: 0;
			box-shadow: none;
		}
	}
DCloud_JSON's avatar
DCloud_JSON 已提交
228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249
	/* #endif */
	.avatar {
		align-items: center;
		justify-content: center;
		margin: 22px 0;
		width: 100%;
	}

	.item {
		flex: 1;
		flex-direction: row;
		justify-content: space-between;
		align-items: center;
	}

	button {
		margin: 10%;
		margin-top: 40px;
		border-radius: 0;
		background-color: #FFFFFF;
		width: 80%;
	}
250

DCloud_JSON's avatar
DCloud_JSON 已提交
251 252 253 254
	.mt10{
		margin-top: 10px;
	}
</style>