stack_wallet/lib/pages/cashfusion/fusion_progress_view.dart

268 lines
9 KiB
Dart
Raw Normal View History

2023-10-16 21:28:09 +00:00
/*
* This file is part of Stack Wallet.
*
* Copyright (c) 2023 Cypher Stack
* All Rights Reserved.
* The code is distributed under GPLv3 license, see LICENSE file for details.
* Generated by julian on 2023-10-16
*
*/
import 'dart:async';
2023-10-16 21:28:09 +00:00
import 'package:flutter/material.dart';
2023-10-18 03:17:16 +00:00
import 'package:flutter_riverpod/flutter_riverpod.dart';
2024-09-16 22:09:34 +00:00
import 'package:wakelock_plus/wakelock_plus.dart';
2024-05-27 23:56:22 +00:00
import '../../pages_desktop_specific/cashfusion/sub_widgets/fusion_progress.dart';
import '../../providers/cash_fusion/fusion_progress_ui_state_provider.dart';
import '../../providers/global/prefs_provider.dart';
import '../../providers/global/wallets_provider.dart';
import '../../themes/stack_colors.dart';
import '../../utilities/show_loading.dart';
import '../../utilities/text_styles.dart';
import '../../utilities/util.dart';
import '../../wallets/crypto_currency/crypto_currency.dart';
import '../../wallets/isar/providers/wallet_info_provider.dart';
import '../../wallets/wallet/wallet_mixin_interfaces/cash_fusion_interface.dart';
import '../../widgets/background.dart';
import '../../widgets/custom_buttons/app_bar_icon_button.dart';
import '../../widgets/desktop/primary_button.dart';
import '../../widgets/desktop/secondary_button.dart';
import '../../widgets/rounded_container.dart';
import '../../widgets/stack_dialog.dart';
2023-10-16 21:28:09 +00:00
2023-10-18 03:17:16 +00:00
class FusionProgressView extends ConsumerStatefulWidget {
2023-10-16 21:28:09 +00:00
const FusionProgressView({
super.key,
required this.walletId,
});
static const routeName = "/cashFusionProgressView";
final String walletId;
@override
2023-10-18 03:17:16 +00:00
ConsumerState<FusionProgressView> createState() => _FusionProgressViewState();
2023-10-16 21:28:09 +00:00
}
2023-10-18 03:17:16 +00:00
class _FusionProgressViewState extends ConsumerState<FusionProgressView> {
2024-05-15 21:20:45 +00:00
late final CryptoCurrency coin;
2023-11-14 22:33:54 +00:00
2023-10-18 15:02:25 +00:00
Future<bool> _requestAndProcessCancel() async {
final shouldCancel = await showDialog<bool?>(
context: context,
barrierDismissible: false,
builder: (_) => StackDialog(
title: "Cancel fusion?",
leftButton: SecondaryButton(
label: "No",
2023-10-23 21:47:08 +00:00
buttonHeight: null,
2023-10-18 15:02:25 +00:00
onPressed: () {
Navigator.of(context).pop(false);
},
),
rightButton: PrimaryButton(
label: "Yes",
2023-10-23 21:47:08 +00:00
buttonHeight: null,
2023-10-18 15:02:25 +00:00
onPressed: () {
Navigator.of(context).pop(true);
},
),
),
);
if (shouldCancel == true && mounted) {
final fusionWallet =
ref.read(pWallets).getWallet(widget.walletId) as CashFusionInterface;
2023-10-18 15:02:25 +00:00
await showLoading(
whileFuture: Future.wait([
fusionWallet.stop(),
Future<void>.delayed(const Duration(seconds: 2)),
]),
context: context,
2024-05-03 18:22:19 +00:00
rootNavigator: Util.isDesktop,
2023-10-18 15:02:25 +00:00
message: "Stopping fusion",
);
2024-09-16 22:09:34 +00:00
await WakelockPlus.disable();
2023-10-18 15:02:25 +00:00
return true;
} else {
return false;
}
2023-10-16 21:28:09 +00:00
}
2023-11-14 22:23:57 +00:00
@override
void initState() {
2023-11-14 22:44:03 +00:00
coin = ref.read(pWalletCoin(widget.walletId));
2023-11-14 22:23:57 +00:00
super.initState();
}
@override
void dispose() {
2024-09-16 22:09:34 +00:00
WakelockPlus.disable();
super.dispose();
}
2023-10-16 21:28:09 +00:00
@override
Widget build(BuildContext context) {
final bool _succeeded =
2023-10-19 17:54:22 +00:00
ref.watch(fusionProgressUIStateProvider(widget.walletId)).succeeded;
final bool _failed =
2023-10-19 17:54:22 +00:00
ref.watch(fusionProgressUIStateProvider(widget.walletId)).failed;
final int _fusionRoundsCompleted = ref
.watch(fusionProgressUIStateProvider(widget.walletId))
.fusionRoundsCompleted;
2024-09-16 22:09:34 +00:00
WakelockPlus.enable();
2023-10-16 21:28:09 +00:00
return WillPopScope(
onWillPop: () async {
2023-10-18 15:02:25 +00:00
return await _requestAndProcessCancel();
2023-10-16 21:28:09 +00:00
},
child: Background(
child: SafeArea(
child: Scaffold(
backgroundColor:
Theme.of(context).extension<StackColors>()!.background,
appBar: AppBar(
automaticallyImplyLeading: false,
leading: AppBarBackButton(
onPressed: () async {
2023-10-18 15:02:25 +00:00
if (await _requestAndProcessCancel()) {
2023-10-16 21:28:09 +00:00
if (mounted) {
Navigator.of(context).pop();
}
}
},
),
title: Text(
"Fusion progress",
style: STextStyles.navBarTitle(context),
),
titleSpacing: 0,
),
body: LayoutBuilder(
builder: (builderContext, constraints) {
return SingleChildScrollView(
child: ConstrainedBox(
constraints: BoxConstraints(
minHeight: constraints.maxHeight,
),
child: IntrinsicHeight(
child: Padding(
padding: const EdgeInsets.all(16),
child: Column(
crossAxisAlignment: CrossAxisAlignment.stretch,
2023-10-16 21:28:09 +00:00
children: [
if (_fusionRoundsCompleted == 0)
RoundedContainer(
color: Theme.of(context)
.extension<StackColors>()!
.snackBarBackError,
child: Text(
"Do not close this window. If you exit, "
"the process will be canceled.",
style:
STextStyles.smallMed14(context).copyWith(
color: Theme.of(context)
.extension<StackColors>()!
.snackBarTextError,
),
textAlign: TextAlign.center,
),
),
if (_fusionRoundsCompleted > 0)
RoundedContainer(
color: Theme.of(context)
.extension<StackColors>()!
.snackBarBackInfo,
child: Text(
"Fusion rounds completed: $_fusionRoundsCompleted",
style: STextStyles.w500_14(context).copyWith(
color: Theme.of(context)
.extension<StackColors>()!
.snackBarTextInfo,
),
textAlign: TextAlign.center,
),
),
const SizedBox(
height: 20,
),
2023-10-16 22:08:15 +00:00
FusionProgress(
walletId: widget.walletId,
2023-10-16 21:28:09 +00:00
),
2023-10-24 22:11:53 +00:00
const Spacer(),
const SizedBox(
height: 16,
),
2023-10-19 17:54:22 +00:00
if (_succeeded)
2023-10-24 18:59:09 +00:00
PrimaryButton(
label: "Fuse again",
2023-10-24 22:43:41 +00:00
onPressed: _fuseAgain,
),
2023-10-24 22:11:53 +00:00
if (_succeeded)
const SizedBox(
height: 16,
),
2023-10-19 17:54:22 +00:00
if (_failed)
2023-10-24 18:59:09 +00:00
PrimaryButton(
label: "Try again",
2023-10-24 22:43:41 +00:00
onPressed: _fuseAgain,
),
2023-10-24 22:11:53 +00:00
if (_failed)
const SizedBox(
height: 16,
),
2023-10-16 21:28:09 +00:00
SecondaryButton(
2023-10-18 15:02:25 +00:00
label: "Cancel",
2023-10-16 21:28:09 +00:00
onPressed: () async {
2023-10-18 15:02:25 +00:00
if (await _requestAndProcessCancel()) {
2023-10-16 21:28:09 +00:00
if (mounted) {
Navigator.of(context).pop();
}
}
},
),
],
),
),
),
),
);
},
),
),
),
),
);
}
/// Fuse again.
void _fuseAgain() async {
final fusionWallet =
ref.read(pWallets).getWallet(widget.walletId) as CashFusionInterface;
2023-11-14 22:23:57 +00:00
final fusionInfo =
ref.read(prefsChangeNotifierProvider).getFusionServerInfo(coin);
try {
fusionWallet.uiState = ref.read(
fusionProgressUIStateProvider(widget.walletId),
);
} catch (e) {
if (!e.toString().contains(
2024-05-27 23:56:22 +00:00
"FusionProgressUIState was already set for ${widget.walletId}",
)) {
rethrow;
}
}
unawaited(fusionWallet.fuse(fusionInfo: fusionInfo));
}
2023-10-16 21:28:09 +00:00
}