Merge pull request #69 from cypherstack/staging

Staging
This commit is contained in:
Rylee Davis 2022-09-19 13:40:09 -06:00 committed by GitHub
commit 41ade117a2
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
8 changed files with 78 additions and 51 deletions

View file

@ -6,22 +6,26 @@ class ContactAddressEntry {
final Coin coin; final Coin coin;
final String address; final String address;
final String label; final String label;
final String? other;
const ContactAddressEntry({ const ContactAddressEntry({
required this.coin, required this.coin,
required this.address, required this.address,
required this.label, required this.label,
this.other,
}); });
ContactAddressEntry copyWith({ ContactAddressEntry copyWith({
Coin? coin, Coin? coin,
String? address, String? address,
String? label, String? label,
String? other,
}) { }) {
return ContactAddressEntry( return ContactAddressEntry(
coin: coin ?? this.coin, coin: coin ?? this.coin,
address: address ?? this.address, address: address ?? this.address,
label: label ?? this.label, label: label ?? this.label,
other: other ?? this.other,
); );
} }
@ -30,6 +34,7 @@ class ContactAddressEntry {
coin: Coin.values.byName(jsonObject["coin"] as String), coin: Coin.values.byName(jsonObject["coin"] as String),
address: jsonObject["address"] as String, address: jsonObject["address"] as String,
label: jsonObject["label"] as String, label: jsonObject["label"] as String,
other: jsonObject["other"] as String?,
); );
} }
@ -38,6 +43,7 @@ class ContactAddressEntry {
"label": label, "label": label,
"address": address, "address": address,
"coin": coin.name, "coin": coin.name,
"other": other ?? "",
}; };
} }

View file

@ -73,6 +73,7 @@ class _AddressBookViewState extends ConsumerState<AddressBookView> {
coin: manager.coin, coin: manager.coin,
address: await manager.currentReceivingAddress, address: await manager.currentReceivingAddress,
label: "Current Receiving", label: "Current Receiving",
other: manager.walletName,
), ),
); );
} }

View file

@ -208,10 +208,18 @@ class ContactPopUp extends ConsumerWidget {
crossAxisAlignment: crossAxisAlignment:
CrossAxisAlignment.start, CrossAxisAlignment.start,
children: [ children: [
Text( if (contact.id == "default")
"${e.label} (${e.coin.ticker})", Text(
style: STextStyles.itemSubtitle12, e.other!,
), style:
STextStyles.itemSubtitle12,
),
if (contact.id != "default")
Text(
"${e.label} (${e.coin.ticker})",
style:
STextStyles.itemSubtitle12,
),
const SizedBox( const SizedBox(
height: 2, height: 2,
), ),

View file

@ -189,7 +189,7 @@ class _WalletViewState extends ConsumerState<WalletView> {
return false; return false;
} }
void _logout() { void _logout() async {
if (_shouldDisableAutoSyncOnLogOut) { if (_shouldDisableAutoSyncOnLogOut) {
// disable auto sync if it was enabled only when loading wallet // disable auto sync if it was enabled only when loading wallet
ref.read(managerProvider).shouldAutoSync = false; ref.read(managerProvider).shouldAutoSync = false;
@ -199,7 +199,7 @@ class _WalletViewState extends ConsumerState<WalletView> {
if (ref.read(prefsChangeNotifierProvider).isAutoBackupEnabled && if (ref.read(prefsChangeNotifierProvider).isAutoBackupEnabled &&
ref.read(prefsChangeNotifierProvider).backupFrequencyType == ref.read(prefsChangeNotifierProvider).backupFrequencyType ==
BackupFrequencyType.afterClosingAWallet) { BackupFrequencyType.afterClosingAWallet) {
ref.read(autoSWBServiceProvider).doBackup(); unawaited(ref.read(autoSWBServiceProvider).doBackup());
} }
} }
@ -364,7 +364,13 @@ class _WalletViewState extends ConsumerState<WalletView> {
onWillPop: _onWillPop, onWillPop: _onWillPop,
child: Scaffold( child: Scaffold(
appBar: AppBar( appBar: AppBar(
automaticallyImplyLeading: false, leading: AppBarBackButton(
onPressed: () {
_logout();
Navigator.of(context).pop();
},
),
titleSpacing: 0,
title: Row( title: Row(
children: [ children: [
SvgPicture.asset( SvgPicture.asset(
@ -376,9 +382,13 @@ class _WalletViewState extends ConsumerState<WalletView> {
const SizedBox( const SizedBox(
width: 16, width: 16,
), ),
Text( Expanded(
ref.watch(managerProvider.select((value) => value.walletName)), child: Text(
style: STextStyles.navBarTitle, ref.watch(
managerProvider.select((value) => value.walletName)),
style: STextStyles.navBarTitle,
overflow: TextOverflow.ellipsis,
),
) )
], ],
), ),

View file

@ -42,7 +42,7 @@ import 'package:stackwallet/utilities/prefs.dart';
import 'package:tuple/tuple.dart'; import 'package:tuple/tuple.dart';
import 'package:uuid/uuid.dart'; import 'package:uuid/uuid.dart';
const int MINIMUM_CONFIRMATIONS = 2; const int MINIMUM_CONFIRMATIONS = 1;
const int DUST_LIMIT = 294; const int DUST_LIMIT = 294;
const String GENESIS_HASH_MAINNET = const String GENESIS_HASH_MAINNET =

View file

@ -79,44 +79,46 @@ class WalletSheetCard extends ConsumerWidget {
const SizedBox( const SizedBox(
width: 12, width: 12,
), ),
Column( Expanded(
mainAxisAlignment: MainAxisAlignment.spaceBetween, child: Column(
crossAxisAlignment: CrossAxisAlignment.start, mainAxisAlignment: MainAxisAlignment.spaceBetween,
children: [ crossAxisAlignment: CrossAxisAlignment.start,
Text( children: [
manager.walletName, Text(
style: STextStyles.titleBold12, manager.walletName,
), style: STextStyles.titleBold12,
const SizedBox( ),
height: 2, const SizedBox(
), height: 2,
FutureBuilder( ),
future: manager.totalBalance, FutureBuilder(
builder: (builderContext, AsyncSnapshot<Decimal> snapshot) { future: manager.totalBalance,
if (snapshot.connectionState == ConnectionState.done && builder: (builderContext, AsyncSnapshot<Decimal> snapshot) {
snapshot.hasData) { if (snapshot.connectionState == ConnectionState.done &&
return Text( snapshot.hasData) {
"${Format.localizedStringAsFixed( return Text(
value: snapshot.data!, "${Format.localizedStringAsFixed(
locale: locale, value: snapshot.data!,
decimalPlaces: 8, locale: locale,
)} ${coin.ticker}", decimalPlaces: 8,
style: STextStyles.itemSubtitle, )} ${coin.ticker}",
); style: STextStyles.itemSubtitle,
} else { );
return AnimatedText( } else {
stringsToLoopThrough: const [ return AnimatedText(
"Loading balance", stringsToLoopThrough: const [
"Loading balance.", "Loading balance",
"Loading balance..", "Loading balance.",
"Loading balance..." "Loading balance..",
], "Loading balance..."
style: STextStyles.itemSubtitle, ],
); style: STextStyles.itemSubtitle,
} );
}, }
), },
], ),
],
),
), ),
], ],
), ),

View file

@ -11,7 +11,7 @@ description: Stack Wallet
# In iOS, build-name is used as CFBundleShortVersionString while build-number used as CFBundleVersion. # In iOS, build-name is used as CFBundleShortVersionString while build-number used as CFBundleVersion.
# Read more about iOS versioning at # Read more about iOS versioning at
# https://developer.apple.com/library/archive/documentation/General/Reference/InfoPlistKeyReference/Articles/CoreFoundationKeys.html # https://developer.apple.com/library/archive/documentation/General/Reference/InfoPlistKeyReference/Articles/CoreFoundationKeys.html
version: 1.4.43+58 version: 1.4.45+60
environment: environment:
sdk: ">=2.17.0 <3.0.0" sdk: ">=2.17.0 <3.0.0"

View file

@ -28,7 +28,7 @@ import 'bitcoin_wallet_test_parameters.dart';
void main() { void main() {
group("bitcoin constants", () { group("bitcoin constants", () {
test("bitcoin minimum confirmations", () async { test("bitcoin minimum confirmations", () async {
expect(MINIMUM_CONFIRMATIONS, 2); expect(MINIMUM_CONFIRMATIONS, 1);
}); });
test("bitcoin dust limit", () async { test("bitcoin dust limit", () async {
expect(DUST_LIMIT, 294); expect(DUST_LIMIT, 294);