Vaani/lib/pages/home_page.dart

127 lines
4.1 KiB
Dart
Raw Normal View History

2024-05-08 05:03:49 -04:00
import 'package:flutter/material.dart';
import 'package:flutter_hooks/flutter_hooks.dart';
import 'package:go_router/go_router.dart';
2024-05-08 05:03:49 -04:00
import 'package:hooks_riverpod/hooks_riverpod.dart';
2024-08-23 04:21:46 -04:00
import 'package:vaani/api/api_provider.dart';
import 'package:vaani/main.dart';
import 'package:vaani/router/router.dart';
import 'package:vaani/settings/api_settings_provider.dart';
2024-05-08 05:03:49 -04:00
2024-05-14 10:11:25 -04:00
import '../shared/widgets/shelves/home_shelf.dart';
2024-05-08 05:03:49 -04:00
class HomePage extends HookConsumerWidget {
const HomePage({super.key});
@override
Widget build(BuildContext context, WidgetRef ref) {
final views = ref.watch(personalizedViewProvider);
final apiSettings = ref.watch(apiSettingsProvider);
2024-05-08 05:03:49 -04:00
final scrollController = useScrollController();
return Scaffold(
appBar: AppBar(
2024-08-23 03:44:44 -04:00
backgroundColor: Colors.transparent,
2024-05-08 05:03:49 -04:00
title: GestureDetector(
2024-08-23 03:44:44 -04:00
child: Text(
'Vaani',
style: Theme.of(context).textTheme.headlineLarge,
),
2024-05-08 05:03:49 -04:00
onTap: () {
// scroll to the top of the page
scrollController.animateTo(
0,
duration: const Duration(milliseconds: 300),
curve: Curves.easeInOut,
);
// refresh the view
ref.invalidate(personalizedViewProvider);
},
),
),
body: Container(
child: views.when(
data: (data) {
2024-09-06 15:10:00 -04:00
if (data.isEmpty) {
return Center(
child: Column(
mainAxisAlignment: MainAxisAlignment.center,
children: [
const Text('No shelves to display'),
// try again button
ElevatedButton(
onPressed: () {
ref.read(apiSettingsProvider.notifier).updateState(
apiSettings.copyWith(activeLibraryId: null),
);
2024-09-06 15:10:00 -04:00
ref.invalidate(personalizedViewProvider);
},
child: const Text('Try again'),
),
],
),
);
}
2024-05-08 05:03:49 -04:00
final shelvesToDisplay = data
2024-05-08 21:25:06 -04:00
// .where((element) => !element.id.contains('discover'))
.map((shelf) {
appLogger.fine('building shelf ${shelf.label}');
2024-05-08 21:25:06 -04:00
return HomeShelf(
title: shelf.label,
shelf: shelf,
);
}).toList();
2024-05-08 05:03:49 -04:00
return RefreshIndicator(
onRefresh: () async {
return ref.refresh(personalizedViewProvider);
},
child: ListView.separated(
itemBuilder: (context, index) => shelvesToDisplay[index],
separatorBuilder: (context, index) => Divider(
color: Theme.of(context).dividerColor.withOpacity(0.1),
indent: 16,
endIndent: 16,
),
itemCount: shelvesToDisplay.length,
controller: scrollController,
),
);
},
2024-05-08 21:25:06 -04:00
loading: () => const HomePageSkeleton(),
2024-05-08 05:03:49 -04:00
error: (error, stack) {
if (apiSettings.activeUser == null ||
apiSettings.activeServer == null) {
return Center(
child: Column(
mainAxisAlignment: MainAxisAlignment.center,
children: [
Text('Error: $error'),
ElevatedButton(
onPressed: () {
GoRouter.of(context).goNamed(Routes.onboarding.name);
},
child: const Text('Go to login'),
),
],
),
);
}
2024-05-08 05:03:49 -04:00
return Text('Error: $error');
},
),
),
);
}
}
2024-05-08 21:25:06 -04:00
class HomePageSkeleton extends StatelessWidget {
const HomePageSkeleton({super.key});
@override
Widget build(BuildContext context) {
return const Scaffold(
body: Center(
child: CircularProgressIndicator(),
),
);
}
}