Work on implementing sheetable client
This commit is contained in:
@@ -1,8 +1,9 @@
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:permission_handler/permission_handler.dart';
|
||||
import 'package:saf/saf.dart';
|
||||
import 'package:sheetless/sheetview.dart';
|
||||
import 'package:path_provider/path_provider.dart';
|
||||
|
||||
import 'api.dart';
|
||||
import 'sheet.dart';
|
||||
|
||||
void main() {
|
||||
@@ -33,38 +34,53 @@ class MyHomePage extends StatefulWidget {
|
||||
}
|
||||
|
||||
class _MyHomePageState extends State<MyHomePage> {
|
||||
ApiClient apiClient = ApiClient();
|
||||
Future<bool> apiLoggedIn = Future.value(false);
|
||||
|
||||
@override
|
||||
void initState() {
|
||||
super.initState();
|
||||
apiLoggedIn = apiClient.login("admin@admin.com", "sheetable");
|
||||
}
|
||||
|
||||
Future<String?> getSafPickedSheetsDirectory() async {
|
||||
await Permission.storage.request();
|
||||
await Permission.manageExternalStorage.request();
|
||||
var pickedDirectories = await Saf.getPersistedPermissionDirectories();
|
||||
if (pickedDirectories == null || pickedDirectories.isEmpty) {
|
||||
return null;
|
||||
}
|
||||
return pickedDirectories.last;
|
||||
}
|
||||
// Future<String?> getSafPickedSheetsDirectory() async {
|
||||
// await Permission.storage.request();
|
||||
// await Permission.manageExternalStorage.request();
|
||||
// var pickedDirectories = await Saf.getPersistedPermissionDirectories();
|
||||
// if (pickedDirectories == null || pickedDirectories.isEmpty) {
|
||||
// return null;
|
||||
// }
|
||||
// return pickedDirectories.last;
|
||||
// }
|
||||
|
||||
Future<List<Sheet>> acquireSheets() async {
|
||||
String? sheetsDirectory = await getSafPickedSheetsDirectory();
|
||||
if (sheetsDirectory == null || sheetsDirectory.isEmpty) {
|
||||
await Saf.getDynamicDirectoryPermission(grantWritePermission: false);
|
||||
sheetsDirectory = await getSafPickedSheetsDirectory();
|
||||
if (sheetsDirectory == null || sheetsDirectory.isEmpty) {
|
||||
throw Exception("No Directory selected");
|
||||
}
|
||||
}
|
||||
// await Permission.storage.request();
|
||||
// await Permission.manageExternalStorage.request();
|
||||
//
|
||||
|
||||
var sheetsDirectoryFiles = await Saf.getFilesPathFor(sheetsDirectory);
|
||||
if (sheetsDirectoryFiles == null) {
|
||||
await Saf.releasePersistedPermissions();
|
||||
throw Exception(
|
||||
"Permissions for directory no longer valid or Directory deleted. Please restart app.");
|
||||
}
|
||||
return loadSheetsSorted(sheetsDirectoryFiles);
|
||||
await apiLoggedIn; // TODO: check if really logged in (returns bool)
|
||||
return await apiClient.fetchSheets();
|
||||
// return api.main();
|
||||
|
||||
// final directory = await getApplicationDocumentsDirectory();
|
||||
// print("Directory is: $directory");
|
||||
// String? sheetsDirectory = "/home/julian/Klavier";
|
||||
// if (sheetsDirectory == null || sheetsDirectory.isEmpty) {
|
||||
// await Saf.getDynamicDirectoryPermission(grantWritePermission: false);
|
||||
// sheetsDirectory = "/home/julian/Klavier";
|
||||
// if (sheetsDirectory == null || sheetsDirectory.isEmpty) {
|
||||
// throw Exception("No Directory selected");
|
||||
// }
|
||||
// }
|
||||
// return List.empty();
|
||||
|
||||
// var sheetsDirectoryFiles = await Saf.getFilesPathFor(sheetsDirectory);
|
||||
// if (sheetsDirectoryFiles == null) {
|
||||
// await Saf.releasePersistedPermissions();
|
||||
// throw Exception(
|
||||
// "Permissions for directory no longer valid or Directory deleted. Please restart app.");
|
||||
// }
|
||||
// return loadSheetsSorted(sheetsDirectoryFiles);
|
||||
}
|
||||
|
||||
@override
|
||||
@@ -82,7 +98,10 @@ class _MyHomePageState extends State<MyHomePage> {
|
||||
callback: (sheet) => Navigator.push(
|
||||
context,
|
||||
MaterialPageRoute(
|
||||
builder: (context) => SheetViewerPage(sheet: sheet),
|
||||
builder: (context) => SheetViewerPage(
|
||||
sheet: sheet,
|
||||
apiClient: apiClient,
|
||||
),
|
||||
),
|
||||
),
|
||||
);
|
||||
|
||||
Reference in New Issue
Block a user