From 4aaf02d4402fffd24d2a932ef65ec7f30f9272ef Mon Sep 17 00:00:00 2001 From: linju <8432241+linjuDcloud@user.noreply.gitee.com> Date: Thu, 15 Apr 2021 00:00:20 +0800 Subject: [PATCH] 123 --- App.vue | 20 ++- common/appInit.js | 117 ++++++++++--- js_sdk/wa-permission/permission.js | 272 +++++++++++++++++++++++++++++ pages.json | 2 +- pages/test/test.vue | 208 ++++++++++++++++------ pages/ucenter/ucenter.vue | 5 +- 6 files changed, 540 insertions(+), 84 deletions(-) create mode 100644 js_sdk/wa-permission/permission.js diff --git a/App.vue b/App.vue index 70bf4ab9..5f9ef245 100644 --- a/App.vue +++ b/App.vue @@ -7,7 +7,25 @@ }, onLaunch: function() { console.log('App Launch') - initApp(); + initApp(); + // #ifdef APP-PLUS + plus.oauth.getServices(oauthServices=>{ + oauthServices.forEach(({_id},item)=>{ + if(_id=='provider'){ + uni.preLogin({ + provider:item, + complete:e=>{ + console.log(e); + } + }) + } + }) + + uni.preloadPage({url: "/uni_modules/uni-login-page/pages/index/index"}); + },err=>{ + console.error('获取服务供应商失败:' + JSON.stringify(err)); + }) + // #endif }, onShow: function() { console.log('App Show') diff --git a/common/appInit.js b/common/appInit.js index 7a387b64..09caaa00 100644 --- a/common/appInit.js +++ b/common/appInit.js @@ -1,28 +1,99 @@ -import checkUpdate from '@/uni_modules/uni-upgrade-center-app/utils/check-update'; -export default function (){ +import checkUpdate from '@/uni_modules/uni-upgrade-center-app/utils/check-update'; +export default function() { + + // 初始化appVersion + initAppVersion(); + + // 检查更新 + checkUpdate(); + + //自定义路由拦截 + // setRouter() - // 初始化appVersion - initAppVersion(); - - // 检查更新 - // checkUpdate(); + //提示网络变化 + eventListenerNetwork() + +} +/** + * // 初始化appVersion + */ +function initAppVersion() { + // #ifdef APP-PLUS + let appid = plus.runtime.appid; + plus.runtime.getProperty(appid, (wgtInfo) => { + wgtInfo.version + let appVersion = plus.runtime; + getApp({ + allowDefault: true + }).appVersion = { + appid, + version: appVersion, + wgtVersion: wgtInfo, + finall: appVersion.versionCode > wgtInfo.versionCode ? appVersion : wgtInfo + } + }); + // #endif +} + +//用于拦截路由 +function setRouter() { + let before_action = e => { + let res = true + //需要登陆的页面 + let needLoginUrls = ['/pages/grid/grid'] + let token = uni.getStorageSync('uni-id-token') + if (needLoginUrls.includes(e.url) && token == '') { + res = false + console.log('该页面需要登陆,即将跳转到login页面'); + } + return res + } + let before_after = e => { + console.log('跳转之后'); + } + + let actions = ["navigateTo", "redirectTo", "reLaunch", "switchTab"] + actions.forEach(action => { + let old_action = uni[action] + uni[action] = e => { + //console.log(e); + if (before_action(e)) { + old_action(e) + before_after(e) + } + } + }) + uni.reLaunch({ + url: '/pages/grid/grid' + }) } -/** - * // 初始化appVersion - */ -function initAppVersion(){ - // #ifdef APP-PLUS - let appid = plus.runtime.appid; - plus.runtime.getProperty(appid ,(wgtInfo) => { - wgtInfo.version - let appVersion = plus.runtime; - getApp({allowDefault: true}).appVersion = { - appid, - version:appVersion, - wgtVersion:wgtInfo, - finall:appVersion.versionCode > wgtInfo.versionCode ? appVersion : wgtInfo - } + +// 设备网络状态变化事件 +function eventListenerNetwork () { + uni.onNetworkStatusChange(function(res) { + console.log(res.isConnected); + console.log(res.networkType); + if (!res.isConnected) { + uni.showModal({ + content: "你未打开网络连接", + confirmText: "前往打开", + complete: (e) => { + console.log(e); + if (uni.getSystemInfoSync().platform == "ios") { + plus.runtime.launchApplication({ + action: 'App-Prefs:root=WIFI' + }, function(e) { + console.log(JSON.stringify(e)); + }); + } else { + var main = plus.android.runtimeMainActivity(); + var Intent = plus.android.importClass("android.content.Intent"); + var mIntent = new Intent('android.settings.DATA_ROAMING_SETTINGS'); + main.startActivity(mIntent); + } + } + }); + } }); - // #endif } \ No newline at end of file diff --git a/js_sdk/wa-permission/permission.js b/js_sdk/wa-permission/permission.js new file mode 100644 index 00000000..5df56239 --- /dev/null +++ b/js_sdk/wa-permission/permission.js @@ -0,0 +1,272 @@ +/** + * 本模块封装了Android、iOS的应用权限判断、打开应用权限设置界面、以及位置系统服务是否开启 + */ + +var isIos +// #ifdef APP-PLUS +isIos = (plus.os.name == "iOS") +// #endif + +// 判断推送权限是否开启 +function judgeIosPermissionPush() { + var result = false; + var UIApplication = plus.ios.import("UIApplication"); + var app = UIApplication.sharedApplication(); + var enabledTypes = 0; + if (app.currentUserNotificationSettings) { + var settings = app.currentUserNotificationSettings(); + enabledTypes = settings.plusGetAttribute("types"); + console.log("enabledTypes1:" + enabledTypes); + if (enabledTypes == 0) { + console.log("推送权限没有开启"); + } else { + result = true; + console.log("已经开启推送功能!") + } + plus.ios.deleteObject(settings); + } else { + enabledTypes = app.enabledRemoteNotificationTypes(); + if (enabledTypes == 0) { + console.log("推送权限没有开启!"); + } else { + result = true; + console.log("已经开启推送功能!") + } + console.log("enabledTypes2:" + enabledTypes); + } + plus.ios.deleteObject(app); + plus.ios.deleteObject(UIApplication); + return result; +} + +// 判断定位权限是否开启 +function judgeIosPermissionLocation() { + var result = false; + var cllocationManger = plus.ios.import("CLLocationManager"); + var status = cllocationManger.authorizationStatus(); + result = (status != 2) + console.log("定位权限开启:" + result); + // 以下代码判断了手机设备的定位是否关闭,推荐另行使用方法 checkSystemEnableLocation + /* var enable = cllocationManger.locationServicesEnabled(); + var status = cllocationManger.authorizationStatus(); + console.log("enable:" + enable); + console.log("status:" + status); + if (enable && status != 2) { + result = true; + console.log("手机定位服务已开启且已授予定位权限"); + } else { + console.log("手机系统的定位没有打开或未给予定位权限"); + } */ + plus.ios.deleteObject(cllocationManger); + return result; +} + +// 判断麦克风权限是否开启 +function judgeIosPermissionRecord() { + var result = false; + var avaudiosession = plus.ios.import("AVAudioSession"); + var avaudio = avaudiosession.sharedInstance(); + var permissionStatus = avaudio.recordPermission(); + console.log("permissionStatus:" + permissionStatus); + if (permissionStatus == 1684369017 || permissionStatus == 1970168948) { + console.log("麦克风权限没有开启"); + } else { + result = true; + console.log("麦克风权限已经开启"); + } + plus.ios.deleteObject(avaudiosession); + return result; +} + +// 判断相机权限是否开启 +function judgeIosPermissionCamera() { + var result = false; + var AVCaptureDevice = plus.ios.import("AVCaptureDevice"); + var authStatus = AVCaptureDevice.authorizationStatusForMediaType('vide'); + console.log("authStatus:" + authStatus); + if (authStatus == 3) { + result = true; + console.log("相机权限已经开启"); + } else { + console.log("相机权限没有开启"); + } + plus.ios.deleteObject(AVCaptureDevice); + return result; +} + +// 判断相册权限是否开启 +function judgeIosPermissionPhotoLibrary() { + var result = false; + var PHPhotoLibrary = plus.ios.import("PHPhotoLibrary"); + var authStatus = PHPhotoLibrary.authorizationStatus(); + console.log("authStatus:" + authStatus); + if (authStatus == 3) { + result = true; + console.log("相册权限已经开启"); + } else { + console.log("相册权限没有开启"); + } + plus.ios.deleteObject(PHPhotoLibrary); + return result; +} + +// 判断通讯录权限是否开启 +function judgeIosPermissionContact() { + var result = false; + var CNContactStore = plus.ios.import("CNContactStore"); + var cnAuthStatus = CNContactStore.authorizationStatusForEntityType(0); + if (cnAuthStatus == 3) { + result = true; + console.log("通讯录权限已经开启"); + } else { + console.log("通讯录权限没有开启"); + } + plus.ios.deleteObject(CNContactStore); + return result; +} + +// 判断日历权限是否开启 +function judgeIosPermissionCalendar() { + var result = false; + var EKEventStore = plus.ios.import("EKEventStore"); + var ekAuthStatus = EKEventStore.authorizationStatusForEntityType(0); + if (ekAuthStatus == 3) { + result = true; + console.log("日历权限已经开启"); + } else { + console.log("日历权限没有开启"); + } + plus.ios.deleteObject(EKEventStore); + return result; +} + +// 判断备忘录权限是否开启 +function judgeIosPermissionMemo() { + var result = false; + var EKEventStore = plus.ios.import("EKEventStore"); + var ekAuthStatus = EKEventStore.authorizationStatusForEntityType(1); + if (ekAuthStatus == 3) { + result = true; + console.log("备忘录权限已经开启"); + } else { + console.log("备忘录权限没有开启"); + } + plus.ios.deleteObject(EKEventStore); + return result; +} + +// Android权限查询 +function requestAndroidPermission(permissionID) { + return new Promise((resolve, reject) => { + plus.android.requestPermissions( + [permissionID], // 理论上支持多个权限同时查询,但实际上本函数封装只处理了一个权限的情况。有需要的可自行扩展封装 + function(resultObj) { + var result = 0; + for (var i = 0; i < resultObj.granted.length; i++) { + var grantedPermission = resultObj.granted[i]; + console.log('已获取的权限:' + grantedPermission); + result = 1 + } + for (var i = 0; i < resultObj.deniedPresent.length; i++) { + var deniedPresentPermission = resultObj.deniedPresent[i]; + console.log('拒绝本次申请的权限:' + deniedPresentPermission); + result = 0 + } + for (var i = 0; i < resultObj.deniedAlways.length; i++) { + var deniedAlwaysPermission = resultObj.deniedAlways[i]; + console.log('永久拒绝申请的权限:' + deniedAlwaysPermission); + result = -1 + } + resolve(result); + // 若所需权限被拒绝,则打开APP设置界面,可以在APP设置界面打开相应权限 + // if (result != 1) { + // gotoAppPermissionSetting() + // } + }, + function(error) { + console.log('申请权限错误:' + error.code + " = " + error.message); + resolve({ + code: error.code, + message: error.message + }); + } + ); + }); +} + +// 使用一个方法,根据参数判断权限 +function judgeIosPermission(permissionID) { + if (permissionID == "location") { + return judgeIosPermissionLocation() + } else if (permissionID == "camera") { + return judgeIosPermissionCamera() + } else if (permissionID == "photoLibrary") { + return judgeIosPermissionPhotoLibrary() + } else if (permissionID == "record") { + return judgeIosPermissionRecord() + } else if (permissionID == "push") { + return judgeIosPermissionPush() + } else if (permissionID == "contact") { + return judgeIosPermissionContact() + } else if (permissionID == "calendar") { + return judgeIosPermissionCalendar() + } else if (permissionID == "memo") { + return judgeIosPermissionMemo() + } + return false; +} + +// 跳转到**应用**的权限页面 +function gotoAppPermissionSetting() { + if (isIos) { + var UIApplication = plus.ios.import("UIApplication"); + var application2 = UIApplication.sharedApplication(); + var NSURL2 = plus.ios.import("NSURL"); + // var setting2 = NSURL2.URLWithString("prefs:root=LOCATION_SERVICES"); + var setting2 = NSURL2.URLWithString("app-settings:"); + application2.openURL(setting2); + + plus.ios.deleteObject(setting2); + plus.ios.deleteObject(NSURL2); + plus.ios.deleteObject(application2); + } else { + // console.log(plus.device.vendor); + var Intent = plus.android.importClass("android.content.Intent"); + var Settings = plus.android.importClass("android.provider.Settings"); + var Uri = plus.android.importClass("android.net.Uri"); + var mainActivity = plus.android.runtimeMainActivity(); + var intent = new Intent(); + intent.setAction(Settings.ACTION_APPLICATION_DETAILS_SETTINGS); + var uri = Uri.fromParts("package", mainActivity.getPackageName(), null); + intent.setData(uri); + mainActivity.startActivity(intent); + } +} + +// 检查系统的设备服务是否开启 +// var checkSystemEnableLocation = async function () { +function checkSystemEnableLocation() { + if (isIos) { + var result = false; + var cllocationManger = plus.ios.import("CLLocationManager"); + var result = cllocationManger.locationServicesEnabled(); + console.log("系统定位开启:" + result); + plus.ios.deleteObject(cllocationManger); + return result; + } else { + var context = plus.android.importClass("android.content.Context"); + var locationManager = plus.android.importClass("android.location.LocationManager"); + var main = plus.android.runtimeMainActivity(); + var mainSvr = main.getSystemService(context.LOCATION_SERVICE); + var result = mainSvr.isProviderEnabled(locationManager.GPS_PROVIDER); + console.log("系统定位开启:" + result); + return result + } +} + +module.exports = { + judgeIosPermission: judgeIosPermission, + requestAndroidPermission: requestAndroidPermission, + checkSystemEnableLocation: checkSystemEnableLocation, + gotoAppPermissionSetting: gotoAppPermissionSetting +} diff --git a/pages.json b/pages.json index da15f581..0a76bf77 100644 --- a/pages.json +++ b/pages.json @@ -213,7 +213,7 @@ "path": "pages/test/test" } ], - "current":1 + "current":0 }, "tabBar": { "color": "#7A7E83", diff --git a/pages/test/test.vue b/pages/test/test.vue index 4ebb2801..f84fe7e0 100644 --- a/pages/test/test.vue +++ b/pages/test/test.vue @@ -1,64 +1,158 @@ - - - - - diff --git a/pages/ucenter/ucenter.vue b/pages/ucenter/ucenter.vue index 68b92669..ea172cf0 100644 --- a/pages/ucenter/ucenter.vue +++ b/pages/ucenter/ucenter.vue @@ -2,8 +2,9 @@ - - Hi,{{login ? userInfo.username : '您未登录'}} + + {{JSON.stringify(userInfo)}} + {{login ? userInfo.nickname||userInfo.mobile : '您未登录'}} -- GitLab