e811f164
吴启风
feat:权限申请页面增加隐私合规...
|
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
|
Future<bool> requestPermission(
BuildContext context,
Permission permission,
String permissionName,
String permissionDesc,
{bool isRequiredPermission = false}) async {
return requestPermissions(context, [permission], [permissionName], permissionDesc,
isRequiredPermission: isRequiredPermission);
}
Future<bool> requestPermissions(
BuildContext context,
List<Permission> permissions,
List<String> permissionNames,
String permissionDesc,
{bool isRequiredPermission = false}) async {
// List<PermissionStatus> statuses = await Future.wait(
// permissions.map((permission) => permission.status),
// );
// bool allGranted = statuses.every((status) => status.isGranted);
bool allGranted = await isPermissionsGranted(permissions);
if (allGranted) {
return true;
} else {
return await Navigator.of(context).push(PageRouteBuilder(
opaque: false,
pageBuilder: ((context, animation, secondaryAnimation) {
return PermissionRequestPage(permissions, permissionNames, permissionDesc,
isRequiredPermission: isRequiredPermission);
})));
}
}
///(实际请求前)判断权限数组是否都授予
Future<bool> isPermissionsGranted(List<Permission> permissions) async {
// 使用 every 直接检查权限状态
return await Future.wait(permissions.map((permission) async {
return await permission.status.isGranted;
})).then((statuses) => statuses.every((status) => status));
}
///请求权限
Future<MapEntry<Permission, PermissionStatus>?> requestPermissionsInner(List<Permission> permissionList) async {
Map<Permission, PermissionStatus> statusesMap = await permissionList.request();
for (var entry in statusesMap.entries) {
if (!entry.value.isGranted) {
return entry;
}
}
return null;
}
|