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

UI tweaks for ETH contract flow #4346

Merged
merged 9 commits into from
Nov 26, 2024
Merged

UI tweaks for ETH contract flow #4346

merged 9 commits into from
Nov 26, 2024

Conversation

ibz
Copy link
Contributor

@ibz ibz commented Nov 13, 2024

This is a continuation of #4343, addressing the UI side of #4302.

@ibz ibz self-assigned this Nov 13, 2024
Copy link

github-actions bot commented Nov 13, 2024

legacy UI changes device test(screens) main(screens)

Copy link

github-actions bot commented Nov 13, 2024

core UI changes device test click test persistence test
T2T1 Model T test(screens) main(screens) test(screens) main(screens) test(screens) main(screens)
T3B1 Safe 3 test(screens) main(screens) test(screens) main(screens) test(screens) main(screens)
T3T1 Safe 5 test(screens) main(screens) test(screens) main(screens) test(screens) main(screens)
All main(screens)

@ibz ibz force-pushed the ibz/20241113-tweaks branch 2 times, most recently from 28d80a5 to 3374fa4 Compare November 14, 2024 11:36
@ibz ibz changed the base branch from main to ibz/20241112-cleanup November 14, 2024 16:36
@ibz ibz force-pushed the ibz/20241113-tweaks branch from 4ee434b to 29da869 Compare November 15, 2024 09:43
@ibz ibz linked an issue Nov 15, 2024 that may be closed by this pull request
@ibz ibz force-pushed the ibz/20241113-tweaks branch from aff8fa9 to 962a2e7 Compare November 15, 2024 11:37
@ibz ibz force-pushed the ibz/20241112-cleanup branch from 3aef883 to fc54ad1 Compare November 15, 2024 11:46
@ibz ibz force-pushed the ibz/20241113-tweaks branch from 962a2e7 to dbaac78 Compare November 15, 2024 12:03
@ibz ibz marked this pull request as ready for review November 15, 2024 12:17
@ibz ibz requested review from matejcik and prusnak as code owners November 15, 2024 12:17
@ibz ibz requested review from obrusvit and removed request for prusnak November 15, 2024 12:17
@ibz ibz force-pushed the ibz/20241113-tweaks branch 2 times, most recently from f4bbfd8 to ee1642a Compare November 15, 2024 12:48
Copy link
Contributor

@matejcik matejcik left a comment

Choose a reason for hiding this comment

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

while we're at this, can you remove text_mono and info (and possibly even hold) from confirm_blob ?

core/embed/rust/src/ui/component/text/formatted.rs Outdated Show resolved Hide resolved
// we would need to account for that and we could not use a constant.
let mut menu_choices = VerticalMenu::empty().danger(
theme::ICON_CANCEL,
verb_cancel.unwrap_or(TR::buttons__cancel.into()),
Copy link
Contributor

Choose a reason for hiding this comment

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

why not make verb_cancel non-Optional and prefill this string at construction time?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Not sure what is the benefit. It would just move the check / unwrap at a higher level, most probably in ConfirmBlobParams - because that one can have it missing. Let's say I also set it to TR::buttons__cancel in ConfirmBlobParams, I would still need to make the check in new_confirm_action. Unless I make it non-optional there too and set a default in uPy... Either way, the default would have to be somewhere, no?

Copy link
Contributor

Choose a reason for hiding this comment

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

Well, yes, we kinda want to work with non-Options from as early as possible. If None here doesn't have a special meaning, it should be unwrapped at the earliest convenient place, which, yes, would be new_confirm_action.
No reason for a code tree this deep to be aware that the caller somewhere six stack frames out was too lazy to specify the value explicitly.

It may make sense to accept a None value from Python, because that's (a) an API boundary and (b) Python doesn't make it convenient to specify translated values as default arguments -- you can't say def confirm(verb: str = TR.some__verb) because then it does not get updated when you change a translation.

But that's a property of the API, that it allows you to not specify a verb. Not a property of the implementation, where we always require a string to work with (unless we don't?), just that we have a default value for it.

Copy link
Contributor Author

@ibz ibz Nov 20, 2024

Choose a reason for hiding this comment

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

OK: fc0bb63

I think I understand your point, and it can be seen like this too, indeed.

I was seeing it from the other angle - as much as possible instantiate these "string bearing structs" like ConfirmBlobParams and ConfirmActionMenuStrings (maybe I should rename it to ConfirmActionMenuParams while at it...) with no parameters, have everything default to None, and do with_XXX only when "XXX" needs to be changed to something other than the default. Otherwise the struct would carry the None all the way to the very end, where the default would be used. I think @obrusvit 's recent changes also went in this direction - dropping as many parameters from ConfirmBlobParams::new and moving them to .with_XXX.

Of course, the two ways are not mutually exclusive, which is what I tried to do at fc0bb6 - not sure whether you guys like it - but basically ConfirmBlobParams::new still means you want to go with defaults, but the default verb_cancel is set to TR::buttons__cancel.into() in the ctor rather than to None - so this "params bearing struct" carries the concrete default around. Maybe if this is what you meant, then I should just replace the rest of the strings in ConfirmBlobParams in the same way... I think I like it...

The disadvantage is of course that multiple instantiations of ConfirmBlobParams around multiple API functions have to unwrap_or if they want to do a .with_verb_cancel (in order to let the uPy code customize the verb. OOOOR, I could make with_verb_cancel accept an Option and have it set the default in case it received None - but I don't know why, that looks less appealing to me (even though the opposite leads to duplication of the default value).

Copy link
Contributor

Choose a reason for hiding this comment

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

Maybe if this is what you meant, then I should just replace the rest of the strings in ConfirmBlobParams in the same way... I think I like it...

yes, this is what I have in mind

multiple instantiations of ConfirmBlobParams around multiple API functions have to unwrap_or if they want to do a .with_verb_cancel (in order to let the uPy code customize the verb. OOOOR, I could make with_verb_cancel accept an Option and have it set the default in case it received None - but I don't know why, that looks less appealing to me (even though the opposite leads to duplication of the default value).

wondering about this .. would it make sense to construct ConfirmBlobParams and friends by passing the micropython options -- gated by #[feature(micropython)] of course?
wdyt @obrusvit

Copy link
Contributor

Choose a reason for hiding this comment

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

I think @obrusvit 's recent changes also went in this direction - dropping as many parameters from ConfirmBlobParams::new and moving them to .with_XXX.

My motivation was not to drop as may params as possible from ConfirmBlobParams::new but to keep only those which are used by all callers. There were 7 params and 4 calls were setting the last 4 to None/False Hence I reduced the new params count to 3 and put the rest to with_xyz builder methods.


wondering about this .. would it make sense to construct ConfirmBlobParams and friends by passing the micropython options -- gated by #[feature(micropython)] of course?
wdyt @obrusvit

Do you mean constructing ConfirmBlobParams with (n_args, args, kwargs). Hmmm, I don't like it very much. IMO, ConfirmBlobParams should be deeper in the UI code with rusty-types.
It's true that initially the trait UiFeaturesFirmware (or whatever the name will be) will be riddled with micropython stuff, but mostly just Obj, which should be replaced later on.

@ibz ibz force-pushed the ibz/20241112-cleanup branch from 313f806 to 69d448f Compare November 19, 2024 10:29
Base automatically changed from ibz/20241112-cleanup to main November 19, 2024 11:36
@ibz ibz force-pushed the ibz/20241113-tweaks branch 2 times, most recently from b0a3a4a to fc0bb63 Compare November 20, 2024 14:00
@ibz
Copy link
Contributor Author

ibz commented Nov 20, 2024

while we're at this, can you remove text_mono and info (and possibly even hold) from confirm_blob ?

I'll do that in the next PR if you don't mind, together with cleanup of warning_hi_prio. There's already too many unrelated changes in this PR, and rebasing becomes a pain.

Copy link
Contributor

@obrusvit obrusvit left a comment

Choose a reason for hiding this comment

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

I have some points to discuss.

core/embed/rust/src/ui/model_tr/component/share_words.rs Outdated Show resolved Hide resolved
// we would need to account for that and we could not use a constant.
let mut menu_choices = VerticalMenu::empty().danger(
theme::ICON_CANCEL,
verb_cancel.unwrap_or(TR::buttons__cancel.into()),
Copy link
Contributor

Choose a reason for hiding this comment

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

I think @obrusvit 's recent changes also went in this direction - dropping as many parameters from ConfirmBlobParams::new and moving them to .with_XXX.

My motivation was not to drop as may params as possible from ConfirmBlobParams::new but to keep only those which are used by all callers. There were 7 params and 4 calls were setting the last 4 to None/False Hence I reduced the new params count to 3 and put the rest to with_xyz builder methods.


wondering about this .. would it make sense to construct ConfirmBlobParams and friends by passing the micropython options -- gated by #[feature(micropython)] of course?
wdyt @obrusvit

Do you mean constructing ConfirmBlobParams with (n_args, args, kwargs). Hmmm, I don't like it very much. IMO, ConfirmBlobParams should be deeper in the UI code with rusty-types.
It's true that initially the trait UiFeaturesFirmware (or whatever the name will be) will be riddled with micropython stuff, but mostly just Obj, which should be replaced later on.

content_area = content_area.inset(Insets::top(theme::SPACING));
content_area = content_area
.inset(Insets::top(theme::SPACING))
.inset(Insets::top(margin as i16));
Copy link
Contributor

Choose a reason for hiding this comment

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

This makes the real margin now SPACING + margin. It's quite confusing but probably fine.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Right. What could I do about it? Rename my parameter to extra_margin? Would that make more sense?

Copy link
Contributor

Choose a reason for hiding this comment

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

Not sure, it seems to be that the 2nd .inset call could be elsewhere or you could not need to use SPACING. Why does not margin contain the spacing aswell?

@ibz
Copy link
Contributor Author

ibz commented Nov 26, 2024

while we're at this, can you remove text_mono and info (and possibly even hold) from confirm_blob ?

BTW, I am centralizing these requests, and some more, here: #4386

@ibz ibz force-pushed the ibz/20241113-tweaks branch 3 times, most recently from 7ab7bd7 to c86d14d Compare November 26, 2024 15:55
[T3T1] Add page counter to paginated blobs.
[T3T1] Add cancel button to individual pages of a blob.
[T3T1] Add margin to the first page of a blob.
[T3B1] Add "continue" button after scrolling through the whole blob.
Copy link
Contributor

@matejcik matejcik Nov 26, 2024

Choose a reason for hiding this comment

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

each of those needs its own file (4302.added, 4302.added.1, 4302.added.2 etc)

(check the output of ./CHANGELOG.unreleased in core dir)

Copy link
Contributor

Choose a reason for hiding this comment

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

I wonder why do we need such granularity in the changelog though. Does it mean anything for the customer?

Copy link
Contributor

Choose a reason for hiding this comment

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

Yeah, we probably don't. I should have said that originally, i just got tripped by a "multi-line" changeset.

Copy link
Member

Choose a reason for hiding this comment

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

I'll change it do something like Improve paginated blob display. in the release branch if noone objects.

@ibz ibz force-pushed the ibz/20241113-tweaks branch 5 times, most recently from 42804bf to 73829d8 Compare November 26, 2024 16:42
@ibz ibz force-pushed the ibz/20241113-tweaks branch from 73829d8 to cc48473 Compare November 26, 2024 17:10
ibz added 7 commits November 26, 2024 20:08
This commit adds a margin and footer description to the first page of
the paginated blobs to be confirmed on Mercury. It also extracts the
part of confirm_blob that deals with the first page to a separate
function in order to keep confirm_blob simple.
@ibz ibz force-pushed the ibz/20241113-tweaks branch from cc48473 to 5155f12 Compare November 26, 2024 19:08
@ibz ibz added the translations Put this label on a PR to run tests in all languages label Nov 26, 2024
@ibz ibz force-pushed the ibz/20241113-tweaks branch from 76bc58c to 5c21566 Compare November 26, 2024 20:42
@mmilata mmilata merged commit c44f901 into main Nov 26, 2024
138 of 139 checks passed
@mmilata mmilata deleted the ibz/20241113-tweaks branch November 26, 2024 21:38
@bosomt
Copy link

bosomt commented Nov 29, 2024

QA OK

tested on TS5,
i will retest on more models later

@bosomt
Copy link

bosomt commented Dec 16, 2024

QA OK

tested on T3B1 and T2T1 /latest 2.8.7 dev version/

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
translations Put this label on a PR to run tests in all languages
Projects
Status: Approved
Development

Successfully merging this pull request may close these issues.

Improve EVM contract flow
5 participants