stack_wallet/lib/widgets/wallet_card.dart

107 lines
3.7 KiB
Dart
Raw Normal View History

import 'dart:async';
2022-08-26 08:11:35 +00:00
import 'package:flutter/material.dart';
import 'package:flutter_riverpod/flutter_riverpod.dart';
import 'package:stackwallet/pages/token_view/token_view.dart';
2022-08-26 08:11:35 +00:00
import 'package:stackwallet/pages/wallet_view/wallet_view.dart';
import 'package:stackwallet/providers/db/main_db_provider.dart';
import 'package:stackwallet/providers/global/secure_store_provider.dart';
2022-08-26 08:11:35 +00:00
import 'package:stackwallet/providers/providers.dart';
import 'package:stackwallet/services/coins/ethereum/ethereum_wallet.dart';
import 'package:stackwallet/services/ethereum/ethereum_token_service.dart';
import 'package:stackwallet/services/transaction_notification_tracker.dart';
2022-08-26 08:11:35 +00:00
import 'package:stackwallet/utilities/constants.dart';
2023-01-02 17:08:13 +00:00
import 'package:stackwallet/utilities/enums/coin_enum.dart';
2023-03-28 22:21:26 +00:00
import 'package:stackwallet/utilities/show_loading.dart';
2022-08-26 08:11:35 +00:00
import 'package:stackwallet/widgets/rounded_white_container.dart';
2022-09-19 17:32:33 +00:00
import 'package:stackwallet/widgets/wallet_info_row/wallet_info_row.dart';
2022-08-26 08:11:35 +00:00
import 'package:tuple/tuple.dart';
class WalletSheetCard extends ConsumerWidget {
const WalletSheetCard({
Key? key,
required this.walletId,
this.contractAddress,
2022-08-26 08:11:35 +00:00
this.popPrevious = false,
}) : super(key: key);
final String walletId;
final String? contractAddress;
2022-08-26 08:11:35 +00:00
final bool popPrevious;
@override
Widget build(BuildContext context, WidgetRef ref) {
return RoundedWhiteContainer(
padding: const EdgeInsets.all(0),
child: MaterialButton(
// splashColor: Theme.of(context).extension<StackColors>()!.highlight,
2022-08-26 08:11:35 +00:00
key: Key("walletsSheetItemButtonKey_$walletId"),
padding: const EdgeInsets.all(5),
materialTapTargetSize: MaterialTapTargetSize.shrinkWrap,
shape: RoundedRectangleBorder(
borderRadius: BorderRadius.circular(
Constants.size.circularBorderRadius,
),
),
2023-01-02 17:08:13 +00:00
onPressed: () async {
2023-03-28 22:21:26 +00:00
final nav = Navigator.of(context);
final manager =
ref.read(walletsChangeNotifierProvider).getManager(walletId);
if (manager.coin == Coin.monero || manager.coin == Coin.wownero) {
2023-01-02 17:08:13 +00:00
await manager.initializeExisting();
}
if (context.mounted) {
2023-03-28 22:21:26 +00:00
if (popPrevious) nav.pop();
unawaited(
2023-03-28 22:21:26 +00:00
nav.pushNamed(
WalletView.routeName,
arguments: Tuple2(
walletId,
ref
.read(walletsChangeNotifierProvider)
.getManagerProvider(walletId)),
),
);
if (contractAddress != null) {
final contract = ref
.read(mainDBProvider)
.getEthContractSync(contractAddress!)!;
ref.read(tokenServiceStateProvider.state).state = EthTokenWallet(
token: contract,
secureStore: ref.read(secureStoreProvider),
ethWallet: manager.wallet as EthereumWallet,
tracker: TransactionNotificationTracker(
walletId: walletId,
),
);
await showLoading<void>(
whileFuture: ref.read(tokenServiceProvider)!.initialize(),
context: context,
opaqueBG: true,
message: "Loading ${contract.name}",
);
2023-03-28 22:21:26 +00:00
// pop loading
nav.pop();
// if (context.mounted) {
await nav.pushNamed(
TokenView.routeName,
arguments: walletId,
);
// }
}
}
2022-08-26 08:11:35 +00:00
},
2022-09-19 17:32:33 +00:00
child: WalletInfoRow(
walletId: walletId,
contractAddress: contractAddress,
2022-08-26 08:11:35 +00:00
),
),
);
}
}