mirror of
https://github.com/johrpan/musicus_mobile.git
synced 2025-10-26 18:57:25 +01:00
Properly handle permissions
The backend has a new state called "needsPermissions" and the app widget reacts accordingly.
This commit is contained in:
parent
bd844c44ea
commit
723977daec
3 changed files with 62 additions and 4 deletions
33
lib/app.dart
33
lib/app.dart
|
|
@ -30,9 +30,40 @@ class App extends StatelessWidget {
|
||||||
home: Builder(
|
home: Builder(
|
||||||
builder: (context) {
|
builder: (context) {
|
||||||
if (backend.status == BackendStatus.loading) {
|
if (backend.status == BackendStatus.loading) {
|
||||||
return Container(
|
return Material(
|
||||||
color: Theme.of(context).scaffoldBackgroundColor,
|
color: Theme.of(context).scaffoldBackgroundColor,
|
||||||
);
|
);
|
||||||
|
} else if (backend.status == BackendStatus.needsPermissions) {
|
||||||
|
return Material(
|
||||||
|
color: Theme.of(context).scaffoldBackgroundColor,
|
||||||
|
child: Column(
|
||||||
|
mainAxisAlignment: MainAxisAlignment.center,
|
||||||
|
children: <Widget>[
|
||||||
|
Text(
|
||||||
|
'Musicus needs permissions\nto access your files.',
|
||||||
|
textAlign: TextAlign.center,
|
||||||
|
style: Theme.of(context).textTheme.headline6,
|
||||||
|
),
|
||||||
|
SizedBox(
|
||||||
|
height: 16.0,
|
||||||
|
),
|
||||||
|
ListTile(
|
||||||
|
leading: const Icon(Icons.done),
|
||||||
|
title: Text('Grant permissions'),
|
||||||
|
onTap: () {
|
||||||
|
backend.requestPermissions();
|
||||||
|
},
|
||||||
|
),
|
||||||
|
ListTile(
|
||||||
|
leading: const Icon(Icons.settings),
|
||||||
|
title: Text('Open system\'s app settings'),
|
||||||
|
onTap: () {
|
||||||
|
backend.openAppSettings();
|
||||||
|
},
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
);
|
||||||
} else {
|
} else {
|
||||||
return Content();
|
return Content();
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -1,10 +1,12 @@
|
||||||
import 'package:flutter/widgets.dart';
|
import 'package:flutter/widgets.dart';
|
||||||
|
import 'package:permission_handler/permission_handler.dart';
|
||||||
import 'package:rxdart/rxdart.dart';
|
import 'package:rxdart/rxdart.dart';
|
||||||
|
|
||||||
import 'database.dart';
|
import 'database.dart';
|
||||||
|
|
||||||
enum BackendStatus {
|
enum BackendStatus {
|
||||||
loading,
|
loading,
|
||||||
|
needsPermissions,
|
||||||
ready,
|
ready,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -23,6 +25,8 @@ class Backend extends StatefulWidget {
|
||||||
}
|
}
|
||||||
|
|
||||||
class BackendState extends State<Backend> {
|
class BackendState extends State<Backend> {
|
||||||
|
final _permissionHandler = PermissionHandler();
|
||||||
|
|
||||||
final playerActive = BehaviorSubject.seeded(false);
|
final playerActive = BehaviorSubject.seeded(false);
|
||||||
final playing = BehaviorSubject.seeded(false);
|
final playing = BehaviorSubject.seeded(false);
|
||||||
final position = BehaviorSubject.seeded(0.0);
|
final position = BehaviorSubject.seeded(0.0);
|
||||||
|
|
@ -47,11 +51,33 @@ class BackendState extends State<Backend> {
|
||||||
Future<void> _load() async {
|
Future<void> _load() async {
|
||||||
db = Database('musicus.sqlite');
|
db = Database('musicus.sqlite');
|
||||||
|
|
||||||
setState(() {
|
final permissionStatus =
|
||||||
status = BackendStatus.ready;
|
await _permissionHandler.checkPermissionStatus(PermissionGroup.storage);
|
||||||
});
|
|
||||||
|
if (permissionStatus != PermissionStatus.granted) {
|
||||||
|
setState(() {
|
||||||
|
status = BackendStatus.needsPermissions;
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
setState(() {
|
||||||
|
status = BackendStatus.ready;
|
||||||
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Future<void> requestPermissions() async {
|
||||||
|
final result =
|
||||||
|
await _permissionHandler.requestPermissions([PermissionGroup.storage]);
|
||||||
|
|
||||||
|
if (result[PermissionGroup.storage] == PermissionStatus.granted) {
|
||||||
|
setState(() {
|
||||||
|
status = BackendStatus.ready;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Future<void> openAppSettings() => _permissionHandler.openAppSettings();
|
||||||
|
|
||||||
void startPlayer() {
|
void startPlayer() {
|
||||||
playerActive.add(true);
|
playerActive.add(true);
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -13,6 +13,7 @@ dependencies:
|
||||||
sdk: flutter
|
sdk: flutter
|
||||||
moor_flutter:
|
moor_flutter:
|
||||||
path:
|
path:
|
||||||
|
permission_handler:
|
||||||
rxdart:
|
rxdart:
|
||||||
|
|
||||||
dev_dependencies:
|
dev_dependencies:
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue