隐私政策弹窗添加描述
This commit is contained in:
@@ -1,272 +1,405 @@
|
|||||||
/**
|
/**
|
||||||
* 本模块封装了Android、iOS的应用权限判断、打开应用权限设置界面、以及位置系统服务是否开启
|
* 本模块封装了Android、iOS的应用权限判断、打开应用权限设置界面、以及位置系统服务是否开启
|
||||||
*/
|
*/
|
||||||
|
var isIos
|
||||||
|
// #ifdef APP-PLUS
|
||||||
|
isIos = (plus.os.name == "iOS")
|
||||||
|
// #endif
|
||||||
|
|
||||||
var isIos
|
// 判断推送权限是否开启
|
||||||
// #ifdef APP-PLUS
|
function judgeIosPermissionPush() {
|
||||||
isIos = (plus.os.name == "iOS")
|
var result = false;
|
||||||
// #endif
|
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 judgeIosPermissionPush() {
|
function judgeIosPermissionLocation() {
|
||||||
var result = false;
|
var result = false;
|
||||||
var UIApplication = plus.ios.import("UIApplication");
|
var cllocationManger = plus.ios.import("CLLocationManager");
|
||||||
var app = UIApplication.sharedApplication();
|
var status = cllocationManger.authorizationStatus();
|
||||||
var enabledTypes = 0;
|
result = (status != 2)
|
||||||
if (app.currentUserNotificationSettings) {
|
console.log("定位权限开启:" + result);
|
||||||
var settings = app.currentUserNotificationSettings();
|
// 以下代码判断了手机设备的定位是否关闭,推荐另行使用方法 checkSystemEnableLocation
|
||||||
enabledTypes = settings.plusGetAttribute("types");
|
/* var enable = cllocationManger.locationServicesEnabled();
|
||||||
console.log("enabledTypes1:" + enabledTypes);
|
var status = cllocationManger.authorizationStatus();
|
||||||
if (enabledTypes == 0) {
|
console.log("enable:" + enable);
|
||||||
console.log("推送权限没有开启");
|
console.log("status:" + status);
|
||||||
} else {
|
if (enable && status != 2) {
|
||||||
result = true;
|
result = true;
|
||||||
console.log("已经开启推送功能!")
|
console.log("手机定位服务已开启且已授予定位权限");
|
||||||
}
|
} else {
|
||||||
plus.ios.deleteObject(settings);
|
console.log("手机系统的定位没有打开或未给予定位权限");
|
||||||
} else {
|
} */
|
||||||
enabledTypes = app.enabledRemoteNotificationTypes();
|
plus.ios.deleteObject(cllocationManger);
|
||||||
if (enabledTypes == 0) {
|
return result;
|
||||||
console.log("推送权限没有开启!");
|
}
|
||||||
} else {
|
|
||||||
result = true;
|
|
||||||
console.log("已经开启推送功能!")
|
|
||||||
}
|
|
||||||
console.log("enabledTypes2:" + enabledTypes);
|
|
||||||
}
|
|
||||||
plus.ios.deleteObject(app);
|
|
||||||
plus.ios.deleteObject(UIApplication);
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
// 判断定位权限是否开启
|
// 判断麦克风权限是否开启
|
||||||
function judgeIosPermissionLocation() {
|
function judgeIosPermissionRecord() {
|
||||||
var result = false;
|
var result = false;
|
||||||
var cllocationManger = plus.ios.import("CLLocationManager");
|
var avaudiosession = plus.ios.import("AVAudioSession");
|
||||||
var status = cllocationManger.authorizationStatus();
|
var avaudio = avaudiosession.sharedInstance();
|
||||||
result = (status != 2)
|
var permissionStatus = avaudio.recordPermission();
|
||||||
console.log("定位权限开启:" + result);
|
console.log("permissionStatus:" + permissionStatus);
|
||||||
// 以下代码判断了手机设备的定位是否关闭,推荐另行使用方法 checkSystemEnableLocation
|
if (permissionStatus == 1684369017 || permissionStatus == 1970168948) {
|
||||||
/* var enable = cllocationManger.locationServicesEnabled();
|
console.log("麦克风权限没有开启");
|
||||||
var status = cllocationManger.authorizationStatus();
|
} else {
|
||||||
console.log("enable:" + enable);
|
result = true;
|
||||||
console.log("status:" + status);
|
console.log("麦克风权限已经开启");
|
||||||
if (enable && status != 2) {
|
}
|
||||||
result = true;
|
plus.ios.deleteObject(avaudiosession);
|
||||||
console.log("手机定位服务已开启且已授予定位权限");
|
return result;
|
||||||
} else {
|
}
|
||||||
console.log("手机系统的定位没有打开或未给予定位权限");
|
|
||||||
} */
|
|
||||||
plus.ios.deleteObject(cllocationManger);
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
// 判断麦克风权限是否开启
|
// 判断相机权限是否开启
|
||||||
function judgeIosPermissionRecord() {
|
function judgeIosPermissionCamera() {
|
||||||
var result = false;
|
var result = false;
|
||||||
var avaudiosession = plus.ios.import("AVAudioSession");
|
var AVCaptureDevice = plus.ios.import("AVCaptureDevice");
|
||||||
var avaudio = avaudiosession.sharedInstance();
|
var authStatus = AVCaptureDevice.authorizationStatusForMediaType('vide');
|
||||||
var permissionStatus = avaudio.recordPermission();
|
console.log("authStatus:" + authStatus);
|
||||||
console.log("permissionStatus:" + permissionStatus);
|
if (authStatus == 3) {
|
||||||
if (permissionStatus == 1684369017 || permissionStatus == 1970168948) {
|
result = true;
|
||||||
console.log("麦克风权限没有开启");
|
console.log("相机权限已经开启");
|
||||||
} else {
|
} else {
|
||||||
result = true;
|
console.log("相机权限没有开启");
|
||||||
console.log("麦克风权限已经开启");
|
}
|
||||||
}
|
plus.ios.deleteObject(AVCaptureDevice);
|
||||||
plus.ios.deleteObject(avaudiosession);
|
return result;
|
||||||
return result;
|
}
|
||||||
}
|
|
||||||
|
|
||||||
// 判断相机权限是否开启
|
// 判断相册权限是否开启
|
||||||
function judgeIosPermissionCamera() {
|
function judgeIosPermissionPhotoLibrary() {
|
||||||
var result = false;
|
var result = false;
|
||||||
var AVCaptureDevice = plus.ios.import("AVCaptureDevice");
|
var PHPhotoLibrary = plus.ios.import("PHPhotoLibrary");
|
||||||
var authStatus = AVCaptureDevice.authorizationStatusForMediaType('vide');
|
var authStatus = PHPhotoLibrary.authorizationStatus();
|
||||||
console.log("authStatus:" + authStatus);
|
console.log("authStatus:" + authStatus);
|
||||||
if (authStatus == 3) {
|
if (authStatus == 3) {
|
||||||
result = true;
|
result = true;
|
||||||
console.log("相机权限已经开启");
|
console.log("相册权限已经开启");
|
||||||
} else {
|
} else {
|
||||||
console.log("相机权限没有开启");
|
console.log("相册权限没有开启");
|
||||||
}
|
}
|
||||||
plus.ios.deleteObject(AVCaptureDevice);
|
plus.ios.deleteObject(PHPhotoLibrary);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
// 判断相册权限是否开启
|
// 判断通讯录权限是否开启
|
||||||
function judgeIosPermissionPhotoLibrary() {
|
function judgeIosPermissionContact() {
|
||||||
var result = false;
|
var result = false;
|
||||||
var PHPhotoLibrary = plus.ios.import("PHPhotoLibrary");
|
var CNContactStore = plus.ios.import("CNContactStore");
|
||||||
var authStatus = PHPhotoLibrary.authorizationStatus();
|
var cnAuthStatus = CNContactStore.authorizationStatusForEntityType(0);
|
||||||
console.log("authStatus:" + authStatus);
|
if (cnAuthStatus == 3) {
|
||||||
if (authStatus == 3) {
|
result = true;
|
||||||
result = true;
|
console.log("通讯录权限已经开启");
|
||||||
console.log("相册权限已经开启");
|
} else {
|
||||||
} else {
|
console.log("通讯录权限没有开启");
|
||||||
console.log("相册权限没有开启");
|
}
|
||||||
}
|
plus.ios.deleteObject(CNContactStore);
|
||||||
plus.ios.deleteObject(PHPhotoLibrary);
|
return result;
|
||||||
return result;
|
}
|
||||||
}
|
|
||||||
|
|
||||||
// 判断通讯录权限是否开启
|
// 判断日历权限是否开启
|
||||||
function judgeIosPermissionContact() {
|
function judgeIosPermissionCalendar() {
|
||||||
var result = false;
|
var result = false;
|
||||||
var CNContactStore = plus.ios.import("CNContactStore");
|
var EKEventStore = plus.ios.import("EKEventStore");
|
||||||
var cnAuthStatus = CNContactStore.authorizationStatusForEntityType(0);
|
var ekAuthStatus = EKEventStore.authorizationStatusForEntityType(0);
|
||||||
if (cnAuthStatus == 3) {
|
if (ekAuthStatus == 3) {
|
||||||
result = true;
|
result = true;
|
||||||
console.log("通讯录权限已经开启");
|
console.log("日历权限已经开启");
|
||||||
} else {
|
} else {
|
||||||
console.log("通讯录权限没有开启");
|
console.log("日历权限没有开启");
|
||||||
}
|
}
|
||||||
plus.ios.deleteObject(CNContactStore);
|
plus.ios.deleteObject(EKEventStore);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
// 判断日历权限是否开启
|
// 判断备忘录权限是否开启
|
||||||
function judgeIosPermissionCalendar() {
|
function judgeIosPermissionMemo() {
|
||||||
var result = false;
|
var result = false;
|
||||||
var EKEventStore = plus.ios.import("EKEventStore");
|
var EKEventStore = plus.ios.import("EKEventStore");
|
||||||
var ekAuthStatus = EKEventStore.authorizationStatusForEntityType(0);
|
var ekAuthStatus = EKEventStore.authorizationStatusForEntityType(1);
|
||||||
if (ekAuthStatus == 3) {
|
if (ekAuthStatus == 3) {
|
||||||
result = true;
|
result = true;
|
||||||
console.log("日历权限已经开启");
|
console.log("备忘录权限已经开启");
|
||||||
} else {
|
} else {
|
||||||
console.log("日历权限没有开启");
|
console.log("备忘录权限没有开启");
|
||||||
}
|
}
|
||||||
plus.ios.deleteObject(EKEventStore);
|
plus.ios.deleteObject(EKEventStore);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
// 判断备忘录权限是否开启
|
// Android权限查询
|
||||||
function judgeIosPermissionMemo() {
|
function requestAndroidPermission(permissionID) {
|
||||||
var result = false;
|
return new Promise((resolve, reject) => {
|
||||||
var EKEventStore = plus.ios.import("EKEventStore");
|
plus.android.requestPermissions(
|
||||||
var ekAuthStatus = EKEventStore.authorizationStatusForEntityType(1);
|
permissionID.split(","),
|
||||||
if (ekAuthStatus == 3) {
|
// [permissionID], // 理论上支持多个权限同时查询,但实际上本函数封装只处理了一个权限的情况。有需要的可自行扩展封装
|
||||||
result = true;
|
function(resultObj) {
|
||||||
console.log("备忘录权限已经开启");
|
var result = 0;
|
||||||
} else {
|
for (var i = 0; i < resultObj.granted.length; i++) {
|
||||||
console.log("备忘录权限没有开启");
|
var grantedPermission = resultObj.granted[i];
|
||||||
}
|
console.log('已获取的权限:' + grantedPermission);
|
||||||
plus.ios.deleteObject(EKEventStore);
|
result = 1
|
||||||
return result;
|
}
|
||||||
}
|
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
|
||||||
|
});
|
||||||
|
}
|
||||||
|
);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
// Android权限查询
|
// 使用一个方法,根据参数判断权限
|
||||||
function requestAndroidPermission(permissionID) {
|
function judgeIosPermission(permissionID) {
|
||||||
return new Promise((resolve, reject) => {
|
if (permissionID == "location") {
|
||||||
plus.android.requestPermissions(
|
return judgeIosPermissionLocation()
|
||||||
[permissionID], // 理论上支持多个权限同时查询,但实际上本函数封装只处理了一个权限的情况。有需要的可自行扩展封装
|
} else if (permissionID == "camera") {
|
||||||
function(resultObj) {
|
return judgeIosPermissionCamera()
|
||||||
var result = 0;
|
} else if (permissionID == "photoLibrary") {
|
||||||
for (var i = 0; i < resultObj.granted.length; i++) {
|
return judgeIosPermissionPhotoLibrary()
|
||||||
var grantedPermission = resultObj.granted[i];
|
} else if (permissionID == "record") {
|
||||||
console.log('已获取的权限:' + grantedPermission);
|
return judgeIosPermissionRecord()
|
||||||
result = 1
|
} else if (permissionID == "push") {
|
||||||
}
|
return judgeIosPermissionPush()
|
||||||
for (var i = 0; i < resultObj.deniedPresent.length; i++) {
|
} else if (permissionID == "contact") {
|
||||||
var deniedPresentPermission = resultObj.deniedPresent[i];
|
return judgeIosPermissionContact()
|
||||||
console.log('拒绝本次申请的权限:' + deniedPresentPermission);
|
} else if (permissionID == "calendar") {
|
||||||
result = 0
|
return judgeIosPermissionCalendar()
|
||||||
}
|
} else if (permissionID == "memo") {
|
||||||
for (var i = 0; i < resultObj.deniedAlways.length; i++) {
|
return judgeIosPermissionMemo()
|
||||||
var deniedAlwaysPermission = resultObj.deniedAlways[i];
|
}
|
||||||
console.log('永久拒绝申请的权限:' + deniedAlwaysPermission);
|
return false;
|
||||||
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) {
|
function gotoAppPermissionSetting() {
|
||||||
if (permissionID == "location") {
|
if (isIos) {
|
||||||
return judgeIosPermissionLocation()
|
var UIApplication = plus.ios.import("UIApplication");
|
||||||
} else if (permissionID == "camera") {
|
var application2 = UIApplication.sharedApplication();
|
||||||
return judgeIosPermissionCamera()
|
var NSURL2 = plus.ios.import("NSURL");
|
||||||
} else if (permissionID == "photoLibrary") {
|
// var setting2 = NSURL2.URLWithString("prefs:root=LOCATION_SERVICES");
|
||||||
return judgeIosPermissionPhotoLibrary()
|
var setting2 = NSURL2.URLWithString("app-settings:");
|
||||||
} else if (permissionID == "record") {
|
application2.openURL(setting2);
|
||||||
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;
|
|
||||||
}
|
|
||||||
|
|
||||||
// 跳转到**应用**的权限页面
|
plus.ios.deleteObject(setting2);
|
||||||
function gotoAppPermissionSetting() {
|
plus.ios.deleteObject(NSURL2);
|
||||||
if (isIos) {
|
plus.ios.deleteObject(application2);
|
||||||
var UIApplication = plus.ios.import("UIApplication");
|
} else {
|
||||||
var application2 = UIApplication.sharedApplication();
|
// console.log(plus.device.vendor);
|
||||||
var NSURL2 = plus.ios.import("NSURL");
|
var Intent = plus.android.importClass("android.content.Intent");
|
||||||
// var setting2 = NSURL2.URLWithString("prefs:root=LOCATION_SERVICES");
|
var Settings = plus.android.importClass("android.provider.Settings");
|
||||||
var setting2 = NSURL2.URLWithString("app-settings:");
|
var Uri = plus.android.importClass("android.net.Uri");
|
||||||
application2.openURL(setting2);
|
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);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
plus.ios.deleteObject(setting2);
|
// 检查系统的设备服务是否开启
|
||||||
plus.ios.deleteObject(NSURL2);
|
// var checkSystemEnableLocation = async function () {
|
||||||
plus.ios.deleteObject(application2);
|
function checkSystemEnableLocation() {
|
||||||
} else {
|
if (isIos) {
|
||||||
// console.log(plus.device.vendor);
|
var result = false;
|
||||||
var Intent = plus.android.importClass("android.content.Intent");
|
var cllocationManger = plus.ios.import("CLLocationManager");
|
||||||
var Settings = plus.android.importClass("android.provider.Settings");
|
var result = cllocationManger.locationServicesEnabled();
|
||||||
var Uri = plus.android.importClass("android.net.Uri");
|
console.log("系统定位开启:" + result);
|
||||||
var mainActivity = plus.android.runtimeMainActivity();
|
plus.ios.deleteObject(cllocationManger);
|
||||||
var intent = new Intent();
|
return result;
|
||||||
intent.setAction(Settings.ACTION_APPLICATION_DETAILS_SETTINGS);
|
} else {
|
||||||
var uri = Uri.fromParts("package", mainActivity.getPackageName(), null);
|
var context = plus.android.importClass("android.content.Context");
|
||||||
intent.setData(uri);
|
var locationManager = plus.android.importClass("android.location.LocationManager");
|
||||||
mainActivity.startActivity(intent);
|
var main = plus.android.runtimeMainActivity();
|
||||||
}
|
var mainSvr = main.getSystemService(context.LOCATION_SERVICE);
|
||||||
}
|
var result = mainSvr.isProviderEnabled(locationManager.GPS_PROVIDER);
|
||||||
|
console.log("系统定位开启:" + result);
|
||||||
|
return result
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// 检查系统的设备服务是否开启
|
let permissionMap = {
|
||||||
// var checkSystemEnableLocation = async function () {
|
"android": {
|
||||||
function checkSystemEnableLocation() {
|
"CAMERA_EXTERNAL_STORAGE": {
|
||||||
if (isIos) {
|
"name": "android.permission.READ_EXTERNAL_STORAGE,android.permission.WRITE_EXTERNAL_STORAGE,android.permission.CAMERA",
|
||||||
var result = false;
|
"title": "相机/相册权限说明",
|
||||||
var cllocationManger = plus.ios.import("CLLocationManager");
|
"content": "便于您使用该功能上传您的照片/图片用于上传用户头像、留言上传图片、申诉反馈上传图片等场景中读取和写入相册和文件内容"
|
||||||
var result = cllocationManger.locationServicesEnabled();
|
},
|
||||||
console.log("系统定位开启:" + result);
|
"CAMERA": {
|
||||||
plus.ios.deleteObject(cllocationManger);
|
"name": "android.permission.CAMERA",
|
||||||
return result;
|
"title": "相机权限说明",
|
||||||
} else {
|
"content": "便于您使用该功能上传您的照片/图片用于上传用户头像、留言上传图片、申诉反馈上传图片等场景中拍摄图片"
|
||||||
var context = plus.android.importClass("android.content.Context");
|
},
|
||||||
var locationManager = plus.android.importClass("android.location.LocationManager");
|
// "EXTERNAL_STORAGE": {
|
||||||
var main = plus.android.runtimeMainActivity();
|
// "name": "android.permission.READ_EXTERNAL_STORAGE,android.permission.WRITE_EXTERNAL_STORAGE",
|
||||||
var mainSvr = main.getSystemService(context.LOCATION_SERVICE);
|
// "title": "相册权限说明",
|
||||||
var result = mainSvr.isProviderEnabled(locationManager.GPS_PROVIDER);
|
// "content": "便于您使用该功能上传您的照片/图片/视频及用于上传工单故障、维修图片、扫码识别设备等信息、意见反馈上传图片、上传设备、客户、设备图片等场景中读取和写入相册和文件内容"
|
||||||
console.log("系统定位开启:" + result);
|
// },
|
||||||
return result
|
// "LOCATION": {
|
||||||
}
|
// "name": "android.location.LocationManager",
|
||||||
}
|
// "title": "定位权限说明",
|
||||||
|
// "content": "便于您使用该功能定位您当前的位置,并上报当前位置给服务器,来智能得按照当前位置给您分配距离您最近的工单信息等功能"
|
||||||
|
// },
|
||||||
|
// "CALLPHONE": {
|
||||||
|
// "name": "android.permission.CALL_PHONE",
|
||||||
|
// "title": "拨打电话权限说明",
|
||||||
|
// "content": "便于您使用该功能能够快速和提交工单信息的客户进行联系并进行及时处理"
|
||||||
|
// },
|
||||||
|
},
|
||||||
|
"ios": {}
|
||||||
|
}
|
||||||
|
|
||||||
|
let view = null;
|
||||||
|
let viewShow = false;
|
||||||
|
|
||||||
|
function showViewDesc(permission) {
|
||||||
|
let plat = isIos ? "ios" : "android";
|
||||||
|
view = new plus.nativeObj.View('per-modal', {
|
||||||
|
top: '0px',
|
||||||
|
left: '0px',
|
||||||
|
width: '100%',
|
||||||
|
backgroundColor: 'rgba(0,0,0,0.4)',
|
||||||
|
//opacity: '.9'
|
||||||
|
})
|
||||||
|
view.drawRect({
|
||||||
|
color: '#fff',
|
||||||
|
radius: '5px'
|
||||||
|
}, {
|
||||||
|
top: '170px',
|
||||||
|
left: '5%',
|
||||||
|
width: '90%',
|
||||||
|
height: "150px",
|
||||||
|
})
|
||||||
|
view.drawText(permissionMap[plat][permission]["title"], {
|
||||||
|
top: '180px',
|
||||||
|
left: "8%",
|
||||||
|
height: "30px"
|
||||||
|
}, {
|
||||||
|
align: "left",
|
||||||
|
color: "#000",
|
||||||
|
}, {
|
||||||
|
onClick: function(e) {
|
||||||
|
console.log(e);
|
||||||
|
}
|
||||||
|
})
|
||||||
|
view.drawText(permissionMap[plat][permission]["content"], {
|
||||||
|
top: '210px',
|
||||||
|
height: "80px",
|
||||||
|
left: "8%",
|
||||||
|
width: "84%"
|
||||||
|
}, {
|
||||||
|
whiteSpace: 'normal',
|
||||||
|
size: "14px",
|
||||||
|
align: "left",
|
||||||
|
color: "#656563"
|
||||||
|
})
|
||||||
|
setTimeout(()=>{
|
||||||
|
view.show()
|
||||||
|
},200)
|
||||||
|
}
|
||||||
|
|
||||||
|
function premissionCheck(permission) {
|
||||||
|
return new Promise(async (resolve, reject) => {
|
||||||
|
let plat = isIos ? "ios" : "android";
|
||||||
|
if (isIos) { // ios
|
||||||
|
// const camera = permission.judgeIosPermission("camera");//判断ios是否给予摄像头权限
|
||||||
|
// //ios相册没权限,系统会自动弹出授权框
|
||||||
|
// //let photoLibrary = permission.judgeIosPermission("photoLibrary");//判断ios是否给予相册权限
|
||||||
|
// if(camera){
|
||||||
|
// resolve();
|
||||||
|
// }else{
|
||||||
|
// reject('需要开启相机使用权限');
|
||||||
|
// }
|
||||||
|
resolve(1)
|
||||||
|
} else { // android
|
||||||
|
let permission_arr = permissionMap[plat][permission]["name"].split(",");
|
||||||
|
|
||||||
|
let flag = true;
|
||||||
|
for(let i = 0;i<permission_arr.length;i++) {
|
||||||
|
let status = plus.navigator.checkPermission(permission_arr[i]);
|
||||||
|
if(status == "undetermined") {
|
||||||
|
flag = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (flag == false) { // 未完全授权
|
||||||
|
showViewDesc(permission);
|
||||||
|
requestAndroidPermission(permissionMap[plat][permission]["name"]).then((res) => {
|
||||||
|
viewShow = false;
|
||||||
|
setTimeout(()=>{
|
||||||
|
viewShow = true;
|
||||||
|
},120)
|
||||||
|
view.close();
|
||||||
|
// if (res == -1) {
|
||||||
|
// uni.showModal({
|
||||||
|
// title: '提示',
|
||||||
|
// content: '操作权限已被拒绝,请手动前往设置',
|
||||||
|
// confirmText: "立即设置",
|
||||||
|
// success: (res) => {
|
||||||
|
// if (res.confirm) {
|
||||||
|
// gotoAppPermissionSetting()
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
// })
|
||||||
|
// }
|
||||||
|
resolve(res)
|
||||||
|
})
|
||||||
|
} else {
|
||||||
|
resolve(1)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
module.exports = {
|
module.exports = {
|
||||||
judgeIosPermission: judgeIosPermission,
|
judgeIosPermission: judgeIosPermission,
|
||||||
requestAndroidPermission: requestAndroidPermission,
|
requestAndroidPermission: requestAndroidPermission,
|
||||||
checkSystemEnableLocation: checkSystemEnableLocation,
|
checkSystemEnableLocation: checkSystemEnableLocation,
|
||||||
gotoAppPermissionSetting: gotoAppPermissionSetting
|
gotoAppPermissionSetting: gotoAppPermissionSetting,
|
||||||
|
premissionCheck: premissionCheck
|
||||||
}
|
}
|
||||||
|
|||||||
272
js_sdk/wa-permission11/permission.js
Normal file
272
js_sdk/wa-permission11/permission.js
Normal file
@@ -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
|
||||||
|
}
|
||||||
@@ -69,7 +69,7 @@ import { mapState, mapMutations } from "vuex";
|
|||||||
|
|
||||||
const { platform } = uni.getSystemInfoSync();
|
const { platform } = uni.getSystemInfoSync();
|
||||||
|
|
||||||
import permision from "@/js_sdk/wa-permission/permission.js";
|
import permision from "@/js_sdk/wa-permission11/permission.js";
|
||||||
|
|
||||||
const definitions = [
|
const definitions = [
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -207,15 +207,15 @@
|
|||||||
</scroll-view>
|
</scroll-view>
|
||||||
</view>
|
</view>
|
||||||
</view>
|
</view>
|
||||||
<uni-section class="mb-10 graybg" title="留言板" type="line">
|
<!-- <uni-section class="mb-10 graybg" title="留言板" type="line">
|
||||||
<template v-slot:right>
|
<template v-slot:right>
|
||||||
<view class="flexbox" style="align-items: center" @click="addSay()">
|
<view class="flexbox" style="align-items: center" @click="addSay()">
|
||||||
<u-icon name="edit-pen" color="#2979ff" size="28"></u-icon>
|
<u-icon name="edit-pen" color="#2979ff" size="28"></u-icon>
|
||||||
<text>发布留言</text>
|
<text>发布留言</text>
|
||||||
</view>
|
</view>
|
||||||
</template>
|
</template>
|
||||||
</uni-section>
|
</uni-section> -->
|
||||||
<view class="liuyanBox">
|
<view class="liuyanBox" v-if="false">
|
||||||
<view class="" v-if="sayList.length > 0">
|
<view class="" v-if="sayList.length > 0">
|
||||||
<commentsList
|
<commentsList
|
||||||
:sayList="sayList"
|
:sayList="sayList"
|
||||||
|
|||||||
@@ -271,7 +271,7 @@
|
|||||||
</view>
|
</view>
|
||||||
</view>
|
</view>
|
||||||
<view style="background: rgba(255, 255, 255, 0.85) !important">
|
<view style="background: rgba(255, 255, 255, 0.85) !important">
|
||||||
<uni-section
|
<!-- <uni-section
|
||||||
style="padding: 0 20rpx"
|
style="padding: 0 20rpx"
|
||||||
class="mb-10 graybg"
|
class="mb-10 graybg"
|
||||||
title="留言板"
|
title="留言板"
|
||||||
@@ -287,8 +287,8 @@
|
|||||||
<text>发布留言</text>
|
<text>发布留言</text>
|
||||||
</view>
|
</view>
|
||||||
</template>
|
</template>
|
||||||
</uni-section>
|
</uni-section> -->
|
||||||
<view class="liuyanBox">
|
<view class="liuyanBox" v-if="false">
|
||||||
<view class="" v-if="sayList.length > 0">
|
<view class="" v-if="sayList.length > 0">
|
||||||
<commentsList
|
<commentsList
|
||||||
:sayList="sayList"
|
:sayList="sayList"
|
||||||
@@ -396,7 +396,7 @@
|
|||||||
</view>
|
</view>
|
||||||
</view>
|
</view>
|
||||||
</view>
|
</view>
|
||||||
<view
|
<view @click="checkPermision"
|
||||||
class="picBtn item flexbox"
|
class="picBtn item flexbox"
|
||||||
v-show="uploadPicLIst.length < 3"
|
v-show="uploadPicLIst.length < 3"
|
||||||
>
|
>
|
||||||
@@ -526,6 +526,7 @@ import commentsList from "@/components/commentsList.vue";
|
|||||||
import emojiList1 from "../../bkhumor-emojiplus/emoji/biaoqin.js";
|
import emojiList1 from "../../bkhumor-emojiplus/emoji/biaoqin.js";
|
||||||
import emotion from "@/bkhumor-emojiplus/components/bkhumor-emojiplus/bkhumor-emojiplus.vue";
|
import emotion from "@/bkhumor-emojiplus/components/bkhumor-emojiplus/bkhumor-emojiplus.vue";
|
||||||
import $http from "@/config/requestConfig.js";
|
import $http from "@/config/requestConfig.js";
|
||||||
|
import permission from "@/js_sdk/wa-permission/permission.js"
|
||||||
var clear;
|
var clear;
|
||||||
import { mapState } from "vuex";
|
import { mapState } from "vuex";
|
||||||
export default {
|
export default {
|
||||||
@@ -699,6 +700,12 @@ export default {
|
|||||||
},
|
},
|
||||||
//方法
|
//方法
|
||||||
methods: {
|
methods: {
|
||||||
|
async checkPermision(){
|
||||||
|
var result = await permission.premissionCheck("CAMERA_EXTERNAL_STORAGE")
|
||||||
|
if (result != 1) {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
},
|
||||||
haveSelected(data) {
|
haveSelected(data) {
|
||||||
console.log(data, " 选择的是");
|
console.log(data, " 选择的是");
|
||||||
if (data.index == 0) {
|
if (data.index == 0) {
|
||||||
|
|||||||
@@ -17,7 +17,7 @@
|
|||||||
</view>
|
</view>
|
||||||
</view>
|
</view>
|
||||||
</view>
|
</view>
|
||||||
<view class="prof">吴门医述是一款专业的医学线上教育平台。内容涵盖中医学、针灸学、心身医学、中西汇通学、肿瘤学。仰望星空、脚踏实地、梦从这里起航。</view>
|
<view class="prof">吴门医述是一款线上视频平台。内容涵盖中医学、针灸学、心身医学、中西汇通学、肿瘤学。仰望星空、脚踏实地、梦从这里起航。</view>
|
||||||
<view class="" style="text-align: center;">
|
<view class="" style="text-align: center;">
|
||||||
<!-- https://main.nuttyreading.com/privacy.html -->
|
<!-- https://main.nuttyreading.com/privacy.html -->
|
||||||
<!-- <text @click="seeDetail('')" style="color: #007aff; font-size: 26rpx;">隐私政策</text> -->
|
<!-- <text @click="seeDetail('')" style="color: #007aff; font-size: 26rpx;">隐私政策</text> -->
|
||||||
|
|||||||
Reference in New Issue
Block a user