import 'package:flutter/material.dart'; import 'package:get/get.dart'; import 'package:infinite_scroll_pagination/infinite_scroll_pagination.dart'; import 'package:solian/models/pagination.dart'; import 'package:solian/models/post.dart'; import 'package:solian/providers/content/posts.dart'; import 'package:solian/widgets/posts/post_list.dart'; class PostReplyList extends StatefulWidget { final Post item; const PostReplyList({ super.key, required this.item, }); @override State createState() => _PostReplyListState(); } class _PostReplyListState extends State { final PagingController _pagingController = PagingController(firstPageKey: 0); Future getReplies(int pageKey) async { final PostProvider provider = Get.find(); Response resp; try { resp = await provider.listPostReplies(widget.item.id.toString(), pageKey); } catch (e) { _pagingController.error = e; return; } final PaginationResult result = PaginationResult.fromJson(resp.body); final parsed = result.data?.map((e) => Post.fromJson(e)).toList(); if (parsed != null && parsed.length >= 10) { _pagingController.appendPage(parsed, pageKey + parsed.length); } else if (parsed != null) { _pagingController.appendLastPage(parsed); } } @override void initState() { super.initState(); _pagingController.addPageRequestListener(getReplies); } @override Widget build(BuildContext context) { return PostListWidget( isShowEmbed: false, controller: _pagingController, ); } } class PostReplyListPopup extends StatelessWidget { final Post item; const PostReplyListPopup({super.key, required this.item}); @override Widget build(BuildContext context) { return Column( crossAxisAlignment: CrossAxisAlignment.start, children: [ Text( 'postReplies'.tr, style: Theme.of(context).textTheme.headlineSmall, ).paddingOnly(left: 24, right: 24, top: 32, bottom: 16), Expanded( child: CustomScrollView( slivers: [PostReplyList(item: item)], ), ), ], ); } }