<!-- pos机账号登录入口 -->
<template>
	<view class="page-content my-bg">
		<cu-custom class="main-topbar bg-main-oil" bgColor="bg-main-oil" :isBack="true">
			<block slot="content">星油云站</block>
		</cu-custom>
		<view class="bg-img margin flex padding-lg radius align-center text-center" :style="'background-image: url('+mainURL+'login-bg.png)'">
			<view class="padding-lg margin text-center text-lg text-white w100">
				<text class>油站工作人员绑定油站</text>
			</view>
		</view>
		<view class="pannel">
			<view class="bg-white margin padding radius shadow-warp">
				<view class="cu-form-group">
					<view class="title mini-label text-black">手机号</view>
					<input type="number" v-model="auth.phone" placeholder="请输入手机号" name="input" />
				</view>
				<view class="cu-form-group  padding-top-sm" v-if="showRandom">
					<view class="title text-black mini-label">验证码</view>
					<input type="number" :maxlength="6" v-model="auth.captcha" placeholder="六位数字验证码" name="input" />
					<text :class="frozen?'text-gray':'oil-main-color'" @tap="sendMsg">{{tips}}</text>
				</view>
				<view class=" cu-form-group padding-top-sm" v-else>
					<view class="title mini-label text-black">密码</view>
					<input type="password" v-model="auth.password" placeholder="请输入登入密码" name="input" />
				</view>
			</view>

			<view class="margin-right padding-right-lg text-right" @tap="showRandom=true" v-if="!showRandom">
				<text class="text-sm text-red padding-right">短信验证码登录</text>
			</view>
			<view class="margin-right padding-right-lg text-right" @tap="showRandom=false" v-else>
				<text class="text-sm text-red padding-right">密码登录</text>
			</view>
		</view>
		<view class="margin-lg  padding-lg bottom-bg">
			<button class="bg-main-oil round" v-if="showRandom" @tap="loginRandom">登录</button>
			<button class="bg-main-oil round" v-else @tap="loginPwd">登录</button>

		</view>
		<official-account @binderror="bindload" @bindload="binderror"></official-account>
		<view class="bottom-part">
			<service-hotline />
		</view>
	</view>
</template>

<script>
	import cloudSiteApi from '@/api/cloud-site.js'
	import loginApi from '@/api/login.js'
	import md5 from 'js-md5'

	export default {
		data() {
			return {
				baseURL: this.global.baseURL,
				mainURL: this.global.mainURL,
				forcedLogin: true,
				oilSiteNo: '',
				showRandom: true,
				auth: {},
				tips: '发送验证码',
				frozen: false // 二维码冷却时间

			}
		},
		created() {
			uni.showShareMenu()
		},
		methods: {
			bindload(){
				console.log('组件夹杂')
			},
			binderror(){
				console.log('组件夹杂失败')
			},	
			loginWeixin() {
				uni.login({
					provider: 'weixin',
					success: loginRes => {
						const code = loginRes.code
						console.log('启动页code', code)
						loginApi.loginWeixin(code).then(res => {
							if (res.code === 20000) {
								uni.reLaunch({
									url: '/pages/index/index',
									fail: (err) => {
										console.log(err)
									}
								})
								uni.showToast({
									title: res.msg,
									icon: 'success',
									duration: 3000
								})
								uni.setStorage({
									key: 'Authorization',
									data: res.data.accessToken,
									success: () => {
										console.log('Authorization成功', res.data.accessToken)
									}
								})
								uni.setStorage({
									key: 'device',
									data: res.data.openid,
									success: () => {
										console.log('deviceopenid', res.data.openid)
									}
								})
								uni.setStorageSync('userMenu', res.data.loginUser.procedureAuthList)
								uni.setStorageSync('loginUser', {
									id: res.data.loginUser.id,
									name: res.data.loginUser.name,
									userPhone: res.data.loginUser.userPhone
								})
							} else {
								uni.reLaunch({
									url: '/pages/login/boforeLogin/boforeLogin',
									fail: (err) => {
										console.log(err)
									}
								})
								console.log('res', res.code)
							}


						}).catch(err => {
							uni.reLaunch({
								url: '/pages/login/boforeLogin/boforeLogin',
								fail: (err) => {
									console.log(err)
								}
							})
						})
					},
					fail: err => {
						console.log(err)
					}
				});
			},

			loginPwd() {
				uni.login({
					provider: 'weixin',
					success: loginRes => {
						const code = loginRes.code
						console.log(code)
						console.log('加密', this.auth.password)
						const data3 = {
							username: this.auth.phone,
							password: md5(this.auth.password),
							code: code
						}
						loginApi.loginWeiXinByPassword(data3).then(res => {
							console.log('res', res)
							uni.showToast({
								title: res.msg,
								icon: 'none'
							})

							console.log('oilSiteCode', this.oilSiteNo)
							if (res.code === 20000) {

								uni.reLaunch({
									url: '/pages/index/index',
									fail: (err) => {
										console.log(err)
									}
								})
								uni.showToast({
									title: res.msg,
									icon: 'success',
									duration: 3000
								})
								uni.setStorage({
									key: 'Authorization',
									data: res.data.accessToken,
									success: () => {
										console.log('Authorization成功', res.data.accessToken)
									}
								})
								uni.setStorage({
									key: 'device',
									data: res.data.openid,
									success: () => {
										console.log('deviceopenid', res.data.openid)
									}
								})
								uni.setStorageSync('userMenu', res.data.loginUser.procedureAuthList)
								uni.setStorageSync('loginUser', {
									id: res.data.loginUser.id,
									name: res.data.loginUser.name,
									userPhone: res.data.loginUser.userPhone
								})
							}
						})
					},
					fail: err => {
						console.log(err)
					}
				});

			},
			loginWeixin() {
				uni.login({
					provider: 'weixin',
					success: loginRes => {
						const code = loginRes.code
						console.log(code)
						loginApi.loginWeixin(code).then(res => {
							if (res.code === 20000) {
								uni.reLaunch({
									url: '/pages/index/index',
									fail: (err) => {
										console.log(err)
									}
								})
								uni.showToast({
									title: res.msg,
									icon: 'success',
									duration: 3000
								})
								uni.setStorage({
									key: 'Authorization',
									data: res.data.accessToken,
									success: () => {
										console.log('Authorization成功', res.data.accessToken)
									}
								})
								uni.setStorage({
									key: 'device',
									data: res.data.openid,
									success: () => {
										console.log('deviceopenid', res.data.openid)
									}
								})
								uni.setStorageSync('userMenu', res.data.loginUser.procedureAuthList)
								uni.setStorageSync('loginUser', {
									id: res.data.loginUser.id,
									name: res.data.loginUser.name,
									userPhone: res.data.loginUser.userPhone
								})
							} else {
								console.log('res', res.code)
								uni.showToast({
									title: '未绑定微信',
									icon: 'none',
									duration: 1500
								})
							}


						})
					},
					fail: err => {
						console.log(err)
					}
				});
			},
			sendMsg() {
				if (!this.frozen) {
					if (this.auth.phone) {
						const data2 = {
							phone: this.auth.phone
						}
						loginApi.loginAppSendSms(data2).then(res => {
							console.log('res', res)
							uni.showToast({
								title: res.msg,
								icon: 'none'
							})
							if (res.code === 20000) {

								this.frozen = true
								setTimeout(() => {
									this.frozen = false
									clearInterval(timer)
									this.tips = `发送验证码`
								}, 1000 * 60);
								let second = 60
								const timer = setInterval(() => {
									second--
									if (second) {
										this.tips = `${second}秒后重发`
									} else {
										this.tips = `发送验证码`
										this.disabled = false
										this.btnColor = '#FE0505'
									}
								}, 1000)

							}

						})

					} else {
						uni.showToast({
							title: '请输入您的账号',
							icon: 'none'
						})
					}
				}
			},

			loginRandom() {
				uni.login({
					provider: 'weixin',
					success: loginRes => {
						const code = loginRes.code
						console.log(code)
						const data2 = {
							phone: this.auth.phone,
							username: this.auth.phone, //类型:String  必有字段  备注:手机号
							verifyCode: this.auth.captcha, //类型:String  必有字段  备注:验证码
							code: code //类型:String  必有字段  备注:微信code
						}
						loginApi.loginWeiXinSMS(data2).then(res => {
							console.log('res', res)
							uni.showToast({
								title: res.msg,
								icon: 'none'
							})

							console.log('oilSiteCode', this.oilSiteNo)
							if (res.code === 20000) {
								uni.reLaunch({
									url: '/pages/index/index',
									fail: (err) => {
										console.log(err)
									}
								})
								uni.showToast({
									title: res.msg,
									icon: 'success',
									duration: 3000
								})
								uni.setStorage({
									key: 'Authorization',
									data: res.data.accessToken,
									success: () => {
										console.log('Authorization成功', res.data.accessToken)
									}
								})
								uni.setStorage({
									key: 'device',
									data: res.data.openid,
									success: () => {
										console.log('deviceopenid', res.data.openid)
									}
								})
								uni.setStorageSync('userMenu', res.data.loginUser.procedureAuthList)
								uni.setStorageSync('loginUser', {
									id: res.data.loginUser.id,
									name: res.data.loginUser.name,
									userPhone: res.data.loginUser.userPhone
								})
							}
						})
					},
					fail: err => {
						console.log(err)
					}
				});

			},
			getMsg() {
				uni.requestSubscribeMessage({
					tmplIds: ['W5XD3NQVa6knC5jXHeWT8GS7q5CHrDUMY_sF79kLkKk'],
					success: (res) => {
						console.log(res)
					}
				})
			},
			getUserInfo({
				detail
			}) {
				console.log('三方登录只演示登录api能力,暂未关联云端数据');
				console.log('detail', detail)
				if (detail.userInfo) {
					this.loginLocal(detail.userInfo.nickName);
				} else {
					uni.showToast({
						icon: 'none',
						title: '登陆失败'
					});
				}

			},
			loginLocal(nickName) {
				uni.setStorageSync('login_type', 'local')
				uni.setStorageSync('username', nickName)
				this.toMain(nickName);
			},
			toMain(userName) {
				// this.login(userName)
				console.log(userName)
				/**
				 * 强制登录时使用reLaunch方式跳转过来
				 * 返回首页也使用reLaunch方式
				 */
				if (this.forcedLogin) {
					uni.reLaunch({
						url: '/pages/index/index',
						success: () => {
							console.log('success')
						},
						fail: err => {
							console.log(err)
						}
					});
				} else {
					uni.navigateBack();
				}

			}
		}
	};
</script>

<style scoped>
	.page-content {
		min-height: 100%;
		position: relative;
	}

	.logo {
		min-width: 100%;
		text-align: center;
	}

	.logo img {
		width: 200upx;
		height: 200rpx;
		background-size: contain;
		margin: auto;
	}

	.bottom-bg {
		position: sticky;
		bottom: 50upx;
	}
</style>