146 lines
		
	
	
		
			4.2 KiB
		
	
	
	
		
			Vue
		
	
	
			
		
		
	
	
			146 lines
		
	
	
		
			4.2 KiB
		
	
	
	
		
			Vue
		
	
	
| <template>
 | ||
| 	<view>
 | ||
| 		<view class='Popup' v-if='isShowAuth'>
 | ||
| 		   <image :src='logoUrl'></image>
 | ||
| 		   <view class='title'>授权提醒</view>
 | ||
| 		   <view class='tip'>请授权头像等信息,以便为您提供更好的服务</view>
 | ||
| 		   <view class='bottom flex'>
 | ||
| 		      <view class='item' @click='close'>随便逛逛</view>
 | ||
| 			  <!-- #ifdef APP-PLUS -->
 | ||
| 			  <button class='item grant' @click="setUserInfo">去授权</button>
 | ||
| 			  <!-- #endif -->
 | ||
| 			  <!-- #ifdef MP -->
 | ||
| 			  <button class='item grant'  type="primary" open-type="getUserInfo" lang="zh_CN" @getuserinfo="setUserInfo">去授权</button>
 | ||
| 			  <!-- #endif -->
 | ||
| 		   </view>
 | ||
| 		</view>
 | ||
| 		<view class='mask' v-if='isShowAuth' @click='close'></view>
 | ||
| 	</view>
 | ||
| </template>
 | ||
| 
 | ||
| <script>
 | ||
| 	const app = getApp();
 | ||
| 	import Cache from '../utils/cache';
 | ||
| 	import { getLogo } from '../api/public';
 | ||
| 	import { LOGO_URL } from '../config/cache';
 | ||
| 	import { mapGetters } from 'vuex';
 | ||
| 	import Routine from '../libs/routine';
 | ||
| 	
 | ||
| 	export default {
 | ||
| 		name:'Authorize',
 | ||
| 		props:{
 | ||
| 			isAuto:{
 | ||
| 				type:Boolean,
 | ||
| 				default:true
 | ||
| 			},
 | ||
| 			isGoIndex:{
 | ||
| 				type:Boolean,
 | ||
| 				default:true
 | ||
| 			},
 | ||
| 			isShowAuth:{
 | ||
| 				type:Boolean,
 | ||
| 				default:false
 | ||
| 			}
 | ||
| 		},
 | ||
| 		data(){
 | ||
| 			return {
 | ||
| 				logoUrl:''
 | ||
| 			}
 | ||
| 		},
 | ||
| 		computed:mapGetters(['isLogin','userInfo']),
 | ||
| 		watch:{
 | ||
| 			isLogin(n){
 | ||
| 				n === true && this.$emit('onLoadFun',this.userInfo);
 | ||
| 			}
 | ||
| 		},
 | ||
| 		created() {
 | ||
| 			this.getLogoUrl();
 | ||
| 			this.setAuthStatus();
 | ||
| 		},
 | ||
| 		methods:{
 | ||
| 			setAuthStatus(){
 | ||
| 				Routine.authorize().then(res=>{
 | ||
| 					if(res.islogin === false)
 | ||
| 						this.setUserInfo();
 | ||
| 					else
 | ||
| 						this.$emit('onLoadFun',this.userInfo);
 | ||
| 				}).catch(res=>{
 | ||
| 					if (this.isAuto) 
 | ||
| 						this.$emit('authColse',true);
 | ||
| 				})
 | ||
| 			},
 | ||
| 			getUserInfo(code){
 | ||
| 				Routine.getUserInfo().then(res=>{
 | ||
| 					let userInfo = res.userInfo
 | ||
| 					userInfo.code = code;
 | ||
| 					userInfo.spread_spid = app.globalData.spid;//获取推广人ID
 | ||
| 					userInfo.spread_code = app.globalData.code;//获取推广人分享二维码ID
 | ||
| 					userInfo.avatar  = userInfo.userInfo.avatarUrl;
 | ||
| 					userInfo.city  = userInfo.userInfo.city;
 | ||
| 					userInfo.country  = userInfo.userInfo.country;
 | ||
| 					userInfo.nickName  = userInfo.userInfo.nickName;
 | ||
| 					userInfo.province  = userInfo.userInfo.province;
 | ||
| 					userInfo.sex  = userInfo.userInfo.gender;
 | ||
| 					Routine.authUserInfo(code,userInfo).then(res=>{
 | ||
| 						uni.hideLoading();
 | ||
| 						this.$emit('authColse',false);
 | ||
| 						this.$emit('onLoadFun',this.userInfo);
 | ||
| 					}).catch(res=>{
 | ||
| 						uni.hideLoading();
 | ||
| 						uni.showToast({
 | ||
| 							title:res.message,
 | ||
| 							icon:'none',
 | ||
| 							duration:2000
 | ||
| 						});
 | ||
| 					})
 | ||
| 				}).catch(res =>{
 | ||
| 					uni.hideLoading();
 | ||
| 				})
 | ||
| 			},
 | ||
| 			setUserInfo(){
 | ||
| 				uni.showLoading({title:'正在登录中'});
 | ||
| 				Routine.getCode().then(code=>{
 | ||
| 					this.getUserInfo(code);
 | ||
| 				}).catch(res=>{
 | ||
| 					uni.hideLoading();
 | ||
| 				})
 | ||
| 			},
 | ||
| 			getLogoUrl(){
 | ||
| 				let that = this;
 | ||
| 				if (Cache.has(LOGO_URL)) {
 | ||
| 					this.logoUrl = Cache.get(LOGO_URL);
 | ||
| 					return;
 | ||
| 				}
 | ||
| 				getLogo().then(res=>{
 | ||
| 					that.logoUrl = res.data.logoUrl
 | ||
| 					Cache.set(LOGO_URL,that.logoUrl);
 | ||
| 				})
 | ||
| 			},
 | ||
| 			close(){
 | ||
| 				let pages = getCurrentPages(), currPage  = pages[pages.length - 1];
 | ||
| 				if(this.isGoIndex){
 | ||
| 					uni.switchTab({url:'/pages/index/index'});
 | ||
| 				} else {
 | ||
| 					this.$emit('authColse',false);
 | ||
| 				}
 | ||
| 				// if (currPage && currPage.isShowAuth != undefined){
 | ||
| 				// 	currPage.isShowAuth = true;
 | ||
| 				// }
 | ||
| 			},
 | ||
| 		}
 | ||
| 	}
 | ||
| </script>
 | ||
| 
 | ||
| <style scoped lang='scss'>
 | ||
| 	.Popup{width:500rpx;background-color:#fff;position:fixed;top:50%;left:50%;margin-left:-250rpx;transform:translateY(-50%);z-index:320;}
 | ||
| 	.Popup image{width:150rpx;height:150rpx;margin:-67rpx auto 0 auto;display:block;border: 8rpx solid #fff;border-radius: 50%}
 | ||
| 	.Popup .title{font-size:28rpx;color:#000;text-align:center;margin-top: 30rpx}
 | ||
| 	.Popup .tip{font-size:22rpx;color:#555;padding:0 24rpx;margin-top:25rpx;}
 | ||
| 	.Popup .bottom .item{width:50%;height:80rpx;background-color:#eeeeee;text-align:center;line-height:80rpx;font-size:24rpx;color:#666;margin-top:54rpx;}
 | ||
| 	.Popup .bottom .item.on{width: 100%}
 | ||
| 	.flex{display:flex;}
 | ||
| 	.Popup .bottom .item.grant{font-size:28rpx;color:#fff;font-weight:bold;background-color:$theme-color;border-radius:0;padding:0;}
 | ||
| 	.mask{position:fixed;top:0;right:0;left:0;bottom:0;background-color:rgba(0,0,0,0.65);z-index:310;}
 | ||
| 	
 | ||
| </style>
 |