From 26fd7bcbe0c21e7a09344871c37257d7cdd2e2cf Mon Sep 17 00:00:00 2001 From: emmanuelm41 Date: Wed, 18 Sep 2024 10:26:21 -0300 Subject: [PATCH 1/3] feat: add new option for PageStyle --- ledger_device_sdk/src/ui/gadgets.rs | 21 ++++++++++++++++++++- 1 file changed, 20 insertions(+), 1 deletion(-) diff --git a/ledger_device_sdk/src/ui/gadgets.rs b/ledger_device_sdk/src/ui/gadgets.rs index 2492944b..8d13c049 100644 --- a/ledger_device_sdk/src/ui/gadgets.rs +++ b/ledger_device_sdk/src/ui/gadgets.rs @@ -368,7 +368,8 @@ pub enum PageStyle { PictureNormal, // Picture (should be 16x16) with two lines of text (page layout depends on device). PictureBold, // Icon on top with one line of text on the bottom. BoldNormal, // One line of bold text and one line of normal text. - Normal, // 2 lines of centered text. + Normal, // 2 lines of centered text. + BoldCenteredNormal, // 2 lines of centered text, where the first one is bold } #[derive(Copy, Clone, Default)] @@ -396,6 +397,21 @@ impl<'a> From<([&'a str; 2], bool)> for Page<'a> { } } +// new bold normal or new normal +impl<'a> From<([&'a str; 2], bool, bool)> for Page<'a> { + fn from((label, bold, centered): ([&'a str; 2], bool, bool)) -> Page<'a> { + if centered { + if bold { + Page::new(PageStyle::BoldCenteredNormal, [label[0], label[1]], None) + } else { + Page::new(PageStyle::Normal, [label[0], label[1]], None) + } + } else { + Page::new(PageStyle::BoldNormal, [label[0], label[1]], None) + } + } +} + // new picture bold impl<'a> From<(&'a str, &'a Glyph<'a>)> for Page<'a> { fn from((label, glyph): (&'a str, &'a Glyph<'a>)) -> Page<'a> { @@ -418,6 +434,9 @@ impl<'a> Page<'a> { PageStyle::Normal => { self.label.place(Location::Middle, Layout::Centered, false); } + PageStyle::BoldCenteredNormal => { + self.label.place(Location::Middle, Layout::Centered, true); + } PageStyle::PictureNormal => { let mut icon_x = 16; let mut icon_y = 8; From e16f6c2327b2e18e9dcaf3a78b8c5079e6c889c6 Mon Sep 17 00:00:00 2001 From: emmanuelm41 Date: Fri, 27 Sep 2024 11:18:29 -0300 Subject: [PATCH 2/3] feat: allow to choose light review or not --- ledger_device_sdk/src/nbgl/nbgl_review.rs | 39 +++++++++++++++++------ 1 file changed, 30 insertions(+), 9 deletions(-) diff --git a/ledger_device_sdk/src/nbgl/nbgl_review.rs b/ledger_device_sdk/src/nbgl/nbgl_review.rs index 31ccb66c..e49cbf9b 100644 --- a/ledger_device_sdk/src/nbgl/nbgl_review.rs +++ b/ledger_device_sdk/src/nbgl/nbgl_review.rs @@ -9,6 +9,7 @@ pub struct NbglReview<'a> { glyph: Option<&'a NbglGlyph<'a>>, tx_type: TransactionType, blind: bool, + light: bool, } impl SyncNBGL for NbglReview<'_> {} @@ -22,6 +23,7 @@ impl<'a> NbglReview<'a> { glyph: None, tx_type: TransactionType::Transaction, blind: false, + light: false, } } @@ -36,6 +38,13 @@ impl<'a> NbglReview<'a> { } } + pub fn light(self) -> NbglReview<'a> { + NbglReview { + light: true, + ..self + } + } + pub fn titles( self, title: &'a str, @@ -106,15 +115,27 @@ impl<'a> NbglReview<'a> { ); } false => { - nbgl_useCaseReview( - self.tx_type.to_c_type(false), - &tag_value_list as *const nbgl_contentTagValueList_t, - &icon as *const nbgl_icon_details_t, - self.title.as_ptr() as *const c_char, - self.subtitle.as_ptr() as *const c_char, - self.finish_title.as_ptr() as *const c_char, - Some(choice_callback), - ); + if self.light { + nbgl_useCaseReviewLight( + self.tx_type.to_c_type(false), + &tag_value_list as *const nbgl_contentTagValueList_t, + &icon as *const nbgl_icon_details_t, + self.title.as_ptr() as *const c_char, + self.subtitle.as_ptr() as *const c_char, + self.finish_title.as_ptr() as *const c_char, + Some(choice_callback), + ); + } else { + nbgl_useCaseReview( + self.tx_type.to_c_type(false), + &tag_value_list as *const nbgl_contentTagValueList_t, + &icon as *const nbgl_icon_details_t, + self.title.as_ptr() as *const c_char, + self.subtitle.as_ptr() as *const c_char, + self.finish_title.as_ptr() as *const c_char, + Some(choice_callback), + ); + } } } let sync_ret = self.ux_sync_wait(false); From 4148e2c35b74e546248531ddb713d2410fd7c46e Mon Sep 17 00:00:00 2001 From: emmanuelm41 Date: Fri, 27 Sep 2024 12:31:10 -0300 Subject: [PATCH 3/3] fix: format --- ledger_device_sdk/src/ui/gadgets.rs | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/ledger_device_sdk/src/ui/gadgets.rs b/ledger_device_sdk/src/ui/gadgets.rs index 8d13c049..041f54d7 100644 --- a/ledger_device_sdk/src/ui/gadgets.rs +++ b/ledger_device_sdk/src/ui/gadgets.rs @@ -366,10 +366,10 @@ impl<'a> Menu<'a> { pub enum PageStyle { #[default] PictureNormal, // Picture (should be 16x16) with two lines of text (page layout depends on device). - PictureBold, // Icon on top with one line of text on the bottom. - BoldNormal, // One line of bold text and one line of normal text. - Normal, // 2 lines of centered text. - BoldCenteredNormal, // 2 lines of centered text, where the first one is bold + PictureBold, // Icon on top with one line of text on the bottom. + BoldNormal, // One line of bold text and one line of normal text. + Normal, // 2 lines of centered text. + BoldCenteredNormal, // 2 lines of centered text, where the first one is bold } #[derive(Copy, Clone, Default)]