import 'package:PiliPlus/common/constants.dart'; import 'package:PiliPlus/common/widgets/loading_widget/http_error.dart'; import 'package:PiliPlus/common/widgets/refresh_indicator.dart'; import 'package:PiliPlus/http/loading_state.dart'; import 'package:PiliPlus/models/dynamics/result.dart'; import 'package:PiliPlus/pages/dynamics/widgets/dynamic_panel.dart'; import 'package:PiliPlus/pages/dynamics_tab/view.dart'; import 'package:PiliPlus/pages/member_dynamics/controller.dart'; import 'package:PiliPlus/utils/global_data.dart'; import 'package:PiliPlus/utils/grid.dart'; import 'package:PiliPlus/utils/utils.dart'; import 'package:flutter/material.dart'; import 'package:get/get.dart'; import 'package:waterfall_flow/waterfall_flow.dart'; class MemberDynamicsPage extends StatefulWidget { const MemberDynamicsPage({super.key, this.mid}); final int? mid; @override State createState() => _MemberDynamicsPageState(); } class _MemberDynamicsPageState extends State with AutomaticKeepAliveClientMixin { late MemberDynamicsController _memberDynamicController; late int mid; @override bool get wantKeepAlive => true; @override void initState() { super.initState(); mid = widget.mid ?? int.parse(Get.parameters['mid']!); final String heroTag = Utils.makeHeroTag(mid); _memberDynamicController = Get.put( MemberDynamicsController(mid), tag: heroTag, ); } @override Widget build(BuildContext context) { super.build(context); return widget.mid == null ? Scaffold( appBar: AppBar(title: const Text('我的动态')), body: SafeArea( bottom: false, child: _buildBody, ), ) : _buildBody; } Widget get _buildBody => refreshIndicator( onRefresh: _memberDynamicController.onRefresh, child: CustomScrollView( physics: const AlwaysScrollableScrollPhysics(), slivers: [ SliverPadding( padding: EdgeInsets.only( bottom: MediaQuery.paddingOf(context).bottom + 80, ), sliver: Obx( () => _buildContent(_memberDynamicController.loadingState.value), ), ), ], ), ); Widget _buildContent(LoadingState?> loadingState) { return switch (loadingState) { Loading() => DynamicsTabPage.dynSkeleton( GlobalData().dynamicsWaterfallFlow, ), Success(:var response) => response?.isNotEmpty == true ? GlobalData().dynamicsWaterfallFlow ? SliverWaterfallFlow.extent( maxCrossAxisExtent: Grid.smallCardWidth * 2, crossAxisSpacing: StyleString.safeSpace, lastChildLayoutTypeBuilder: (index) { if (index == response.length - 1) { _memberDynamicController.onLoadMore(); } return index == response.length ? LastChildLayoutType.foot : LastChildLayoutType.none; }, children: response! .map( (item) => DynamicPanel( item: item, onRemove: _memberDynamicController.onRemove, onSetTop: _memberDynamicController.onSetTop, ), ) .toList(), ) : SliverCrossAxisGroup( slivers: [ const SliverFillRemaining(), SliverConstrainedCrossAxis( maxExtent: Grid.smallCardWidth * 2, sliver: SliverList.builder( itemBuilder: (context, index) { if (index == response.length - 1) { _memberDynamicController.onLoadMore(); } return DynamicPanel( item: response[index], onRemove: _memberDynamicController.onRemove, onSetTop: _memberDynamicController.onSetTop, ); }, itemCount: response!.length, ), ), const SliverFillRemaining(), ], ) : HttpError( onReload: _memberDynamicController.onReload, ), Error(:var errMsg) => HttpError( errMsg: errMsg, onReload: _memberDynamicController.onReload, ), }; } }