diff --git a/assets/images/notification_icon.png b/assets/images/notification_icon.png
deleted file mode 100644
index a6d60211a0..0000000000
Binary files a/assets/images/notification_icon.png and /dev/null differ
diff --git a/assets/images/notification_icon.svg b/assets/images/notification_icon.svg
new file mode 100644
index 0000000000..099039e67d
--- /dev/null
+++ b/assets/images/notification_icon.svg
@@ -0,0 +1,69 @@
+
+
+
+
\ No newline at end of file
diff --git a/assets/text/Monerocom_Release_Notes.txt b/assets/text/Monerocom_Release_Notes.txt
index 732e58a188..05f78b809e 100644
--- a/assets/text/Monerocom_Release_Notes.txt
+++ b/assets/text/Monerocom_Release_Notes.txt
@@ -1,2 +1,2 @@
-New themes
+In-App live status page for the app services
Bug fixes and enhancements
\ No newline at end of file
diff --git a/assets/text/Release_Notes.txt b/assets/text/Release_Notes.txt
index 1c2ec154cb..05f78b809e 100644
--- a/assets/text/Release_Notes.txt
+++ b/assets/text/Release_Notes.txt
@@ -1,6 +1,2 @@
-Add Solana wallet
-Support ALL Bitcoin address types (Legacy, Segwit (both variants), Taproot)
-Enhance Sending/Receiving flow for Bitcoin
-Improve fee calculations in Bitcoin
-New themes
+In-App live status page for the app services
Bug fixes and enhancements
\ No newline at end of file
diff --git a/cw_core/lib/monero_transaction_priority.dart b/cw_core/lib/monero_transaction_priority.dart
index f5c00ecc7b..81058f336a 100644
--- a/cw_core/lib/monero_transaction_priority.dart
+++ b/cw_core/lib/monero_transaction_priority.dart
@@ -1,7 +1,4 @@
import 'package:cw_core/transaction_priority.dart';
-import 'package:cw_core/wallet_type.dart';
-//import 'package:cake_wallet/generated/i18n.dart';
-import 'package:cw_core/enumerable_item.dart';
class MoneroTransactionPriority extends TransactionPriority {
const MoneroTransactionPriority({required String title, required int raw})
@@ -12,21 +9,20 @@ class MoneroTransactionPriority extends TransactionPriority {
MoneroTransactionPriority.automatic,
MoneroTransactionPriority.medium,
MoneroTransactionPriority.fast,
- MoneroTransactionPriority.fastest
+ MoneroTransactionPriority.fastest,
];
- static const slow = MoneroTransactionPriority(title: 'Slow', raw: 0);
- static const automatic = MoneroTransactionPriority(title: 'Automatic', raw: 1);
+ static const automatic = MoneroTransactionPriority(title: 'Automatic', raw: 0);
+ static const slow = MoneroTransactionPriority(title: 'Slow', raw: 1);
static const medium = MoneroTransactionPriority(title: 'Medium', raw: 2);
static const fast = MoneroTransactionPriority(title: 'Fast', raw: 3);
static const fastest = MoneroTransactionPriority(title: 'Fastest', raw: 4);
- static const standard = slow;
static MoneroTransactionPriority deserialize({required int raw}) {
switch (raw) {
case 0:
- return slow;
- case 1:
return automatic;
+ case 1:
+ return slow;
case 2:
return medium;
case 3:
diff --git a/cw_monero/lib/monero_wallet.dart b/cw_monero/lib/monero_wallet.dart
index 58f63d7cea..5644f6f2ef 100644
--- a/cw_monero/lib/monero_wallet.dart
+++ b/cw_monero/lib/monero_wallet.dart
@@ -282,9 +282,7 @@ abstract class MoneroWalletBase
pendingTransactionDescription = await transaction_history.createTransaction(
address: address!,
amount: amount,
- priorityRaw: _credentials.priority == MoneroTransactionPriority.automatic
- ? MoneroTransactionPriority.medium.serialize()
- : _credentials.priority.serialize(),
+ priorityRaw: _credentials.priority.serialize(),
accountIndex: walletAddresses.account!.id,
preferredInputs: inputs);
}
diff --git a/lib/entities/default_settings_migration.dart b/lib/entities/default_settings_migration.dart
index fb3e9e80ce..0851d00f54 100644
--- a/lib/entities/default_settings_migration.dart
+++ b/lib/entities/default_settings_migration.dart
@@ -201,6 +201,9 @@ Future defaultSettingsMigration(
await changeSolanaCurrentNodeToDefault(
sharedPreferences: sharedPreferences, nodes: nodes);
break;
+ case 28:
+ await _updateMoneroPriority(sharedPreferences);
+ break;
default:
break;
}
@@ -215,6 +218,18 @@ Future defaultSettingsMigration(
await sharedPreferences.setInt(PreferencesKey.currentDefaultSettingsMigrationVersion, version);
}
+Future _updateMoneroPriority(SharedPreferences sharedPreferences) async {
+ final currentPriority =
+ await sharedPreferences.getInt(PreferencesKey.moneroTransactionPriority) ??
+ monero!.getDefaultTransactionPriority().serialize();
+
+ // was set to automatic but automatic should be 0
+ if (currentPriority == 1) {
+ sharedPreferences.setInt(PreferencesKey.moneroTransactionPriority,
+ monero!.getDefaultTransactionPriority().serialize()); // 0
+ }
+}
+
Future _validateWalletInfoBoxData(Box walletInfoSource) async {
try {
final root = await getApplicationDocumentsDirectory();
diff --git a/lib/main.dart b/lib/main.dart
index 0c8a4c0945..a87bcfdad8 100644
--- a/lib/main.dart
+++ b/lib/main.dart
@@ -163,7 +163,7 @@ Future initializeAppConfigs() async {
transactionDescriptions: transactionDescriptions,
secureStorage: secureStorage,
anonpayInvoiceInfo: anonpayInvoiceInfo,
- initialMigrationVersion: 27);
+ initialMigrationVersion: 28);
}
Future initialSetup(
diff --git a/lib/src/screens/dashboard/desktop_widgets/desktop_sidebar/side_menu_item.dart b/lib/src/screens/dashboard/desktop_widgets/desktop_sidebar/side_menu_item.dart
index 8119e9fd4e..940ab54cad 100644
--- a/lib/src/screens/dashboard/desktop_widgets/desktop_sidebar/side_menu_item.dart
+++ b/lib/src/screens/dashboard/desktop_widgets/desktop_sidebar/side_menu_item.dart
@@ -7,13 +7,15 @@ class SideMenuItem extends StatelessWidget {
required this.onTap,
this.imagePath,
this.icon,
+ this.widget,
this.isSelected = false,
- }) : assert((icon != null && imagePath == null) || (icon == null && imagePath != null));
+ }) : assert(widget != null || icon != null || imagePath != null);
final void Function() onTap;
final String? imagePath;
final IconData? icon;
final bool isSelected;
+ final Widget? widget;
Color _setColor(BuildContext context) {
if (isSelected) {
@@ -28,18 +30,7 @@ class SideMenuItem extends StatelessWidget {
return InkWell(
child: Padding(
padding: EdgeInsets.all(20),
- child: icon != null
- ? Icon(
- icon,
- color: _setColor(context),
- )
- : Image.asset(
- imagePath ?? '',
- fit: BoxFit.cover,
- height: 30,
- width: 30,
- color: _setColor(context),
- ),
+ child: widget ?? _getIcon(context),
),
onTap: () => onTap.call(),
highlightColor: Colors.transparent,
@@ -48,4 +39,19 @@ class SideMenuItem extends StatelessWidget {
splashColor: Colors.transparent,
);
}
+
+ Widget _getIcon(BuildContext context) {
+ return icon != null
+ ? Icon(
+ icon,
+ color: _setColor(context),
+ )
+ : Image.asset(
+ imagePath ?? '',
+ fit: BoxFit.cover,
+ height: 30,
+ width: 30,
+ color: _setColor(context),
+ );
+ }
}
diff --git a/lib/src/screens/dashboard/desktop_widgets/desktop_sidebar_wrapper.dart b/lib/src/screens/dashboard/desktop_widgets/desktop_sidebar_wrapper.dart
index f73570048d..d0ddb19e64 100644
--- a/lib/src/screens/dashboard/desktop_widgets/desktop_sidebar_wrapper.dart
+++ b/lib/src/screens/dashboard/desktop_widgets/desktop_sidebar_wrapper.dart
@@ -9,6 +9,7 @@ import 'package:cake_wallet/src/screens/dashboard/desktop_widgets/desktop_sideba
import 'package:cake_wallet/src/screens/dashboard/desktop_widgets/desktop_wallet_selection_dropdown.dart';
import 'package:cake_wallet/src/screens/dashboard/widgets/sync_indicator.dart';
import 'package:cake_wallet/src/screens/wallet_connect/widgets/modals/bottom_sheet_listener.dart';
+import 'package:cake_wallet/src/widgets/services_updates_widget.dart';
import 'package:cake_wallet/view_model/dashboard/dashboard_view_model.dart';
import 'package:cake_wallet/view_model/dashboard/desktop_sidebar_view_model.dart';
import 'package:flutter/cupertino.dart';
@@ -105,12 +106,18 @@ class DesktopSidebarWrapper extends BasePage {
? selectedIconPath
: unselectedIconPath,
),
+ SideMenuItem(
+ widget: ServicesUpdatesWidget(dashboardViewModel.getServicesStatus()),
+ isSelected: desktopSidebarViewModel.currentPage == SidebarItem.status,
+ onTap: () {},
+ ),
],
bottomItems: [
SideMenuItem(
- imagePath: 'assets/images/support_icon.png',
- isSelected: desktopSidebarViewModel.currentPage == SidebarItem.support,
- onTap: () => desktopSidebarViewModel.onPageChange(SidebarItem.support)),
+ imagePath: 'assets/images/support_icon.png',
+ isSelected: desktopSidebarViewModel.currentPage == SidebarItem.support,
+ onTap: () => desktopSidebarViewModel.onPageChange(SidebarItem.support),
+ ),
SideMenuItem(
imagePath: 'assets/images/settings_outline.png',
isSelected: desktopSidebarViewModel.currentPage == SidebarItem.settings,
diff --git a/lib/src/widgets/services_updates_widget.dart b/lib/src/widgets/services_updates_widget.dart
index 7a8614b75d..9557ff6b96 100644
--- a/lib/src/widgets/services_updates_widget.dart
+++ b/lib/src/widgets/services_updates_widget.dart
@@ -6,6 +6,7 @@ import 'package:cake_wallet/src/widgets/service_status_tile.dart';
import 'package:cake_wallet/themes/extensions/dashboard_page_theme.dart';
import 'package:cake_wallet/themes/extensions/wallet_list_theme.dart';
import 'package:flutter/material.dart';
+import 'package:flutter_svg/flutter_svg.dart';
import 'package:shared_preferences/shared_preferences.dart';
import 'package:url_launcher/url_launcher.dart';
@@ -96,15 +97,16 @@ class ServicesUpdatesWidget extends StatelessWidget {
: null,
child: Stack(
children: [
- Image.asset(
- "assets/images/notification_icon.png",
+ SvgPicture.asset(
+ "assets/images/notification_icon.svg",
color: Theme.of(context).extension()!.pageTitleTextColor,
+ width: 30,
),
if (state.hasData && state.data!.hasUpdates)
Container(
height: 7,
width: 7,
- margin: EdgeInsetsDirectional.only(start: 8),
+ margin: EdgeInsetsDirectional.only(start: 15),
decoration: BoxDecoration(
color: Colors.red,
shape: BoxShape.circle,
diff --git a/lib/view_model/dashboard/dashboard_view_model.dart b/lib/view_model/dashboard/dashboard_view_model.dart
index a21a92cb42..b02c09f827 100644
--- a/lib/view_model/dashboard/dashboard_view_model.dart
+++ b/lib/view_model/dashboard/dashboard_view_model.dart
@@ -344,15 +344,13 @@ abstract class DashboardViewModelBase with Store {
bool hasExchangeAction;
@computed
- bool get isEnabledBuyAction =>
- !settingsStore.disableBuy && availableBuyProviders.isNotEmpty;
+ bool get isEnabledBuyAction => !settingsStore.disableBuy && availableBuyProviders.isNotEmpty;
@observable
bool hasBuyAction;
@computed
- bool get isEnabledSellAction =>
- !settingsStore.disableSell && availableSellProviders.isNotEmpty;
+ bool get isEnabledSellAction => !settingsStore.disableSell && availableSellProviders.isNotEmpty;
@observable
bool hasSellAction;
@@ -477,7 +475,8 @@ abstract class DashboardViewModelBase with Store {
Future> checkAffectedWallets() async {
// await load file
- final vulnerableSeedsString = await rootBundle.loadString('assets/text/cakewallet_weak_bitcoin_seeds_hashed_sorted_version1.txt');
+ final vulnerableSeedsString = await rootBundle
+ .loadString('assets/text/cakewallet_weak_bitcoin_seeds_hashed_sorted_version1.txt');
final vulnerableSeeds = vulnerableSeedsString.split("\n");
final walletInfoSource = await CakeHive.openBox(WalletInfo.boxName);
@@ -513,13 +512,16 @@ abstract class DashboardViewModelBase with Store {
final oldSha = sharedPreferences.getString(PreferencesKey.serviceStatusShaKey);
-
final hash = await Cryptography.instance.sha256().hash(utf8.encode(res.body));
final currentSha = bytesToHex(hash.bytes);
final hasUpdates = oldSha != currentSha;
- return ServicesResponse.fromJson(json.decode(res.body) as Map, hasUpdates, currentSha);
+ return ServicesResponse.fromJson(
+ json.decode(res.body) as Map,
+ hasUpdates,
+ currentSha,
+ );
} catch (_) {
return ServicesResponse([], false, '');
}
diff --git a/lib/view_model/dashboard/desktop_sidebar_view_model.dart b/lib/view_model/dashboard/desktop_sidebar_view_model.dart
index 543b44b354..52a6dc49ba 100644
--- a/lib/view_model/dashboard/desktop_sidebar_view_model.dart
+++ b/lib/view_model/dashboard/desktop_sidebar_view_model.dart
@@ -5,6 +5,7 @@ part 'desktop_sidebar_view_model.g.dart';
enum SidebarItem {
dashboard,
transactions,
+ status,
support,
settings,
}
diff --git a/scripts/android/app_env.sh b/scripts/android/app_env.sh
index fa3701fa71..eb1aaaacc7 100644
--- a/scripts/android/app_env.sh
+++ b/scripts/android/app_env.sh
@@ -15,15 +15,15 @@ TYPES=($MONERO_COM $CAKEWALLET $HAVEN)
APP_ANDROID_TYPE=$1
MONERO_COM_NAME="Monero.com"
-MONERO_COM_VERSION="1.11.0"
-MONERO_COM_BUILD_NUMBER=77
+MONERO_COM_VERSION="1.11.1"
+MONERO_COM_BUILD_NUMBER=78
MONERO_COM_BUNDLE_ID="com.monero.app"
MONERO_COM_PACKAGE="com.monero.app"
MONERO_COM_SCHEME="monero.com"
CAKEWALLET_NAME="Cake Wallet"
-CAKEWALLET_VERSION="4.14.0"
-CAKEWALLET_BUILD_NUMBER=196
+CAKEWALLET_VERSION="4.14.1"
+CAKEWALLET_BUILD_NUMBER=197
CAKEWALLET_BUNDLE_ID="com.cakewallet.cake_wallet"
CAKEWALLET_PACKAGE="com.cakewallet.cake_wallet"
CAKEWALLET_SCHEME="cakewallet"
diff --git a/scripts/android/build_monero.sh b/scripts/android/build_monero.sh
index 7e9b58b6dc..fb596e4529 100755
--- a/scripts/android/build_monero.sh
+++ b/scripts/android/build_monero.sh
@@ -1,13 +1,12 @@
#!/bin/sh
. ./config.sh
-MONERO_BRANCH=release-v0.18.2.2-android_tx_priority_fix
+MONERO_BRANCH=release-v0.18.3.2-android
MONERO_SRC_DIR=${WORKDIR}/monero
git clone https://github.com/cake-tech/monero.git ${MONERO_SRC_DIR} --branch ${MONERO_BRANCH}
cd $MONERO_SRC_DIR
-git submodule init
-git submodule update
+git submodule update --init --force
for arch in "aarch" "aarch64" "i686" "x86_64"
do
@@ -59,7 +58,7 @@ cd $MONERO_SRC_DIR
rm -rf ./build/release
mkdir -p ./build/release
cd ./build/release
-CC=${CLANG} CXX=${CXXLANG} cmake -D USE_DEVICE_TREZOR=OFF -D BUILD_GUI_DEPS=1 -D BUILD_TESTS=OFF -D ARCH=${ARCH} -D STATIC=ON -D BUILD_64=${BUILD_64} -D CMAKE_BUILD_TYPE=release -D ANDROID=true -D INSTALL_VENDORED_LIBUNBOUND=ON -D BUILD_TAG=${TAG} -D CMAKE_SYSTEM_NAME="Android" -D CMAKE_ANDROID_STANDALONE_TOOLCHAIN="${ANDROID_STANDALONE_TOOLCHAIN_PATH}" -D CMAKE_ANDROID_ARCH_ABI=${ARCH_ABI} $FLAGS ../..
+CC=${CLANG} CXX=${CXXLANG} cmake -D USE_DEVICE_TREZOR=OFF -D BUILD_GUI_DEPS=1 -D BUILD_TESTS=OFF -D ARCH=${ARCH} -D STATIC=ON -D BUILD_64=${BUILD_64} -D CMAKE_BUILD_TYPE=release -D ANDROID=true -D INSTALL_VENDORED_LIBUNBOUND=ON -D BUILD_TAG=${TAG} -D CMAKE_SYSTEM_NAME="Android" -D CMAKE_ANDROID_STANDALONE_TOOLCHAIN="${ANDROID_STANDALONE_TOOLCHAIN_PATH}" -D CMAKE_ANDROID_ARCH_ABI=${ARCH_ABI} -D MANUAL_SUBMODULES=1 $FLAGS ../..
make wallet_api -j$THREADS
find . -path ./lib -prune -o -name '*.a' -exec cp '{}' lib \;
diff --git a/scripts/ios/app_env.sh b/scripts/ios/app_env.sh
index 31f0b95485..1c778063d4 100644
--- a/scripts/ios/app_env.sh
+++ b/scripts/ios/app_env.sh
@@ -13,13 +13,13 @@ TYPES=($MONERO_COM $CAKEWALLET $HAVEN)
APP_IOS_TYPE=$1
MONERO_COM_NAME="Monero.com"
-MONERO_COM_VERSION="1.11.0"
-MONERO_COM_BUILD_NUMBER=75
+MONERO_COM_VERSION="1.11.1"
+MONERO_COM_BUILD_NUMBER=76
MONERO_COM_BUNDLE_ID="com.cakewallet.monero"
CAKEWALLET_NAME="Cake Wallet"
-CAKEWALLET_VERSION="4.14.0"
-CAKEWALLET_BUILD_NUMBER=215
+CAKEWALLET_VERSION="4.14.1"
+CAKEWALLET_BUILD_NUMBER=216
CAKEWALLET_BUNDLE_ID="com.fotolockr.cakewallet"
HAVEN_NAME="Haven"
diff --git a/scripts/ios/build_monero.sh b/scripts/ios/build_monero.sh
index 2c81576f12..6f06f22c19 100755
--- a/scripts/ios/build_monero.sh
+++ b/scripts/ios/build_monero.sh
@@ -4,7 +4,7 @@
MONERO_URL="https://github.com/cake-tech/monero.git"
MONERO_DIR_PATH="${EXTERNAL_IOS_SOURCE_DIR}/monero"
-MONERO_VERSION=release-v0.18.2.2_tx_priority_fix
+MONERO_VERSION=release-v0.18.3.2
BUILD_TYPE=release
PREFIX=${EXTERNAL_IOS_DIR}
DEST_LIB_DIR=${EXTERNAL_IOS_LIB_DIR}/monero
@@ -52,6 +52,7 @@ cmake -D IOS=ON \
-DUNBOUND_INCLUDE_DIR=${EXTERNAL_IOS_INCLUDE_DIR} \
-DCMAKE_INSTALL_PREFIX=${INSTALL_PREFIX} \
-DUSE_DEVICE_TREZOR=OFF \
+ -DMANUAL_SUBMODULES=1 \
../..
make wallet_api -j4
find . -path ./lib -prune -o -name '*.a' -exec cp '{}' lib \;
diff --git a/scripts/macos/app_env.sh b/scripts/macos/app_env.sh
index 4dec47f40f..4c84832e69 100755
--- a/scripts/macos/app_env.sh
+++ b/scripts/macos/app_env.sh
@@ -16,13 +16,13 @@ if [ -n "$1" ]; then
fi
MONERO_COM_NAME="Monero.com"
-MONERO_COM_VERSION="1.1.0"
-MONERO_COM_BUILD_NUMBER=7
+MONERO_COM_VERSION="1.1.1"
+MONERO_COM_BUILD_NUMBER=9
MONERO_COM_BUNDLE_ID="com.cakewallet.monero"
CAKEWALLET_NAME="Cake Wallet"
-CAKEWALLET_VERSION="1.7.0"
-CAKEWALLET_BUILD_NUMBER=55
+CAKEWALLET_VERSION="1.7.1"
+CAKEWALLET_BUILD_NUMBER=56
CAKEWALLET_BUNDLE_ID="com.fotolockr.cakewallet"
if ! [[ " ${TYPES[*]} " =~ " ${APP_MACOS_TYPE} " ]]; then
diff --git a/scripts/macos/build_monero.sh b/scripts/macos/build_monero.sh
index 2a1ae89a53..1af7ae0e3a 100755
--- a/scripts/macos/build_monero.sh
+++ b/scripts/macos/build_monero.sh
@@ -4,7 +4,7 @@
MONERO_URL="https://github.com/cake-tech/monero.git"
MONERO_DIR_PATH="${EXTERNAL_MACOS_SOURCE_DIR}/monero"
-MONERO_VERSION=release-v0.18.2.2_tx_priority_fix
+MONERO_VERSION=release-v0.18.3.2
BUILD_TYPE=release
PREFIX=${EXTERNAL_MACOS_DIR}
DEST_LIB_DIR=${EXTERNAL_MACOS_LIB_DIR}/monero
@@ -46,6 +46,7 @@ cmake -DARCH=${ARCH} \
-DUNBOUND_INCLUDE_DIR=${EXTERNAL_MACOS_INCLUDE_DIR} \
-DCMAKE_INSTALL_PREFIX=${INSTALL_PREFIX} \
-DUSE_DEVICE_TREZOR=OFF \
+ -DMANUAL_SUBMODULES=1 \
../..
make wallet_api -j4
find . -path ./lib -prune -o -name '*.a' -exec cp '{}' lib \;