login.vue 8.28 KB

<template>
	<div class="content">
		<modal-comp :visible="modalVisiable" :show-confirm="false" :icon="modalIcon" :content="modalContent" :confirm="modalCallback" :overlay="modalCallback"></modal-comp>
		<div class="ebg">
			<img src="@/assets/images/common/login-bg.png">
		</div>
		<div class="top-space"></div>
		<div class="box">
			<!-- 帐密登陆 -->
			<div v-if="type == 1" class="login">
				<div class="login-tit">
					<img v-if="locale == 'zh'" src="@/assets/images/login/login-tit-zh.png">
					<img v-if="locale == 'tc'" src="@/assets/images/login/login-tit-tc.png">
					<img v-if="locale == 'en'" class="img-en" src="@/assets/images/login/login-tit-en.png">
				</div>
				<div class="login-nav">
					<div @click="onLoginTypeHandler(1)" class="login-nav-tit text-r pointer active">{{$t('login.loginType1')}}</div>
					<div class="login-nav-v-line"></div>
					<div @click="onLoginTypeHandler(2)" class="login-nav-tit pointer">{{$t('login.loginType2')}}</div>
				</div>
				<div class="gird-g form">
					<div class="pure-u-1 form-item">
						<div class="label">
							<img src="@/assets/images/login/icon-login-user.png"> {{$t('login.account')}}
						</div>
						<div class="ipt-wrap">
							<input v-model="loginForm.userId" :placeholder="$t('login.accountPlaceholder')" class="ipt" :class="{ err : errorTips.e1.length > 0 }" type="text">
						</div>
						<div class="validator" v-if="errorTips.e1.length > 0 ">
							<img src="@/assets/images/common/icon-notice.png" alt="">{{errorTips.e1}}
						</div>
					</div>
					<div class="pure-u-1 form-item">
						<div class="label">
							<img src="@/assets/images/login/icon-login-password.png"> {{$t('login.password')}}
						</div>
						<div class="ipt-wrap">
							<input v-model="loginForm.password" :placeholder="$t('login.passwordPlaceholder')" class="ipt" :class="{ err : errorTips.e2.length > 0 }" type="password">
						</div>
						<div class="validator" v-if="errorTips.e2.length > 0 ">
							<img src="@/assets/images/common/icon-notice.png" alt="">{{errorTips.e2}}
						</div>
					</div>
					<div class="pure-u-1 form-item" v-if="type == 1 && loginCheck.showImageCode">
						<div class="ipt-wrap">
							<input :placeholder="$t('login.verifyPlaceholder')" class="ipt ipt-verify" :class="{ err : errorTips.e3.length > 0 }" type="text" v-model="loginForm.imageValue">
							<div class="ipt verify-btn pointer vcode" @click="handlerRefreshImageValue">
								<img :src="values.imageBase64">
							</div>
						</div>
						<div class="validator" v-if="errorTips.e3.length > 0 ">
							<img src="@/assets/images/common/icon-notice.png" alt="">{{errorTips.e3}}
						</div>
					</div>
				</div>
				<div class="login-protocol pointer" @click="loginCheck.agreeProtocol = !loginCheck.agreeProtocol">
					<img v-if="!loginCheck.agreeProtocol" class="check" src="@/assets/images/login/un-check.png">
					<img v-if="loginCheck.agreeProtocol" class="check" src="@/assets/images/login/check.png"> {{$t('login.agree')}}
					<span @click="onProtocolHandler()" class="protocol pointer">{{$t('login.protocol')}}</span>
				</div>
				<div @click="handlerLogin()" class="login-submit pointer">{{$t('login.login')}}</div>
				<div class="login-func">
					<div @click="onRegisterHandler()" class="login-func-btn pointer">{{$t('login.register')}}</div>
					<div @click="onForgetHandler()" class="login-func-btn pointer">{{$t('login.forget')}}</div>
				</div>
			</div>

			<!-- OTP登陆 -->
			<div v-if="type == 2" class="login">
				<div class="login-tit">
					<img v-if="locale == 'zh'" src="@/assets/images/login/login-tit-zh.png">
					<img v-if="locale == 'tc'" src="@/assets/images/login/login-tit-tc.png">
					<img v-if="locale == 'en'" class="img-en" src="@/assets/images/login/login-tit-en.png">
				</div>
				<div class="login-nav">
					<div @click="onLoginTypeHandler(1)" class="login-nav-tit text-r pointer"> {{$t('login.loginType1')}}</div>
					<div class="login-nav-v-line"></div>
					<div @click="onLoginTypeHandler(2)" class="login-nav-tit pointer active"> {{$t('login.loginType2')}}</div>
				</div>
				<div class="gird-g form">
					<div class="pure-u-1 form-item">
						<div class="label">
							<img src="@/assets/images/login/icon-login-phone.png"> {{$t('login.mobile')}}
						</div>
						<div class="ipt-wrap">
							<input :placeholder="$t('login.mobilePlaceholder')" class="ipt" type="text" :class="{ err : errorTips.oe1.length > 0 }" v-model="loginForm.mobileNo">
						</div>
						<div class="validator" v-if="errorTips.oe1.length > 0 ">
							<img src="@/assets/images/common/icon-notice.png" alt="">{{errorTips.oe1}}
						</div>
					</div>
					<div class="pure-u-1 form-item" v-if="type == 2 && loginCheck.showImageCode">
						<div class="ipt-wrap">
							<input :placeholder="$t('login.verifyPlaceholder')" class="ipt ipt-verify" :class="{ err : errorTips.oe3.length > 0 }" type="text" v-model="loginForm.imageValue">
							<div class="ipt verify-btn pointer vcode" @click="handlerRefreshImageValue">
								<img :src="values.imageBase64">
							</div>
						</div>
						<div class="validator" v-if="errorTips.oe3.length > 0 ">
							<img src="@/assets/images/common/icon-notice.png" alt="">{{errorTips.oe3}}
						</div>
					</div>
					<div class="pure-u-1 form-item">
						<div class="label">
							<img src="@/assets/images/login/icon-login-message.png"> {{$t('login.verifyCode')}}
						</div>
						<div class="ipt-wrap">
							<div class="ipt ipt2" :class="{ err : errorTips.oe2.length > 0 }">
								<input :placeholder="$t('login.verifyCodePlaceholder')" class="ipt-code" type="text" v-model="loginForm.otp">
								<div v-if="times.remain == 0" class="veri-btn pointer" @click="handlerStdSendOTP">{{$t('register.verifyCodeGet')}}</div>
								<div v-else class="veri-btn-default">{{times.tip}}</div>
							</div>
						</div>
						<div class="validator" v-if="errorTips.oe2.length > 0 ">
							<img src="@/assets/images/common/icon-notice.png" alt="">{{errorTips.oe2}}
						</div>
					</div>
				</div>
				<div class="login-protocol pointer" @click="loginCheck.agreeProtocol = !loginCheck.agreeProtocol">
					<img v-if="!loginCheck.agreeProtocol" class="check" src="@/assets/images/login/un-check.png">
					<img v-if="loginCheck.agreeProtocol" class="check" src="@/assets/images/login/check.png"> {{$t('login.agree')}}
					<span @click="onProtocolHandler()" class="protocol pointer">{{$t('login.protocol')}}</span>
				</div>
				<div @click="handlerLogin()" class="login-submit pointer">{{$t('login.login')}}</div>
				<div class="login-func">
					<div @click="toRegisterPage()" class="login-func-btn pointer">{{$t('login.register')}}</div>
					<div @click="onForgetHandler()" class="login-func-btn pointer">{{$t('login.forget')}}</div>
				</div>
			</div>

			<!---->
			<div v-if="type == 3" class="login">
				<div class="login-tit">
					<img v-if="locale == 'zh'" src="@/assets/images/login/login-tit-zh.png">
					<img v-if="locale == 'tc'" src="@/assets/images/login/login-tit-tc.png">
					<img v-if="locale == 'en'" class="img-en" src="@/assets/images/login/login-tit-en.png">
				</div>
				<div class="gird-g form">
					<div class="pure-u-1 form-item">
						<div class="label">
							<img src="@/assets/images/register/icon-register-lock.png"> {{$t('register.newPassword')}}
						</div>
						<div class="ipt-wrap">
							<input :placeholder="$t('register.newPasswordPlaceholder')" class="ipt" type="password" v-model="values.password">
						</div>
						<div class="validator" v-if="errorTips.p4.length > 0 ">
							<img src="@/assets/images/common/icon-notice.png" alt="">{{errorTips.p4}}
						</div>
					</div>
					<div class="pure-u-1 form-item">
						<div class="label">
							<img src="@/assets/images/register/icon-register-lock.png"> {{$t('register.newPasswordSure')}}
						</div>
						<div class="ipt-wrap">
							<input :placeholder="$t('register.newPasswordSurePlaceholder')" class="ipt" type="password" v-model="values.passwordRepeat">
						</div>
						<div class="validator" v-if="errorTips.p5.length > 0 ">
							<img src="@/assets/images/common/icon-notice.png" alt="">{{errorTips.p5}}
						</div>
					</div>
				</div>
				<div @click="onRegisterHandler()" class="login-submit pointer">{{$t('register.sure')}}</div>
			</div>
		</div>
	</div>
</template>

<script src="./login.js"></script>
<style lang="scss" scoped>
@import "./login.scss";
</style>