123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622 |
- <template>
- <view class="body" :style="{height:screenHeight}">
- <image v-if="isDevelop" class="login-bg" :src="loginBg" mode="widthFix"></image>
- <u-toast ref="uToast"></u-toast>
- <view style="height: 40%;position: relative;z-index: 10;">
- <view class="logo-wrap" :class="{dev:isDevelop}">
- <img :src="logoSrc" class="logo" :class="{dev:isDevelop}" alt="">
- <!-- <img :src="sitename" class="sitename" alt=""> -->
- <!-- <u--image :src="logoSrc" width="200rpx" height="200rpx"></u--image>
- <u--image :src="sitename" width="460rpx" height="142rpx"></u--image> -->
- </view>
- <!-- <u-button text="getUserProfile" type="success" :hairline="false" throttleTime="2000" shape="circle" open-type="getUserProfile"
- @click="getUserProfile"></u-button> -->
- <!-- <u-button v-if="loginBtn" text="手机号快捷登录" type="success" :hairline="false" throttleTime="2000" shape="circle"
- @click="openAuth"></u-button> -->
- <view class="btn-wrap" style="margin:94rpx">
- <!-- #ifdef MP -->
- <u-button
- v-if="loginBtn&&checked.length>0"
- :hair-line='false'
- type="error"
- color="#ED0000"
- throttleTime="2000"
- shape="circle"
- open-type="getPhoneNumber"
- @getphonenumber="authPhone">登录
- </u-button>
- <u-button
- v-else
- :hair-line='false'
- type="error"
- color="#ED0000"
- @click="disabledClick"
- shape="circle">登录
- </u-button>
- <!-- #endif -->
- <!-- #ifdef H5 -->
- <u-button
- :hair-line='false'
- type="error"
- color="#ED0000"
- @click="disabledClick"
- shape="circle">登录
- </u-button>
- <!-- #endif -->
- </view>
- <view class="rule-wrap u-flex u-flex-wrap u-row-center">
- <u-checkbox-group v-model="checked" @change="checkboxChange" placement="row">
- <u-checkbox activeColor="#1677FF" name="同意" labelSize="24rpx" shape="circle" label="我已阅读并同意"></u-checkbox>
- </u-checkbox-group>
- <text class="link" @click="$u.route('/pages/login/regulation',{regulationName:'用户服务协议',type:1})">《用户服务协议》</text>
- 和<text class="link" @click="$u.route('/pages/login/regulation',{regulationName:'用户隐私政策',type:2})">《用户隐私政策》</text>
- </view>
- </view>
-
- <!-- 微信获取手机号弹窗 -->
- <!-- <u-modal :show="showAuthorizePhone" :show-title="false"
- :show-confirm-button="false">
- <view class="slot-content">
- <div class="auth-card">
- <div class="img">
- <img class="avatar-img" :src="logoSrc" mode="widthFix">
- </div>
- <div class="title">{{bname}}</div>
- <div class="content">申请获得您的手机号</div>
- </div>
- <div class="auth-btncard u-flex u-row-between">
- <div class="btn-unok"><u-button :hair-line='false' :custom-style="customStyleUnOk" @click="showAuthorizePhone=false">拒绝</u-button></div>
- <div class="btn-ok"><u-button :hair-line='false' :custom-style="customStyleOk" open-type="getPhoneNumber" @getphonenumber="authPhone"> 允许</u-button></div>
- </div>
- </view>
- </u-modal> -->
- <!-- 微信获取用户头像昵称弹窗 -->
- <!-- <u-modal :show="showAuthorizeUser" :show-title="false"
- :show-confirm-button="false">
- <view class="slot-content">
- <div class="auth-card">
- <div class="img">
- <img class="avatar-img"
- :src="logoSrc"
- mode="widthFix">
- </div>
- <div class="title">{{bname}}</div>
- <div class="content">邀请您补全个人信息<br></br>(昵称、头像)</div>
- <div style="margin-left: 100rpx;margin-right: 100rpx">
- <u-form :model="user" ref="uForm">
- <u-form-item label="头像">
- <button class="avatar-wrapper" open-type="chooseAvatar" @chooseavatar="onChooseAvatar" slot="right">
- <image class="avatar" :src="user.avatar"></image>
- </button>
- </u-form-item>
- <u-form-item label="昵称">
- <input type="nickname" class="weui-input u-border-bottom" @blur="nickNameInput" placeholder="请输入昵称"/>
- </u-form-item>
- </u-form>
- </div>
- </div>
- <div class="auth-btncard">
- <div class="btn-unok"><u-button :hair-line='false' :custom-style="customStyleUnOk" @click="showAuthorizeUser=false"> 拒绝</u-button></div>
- <div class="btn-ok"><u-button :hair-line='false' :custom-style="customStyleOk" @click="authUser"> 允许</u-button></div>
- </div>
- </view>
- </u-modal> -->
- </view>
- </template>
- <script>
- export default {
- data() {
- return {
- staticUrl:this.$commonConfig.staticUrl,
- checked:false,
- checkboxVal:null,
- loginBtn:true,
- bname:'旭烁集团',
- //屏幕高度
- screenHeight: "",
- loginBg: `${this.$commonConfig.staticUrl}/img/login-page-bg-dev.png`,
- logoSrc: `${this.$commonConfig.staticUrl}/img/logo.png`,
- // sitename:"/static/sitename.png",
- miniappLoginInfo:null,
- hasUserInfo:false,
- userInfo: null,
- user:{
- avatar:'https://mmbiz.qpic.cn/mmbiz/icTdbqWNOwNRna42FI242Lcia07jQodd2FJGIYQfG0LAJGFxM4FbnQP6yfMxBgJ0F3YRqJCJ1aPAK2dQagdusBZg/0',
- name:'',
- mobile:'',
- },
- code: '',
- showAuthorizeUser: false,
- showAuthorizePhone: false,
- customStyleUnOk:{},
- customStyleOk:{'margin-left': '30px',color:'#00A447'},
- backUrl:null,
- scene:'',
- retailId:'',
- isDevelop:undefined,
- };
- },
- onLoad(e) {
- // console.log('envVersion',wx.getAccountInfoSync().miniProgram.envVersion);
- console.log('this.$isDevelop',this.$isDevelop);
- if(this.$isDevelop){
- this.isDevelop = true;
- this.logoSrc = `${this.$commonConfig.staticUrl}/img/logo-dev.png`;
- }
-
- // console.log("onLoad e=======",e)
- if(e&&e.scene){
- this.scene = e.scene;
- // console.log('login e.scene',e.scene);
- this.scene&&uni.setStorage({
- key:'scene',
- data:e.scene,
- // timestamp: new Date().getTime(), // 添加时间戳
- success: function (res) {
- // console.log('onLoad success scene====',res);
- }
- });
- }
- // #ifdef H5
- if(e&&e.code) { // 微信第三方登录成功
- this.code = e.code
- this.login(e)
- }
- // #endif
- let that = this;
- //获取屏幕高度,我的项目再store里已经取到了
- uni.getSystemInfo({
- success: (res) => {
- this.screenHeight = res.windowHeight + "px"
- }
- });
- uni.getStorage({
- key: 'backUrl',
- success: function (res) {
- that.backUrl = '/'+res.data;
- }
- });
- },
- onShow() {
- // #ifdef H5
- let pages = getCurrentPages(); //当前页面栈
- // console.log("pages=====",pages)
- // #endif
- // #ifdef MP
- // uni.showLoading({
- // mask:true
- // });
- this.getChatCode();
- // setTimeout(() => {
- // this.openAuth();
- // // this.showAuthorizeUser = true //弹出头像用户名
- // }, 100);
- // #endif
- let userInfo = uni.getStorageSync('userInfo');
- this.user.name = userInfo.name;
- },
- methods: {
- openAuth(){
- this.showAuthorizePhone = true;
- // let userInfo = uni.getStorageSync('userInfo')
- // console.log('userInfo>>>>>>>>>>>>>>>>>>>>>',userInfo)
- // if(userInfo){
- // this.showAuthorizeUser = true;
- // }else{
- // this.showAuthorizePhone = true;
- // }
- // uni.hideLoading()
- },
- getChatCode() {
- //因为作用域先提前赋值
- var that = this
- //使用uni封装的一键登录方法
- uni.login({
- provider: 'weixin',
- success(res) {
- //成功后带着微信登录返回的code去请求我们的后端
- that.code = res.code;
- // console.log('code',that.code);
- }
- })
- },
- getUserProfile() {
- var that = this
- uni.getUserProfile({
- desc: "获取你的昵称、头像",
- success(res) {
- // console.log('getUserProfile success',res);
- if (res.errMsg == "getUserProfile:ok" && res.userInfo != undefined) {
- //我用store来存储一些数据,你可以放到你要放的地方
- // console.log(' res.userInfo', res.userInfo);
- // that.$u.vuex('wx_user_info.nickName', res.userInfo.nickName);
- // that.$u.vuex('wx_user_info.avatarUrl', res.userInfo.avatarUrl);
- // that.getChatCode()
- }
- },
- complete(res) {
- // console.log('complete',res);
- }
- })
- },
- //获取昵称输入内容
- // userNameInput(e){
- // this.user.nickName = e.detail.value
- // },
- onChooseAvatar(e) {
- console.log('头像信息》')
- console.log(e)
- this.user.avatar = e.detail.avatarUrl;
- },
- async authPhone(e){
- // console.log('checked',this.checked);
- // console.log('detail',e.detail);
- let errMsg = e.detail?.errMsg;
- if(errMsg!='getPhoneNumber:ok'){
- uni.showToast({
- title:'您已拒绝使用!',
- icon:'error'
- })
- return
- }
- this.showAuthorizePhone=false;
- this.loginBtn = false;
- let _this = this;
-
- console.log('this.scene',this.scene);
- if(!this.scene){
- await uni.getStorage({
- key: 'scene',
- success: function (res) {
- // console.log('scene====',res.data);
- if(res.data){
- _this.scene = res.data
- }
- }
- });
- }
- // this.getMobile()
- let mobileData = await this.$u.api.getMobile({code:e.detail.code});
- // console.log('mobileData',mobileData);
- let mobile = mobileData.data?.mobile;
- if(mobile){
- this.mobile = mobile
- }else{
- // uni.showToast({
- // title: '没有获取手机号',
- // icon:'error',
- // duration: 2000
- // });
- }
- this.login(e);
- this.loginBtn = true;
- },
- async login(e){
- // console.log('e',e);
- let _this = this;
- let wxinfo = null
- let data = {}
- // #ifdef MP
- wxinfo = await this.$u.api.wxinfo({code:this.code});
- let {openid,sessionKey,unionid} = wxinfo.data;
-
- _this.$u.vuex('vuex_wechatOpenid', openid);
- const { errMsg, iv, encryptedData } = e.detail;
- if (errMsg !== 'getPhoneNumber:ok') return;
-
- data = {
- code: this.code,
- encryptedData: encryptedData,
- ivStr: iv,
- openId:openid,
- sessionKey,
- sourceType:1,
- mobile:this.mobile
- }
- console.log('this.scene',this.scene);
- if(this.scene&&this.scene!='undefined'){
- await this.$u.api.uncompress({scene:this.scene}).then(res=>{
- // data.performId = res.data.performId;
- data.label = res.data.label;
- data.retailId = res.data.retailId;
- this.retailId = res.data.retailId;
- data.retailId&&uni.setStorage({
- key:'retailId',
- data:data.retailId
- });
- // console.log('uncompress',res.data);
- }).catch(err=>{
- console.log('uncompress err',err);
- })
- }
- // #endif
-
- // #ifdef H5
- wxinfo = await this.$u.api.wxinfoH5({code:this.code});
- let { openid } = wxinfo.data;
- data = {
- "openId": "",
- "h5OpenId": openid,
- "mobile": ""
- }
- // #endif
- console.log('----------登陆中',data)
- this.$u.api.login(data).then(res=>{
- // console.log('微信登录返回结果========',res.data)
- _this.$u.vuex('vuex_user_info', res.data);
- // _this.$u.vuex('vuex_member_info',res.data);
- // uni.setStorageSync('userInfo', res.data)
- this.showAuthorizePhone = false;
- // uni.removeStorage({
- // key:'scene'
- // });
- // console.log('res.data.userid',res.data.userid);
- this.getMemberInfo(res.data.userId);
-
- }).catch(err=>{
- console.log('err',err);
- this.showAuthorizePhone = false
- })
- },
- handleBindRetail(retailId){
- this.$u.api.bindRetail({retailId:retailId}).then(res=>{
- console.log('bindRetail',res);
- }).catch(err=>{
- console.log('bindRetail err',err);
- })
- },
- async getMemberInfo(userid){
- // console.log('userid',userid);
- let _this = this;
- if(this.retailId){
- await this.handleBindRetail(this.retailId);
- }
- this.$u.api.memberInfo({id:userid}).then(res=> {
- if(res.code ===200) {
- _this.userInfo = res.data;
- this.$u.vuex('vuex_member_info', res.data);
- // this.$u.vuex('vuex_member_info.avatar', 'https://mmbiz.qpic.cn/mmbiz/icTdbqWNOwNRna42FI242Lcia07jQodd2FJGIYQfG0LAJGFxM4FbnQP6yfMxBgJ0F3YRqJCJ1aPAK2dQagdusBZg/0');
- if(!res.data.name){
- this.$u.vuex('vuex_member_info.name', '微信用户');
- this.updateMemberInfo();
- }else{
- this.goBack();
- }
- // 下面需要获取微信头像和昵称
- // if(res.data.name){
- // _this.hasUserInfo = true;
- // _this.userInfo = res.data;
- // uni.navigateTo({
- // url: '/pages/index/index'
- // })
- // }else{
- // _this.showAuthorizeUser = true
- // // uni.hideLoading()
- // }
- // console.log('---------登陆成功')
-
- }
- })
- },
- goBack(){
- let url = this.backUrl&&this.backUrl.length>0?this.backUrl:'/pages/index/index';
- // console.log('url',url);
- uni.removeStorage({
- key: 'backUrl',
- success: function (res) {
- console.log('goBackurl================',decodeURIComponent(url));
- uni.reLaunch({url: decodeURIComponent(url)});
- }
- });
- },
- updateMemberInfo(){
- let params ={
- id:this.userInfo.id,
- // avatar:'https://mmbiz.qpic.cn/mmbiz/icTdbqWNOwNRna42FI242Lcia07jQodd2FJGIYQfG0LAJGFxM4FbnQP6yfMxBgJ0F3YRqJCJ1aPAK2dQagdusBZg/0',
- name:'微信用户'
- };
- this.$u.api.updateMemberInfo(params).then(res=>{
- this.goBack();
- }).catch(err=>{
- console.log('err',err);
- })
- },
- authUser(){
- let userInfo = this.vuex_user_info || {};
- // console.log('this===',this);
- // console.log('vuex_user_info===',this.vuex_user_info);
- // console.log('userInfo',userInfo);
- // console.log('this.user',this.user);
- if(!this.user.name){
- uni.showToast({
- title: '请输入您的昵称!',
- icon:'error',
- duration: 2000
- });
- return;
- }
- userInfo.avatar = this.user.avatar;
- userInfo.name = this.user.name;
- this.userInfo = userInfo;
- uni.setStorageSync('userInfo', userInfo)
- this.user.id = userInfo.userid;
- let param = {
- id:this.user.id,
- name:this.user.name,
- avatar:this.user.avatar
- }
- this.$u.api.updateMemberInfo(param).then(res=>{
- this.hasUserInfo = true;
- this.showAuthorizeUser = false;
- uni.navigateTo({
- url: '/pages/index/index'
- })
- }).catch(err=>{
- console.log('err',err);
- })
- },
- nickNameInput(e){
- this.user.name = e.detail.value
- },
- checkboxChange(e){
- this.checkboxVal = e[0];
- },
- disabledClick(){
- // console.log('checked',this.checked?.length);
- // console.log('loginBtn',this.loginBtn);
- // #ifdef MP
- if(!this.checked||this.checked?.length<=0){
- uni.showToast({
- title:'请先同意使用条款!',
- icon:'none'
- })
- }else if(this.loginBtn==false){
- uni.showToast({
- title:'登录中!',
- icon:'none'
- })
- }
- // #endif
-
- // #ifdef H5
- if(!this.checked||this.checked?.length<=0){
- uni.showToast({
- title:'请先同意使用条款!',
- icon:'none'
- })
- }else{
- uni.showToast({
- title:'登录中!',
- icon:'none'
- })
- this.redirectToAuth()
- }
- // #endif
- },
- /** 公众号 微信授权登录 */
- redirectToAuth() {
- const appid = 'wx6490eaa0d20d2be2';
- const redirectUri = encodeURIComponent('https://greath5.dev.gztjy.top/pages/login/login');
- const authUrl = `https://open.weixin.qq.com/connect/oauth2/authorize?appid=${appid}&redirect_uri=${redirectUri}&response_type=code&scope=snsapi_base&state=STATE#wechat_redirect`;
-
- window.location.href = authUrl;
- },
- }
- }
- </script>
- <style lang="scss" scoped>
- .login-bg{
- position: fixed;
- left: 0;
- right: 0;
- top: 0;
- width: 100%;
- }
- .body {
- background-color: #fff;
- box-sizing: border-box;
- text-align: center;
- .logo-wrap {
- padding-top: 25vh;
- &.dev{
- padding-top: 530rpx;
- margin-bottom: 125rpx;
- }
- img{
- display: block;
- margin: 0 auto;
- }
- .logo{
- width: 480rpx;
- height: 263rpx;
- &.dev{
- width: 380rpx;
- height: 140rpx;
- }
- }
- .sitename{
- width: 460rpx;
- height: 142rpx;
- }
- }
- }
- //
- .auth-btncard{
- margin-top: 20px;
- .btn-unok{
- width: 45%;
- float: left;
- }
- .btn-ok{
- width: 45%;
- float: left;
- margin: 0;
- padding: 0;
- border: 0px solid transparent; //自定义边框
- outline: none; //消除默认点击蓝色边框效果
- u-button{
- font-size: 16px;
- margin: 0;
- padding: 0;
- // border: 0px solid transparent; //自定义边框
- outline: none; //消除默认点击蓝色边框效果
- }
- }
- }
- .auth-card{
- text-align: center;
- .avatar-img{
- width: 150rpx;
- height: 150rpx;
- overflow: hidden;
- border-radius: 100%;
- margin-top: 30rpx;
- }
- .title{
- font-size: 30rpx;
- }
- .content{
- margin-top: 10rpx;
- margin-bottom: 20rpx;
- }
- }
- .avatar-wrapper{
- width: 150rpx;
- height: 100rpx;
- color: #333 !important;
- text-align: center !important;
- border: none !important;
- border-radius:0 !important;
- background-color:transparent !important;
- }
- .avatar-wrapper::after {
- border: none !important;
- }
- .avatar{
- width: 100rpx;
- height: 100rpx;
- overflow: hidden;
- border-radius: 100%;
- }
- .rule-wrap{
- position: fixed;
- left: 0;
- right: 0;
- bottom: 20px;
- margin: 40rpx auto;
- font-size: 24rpx;
- line-height: 1.5;
- .link{
- white-space: nowrap;
- color: #1677FF;
- }
- }
- </style>
|