import 'package:PiliPlus/common/widgets/loading_widget/loading_widget.dart'; import 'package:PiliPlus/common/widgets/refresh_indicator.dart'; import 'package:PiliPlus/http/loading_state.dart'; import 'package:PiliPlus/models/space_article/item.dart'; import 'package:PiliPlus/pages/member_article/controller.dart'; import 'package:PiliPlus/pages/member_article/widget/item.dart'; import 'package:PiliPlus/utils/grid.dart'; import 'package:flutter/material.dart'; import 'package:get/get.dart'; class MemberArticle extends StatefulWidget { const MemberArticle({ super.key, required this.heroTag, required this.mid, }); final String? heroTag; final int mid; @override State createState() => _MemberArticleState(); } class _MemberArticleState extends State with AutomaticKeepAliveClientMixin { @override bool get wantKeepAlive => true; late final _controller = Get.put( MemberArticleCtr(mid: widget.mid), tag: widget.heroTag, ); @override Widget build(BuildContext context) { super.build(context); return Obx(() => _buildBody(_controller.loadingState.value)); } Widget _buildBody(LoadingState?> loadingState) { return switch (loadingState) { Loading() => loadingWidget, Success() => loadingState.response?.isNotEmpty == true ? refreshIndicator( onRefresh: () async { await _controller.onRefresh(); }, child: CustomScrollView( slivers: [ SliverPadding( padding: EdgeInsets.only( top: 7, bottom: MediaQuery.paddingOf(context).bottom + 80, ), sliver: SliverGrid( gridDelegate: Grid.videoCardHDelegate(context), delegate: SliverChildBuilderDelegate( (context, index) { if (index == loadingState.response!.length - 1) { _controller.onLoadMore(); } return MemberArticleItem( item: loadingState.response![index], ); }, childCount: loadingState.response!.length, ), ), ), ], ), ) : scrollErrorWidget( onReload: _controller.onReload, ), Error() => scrollErrorWidget( errMsg: loadingState.errMsg, onReload: _controller.onReload, ), }; } }