zwallet/lib/rescan.dart

106 lines
3.2 KiB
Dart
Raw Normal View History

2022-03-31 22:21:28 -07:00
import 'package:connectivity_plus/connectivity_plus.dart';
import 'package:flutter/material.dart';
import 'package:intl/intl.dart';
import 'package:warp_api/warp_api.dart';
import 'generated/l10n.dart';
import 'main.dart';
final rescanKey = GlobalKey<RescanFormState>();
Future<int?> rescanDialog(BuildContext context) async {
2022-09-24 05:05:45 -07:00
try {
DateTime minDate = WarpApi.getActivationDate();
2023-03-11 19:35:23 -08:00
final bool approved = await showDialog<bool>(
context: context,
barrierDismissible: false,
builder: (context) => AlertDialog(
title: Text(S.of(context).rescanFrom),
2022-09-24 05:05:45 -07:00
content: RescanForm(minDate, key: rescanKey),
actions: confirmButtons(
context, () => Navigator.of(context).pop(true),
cancelValue: false))) ??
false;
2022-04-15 23:51:13 -07:00
if (approved) {
2022-09-24 05:05:45 -07:00
final date = rescanKey.currentState!.startDate;
final heightText = rescanKey.currentState!.heightController.text;
final approved = await confirmWifi(context);
if (approved) {
2023-03-11 19:35:23 -08:00
showSnackBar(S.of(context).rescanning, autoClose: true);
2022-09-24 05:05:45 -07:00
final height = int.tryParse(heightText);
if (height != null) return height;
final height2 = await WarpApi.getBlockHeightByTime(date);
return height2;
}
2022-04-15 23:51:13 -07:00
}
2023-03-11 19:35:23 -08:00
} on String {}
2022-03-31 22:21:28 -07:00
return null;
}
class RescanForm extends StatefulWidget {
2022-09-24 05:05:45 -07:00
final minDate;
RescanForm(this.minDate, {Key? key}) : super(key: key);
2022-03-31 22:21:28 -07:00
@override
RescanFormState createState() => RescanFormState();
}
class RescanFormState extends State<RescanForm> {
DateTime maxDate = DateTime.now();
late DateTime startDate;
2022-09-04 04:21:12 -07:00
var heightController = TextEditingController();
2022-03-31 22:21:28 -07:00
@override
void initState() {
super.initState();
2022-09-24 05:05:45 -07:00
startDate = widget.minDate;
2022-03-31 22:21:28 -07:00
}
@override
Widget build(BuildContext context) {
final dateFormat = DateFormat('yyyy-MM-dd');
return SingleChildScrollView(
2023-03-11 19:35:23 -08:00
child: Column(children: [
OutlinedButton(
onPressed: _showDatePicker,
child: Text(dateFormat.format(startDate))),
Padding(padding: EdgeInsets.symmetric(vertical: 8), child: Text('OR')),
TextFormField(
decoration: InputDecoration(labelText: S.of(context).height),
keyboardType: TextInputType.number,
controller: heightController,
),
]));
2022-03-31 22:21:28 -07:00
}
_showDatePicker() async {
2023-03-11 19:35:23 -08:00
final date = await showDatePicker(
context: context,
firstDate: widget.minDate,
initialDate: startDate,
lastDate: maxDate);
2022-03-31 22:21:28 -07:00
if (date != null) {
setState(() {
startDate = date;
});
}
}
}
Future<bool> confirmWifi(BuildContext context) async {
if (!isMobile()) return true;
final connectivity = await Connectivity().checkConnectivity();
if (connectivity == ConnectivityResult.mobile) {
return await showDialog<bool?>(
context: context,
barrierDismissible: false,
builder: (context) => AlertDialog(
title: Text(S.of(context).rescan),
2023-03-11 19:35:23 -08:00
content: Text(S.of(context).mobileCharges),
2022-03-31 22:21:28 -07:00
actions: confirmButtons(
context, () => Navigator.of(context).pop(true),
cancelValue: false))) ??
false;
}
return true;
}