Files
umbrix/lib/utils/placeholders.dart
problematicconsumer 684acc555d Migrate to singbox
2023-08-19 22:27:23 +03:30

65 lines
1.5 KiB
Dart

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 {
const SliverErrorBodyPlaceholder(
this.msg, {
super.key,
this.icon = Icons.error,
});
final String msg;
final IconData? icon;
@override
Widget build(BuildContext context, WidgetRef ref) {
return SliverFillRemaining(
hasScrollBody: false,
child: Column(
mainAxisAlignment: MainAxisAlignment.center,
children: [
if (icon != null) ...[
Icon(icon),
const Gap(16),
],
Text(msg),
],
),
);
}
}