<template>
	<view :style="viewColor">
		<view class="container">
			<view class="header">
				<text class="title">绑定手机号</text>
				<text class="iconfont icon-guanbi5" @tap="closePopup"></text>
			</view>
			<view class="main_counts">
				<form report-submit='true'>
					<view class="ChangePassword">
						<view class="list">
							<view class="item">
								<input type='number' placeholder='输入手机号码' placeholder-class='placeholder' v-model="phone"></input>
							</view>
							<view class="item acea-row row-between-wrapper">
								<input type='number' placeholder='输入验证码' placeholder-class='placeholder' class="codeIput" v-model="captcha"></input>
								<button class="code" :class="disabled === true ? 'on' : ''" :disabled='disabled' @click="handleVerify">
									{{ text }}
								</button>
							</view>
						</view>
						<button form-type="submit" @click="editPwd" class="confirmBnt">确认绑定</button>
						<!-- #ifdef MP -->
						<button v-if="!isCommuity" form-type="submit" class="getPhoneBtn" open-type="getPhoneNumber" @getphonenumber="getPhoneNumber"><text class="iconfont icon-weixin2"></text>使用微信绑定号码</button>
						<!-- #endif -->
					</view>
				</form>		
			</view>	
		</view>
		<Verify @success="success" :captchaType="'blockPuzzle'" :imgSize="{ width: '330px', height: '155px' }" ref="verify"></Verify>
		<view class='mask' catchtouchmove="true" :hidden='popup.show==false' @tap="closePopup"></view>
	</view>
	
</template>

<script>
	// +----------------------------------------------------------------------
	// | CRMEB [ CRMEB赋能开发者,助力企业发展 ]
	// +----------------------------------------------------------------------
	// | Copyright (c) 2016~2021 https://www.crmeb.com All rights reserved.
	// +----------------------------------------------------------------------
	// | Licensed CRMEB并不是自由软件,未经许可不能去掉CRMEB相关版权
	// +----------------------------------------------------------------------
	// | Author: CRMEB Team <admin@crmeb.com>
	// +----------------------------------------------------------------------
	import sendVerifyCode from "@/mixins/SendVerifyCode";
	import {
		bindingPhone,
		verifyCode, appletsDecrypt
	} from '@/api/api.js';
	import { registerVerify } from '@/api/user.js'
	import {
		mapGetters
	} from "vuex";
  import Verify from '@/components/verify/verify.vue';
	export default {
		props:{
			isCommuity: {
				type: Boolean,
				default: false
			}
		},
		mixins: [sendVerifyCode],
		components: {
      Verify
		},
		data() {
			return {
				phone:'',
				captcha:'',
				isAuto: false, //没有授权的不会自动授权
				isShowAuth: false, //是否隐藏授权
				key: '',
				codeVal: '',
				popup: {
					show: false
				},
			};
		},
		computed: mapGetters(['isLogin','viewColor']),
		onLoad() {
			
		},
		methods: {
			// 点击关闭按钮
			closePopup() {
				this.$emit('close');
			},
			// #ifdef MP
			getPhoneNumber(e) {
				let that = this;
				appletsDecrypt({
					iv:e.detail.iv,
					encryptedData:e.detail.encryptedData,
					code:that.codeVal
					}).then(res => {
						that.$util.Tips({
							title: '绑定成功!',
							icon: 'success'
						})
						setTimeout(()=>{
							uni.switchTab({
								url: '/pages/user/index',
							});
						},2000)
					})
			},
			// #endif
			editPwd: function() {
				let that = this;
				if (!that.phone) return that.$util.Tips({
					title: '请输入手机号码!'
				});
				if (!(/^1(3|4|5|7|8|9|6)\d{9}$/i.test(that.phone))) return that.$util.Tips({
					title: '请输入正确的手机号码!'
				});
				if (!that.captcha) return that.$util.Tips({
					title: '请填写验证码'
				});
				bindingPhone({
					phone: that.phone,
					sms_code: that.captcha
				}).then(res => {
					if (res.data !== undefined && res.data.is_bind) {
						uni.showModal({
							title: '是否绑定手机号',
							content: res.msg,
							confirmText: '绑定',
							success(res) {
								if (res.confirm) {
									bindingPhone({
										phone: that.phone,
										captcha: that.captcha,
										step: 1
									}).then(res => {
										that.$emit('close');
										return that.$util.Tips({
											title: res.msg,
											icon: 'success'
										});
									}).catch(err => {
										return that.$util.Tips({
											title: err
										});
									})
								} else if (res.cancel) {
									return that.$util.Tips({
										title: '您已取消绑定!'
									}, {
										tab: 5,
										url: '/pages/users/user_info/index'
									});
								}
							}
						});
					} else
						that.$emit('close');
						return that.$util.Tips({
							title: '绑定成功!',
							icon: 'success'
						});
				}).catch(err => {
					return that.$util.Tips({
						title: err
					});
				})
			},
			/**
			 * 发送验证码
			 *
			 */
			async code(data) {
				let that = this;
				if (!that.phone) return that.$util.Tips({
					title: '请填写手机号码!'
				});
				if (!(/^1(3|4|5|7|8|9|6)\d{9}$/i.test(that.phone))) return that.$util.Tips({
					title: '请输入正确的手机号码!'
				});
				this.disabled = true
				await registerVerify({
					phone:that.phone,
					key:that.key,
					code:that.captcha,
					type: 'binding',
          captchaType: 'blockPuzzle',
					captchaVerification: data.captchaVerification
				}).then(res => {
					this.disabled = false
					that.$util.Tips({
						title: res.msg
					});
					that.sendCode();
				}).catch(err => {
					this.disabled = false
					return that.$util.Tips({
						title: err
					});
				});
			},
			success(data) {
				this.$refs.verify.hide();
				this.code(data);
			},
			handleVerify() {
				let that = this;
				if (!that.phone) return that.$util.Tips({
					title: '请填写手机号码!'
				});
				if (!(/^1(3|4|5|7|8|9|6)\d{9}$/i.test(that.phone))) return that.$util.Tips({
					title: '请输入正确的手机号码!'
				});
				this.$refs.verify.show();
			}
		}
	}
</script>

<style lang="scss" scoped>
	
.container{
	background-color: #ffffff;
	border-radius: 16rpx 16rpx 0 0;
	position: relative;
	padding-bottom: 30rpx;
	.header{
		position: relative;
		padding: 40rpx 30rpx;
		text-align: center;
		.title{
			color: #282828;
			font-size: 32rpx;
		}
		.iconfont{
			color: #8A8A8A;
			font-size: 28rpx;
			position: absolute;
			top: 0;
			right: 0;
		}
		.icon-guanbi5 {
			right: 20rpx;
			color: #8a8a8a;
			font-size: 30rpx;
			line-height: 30rpx;
			top: 20rpx;
			background-color: transparent;
			font-weight: normal;
		}		
	}
}
.ChangePassword{
	padding: 0 30rpx 100rpx;
}
.ChangePassword .phone {
		font-size: 32rpx;
		font-weight: bold;
		text-align: center;
		margin-top: 55rpx;
	}
	.ChangePassword .list .item {

		height: 86rpx;
		margin-bottom: 30rpx;
		flex-direction: row;
	}
	.ChangePassword .list .item input {

		height: 100%;
		font-size: 32rpx;	
		border: 1px solid #DCDCDC;
		border-radius: 43rpx;
		padding: 0 40rpx;
	}
	.ChangePassword .list .item .placeholder {
		color: #b9b9bc;
	}
	.ChangePassword .list .item input.codeIput {
		max-width: 400rpx;
	}
	.ChangePassword .list .item .code {
		font-size: 28rpx;
		background-color: var(--view-minorColor);
		color: var(--view-theme);
		width: 230rpx;
		height: 86rpx;
		border-radius: 43rpx;
		display: flex;
		align-items: center;
		justify-content: center;
	}
	.ChangePassword .list .item .code.on {
		color: #b9b9bc;
	}
	.ChangePassword .confirmBnt {
		font-size: 32rpx;
		width: 580rpx;
		height: 90rpx;
		border-radius: 45rpx;
		color: #fff;
		margin: 60rpx auto 0 auto;
		text-align: center;
		line-height: 90rpx;
		background-color: var(--view-theme);
	}
	.getPhoneBtn{
		font-size: 32rpx;
		width: 580rpx;
		height: 90rpx;
		border-radius: 45rpx;
		border: 1px solid #3CB625;
		color: #3CB625;
		margin: 40rpx auto 0 auto;
		text-align: center;
		line-height: 90rpx;
		.iconfont{
			font-size: 32rpx;
			margin-right: 12rpx;
		}
	}
	/deep/.verifybox{
		top: auto!important;
	}
</style>