refactor(mobile): log service (#16383)

refactor: log service

Co-authored-by: shenlong-tanwen <139912620+shalong-tanwen@users.noreply.github.com>
This commit is contained in:
shenlong 2025-02-28 01:48:49 +05:30 committed by GitHub
parent fbd85a89e0
commit 28c664c769
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
24 changed files with 656 additions and 201 deletions

View file

@ -2,10 +2,11 @@ import 'package:auto_route/auto_route.dart';
import 'package:flutter/material.dart';
import 'package:flutter_hooks/flutter_hooks.dart';
import 'package:hooks_riverpod/hooks_riverpod.dart';
import 'package:immich_mobile/domain/models/log.model.dart';
import 'package:immich_mobile/domain/services/log.service.dart';
import 'package:immich_mobile/extensions/build_context_extensions.dart';
import 'package:immich_mobile/extensions/theme_extensions.dart';
import 'package:immich_mobile/routing/router.dart';
import 'package:immich_mobile/entities/logger_message.entity.dart';
import 'package:immich_mobile/services/immich_logger.service.dart';
import 'package:intl/intl.dart';
@ -17,8 +18,11 @@ class AppLogPage extends HookConsumerWidget {
@override
Widget build(BuildContext context, WidgetRef ref) {
final immichLogger = ImmichLogger();
final logMessages = useState(immichLogger.messages);
final immichLogger = LogService.I;
final shouldReload = useState(false);
final logMessages = useFuture(
useMemoized(() => immichLogger.getMessages(), [shouldReload.value]),
);
Widget colorStatusIndicator(Color color) {
return Column(
@ -71,7 +75,7 @@ class AppLogPage extends HookConsumerWidget {
),
onPressed: () {
immichLogger.clearLogs();
logMessages.value = [];
shouldReload.value = !shouldReload.value;
},
),
Builder(
@ -84,7 +88,7 @@ class AppLogPage extends HookConsumerWidget {
size: 20.0,
),
onPressed: () {
immichLogger.shareLogs(iconContext);
ImmichLogger.shareLogs(iconContext);
},
);
},
@ -105,9 +109,9 @@ class AppLogPage extends HookConsumerWidget {
separatorBuilder: (context, index) {
return const Divider(height: 0);
},
itemCount: logMessages.value.length,
itemCount: logMessages.data?.length ?? 0,
itemBuilder: (context, index) {
var logMessage = logMessages.value[index];
var logMessage = logMessages.data![index];
return ListTile(
onTap: () => context.pushRoute(
AppLogDetailRoute(
@ -128,7 +132,7 @@ class AppLogPage extends HookConsumerWidget {
),
),
subtitle: Text(
"at ${DateFormat("HH:mm:ss.SSS").format(logMessage.createdAt)} in ${logMessage.context1}",
"at ${DateFormat("HH:mm:ss.SSS").format(logMessage.createdAt)} in ${logMessage.logger}",
style: TextStyle(
fontSize: 12.0,
color: context.colorScheme.onSurfaceSecondary,