Files
umbrix/lib/utils/placeholders.dart

66 lines
1.6 KiB
Dart
Raw Permalink Normal View History

2024-02-15 15:23:02 +03:30
import 'package:fluentui_system_icons/fluentui_system_icons.dart';
2023-07-06 17:18:41 +03:30
import 'package:flutter/material.dart';
import 'package:gap/gap.dart';
import 'package:hooks_riverpod/hooks_riverpod.dart';
// TODO: improve
class SliverBodyPlaceholder extends HookConsumerWidget {
const SliverBodyPlaceholder(this.children, {super.key});
final List<Widget> children;
@override
Widget build(BuildContext context, WidgetRef ref) {
return SliverFillRemaining(
hasScrollBody: false,
child: Column(
mainAxisAlignment: MainAxisAlignment.center,
children: children,
),
);
}
}
class SliverLoadingBodyPlaceholder extends HookConsumerWidget {
const SliverLoadingBodyPlaceholder({super.key});
@override
Widget build(BuildContext context, WidgetRef ref) {
return const SliverFillRemaining(
hasScrollBody: false,
child: Column(
mainAxisAlignment: MainAxisAlignment.center,
children: [CircularProgressIndicator()],
),
);
}
}
class SliverErrorBodyPlaceholder extends HookConsumerWidget {
2023-08-19 22:27:23 +03:30
const SliverErrorBodyPlaceholder(
this.msg, {
super.key,
2024-02-15 15:23:02 +03:30
this.icon = FluentIcons.error_circle_24_regular,
2023-08-19 22:27:23 +03:30
});
2023-07-06 17:18:41 +03:30
final String msg;
final IconData? icon;
@override
Widget build(BuildContext context, WidgetRef ref) {
return SliverFillRemaining(
hasScrollBody: false,
child: Column(
mainAxisAlignment: MainAxisAlignment.center,
children: [
2023-08-19 22:27:23 +03:30
if (icon != null) ...[
Icon(icon),
const Gap(16),
],
2023-07-06 17:18:41 +03:30
Text(msg),
],
),
);
}
}