lemmur-app-android/lib/widgets/sortable_infinite_list.dart

82 lines
2.2 KiB
Dart
Raw Normal View History

import 'package:flutter/material.dart';
import 'package:flutter_hooks/flutter_hooks.dart';
import 'package:lemmy_api_client/lemmy_api_client.dart';
2020-09-29 10:53:40 +02:00
import '../comment_tree.dart';
import '../hooks/infinite_scroll.dart';
2020-09-29 10:53:40 +02:00
import 'comment.dart';
import 'infinite_scroll.dart';
2020-09-29 10:53:40 +02:00
import 'post.dart';
import 'post_list_options.dart';
/// Infinite list of posts
class SortableInfiniteList<T> extends HookWidget {
final Future<List<T>> Function(int page, int batchSize, SortType sortType)
fetcher;
final Widget Function(T) builder;
final Function onStyleChange;
SortableInfiniteList({
@required this.fetcher,
@required this.builder,
this.onStyleChange,
}) : assert(fetcher != null),
assert(builder != null);
@override
Widget build(BuildContext context) {
final isc = useInfiniteScrollController();
final sort = useState(SortType.active);
void changeSorting(SortType newSort) {
sort.value = newSort;
isc.clear();
}
return InfiniteScroll<T>(
prepend: PostListOptions(
onChange: changeSorting,
styleButton: onStyleChange != null,
),
builder: builder,
padding: EdgeInsets.zero,
fetchMore: (page, batchSize) => fetcher(page, batchSize, sort.value),
controller: isc,
batchSize: 20,
);
}
}
class InfinitePostList extends StatelessWidget {
final Future<List<PostView>> Function(
int page, int batchSize, SortType sortType) fetcher;
2020-09-29 21:08:02 +02:00
InfinitePostList({@required this.fetcher}) : assert(fetcher != null);
Widget build(BuildContext context) => SortableInfiniteList<PostView>(
onStyleChange: () {},
builder: (post) => Column(
children: [
Post(post),
SizedBox(height: 20),
],
),
fetcher: fetcher,
);
}
2020-09-29 10:53:40 +02:00
class InfiniteCommentList extends StatelessWidget {
final Future<List<CommentView>> Function(
int page, int batchSize, SortType sortType) fetcher;
2020-09-29 21:08:02 +02:00
InfiniteCommentList({@required this.fetcher}) : assert(fetcher != null);
2020-09-29 10:53:40 +02:00
Widget build(BuildContext context) => SortableInfiniteList<CommentView>(
builder: (comment) => Comment(
CommentTree(comment),
postCreatorId: null,
),
fetcher: fetcher,
);
}