206 lines
10 KiB
Vue
206 lines
10 KiB
Vue
|
<template>
|
||
|
<view>
|
||
|
<view class="accredit_model">
|
||
|
<view class="model_container">
|
||
|
<view class="model_top">
|
||
|
<image class="model_icon" src="@/static/images/model_img.png"></image>
|
||
|
</view>
|
||
|
<view class="model_content">
|
||
|
<view class="model_title">授权提示</view>
|
||
|
<view class="model_desc">{{content}}</view>
|
||
|
<view class="model_btns">
|
||
|
<view class="mbtn cancel_btn" @click="modelCancel()">取消</view>
|
||
|
<view class="mbtn confirm_btn" @click="modelConfirm()" v-if="locationType">确定</view>
|
||
|
<!-- <view class="mbtn confirm_btn" @click="modelConfirm()" v-if="userPhoneType">确定</view> -->
|
||
|
<button class="mbtn confirm_btn" v-if="userPhoneType" open-type="getPhoneNumber" @getphonenumber="getphonenumber">确定</button>
|
||
|
</view>
|
||
|
</view>
|
||
|
</view>
|
||
|
</view>
|
||
|
<view class="mask"></view>
|
||
|
</view>
|
||
|
</template>
|
||
|
<script>
|
||
|
const app = getApp();
|
||
|
import Routine from '@/libs/routine';
|
||
|
import {loginMobile,registerVerify,getCodeApi,getUserInfo} from "@/api/user";
|
||
|
import { getLogo, getUserPhone } from '@/api/public';
|
||
|
export default {
|
||
|
name:'',
|
||
|
props:{
|
||
|
locationType:{
|
||
|
type:Boolean,
|
||
|
default:false
|
||
|
},
|
||
|
userPhoneType:{
|
||
|
type:Boolean,
|
||
|
default:false
|
||
|
},
|
||
|
authKey:{
|
||
|
type:String,
|
||
|
default:'',
|
||
|
},
|
||
|
isPhoneBox:{
|
||
|
type:Boolean,
|
||
|
default:false,
|
||
|
},
|
||
|
content:{
|
||
|
type:String,
|
||
|
default:'申请获取用于完整服务',
|
||
|
}
|
||
|
},
|
||
|
data() {
|
||
|
return {
|
||
|
isStatus:false
|
||
|
}
|
||
|
},
|
||
|
methods:{
|
||
|
modelCancel(){
|
||
|
this.$emit('closeModel',{isStatus:this.isStatus});
|
||
|
},
|
||
|
modelConfirm(){
|
||
|
this.$emit('confirmModel');
|
||
|
},
|
||
|
// #ifdef MP
|
||
|
// 小程序获取手机号码
|
||
|
getphonenumber(e){
|
||
|
uni.showLoading({ title: '加载中' });
|
||
|
Routine.getCode()
|
||
|
.then(code => {
|
||
|
this.getUserPhoneNumber(e.detail.encryptedData, e.detail.iv, code);
|
||
|
})
|
||
|
.catch(error => {
|
||
|
uni.hideLoading();
|
||
|
});
|
||
|
},
|
||
|
// 小程序获取手机号码回调
|
||
|
getUserPhoneNumber(encryptedData, iv, code) {
|
||
|
getUserPhone({
|
||
|
encryptedData: encryptedData,
|
||
|
iv: iv,
|
||
|
code: code,
|
||
|
key:this.authKey,
|
||
|
type: 'routine'
|
||
|
})
|
||
|
.then(res => {
|
||
|
this.$store.commit('LOGIN', {
|
||
|
token: res.data.token
|
||
|
});
|
||
|
this.$store.commit("SETUID", res.data.uid);
|
||
|
this.getUserInfo();
|
||
|
})
|
||
|
.catch(res => {
|
||
|
uni.hideLoading();
|
||
|
this.$util.Tips({
|
||
|
title: res
|
||
|
});
|
||
|
});
|
||
|
},
|
||
|
/**
|
||
|
* 获取个人用户信息
|
||
|
*/
|
||
|
getUserInfo: function() {
|
||
|
let that = this;
|
||
|
getUserInfo().then(res => {
|
||
|
uni.hideLoading();
|
||
|
that.$store.commit("UPDATE_USERINFO", res.data);
|
||
|
that.isStatus = true
|
||
|
this.modelCancel();
|
||
|
});
|
||
|
},
|
||
|
// #endif
|
||
|
}
|
||
|
}
|
||
|
</script>
|
||
|
|
||
|
<style scoped lang="scss">
|
||
|
.accredit_model{
|
||
|
/* position: relative; */
|
||
|
width: 560rpx;
|
||
|
height: 660rpx;
|
||
|
position: fixed;
|
||
|
left: 50%;
|
||
|
top: 50%;
|
||
|
transform: translate(-50%,-50%);
|
||
|
z-index: 999;
|
||
|
}
|
||
|
.model_container{
|
||
|
width: 100%;
|
||
|
height: 660rpx;
|
||
|
}
|
||
|
.model_top{
|
||
|
width: 100%;
|
||
|
height: 270rpx;
|
||
|
// background: #D64532;
|
||
|
@include main_bg_color(theme);
|
||
|
border-radius: 20rpx 20rpx 0 0;
|
||
|
background-image: url(
|
||
|
background-size: cover;
|
||
|
display: flex;
|
||
|
justify-content: center;
|
||
|
align-items: flex-end;
|
||
|
}
|
||
|
.model_icon{
|
||
|
width: 230rpx;
|
||
|
height: 210rpx;
|
||
|
}
|
||
|
.model_content{
|
||
|
width: 100%;
|
||
|
height: 390rpx;
|
||
|
background-color: #fff;
|
||
|
border-radius: 0 0 20rpx 20rpx;
|
||
|
padding: 32rpx;
|
||
|
box-sizing: border-box;
|
||
|
}
|
||
|
.model_title{
|
||
|
text-align: center;
|
||
|
font-size: 36rpx;
|
||
|
font-family: PingFangSC-Semibold, PingFang SC;
|
||
|
font-weight: 600;
|
||
|
color: #333333;
|
||
|
line-height: 50rpx;
|
||
|
}
|
||
|
.model_desc{
|
||
|
width: 448rpx;
|
||
|
height: 96rpx;
|
||
|
margin: 20rpx auto 0;
|
||
|
font-size: 32rpx;
|
||
|
text-align: center;
|
||
|
font-family: PingFangSC-Regular, PingFang SC;
|
||
|
font-weight: 400;
|
||
|
color: #666666;
|
||
|
line-height: 48rpx;
|
||
|
}
|
||
|
.model_btns{
|
||
|
width: 448rpx;
|
||
|
height: 82rpx;
|
||
|
margin: auto;
|
||
|
display: flex;
|
||
|
justify-content: space-between;
|
||
|
}
|
||
|
.mbtn{
|
||
|
width: 208rpx;
|
||
|
height: 82rpx;
|
||
|
border-radius: 42rpx;
|
||
|
margin-top: 44rpx;
|
||
|
}
|
||
|
.cancel_btn{
|
||
|
background: #F5F5F5;
|
||
|
font-weight: 400;
|
||
|
color: #666666;
|
||
|
line-height: 82rpx;
|
||
|
text-align: center;
|
||
|
font-size: 32rpx;
|
||
|
}
|
||
|
.confirm_btn{
|
||
|
@include linear-gradient(theme);
|
||
|
font-weight: 400;
|
||
|
color: #fff;
|
||
|
line-height: 82rpx;
|
||
|
text-align: center;
|
||
|
font-size: 32rpx;
|
||
|
}
|
||
|
.mask{
|
||
|
z-index: 900;
|
||
|
}
|
||
|
</style>
|