83 lines
2.3 KiB
Dart
83 lines
2.3 KiB
Dart
import 'package:flutter/material.dart';
|
|
import 'package:flutter_hooks/flutter_hooks.dart';
|
|
import 'package:lemmy_api_client/lemmy_api_client.dart';
|
|
|
|
import '../comment_tree.dart';
|
|
import '../hooks/infinite_scroll.dart';
|
|
import 'comment.dart';
|
|
import 'infinite_scroll.dart';
|
|
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,
|
|
defaultSort: SortType.active,
|
|
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;
|
|
|
|
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,
|
|
);
|
|
}
|
|
|
|
class InfiniteCommentList extends StatelessWidget {
|
|
final Future<List<CommentView>> Function(
|
|
int page, int batchSize, SortType sortType) fetcher;
|
|
|
|
InfiniteCommentList({@required this.fetcher}) : assert(fetcher != null);
|
|
|
|
Widget build(BuildContext context) => SortableInfiniteList<CommentView>(
|
|
builder: (comment) => Comment(
|
|
CommentTree(comment),
|
|
postCreatorId: null,
|
|
),
|
|
fetcher: fetcher,
|
|
);
|
|
}
|