Overworking prints

This commit is contained in:
2025-06-08 20:50:08 +02:00
parent 11aa7494f3
commit f1009c9a38

View File

@@ -7,14 +7,10 @@ import 'package:file_picker/file_picker.dart';
import 'package:file_saver/file_saver.dart'; import 'package:file_saver/file_saver.dart';
import 'package:flutter/services.dart'; import 'package:flutter/services.dart';
import 'package:json_schema/json_schema.dart'; import 'package:json_schema/json_schema.dart';
import 'package:logger/logger.dart';
import 'package:path_provider/path_provider.dart'; import 'package:path_provider/path_provider.dart';
class LocalStorageService { class LocalStorageService {
static const String _fileName = 'game_data.json'; static const String _fileName = 'game_data.json';
static var logger = Logger(
printer: PrettyPrinter(),
);
/// 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 getJsonFile() {
@@ -36,38 +32,44 @@ class LocalStorageService {
final file = await _getFilePath(); final file = await _getFilePath();
final jsonFile = getJsonFile(); final jsonFile = getJsonFile();
await file.writeAsString(jsonFile); await file.writeAsString(jsonFile);
logger.i('Die Spieldaten wurden zwischengespeichert.'); print(
'[local_storage_service.dart] Die Spieldaten wurden zwischengespeichert.');
} catch (e) { } catch (e) {
logger.w('Fehler beim Speichern der Spieldaten. Exception: $e'); print(
'[local_storage_service.dart] Fehler beim Speichern der Spieldaten. Exception: $e');
} }
} }
/// Loads the game data from a local JSON file. /// Loads the game data from a local JSON file.
static Future<bool> loadGameSessions() async { static Future<bool> loadGameSessions() async {
logger.d('Versuche, Daten zu laden...'); print('[local_storage_service.dart] Versuche, Daten zu laden...');
try { try {
final file = await _getFilePath(); final file = await _getFilePath();
if (!await file.exists()) { if (!await file.exists()) {
logger.w('Es existiert noch keine Datei mit Spieldaten'); print(
'[local_storage_service.dart] Es existiert noch keine Datei mit Spieldaten');
return false; return false;
} }
logger.d('Es existiert bereits eine Datei mit Spieldaten'); print(
'[local_storage_service.dart] Es existiert bereits eine Datei mit Spieldaten');
final jsonString = await file.readAsString(); final jsonString = await file.readAsString();
if (jsonString.isEmpty) { if (jsonString.isEmpty) {
logger.w('Die gefundene Datei ist leer'); print('[local_storage_service.dart] Die gefundene Datei ist leer');
return false; return false;
} }
if (!await validateJsonSchema(jsonString)) { if (!await validateJsonSchema(jsonString)) {
logger.w('Die Datei konnte nicht validiert werden'); print(
'[local_storage_service.dart] Die Datei konnte nicht validiert werden');
gameManager.gameList = []; gameManager.gameList = [];
return false; return false;
} }
logger.d('Die gefundene Datei hat Inhalt'); print('[local_storage_service.dart] Die gefundene Datei hat Inhalt');
logger.d('Die gefundene Datei wurde erfolgreich validiert'); print(
'[local_storage_service.dart] Die gefundene Datei wurde erfolgreich validiert');
final jsonList = json.decode(jsonString) as List<dynamic>; final jsonList = json.decode(jsonString) as List<dynamic>;
gameManager.gameList = jsonList gameManager.gameList = jsonList
@@ -75,11 +77,12 @@ class LocalStorageService {
GameSession.fromJson(jsonItem as Map<String, dynamic>)) GameSession.fromJson(jsonItem as Map<String, dynamic>))
.toList(); .toList();
logger.i('Die Spieldaten wurden erfolgreich geladen und verarbeitet'); print(
'[local_storage_service.dart] Die Spieldaten wurden erfolgreich geladen und verarbeitet');
return true; return true;
} catch (e) { } catch (e) {
logger.e('Fehler beim Laden der Spieldaten:\n$e', print(
error: 'JSON nicht geladen'); '[local_storage_service.dart] Fehler beim Laden der Spieldaten:\n$e');
gameManager.gameList = []; gameManager.gameList = [];
return false; return false;
} }
@@ -96,11 +99,12 @@ class LocalStorageService {
ext: 'json', ext: 'json',
mimeType: MimeType.json, mimeType: MimeType.json,
); );
logger.i('Die Spieldaten wurden exportiert. Dateipfad: $result'); print(
'[local_storage_service.dart] Die Spieldaten wurden exportiert. Dateipfad: $result');
return true; return true;
} catch (e) { } catch (e) {
logger.w('Fehler beim Exportieren der Spieldaten. Exception: $e', print(
error: 'JSON nicht exportiert'); '[local_storage_service.dart] Fehler beim Exportieren der Spieldaten. Exception: $e');
return false; return false;
} }
} }
@@ -114,7 +118,8 @@ class LocalStorageService {
); );
if (result == null) { if (result == null) {
logger.d('Der Filepicker-Dialog wurde abgebrochen'); print(
'[local_storage_service.dart] Der Filepicker-Dialog wurde abgebrochen');
return false; return false;
} }
@@ -129,14 +134,16 @@ class LocalStorageService {
.map((jsonItem) => .map((jsonItem) =>
GameSession.fromJson(jsonItem as Map<String, dynamic>)) GameSession.fromJson(jsonItem as Map<String, dynamic>))
.toList(); .toList();
logger.i('Die Datei wurde erfolgreich Importiertn'); print(
'[local_storage_service.dart] Die Datei wurde erfolgreich Importiertn');
return true; return true;
} on FormatException catch (e) { } on FormatException catch (e) {
logger.e('Ungültiges JSON-Format. Exception: $e', error: 'Formatfehler'); print(
'[local_storage_service.dart] Ungültiges JSON-Format. Exception: $e');
return false; return false;
} on Exception catch (e) { } on Exception catch (e) {
logger.e('Fehler beim Dateizugriff. Exception: $e', print(
error: 'Dateizugriffsfehler'); '[local_storage_service.dart] Fehler beim Dateizugriff. Exception: $e');
return false; return false;
} }
} }
@@ -158,14 +165,15 @@ class LocalStorageService {
final result = schema.validate(jsonData); final result = schema.validate(jsonData);
if (result.isValid) { if (result.isValid) {
logger.d('JSON ist erfolgreich validiert.'); print('[local_storage_service.dart] JSON ist erfolgreich validiert.');
return true; return true;
} }
logger.w('JSON ist nicht gültig.\nFehler: ${result.errors}'); print(
'[local_storage_service.dart] JSON ist nicht gültig.\nFehler: ${result.errors}');
return false; return false;
} catch (e) { } catch (e) {
logger.e('Fehler beim Validieren des JSON-Schemas: $e', print(
error: 'Validierung fehlgeschlagen'); '[local_storage_service.dart] Fehler beim Validieren des JSON-Schemas: $e');
return false; return false;
} }
} }
@@ -174,11 +182,12 @@ class LocalStorageService {
try { try {
gameManager.gameList.clear(); gameManager.gameList.clear();
await saveGameSessions(); await saveGameSessions();
logger.i('Alle Runden wurden erfolgreich gelöscht.'); print(
'[local_storage_service.dart] Alle Runden wurden erfolgreich gelöscht.');
return true; return true;
} catch (e) { } catch (e) {
logger.e('Fehler beim Löschen aller Runden: $e', print(
error: 'Löschen fehlgeschlagen'); '[local_storage_service.dart] Fehler beim Löschen aller Runden: $e');
return false; return false;
} }
} }