mirror of
https://github.com/immich-app/immich.git
synced 2024-12-19 00:32:49 +02:00
af32183728
* refactor: autoroutex pushroute * refactor: autoroutex popRoute * refactor: autoroutex navigate and replace * chore: add doc comments for extension methods * refactor: Add LoggerMixin and refactor Album activities to use mixin * refactor: Activity page * chore: activity user from user constructor * fix: update current asset after build method * refactor: tests with similar structure as lib * chore: remove avoid-declaring-call-method rule from dcm analysis * test: fix proper expect order * test: activity_statistics_provider_test * test: activity_provider_test * test: use proper matchers * test: activity_text_field_test & dismissible_activity_test added * test: add http mock to return transparent image * test: download isar core libs during test * test: add widget tags to widget test cases * test: activity_tile_test * build: currentAlbumProvider to generator * movie add / remove like to activity input tile * test: activities_page_test.dart * chore: better error logs * chore: dismissibleactivity as statelesswidget --------- Co-authored-by: shalong-tanwen <139912620+shalong-tanwen@users.noreply.github.com>
47 lines
1.4 KiB
Dart
47 lines
1.4 KiB
Dart
import 'package:easy_localization/easy_localization.dart';
|
|
import 'package:flutter/material.dart';
|
|
import 'package:immich_mobile/extensions/build_context_extensions.dart';
|
|
|
|
// Error widget to be used in Scaffold when an AsyncError is received
|
|
class ScaffoldErrorBody extends StatelessWidget {
|
|
final bool withIcon;
|
|
final String? errorMsg;
|
|
|
|
const ScaffoldErrorBody({super.key, this.withIcon = true, this.errorMsg});
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
return Column(
|
|
crossAxisAlignment: CrossAxisAlignment.center,
|
|
mainAxisAlignment: MainAxisAlignment.center,
|
|
children: [
|
|
Text(
|
|
"scaffold_body_error_occurred",
|
|
style: context.textTheme.displayMedium,
|
|
textAlign: TextAlign.center,
|
|
).tr(),
|
|
if (withIcon)
|
|
Center(
|
|
child: Padding(
|
|
padding: const EdgeInsets.only(top: 15),
|
|
child: Icon(
|
|
Icons.error_outline,
|
|
size: 100,
|
|
color: context.themeData.iconTheme.color?.withOpacity(0.5),
|
|
),
|
|
),
|
|
),
|
|
if (withIcon && errorMsg != null)
|
|
Padding(
|
|
padding: const EdgeInsets.all(20),
|
|
child: Text(
|
|
errorMsg!,
|
|
style: context.textTheme.displaySmall,
|
|
textAlign: TextAlign.center,
|
|
),
|
|
),
|
|
],
|
|
);
|
|
}
|
|
}
|