Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/koji-1009/paging_view
Like Android Jetpack's Paging library 3, manages data and displays paged lists.
https://github.com/koji-1009/paging_view
dart flutter paging
Last synced: about 1 month ago
JSON representation
Like Android Jetpack's Paging library 3, manages data and displays paged lists.
- Host: GitHub
- URL: https://github.com/koji-1009/paging_view
- Owner: koji-1009
- License: mit
- Created: 2022-07-18T06:24:07.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2024-10-05T03:00:06.000Z (4 months ago)
- Last Synced: 2024-12-09T00:50:34.894Z (about 1 month ago)
- Topics: dart, flutter, paging
- Language: Dart
- Homepage: https://koji-1009.github.io/paging_view/
- Size: 11 MB
- Stars: 4
- Watchers: 3
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
- Codeowners: .github/CODEOWNERS
Awesome Lists containing this project
README
# paging_view
Like Android Jetpack's Paging library 3, manages data and displays paged lists.
## Live preview
https://koji-1009.github.io/paging_view/
## How to use
1. Create a class that is extended `DataSource`.
2. Get an instance of the step 1 class in the widget.
3. Set the step 2 instance obtained to `PagingList` or `PagingGrid`.```dart
@riverpod
DataSourcePublicRepositories dataSourcePublicRepositories(
DataSourcePublicRepositoriesRef ref,
) {
final dataSource = DataSourcePublicRepositories(
repository: ref.watch(
gitHubRepositoryProvider,
),
);ref.onDispose(() {
dataSource.dispose();
});return dataSource;
}/// 1
final class DataSourcePublicRepositories extends DataSource {
DataSourcePublicRepositories({
required this.repository,
});final GitHubRepository repository;
@override
Future> load(LoadAction action) async =>
switch (action) {
Refresh() => await fetch(null),
Prepend(key: final _) => const None(),
Append(key: final key) => await fetch(key),
};Future> fetch(int? key) async {
final PageData data;
if (key == null) {
data = await repository.repositories();
} else {
data = await repository.repositories(
since: key,
);
}
return Success(
page: data,
);
}
}class HomePage extends ConsumerWidget {
const HomePage({super.key});@override
Widget build(BuildContext context, WidgetRef ref) {
/// 2
final dataSource = ref.watch(dataSourcePublicRepositoriesProvider);
final body = PagingList(
/// 3
dataSource: dataSource,
builder: (context, repository, index) => Card(
child: ListTile(
title: Text(repository.fullName),
subtitle: Text(repository.description),
),
),
errorBuilder: (context, e) => Center(
child: Text('$e'),
),
initialLoadingWidget: const Center(
child: Padding(
padding: EdgeInsets.all(16),
child: CircularProgressIndicator.adaptive(),
),
),
appendLoadingWidget: const Center(
child: Padding(
padding: EdgeInsets.all(16),
child: CircularProgressIndicator.adaptive(),
),
),
padding: const EdgeInsets.symmetric(
horizontal: 16,
),
);
return Scaffold(
appBar: AppBar(
title: const Text('GitHub public repositories'),
),
body: RefreshIndicator(
onRefresh: () async => dataSource.refresh(),
child: body,
),
);
}
}
```