userinfo.vue 7.0 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
			</uni-list-item>
		</uni-list>
17 18 19 20 21 22 23 24 25 26
		<uni-list class="mt10">
			<uni-list-item @click="bindThirdAccount('Weixin')" title="微信" link
				:rightText="userInfo.wx_openid ? '已绑定': '未绑定' "></uni-list-item>
			<uni-list-item @click="bindThirdAccount('QQ')" title="QQ" link
				:rightText="userInfo.qq_openid ? '已绑定': '未绑定' "></uni-list-item>
			<uni-list-item @click="bindThirdAccount('Alipay')" title="支付宝" link
				:rightText="userInfo.ali_openid ? '已绑定': '未绑定' "></uni-list-item>
			<uni-list-item @click="bindThirdAccount('Apple')" title="Apple" link
				:rightText="userInfo.apple_openid ? '已绑定': '未绑定' "></uni-list-item>
		</uni-list>
DCloud_JSON's avatar
DCloud_JSON 已提交
27 28 29 30 31 32 33 34
		<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 已提交
35
		<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 已提交
36
		<template v-if="showLoginManage">
DCloud_JSON's avatar
1.0.20  
DCloud_JSON 已提交
37
			<button v-if="userInfo._id" @click="logout">退出登录</button>
DCloud_JSON's avatar
1.0.12  
DCloud_JSON 已提交
38 39
			<button v-else @click="login">去登录</button>
		</template>
DCloud_JSON's avatar
DCloud_JSON 已提交
40 41 42 43 44 45
	</view>
</template>
<script>
	const db = uniCloud.database();
	const usersTable = db.collection('uni-id-users')
	const uniIdCo = uniCloud.importObject("uni-id-co")
46 47 48 49
  import {
    store,
    mutations
  } from '@/uni_modules/uni-id-pages/common/store.js'
DCloud_JSON's avatar
DCloud_JSON 已提交
50
	export default {
51 52 53 54 55
    computed: {
      userInfo() {
        return store.userInfo
      }
    },
DCloud_JSON's avatar
DCloud_JSON 已提交
56 57 58 59 60 61 62 63 64 65
		data() {
			return {
				univerifyStyle: {
					authButton: {
						"title": "本机号码一键绑定", // 授权按钮文案
					},
					otherLoginButton: {
						"title": "其他号码绑定",
					}
				},
DCloud_JSON's avatar
1.0.20  
DCloud_JSON 已提交
66 67 68 69
				// userInfo: {
				// 	mobile:'',
				// 	nickname:''
				// },
DCloud_JSON's avatar
1.0.12  
DCloud_JSON 已提交
70 71
				hasPwd:false,
				showLoginManage:false//通过页面传参隐藏登录&退出登录按钮
DCloud_JSON's avatar
DCloud_JSON 已提交
72 73 74 75 76 77
			}
		},
		async onShow() {
			this.univerifyStyle.authButton.title = "本机号码一键绑定"
			this.univerifyStyle.otherLoginButton.title = "其他号码绑定"
		},
DCloud_JSON's avatar
1.0.12  
DCloud_JSON 已提交
78 79 80 81
		async onLoad(e) {
			if(e.showLoginManage){
				this.showLoginManage = true//通过页面传参隐藏登录&退出登录按钮
			}
DCloud_JSON's avatar
DCloud_JSON 已提交
82 83
			//判断当前用户是否有密码,否则就不显示密码修改功能
			let res = await uniIdCo.getAccountInfo()
DCloud_JSON's avatar
DCloud_JSON 已提交
84 85 86 87 88 89 90 91 92 93 94
			this.hasPwd = res.isPasswordSet
		},
		methods: {
			login() {
				uni.navigateTo({
					url: '/uni_modules/uni-id-pages/pages/login/login-withoutpwd',
					complete: (e) => {
						console.log(e);
					}
				})
			},
95 96 97 98 99 100
      logout(){
        mutations.logout()
      },
      bindMobileSuccess(){
        mutations.updateUserInfo()
      },
DCloud_JSON's avatar
DCloud_JSON 已提交
101 102
			changePassword(){
				uni.navigateTo({
DCloud_JSON's avatar
DCloud_JSON 已提交
103
					url: '/uni_modules/uni-id-pages/pages/userinfo/change_pwd/change_pwd',
DCloud_JSON's avatar
DCloud_JSON 已提交
104 105 106 107
					complete: (e) => {
						console.log(e);
					}
				})
DCloud_JSON's avatar
DCloud_JSON 已提交
108 109 110 111 112 113 114 115 116 117 118 119 120 121 122
			},
			bindMobile() {
				// #ifdef APP-PLUS
				uni.preLogin({
					provider: 'univerify',
					success: this.univerify(), //预登录成功
					fail: (res) => { // 预登录失败
						// 不显示一键登录选项(或置灰)
						console.log(res)
						this.bindMobileBySmsCode()
					}
				})
				// #endif

				// #ifdef MP-WEIXIN
123
				this.$refs['bind-mobile-by-sms'].open()
DCloud_JSON's avatar
DCloud_JSON 已提交
124 125 126 127 128 129 130 131 132 133 134 135 136 137 138
				// #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);
139
              mutations.updateUserInfo()
DCloud_JSON's avatar
DCloud_JSON 已提交
140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155
						}).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() {
156 157 158
        uni.navigateTo({
          url: './bind-mobile/bind-mobile'
        })
DCloud_JSON's avatar
DCloud_JSON 已提交
159 160 161
			},
			setNickname(nickname) {
				console.log(nickname);
162 163 164 165 166 167
        if (nickname) {
          mutations.updateUserInfo({nickname})
          this.$refs.dialog.close()
        } else {
          this.$refs.dialog.open()
        }
DCloud_JSON's avatar
DCloud_JSON 已提交
168 169 170 171 172
			},
			deactivate(){
				uni.navigateTo({
					url:"/uni_modules/uni-id-pages/pages/userinfo/deactivate/deactivate"
				})
173 174 175 176 177 178 179 180 181
			},
      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()]
182

183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208
        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({
                  title: res.errMsg || '绑定失败'
                })
              }
              await mutations.updateUserInfo()
            },
            fail: async (err) => {
              console.log(err);
              uni.hideLoading()
            }
          })
        }

      }
DCloud_JSON's avatar
DCloud_JSON 已提交
209 210 211 212 213
		}
	}
</script>
<style lang="scss" scoped>

DCloud_JSON's avatar
1.0.20  
DCloud_JSON 已提交
214
	@import "@/uni_modules/uni-id-pages/common/login-page.scss";
DCloud_JSON's avatar
DCloud_JSON 已提交
215 216 217 218 219 220 221 222 223 224 225

	.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 已提交
226 227 228 229 230 231 232 233 234 235 236
	@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 已提交
237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258
	/* #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%;
	}
259

DCloud_JSON's avatar
DCloud_JSON 已提交
260 261 262 263
	.mt10{
		margin-top: 10px;
	}
</style>