import 'package:easy_debounce/easy_throttle.dart'; import 'package:flutter/material.dart'; import 'package:get/get.dart'; import 'package:PiliPalaX/common/widgets/http_error.dart'; import '../../common/constants.dart'; import '../../utils/grid.dart'; import 'controller.dart'; import 'widgets/item.dart'; class SubPage extends StatefulWidget { const SubPage({super.key}); @override State createState() => _SubPageState(); } class _SubPageState extends State { final SubController _subController = Get.put(SubController()); late Future _futureBuilderFuture; late ScrollController scrollController; @override void initState() { super.initState(); _futureBuilderFuture = _subController.querySubFolder(); scrollController = _subController.scrollController; scrollController.addListener( () { if (scrollController.position.pixels >= scrollController.position.maxScrollExtent - 300) { EasyThrottle.throttle('history', const Duration(seconds: 1), () { _subController.onLoad(); }); } }, ); } @override Widget build(BuildContext context) { return Scaffold( appBar: AppBar( centerTitle: false, titleSpacing: 0, title: Text( '我的订阅', style: Theme.of(context).textTheme.titleMedium, ), ), body: FutureBuilder( future: _futureBuilderFuture, builder: (context, snapshot) { if (snapshot.connectionState == ConnectionState.done) { Map? data = snapshot.data; if (data != null && data['status']) { return Obx(() => CustomScrollView(controller: scrollController, slivers: [ SliverGrid( gridDelegate: SliverGridDelegateWithMaxCrossAxisExtent( mainAxisSpacing: StyleString.cardSpace, crossAxisSpacing: StyleString.safeSpace, maxCrossAxisExtent: Grid.maxRowWidth * 2, mainAxisExtent: Grid.calculateActualWidth(context, Grid.maxRowWidth * 2, StyleString.safeSpace) / 1.9 / StyleString.aspectRatio), delegate: SliverChildBuilderDelegate( childCount: _subController.subFolderData.value.list!.length, (BuildContext context, int index) { return SubItem( subFolderItem: _subController .subFolderData.value.list![index]); }, ), ) ])); } else { return CustomScrollView( physics: const NeverScrollableScrollPhysics(), slivers: [ HttpError( errMsg: data?['msg'], fn: () => setState(() {}), ), ], ); } } else { // 骨架屏 return const Text('请求中'); } }, ), ); } }