From 1ff19194e74e09ae01f7b227a5a3e6bf871661cf Mon Sep 17 00:00:00 2001 From: julian Date: Fri, 7 Apr 2023 15:40:00 -0600 Subject: [PATCH] add custom token dialog modified for desktop --- .../edit_wallet_tokens_view.dart | 133 ++++++++++++------ .../sub_widgets/add_token_text.dart | 26 ++-- 2 files changed, 101 insertions(+), 58 deletions(-) diff --git a/lib/pages/add_wallet_views/add_token_view/edit_wallet_tokens_view.dart b/lib/pages/add_wallet_views/add_token_view/edit_wallet_tokens_view.dart index 7f8fd4b53..936ca5405 100644 --- a/lib/pages/add_wallet_views/add_token_view/edit_wallet_tokens_view.dart +++ b/lib/pages/add_wallet_views/add_token_view/edit_wallet_tokens_view.dart @@ -12,7 +12,6 @@ import 'package:stackwallet/pages/add_wallet_views/add_token_view/sub_widgets/ad import 'package:stackwallet/pages/add_wallet_views/add_token_view/sub_widgets/add_token_list_element.dart'; import 'package:stackwallet/pages/add_wallet_views/add_token_view/sub_widgets/add_token_text.dart'; import 'package:stackwallet/pages_desktop_specific/desktop_home_view.dart'; -import 'package:stackwallet/pages_desktop_specific/my_stack_view/exit_to_my_stack_button.dart'; import 'package:stackwallet/providers/global/wallets_provider.dart'; import 'package:stackwallet/services/coins/ethereum/ethereum_wallet.dart'; import 'package:stackwallet/utilities/assets.dart'; @@ -113,18 +112,32 @@ class _EditWalletTokensViewState extends ConsumerState { } Future _addToken() async { - final token = await Navigator.of(context).pushNamed( - AddCustomTokenView.routeName, - arguments: widget.walletId, - ); - if (token is EthContract) { - await MainDB.instance.putEthContract(token); + EthContract? contract; + + if (isDesktop) { + contract = await showDialog( + context: context, + builder: (context) => const DesktopDialog( + maxWidth: 580, + maxHeight: 500, + child: AddCustomTokenView(), + ), + ); + } else { + contract = await Navigator.of(context).pushNamed( + AddCustomTokenView.routeName, + ); + } + + if (contract != null) { + await MainDB.instance.putEthContract(contract); if (mounted) { setState(() { if (tokenEntities - .where((e) => e.token.address == token.address) + .where((e) => e.token.address == contract!.address) .isEmpty) { - tokenEntities.add(AddTokenListElementData(token)..selected = true); + tokenEntities + .add(AddTokenListElementData(contract!)..selected = true); tokenEntities.sort((a, b) => a.token.name.compareTo(b.token.name)); } }); @@ -184,51 +197,79 @@ class _EditWalletTokensViewState extends ConsumerState { builder: (child) => DesktopScaffold( appBar: DesktopAppBar( isCompactHeight: false, + useSpacers: false, leading: const AppBarBackButton(), + overlayCenter: Text( + walletName, + style: STextStyles.desktopSubtitleH2(context), + ), trailing: widget.contractsToMarkSelected == null - ? const ExitToMyStackButton() + ? Padding( + padding: const EdgeInsets.only( + right: 24, + ), + child: SizedBox( + height: 56, + child: TextButton( + style: Theme.of(context) + .extension()! + .getSmallSecondaryEnabledButtonStyle(context), + onPressed: _addToken, + child: Padding( + padding: const EdgeInsets.symmetric( + horizontal: 30, + ), + child: Text( + "Add custom token", + style: + STextStyles.desktopButtonSmallSecondaryEnabled( + context), + ), + ), + ), + ), + ) : null, ), body: SizedBox( width: 480, - child: RoundedWhiteContainer( - radiusMultiplier: 2, - padding: const EdgeInsets.only( - left: 20, - top: 20, - right: 20, - bottom: 0, - ), - child: Column( - children: [ - AddTokenText( - isDesktop: true, - walletName: walletName, - ), - const SizedBox( - height: 16, - ), - Expanded( + child: Column( + children: [ + const AddTokenText( + isDesktop: true, + ), + const SizedBox( + height: 16, + ), + Expanded( + child: RoundedWhiteContainer( + radiusMultiplier: 2, + padding: const EdgeInsets.only( + left: 20, + top: 20, + right: 20, + bottom: 0, + ), child: child, ), - const SizedBox( - height: 26, + ), + const SizedBox( + height: 26, + ), + SizedBox( + height: 70, + width: 480, + child: PrimaryButton( + label: widget.contractsToMarkSelected != null + ? "Save" + : "Next", + onPressed: onNextPressed, ), - SizedBox( - height: 70, - width: 480, - child: PrimaryButton( - label: widget.contractsToMarkSelected != null - ? "Save" - : "Next", - onPressed: onNextPressed, - ), - ), - const SizedBox( - height: 32, - ), - ], - ), + ), + const SizedBox( + height: 32, + ), + ], ), ), ), @@ -369,7 +410,7 @@ class _EditWalletTokensViewState extends ConsumerState { child: AddTokenList( walletId: widget.walletId, items: filter(_searchTerm, tokenEntities), - addFunction: widget.isDesktopPopup ? null : _addToken, + addFunction: isDesktop ? null : _addToken, ), ), const SizedBox( diff --git a/lib/pages/add_wallet_views/add_token_view/sub_widgets/add_token_text.dart b/lib/pages/add_wallet_views/add_token_view/sub_widgets/add_token_text.dart index c1edfc2eb..115d8be5c 100644 --- a/lib/pages/add_wallet_views/add_token_view/sub_widgets/add_token_text.dart +++ b/lib/pages/add_wallet_views/add_token_view/sub_widgets/add_token_text.dart @@ -5,10 +5,10 @@ class AddTokenText extends StatelessWidget { const AddTokenText({ Key? key, required this.isDesktop, - required this.walletName, + this.walletName, }) : super(key: key); - final String walletName; + final String? walletName; final bool isDesktop; @override @@ -16,16 +16,18 @@ class AddTokenText extends StatelessWidget { return Column( crossAxisAlignment: CrossAxisAlignment.stretch, children: [ - Text( - walletName, - textAlign: TextAlign.center, - style: isDesktop - ? STextStyles.sectionLabelMedium12(context) // todo: fixme - : STextStyles.sectionLabelMedium12(context), - ), - const SizedBox( - height: 4, - ), + if (walletName != null) + Text( + walletName!, + textAlign: TextAlign.center, + style: isDesktop + ? STextStyles.sectionLabelMedium12(context) // todo: fixme + : STextStyles.sectionLabelMedium12(context), + ), + if (walletName != null) + const SizedBox( + height: 4, + ), Text( "Edit Tokens", textAlign: TextAlign.center,