secant-android-wallet/CHANGELOG.md

399 lines
18 KiB
Markdown

# Changelog
All notable changes to this application will be documented in this file.
The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/),
and this application adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
## [Unreleased]
### Added
- The device authentication feature on the Zashi app launch has been added
- The Flexa SDK has been adopted to enable payments using the embedded Flexa UI
### Fixed
- Address book toast now correctly shows on send screen when adding both new and known addresses to text field
## [1.2.1 (760)] - 2024-10-22
### Changed
- Global design updates
- Onboarding screen has been redesigned
- Scan QR screen has been redesigned
- The Receive screen UI has been redesigned
- Send screen redesigned & added a possibility to pick a contact from address book
- Confirmation screen redesigned & added a contact name to the transaction if the contact is in address book
- History item redesigned & added an option to create a contact from unknown address
- Address Book, Create/Update/Delete Contact, Create Contact by QR screens added
- The Scan QR code screen now supports scanning of ZIP 321 Uris
### Added
- Address book local storage support
- New Integrations screen in settings
- New QR Code detail screen has been added
- The new Request ZEC screens have been added. They provide a way to build ZIP 321 Uri consisting of the amount,
message, and receiver address and then creates a QR code image of it.
## [1.2 (739)] - 2024-09-27
### Changed
- Adopted snapshot Zcash SDK version 2.2.5, which brings fix for the incorrect check inside the `BlockHeight` component
## [1.2 (735)] - 2024-09-20
### Added
- All app's error dialogs now have a new Report error button that opens and prefills users' email clients
### Changed
- The Message text field on the Send Form screen has been updated to provide the Return key on the software keyboard
and make auto-capitalization on the beginning of every sentence or new line.
### Fixed
- `EmailUtils.newMailActivityIntent` has been updated to produce an `Intent` that more e-mail clients can understand
## [1.2 (731)] - 2024-09-16
### Changed
- Adopted the latest snapshot Zcash SDK version 2.2.4 that brings improvements in the disposal logic of its
internal `TorClient` component
## [1.2 (729)] - 2024-09-13
### Added
- Transaction resubmission feature has been added. It periodically searches for unmined sent transactions that
are still within their expiry window and resubmits them if there are any.
- The Choose server screen now provides a new search for the three fastest servers feature
- Android 15 (Android SDK API level 35) support for 16 KB memory page size has been added
- Coinbase Onramp integration button has been added to the Advanced Settings screen
### Changed
- Choose server screen has been redesigned
- Settings and Advanced Settings screens have been redesigned
- Android `compileSdkVersion` and `targetSdkVersion` have been updated to version 35
### Fixed
- The issue of printing the stacktrace of errors in dialogs has been resolved
## [1.1.7 (718)] - 2024-09-06
### Added
- Dependency injection using Koin has been added to the project. This helps us keep the codebase organized while
adding new app features.
### Changed
- Zcash SDK version 2.2.3-SNAPSHOT has been adopted
### Fixed
- The Zec to USD currency conversion logic on the Send screen, which caused issues on lower Android SDK versions
together with non-English device localizations, has been fixed.
## [1.1.6 (712)] - 2024-09-04
### Added
- Zcash SDK 2.2.2 has been adopted. It brings several new important features:
- Currency exchange rates (currently just USD/ZEC) are now made available via the SDK.
The exchange rate computed as the median of values provided by at least three separate
cryptocurrency exchanges, and is fetched over Tor connections in order to avoid leaking
the wallet's IP address to the exchanges.
- Sending to ZIP 320 (TEX) addresses is now supported. When sending to a ZIP 320 address,
the wallet will first automatically de-shield the required funds to a fresh ephemeral
transparent address, and then will make a second fully-transparent transaction sending
the funds to the eventual recipient that is not linkable via on-chain information to any
other transaction in the user's wallet.
- As part of adding ZIP 320 support, the SDK now also provides full support for recovering
transparent transaction history. Prior to this release, only transactions belonging to the
wallet that contained either some shielded component OR a member of the current
transparent UTXO set were included in transaction history.
- Thus, the balances widget now optionally displays the USD value as well
- A new option to enter the USD amount in the Send screen has been added
### Changed
- Android NDK version has been bumped to 26.1.10909125
### Fixed
- The app screenshot testing has been re-enabled after we moved away from AppCompat components
## [1.1.5 (706)] - 2024-08-09
### Changed
- Adopted the latest Zcash SDK version 2.1.3, which brings a significant block synchronization speed-up and improved
UTXOs fetching logic
## [1.1.4 (700)] - 2024-07-23
### Added
- A new What's New screen has been added, accessible from the About screen. It contains the release notes parsed
from the new [docs/whatsNew/WHATS_NEW_EN.md] file
- These release notes and release priority are both propagated to every new Google Play release using CI logic
- Copying sensitive information like addresses, transaction IDs, or wallet secrets into the device clipboard is now
masked out from the system visual confirmation, but it's still copied as expected. `ClipDescription.EXTRA_IS_SENSITIVE`
flag is used on Android SDK level 33 and higher, masking out the `Toast` text on levels below it.
- `androidx.fragment:fragment-compose` dependency has been added
### Changed
- The About screen has been redesigned to align with the new design guidelines
- `StyledBalance` text styles have been refactored from `Pair` into `BalanceTextStyle`
- The Restore Success dialog has been reworked into a separate screen, allowing users to opt out of the Keep screen
on while restoring option
- `targetSdk` property value changed from 33 to 34
- The Zcash SDK dependency has been switched from `2.1.2-SNAPSHOT` to `2.1.2`
### Fixed
- Support Screen now shows the Send button above keyboard instead of overlaying it. This was achieved by setting
`adjustResize` to `MainActivity` and adding `imePadding` to top level composable
- QR code scanning speed and reliability have been improved to address the latest reported scan issue. The obtained
image cropping and image reader hints have been changed as part of these improvements.
- The handling of Android configuration changes has been improved.
`android:configChanges="orientation|locale|layoutDirection|screenLayout|uiMode|colorMode|keyboard|screenSize"`
option has been added to the app's `AndroidManifest.xml`, leaving the configuration changes handling entirely to
the Jetpack Compose layer.
### Removed
- `androidx.appcompat:appcompat` dependency has been removed
## [1.1.3 (682)] - 2024-07-03
### Added
- Proper ZEC amount abbreviation has been added across the entire app as described by the design document
- The new Hide Balances feature has been added to the Account, Send, and Balances screen.
### Fixed
- The app navigation has been improved to always behave the same for system, gesture, or top app bar back navigation
actions
- The app authentication now correctly handles authentication success after a previous failed state
## [1.1.2 (676)] - 2024-06-24
### Fixed
- Disabled Tertiary button container color has been changed to distinguish between the button's disabled container
color and the circular loading bar
## [1.1.2 (673)] - 2024-06-21
### Fixed
- Conditional developer Dark mode switcher has been removed
## [1.1.2 (671)] - 2024-06-21
### Added
- New bubble message style for the Send and Transaction history item text components
- Display all messages within the transaction history record when it is expanded
- The Dark mode is now officially supported by the entire app UI
- The Scan screen now allows users to pick and scan a QR code of an address from a photo saved in the device library
### Changed
- The Not Enough Free Space screen UI has been slightly refactored to align with the latest design guidelines
## [1.1.1 (660)] - 2024-06-05
### Added
- Grid pattern background has been added to several screens
- A new disconnected dialog reminder has been added to inform users about possible server issues
- When the app is experiencing such server connection issues, a new DISCONNECTED label will be displayed below the
screen title
- The transaction history list will be displayed when the app has server connection issues. Such a list might have a
slightly different order.
### Changed
- The color palette used across the app has been reworked to align with the updated design document
### Fixed
- An updated snapshot Zcash SDK version has been adopted to improve unstable lightwalletd communication
- Transaction submission has been slightly refactored to improve its stability
## [1.1 (655)] - 2024-05-24
### Added
- Zashi now provides system biometric or device credential (pattern, pin, or password) authentication for these use
cases: Send funds, Recovery Phrase, Export Private Data, and Delete Wallet.
- The app entry animation has been reworked to apply on every app access point, i.e. it will be displayed when
users return to an already set up app as well.
- Synchronizer status details are now available to users by pressing the simple status view placed above the
synchronization progress bar. The details are displayed within a dialog window on the Balances and Account screens.
This view also occasionally presents information about a possible Zashi app update available on Google Play. The
app redirects users to the Google Play Zashi page by pressing the view.
### Changed
- The app dialog window has now a bit more rounded corners
- A few more minor UI improvements
## [1.0 (650)] - 2024-05-07
### Added
- Delete Zashi feature has been added. It's accessible from the Advanced settings screen. It removes the wallet
secrets from Zashi and resets its state.
- Transaction messages are now checked and removed in case of duplicity
### Changed
- We've improved the visibility logic of the little loader that is part of the Balances widget
- The App-Update screen UI has been reworked to align with the latest design guidelines
### Removed
- Concatenation of the messages on a multi-messages transaction has been removed and will be addressed using a new
design
### Fixed
- Transparent funds shielding action has been improved to address the latest user feedback
- Onboarding screen dynamic height calculation has been improved
- A few more minor UI improvements
## [1.0 (638)] - 2024-04-26
### Fixed
- Default server selection option
## [1.0 (636)] - 2024-04-26
### Changed
- We have added one more group of server options (zec.rocks) for increased coverage and reliability
- zec.rocks:443 is now default wallet option
## [1.0 (630)] - 2024-04-24
### Changed
- We have added more server options for increased coverage and reliability
- If you experience issues with the Zcash Lightwalletd Mainnet server selected by default, please switch to one of
the Ywallet servers: https://status.zcash-infra.com/
## [1.0 (628)] - 2024-04-23
### Changed
- The Scan QR code screen has been reworked to align with the rest of the screens
- The Send Form screen scrolls to the Send button on very small devices after the memo is typed
### Fixed
- Sending zero funds is allowed only for shielded recipient address type
- The Balances widget loader has been improved to better handle cases, like a wallet with only transparent funds
## [0.2.0 (609)] - 2024-04-18
### Added
- Advanced Settings screen that provides more technical options like Export private data, Recovery phrase, or
Choose server has been added
- A new Server switching screen has been added. Its purpose is to enable switching between predefined and custom
lightwalletd servers in runtime.
- The About screen now contains a link to the new Zashi Privacy Policy website
- The Send Confirmation screen has been reworked according to the new design
- Transitions between screens are now animated with a simple slide animation
- Proposal API from the Zcash SDK has been integrated together with handling error states for multi-transaction
submission
- New Restoring Your Wallet label and Synchronization widget have been added to all post-onboarding screens to notify
users about the current state of the wallet-restoring process
### Changed
- The Transaction History UI has been incorporated into the Account screen and completely reworked according to the
design guidelines
- Reworked Send screens flow and their look (e.g., Send Failure screen is now a modal dialog instead of a separate
screen)
- The sending and shielding funds logic has been connected to the new Proposal API from the Zcash SDK
- The error dialog contains an error description now. It's useful for tracking down the failure cause.
- A small circular progress indicator is displayed when the app runs block synchronization, and the available balance
is zero instead of reflecting a result value.
- Block synchronization statuses have been simplified to Syncing, Synced, and Error states only
- All internal dependencies have been updated
### Fixed
- Button sizing has been updated to align with the design guidelines and preserve stretching if necessary
### Removed
- The seed copy feature from the New wallet recovery and Seed recovery screens has been removed for security reasons
## [0.2.0 (560)] - 2024-02-27
### Added
- A periodic background block synchronization has been added. When the device is connected to the internet using an
unmetered connection and is plugged into the power, the background task will start to synchronize blocks randomly
between 3 and 4 a.m.
### Changed
- The Send screen form has changed its UI to align with the Figma design. All the form fields provide validations
and proper UI response.
## [0.2.0 (554)] - 2024-02-13
### Changed
- Update the Zcash SDK dependency to version 2.0.6, which adds more details on current balances
### Added
- The Balances screen now provides details on current balances like Change pending and Pending transactions
- The Balances screen adds a new Block synchronization progress bar and status, which were initially part of the
Account screen and redesigned
- The Balances screen supports transparent funds shielding within its new shielding panel
### Fixed
- Fixed character replacement in Zcash addresses on the Receive screen caused by ligatures in the app's primary font
using the secondary font. This will be revisited once a proper font is added.
- Improved spacing of titles of bottom navigation tabs, so they work better on smaller screens
## [0.2.0 (541)] - 2024-01-30
- Update the Zcash SDK dependency to version 2.0.5, which improves the performance of block synchronization
## [0.2.0 (540)] - 2024-01-27
### Added
- The current balance UI on top of the Account screen has been reworked. It now displays the currently available
balance as well.
- The same current balance UI was incorporated into the Send and Balances screens.
- The Send Error screen now contains a simple text with the reason for failure. The Send screen UI refactoring is
still in progress.
### Fixed
- Properly clearing focus from the Send text fields when moved to another screen
## [0.2.0 (530)] - 2024-01-16
### Changed
- The Not Enough Space screen used for notifying about insufficient free device disk space now provides the light
theme by default
- The App Update screen UI was improved to align with the other implemented screens according to the new design. Its
final design is still in progress.
- The Receive screen provides a new UI and features. The Unified and Transparent Zcash addresses are displayed on
this screen, together with buttons for copying the address and sharing the address's QR code.
### Removed
- Address Detail screen in favor of the Receive screen
## [0.2.0 (523)] - 2024-01-09
### Added
- Transaction history items now display Memos within the Android Toast, triggered by clicking the item
- Transaction history items add displaying transaction IDs; the ID element is also clickable
### Changed
- All project dependencies have been updated, including the Zcash SDK dependency
## [0.2.0 (517)] - 2023-12-21
### Changed
- Home screen navigation switched from the Side menu to the Bottom Navigation Tabs menu
- Re-enabled the possibility of installing different Zashi application build types on the same device simultaneously
(i.e., Mainnet, Testnet, Production, Debug)
- Send screen form now validates a maximum amount for sending with respect to the available balance
- Send form now supports software keyboard confirm actions
- And a few more miner UI improvements
### Fixed
- Resizing Send screen Form TextFields when focused
- Hidden Send screen Form TextFields behind the software keyboard when focused
- Monetary separators issues on the Send screen Form
## [0.2.0 (505)] - 2023-12-11
### Added
- Unfinished features show a "Not implemented yet" message after accessing in the app UI
### Changed
- Home and Receive screens have their Top app bar UI changed
- Automatic brightness adjustment switched to an on-demand feature after a new button is clicked on the Receive screen
### Removed
- Home screen side menu navigation was removed in favor of the Settings screen
## [0.2.0 (491)] - 2023-12-01
### Changed
- Updated user interface of these screens:
- New Wallet Recovery Seed screen (accessible from onboarding)
- Seed Recovery screen (accessible from Settings)
- Restore Seed screen for an existing wallet (accessible from onboarding)
- Restore Seed Birthday Height screen for an existing wallet (accessible from onboarding)