63 lines
1.9 KiB
Dart
63 lines
1.9 KiB
Dart
import 'package:flutter/material.dart';
|
|
import 'package:hooks_riverpod/hooks_riverpod.dart';
|
|
import 'package:island/models/realm.dart';
|
|
import 'package:island/pods/network.dart';
|
|
import 'package:island/pods/paging.dart';
|
|
import 'package:island/widgets/paging/pagination_list.dart';
|
|
import 'package:island/widgets/realm/realm_list_tile.dart';
|
|
import 'package:styled_widget/styled_widget.dart';
|
|
|
|
final realmListNotifierProvider = AsyncNotifierProvider.autoDispose
|
|
.family<RealmListNotifier, List<SnRealm>, String?>(RealmListNotifier.new);
|
|
|
|
class RealmListNotifier extends AsyncNotifier<List<SnRealm>>
|
|
with AsyncPaginationController<SnRealm> {
|
|
String? arg;
|
|
RealmListNotifier(this.arg);
|
|
|
|
static const int _pageSize = 20;
|
|
|
|
@override
|
|
Future<List<SnRealm>> fetch() async {
|
|
final client = ref.read(apiClientProvider);
|
|
|
|
final queryParams = {
|
|
'offset': fetchedCount,
|
|
'take': _pageSize,
|
|
if (arg != null && arg!.isNotEmpty) 'query': arg,
|
|
};
|
|
|
|
final response = await client.get(
|
|
'/sphere/discovery/realms',
|
|
queryParameters: queryParams,
|
|
);
|
|
totalCount = int.parse(response.headers.value('X-Total') ?? '0');
|
|
final List<dynamic> data = response.data;
|
|
return data.map((json) => SnRealm.fromJson(json)).toList();
|
|
}
|
|
}
|
|
|
|
class SliverRealmList extends HookConsumerWidget {
|
|
const SliverRealmList({super.key, this.query});
|
|
|
|
final String? query;
|
|
|
|
@override
|
|
Widget build(BuildContext context, WidgetRef ref) {
|
|
final provider = realmListNotifierProvider(query);
|
|
return PaginationList(
|
|
provider: provider,
|
|
notifier: provider.notifier,
|
|
isSliver: true,
|
|
isRefreshable: false,
|
|
spacing: 8,
|
|
itemBuilder: (context, index, realm) {
|
|
return ConstrainedBox(
|
|
constraints: const BoxConstraints(maxWidth: 540),
|
|
child: RealmListTile(realm: realm),
|
|
).center();
|
|
},
|
|
);
|
|
}
|
|
}
|