From 2b0ad1c7eb27a2c9960f883b5f18a27f8fd46120 Mon Sep 17 00:00:00 2001 From: julian Date: Mon, 10 Apr 2023 09:44:38 -0600 Subject: [PATCH] add search to mobile coin wallets per-coin list --- lib/pages/wallets_view/wallets_overview.dart | 255 +++++++++- .../dialogs/desktop_coin_wallets_dialog.dart | 441 ------------------ .../desktop_expanding_wallet_card.dart | 192 ++++++++ .../my_stack_view/wallet_summary_table.dart | 4 +- lib/widgets/master_wallet_card.dart | 4 +- lib/widgets/wallet_card.dart | 6 +- test/widget_tests/wallet_card_test.dart | 4 +- 7 files changed, 441 insertions(+), 465 deletions(-) delete mode 100644 lib/pages_desktop_specific/my_stack_view/dialogs/desktop_coin_wallets_dialog.dart create mode 100644 lib/pages_desktop_specific/my_stack_view/dialogs/desktop_expanding_wallet_card.dart diff --git a/lib/pages/wallets_view/wallets_overview.dart b/lib/pages/wallets_view/wallets_overview.dart index e79c13383..bc68ec30b 100644 --- a/lib/pages/wallets_view/wallets_overview.dart +++ b/lib/pages/wallets_view/wallets_overview.dart @@ -1,6 +1,14 @@ import 'package:flutter/material.dart'; import 'package:flutter_riverpod/flutter_riverpod.dart'; +import 'package:flutter_svg/svg.dart'; +import 'package:stackwallet/models/isar/models/ethereum/eth_contract.dart'; +import 'package:stackwallet/pages_desktop_specific/my_stack_view/dialogs/desktop_expanding_wallet_card.dart'; +import 'package:stackwallet/providers/db/main_db_provider.dart'; import 'package:stackwallet/providers/providers.dart'; +import 'package:stackwallet/services/coins/ethereum/ethereum_wallet.dart'; +import 'package:stackwallet/services/coins/manager.dart'; +import 'package:stackwallet/utilities/assets.dart'; +import 'package:stackwallet/utilities/constants.dart'; import 'package:stackwallet/utilities/enums/coin_enum.dart'; import 'package:stackwallet/utilities/text_styles.dart'; import 'package:stackwallet/utilities/theme/stack_colors.dart'; @@ -8,18 +16,25 @@ import 'package:stackwallet/utilities/util.dart'; import 'package:stackwallet/widgets/background.dart'; import 'package:stackwallet/widgets/conditional_parent.dart'; import 'package:stackwallet/widgets/custom_buttons/app_bar_icon_button.dart'; +import 'package:stackwallet/widgets/icon_widgets/x_icon.dart'; import 'package:stackwallet/widgets/master_wallet_card.dart'; +import 'package:stackwallet/widgets/rounded_white_container.dart'; +import 'package:stackwallet/widgets/stack_text_field.dart'; +import 'package:stackwallet/widgets/textfield_icon_button.dart'; import 'package:stackwallet/widgets/wallet_card.dart'; +import 'package:tuple/tuple.dart'; class WalletsOverview extends ConsumerStatefulWidget { const WalletsOverview({ Key? key, required this.coin, + this.navigatorState, }) : super(key: key); final Coin coin; + final NavigatorState? navigatorState; - static const routeName = "/ethWalletsOverview"; + static const routeName = "/walletsOverview"; @override ConsumerState createState() => _EthWalletsOverviewState(); @@ -28,20 +43,123 @@ class WalletsOverview extends ConsumerStatefulWidget { class _EthWalletsOverviewState extends ConsumerState { final isDesktop = Util.isDesktop; - final List walletIds = []; + late final TextEditingController _searchController; + late final FocusNode searchFieldFocusNode; + + String _searchString = ""; + + final List>> wallets = []; + + List>> _filter(String searchTerm) { + if (searchTerm.isEmpty) { + return wallets; + } + + final List>> results = []; + final term = searchTerm.toLowerCase(); + + for (final tuple in wallets) { + bool includeManager = false; + // search wallet name and total balance + includeManager |= _elementContains(tuple.item1.walletName, term); + includeManager |= _elementContains( + tuple.item1.balance.total.decimal.toString(), + term, + ); + + final List contracts = []; + + for (final contract in tuple.item2) { + if (_elementContains(contract.name, term)) { + contracts.add(contract); + } else if (_elementContains(contract.symbol, term)) { + contracts.add(contract); + } else if (_elementContains(contract.type.name, term)) { + contracts.add(contract); + } else if (_elementContains(contract.address, term)) { + contracts.add(contract); + } + } + + if (includeManager || contracts.isNotEmpty) { + results.add(Tuple2(tuple.item1, contracts)); + } + } + + return results; + } + + bool _elementContains(String element, String term) { + return element.toLowerCase().contains(term); + } @override void initState() { + _searchController = TextEditingController(); + searchFieldFocusNode = FocusNode(); + final walletsData = ref.read(walletsServiceChangeNotifierProvider).fetchWalletsData(); walletsData.removeWhere((key, value) => value.coin != widget.coin); - walletIds.clear(); - walletIds.addAll(walletsData.values.map((e) => e.walletId)); + if (widget.coin == Coin.ethereum) { + for (final data in walletsData.values) { + final List contracts = []; + final manager = + ref.read(walletsChangeNotifierProvider).getManager(data.walletId); + final contractAddresses = (manager.wallet as EthereumWallet) + .getWalletTokenContractAddresses(); + + // fetch each contract + for (final contractAddress in contractAddresses) { + final contract = ref + .read( + mainDBProvider, + ) + .getEthContractSync( + contractAddress, + ); + + // add it to list if it exists in DB + if (contract != null) { + contracts.add(contract); + } + } + + // add tuple to list + wallets.add( + Tuple2( + ref.read(walletsChangeNotifierProvider).getManager( + data.walletId, + ), + contracts, + ), + ); + } + } else { + // add non token wallet tuple to list + for (final data in walletsData.values) { + wallets.add( + Tuple2( + ref.read(walletsChangeNotifierProvider).getManager( + data.walletId, + ), + [], + ), + ); + } + } super.initState(); } + @override + void dispose() { + _searchController.dispose(); + searchFieldFocusNode.dispose(); + super.dispose(); + } + @override Widget build(BuildContext context) { return Background( @@ -64,18 +182,125 @@ class _EthWalletsOverviewState extends ConsumerState { ), ), ), - child: ListView.separated( - itemCount: walletIds.length, - separatorBuilder: (_, __) => const SizedBox( - height: 8, - ), - itemBuilder: (_, index) => widget.coin == Coin.ethereum - ? MasterWalletCard( - walletId: walletIds[index], - ) - : WalletSheetCard( - walletId: walletIds[index], + child: Column( + children: [ + ClipRRect( + borderRadius: BorderRadius.circular( + Constants.size.circularBorderRadius, + ), + child: TextField( + autocorrect: !isDesktop, + enableSuggestions: !isDesktop, + controller: _searchController, + focusNode: searchFieldFocusNode, + onChanged: (value) { + setState(() { + _searchString = value; + }); + }, + style: isDesktop + ? STextStyles.desktopTextExtraSmall(context).copyWith( + color: Theme.of(context) + .extension()! + .textFieldActiveText, + height: 1.8, + ) + : STextStyles.field(context), + decoration: standardInputDecoration( + "Search...", + searchFieldFocusNode, + context, + desktopMed: isDesktop, + ).copyWith( + prefixIcon: Padding( + padding: EdgeInsets.symmetric( + horizontal: isDesktop ? 12 : 10, + vertical: isDesktop ? 18 : 16, + ), + child: SvgPicture.asset( + Assets.svg.search, + width: isDesktop ? 20 : 16, + height: isDesktop ? 20 : 16, + ), + ), + suffixIcon: _searchController.text.isNotEmpty + ? Padding( + padding: const EdgeInsets.only(right: 0), + child: UnconstrainedBox( + child: Row( + children: [ + TextFieldIconButton( + child: const XIcon(), + onTap: () async { + setState(() { + _searchController.text = ""; + _searchString = ""; + }); + }, + ), + ], + ), + ), + ) + : null, ), + ), + ), + const SizedBox( + height: 16, + ), + Expanded( + child: Builder( + builder: (context) { + final data = _filter(_searchString); + return ListView.separated( + itemBuilder: (_, index) { + final element = data[index]; + + if (element.item1.hasTokenSupport) { + if (isDesktop) { + return DesktopExpandingWalletCard( + key: Key( + "${element.item1.walletName}_${element.item2.map((e) => e.address).join()}"), + data: element, + navigatorState: widget.navigatorState!, + ); + } else { + return MasterWalletCard( + walletId: element.item1.walletId, + ); + } + } else { + return ConditionalParent( + condition: isDesktop, + builder: (child) => RoundedWhiteContainer( + padding: const EdgeInsets.symmetric( + vertical: 14, + horizontal: 20, + ), + borderColor: Theme.of(context) + .extension()! + .backgroundAppBar, + child: child, + ), + child: SimpleWalletCard( + walletId: element.item1.walletId, + popPrevious: isDesktop, + desktopNavigatorState: + isDesktop ? widget.navigatorState : null, + ), + ); + } + }, + separatorBuilder: (_, __) => SizedBox( + height: isDesktop ? 10 : 8, + ), + itemCount: data.length, + ); + }, + ), + ), + ], ), ), ); diff --git a/lib/pages_desktop_specific/my_stack_view/dialogs/desktop_coin_wallets_dialog.dart b/lib/pages_desktop_specific/my_stack_view/dialogs/desktop_coin_wallets_dialog.dart deleted file mode 100644 index 114503206..000000000 --- a/lib/pages_desktop_specific/my_stack_view/dialogs/desktop_coin_wallets_dialog.dart +++ /dev/null @@ -1,441 +0,0 @@ -import 'package:flutter/material.dart'; -import 'package:flutter_riverpod/flutter_riverpod.dart'; -import 'package:flutter_svg/flutter_svg.dart'; -import 'package:flutter_svg/svg.dart'; -import 'package:stackwallet/models/isar/models/ethereum/eth_contract.dart'; -import 'package:stackwallet/providers/db/main_db_provider.dart'; -import 'package:stackwallet/providers/providers.dart'; -import 'package:stackwallet/services/coins/ethereum/ethereum_wallet.dart'; -import 'package:stackwallet/services/coins/manager.dart'; -import 'package:stackwallet/utilities/assets.dart'; -import 'package:stackwallet/utilities/constants.dart'; -import 'package:stackwallet/utilities/enums/coin_enum.dart'; -import 'package:stackwallet/utilities/text_styles.dart'; -import 'package:stackwallet/utilities/theme/stack_colors.dart'; -import 'package:stackwallet/utilities/util.dart'; -import 'package:stackwallet/widgets/animated_widgets/rotate_icon.dart'; -import 'package:stackwallet/widgets/expandable.dart'; -import 'package:stackwallet/widgets/icon_widgets/x_icon.dart'; -import 'package:stackwallet/widgets/rounded_white_container.dart'; -import 'package:stackwallet/widgets/stack_text_field.dart'; -import 'package:stackwallet/widgets/textfield_icon_button.dart'; -import 'package:stackwallet/widgets/wallet_card.dart'; -import 'package:stackwallet/widgets/wallet_info_row/sub_widgets/wallet_info_row_balance_future.dart'; -import 'package:stackwallet/widgets/wallet_info_row/sub_widgets/wallet_info_row_coin_icon.dart'; -import 'package:tuple/tuple.dart'; - -class DesktopCoinWalletsDialog extends ConsumerStatefulWidget { - const DesktopCoinWalletsDialog({ - Key? key, - required this.coin, - required this.navigatorState, - }) : super(key: key); - - final Coin coin; - final NavigatorState navigatorState; - - @override - ConsumerState createState() => - _DesktopCoinWalletsDialogState(); -} - -class _DesktopCoinWalletsDialogState - extends ConsumerState { - final isDesktop = Util.isDesktop; - - late final TextEditingController _searchController; - late final FocusNode searchFieldFocusNode; - - String _searchString = ""; - - final List>> wallets = []; - - List>> _filter(String searchTerm) { - if (searchTerm.isEmpty) { - return wallets; - } - - final List>> results = []; - final term = searchTerm.toLowerCase(); - - for (final tuple in wallets) { - bool includeManager = false; - // search wallet name and total balance - includeManager |= _elementContains(tuple.item1.walletName, term); - includeManager |= _elementContains( - tuple.item1.balance.total.decimal.toString(), - term, - ); - - final List contracts = []; - - for (final contract in tuple.item2) { - if (_elementContains(contract.name, term)) { - contracts.add(contract); - } else if (_elementContains(contract.symbol, term)) { - contracts.add(contract); - } else if (_elementContains(contract.type.name, term)) { - contracts.add(contract); - } else if (_elementContains(contract.address, term)) { - contracts.add(contract); - } - } - - if (includeManager || contracts.isNotEmpty) { - results.add(Tuple2(tuple.item1, contracts)); - } - } - - return results; - } - - bool _elementContains(String element, String term) { - return element.toLowerCase().contains(term); - } - - @override - void initState() { - _searchController = TextEditingController(); - searchFieldFocusNode = FocusNode(); - - final walletsData = - ref.read(walletsServiceChangeNotifierProvider).fetchWalletsData(); - walletsData.removeWhere((key, value) => value.coin != widget.coin); - - if (widget.coin == Coin.ethereum) { - for (final data in walletsData.values) { - final List contracts = []; - final manager = - ref.read(walletsChangeNotifierProvider).getManager(data.walletId); - final contractAddresses = (manager.wallet as EthereumWallet) - .getWalletTokenContractAddresses(); - - // fetch each contract - for (final contractAddress in contractAddresses) { - final contract = ref - .read( - mainDBProvider, - ) - .getEthContractSync( - contractAddress, - ); - - // add it to list if it exists in DB - if (contract != null) { - contracts.add(contract); - } - } - - // add tuple to list - wallets.add( - Tuple2( - ref.read(walletsChangeNotifierProvider).getManager( - data.walletId, - ), - contracts, - ), - ); - } - } else { - // add non token wallet tuple to list - for (final data in walletsData.values) { - wallets.add( - Tuple2( - ref.read(walletsChangeNotifierProvider).getManager( - data.walletId, - ), - [], - ), - ); - } - } - - super.initState(); - } - - @override - void dispose() { - _searchController.dispose(); - searchFieldFocusNode.dispose(); - super.dispose(); - } - - @override - Widget build(BuildContext context) { - return Column( - children: [ - ClipRRect( - borderRadius: BorderRadius.circular( - Constants.size.circularBorderRadius, - ), - child: TextField( - autocorrect: !isDesktop, - enableSuggestions: !isDesktop, - controller: _searchController, - focusNode: searchFieldFocusNode, - onChanged: (value) { - setState(() { - _searchString = value; - }); - }, - style: isDesktop - ? STextStyles.desktopTextExtraSmall(context).copyWith( - color: Theme.of(context) - .extension()! - .textFieldActiveText, - height: 1.8, - ) - : STextStyles.field(context), - decoration: standardInputDecoration( - "Search...", - searchFieldFocusNode, - context, - desktopMed: isDesktop, - ).copyWith( - prefixIcon: Padding( - padding: EdgeInsets.symmetric( - horizontal: isDesktop ? 12 : 10, - vertical: isDesktop ? 18 : 16, - ), - child: SvgPicture.asset( - Assets.svg.search, - width: isDesktop ? 20 : 16, - height: isDesktop ? 20 : 16, - ), - ), - suffixIcon: _searchController.text.isNotEmpty - ? Padding( - padding: const EdgeInsets.only(right: 0), - child: UnconstrainedBox( - child: Row( - children: [ - TextFieldIconButton( - child: const XIcon(), - onTap: () async { - setState(() { - _searchController.text = ""; - _searchString = ""; - }); - }, - ), - ], - ), - ), - ) - : null, - ), - ), - ), - const SizedBox( - height: 16, - ), - Expanded( - child: Builder(builder: (context) { - final data = _filter(_searchString); - return ListView.separated( - itemBuilder: (_, index) => widget.coin == Coin.ethereum - ? _DesktopWalletCard( - key: Key( - "${data[index].item1.walletName}_${data[index].item2.map((e) => e.address).join()}"), - data: data[index], - navigatorState: widget.navigatorState, - ) - : RoundedWhiteContainer( - padding: const EdgeInsets.symmetric( - vertical: 14, - horizontal: 20, - ), - borderColor: Theme.of(context) - .extension()! - .backgroundAppBar, - child: WalletSheetCard( - walletId: data[index].item1.walletId, - popPrevious: true, - desktopNavigatorState: widget.navigatorState, - ), - ), - separatorBuilder: (_, __) => const SizedBox( - height: 10, - ), - itemCount: data.length, - ); - }), - ), - ], - ); - } -} - -class _DesktopWalletCard extends StatefulWidget { - const _DesktopWalletCard({ - Key? key, - required this.data, - required this.navigatorState, - }) : super(key: key); - - final Tuple2> data; - final NavigatorState navigatorState; - - @override - State<_DesktopWalletCard> createState() => _DesktopWalletCardState(); -} - -class _DesktopWalletCardState extends State<_DesktopWalletCard> { - final expandableController = ExpandableController(); - final rotateIconController = RotateIconController(); - final List tokenContractAddresses = []; - - @override - void initState() { - if (widget.data.item1.hasTokenSupport) { - tokenContractAddresses.addAll( - widget.data.item2.map((e) => e.address), - ); - } - - super.initState(); - } - - @override - Widget build(BuildContext context) { - return RoundedWhiteContainer( - padding: EdgeInsets.zero, - borderColor: Theme.of(context).extension()!.backgroundAppBar, - child: Expandable( - initialState: widget.data.item1.hasTokenSupport - ? ExpandableState.expanded - : ExpandableState.collapsed, - controller: expandableController, - onExpandWillChange: (toState) { - if (toState == ExpandableState.expanded) { - rotateIconController.forward?.call(); - } else { - rotateIconController.reverse?.call(); - } - }, - header: Padding( - padding: const EdgeInsets.symmetric( - horizontal: 20, - vertical: 14, - ), - child: Row( - children: [ - Expanded( - child: Row( - children: [ - Expanded( - flex: 2, - child: Row( - children: [ - WalletInfoCoinIcon( - coin: widget.data.item1.coin, - ), - const SizedBox( - width: 12, - ), - Text( - widget.data.item1.walletName, - style: STextStyles.desktopTextExtraSmall(context) - .copyWith( - color: Theme.of(context) - .extension()! - .textDark, - ), - ), - ], - ), - ), - Expanded( - flex: 4, - child: WalletInfoRowBalance( - walletId: widget.data.item1.walletId, - ), - ), - ], - ), - ), - MaterialButton( - padding: const EdgeInsets.all(5), - materialTapTargetSize: MaterialTapTargetSize.shrinkWrap, - minWidth: 32, - height: 32, - color: Theme.of(context) - .extension()! - .textFieldDefaultBG, - elevation: 0, - hoverElevation: 0, - disabledElevation: 0, - highlightElevation: 0, - shape: RoundedRectangleBorder( - borderRadius: BorderRadius.circular( - Constants.size.circularBorderRadius, - ), - ), - onPressed: () { - if (expandableController.state == ExpandableState.collapsed) { - rotateIconController.forward?.call(); - } else { - rotateIconController.reverse?.call(); - } - expandableController.toggle?.call(); - }, - child: RotateIcon( - controller: rotateIconController, - icon: RotatedBox( - quarterTurns: 2, - child: SvgPicture.asset( - Assets.svg.chevronDown, - width: 14, - ), - ), - curve: Curves.easeInOut, - ), - ), - ], - ), - ), - body: ListView( - shrinkWrap: true, - primary: false, - children: [ - Container( - width: double.infinity, - height: 1, - color: - Theme.of(context).extension()!.backgroundAppBar, - ), - Padding( - padding: const EdgeInsets.only( - left: 32, - right: 14, - top: 14, - bottom: 14, - ), - child: WalletSheetCard( - walletId: widget.data.item1.walletId, - popPrevious: true, - desktopNavigatorState: widget.navigatorState, - ), - ), - ...tokenContractAddresses.map( - (e) => Padding( - padding: const EdgeInsets.only( - left: 32, - right: 14, - top: 14, - bottom: 14, - ), - child: WalletSheetCard( - walletId: widget.data.item1.walletId, - contractAddress: e, - popPrevious: true, - desktopNavigatorState: widget.navigatorState, - ), - ), - ), - ], - ), - ), - ); - } -} diff --git a/lib/pages_desktop_specific/my_stack_view/dialogs/desktop_expanding_wallet_card.dart b/lib/pages_desktop_specific/my_stack_view/dialogs/desktop_expanding_wallet_card.dart new file mode 100644 index 000000000..3d40d7e9e --- /dev/null +++ b/lib/pages_desktop_specific/my_stack_view/dialogs/desktop_expanding_wallet_card.dart @@ -0,0 +1,192 @@ +import 'package:flutter/material.dart'; +import 'package:flutter_svg/flutter_svg.dart'; +import 'package:flutter_svg/svg.dart'; +import 'package:stackwallet/models/isar/models/ethereum/eth_contract.dart'; +import 'package:stackwallet/services/coins/manager.dart'; +import 'package:stackwallet/utilities/assets.dart'; +import 'package:stackwallet/utilities/constants.dart'; +import 'package:stackwallet/utilities/text_styles.dart'; +import 'package:stackwallet/utilities/theme/stack_colors.dart'; +import 'package:stackwallet/widgets/animated_widgets/rotate_icon.dart'; +import 'package:stackwallet/widgets/expandable.dart'; +import 'package:stackwallet/widgets/rounded_white_container.dart'; +import 'package:stackwallet/widgets/wallet_card.dart'; +import 'package:stackwallet/widgets/wallet_info_row/sub_widgets/wallet_info_row_balance_future.dart'; +import 'package:stackwallet/widgets/wallet_info_row/sub_widgets/wallet_info_row_coin_icon.dart'; +import 'package:tuple/tuple.dart'; + +class DesktopExpandingWalletCard extends StatefulWidget { + const DesktopExpandingWalletCard({ + Key? key, + required this.data, + required this.navigatorState, + }) : super(key: key); + + final Tuple2> data; + final NavigatorState navigatorState; + + @override + State createState() => + _DesktopExpandingWalletCardState(); +} + +class _DesktopExpandingWalletCardState + extends State { + final expandableController = ExpandableController(); + final rotateIconController = RotateIconController(); + final List tokenContractAddresses = []; + + @override + void initState() { + if (widget.data.item1.hasTokenSupport) { + tokenContractAddresses.addAll( + widget.data.item2.map((e) => e.address), + ); + } + + super.initState(); + } + + @override + Widget build(BuildContext context) { + return RoundedWhiteContainer( + padding: EdgeInsets.zero, + borderColor: Theme.of(context).extension()!.backgroundAppBar, + child: Expandable( + initialState: widget.data.item1.hasTokenSupport + ? ExpandableState.expanded + : ExpandableState.collapsed, + controller: expandableController, + onExpandWillChange: (toState) { + if (toState == ExpandableState.expanded) { + rotateIconController.forward?.call(); + } else { + rotateIconController.reverse?.call(); + } + }, + header: Padding( + padding: const EdgeInsets.symmetric( + horizontal: 20, + vertical: 14, + ), + child: Row( + children: [ + Expanded( + child: Row( + children: [ + Expanded( + flex: 2, + child: Row( + children: [ + WalletInfoCoinIcon( + coin: widget.data.item1.coin, + ), + const SizedBox( + width: 12, + ), + Text( + widget.data.item1.walletName, + style: STextStyles.desktopTextExtraSmall(context) + .copyWith( + color: Theme.of(context) + .extension()! + .textDark, + ), + ), + ], + ), + ), + Expanded( + flex: 4, + child: WalletInfoRowBalance( + walletId: widget.data.item1.walletId, + ), + ), + ], + ), + ), + MaterialButton( + padding: const EdgeInsets.all(5), + materialTapTargetSize: MaterialTapTargetSize.shrinkWrap, + minWidth: 32, + height: 32, + color: Theme.of(context) + .extension()! + .textFieldDefaultBG, + elevation: 0, + hoverElevation: 0, + disabledElevation: 0, + highlightElevation: 0, + shape: RoundedRectangleBorder( + borderRadius: BorderRadius.circular( + Constants.size.circularBorderRadius, + ), + ), + onPressed: () { + if (expandableController.state == ExpandableState.collapsed) { + rotateIconController.forward?.call(); + } else { + rotateIconController.reverse?.call(); + } + expandableController.toggle?.call(); + }, + child: RotateIcon( + controller: rotateIconController, + icon: RotatedBox( + quarterTurns: 2, + child: SvgPicture.asset( + Assets.svg.chevronDown, + width: 14, + ), + ), + curve: Curves.easeInOut, + ), + ), + ], + ), + ), + body: ListView( + shrinkWrap: true, + primary: false, + children: [ + Container( + width: double.infinity, + height: 1, + color: + Theme.of(context).extension()!.backgroundAppBar, + ), + Padding( + padding: const EdgeInsets.only( + left: 32, + right: 14, + top: 14, + bottom: 14, + ), + child: SimpleWalletCard( + walletId: widget.data.item1.walletId, + popPrevious: true, + desktopNavigatorState: widget.navigatorState, + ), + ), + ...tokenContractAddresses.map( + (e) => Padding( + padding: const EdgeInsets.only( + left: 32, + right: 14, + top: 14, + bottom: 14, + ), + child: SimpleWalletCard( + walletId: widget.data.item1.walletId, + contractAddress: e, + popPrevious: true, + desktopNavigatorState: widget.navigatorState, + ), + ), + ), + ], + ), + ), + ); + } +} diff --git a/lib/pages_desktop_specific/my_stack_view/wallet_summary_table.dart b/lib/pages_desktop_specific/my_stack_view/wallet_summary_table.dart index 9741ae905..505906849 100644 --- a/lib/pages_desktop_specific/my_stack_view/wallet_summary_table.dart +++ b/lib/pages_desktop_specific/my_stack_view/wallet_summary_table.dart @@ -1,7 +1,7 @@ import 'package:flutter/material.dart'; import 'package:flutter_riverpod/flutter_riverpod.dart'; import 'package:flutter_svg/svg.dart'; -import 'package:stackwallet/pages_desktop_specific/my_stack_view/dialogs/desktop_coin_wallets_dialog.dart'; +import 'package:stackwallet/pages/wallets_view/wallets_overview.dart'; import 'package:stackwallet/providers/providers.dart'; import 'package:stackwallet/utilities/amount/amount.dart'; import 'package:stackwallet/utilities/assets.dart'; @@ -103,7 +103,7 @@ class _DesktopWalletSummaryRowState extends State { right: 32, bottom: 32, ), - child: DesktopCoinWalletsDialog( + child: WalletsOverview( coin: widget.coin, navigatorState: Navigator.of(context), ), diff --git a/lib/widgets/master_wallet_card.dart b/lib/widgets/master_wallet_card.dart index 165ae9ec5..929edb039 100644 --- a/lib/widgets/master_wallet_card.dart +++ b/lib/widgets/master_wallet_card.dart @@ -116,7 +116,7 @@ class _MasterWalletCardState extends ConsumerState { padding: const EdgeInsets.all( 7, ), - child: WalletSheetCard( + child: SimpleWalletCard( walletId: widget.walletId, popPrevious: true, ), @@ -128,7 +128,7 @@ class _MasterWalletCardState extends ConsumerState { right: 7, bottom: 7, ), - child: WalletSheetCard( + child: SimpleWalletCard( walletId: widget.walletId, contractAddress: e, popPrevious: true, diff --git a/lib/widgets/wallet_card.dart b/lib/widgets/wallet_card.dart index 9e4fbc034..5e1ed21fd 100644 --- a/lib/widgets/wallet_card.dart +++ b/lib/widgets/wallet_card.dart @@ -21,8 +21,8 @@ import 'package:stackwallet/widgets/rounded_white_container.dart'; import 'package:stackwallet/widgets/wallet_info_row/wallet_info_row.dart'; import 'package:tuple/tuple.dart'; -class WalletSheetCard extends ConsumerWidget { - const WalletSheetCard({ +class SimpleWalletCard extends ConsumerWidget { + const SimpleWalletCard({ Key? key, required this.walletId, this.contractAddress, @@ -113,7 +113,7 @@ class WalletSheetCard extends ConsumerWidget { child: MaterialButton( // splashColor: Theme.of(context).extension()!.highlight, key: Key("walletsSheetItemButtonKey_$walletId"), - padding: const EdgeInsets.all(5), + padding: const EdgeInsets.all(10), materialTapTargetSize: MaterialTapTargetSize.shrinkWrap, shape: RoundedRectangleBorder( borderRadius: BorderRadius.circular( diff --git a/test/widget_tests/wallet_card_test.dart b/test/widget_tests/wallet_card_test.dart index c8d2231c8..fe2479e1e 100644 --- a/test/widget_tests/wallet_card_test.dart +++ b/test/widget_tests/wallet_card_test.dart @@ -84,7 +84,7 @@ void main() { ), home: mockingjay.MockNavigatorProvider( navigator: navigator, - child: const WalletSheetCard( + child: const SimpleWalletCard( walletId: "wallet id", )), ), @@ -122,7 +122,7 @@ void main() { mockito.when(wallets.getManagerProvider("wallet id")).thenAnswer( (realInvocation) => ChangeNotifierProvider((ref) => manager)); - const walletSheetCard = WalletSheetCard( + const walletSheetCard = SimpleWalletCard( walletId: "wallet id", );