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 @@
-
-
- test
-
-
-
-
-
-
-
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