Skip to content

Commit

Permalink
Merge pull request #185 from LedgerHQ/y333/fix_sititch_toggle
Browse files Browse the repository at this point in the history
Fix UX switch toggle issue
  • Loading branch information
yogh333 authored Sep 9, 2024
2 parents ff6bdd9 + d82516e commit 7586350
Show file tree
Hide file tree
Showing 3 changed files with 21 additions and 7 deletions.
2 changes: 1 addition & 1 deletion Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion ledger_device_sdk/Cargo.toml
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
[package]
name = "ledger_device_sdk"
version = "1.15.2"
version = "1.15.3"
authors = ["yhql", "yogh333", "agrojean-ledger", "kingofpayne"]
edition = "2021"
license.workspace = true
Expand Down
24 changes: 19 additions & 5 deletions ledger_device_sdk/src/nbgl.rs
Original file line number Diff line number Diff line change
Expand Up @@ -190,12 +190,22 @@ unsafe extern "C" fn settings_callback(token: c_int, _index: u8, _page: c_int) {
panic!("Invalid token.");
}

let setting_idx: usize = idx as usize;

match SWITCH_ARRAY[setting_idx].initState {
OFF_STATE => SWITCH_ARRAY[setting_idx].initState = ON_STATE,
ON_STATE => SWITCH_ARRAY[setting_idx].initState = OFF_STATE,
_ => panic!("Invalid state."),
}

if let Some(data) = NVM_REF.as_mut() {
let setting_idx: usize = idx as usize;
let mut switch_values: [u8; SETTINGS_SIZE] = data.get_ref().clone();
switch_values[setting_idx] = !switch_values[setting_idx];
if switch_values[setting_idx] == OFF_STATE {
switch_values[setting_idx] = ON_STATE;
} else {
switch_values[setting_idx] = OFF_STATE;
}
data.update(&switch_values);
SWITCH_ARRAY[setting_idx].initState = switch_values[setting_idx] as nbgl_state_t;
}
}

Expand Down Expand Up @@ -310,8 +320,12 @@ impl<'a> NbglHomeAndSettings<'a> {
for (i, setting) in self.setting_contents.iter().enumerate() {
SWITCH_ARRAY[i].text = setting[0].as_ptr();
SWITCH_ARRAY[i].subText = setting[1].as_ptr();
SWITCH_ARRAY[i].initState =
NVM_REF.as_mut().unwrap().get_ref()[i] as nbgl_state_t;
let state = if let Some(data) = NVM_REF.as_mut() {
data.get_ref()[i]
} else {
OFF_STATE
};
SWITCH_ARRAY[i].initState = state;
SWITCH_ARRAY[i].token = (FIRST_USER_TOKEN + i as u32) as u8;
SWITCH_ARRAY[i].tuneId = TuneIndex::TapCasual as u8;
}
Expand Down

0 comments on commit 7586350

Please sign in to comment.