Removed doubled code and merged methods
This commit is contained in:
@@ -20,8 +20,8 @@ enum ImportStatus {
|
|||||||
class LocalStorageService {
|
class LocalStorageService {
|
||||||
static const String _fileName = 'game_data.json';
|
static const String _fileName = 'game_data.json';
|
||||||
|
|
||||||
/// Writes the game session list to a JSON file and returns it as string.
|
/// Writes the game session list to a JSON file and returns it as string.
|
||||||
static String getJsonFile() {
|
static String getGameDataAsJsonFile() {
|
||||||
final jsonFile =
|
final jsonFile =
|
||||||
gameManager.gameList.map((session) => session.toJson()).toList();
|
gameManager.gameList.map((session) => session.toJson()).toList();
|
||||||
return json.encode(jsonFile);
|
return json.encode(jsonFile);
|
||||||
@@ -39,7 +39,7 @@ class LocalStorageService {
|
|||||||
print('[local_storage_service.dart] Versuche, Daten zu speichern...');
|
print('[local_storage_service.dart] Versuche, Daten zu speichern...');
|
||||||
try {
|
try {
|
||||||
final file = await _getFilePath();
|
final file = await _getFilePath();
|
||||||
final jsonFile = getJsonFile();
|
final jsonFile = getGameDataAsJsonFile();
|
||||||
await file.writeAsString(jsonFile);
|
await file.writeAsString(jsonFile);
|
||||||
print(
|
print(
|
||||||
'[local_storage_service.dart] Die Spieldaten wurden zwischengespeichert.');
|
'[local_storage_service.dart] Die Spieldaten wurden zwischengespeichert.');
|
||||||
@@ -102,19 +102,27 @@ class LocalStorageService {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Opens the file picker to save a JSON file with the current game data.
|
/// Opens the file picker to export game data as a JSON file.
|
||||||
static Future<bool> exportGameData() async {
|
/// This method will export the given [jsonString] as a JSON file. It opens
|
||||||
final jsonString = getJsonFile();
|
/// the file picker with the choosen [fileName].
|
||||||
|
static Future<bool> exportJsonData(
|
||||||
|
String jsonString,
|
||||||
|
String fileName,
|
||||||
|
) async {
|
||||||
try {
|
try {
|
||||||
final bytes = Uint8List.fromList(utf8.encode(jsonString));
|
final bytes = Uint8List.fromList(utf8.encode(jsonString));
|
||||||
final result = await FileSaver.instance.saveAs(
|
final path = await FileSaver.instance.saveAs(
|
||||||
name: 'cabo_counter-game_data',
|
name: fileName,
|
||||||
bytes: bytes,
|
bytes: bytes,
|
||||||
ext: 'json',
|
ext: 'json',
|
||||||
mimeType: MimeType.json,
|
mimeType: MimeType.json,
|
||||||
);
|
);
|
||||||
print(
|
if (path == null) {
|
||||||
'[local_storage_service.dart] Die Spieldaten wurden exportiert. Dateipfad: $result');
|
print('[local_storage_service.dart]: Export abgebrochen');
|
||||||
|
} else {
|
||||||
|
print(
|
||||||
|
'[local_storage_service.dart] Die Spieldaten wurden exportiert. Dateipfad: $path');
|
||||||
|
}
|
||||||
return true;
|
return true;
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
print(
|
print(
|
||||||
@@ -123,43 +131,36 @@ class LocalStorageService {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Opens the file picker to export all game sessions as a JSON file.
|
||||||
|
static Future<bool> exportGameData() async {
|
||||||
|
String jsonString = getGameDataAsJsonFile();
|
||||||
|
String fileName = 'cabo_counter-game_data';
|
||||||
|
return exportJsonData(jsonString, fileName);
|
||||||
|
}
|
||||||
|
|
||||||
/// Opens the file picker to save a single game session as a JSON file.
|
/// Opens the file picker to save a single game session as a JSON file.
|
||||||
static Future<bool> exportSingleGameSession(GameSession session) async {
|
static Future<bool> exportSingleGameSession(GameSession session) async {
|
||||||
final jsonString = json.encode(session.toJson());
|
String jsonString = json.encode(session.toJson());
|
||||||
try {
|
String fileName = 'cabo_counter-game_${session.id.substring(0, 7)}';
|
||||||
final bytes = Uint8List.fromList(utf8.encode(jsonString));
|
return exportJsonData(jsonString, fileName);
|
||||||
final result = await FileSaver.instance.saveAs(
|
|
||||||
name: 'cabo_counter-game_${session.id.substring(0, 7)}',
|
|
||||||
bytes: bytes,
|
|
||||||
ext: 'json',
|
|
||||||
mimeType: MimeType.json,
|
|
||||||
);
|
|
||||||
print(
|
|
||||||
'[local_storage_service.dart] Die Spieldaten der Session wurden exportiert. Dateipfad: $result');
|
|
||||||
return true;
|
|
||||||
} catch (e) {
|
|
||||||
print(
|
|
||||||
'[local_storage_service.dart] Fehler beim Exportieren der Spieldaten der Session. Exception: $e');
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Opens the file picker to import a JSON file and loads the game data from it.
|
/// Opens the file picker to import a JSON file and loads the game data from it.
|
||||||
static Future<ImportStatus> importJsonFile() async {
|
static Future<ImportStatus> importJsonFile() async {
|
||||||
final result = await FilePicker.platform.pickFiles(
|
final path = await FilePicker.platform.pickFiles(
|
||||||
dialogTitle: 'Wähle eine Datei mit Spieldaten aus',
|
dialogTitle: 'Wähle eine Datei mit Spieldaten aus',
|
||||||
type: FileType.custom,
|
type: FileType.custom,
|
||||||
allowedExtensions: ['json'],
|
allowedExtensions: ['json'],
|
||||||
);
|
);
|
||||||
|
|
||||||
if (result == null) {
|
if (path == null) {
|
||||||
print(
|
print(
|
||||||
'[local_storage_service.dart] Der Filepicker-Dialog wurde abgebrochen');
|
'[local_storage_service.dart] Der Filepicker-Dialog wurde abgebrochen');
|
||||||
return ImportStatus.canceled;
|
return ImportStatus.canceled;
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
final jsonString = await _readFileContent(result.files.single);
|
final jsonString = await _readFileContent(path.files.single);
|
||||||
|
|
||||||
if (!await validateJsonSchema(jsonString)) {
|
if (!await validateJsonSchema(jsonString)) {
|
||||||
return ImportStatus.validationError;
|
return ImportStatus.validationError;
|
||||||
|
|||||||
Reference in New Issue
Block a user