mirror of
https://github.com/immich-app/immich.git
synced 2025-01-07 00:50:23 -05:00
bc3979029d
* Add "details" column to LoggerMessage * Include error details in log details page * Move error details out of log message * Add error message to mixin * Create extension for HTTP Response logging * Fix analyze errors * format * fix analyze errors, format again
40 lines
1.2 KiB
Dart
40 lines
1.2 KiB
Dart
import 'package:flutter/material.dart';
|
|
import 'package:hooks_riverpod/hooks_riverpod.dart';
|
|
import 'package:immich_mobile/shared/ui/immich_loading_indicator.dart';
|
|
import 'package:immich_mobile/shared/ui/scaffold_error_body.dart';
|
|
import 'package:logging/logging.dart';
|
|
|
|
extension LogOnError<T> on AsyncValue<T> {
|
|
static final Logger _asyncErrorLogger = Logger("AsyncValue");
|
|
|
|
/// Used to return the [ImmichLoadingIndicator] and [ScaffoldErrorBody] widgets by default on loading
|
|
/// and error cases respectively
|
|
Widget widgetWhen({
|
|
bool skipLoadingOnRefresh = true,
|
|
Widget Function()? onLoading,
|
|
Widget Function(Object? error, StackTrace? stack)? onError,
|
|
required Widget Function(T data) onData,
|
|
}) {
|
|
if (isLoading) {
|
|
bool skip = false;
|
|
if (isRefreshing) {
|
|
skip = skipLoadingOnRefresh;
|
|
}
|
|
|
|
if (!skip) {
|
|
return onLoading?.call() ??
|
|
const Center(
|
|
child: ImmichLoadingIndicator(),
|
|
);
|
|
}
|
|
}
|
|
|
|
if (hasError && !hasValue) {
|
|
_asyncErrorLogger.severe('Could not load value', error, stackTrace);
|
|
return onError?.call(error, stackTrace) ??
|
|
ScaffoldErrorBody(errorMsg: error?.toString());
|
|
}
|
|
|
|
return onData(requireValue);
|
|
}
|
|
}
|