stack_wallet/lib/widgets/wallet_card.dart

199 lines
5.9 KiB
Dart
Raw Permalink Normal View History

2023-05-26 21:21:16 +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 Cypher Stack on 2023-05-26
*
*/
import 'dart:async';
2022-08-26 08:11:35 +00:00
import 'package:flutter/material.dart';
import 'package:flutter_riverpod/flutter_riverpod.dart';
2024-05-27 23:56:22 +00:00
import '../models/isar/models/ethereum/eth_contract.dart';
import '../pages/token_view/token_view.dart';
import '../pages/wallet_view/wallet_view.dart';
import '../pages_desktop_specific/my_stack_view/wallet_view/desktop_token_view.dart';
import '../pages_desktop_specific/my_stack_view/wallet_view/desktop_wallet_view.dart';
import '../providers/db/main_db_provider.dart';
import '../providers/providers.dart';
import '../utilities/constants.dart';
import '../utilities/logger.dart';
import '../utilities/show_loading.dart';
import '../utilities/util.dart';
import '../wallets/isar/providers/eth/current_token_wallet_provider.dart';
import '../wallets/wallet/impl/ethereum_wallet.dart';
import '../wallets/wallet/impl/sub_wallets/eth_token_wallet.dart';
import '../wallets/wallet/wallet.dart';
import '../wallets/wallet/wallet_mixin_interfaces/cw_based_interface.dart';
import 'conditional_parent.dart';
import 'desktop/primary_button.dart';
import 'dialogs/basic_dialog.dart';
import 'rounded_white_container.dart';
import 'wallet_info_row/wallet_info_row.dart';
2022-08-26 08:11:35 +00:00
class SimpleWalletCard extends ConsumerWidget {
const SimpleWalletCard({
2024-05-27 23:56:22 +00:00
super.key,
2022-08-26 08:11:35 +00:00
required this.walletId,
this.contractAddress,
2022-08-26 08:11:35 +00:00
this.popPrevious = false,
2023-04-03 22:22:40 +00:00
this.desktopNavigatorState,
2024-05-27 23:56:22 +00:00
});
2022-08-26 08:11:35 +00:00
final String walletId;
final String? contractAddress;
2022-08-26 08:11:35 +00:00
final bool popPrevious;
2023-04-03 22:22:40 +00:00
final NavigatorState? desktopNavigatorState;
2022-08-26 08:11:35 +00:00
Future<bool> _loadTokenWallet(
BuildContext context,
WidgetRef ref,
Wallet wallet,
EthContract contract,
) async {
2024-01-10 22:53:12 +00:00
final old = ref.read(tokenServiceStateProvider);
// exit previous if there is one
unawaited(old?.exit());
2024-01-10 23:40:42 +00:00
ref.read(tokenServiceStateProvider.state).state = Wallet.loadTokenWallet(
ethWallet: wallet as EthereumWallet,
contract: contract,
) as EthTokenWallet;
try {
2024-01-10 22:53:12 +00:00
await ref.read(pCurrentTokenWallet)!.init();
return true;
} catch (_) {
await showDialog<void>(
barrierDismissible: false,
context: context,
builder: (context) => BasicDialog(
title: "Failed to load token data",
desktopHeight: double.infinity,
desktopWidth: 450,
rightButton: PrimaryButton(
label: "OK",
onPressed: () {
Navigator.of(context).pop();
Navigator.of(context).pop();
if (desktopNavigatorState == null) {
Navigator.of(context).pop();
}
},
),
),
);
return false;
}
}
2023-04-03 22:22:40 +00:00
void _openWallet(BuildContext context, WidgetRef ref) async {
final nav = Navigator.of(context);
final wallet = ref.read(pWallets).getWallet(walletId);
2023-04-03 22:22:40 +00:00
if (context.mounted) {
final Future<void> loadFuture;
if (wallet is CwBasedInterface) {
loadFuture = wallet.init().then((value) async => await (wallet).open());
} else {
loadFuture = wallet.init();
}
await showLoading(
whileFuture: loadFuture,
context: context,
message: 'Opening ${wallet.info.name}',
2024-05-03 18:22:19 +00:00
rootNavigator: Util.isDesktop,
);
2023-04-03 22:22:40 +00:00
if (popPrevious) nav.pop();
if (desktopNavigatorState != null) {
unawaited(
desktopNavigatorState!.pushNamed(
DesktopWalletView.routeName,
arguments: walletId,
2022-08-26 08:11:35 +00:00
),
2023-04-03 22:22:40 +00:00
);
} else {
unawaited(
nav.pushNamed(
WalletView.routeName,
arguments: walletId,
2023-04-03 22:22:40 +00:00
),
);
}
2023-03-28 22:21:26 +00:00
2023-04-03 22:22:40 +00:00
if (contractAddress != null) {
final contract =
ref.read(mainDBProvider).getEthContractSync(contractAddress!)!;
final success = await showLoading<bool>(
whileFuture: _loadTokenWallet(
2024-05-27 23:56:22 +00:00
desktopNavigatorState?.context ?? context,
ref,
wallet,
contract,
),
context: desktopNavigatorState?.context ?? context,
2023-04-03 22:22:40 +00:00
opaqueBG: true,
message: "Loading ${contract.name}",
2024-05-03 18:22:19 +00:00
rootNavigator: Util.isDesktop,
2023-04-03 22:22:40 +00:00
);
if (!success!) {
2023-07-01 20:09:38 +00:00
// TODO: show error dialog here?
Logging.instance.log(
"Failed to load token wallet for $contract",
level: LogLevel.Error,
);
return;
}
2023-04-03 22:22:40 +00:00
if (desktopNavigatorState != null) {
2023-04-03 23:05:48 +00:00
await desktopNavigatorState!.pushNamed(
DesktopTokenView.routeName,
arguments: walletId,
);
2023-04-03 22:22:40 +00:00
} else {
await nav.pushNamed(
TokenView.routeName,
2023-10-17 17:21:53 +00:00
arguments: (walletId: walletId, popPrevious: !Util.isDesktop),
2023-04-03 22:22:40 +00:00
);
}
}
}
}
2023-03-28 22:21:26 +00:00
2023-04-03 22:22:40 +00:00
@override
Widget build(BuildContext context, WidgetRef ref) {
return ConditionalParent(
condition: !Util.isDesktop,
builder: (child) => RoundedWhiteContainer(
padding: const EdgeInsets.all(0),
child: MaterialButton(
// splashColor: Theme.of(context).extension<StackColors>()!.highlight,
key: Key("walletsSheetItemButtonKey_$walletId"),
padding: const EdgeInsets.all(10),
2023-04-03 22:22:40 +00:00
materialTapTargetSize: MaterialTapTargetSize.shrinkWrap,
shape: RoundedRectangleBorder(
borderRadius: BorderRadius.circular(
Constants.size.circularBorderRadius,
),
),
onPressed: () => _openWallet(context, ref),
child: child,
2022-08-26 08:11:35 +00:00
),
),
2023-04-03 22:22:40 +00:00
child: WalletInfoRow(
walletId: walletId,
contractAddress: contractAddress,
onPressedDesktop:
Util.isDesktop ? () => _openWallet(context, ref) : null,
),
2022-08-26 08:11:35 +00:00
);
}
}