mirror of
https://github.com/crmeb/CRMEB.git
synced 2026-01-31 09:48:14 +00:00
267 lines
7.0 KiB
Vue
267 lines
7.0 KiB
Vue
<script>
|
|
import {
|
|
checkLogin
|
|
} from './libs/login';
|
|
import {
|
|
HTTP_REQUEST_URL
|
|
} from './config/app';
|
|
import {
|
|
getShopConfig,
|
|
silenceAuth
|
|
} from '@/api/public';
|
|
import Auth from './libs/wechat.js';
|
|
import Routine from '@/libs/routine.js';
|
|
export default {
|
|
globalData: {
|
|
spid: 0,
|
|
code: 0,
|
|
isLogin: false,
|
|
userInfo: {},
|
|
MyMenus: [],
|
|
globalData: false,
|
|
isIframe: false,
|
|
tabbarShow: true
|
|
},
|
|
onLaunch: function(option) {
|
|
let that = this;
|
|
// #ifdef MP
|
|
if (HTTP_REQUEST_URL == '') {
|
|
console.error(
|
|
"请配置根目录下的config.js文件中的 'HTTP_REQUEST_URL'\n\n请修改开发者工具中【详情】->【AppID】改为自己的Appid\n\n请前往后台【小程序】->【小程序配置】填写自己的 appId and AppSecret"
|
|
);
|
|
return false;
|
|
}
|
|
if (option.query.hasOwnProperty('scene')) {
|
|
switch (option.scene) {
|
|
//扫描小程序码
|
|
case 1047:
|
|
let val = that.$util.getUrlParams(decodeURIComponent(option.query.scene));
|
|
that.globalData.code = val.pid === undefined ? val : val.pid;
|
|
break;
|
|
//长按图片识别小程序码
|
|
case 1048:
|
|
that.globalData.code = option.query.scene;
|
|
break;
|
|
//手机相册选取小程序码
|
|
case 1049:
|
|
that.globalData.code = option.query.scene;
|
|
break;
|
|
//直接进入小程序
|
|
case 1001:
|
|
that.globalData.spid = option.query.scene;
|
|
break;
|
|
}
|
|
}
|
|
const updateManager = uni.getUpdateManager();
|
|
|
|
updateManager.onCheckForUpdate(function(res) {
|
|
// 请求完新版本信息的回调
|
|
});
|
|
|
|
updateManager.onUpdateReady(function() {
|
|
uni.showModal({
|
|
title: '更新提示',
|
|
content: '新版本已经准备好,是否重启应用?',
|
|
success: function(res) {
|
|
if (res.confirm) {
|
|
// 新的版本已经下载好,调用 applyUpdate 应用新版本并重启
|
|
updateManager.applyUpdate();
|
|
}
|
|
}
|
|
});
|
|
});
|
|
updateManager.onUpdateFailed(function() {
|
|
return that.Tips({
|
|
title: '新版本下载失败'
|
|
});
|
|
});
|
|
// #endif
|
|
getShopConfig().then(res => {
|
|
this.$store.commit('SETPHONESTATUS', res.data.status);
|
|
});
|
|
// 获取导航高度;
|
|
uni.getSystemInfo({
|
|
success: function(res) {
|
|
that.globalData.navHeight = res.statusBarHeight * (750 / res.windowWidth) + 91;
|
|
}
|
|
});
|
|
|
|
// #ifdef H5
|
|
uni.getSystemInfo({
|
|
success(e) {
|
|
/* 窗口宽度大于420px且不在PC页面且不在移动设备时跳转至 PC.html 页面 */
|
|
if (e.windowWidth > 420 && !window.top.isPC && !/iOS|Android/i.test(e.system)) {
|
|
window.location.pathname = '/static/html/pc.html';
|
|
}
|
|
}
|
|
})
|
|
if (option.query.hasOwnProperty('type') && option.query.type == "iframeMakkMinkkJuan") {
|
|
this.globalData.isIframe = true;
|
|
} else {
|
|
this.globalData.isIframe = false;
|
|
}
|
|
// try {
|
|
// // 静默授权code
|
|
// var snsapiCode = uni.getStorageSync('snsapiCode');
|
|
// } catch (e) {}
|
|
if(window.location.pathname !== '/'){
|
|
let snsapiBase = 'snsapi_base';
|
|
let urlData = location.pathname + location.search;
|
|
// if (snsapiCode) {
|
|
// return
|
|
// } else {
|
|
if (!that.$store.getters.isLogin && Auth.isWeixin()) {
|
|
const {
|
|
code,
|
|
state,
|
|
scope
|
|
} = option.query;
|
|
if (code && code != uni.getStorageSync('snsapiCode') && location.pathname.indexOf(
|
|
'/pages/users/wechat_login/index') === -1) {
|
|
// 存储静默授权code
|
|
uni.setStorageSync('snsapiCode', code);
|
|
let spread = that.globalData.spid ? that.globalData.spid : '';
|
|
silenceAuth({
|
|
code: code,
|
|
spread: that.$Cache.get('spread'),
|
|
spid: that.globalData.code
|
|
})
|
|
.then(res => {
|
|
uni.setStorageSync('snRouter', decodeURIComponent(decodeURIComponent(option.query
|
|
.back_url)));
|
|
if (res.data.key !== undefined && res.data.key) {
|
|
this.$Cache.set('snsapiKey', res.data.key);
|
|
} else {
|
|
let time = res.data.expires_time - this.$Cache.time();
|
|
this.$store.commit('LOGIN', {
|
|
token: res.data.token,
|
|
time: time
|
|
});
|
|
this.$store.commit('SETUID', res.data.userInfo.uid);
|
|
this.$store.commit('UPDATE_USERINFO', res.data.userInfo);
|
|
// location.href = decodeURIComponent(decodeURIComponent(option.query.back_url));
|
|
}
|
|
})
|
|
.catch(res => {
|
|
let url = ''
|
|
if (option.query.back_url instanceof Array) {
|
|
url = option.query.back_url[option.query.back_url.length - 1]
|
|
} else {
|
|
url = option.query.back_url
|
|
}
|
|
if (!that.$Cache.has('snsapiKey')) {
|
|
if (location.pathname.indexOf('/pages/users/wechat_login/index') === -1) {
|
|
Auth.oAuth(snsapiBase, url);
|
|
}
|
|
}
|
|
});
|
|
} else {
|
|
if (!this.$Cache.has('snsapiKey')) {
|
|
if (location.pathname.indexOf('/pages/users/wechat_login/index') === -1) {
|
|
Auth.oAuth(snsapiBase, urlData);
|
|
}
|
|
}
|
|
}
|
|
} else {
|
|
if (option.query.back_url) {
|
|
// alert(uni.getStorageSync('snsapiCode'))
|
|
// alert(uni.getStorageSync('snRouter'))
|
|
location.href = uni.getStorageSync('snRouter')
|
|
}
|
|
}
|
|
}
|
|
// }
|
|
|
|
// #endif
|
|
// #ifdef MP
|
|
// 小程序静默授权
|
|
console.log(this.$store.getters.isLogin, 'this.$store');
|
|
if (!this.$store.getters.isLogin) {
|
|
Routine.getCode()
|
|
.then(code => {
|
|
this.silenceAuth(code);
|
|
})
|
|
.catch(res => {
|
|
uni.hideLoading();
|
|
});
|
|
}
|
|
// #endif
|
|
},
|
|
mounted() {},
|
|
methods: {
|
|
// 小程序静默授权
|
|
silenceAuth(code) {
|
|
let that = this;
|
|
let spread = that.globalData.spid ? that.globalData.spid : '';
|
|
silenceAuth({
|
|
code: code,
|
|
spread_spid: spread,
|
|
spread_code: that.globalData.code
|
|
})
|
|
.then(res => {
|
|
if (res.data.token !== undefined && res.data.token) {
|
|
uni.hideLoading();
|
|
let time = res.data.expires_time - this.$Cache.time();
|
|
that.$store.commit('LOGIN', {
|
|
token: res.data.token,
|
|
time: time
|
|
});
|
|
that.$store.commit('SETUID', res.data.userInfo.uid);
|
|
that.$store.commit('UPDATE_USERINFO', res.data.userInfo);
|
|
}
|
|
})
|
|
.catch(res => {
|
|
console.log(res);
|
|
});
|
|
}
|
|
},
|
|
onHide: function() {
|
|
//console.log('App Hide')
|
|
}
|
|
};
|
|
</script>
|
|
|
|
<style>
|
|
@import url("@/plugin/emoji-awesome/css/google.min.css");
|
|
@import url('@/plugin/animate/animate.min.css');
|
|
@import 'static/css/base.css';
|
|
@import 'static/iconfont/iconfont.css';
|
|
@import 'static/css/guildford.css';
|
|
@import 'static/css/style.scss';
|
|
|
|
|
|
/* #ifdef H5 */
|
|
body::-webkit-scrollbar,
|
|
html::-webkit-scrollbar {
|
|
display: none;
|
|
}
|
|
|
|
/* #endif */
|
|
view {
|
|
box-sizing: border-box;
|
|
}
|
|
|
|
.bg-color-red {
|
|
background-color: #e93323 !important;
|
|
}
|
|
|
|
.syspadding {
|
|
padding-top: var(--status-bar-height);
|
|
}
|
|
|
|
.flex {
|
|
display: flex;
|
|
}
|
|
|
|
.uni-scroll-view::-webkit-scrollbar {
|
|
/* 隐藏滚动条,但依旧具备可以滚动的功能 */
|
|
display: none;
|
|
}
|
|
|
|
::-webkit-scrollbar {
|
|
width: 0;
|
|
height: 0;
|
|
color: transparent;
|
|
}
|
|
</style>
|