1
0
mirror of https://github.com/git-touch/git-touch synced 2025-01-22 04:06:35 +01:00
git-touch-android-ios-app/lib/scaffolds/refresh_stateful.dart
2019-11-02 20:54:23 +08:00

82 lines
1.9 KiB
Dart

import 'package:flutter/material.dart';
import 'package:flutter/cupertino.dart';
import 'package:git_touch/scaffolds/common.dart';
import 'package:git_touch/scaffolds/utils.dart';
import 'package:primer/primer.dart';
class RefreshStatefulScaffold<T> extends StatefulWidget {
final Widget title;
final Widget Function(T data, void Function(VoidCallback fn) setState)
bodyBuilder;
final Future<T> Function() fetchData;
final Widget Function(T data, void Function(VoidCallback fn) setState)
actionBuilder;
RefreshStatefulScaffold({
@required this.title,
@required this.bodyBuilder,
@required this.fetchData,
this.actionBuilder,
});
@override
_RefreshStatefulScaffoldState createState() =>
_RefreshStatefulScaffoldState();
}
class _RefreshStatefulScaffoldState<T>
extends State<RefreshStatefulScaffold<T>> {
bool _loading;
T _data;
String _error = '';
@override
void initState() {
super.initState();
_refresh();
setState(() {});
}
Future<void> _refresh() async {
try {
setState(() {
_error = '';
_loading = true;
});
_data = await widget.fetchData();
} catch (err) {
_error = err.toString();
throw err;
} finally {
if (mounted) {
setState(() {
_loading = false;
});
}
}
}
Widget get _action {
if (widget.actionBuilder == null) return null;
return widget.actionBuilder(_data, setState);
}
@override
Widget build(BuildContext context) {
return CommonScaffold(
backgroundColor: _data == null ? Colors.white : PrimerColors.gray100,
title: widget.title,
body: RefreshWrapper(
onRefresh: _refresh,
body: ErrorLoadingWrapper(
bodyBuilder: () => widget.bodyBuilder(_data, setState),
error: _error,
loading: _data == null,
reload: _refresh,
),
),
action: _action,
);
}
}