login.uvue 2.8 KB
Newer Older
DCloud_JSON's avatar
DCloud_JSON 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23
<template>
	<view class="page">
		<!-- 顶部文字 -->
		<!-- <text class="title">请选择登录方式{{loginType}}--isAgree:{{pendingAgreements}}</text> -->

		<!--  应用图标 -->
		<image class="app-logo" :src="logo" mode="aspectFit"></image>

    <!-- 苹果账号 微信账号 微信账号手机号 登录 -->
    <view class="big-login-box" v-if="['apple','weixin', 'weixinMobile'].includes(loginType)">
      <text class="tip">将根据第三方账号服务平台的授权范围获取你的信息</text>
      <image v-if="loginType !== 'weixinMobile'" @click="login" :src="imgSrc" mode="widthFix" class="big-login-img">
      </image>
      <button v-else type="primary" open-type="getmobileNumber" @getmobilenumber="login"
        class="uni-btn">微信授权手机号登录</button>
      <!-- 同意隐私政策协议 -->
      <uni-id-pages-x-agreements class="agreements-box" scope="login" />
    </view>

		<!-- 密码登录 -->
		<uni-id-pages-x-loginByPwd v-if="loginType == 'username'" />

		<!-- 手机号验证码登录 -->
DCloud_JSON's avatar
DCloud_JSON 已提交
24
		<uni-id-pages-x-loginBySmsCode v-else-if="loginType == 'smsCode'" />
DCloud_JSON's avatar
DCloud_JSON 已提交
25 26 27 28 29 30 31 32 33 34 35

		<!-- 固定定位的快捷登录按钮 -->
		<uni-id-pages-x-fab-login :currentLoginType="loginType"
			@changeLoginType="changeLoginType"></uni-id-pages-x-fab-login>

	</view>
</template>

<script>
	import { state } from '@/uni_modules/uni-id-pages-x/store.uts';
	import config from '@/uni_modules/uni-id-pages-x/config.uts';
A
Anne_LXM 已提交
36
  // #ifdef APP && uniVersion >= 3.98
DCloud_JSON's avatar
DCloud_JSON 已提交
37
  import Univerify from '@/uni_modules/uni-id-pages-x/lib/Univerify.uts'
雪洛's avatar
雪洛 已提交
38
  // #endif
DCloud_JSON's avatar
DCloud_JSON 已提交
39
  export default {
DCloud_JSON's avatar
DCloud_JSON 已提交
40 41 42 43 44 45 46 47 48 49 50
		computed: {
			//大快捷登录按钮图
			imgSrc() : string {
				return this.loginType == 'weixin' ? '/uni_modules/uni-id-pages-x/static/login/weixin.png' : '/uni_modules/uni-id-pages-x/static/app/apple.png'
			},
			pendingAgreements() : boolean {
				return state.pendingAgreements
			}
		},
		data() {
			return {
51
				loginType: "username",
DCloud_JSON's avatar
DCloud_JSON 已提交
52 53 54
				logo: "/static/logo.png"
			}
		},
DCloud_JSON's avatar
DCloud_JSON 已提交
55
		onLoad(param) {
DCloud_JSON's avatar
DCloud_JSON 已提交
56
			let type = param["type"]
A
Anne_LXM 已提交
57
      if ( type == null){
DCloud_JSON's avatar
DCloud_JSON 已提交
58 59 60
       let loginTypes = config.getArray<string>("loginTypes");
       type = loginTypes![0];
      }
A
Anne_LXM 已提交
61
      // console.log('type:',type)
DCloud_JSON's avatar
DCloud_JSON 已提交
62
      this.loginType = type
DCloud_JSON's avatar
DCloud_JSON 已提交
63 64
		},
		methods: {
DCloud_JSON's avatar
DCloud_JSON 已提交
65 66
      login(){},
      verify(){
A
Anne_LXM 已提交
67
        // #ifdef APP && uniVersion >= 3.98
DCloud_JSON's avatar
DCloud_JSON 已提交
68 69 70 71
        const univerifyManager = new Univerify()
        univerifyManager.verify(true)
        // #endif
      },
DCloud_JSON's avatar
DCloud_JSON 已提交
72
			changeLoginType(type : string) {
DCloud_JSON's avatar
DCloud_JSON 已提交
73 74 75 76 77
				if ( type === "univerify" ) {
          this.verify()
				}else{
          this.loginType = type
        }
DCloud_JSON's avatar
DCloud_JSON 已提交
78 79 80 81 82
			}
		}
	}
</script>

A
Anne_LXM 已提交
83
<style lang="scss">
DCloud_JSON's avatar
DCloud_JSON 已提交
84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100
	@import url("/uni_modules/uni-id-pages-x/common/common.scss");

	.app-logo {
		width: 150rpx;
		height: 150rpx;
		margin: 30px 300rpx;
	}

	.big-login-box .agreements-box {
		justify-content: center;
	}

	.big-login-img {
		margin: 10px 25rpx;
		height: 60px;
		width: 700rpx;
	}
DCloud_JSON's avatar
DCloud_JSON 已提交
101
</style>