import 'package:PiliPlus/common/constants.dart'; import 'package:PiliPlus/common/skeleton/video_card_h.dart'; import 'package:PiliPlus/common/widgets/loading_widget/http_error.dart'; import 'package:PiliPlus/common/widgets/video_card/video_card_h.dart'; import 'package:PiliPlus/http/loading_state.dart'; import 'package:PiliPlus/models/model_hot_video_item.dart'; import 'package:PiliPlus/pages/video/related/controller.dart'; import 'package:PiliPlus/utils/grid.dart'; import 'package:flutter/material.dart'; import 'package:get/get.dart'; class RelatedVideoPanel extends StatefulWidget { const RelatedVideoPanel({super.key, required this.heroTag}); final String heroTag; @override State createState() => _RelatedVideoPanelState(); } class _RelatedVideoPanelState extends State with AutomaticKeepAliveClientMixin { late final RelatedController _relatedController = Get.put(RelatedController(), tag: widget.heroTag); @override bool get wantKeepAlive => true; @override Widget build(BuildContext context) { super.build(context); return SliverPadding( padding: const EdgeInsets.only(top: StyleString.safeSpace - 5, bottom: 80), sliver: Obx(() => _buildBody(_relatedController.loadingState.value)), ); } Widget _buildBody(LoadingState?> loadingState) { return switch (loadingState) { Loading() => SliverGrid( gridDelegate: Grid.videoCardHDelegate(context), delegate: SliverChildBuilderDelegate( (context, index) { return const VideoCardHSkeleton(); }, childCount: 5, ), ), Success(:var response) => response?.isNotEmpty == true ? SliverGrid( gridDelegate: Grid.videoCardHDelegate(context), delegate: SliverChildBuilderDelegate( (context, index) { return VideoCardH( videoItem: response[index], showPubdate: true, ); }, childCount: response!.length, ), ) : const SliverToBoxAdapter(), Error(:var errMsg) => HttpError( errMsg: errMsg, onReload: _relatedController.onReload, ), }; } }