mirror of
https://github.com/trezor/trezor-firmware.git
synced 2025-01-07 14:00:57 +00:00
refactor(core): move confirm_with_info
- decided to import stuff from micropython so that I don't have to write `crate::micropython::yadayada` everywhere. I'll remove that from other functions later during squash.
This commit is contained in:
parent
1653c7d250
commit
03756faf70
@ -184,6 +184,23 @@ extern "C" fn new_confirm_reset_device(n_args: usize, args: *const Obj, kwargs:
|
|||||||
unsafe { util::try_with_args_and_kwargs(n_args, args, kwargs, block) }
|
unsafe { util::try_with_args_and_kwargs(n_args, args, kwargs, block) }
|
||||||
}
|
}
|
||||||
|
|
||||||
|
extern "C" fn new_confirm_with_info(n_args: usize, args: *const Obj, kwargs: *mut Map) -> Obj {
|
||||||
|
let block = move |_args: &[Obj], kwargs: &Map| {
|
||||||
|
let title: TString = kwargs.get(Qstr::MP_QSTR_title)?.try_into()?;
|
||||||
|
let button: TString = kwargs.get(Qstr::MP_QSTR_button)?.try_into()?;
|
||||||
|
let info_button: TString = kwargs.get(Qstr::MP_QSTR_info_button)?.try_into()?;
|
||||||
|
let verb_cancel: Option<TString<'static>> = kwargs
|
||||||
|
.get(Qstr::MP_QSTR_verb_cancel)
|
||||||
|
.unwrap_or_else(|_| Obj::const_none())
|
||||||
|
.try_into_option()?;
|
||||||
|
let items: Obj = kwargs.get(Qstr::MP_QSTR_items)?;
|
||||||
|
|
||||||
|
let layout = ModelUI::confirm_with_info(title, button, info_button, verb_cancel, items)?;
|
||||||
|
Ok(LayoutObj::new_root(layout)?.into())
|
||||||
|
};
|
||||||
|
unsafe { util::try_with_args_and_kwargs(n_args, args, kwargs, block) }
|
||||||
|
}
|
||||||
|
|
||||||
extern "C" fn new_continue_recovery_homepage(
|
extern "C" fn new_continue_recovery_homepage(
|
||||||
n_args: usize,
|
n_args: usize,
|
||||||
args: *const Obj,
|
args: *const Obj,
|
||||||
@ -794,6 +811,19 @@ pub static mp_module_trezorui_api: Module = obj_module! {
|
|||||||
/// """Confirm TOS before creating wallet creation or wallet recovery."""
|
/// """Confirm TOS before creating wallet creation or wallet recovery."""
|
||||||
Qstr::MP_QSTR_confirm_reset_device => obj_fn_kw!(0, new_confirm_reset_device).as_obj(),
|
Qstr::MP_QSTR_confirm_reset_device => obj_fn_kw!(0, new_confirm_reset_device).as_obj(),
|
||||||
|
|
||||||
|
/// def confirm_with_info(
|
||||||
|
/// *,
|
||||||
|
/// title: str,
|
||||||
|
/// button: str,
|
||||||
|
/// info_button: str,
|
||||||
|
/// verb_cancel: str | None = None,
|
||||||
|
/// items: Iterable[tuple[int, str | bytes]],
|
||||||
|
/// ) -> LayoutObj[UiResult]:
|
||||||
|
/// """Confirm given items but with third button. Always single page
|
||||||
|
/// without scrolling. In mercury, the button is placed in
|
||||||
|
/// context menu."""
|
||||||
|
Qstr::MP_QSTR_confirm_with_info => obj_fn_kw!(0, new_confirm_with_info).as_obj(),
|
||||||
|
|
||||||
/// def continue_recovery_homepage(
|
/// def continue_recovery_homepage(
|
||||||
/// *,
|
/// *,
|
||||||
/// text: str,
|
/// text: str,
|
||||||
|
@ -695,31 +695,6 @@ extern "C" fn new_confirm_total(n_args: usize, args: *const Obj, kwargs: *mut Ma
|
|||||||
unsafe { util::try_with_args_and_kwargs(n_args, args, kwargs, block) }
|
unsafe { util::try_with_args_and_kwargs(n_args, args, kwargs, block) }
|
||||||
}
|
}
|
||||||
|
|
||||||
extern "C" fn new_confirm_with_info(n_args: usize, args: *const Obj, kwargs: *mut Map) -> Obj {
|
|
||||||
let block = move |_args: &[Obj], kwargs: &Map| {
|
|
||||||
let title: TString = kwargs.get(Qstr::MP_QSTR_title)?.try_into()?;
|
|
||||||
let button: TString = kwargs.get(Qstr::MP_QSTR_button)?.try_into()?;
|
|
||||||
let info_button: TString = kwargs.get(Qstr::MP_QSTR_info_button)?.try_into()?;
|
|
||||||
let items: Obj = kwargs.get(Qstr::MP_QSTR_items)?;
|
|
||||||
|
|
||||||
let mut paragraphs = ParagraphVecShort::new();
|
|
||||||
|
|
||||||
for para in IterBuf::new().try_iterate(items)? {
|
|
||||||
let [font, text]: [Obj; 2] = util::iter_into_array(para)?;
|
|
||||||
let style: &TextStyle = theme::textstyle_number(font.try_into()?);
|
|
||||||
let text: TString = text.try_into()?;
|
|
||||||
paragraphs.add(Paragraph::new(style, text));
|
|
||||||
if paragraphs.is_full() {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
let flow = flow::new_confirm_with_info(title, Some(button), info_button, paragraphs, None)?;
|
|
||||||
Ok(LayoutObj::new_root(flow)?.into())
|
|
||||||
};
|
|
||||||
unsafe { util::try_with_args_and_kwargs(n_args, args, kwargs, block) }
|
|
||||||
}
|
|
||||||
|
|
||||||
extern "C" fn new_get_address(n_args: usize, args: *const Obj, kwargs: *mut Map) -> Obj {
|
extern "C" fn new_get_address(n_args: usize, args: *const Obj, kwargs: *mut Map) -> Obj {
|
||||||
let block = move |_args: &[Obj], kwargs: &Map| {
|
let block = move |_args: &[Obj], kwargs: &Map| {
|
||||||
let title: TString = kwargs.get(Qstr::MP_QSTR_title)?.try_into()?;
|
let title: TString = kwargs.get(Qstr::MP_QSTR_title)?.try_into()?;
|
||||||
@ -901,17 +876,6 @@ pub static mp_module_trezorui2: Module = obj_module! {
|
|||||||
/// """Transaction summary. Always hold to confirm."""
|
/// """Transaction summary. Always hold to confirm."""
|
||||||
Qstr::MP_QSTR_confirm_total => obj_fn_kw!(0, new_confirm_total).as_obj(),
|
Qstr::MP_QSTR_confirm_total => obj_fn_kw!(0, new_confirm_total).as_obj(),
|
||||||
|
|
||||||
/// def confirm_with_info(
|
|
||||||
/// *,
|
|
||||||
/// title: str,
|
|
||||||
/// button: str,
|
|
||||||
/// info_button: str,
|
|
||||||
/// items: Iterable[tuple[int, str]],
|
|
||||||
/// ) -> LayoutObj[UiResult]:
|
|
||||||
/// """Confirm given items but with third button. In mercury, the button is placed in
|
|
||||||
/// context menu."""
|
|
||||||
Qstr::MP_QSTR_confirm_with_info => obj_fn_kw!(0, new_confirm_with_info).as_obj(),
|
|
||||||
|
|
||||||
/// def flow_prompt_backup() -> LayoutObj[UiResult]:
|
/// def flow_prompt_backup() -> LayoutObj[UiResult]:
|
||||||
/// """Prompt a user to create backup with an option to skip."""
|
/// """Prompt a user to create backup with an option to skip."""
|
||||||
Qstr::MP_QSTR_flow_prompt_backup => obj_fn_0!(new_prompt_backup).as_obj(),
|
Qstr::MP_QSTR_flow_prompt_backup => obj_fn_0!(new_prompt_backup).as_obj(),
|
||||||
|
@ -3,16 +3,19 @@ use core::cmp::Ordering;
|
|||||||
use crate::{
|
use crate::{
|
||||||
error::{value_error, Error},
|
error::{value_error, Error},
|
||||||
io::BinaryData,
|
io::BinaryData,
|
||||||
micropython::{gc::Gc, list::List, util},
|
micropython::{gc::Gc, iter::IterBuf, list::List, obj::Obj, util},
|
||||||
strutil::TString,
|
strutil::TString,
|
||||||
translations::TR,
|
translations::TR,
|
||||||
ui::{
|
ui::{
|
||||||
component::{
|
component::{
|
||||||
connect::Connect,
|
connect::Connect,
|
||||||
swipe_detect::SwipeSettings,
|
swipe_detect::SwipeSettings,
|
||||||
text::paragraphs::{
|
text::{
|
||||||
Checklist, Paragraph, ParagraphSource, ParagraphVecLong, ParagraphVecShort,
|
paragraphs::{
|
||||||
Paragraphs, VecExt,
|
Checklist, Paragraph, ParagraphSource, ParagraphVecLong, ParagraphVecShort,
|
||||||
|
Paragraphs, VecExt,
|
||||||
|
},
|
||||||
|
TextStyle,
|
||||||
},
|
},
|
||||||
Border, CachedJpeg, ComponentExt, Empty, Never, Timeout,
|
Border, CachedJpeg, ComponentExt, Empty, Never, Timeout,
|
||||||
},
|
},
|
||||||
@ -32,8 +35,8 @@ use super::{
|
|||||||
SwipeContent, SwipeUpScreen, VerticalMenu,
|
SwipeContent, SwipeUpScreen, VerticalMenu,
|
||||||
},
|
},
|
||||||
flow::{
|
flow::{
|
||||||
self, new_confirm_action_simple, ConfirmActionExtra, ConfirmActionMenu,
|
self, new_confirm_action_simple, ConfirmActionExtra, ConfirmActionMenuStrings,
|
||||||
ConfirmActionMenuStrings, ConfirmActionStrings,
|
ConfirmActionStrings,
|
||||||
},
|
},
|
||||||
theme, ModelMercuryFeatures,
|
theme, ModelMercuryFeatures,
|
||||||
};
|
};
|
||||||
@ -232,6 +235,29 @@ impl UIFeaturesFirmware for ModelMercuryFeatures {
|
|||||||
Ok(flow)
|
Ok(flow)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn confirm_with_info(
|
||||||
|
title: TString<'static>,
|
||||||
|
button: TString<'static>,
|
||||||
|
info_button: TString<'static>,
|
||||||
|
verb_cancel: Option<TString<'static>>,
|
||||||
|
items: Obj,
|
||||||
|
) -> Result<impl LayoutMaybeTrace, Error> {
|
||||||
|
let mut paragraphs = ParagraphVecShort::new();
|
||||||
|
|
||||||
|
for para in IterBuf::new().try_iterate(items)? {
|
||||||
|
let [font, text]: [Obj; 2] = util::iter_into_array(para)?;
|
||||||
|
let style: &TextStyle = theme::textstyle_number(font.try_into()?);
|
||||||
|
let text: TString = text.try_into()?;
|
||||||
|
paragraphs.add(Paragraph::new(style, text));
|
||||||
|
if paragraphs.is_full() {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
let flow = flow::new_confirm_with_info(title, Some(button), info_button, paragraphs, None)?;
|
||||||
|
Ok(flow)
|
||||||
|
}
|
||||||
|
|
||||||
fn check_homescreen_format(image: BinaryData, __accept_toif: bool) -> bool {
|
fn check_homescreen_format(image: BinaryData, __accept_toif: bool) -> bool {
|
||||||
super::component::check_homescreen_format(image)
|
super::component::check_homescreen_format(image)
|
||||||
}
|
}
|
||||||
|
@ -778,41 +778,6 @@ extern "C" fn new_multiple_pages_texts(n_args: usize, args: *const Obj, kwargs:
|
|||||||
unsafe { util::try_with_args_and_kwargs(n_args, args, kwargs, block) }
|
unsafe { util::try_with_args_and_kwargs(n_args, args, kwargs, block) }
|
||||||
}
|
}
|
||||||
|
|
||||||
extern "C" fn new_confirm_with_info(n_args: usize, args: *const Obj, kwargs: *mut Map) -> Obj {
|
|
||||||
let block = move |_args: &[Obj], kwargs: &Map| {
|
|
||||||
let title: TString = kwargs.get(Qstr::MP_QSTR_title)?.try_into()?;
|
|
||||||
let button: TString<'static> = kwargs.get(Qstr::MP_QSTR_button)?.try_into()?;
|
|
||||||
let verb_cancel: Option<TString<'static>> = kwargs
|
|
||||||
.get(Qstr::MP_QSTR_verb_cancel)
|
|
||||||
.unwrap_or_else(|_| Obj::const_none())
|
|
||||||
.try_into_option()?;
|
|
||||||
let items: Obj = kwargs.get(Qstr::MP_QSTR_items)?;
|
|
||||||
|
|
||||||
let mut paragraphs = ParagraphVecShort::new();
|
|
||||||
|
|
||||||
for para in IterBuf::new().try_iterate(items)? {
|
|
||||||
let [font, text]: [Obj; 2] = util::iter_into_array(para)?;
|
|
||||||
let style: &TextStyle = theme::textstyle_number(font.try_into()?);
|
|
||||||
let text: TString = text.try_into()?;
|
|
||||||
paragraphs.add(Paragraph::new(style, text));
|
|
||||||
if paragraphs.is_full() {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
let obj = LayoutObj::new(Frame::new(
|
|
||||||
title,
|
|
||||||
ShowMore::<Paragraphs<ParagraphVecShort>>::new(
|
|
||||||
paragraphs.into_paragraphs(),
|
|
||||||
verb_cancel,
|
|
||||||
button,
|
|
||||||
),
|
|
||||||
))?;
|
|
||||||
Ok(obj.into())
|
|
||||||
};
|
|
||||||
unsafe { util::try_with_args_and_kwargs(n_args, args, kwargs, block) }
|
|
||||||
}
|
|
||||||
|
|
||||||
extern "C" fn new_confirm_more(n_args: usize, args: *const Obj, kwargs: *mut Map) -> Obj {
|
extern "C" fn new_confirm_more(n_args: usize, args: *const Obj, kwargs: *mut Map) -> Obj {
|
||||||
let block = move |_args: &[Obj], kwargs: &Map| {
|
let block = move |_args: &[Obj], kwargs: &Map| {
|
||||||
let title: TString = kwargs.get(Qstr::MP_QSTR_title)?.try_into()?;
|
let title: TString = kwargs.get(Qstr::MP_QSTR_title)?.try_into()?;
|
||||||
@ -977,18 +942,6 @@ pub static mp_module_trezorui2: Module = obj_module! {
|
|||||||
/// """Show multiple texts, each on its own page."""
|
/// """Show multiple texts, each on its own page."""
|
||||||
Qstr::MP_QSTR_multiple_pages_texts => obj_fn_kw!(0, new_multiple_pages_texts).as_obj(),
|
Qstr::MP_QSTR_multiple_pages_texts => obj_fn_kw!(0, new_multiple_pages_texts).as_obj(),
|
||||||
|
|
||||||
/// def confirm_with_info(
|
|
||||||
/// *,
|
|
||||||
/// title: str,
|
|
||||||
/// button: str,
|
|
||||||
/// info_button: str, # unused on TR
|
|
||||||
/// items: Iterable[Tuple[int, str | bytes]],
|
|
||||||
/// verb_cancel: str | None = None,
|
|
||||||
/// ) -> LayoutObj[UiResult]:
|
|
||||||
/// """Confirm given items but with third button. Always single page
|
|
||||||
/// without scrolling."""
|
|
||||||
Qstr::MP_QSTR_confirm_with_info => obj_fn_kw!(0, new_confirm_with_info).as_obj(),
|
|
||||||
|
|
||||||
/// def confirm_more(
|
/// def confirm_more(
|
||||||
/// *,
|
/// *,
|
||||||
/// title: str,
|
/// title: str,
|
||||||
|
@ -4,7 +4,7 @@ use crate::{
|
|||||||
error::Error,
|
error::Error,
|
||||||
io::BinaryData,
|
io::BinaryData,
|
||||||
maybe_trace::MaybeTrace,
|
maybe_trace::MaybeTrace,
|
||||||
micropython::{gc::Gc, list::List},
|
micropython::{gc::Gc, iter::IterBuf, list::List, obj::Obj, util},
|
||||||
strutil::TString,
|
strutil::TString,
|
||||||
translations::TR,
|
translations::TR,
|
||||||
ui::{
|
ui::{
|
||||||
@ -16,6 +16,7 @@ use crate::{
|
|||||||
Checklist, Paragraph, ParagraphSource, ParagraphVecLong, ParagraphVecShort,
|
Checklist, Paragraph, ParagraphSource, ParagraphVecLong, ParagraphVecShort,
|
||||||
Paragraphs, VecExt,
|
Paragraphs, VecExt,
|
||||||
},
|
},
|
||||||
|
TextStyle,
|
||||||
},
|
},
|
||||||
Component, ComponentExt, Empty, FormattedText, Label, LineBreaking, Paginate, Timeout,
|
Component, ComponentExt, Empty, FormattedText, Label, LineBreaking, Paginate, Timeout,
|
||||||
},
|
},
|
||||||
@ -36,7 +37,7 @@ use super::{
|
|||||||
component::{
|
component::{
|
||||||
ButtonDetails, ButtonPage, CoinJoinProgress, ConfirmHomescreen, Flow, FlowPages, Frame,
|
ButtonDetails, ButtonPage, CoinJoinProgress, ConfirmHomescreen, Flow, FlowPages, Frame,
|
||||||
Homescreen, Lockscreen, NumberInput, PassphraseEntry, PinEntry, Progress, ScrollableFrame,
|
Homescreen, Lockscreen, NumberInput, PassphraseEntry, PinEntry, Progress, ScrollableFrame,
|
||||||
ShareWords, SimpleChoice, WordlistEntry, WordlistType,
|
ShareWords, ShowMore, SimpleChoice, WordlistEntry, WordlistType,
|
||||||
},
|
},
|
||||||
theme, ModelTRFeatures,
|
theme, ModelTRFeatures,
|
||||||
};
|
};
|
||||||
@ -290,6 +291,36 @@ impl UIFeaturesFirmware for ModelTRFeatures {
|
|||||||
content_in_button_page(title, formatted, button, Some("".into()), false)
|
content_in_button_page(title, formatted, button, Some("".into()), false)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn confirm_with_info(
|
||||||
|
title: TString<'static>,
|
||||||
|
button: TString<'static>,
|
||||||
|
_info_button: TString<'static>,
|
||||||
|
verb_cancel: Option<TString<'static>>,
|
||||||
|
items: Obj,
|
||||||
|
) -> Result<impl LayoutMaybeTrace, Error> {
|
||||||
|
let mut paragraphs = ParagraphVecShort::new();
|
||||||
|
|
||||||
|
for para in IterBuf::new().try_iterate(items)? {
|
||||||
|
let [font, text]: [Obj; 2] = util::iter_into_array(para)?;
|
||||||
|
let style: &TextStyle = theme::textstyle_number(font.try_into()?);
|
||||||
|
let text: TString = text.try_into()?;
|
||||||
|
paragraphs.add(Paragraph::new(style, text));
|
||||||
|
if paragraphs.is_full() {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
let layout = RootComponent::new(Frame::new(
|
||||||
|
title,
|
||||||
|
ShowMore::<Paragraphs<ParagraphVecShort>>::new(
|
||||||
|
paragraphs.into_paragraphs(),
|
||||||
|
verb_cancel,
|
||||||
|
button,
|
||||||
|
),
|
||||||
|
));
|
||||||
|
Ok(layout)
|
||||||
|
}
|
||||||
|
|
||||||
fn check_homescreen_format(image: BinaryData, _accept_toif: bool) -> bool {
|
fn check_homescreen_format(image: BinaryData, _accept_toif: bool) -> bool {
|
||||||
super::component::check_homescreen_format(image)
|
super::component::check_homescreen_format(image)
|
||||||
}
|
}
|
||||||
|
@ -689,37 +689,6 @@ extern "C" fn new_confirm_total(n_args: usize, args: *const Obj, kwargs: *mut Ma
|
|||||||
unsafe { util::try_with_args_and_kwargs(n_args, args, kwargs, block) }
|
unsafe { util::try_with_args_and_kwargs(n_args, args, kwargs, block) }
|
||||||
}
|
}
|
||||||
|
|
||||||
extern "C" fn new_confirm_with_info(n_args: usize, args: *const Obj, kwargs: *mut Map) -> Obj {
|
|
||||||
let block = move |_args: &[Obj], kwargs: &Map| {
|
|
||||||
let title: TString = kwargs.get(Qstr::MP_QSTR_title)?.try_into()?;
|
|
||||||
let button: TString = kwargs.get(Qstr::MP_QSTR_button)?.try_into()?;
|
|
||||||
let info_button: TString = kwargs.get(Qstr::MP_QSTR_info_button)?.try_into()?;
|
|
||||||
let items: Obj = kwargs.get(Qstr::MP_QSTR_items)?;
|
|
||||||
|
|
||||||
let mut paragraphs = ParagraphVecShort::new();
|
|
||||||
|
|
||||||
for para in IterBuf::new().try_iterate(items)? {
|
|
||||||
let [font, text]: [Obj; 2] = util::iter_into_array(para)?;
|
|
||||||
let style: &TextStyle = theme::textstyle_number(font.try_into()?);
|
|
||||||
let text: TString = text.try_into()?;
|
|
||||||
paragraphs.add(Paragraph::new(style, text));
|
|
||||||
if paragraphs.is_full() {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
let buttons = Button::cancel_info_confirm(button, info_button);
|
|
||||||
|
|
||||||
let obj = LayoutObj::new(Frame::left_aligned(
|
|
||||||
theme::label_title(),
|
|
||||||
title,
|
|
||||||
Dialog::new(paragraphs.into_paragraphs(), buttons),
|
|
||||||
))?;
|
|
||||||
Ok(obj.into())
|
|
||||||
};
|
|
||||||
unsafe { util::try_with_args_and_kwargs(n_args, args, kwargs, block) }
|
|
||||||
}
|
|
||||||
|
|
||||||
extern "C" fn new_confirm_more(n_args: usize, args: *const Obj, kwargs: *mut Map) -> Obj {
|
extern "C" fn new_confirm_more(n_args: usize, args: *const Obj, kwargs: *mut Map) -> Obj {
|
||||||
let block = move |_args: &[Obj], kwargs: &Map| {
|
let block = move |_args: &[Obj], kwargs: &Map| {
|
||||||
let title: TString = kwargs.get(Qstr::MP_QSTR_title)?.try_into()?;
|
let title: TString = kwargs.get(Qstr::MP_QSTR_title)?.try_into()?;
|
||||||
@ -863,17 +832,6 @@ pub static mp_module_trezorui2: Module = obj_module! {
|
|||||||
/// """Transaction summary. Always hold to confirm."""
|
/// """Transaction summary. Always hold to confirm."""
|
||||||
Qstr::MP_QSTR_confirm_total => obj_fn_kw!(0, new_confirm_total).as_obj(),
|
Qstr::MP_QSTR_confirm_total => obj_fn_kw!(0, new_confirm_total).as_obj(),
|
||||||
|
|
||||||
/// def confirm_with_info(
|
|
||||||
/// *,
|
|
||||||
/// title: str,
|
|
||||||
/// button: str,
|
|
||||||
/// info_button: str,
|
|
||||||
/// items: Iterable[tuple[int, str | bytes]],
|
|
||||||
/// ) -> LayoutObj[UiResult]:
|
|
||||||
/// """Confirm given items but with third button. Always single page
|
|
||||||
/// without scrolling."""
|
|
||||||
Qstr::MP_QSTR_confirm_with_info => obj_fn_kw!(0, new_confirm_with_info).as_obj(),
|
|
||||||
|
|
||||||
/// def confirm_more(
|
/// def confirm_more(
|
||||||
/// *,
|
/// *,
|
||||||
/// title: str,
|
/// title: str,
|
||||||
|
@ -3,16 +3,19 @@ use core::cmp::Ordering;
|
|||||||
use crate::{
|
use crate::{
|
||||||
error::{value_error, Error},
|
error::{value_error, Error},
|
||||||
io::BinaryData,
|
io::BinaryData,
|
||||||
micropython::{gc::Gc, list::List},
|
micropython::{gc::Gc, iter::IterBuf, list::List, obj::Obj, util},
|
||||||
strutil::TString,
|
strutil::TString,
|
||||||
translations::TR,
|
translations::TR,
|
||||||
ui::{
|
ui::{
|
||||||
component::{
|
component::{
|
||||||
connect::Connect,
|
connect::Connect,
|
||||||
image::BlendedImage,
|
image::BlendedImage,
|
||||||
text::paragraphs::{
|
text::{
|
||||||
Checklist, Paragraph, ParagraphSource, ParagraphVecLong, ParagraphVecShort,
|
paragraphs::{
|
||||||
Paragraphs, VecExt,
|
Checklist, Paragraph, ParagraphSource, ParagraphVecLong, ParagraphVecShort,
|
||||||
|
Paragraphs, VecExt,
|
||||||
|
},
|
||||||
|
TextStyle,
|
||||||
},
|
},
|
||||||
Border, ComponentExt, Empty, Jpeg, Label, Never, Timeout,
|
Border, ComponentExt, Empty, Jpeg, Label, Never, Timeout,
|
||||||
},
|
},
|
||||||
@ -272,6 +275,35 @@ impl UIFeaturesFirmware for ModelTTFeatures {
|
|||||||
Ok(layout)
|
Ok(layout)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn confirm_with_info(
|
||||||
|
title: TString<'static>,
|
||||||
|
button: TString<'static>,
|
||||||
|
info_button: TString<'static>,
|
||||||
|
_verb_cancel: Option<TString<'static>>,
|
||||||
|
items: Obj,
|
||||||
|
) -> Result<impl LayoutMaybeTrace, Error> {
|
||||||
|
let mut paragraphs = ParagraphVecShort::new();
|
||||||
|
|
||||||
|
for para in IterBuf::new().try_iterate(items)? {
|
||||||
|
let [font, text]: [Obj; 2] = util::iter_into_array(para)?;
|
||||||
|
let style: &TextStyle = theme::textstyle_number(font.try_into()?);
|
||||||
|
let text: TString = text.try_into()?;
|
||||||
|
paragraphs.add(Paragraph::new(style, text));
|
||||||
|
if paragraphs.is_full() {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
let buttons = Button::cancel_info_confirm(button, info_button);
|
||||||
|
|
||||||
|
let layout = RootComponent::new(Frame::left_aligned(
|
||||||
|
theme::label_title(),
|
||||||
|
title,
|
||||||
|
Dialog::new(paragraphs.into_paragraphs(), buttons),
|
||||||
|
));
|
||||||
|
Ok(layout)
|
||||||
|
}
|
||||||
|
|
||||||
fn check_homescreen_format(image: BinaryData, accept_toif: bool) -> bool {
|
fn check_homescreen_format(image: BinaryData, accept_toif: bool) -> bool {
|
||||||
super::component::check_homescreen_format(image, false)
|
super::component::check_homescreen_format(image, false)
|
||||||
}
|
}
|
||||||
|
@ -64,6 +64,14 @@ pub trait UIFeaturesFirmware {
|
|||||||
|
|
||||||
fn confirm_reset_device(recovery: bool) -> Result<impl LayoutMaybeTrace, Error>;
|
fn confirm_reset_device(recovery: bool) -> Result<impl LayoutMaybeTrace, Error>;
|
||||||
|
|
||||||
|
fn confirm_with_info(
|
||||||
|
title: TString<'static>,
|
||||||
|
button: TString<'static>,
|
||||||
|
info_button: TString<'static>,
|
||||||
|
verb_cancel: Option<TString<'static>>,
|
||||||
|
items: Obj, // TODO: replace Obj
|
||||||
|
) -> Result<impl LayoutMaybeTrace, Error>;
|
||||||
|
|
||||||
fn continue_recovery_homepage(
|
fn continue_recovery_homepage(
|
||||||
text: TString<'static>,
|
text: TString<'static>,
|
||||||
subtext: Option<TString<'static>>,
|
subtext: Option<TString<'static>>,
|
||||||
|
@ -124,18 +124,6 @@ def confirm_total(
|
|||||||
"""Transaction summary. Always hold to confirm."""
|
"""Transaction summary. Always hold to confirm."""
|
||||||
|
|
||||||
|
|
||||||
# rust/src/ui/model_mercury/layout.rs
|
|
||||||
def confirm_with_info(
|
|
||||||
*,
|
|
||||||
title: str,
|
|
||||||
button: str,
|
|
||||||
info_button: str,
|
|
||||||
items: Iterable[tuple[int, str]],
|
|
||||||
) -> LayoutObj[UiResult]:
|
|
||||||
"""Confirm given items but with third button. In mercury, the button is placed in
|
|
||||||
context menu."""
|
|
||||||
|
|
||||||
|
|
||||||
# rust/src/ui/model_mercury/layout.rs
|
# rust/src/ui/model_mercury/layout.rs
|
||||||
def flow_prompt_backup() -> LayoutObj[UiResult]:
|
def flow_prompt_backup() -> LayoutObj[UiResult]:
|
||||||
"""Prompt a user to create backup with an option to skip."""
|
"""Prompt a user to create backup with an option to skip."""
|
||||||
@ -356,19 +344,6 @@ def multiple_pages_texts(
|
|||||||
"""Show multiple texts, each on its own page."""
|
"""Show multiple texts, each on its own page."""
|
||||||
|
|
||||||
|
|
||||||
# rust/src/ui/model_tr/layout.rs
|
|
||||||
def confirm_with_info(
|
|
||||||
*,
|
|
||||||
title: str,
|
|
||||||
button: str,
|
|
||||||
info_button: str, # unused on TR
|
|
||||||
items: Iterable[Tuple[int, str | bytes]],
|
|
||||||
verb_cancel: str | None = None,
|
|
||||||
) -> LayoutObj[UiResult]:
|
|
||||||
"""Confirm given items but with third button. Always single page
|
|
||||||
without scrolling."""
|
|
||||||
|
|
||||||
|
|
||||||
# rust/src/ui/model_tr/layout.rs
|
# rust/src/ui/model_tr/layout.rs
|
||||||
def confirm_more(
|
def confirm_more(
|
||||||
*,
|
*,
|
||||||
@ -493,18 +468,6 @@ def confirm_total(
|
|||||||
"""Transaction summary. Always hold to confirm."""
|
"""Transaction summary. Always hold to confirm."""
|
||||||
|
|
||||||
|
|
||||||
# rust/src/ui/model_tt/layout.rs
|
|
||||||
def confirm_with_info(
|
|
||||||
*,
|
|
||||||
title: str,
|
|
||||||
button: str,
|
|
||||||
info_button: str,
|
|
||||||
items: Iterable[tuple[int, str | bytes]],
|
|
||||||
) -> LayoutObj[UiResult]:
|
|
||||||
"""Confirm given items but with third button. Always single page
|
|
||||||
without scrolling."""
|
|
||||||
|
|
||||||
|
|
||||||
# rust/src/ui/model_tt/layout.rs
|
# rust/src/ui/model_tt/layout.rs
|
||||||
def confirm_more(
|
def confirm_more(
|
||||||
*,
|
*,
|
||||||
|
@ -163,6 +163,20 @@ def confirm_reset_device(recovery: bool) -> LayoutObj[UiResult]:
|
|||||||
"""Confirm TOS before creating wallet creation or wallet recovery."""
|
"""Confirm TOS before creating wallet creation or wallet recovery."""
|
||||||
|
|
||||||
|
|
||||||
|
# rust/src/ui/api/firmware_upy.rs
|
||||||
|
def confirm_with_info(
|
||||||
|
*,
|
||||||
|
title: str,
|
||||||
|
button: str,
|
||||||
|
info_button: str,
|
||||||
|
verb_cancel: str | None = None,
|
||||||
|
items: Iterable[tuple[int, str | bytes]],
|
||||||
|
) -> LayoutObj[UiResult]:
|
||||||
|
"""Confirm given items but with third button. Always single page
|
||||||
|
without scrolling. In mercury, the button is placed in
|
||||||
|
context menu."""
|
||||||
|
|
||||||
|
|
||||||
# rust/src/ui/api/firmware_upy.rs
|
# rust/src/ui/api/firmware_upy.rs
|
||||||
def continue_recovery_homepage(
|
def continue_recovery_homepage(
|
||||||
*,
|
*,
|
||||||
|
@ -394,7 +394,7 @@ async def should_show_payment_request_details(
|
|||||||
Raises ActionCancelled if the user cancels.
|
Raises ActionCancelled if the user cancels.
|
||||||
"""
|
"""
|
||||||
result = await interact(
|
result = await interact(
|
||||||
trezorui2.confirm_with_info(
|
trezorui_api.confirm_with_info(
|
||||||
title=TR.send__title_sending,
|
title=TR.send__title_sending,
|
||||||
items=[(ui.NORMAL, f"{amount} to\n{recipient_name}")]
|
items=[(ui.NORMAL, f"{amount} to\n{recipient_name}")]
|
||||||
+ [(ui.NORMAL, memo) for memo in memos],
|
+ [(ui.NORMAL, memo) for memo in memos],
|
||||||
@ -431,7 +431,7 @@ async def should_show_more(
|
|||||||
confirm = TR.buttons__confirm
|
confirm = TR.buttons__confirm
|
||||||
|
|
||||||
result = await interact(
|
result = await interact(
|
||||||
trezorui2.confirm_with_info(
|
trezorui_api.confirm_with_info(
|
||||||
title=title,
|
title=title,
|
||||||
items=para,
|
items=para,
|
||||||
button=confirm,
|
button=confirm,
|
||||||
|
@ -525,11 +525,11 @@ async def should_show_more(
|
|||||||
confirm = TR.buttons__confirm
|
confirm = TR.buttons__confirm
|
||||||
|
|
||||||
result = await interact(
|
result = await interact(
|
||||||
trezorui2.confirm_with_info(
|
trezorui_api.confirm_with_info(
|
||||||
title=title,
|
title=title,
|
||||||
items=para,
|
items=para,
|
||||||
button=confirm,
|
button=confirm,
|
||||||
verb_cancel=verb_cancel, # type: ignore [No parameter named "verb_cancel"]
|
verb_cancel=verb_cancel,
|
||||||
info_button=button_text, # unused on TR
|
info_button=button_text, # unused on TR
|
||||||
),
|
),
|
||||||
br_name,
|
br_name,
|
||||||
@ -735,7 +735,7 @@ async def confirm_value(
|
|||||||
send_button_request = True
|
send_button_request = True
|
||||||
while True:
|
while True:
|
||||||
result = await interact(
|
result = await interact(
|
||||||
trezorui2.confirm_with_info(
|
trezorui_api.confirm_with_info(
|
||||||
title=title,
|
title=title,
|
||||||
items=((ui.NORMAL, value),),
|
items=((ui.NORMAL, value),),
|
||||||
button=verb or TR.buttons__confirm,
|
button=verb or TR.buttons__confirm,
|
||||||
|
@ -451,7 +451,7 @@ async def should_show_payment_request_details(
|
|||||||
Raises ActionCancelled if the user cancels.
|
Raises ActionCancelled if the user cancels.
|
||||||
"""
|
"""
|
||||||
result = await interact(
|
result = await interact(
|
||||||
trezorui2.confirm_with_info(
|
trezorui_api.confirm_with_info(
|
||||||
title=TR.send__title_sending,
|
title=TR.send__title_sending,
|
||||||
items=[(ui.NORMAL, f"{amount} to\n{recipient_name}")]
|
items=[(ui.NORMAL, f"{amount} to\n{recipient_name}")]
|
||||||
+ [(ui.NORMAL, memo) for memo in memos],
|
+ [(ui.NORMAL, memo) for memo in memos],
|
||||||
@ -488,7 +488,7 @@ async def should_show_more(
|
|||||||
confirm = TR.buttons__confirm
|
confirm = TR.buttons__confirm
|
||||||
|
|
||||||
result = await interact(
|
result = await interact(
|
||||||
trezorui2.confirm_with_info(
|
trezorui_api.confirm_with_info(
|
||||||
title=title,
|
title=title,
|
||||||
items=para,
|
items=para,
|
||||||
button=confirm,
|
button=confirm,
|
||||||
|
Loading…
Reference in New Issue
Block a user