mirror of
https://github.com/trezor/trezor-firmware.git
synced 2025-01-18 11:21:11 +00:00
a44e738d31
[no changelog]
475 lines
10 KiB
Python
475 lines
10 KiB
Python
from typing import *
|
|
CONFIRMED: object
|
|
CANCELLED: object
|
|
|
|
|
|
# rust/src/ui/model_tr/layout.rs
|
|
def disable_animation(disable: bool) -> None:
|
|
"""Disable animations, debug builds only."""
|
|
|
|
|
|
# rust/src/ui/model_tr/layout.rs
|
|
def confirm_action(
|
|
*,
|
|
title: str,
|
|
action: str | None = None,
|
|
description: str | None = None,
|
|
verb: str | None = None,
|
|
verb_cancel: str | None = None,
|
|
hold: bool = False,
|
|
hold_danger: bool = False, # unused on TR
|
|
reverse: bool = False,
|
|
) -> object:
|
|
"""Confirm action."""
|
|
|
|
|
|
# rust/src/ui/model_tr/layout.rs
|
|
def confirm_text(
|
|
*,
|
|
title: str,
|
|
data: str,
|
|
description: str | None,
|
|
) -> object:
|
|
"""Confirm text."""
|
|
CONFIRMED: object
|
|
CANCELLED: object
|
|
INFO: object
|
|
|
|
|
|
# rust/src/ui/model_tt/layout.rs
|
|
def disable_animation(disable: bool) -> None:
|
|
"""Disable animations, debug builds only."""
|
|
|
|
|
|
# rust/src/ui/model_tt/layout.rs
|
|
def jpeg_info(data: bytes) -> (width: int, height: int, mcu_height: int):
|
|
"""Get JPEG image dimensions."""
|
|
|
|
|
|
# rust/src/ui/model_tt/layout.rs
|
|
def jpeg_test(data: bytes) -> bool:
|
|
"""Test JPEG image."""
|
|
|
|
|
|
# rust/src/ui/model_tt/layout.rs
|
|
def confirm_action(
|
|
*,
|
|
title: str,
|
|
action: str | None,
|
|
description: str | None,
|
|
verb: str | None = None,
|
|
verb_cancel: str | None = None,
|
|
hold: bool = False,
|
|
hold_danger: bool = False,
|
|
reverse: bool = False,
|
|
) -> object:
|
|
"""Confirm action."""
|
|
|
|
|
|
# rust/src/ui/model_tt/layout.rs
|
|
def confirm_homescreen(
|
|
*,
|
|
title: str,
|
|
image: bytes,
|
|
) -> object:
|
|
"""Confirm homescreen."""
|
|
|
|
|
|
# rust/src/ui/model_tt/layout.rs
|
|
def confirm_blob(
|
|
*,
|
|
title: str,
|
|
data: str | bytes,
|
|
description: str | None,
|
|
extra: str | None,
|
|
verb: str | None = None,
|
|
verb_cancel: str | None = None,
|
|
hold: bool = False,
|
|
) -> object:
|
|
"""Confirm byte sequence data."""
|
|
|
|
|
|
# rust/src/ui/model_tt/layout.rs
|
|
def confirm_address(
|
|
*,
|
|
title: str,
|
|
data: str | bytes,
|
|
description: str | None,
|
|
extra: str | None,
|
|
) -> object:
|
|
"""Confirm address. Similar to `confirm_blob` but has corner info button
|
|
and allows left swipe which does the same thing as the button."""
|
|
|
|
|
|
# rust/src/ui/model_tt/layout.rs
|
|
def confirm_properties(
|
|
*,
|
|
title: str,
|
|
items: list[tuple[str | None, str | bytes | None, bool]],
|
|
hold: bool = False,
|
|
) -> object:
|
|
"""Confirm list of key-value pairs. The third component in the tuple should be True if
|
|
the value is to be rendered as binary with monospace font, False otherwise."""
|
|
|
|
|
|
# rust/src/ui/model_tt/layout.rs
|
|
def confirm_reset_device(
|
|
*,
|
|
title: str,
|
|
button: str,
|
|
) -> object:
|
|
"""Confirm TOS before device setup."""
|
|
|
|
|
|
# rust/src/ui/model_tt/layout.rs
|
|
def show_qr(
|
|
*,
|
|
title: str,
|
|
address: str,
|
|
verb_cancel: str,
|
|
case_sensitive: bool,
|
|
) -> object:
|
|
"""Show QR code."""
|
|
|
|
|
|
# rust/src/ui/model_tt/layout.rs
|
|
def show_address_details(
|
|
*,
|
|
address: str,
|
|
case_sensitive: bool,
|
|
account: str | None,
|
|
path: str | None,
|
|
xpubs: list[tuple[str, str]],
|
|
) -> object:
|
|
"""Show address details - QR code, account, path, cosigner xpubs."""
|
|
|
|
|
|
# rust/src/ui/model_tt/layout.rs
|
|
def show_spending_details(
|
|
*,
|
|
account: str,
|
|
fee_rate: str | None = None,
|
|
) -> object:
|
|
"""Show metadata when for outgoing transaction."""
|
|
|
|
|
|
# rust/src/ui/model_tt/layout.rs
|
|
def confirm_value(
|
|
*,
|
|
title: str,
|
|
value: str,
|
|
description: str | None = None,
|
|
subtitle: str | None = None,
|
|
verb: str | None = None,
|
|
verb_cancel: str | None = None,
|
|
info_button: bool = False,
|
|
hold: bool = False,
|
|
) -> object:
|
|
"""Confirm value. Merge of confirm_total and confirm_output."""
|
|
|
|
|
|
# rust/src/ui/model_tt/layout.rs
|
|
def confirm_total(
|
|
*,
|
|
title: str,
|
|
items: List[Tuple[str, str]],
|
|
info_button: bool = False,
|
|
) -> object:
|
|
"""Transaction summary. Always hold to confirm."""
|
|
|
|
|
|
# rust/src/ui/model_tt/layout.rs
|
|
def confirm_modify_output(
|
|
*,
|
|
address: str,
|
|
sign: int,
|
|
amount_change: str,
|
|
amount_new: str,
|
|
) -> object:
|
|
"""Decrease or increase amount for given address."""
|
|
|
|
|
|
# rust/src/ui/model_tt/layout.rs
|
|
def confirm_modify_fee(
|
|
*,
|
|
sign: int,
|
|
user_fee_change: str,
|
|
total_fee_new: str,
|
|
) -> object:
|
|
"""Decrease or increase transaction fee."""
|
|
|
|
|
|
# rust/src/ui/model_tt/layout.rs
|
|
def confirm_fido(
|
|
*,
|
|
title: str,
|
|
app_name: str,
|
|
icon_name: str | None,
|
|
accounts: list[str | None],
|
|
) -> int | object:
|
|
"""FIDO confirmation.
|
|
Returns page index in case of confirmation and CANCELLED otherwise.
|
|
"""
|
|
|
|
|
|
# rust/src/ui/model_tt/layout.rs
|
|
def show_error(
|
|
*,
|
|
title: str,
|
|
button: str = "CONTINUE",
|
|
description: str = "",
|
|
allow_cancel: bool = False,
|
|
time_ms: int = 0,
|
|
) -> object:
|
|
"""Error modal. No buttons shown when `button` is empty string."""
|
|
|
|
|
|
# rust/src/ui/model_tt/layout.rs
|
|
def show_warning(
|
|
*,
|
|
title: str,
|
|
button: str = "CONTINUE",
|
|
description: str = "",
|
|
allow_cancel: bool = False,
|
|
time_ms: int = 0,
|
|
) -> object:
|
|
"""Warning modal. No buttons shown when `button` is empty string."""
|
|
|
|
|
|
# rust/src/ui/model_tt/layout.rs
|
|
def show_success(
|
|
*,
|
|
title: str,
|
|
button: str = "CONTINUE",
|
|
description: str = "",
|
|
allow_cancel: bool = False,
|
|
time_ms: int = 0,
|
|
) -> object:
|
|
"""Success modal. No buttons shown when `button` is empty string."""
|
|
|
|
|
|
# rust/src/ui/model_tt/layout.rs
|
|
def show_info(
|
|
*,
|
|
title: str,
|
|
button: str = "CONTINUE",
|
|
description: str = "",
|
|
allow_cancel: bool = False,
|
|
time_ms: int = 0,
|
|
) -> object:
|
|
"""Info modal. No buttons shown when `button` is empty string."""
|
|
|
|
|
|
# rust/src/ui/model_tt/layout.rs
|
|
def show_mismatch() -> object:
|
|
"""Warning modal, receiving address mismatch."""
|
|
|
|
|
|
# rust/src/ui/model_tt/layout.rs
|
|
def show_simple(
|
|
*,
|
|
title: str | None,
|
|
description: str,
|
|
button: str | None = None,
|
|
) -> object:
|
|
"""Simple dialog with text and one button."""
|
|
|
|
|
|
# rust/src/ui/model_tt/layout.rs
|
|
def confirm_with_info(
|
|
*,
|
|
title: str,
|
|
button: str,
|
|
info_button: str,
|
|
items: Iterable[Tuple[int, str]],
|
|
) -> object:
|
|
"""Confirm given items but with third button. Always single page
|
|
without scrolling."""
|
|
|
|
|
|
# rust/src/ui/model_tt/layout.rs
|
|
def confirm_more(
|
|
*,
|
|
title: str,
|
|
button: str,
|
|
items: Iterable[Tuple[int, str]],
|
|
) -> object:
|
|
"""Confirm long content with the possibility to go back from any page.
|
|
Meant to be used with confirm_with_info."""
|
|
|
|
|
|
# rust/src/ui/model_tt/layout.rs
|
|
def confirm_coinjoin(
|
|
*,
|
|
max_rounds: str,
|
|
max_feerate: str,
|
|
) -> object:
|
|
"""Confirm coinjoin authorization."""
|
|
|
|
|
|
# rust/src/ui/model_tt/layout.rs
|
|
def request_pin(
|
|
*,
|
|
prompt: str,
|
|
subprompt: str,
|
|
allow_cancel: bool = True,
|
|
wrong_pin: bool = False,
|
|
) -> str | object:
|
|
"""Request pin on device."""
|
|
|
|
|
|
# rust/src/ui/model_tt/layout.rs
|
|
def request_passphrase(
|
|
*,
|
|
prompt: str,
|
|
max_len: int,
|
|
) -> str | object:
|
|
"""Passphrase input keyboard."""
|
|
|
|
|
|
# rust/src/ui/model_tt/layout.rs
|
|
def request_bip39(
|
|
*,
|
|
prompt: str,
|
|
) -> str:
|
|
"""BIP39 word input keyboard."""
|
|
|
|
|
|
# rust/src/ui/model_tt/layout.rs
|
|
def request_slip39(
|
|
*,
|
|
prompt: str,
|
|
) -> str:
|
|
"""SLIP39 word input keyboard."""
|
|
|
|
|
|
# rust/src/ui/model_tt/layout.rs
|
|
def select_word(
|
|
*,
|
|
title: str,
|
|
description: str,
|
|
words: Iterable[str],
|
|
) -> int:
|
|
"""Select mnemonic word from three possibilities - seed check after backup. The
|
|
iterable must be of exact size. Returns index in range `0..3`."""
|
|
|
|
|
|
# rust/src/ui/model_tt/layout.rs
|
|
def show_share_words(
|
|
*,
|
|
title: str,
|
|
pages: Iterable[str],
|
|
) -> object:
|
|
"""Show mnemonic for backup. Expects the words pre-divided into individual pages."""
|
|
|
|
|
|
# rust/src/ui/model_tt/layout.rs
|
|
def request_number(
|
|
*,
|
|
title: str,
|
|
count: int,
|
|
min_count: int,
|
|
max_count: int,
|
|
description: Callable[[int], str] | None = None,
|
|
) -> object:
|
|
"""Number input with + and - buttons, description, and info button."""
|
|
|
|
|
|
# rust/src/ui/model_tt/layout.rs
|
|
def show_checklist(
|
|
*,
|
|
title: str,
|
|
items: Iterable[str],
|
|
active: int,
|
|
button: str,
|
|
) -> object:
|
|
"""Checklist of backup steps. Active index is highlighted, previous items have check
|
|
mark nex to them."""
|
|
|
|
|
|
# rust/src/ui/model_tt/layout.rs
|
|
def confirm_recovery(
|
|
*,
|
|
title: str,
|
|
description: str,
|
|
button: str,
|
|
dry_run: bool,
|
|
info_button: bool,
|
|
) -> object:
|
|
"""Device recovery homescreen."""
|
|
|
|
|
|
# rust/src/ui/model_tt/layout.rs
|
|
def select_word_count(
|
|
*,
|
|
dry_run: bool,
|
|
) -> int | CANCELLED:
|
|
"""Select mnemonic word count from (12, 18, 20, 24, 33)."""
|
|
|
|
|
|
# rust/src/ui/model_tt/layout.rs
|
|
def show_group_share_success(
|
|
*,
|
|
lines: Iterable[str]
|
|
) -> int:
|
|
"""Shown after successfully finishing a group."""
|
|
|
|
|
|
# rust/src/ui/model_tt/layout.rs
|
|
def show_remaining_shares(
|
|
*,
|
|
pages: Iterable[tuple[str, str]],
|
|
) -> int:
|
|
"""Shows SLIP39 state after info button is pressed on `confirm_recovery`."""
|
|
|
|
|
|
# rust/src/ui/model_tt/layout.rs
|
|
def show_progress(
|
|
*,
|
|
title: str,
|
|
indeterminate: bool = False,
|
|
description: str | None = None,
|
|
) -> object:
|
|
"""Show progress loader. Please note that the number of lines reserved on screen for
|
|
description is determined at construction time. If you want multiline descriptions
|
|
make sure the initial desciption has at least that amount of lines."""
|
|
|
|
|
|
# rust/src/ui/model_tt/layout.rs
|
|
def show_progress_coinjoin(
|
|
*,
|
|
title: str,
|
|
indeterminate: bool = False,
|
|
time_ms: int = 0,
|
|
skip_first_paint: bool = False,
|
|
) -> object:
|
|
"""Show progress loader for coinjoin. Returns CANCELLED after a specified time when
|
|
time_ms timeout is passed."""
|
|
|
|
|
|
# rust/src/ui/model_tt/layout.rs
|
|
def show_homescreen(
|
|
*,
|
|
label: str,
|
|
hold: bool,
|
|
notification: str | None,
|
|
notification_level: int = 0,
|
|
skip_first_paint: bool,
|
|
) -> CANCELLED:
|
|
"""Idle homescreen."""
|
|
|
|
|
|
# rust/src/ui/model_tt/layout.rs
|
|
def show_lockscreen(
|
|
*,
|
|
label: str,
|
|
bootscreen: bool,
|
|
skip_first_paint: bool,
|
|
) -> CANCELLED:
|
|
"""Homescreen for locked device."""
|
|
|
|
|
|
# rust/src/ui/model_tt/layout.rs
|
|
def draw_welcome_screen() -> None:
|
|
"""Show logo icon with the model name at the bottom and return."""
|