mirror of
https://github.com/cake-tech/cake_wallet.git
synced 2025-06-28 20:39:51 +00:00
* feat: rebase btc-addr-types, migrate to bitcoin_base * feat: allow scanning elect-rs using get_tweaks * feat: scanning and adding addresses working with getTweaks, add btc SP address type * chore: pubspec.lock * chore: pubspec.lock * fix: scan when switching, fix multiple unspents in same tx * fix: initial scan * fix: initial scan * fix: scanning issues * fix: sync, storing silent unspents * chore: deps * fix: label issues, clear spent utxo * chore: deps * fix: build * fix: missing types * feat: new electrs API & changes, fixes for last block scanning * feat: Scan Silent Payments homepage toggle * chore: build configure * feat: generic fixes, testnet UI improvements, useSSL on bitcoin nodes * fix: invalid Object in sendData * feat: improve addresses page & address book displays * feat: silent payments labeled addresses disclaimer * fix: missing i18n * chore: print * feat: single block scan, rescan by date working for btc mainnet * feat: new cake features page replace market page, move sp scan toggle, auto switch node pop up alert * feat: delete silent addresses * fix: red dot in non ssl nodes * fix: inconsistent connection states, fix tx history * fix: tx & balance displays, cpfp sending * feat: new rust lib * chore: node path * fix: check node based on network * fix: missing txcount from addresses * style: padding in feature page cards * fix: restore not getting all wallet addresses by type * fix: auto switch node broken * fix: silent payment txs not being restored * feat: change scanning to subscription model, sync improvements * fix: scan re-subscription * fix: default nodes * fix: improve scanning by date, fix single block scan * refactor: common function for input tx selection * fix: nodes & build * fix: send all with multiple outs * refactor: unchanged file * Update pr_test_build.yml * chore: upgrade * chore: merge changes * refactor: unchanged files [skip ci] * fix: scan fixes, add date, allow sending while scanning * feat: sync fixes, sp settings * feat: fix resyncing * fix: date from height logic, status disconnected & chain tip get * fix: params * feat: electrum migration if using cake electrum * fix nodes update versions * re-enable tron * update sp_scanner to work on iOS [skip ci] * fix: wrong socket for old electrum nodes * Fix unchecked wallet type call * fix: double balance * feat: node domain * fix: menu name * fix: update tip on set scanning * fix: connection switching back and forth * feat: check if node is electrs, and supports sp * chore: fix build * minor enhancements * fixes and enhancements * solve conflicts with main * fix: status toggle * minor enhancement * Monero.com fixes * update sp_scanner to include windows and linux --------- Co-authored-by: Omar Hatem <omarh.ismail1@gmail.com>
241 lines
11 KiB
Dart
241 lines
11 KiB
Dart
import 'package:cake_wallet/src/screens/nano_accounts/nano_account_list_page.dart';
|
|
import 'package:cake_wallet/src/widgets/keyboard_done_button.dart';
|
|
import 'package:cake_wallet/themes/extensions/balance_page_theme.dart';
|
|
import 'package:cake_wallet/themes/extensions/keyboard_theme.dart';
|
|
import 'package:cake_wallet/themes/extensions/receive_page_theme.dart';
|
|
import 'package:cake_wallet/src/widgets/gradient_background.dart';
|
|
import 'package:cake_wallet/src/widgets/section_divider.dart';
|
|
import 'package:cake_wallet/themes/theme_base.dart';
|
|
import 'package:cake_wallet/utils/share_util.dart';
|
|
import 'package:cake_wallet/utils/show_pop_up.dart';
|
|
import 'package:cw_core/wallet_type.dart';
|
|
import 'package:flutter/material.dart';
|
|
import 'package:flutter_mobx/flutter_mobx.dart';
|
|
import 'package:cake_wallet/routes.dart';
|
|
import 'package:cake_wallet/generated/i18n.dart';
|
|
import 'package:cake_wallet/di.dart';
|
|
import 'package:cake_wallet/src/screens/base_page.dart';
|
|
import 'package:cake_wallet/src/screens/monero_accounts/monero_account_list_page.dart';
|
|
import 'package:cake_wallet/src/screens/receive/widgets/header_tile.dart';
|
|
import 'package:cake_wallet/src/screens/receive/widgets/address_cell.dart';
|
|
import 'package:cake_wallet/view_model/wallet_address_list/wallet_account_list_header.dart';
|
|
import 'package:cake_wallet/view_model/wallet_address_list/wallet_address_list_header.dart';
|
|
import 'package:cake_wallet/view_model/wallet_address_list/wallet_address_list_item.dart';
|
|
import 'package:cake_wallet/view_model/wallet_address_list/wallet_address_list_view_model.dart';
|
|
import 'package:cake_wallet/src/screens/receive/widgets/qr_widget.dart';
|
|
import 'package:keyboard_actions/keyboard_actions.dart';
|
|
|
|
class ReceivePage extends BasePage {
|
|
ReceivePage({required this.addressListViewModel})
|
|
: _cryptoAmountFocus = FocusNode(),
|
|
_amountController = TextEditingController(),
|
|
_formKey = GlobalKey<FormState>() {
|
|
_amountController.addListener(() {
|
|
if (_formKey.currentState!.validate()) {
|
|
addressListViewModel.changeAmount(_amountController.text);
|
|
}
|
|
});
|
|
}
|
|
|
|
final WalletAddressListViewModel addressListViewModel;
|
|
final TextEditingController _amountController;
|
|
final GlobalKey<FormState> _formKey;
|
|
static const _heroTag = 'receive_page';
|
|
|
|
@override
|
|
String get title => S.current.receive;
|
|
|
|
@override
|
|
bool get gradientBackground => true;
|
|
|
|
@override
|
|
bool get resizeToAvoidBottomInset => true;
|
|
|
|
final FocusNode _cryptoAmountFocus;
|
|
|
|
@override
|
|
Widget middle(BuildContext context) {
|
|
return Text(
|
|
title,
|
|
style: TextStyle(
|
|
fontSize: 18.0,
|
|
fontWeight: FontWeight.bold,
|
|
fontFamily: 'Lato',
|
|
color: pageIconColor(context)),
|
|
);
|
|
}
|
|
|
|
@override
|
|
Widget Function(BuildContext, Widget) get rootWrapper =>
|
|
(BuildContext context, Widget scaffold) => GradientBackground(scaffold: scaffold);
|
|
|
|
@override
|
|
Widget trailing(BuildContext context) {
|
|
return Material(
|
|
color: Colors.transparent,
|
|
child: Semantics(
|
|
label: S.of(context).share,
|
|
child: IconButton(
|
|
padding: EdgeInsets.zero,
|
|
constraints: BoxConstraints(),
|
|
highlightColor: Colors.transparent,
|
|
splashColor: Colors.transparent,
|
|
iconSize: 25,
|
|
onPressed: () {
|
|
ShareUtil.share(
|
|
text: addressListViewModel.uri.toString(),
|
|
context: context,
|
|
);
|
|
},
|
|
icon: Icon(
|
|
Icons.share,
|
|
size: 20,
|
|
color: pageIconColor(context),
|
|
),
|
|
),
|
|
));
|
|
}
|
|
|
|
@override
|
|
Widget body(BuildContext context) {
|
|
return KeyboardActions(
|
|
config: KeyboardActionsConfig(
|
|
keyboardActionsPlatform: KeyboardActionsPlatform.IOS,
|
|
keyboardBarColor: Theme.of(context).extension<KeyboardTheme>()!.keyboardBarColor,
|
|
nextFocus: false,
|
|
actions: [
|
|
KeyboardActionsItem(
|
|
focusNode: _cryptoAmountFocus,
|
|
toolbarButtons: [(_) => KeyboardDoneButton()],
|
|
)
|
|
]),
|
|
child: SingleChildScrollView(
|
|
child: Column(
|
|
children: <Widget>[
|
|
Padding(
|
|
padding: EdgeInsets.fromLTRB(24, 50, 24, 24),
|
|
child: QRWidget(
|
|
addressListViewModel: addressListViewModel,
|
|
formKey: _formKey,
|
|
heroTag: _heroTag,
|
|
amountTextFieldFocusNode: _cryptoAmountFocus,
|
|
amountController: _amountController,
|
|
isLight: currentTheme.type == ThemeType.light),
|
|
),
|
|
Observer(
|
|
builder: (_) => ListView.separated(
|
|
padding: EdgeInsets.all(0),
|
|
separatorBuilder: (context, _) => const HorizontalSectionDivider(),
|
|
shrinkWrap: true,
|
|
physics: NeverScrollableScrollPhysics(),
|
|
itemCount: addressListViewModel.items.length,
|
|
itemBuilder: (context, index) {
|
|
final item = addressListViewModel.items[index];
|
|
Widget cell = Container();
|
|
|
|
if (item is WalletAccountListHeader) {
|
|
cell = HeaderTile(
|
|
showTrailingButton: true,
|
|
walletAddressListViewModel: addressListViewModel,
|
|
trailingButtonTap: () async {
|
|
if (addressListViewModel.type == WalletType.monero ||
|
|
addressListViewModel.type == WalletType.haven) {
|
|
await showPopUp<void>(
|
|
context: context,
|
|
builder: (_) => getIt.get<MoneroAccountListPage>());
|
|
} else {
|
|
await showPopUp<void>(
|
|
context: context,
|
|
builder: (_) => getIt.get<NanoAccountListPage>());
|
|
}
|
|
},
|
|
title: S.of(context).accounts,
|
|
trailingIcon: Icon(
|
|
Icons.arrow_forward_ios,
|
|
size: 14,
|
|
color: Theme.of(context).extension<ReceivePageTheme>()!.iconsColor,
|
|
));
|
|
}
|
|
|
|
if (item is WalletAddressListHeader) {
|
|
final hasTitle = item.title != null;
|
|
|
|
cell = HeaderTile(
|
|
title: hasTitle ? item.title! : S.of(context).addresses,
|
|
walletAddressListViewModel: addressListViewModel,
|
|
showTrailingButton:
|
|
!addressListViewModel.isAutoGenerateSubaddressEnabled && !hasTitle,
|
|
showSearchButton: true,
|
|
trailingButtonTap: () =>
|
|
Navigator.of(context).pushNamed(Routes.newSubaddress),
|
|
trailingIcon: hasTitle
|
|
? null
|
|
: Icon(
|
|
Icons.add,
|
|
size: 20,
|
|
color:
|
|
Theme.of(context).extension<ReceivePageTheme>()!.iconsColor,
|
|
),
|
|
);
|
|
}
|
|
|
|
if (item is WalletAddressListItem) {
|
|
cell = Observer(builder: (_) {
|
|
final isCurrent = item.address == addressListViewModel.address.address;
|
|
final backgroundColor = isCurrent
|
|
? Theme.of(context)
|
|
.extension<ReceivePageTheme>()!
|
|
.currentTileBackgroundColor
|
|
: Theme.of(context)
|
|
.extension<ReceivePageTheme>()!
|
|
.tilesBackgroundColor;
|
|
final textColor = isCurrent
|
|
? Theme.of(context)
|
|
.extension<ReceivePageTheme>()!
|
|
.currentTileTextColor
|
|
: Theme.of(context).extension<ReceivePageTheme>()!.tilesTextColor;
|
|
|
|
return AddressCell.fromItem(
|
|
item,
|
|
isCurrent: isCurrent,
|
|
hasBalance: addressListViewModel.isElectrumWallet,
|
|
backgroundColor: backgroundColor,
|
|
textColor: textColor,
|
|
onTap: item.isOneTimeReceiveAddress == true
|
|
? null
|
|
: (_) => addressListViewModel.setAddress(item),
|
|
onEdit: item.isOneTimeReceiveAddress == true || item.isPrimary
|
|
? null
|
|
: () => Navigator.of(context)
|
|
.pushNamed(Routes.newSubaddress, arguments: item),
|
|
onDelete: !addressListViewModel.isSilentPayments || item.isPrimary
|
|
? null
|
|
: () => addressListViewModel.deleteAddress(item),
|
|
);
|
|
});
|
|
}
|
|
|
|
return index != 0
|
|
? cell
|
|
: ClipRRect(
|
|
borderRadius: BorderRadius.only(
|
|
topLeft: Radius.circular(30), topRight: Radius.circular(30)),
|
|
child: cell,
|
|
);
|
|
})),
|
|
Padding(
|
|
padding: EdgeInsets.fromLTRB(24, 24, 24, 32),
|
|
child: Text(
|
|
addressListViewModel.isSilentPayments
|
|
? S.of(context).silent_payments_disclaimer
|
|
: S.of(context).electrum_address_disclaimer,
|
|
textAlign: TextAlign.center,
|
|
style: TextStyle(
|
|
fontSize: 15,
|
|
color: Theme.of(context).extension<BalancePageTheme>()!.labelTextColor)),
|
|
),
|
|
],
|
|
),
|
|
));
|
|
}
|
|
}
|