Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Introduce the Desktop Wallet Activity Page #442

Merged
merged 1 commit into from
Mar 18, 2025

Conversation

johnny9
Copy link
Contributor

@johnny9 johnny9 commented Jan 23, 2025

This commit introduces the basic Activity Page and Activity details Page. The pages are backed by activitylistmodel which queries the wallet interface and converts the WalletTx objects into Transaction objects in the list that returns the properties for each send/receive to one of our wallet's addresses.

Screenshot from 2025-03-10 11-27-20

Screenshot from 2025-03-10 11-27-29

@@ -122,9 +122,8 @@ Page {
width: parent.width
height: parent.height
currentIndex: navigationTabs.checkedButton.index
Item {
Activity {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

it builds, but doesn't run

./bitcoin-qt -signet
QSocketNotifier: Can only be used with threads started with QThread
QQmlApplicationEngine failed to load component
qrc:/qml/pages/main.qml:83:9: Type DesktopWallets unavailable
qrc:/qml/pages/wallet/DesktopWallets.qml:125:9: Activity is not a type
~InitExecutor : Stopping thread
~InitExecutor : Stopped thread

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Updated the PR to include the missing component

Copy link
Contributor

@pablomartin4btc pablomartin4btc left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Concept ACK

Light tACK 357611e on regtest.
  • Wallet main's activity page.
    Screenshot from 2025-02-03 16-28-39

  • Activity's details page.
    Screenshot from 2025-02-03 16-28-51

I think you could add the screenshots to the PR's description.

I found @GBKS's prototype for the activity page here, perhaps you could also add it to the top as a reference. I think the icons need to be updated (for send and receive) same for the magnifying glass search icon at the top right (follow-up?).

Not part of this PR's code I think but while testing, in order to update the activity page contents, switching among the different wallets doesn't work, at least for me, can't remember if it was already an issue or wasn't intended to work yet.

I'd reduce the amount of commits and make a clean up (eg in 1st commit you add some empty files that you remove on the 2nd, perhaps you only amend the 1st commit removing them and delete the 2nd commit?).

Copy link
Contributor

@MarnixCroes MarnixCroes left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

357611e

tx's are not always ordered on time
Screenshot from 2025-02-13 12-12-23
and I guess all addresses should be same width?
easier on the eye

@johnny9 johnny9 force-pushed the activity-page branch 7 times, most recently from 1fa72da to 8971438 Compare March 9, 2025 19:36
@johnny9
Copy link
Contributor Author

johnny9 commented Mar 10, 2025

Update 2fc8e69 to 8971438

  • Added missing icons
  • Updated fromWalletTx method to match the logic in the latest qt builds. This method converts the WalletTx objects into Transaction objects for the activitylistmodel.

@johnny9
Copy link
Contributor Author

johnny9 commented Mar 11, 2025

Tested on Ubuntu

  1. load it up see it doesnt crash and qml loads
  2. check icons appear
  3. click into details on an item and switch wallet and make sure the details popped and the list updated.
    @jarolrod

@hebasto hebasto changed the title qml: Introduce the Desktop Wallet Activity Page Introduce the Desktop Wallet Activity Page Mar 17, 2025
@hebasto
Copy link
Member

hebasto commented Mar 17, 2025

Needs rebase.

@johnny9
Copy link
Contributor Author

johnny9 commented Mar 17, 2025

Update from a385f3f to af0fe4b

  • Rebased with main

@hebasto

@johnny9
Copy link
Contributor Author

johnny9 commented Mar 17, 2025

Update from af0fe4b to 28ede4b

  • minor whitespace fix in main.qml

Copy link
Member

@hebasto hebasto left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

ACK 28ede4b, I have skimmed through the code and it looks OK.

@johnny9
Please ensure that you the clang-format-diff.py tool to your changes before pushing.

@hebasto hebasto merged commit 59fa29a into bitcoin-core:main Mar 18, 2025
9 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants