1
0
mirror of https://github.com/trezor/trezor-firmware.git synced 2025-01-03 12:00:59 +00:00

refactor(core): sync layout code

Refactor mercury layout code according to recent changes in model_t
layout code.

[no changelog]
This commit is contained in:
obrusvit 2024-06-02 17:16:39 +02:00 committed by matejcik
parent 936fe1aea9
commit d4b854a95e

View File

@ -281,7 +281,7 @@ async def raise_if_not_confirmed(
raise exc raise exc
async def confirm_action( def confirm_action(
br_type: str, br_type: str,
title: str, title: str,
action: str | None = None, action: str | None = None,
@ -297,11 +297,11 @@ async def confirm_action(
br_code: ButtonRequestType = BR_TYPE_OTHER, br_code: ButtonRequestType = BR_TYPE_OTHER,
prompt_screen: bool = False, prompt_screen: bool = False,
prompt_title: str | None = None, prompt_title: str | None = None,
) -> None: ) -> Awaitable[None]:
if description is not None and description_param is not None: if description is not None and description_param is not None:
description = description.format(description_param) description = description.format(description_param)
await raise_if_not_confirmed( return raise_if_not_confirmed(
interact( interact(
RustLayout( RustLayout(
trezorui2.confirm_action( trezorui2.confirm_action(
@ -325,13 +325,13 @@ async def confirm_action(
) )
async def confirm_single( def confirm_single(
br_type: str, br_type: str,
title: str, title: str,
description: str, description: str,
description_param: str | None = None, description_param: str | None = None,
verb: str | None = None, verb: str | None = None,
) -> None: ) -> Awaitable[None]:
description_param = description_param or "" description_param = description_param or ""
# Placeholders are coming from translations in form of {0} # Placeholders are coming from translations in form of {0}
@ -340,7 +340,7 @@ async def confirm_single(
template_str = "{}" template_str = "{}"
begin, _separator, end = description.partition(template_str) begin, _separator, end = description.partition(template_str)
await raise_if_not_confirmed( return raise_if_not_confirmed(
interact( interact(
RustLayout( RustLayout(
trezorui2.confirm_emphasized( trezorui2.confirm_emphasized(
@ -355,13 +355,13 @@ async def confirm_single(
) )
async def confirm_reset_device(_title: str, recovery: bool = False) -> None: def confirm_reset_device(_title: str, recovery: bool = False) -> Awaitable[None]:
if recovery: if recovery:
await raise_if_not_confirmed( return raise_if_not_confirmed(
RustLayout(trezorui2.flow_confirm_reset_recover()), RustLayout(trezorui2.flow_confirm_reset_recover()),
) )
else: else:
await raise_if_not_confirmed( return raise_if_not_confirmed(
RustLayout(trezorui2.flow_confirm_reset_create()), RustLayout(trezorui2.flow_confirm_reset_create()),
) )
@ -386,16 +386,16 @@ async def prompt_backup() -> bool:
return result is CONFIRMED return result is CONFIRMED
async def confirm_path_warning( def confirm_path_warning(
path: str, path: str,
path_type: str | None = None, path_type: str | None = None,
) -> None: ) -> Awaitable[None]:
description = ( description = (
TR.addr_mismatch__wrong_derivation_path TR.addr_mismatch__wrong_derivation_path
if not path_type if not path_type
else f"{TR.words__unknown} {path_type.lower()}." else f"{TR.words__unknown} {path_type.lower()}."
) )
await raise_if_not_confirmed( return raise_if_not_confirmed(
interact( interact(
RustLayout( RustLayout(
trezorui2.flow_warning_hi_prio( trezorui2.flow_warning_hi_prio(
@ -408,8 +408,8 @@ async def confirm_path_warning(
) )
async def confirm_multisig_warning() -> None: def confirm_multisig_warning() -> Awaitable[None]:
await raise_if_not_confirmed( return raise_if_not_confirmed(
interact( interact(
RustLayout( RustLayout(
trezorui2.flow_warning_hi_prio( trezorui2.flow_warning_hi_prio(
@ -423,10 +423,10 @@ async def confirm_multisig_warning() -> None:
) )
async def confirm_homescreen( def confirm_homescreen(
image: bytes, image: bytes,
) -> None: ) -> Awaitable[None]:
await raise_if_not_confirmed( return raise_if_not_confirmed(
interact( interact(
RustLayout( RustLayout(
trezorui2.confirm_homescreen( trezorui2.confirm_homescreen(
@ -531,15 +531,15 @@ async def show_error_and_raise(
raise exc raise exc
async def show_warning( def show_warning(
br_type: str, br_type: str,
content: str, content: str,
subheader: str | None = None, subheader: str | None = None,
button: str | None = None, button: str | None = None,
br_code: ButtonRequestType = ButtonRequestType.Warning, br_code: ButtonRequestType = ButtonRequestType.Warning,
) -> None: ) -> Awaitable[None]:
button = button or TR.buttons__continue # def_arg button = button or TR.buttons__continue # def_arg
await raise_if_not_confirmed( return raise_if_not_confirmed(
interact( interact(
RustLayout( RustLayout(
trezorui2.show_warning( trezorui2.show_warning(
@ -554,18 +554,18 @@ async def show_warning(
) )
async def show_success( def show_success(
br_type: str, br_type: str,
content: str, content: str,
subheader: str | None = None, subheader: str | None = None,
button: str | None = None, button: str | None = None,
) -> None: ) -> Awaitable[None]:
await raise_if_not_confirmed( return raise_if_not_confirmed(
interact( interact(
RustLayout( RustLayout(
trezorui2.show_success( trezorui2.show_success(
title=content, title=content,
description=subheader, description=subheader if subheader else "",
) )
), ),
br_type, br_type,
@ -721,7 +721,7 @@ async def _confirm_ask_pagination(
assert False assert False
async def confirm_blob( def confirm_blob(
br_type: str, br_type: str,
title: str, title: str,
data: bytes | str, data: bytes | str,
@ -733,7 +733,7 @@ async def confirm_blob(
ask_pagination: bool = False, ask_pagination: bool = False,
chunkify: bool = False, chunkify: bool = False,
prompt_screen: bool = True, prompt_screen: bool = True,
) -> None: ) -> Awaitable[None]:
layout = RustLayout( layout = RustLayout(
trezorui2.confirm_blob( trezorui2.confirm_blob(
title=title, title=title,
@ -750,10 +750,10 @@ async def confirm_blob(
if ask_pagination and layout.page_count() > 1: if ask_pagination and layout.page_count() > 1:
assert not hold assert not hold
await _confirm_ask_pagination(br_type, title, data, description or "", br_code) return _confirm_ask_pagination(br_type, title, data, description or "", br_code)
else: else:
await raise_if_not_confirmed( return raise_if_not_confirmed(
interact( interact(
layout, layout,
br_type, br_type,
@ -762,14 +762,14 @@ async def confirm_blob(
) )
async def confirm_address( def confirm_address(
title: str, title: str,
address: str, address: str,
description: str | None = None, description: str | None = None,
br_type: str = "confirm_address", br_type: str = "confirm_address",
br_code: ButtonRequestType = BR_TYPE_OTHER, br_code: ButtonRequestType = BR_TYPE_OTHER,
) -> None: ) -> Awaitable[None]:
return await confirm_value( return confirm_value(
title, title,
address, address,
description or "", description or "",
@ -779,14 +779,14 @@ async def confirm_address(
) )
async def confirm_text( def confirm_text(
br_type: str, br_type: str,
title: str, title: str,
data: str, data: str,
description: str | None = None, description: str | None = None,
br_code: ButtonRequestType = BR_TYPE_OTHER, br_code: ButtonRequestType = BR_TYPE_OTHER,
) -> None: ) -> Awaitable[None]:
return await confirm_value( return confirm_value(
title, title,
data, data,
description or "", description or "",
@ -864,17 +864,17 @@ def confirm_value(
) )
async def confirm_properties( def confirm_properties(
br_type: str, br_type: str,
title: str, title: str,
props: Iterable[PropertyType], props: Iterable[PropertyType],
hold: bool = False, hold: bool = False,
br_code: ButtonRequestType = ButtonRequestType.ConfirmOutput, br_code: ButtonRequestType = ButtonRequestType.ConfirmOutput,
) -> None: ) -> Awaitable[None]:
# Monospace flag for values that are bytes. # Monospace flag for values that are bytes.
items = [(prop[0], prop[1], isinstance(prop[1], bytes)) for prop in props] items = [(prop[0], prop[1], isinstance(prop[1], bytes)) for prop in props]
await raise_if_not_confirmed( return raise_if_not_confirmed(
interact( interact(
RustLayout( RustLayout(
trezorui2.confirm_properties( trezorui2.confirm_properties(
@ -889,7 +889,7 @@ async def confirm_properties(
) )
async def confirm_total( def confirm_total(
total_amount: str, total_amount: str,
fee_amount: str, fee_amount: str,
title: str | None = None, title: str | None = None,
@ -900,7 +900,7 @@ async def confirm_total(
fee_rate_amount: str | None = None, fee_rate_amount: str | None = None,
br_type: str = "confirm_total", br_type: str = "confirm_total",
br_code: ButtonRequestType = ButtonRequestType.SignTx, br_code: ButtonRequestType = ButtonRequestType.SignTx,
) -> None: ) -> Awaitable[None]:
title = title or TR.words__title_summary # def_arg title = title or TR.words__title_summary # def_arg
total_label = total_label or TR.send__total_amount # def_arg total_label = total_label or TR.send__total_amount # def_arg
fee_label = fee_label or TR.send__incl_transaction_fee # def_arg fee_label = fee_label or TR.send__incl_transaction_fee # def_arg
@ -918,7 +918,7 @@ async def confirm_total(
if fee_rate_amount: if fee_rate_amount:
fee_items.append((TR.confirm_total__fee_rate, fee_rate_amount)) fee_items.append((TR.confirm_total__fee_rate, fee_rate_amount))
await raise_if_not_confirmed( return raise_if_not_confirmed(
RustLayout( RustLayout(
trezorui2.flow_confirm_summary( trezorui2.flow_confirm_summary(
title=title, title=title,
@ -932,18 +932,18 @@ async def confirm_total(
) )
async def confirm_summary( def confirm_summary(
items: Iterable[tuple[str, str]], items: Iterable[tuple[str, str]],
title: str | None = None, title: str | None = None,
info_items: Iterable[tuple[str, str]] | None = None, info_items: Iterable[tuple[str, str]] | None = None,
info_title: str | None = None, info_title: str | None = None,
br_type: str = "confirm_total", br_type: str = "confirm_total",
br_code: ButtonRequestType = ButtonRequestType.SignTx, br_code: ButtonRequestType = ButtonRequestType.SignTx,
) -> None: ) -> Awaitable[None]:
# TODO: info_title # TODO: info_title
title = title or TR.words__title_summary # def_arg title = title or TR.words__title_summary # def_arg
await raise_if_not_confirmed( return raise_if_not_confirmed(
RustLayout( RustLayout(
trezorui2.flow_confirm_summary( trezorui2.flow_confirm_summary(
title=title, title=title,
@ -1051,7 +1051,7 @@ if not utils.BITCOIN_ONLY:
br_code=br_code, br_code=br_code,
) )
async def confirm_solana_tx( def confirm_solana_tx(
amount: str, amount: str,
fee: str, fee: str,
items: Iterable[tuple[str, str]], items: Iterable[tuple[str, str]],
@ -1059,12 +1059,12 @@ if not utils.BITCOIN_ONLY:
fee_title: str | None = None, fee_title: str | None = None,
br_type: str = "confirm_solana_tx", br_type: str = "confirm_solana_tx",
br_code: ButtonRequestType = ButtonRequestType.SignTx, br_code: ButtonRequestType = ButtonRequestType.SignTx,
): ) -> Awaitable[None]:
amount_title = ( amount_title = (
amount_title if amount_title is not None else f"{TR.words__amount}:" amount_title if amount_title is not None else f"{TR.words__amount}:"
) # def_arg ) # def_arg
fee_title = fee_title or TR.words__fee # def_arg fee_title = fee_title or TR.words__fee # def_arg
await confirm_summary( return confirm_summary(
((amount_title, amount), (fee_title, fee)), ((amount_title, amount), (fee_title, fee)),
info_items=items, info_items=items,
br_type=br_type, br_type=br_type,
@ -1072,8 +1072,8 @@ if not utils.BITCOIN_ONLY:
) )
async def confirm_joint_total(spending_amount: str, total_amount: str) -> None: def confirm_joint_total(spending_amount: str, total_amount: str) -> Awaitable[None]:
await confirm_summary( return confirm_summary(
items=[ items=[
(TR.send__you_are_contributing, spending_amount), (TR.send__you_are_contributing, spending_amount),
(TR.send__to_the_total_amount, total_amount), (TR.send__to_the_total_amount, total_amount),
@ -1084,7 +1084,7 @@ async def confirm_joint_total(spending_amount: str, total_amount: str) -> None:
) )
async def confirm_metadata( def confirm_metadata(
br_type: str, br_type: str,
title: str, title: str,
content: str, content: str,
@ -1092,9 +1092,9 @@ async def confirm_metadata(
br_code: ButtonRequestType = ButtonRequestType.SignTx, br_code: ButtonRequestType = ButtonRequestType.SignTx,
hold: bool = False, hold: bool = False,
verb: str | None = None, verb: str | None = None,
) -> None: ) -> Awaitable[None]:
verb = verb or TR.buttons__continue # def_arg verb = verb or TR.buttons__continue # def_arg
await confirm_action( return confirm_action(
br_type, br_type,
title=title, title=title,
action="", action="",
@ -1106,8 +1106,8 @@ async def confirm_metadata(
) )
async def confirm_replacement(title: str, txid: str) -> None: def confirm_replacement(title: str, txid: str) -> Awaitable[None]:
await confirm_blob( return confirm_blob(
"confirm_replacement", "confirm_replacement",
title, title,
txid, txid,
@ -1187,13 +1187,13 @@ async def with_info(
return result return result
async def confirm_modify_fee( def confirm_modify_fee(
title: str, title: str,
sign: int, sign: int,
user_fee_change: str, user_fee_change: str,
total_fee_new: str, total_fee_new: str,
fee_rate_amount: str | None = None, fee_rate_amount: str | None = None,
) -> None: ) -> Awaitable[None]:
fee_layout = RustLayout( fee_layout = RustLayout(
trezorui2.confirm_modify_fee( trezorui2.confirm_modify_fee(
title=title, title=title,
@ -1212,13 +1212,13 @@ async def confirm_modify_fee(
items=items, items=items,
) )
) )
await raise_if_not_confirmed( return raise_if_not_confirmed(
with_info(fee_layout, info_layout, "modify_fee", ButtonRequestType.SignTx) with_info(fee_layout, info_layout, "modify_fee", ButtonRequestType.SignTx)
) )
async def confirm_coinjoin(max_rounds: int, max_fee_per_vbyte: str) -> None: def confirm_coinjoin(max_rounds: int, max_fee_per_vbyte: str) -> Awaitable[None]:
await raise_if_not_confirmed( return raise_if_not_confirmed(
interact( interact(
RustLayout( RustLayout(
trezorui2.confirm_coinjoin( trezorui2.confirm_coinjoin(
@ -1233,10 +1233,10 @@ async def confirm_coinjoin(max_rounds: int, max_fee_per_vbyte: str) -> None:
# TODO cleanup @ redesign # TODO cleanup @ redesign
async def confirm_sign_identity( def confirm_sign_identity(
proto: str, identity: str, challenge_visual: str | None proto: str, identity: str, challenge_visual: str | None
) -> None: ) -> Awaitable[None]:
await confirm_blob( return confirm_blob(
"sign_identity", "sign_identity",
f"{TR.words__sign} {proto}", f"{TR.words__sign} {proto}",
identity, identity,
@ -1326,7 +1326,7 @@ async def confirm_signverify(
address_layout.request_complete_repaint() address_layout.request_complete_repaint()
async def show_error_popup( def show_error_popup(
title: str, title: str,
description: str, description: str,
subtitle: str | None = None, subtitle: str | None = None,
@ -1334,13 +1334,13 @@ async def show_error_popup(
*, *,
button: str = "", button: str = "",
timeout_ms: int = 0, timeout_ms: int = 0,
) -> None: ) -> Awaitable[None]:
if not button and not timeout_ms: if not button and not timeout_ms:
raise ValueError("Either button or timeout_ms must be set") raise ValueError("Either button or timeout_ms must be set")
if subtitle: if subtitle:
title += f"\n{subtitle}" title += f"\n{subtitle}"
await RustLayout( return RustLayout(
trezorui2.show_error( trezorui2.show_error(
title=title, title=title,
description=description.format(description_param), description=description.format(description_param),
@ -1417,7 +1417,7 @@ async def request_pin_on_device(
async def confirm_reenter_pin( async def confirm_reenter_pin(
is_wipe_code: bool = False, is_wipe_code: bool = False,
) -> None: ) -> None:
"""Not supported for TT.""" """Not supported for Mercury."""
pass pass
@ -1444,14 +1444,14 @@ async def wipe_code_same_as_pin_popup() -> None:
) )
async def confirm_set_new_pin( def confirm_set_new_pin(
br_type: str, br_type: str,
title: str, title: str,
description: str, description: str,
information: str, information: str,
br_code: ButtonRequestType = BR_TYPE_OTHER, br_code: ButtonRequestType = BR_TYPE_OTHER,
) -> None: ) -> Awaitable[None]:
await raise_if_not_confirmed( return raise_if_not_confirmed(
interact( interact(
RustLayout( RustLayout(
trezorui2.flow_confirm_set_new_pin(title=title, description=description) trezorui2.flow_confirm_set_new_pin(title=title, description=description)
@ -1462,8 +1462,8 @@ async def confirm_set_new_pin(
) )
async def confirm_firmware_update(description: str, fingerprint: str) -> None: def confirm_firmware_update(description: str, fingerprint: str) -> Awaitable[None]:
await raise_if_not_confirmed( return raise_if_not_confirmed(
interact( interact(
RustLayout( RustLayout(
trezorui2.confirm_firmware_update( trezorui2.confirm_firmware_update(