gecko/lib/providers/chest_provider.dart

73 lines
2.1 KiB
Dart
Raw Normal View History

2021-12-23 12:36:09 +01:00
import 'dart:async';
2021-11-17 06:20:23 +01:00
import 'package:flutter/material.dart';
import 'package:gecko/globals.dart';
import 'package:gecko/models/chest_data.dart';
2022-05-24 16:51:40 +02:00
import 'package:gecko/models/wallet_data.dart';
import 'package:gecko/providers/substrate_sdk.dart';
import 'package:provider/provider.dart';
2021-11-17 06:20:23 +01:00
class ChestProvider with ChangeNotifier {
void rebuildWidget() {
notifyListeners();
}
Future deleteChest(context, ChestData _chest) async {
2021-12-23 21:44:24 +01:00
final bool? _answer = await (_confirmDeletingChest(context, _chest.name));
2022-05-24 16:51:40 +02:00
SubstrateSdk _sub = Provider.of<SubstrateSdk>(context, listen: false);
2021-12-23 21:44:24 +01:00
if (_answer!) {
2022-05-24 16:51:40 +02:00
await _sub.deleteAccounts(getChestWallets(_chest));
2021-11-18 02:37:46 +01:00
await chestBox.delete(_chest.key);
if (chestBox.isEmpty) {
await configBox.put('currentChest', 0);
} else {
2021-12-23 12:36:09 +01:00
int? lastChest = chestBox.toMap().keys.first;
2021-11-18 02:37:46 +01:00
await configBox.put('currentChest', lastChest);
}
2021-11-17 06:20:23 +01:00
Navigator.popUntil(
context,
ModalRoute.withName('/'),
);
2021-11-18 02:37:46 +01:00
notifyListeners();
2021-11-17 06:20:23 +01:00
}
}
2022-05-24 16:51:40 +02:00
List<String> getChestWallets(ChestData _chest) {
List<String> toDelete = [];
log.d(_chest.key);
walletBox.toMap().forEach((key, WalletData value) {
if (value.chest == _chest.key) {
toDelete.add(value.address!);
}
});
return toDelete;
}
2021-12-23 12:36:09 +01:00
Future<bool?> _confirmDeletingChest(context, String? _walletName) async {
2021-11-17 06:20:23 +01:00
return showDialog<bool>(
context: context,
barrierDismissible: true, // user must tap button!
builder: (BuildContext context) {
return AlertDialog(
title: Text(
'Êtes-vous sûr de vouloir supprimer le coffre "$_walletName" ?'),
actions: <Widget>[
TextButton(
child: const Text("Non", key: Key('cancelDeleting')),
onPressed: () {
Navigator.pop(context, false);
},
),
TextButton(
child: const Text("Oui", key: Key('confirmDeleting')),
onPressed: () {
Navigator.pop(context, true);
},
),
],
);
},
);
}
}