Refresher.dart 1.6KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. import 'package:farmer_client/models/entities/PagedResult.dart';
  2. import 'package:flutter/material.dart';
  3. class RefreshBuilder extends StatefulWidget {
  4. RefreshBuilder({
  5. Key? key,
  6. required this.builder,
  7. required this.fetch,
  8. required this.useState,
  9. this.onError,
  10. }): super(key: key);
  11. Future Function(Map param) fetch;
  12. Function({PagedResult state, void Function(VoidCallback) setState}) useState;
  13. Function? onError;
  14. Widget Function({
  15. BuildContext context,
  16. Function toggle,
  17. }) builder;
  18. @override
  19. State<StatefulWidget> createState() => _RefresherState();
  20. }
  21. class _RefresherState extends State<RefreshBuilder> {
  22. PagedResult result = PagedResult(total: 0, size: 0, pages: 0, current: 0);
  23. List<dynamic> listData = [];
  24. void Function(void Function())? _subSetState;
  25. @override
  26. initState() {
  27. super.initState();
  28. fetchData();
  29. }
  30. Future fetchData() {
  31. return Future.value(widget.fetch({ "pageNum": 1 }).then((res) {
  32. final pagedResult = PagedResult.fromJson(res);
  33. widget.useState(state: pagedResult, setState: setState);
  34. }).catchError((err) {
  35. print(err);
  36. if (null != widget.onError) {
  37. widget.onError!(err);
  38. }
  39. }));
  40. }
  41. toggle() {
  42. fetchData();
  43. }
  44. @override
  45. Widget build(BuildContext context) {
  46. return RefreshIndicator(
  47. triggerMode: RefreshIndicatorTriggerMode.onEdge,
  48. onRefresh: fetchData,
  49. child: widget.builder(
  50. context: context,
  51. toggle: toggle
  52. ),
  53. );
  54. }
  55. }