spotube/lib/pages/search/tabs/playlists.dart
Kingkor Roy Tirtho 7037145519 feat: add ErrorBox and NoDefaultMetadataPlugin components
- Implemented ErrorBox for displaying error messages with retry functionality and log viewing.
- Created NoDefaultMetadataPlugin to inform users about missing default metadata providers and provide navigation to manage them.
2025-08-19 22:34:37 +06:00

59 lines
2.2 KiB
Dart

import 'package:flutter_hooks/flutter_hooks.dart';
import 'package:hooks_riverpod/hooks_riverpod.dart';
import 'package:shadcn_flutter/shadcn_flutter.dart';
import 'package:spotube/collections/fake.dart';
import 'package:spotube/components/fallbacks/error_box.dart';
import 'package:spotube/components/playbutton_view/playbutton_view.dart';
import 'package:spotube/modules/playlist/playlist_card.dart';
import 'package:spotube/modules/search/loading.dart';
import 'package:spotube/pages/search/search.dart';
import 'package:spotube/provider/metadata_plugin/search/playlists.dart';
class SearchPagePlaylistsTab extends HookConsumerWidget {
const SearchPagePlaylistsTab({super.key});
@override
Widget build(BuildContext context, ref) {
final controller = useScrollController();
final searchTerm = ref.watch(searchTermStateProvider);
final searchPlaylistsSnapshot =
ref.watch(metadataPluginSearchPlaylistsProvider(searchTerm));
final searchPlaylistsNotifier =
ref.read(metadataPluginSearchPlaylistsProvider(searchTerm).notifier);
final searchPlaylists = searchPlaylistsSnapshot.asData?.value.items ??
[FakeData.playlistSimple];
if (searchPlaylistsSnapshot.hasError) {
return ErrorBox(
error: searchPlaylistsSnapshot.error!,
onRetry: () {
ref.invalidate(metadataPluginSearchPlaylistsProvider(searchTerm));
},
);
}
return SearchPlaceholder(
snapshot: searchPlaylistsSnapshot,
child: Padding(
padding: const EdgeInsets.symmetric(horizontal: 16),
child: CustomScrollView(
slivers: [
PlaybuttonView(
controller: controller,
itemCount: searchPlaylists.length,
hasMore: searchPlaylistsSnapshot.asData?.value.hasMore == true,
isLoading: searchPlaylistsSnapshot.isLoading,
onRequestMore: searchPlaylistsNotifier.fetchMore,
gridItemBuilder: (context, index) =>
PlaylistCard(searchPlaylists[index]),
listItemBuilder: (context, index) =>
PlaylistCard.tile(searchPlaylists[index]),
),
],
),
),
);
}
}